| 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; | 
 | 51 | }; | 
 | 52 |  | 
 | 53 | struct input_polled_dev *input_allocate_polled_device(void); | 
 | 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 |