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