input-polldev.h 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. #ifndef _INPUT_POLLDEV_H
  2. #define _INPUT_POLLDEV_H
  3. /*
  4. * Copyright (c) 2007 Dmitry Torokhov
  5. *
  6. * This program is free software; you can redistribute it and/or modify it
  7. * under the terms of the GNU General Public License version 2 as published by
  8. * the Free Software Foundation.
  9. */
  10. #include <linux/input.h>
  11. #include <linux/workqueue.h>
  12. /**
  13. * struct input_polled_dev - simple polled input device
  14. * @private: private driver data
  15. * @flush: driver-supplied method that flushes device's state upon
  16. * opening (optional)
  17. * @poll: driver-supplied method that polls the device and posts
  18. * input events (mandatory).
  19. * @poll_interval: specifies how often the poll() method shoudl be called.
  20. * @input: input device structire associated with the polled device.
  21. * Must be properly initialized by the driver (id, name, phys, bits).
  22. *
  23. * Polled input device provides a skeleton for supporting simple input
  24. * devices that do not raise interrupts but have to be periodically
  25. * scanned or polled to detect changes in their state.
  26. */
  27. struct input_polled_dev {
  28. void *private;
  29. void (*flush)(struct input_polled_dev *dev);
  30. void (*poll)(struct input_polled_dev *dev);
  31. unsigned int poll_interval; /* msec */
  32. struct input_dev *input;
  33. struct delayed_work work;
  34. };
  35. struct input_polled_dev *input_allocate_polled_device(void);
  36. void input_free_polled_device(struct input_polled_dev *dev);
  37. int input_register_polled_device(struct input_polled_dev *dev);
  38. void input_unregister_polled_device(struct input_polled_dev *dev);
  39. #endif