Dmitry Torokhov | 0dcd807 | 2007-04-29 23:42:45 -0400 | [diff] [blame] | 1 | #ifndef _INPUT_POLLDEV_H |
| 2 | #define _INPUT_POLLDEV_H |
| 3 | |
| 4 | /* |
| 5 | * Copyright (c) 2007 Dmitry Torokhov |
| 6 | * |
| 7 | * This program is free software; you can redistribute it and/or modify it |
| 8 | * under the terms of the GNU General Public License version 2 as published by |
| 9 | * the Free Software Foundation. |
| 10 | */ |
| 11 | |
| 12 | #include <linux/input.h> |
| 13 | #include <linux/workqueue.h> |
| 14 | |
| 15 | /** |
| 16 | * struct input_polled_dev - simple polled input device |
Samu Onkalo | b0aba1e | 2009-10-18 00:38:57 -0700 | [diff] [blame] | 17 | * @private: private driver data. |
| 18 | * @open: driver-supplied method that prepares device for polling |
| 19 | * (enabled the device and maybe flushes device state). |
| 20 | * @close: driver-supplied method that is called when device is no |
| 21 | * longer being polled. Used to put device into low power mode. |
Dmitry Torokhov | 0dcd807 | 2007-04-29 23:42:45 -0400 | [diff] [blame] | 22 | * @poll: driver-supplied method that polls the device and posts |
| 23 | * input events (mandatory). |
Samu Onkalo | dad725d | 2009-11-13 21:13:22 -0800 | [diff] [blame] | 24 | * @poll_interval: specifies how often the poll() method should be called. |
Dmitry Torokhov | 2546bcc | 2011-01-31 21:06:34 -0800 | [diff] [blame] | 25 | * Defaults to 500 msec unless overridden when registering the device. |
Samu Onkalo | dad725d | 2009-11-13 21:13:22 -0800 | [diff] [blame] | 26 | * @poll_interval_max: specifies upper bound for the poll interval. |
| 27 | * Defaults to the initial value of @poll_interval. |
| 28 | * @poll_interval_min: specifies lower bound for the poll interval. |
| 29 | * Defaults to 0. |
Dmitry Torokhov | 2546bcc | 2011-01-31 21:06:34 -0800 | [diff] [blame] | 30 | * @input: input device structure associated with the polled device. |
Dmitry Torokhov | 0dcd807 | 2007-04-29 23:42:45 -0400 | [diff] [blame] | 31 | * Must be properly initialized by the driver (id, name, phys, bits). |
| 32 | * |
| 33 | * Polled input device provides a skeleton for supporting simple input |
| 34 | * devices that do not raise interrupts but have to be periodically |
| 35 | * scanned or polled to detect changes in their state. |
| 36 | */ |
| 37 | struct input_polled_dev { |
| 38 | void *private; |
| 39 | |
Samu Onkalo | b0aba1e | 2009-10-18 00:38:57 -0700 | [diff] [blame] | 40 | void (*open)(struct input_polled_dev *dev); |
| 41 | void (*close)(struct input_polled_dev *dev); |
Dmitry Torokhov | 0dcd807 | 2007-04-29 23:42:45 -0400 | [diff] [blame] | 42 | void (*poll)(struct input_polled_dev *dev); |
| 43 | unsigned int poll_interval; /* msec */ |
Samu Onkalo | dad725d | 2009-11-13 21:13:22 -0800 | [diff] [blame] | 44 | unsigned int poll_interval_max; /* msec */ |
| 45 | unsigned int poll_interval_min; /* msec */ |
Dmitry Torokhov | 0dcd807 | 2007-04-29 23:42:45 -0400 | [diff] [blame] | 46 | |
| 47 | struct input_dev *input; |
Samu Onkalo | dad725d | 2009-11-13 21:13:22 -0800 | [diff] [blame] | 48 | |
| 49 | /* private: */ |
Dmitry Torokhov | 0dcd807 | 2007-04-29 23:42:45 -0400 | [diff] [blame] | 50 | struct delayed_work work; |
Dmitry Torokhov | bf1de97 | 2014-04-28 10:49:51 -0700 | [diff] [blame^] | 51 | |
| 52 | bool devres_managed; |
Dmitry Torokhov | 0dcd807 | 2007-04-29 23:42:45 -0400 | [diff] [blame] | 53 | }; |
| 54 | |
| 55 | struct input_polled_dev *input_allocate_polled_device(void); |
Dmitry Torokhov | bf1de97 | 2014-04-28 10:49:51 -0700 | [diff] [blame^] | 56 | struct input_polled_dev *devm_input_allocate_polled_device(struct device *dev); |
Dmitry Torokhov | 0dcd807 | 2007-04-29 23:42:45 -0400 | [diff] [blame] | 57 | void input_free_polled_device(struct input_polled_dev *dev); |
| 58 | int input_register_polled_device(struct input_polled_dev *dev); |
| 59 | void input_unregister_polled_device(struct input_polled_dev *dev); |
| 60 | |
| 61 | #endif |