psmouse.h 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. #ifndef _PSMOUSE_H
  2. #define _PSMOUSE_H
  3. #define PSMOUSE_CMD_SETSCALE11 0x00e6
  4. #define PSMOUSE_CMD_SETSCALE21 0x00e7
  5. #define PSMOUSE_CMD_SETRES 0x10e8
  6. #define PSMOUSE_CMD_GETINFO 0x03e9
  7. #define PSMOUSE_CMD_SETSTREAM 0x00ea
  8. #define PSMOUSE_CMD_SETPOLL 0x00f0
  9. #define PSMOUSE_CMD_POLL 0x00eb /* caller sets number of bytes to receive */
  10. #define PSMOUSE_CMD_RESET_WRAP 0x00ec
  11. #define PSMOUSE_CMD_GETID 0x02f2
  12. #define PSMOUSE_CMD_SETRATE 0x10f3
  13. #define PSMOUSE_CMD_ENABLE 0x00f4
  14. #define PSMOUSE_CMD_DISABLE 0x00f5
  15. #define PSMOUSE_CMD_RESET_DIS 0x00f6
  16. #define PSMOUSE_CMD_RESET_BAT 0x02ff
  17. #define PSMOUSE_RET_BAT 0xaa
  18. #define PSMOUSE_RET_ID 0x00
  19. #define PSMOUSE_RET_ACK 0xfa
  20. #define PSMOUSE_RET_NAK 0xfe
  21. enum psmouse_state {
  22. PSMOUSE_IGNORE,
  23. PSMOUSE_INITIALIZING,
  24. PSMOUSE_RESYNCING,
  25. PSMOUSE_CMD_MODE,
  26. PSMOUSE_ACTIVATED,
  27. };
  28. /* psmouse protocol handler return codes */
  29. typedef enum {
  30. PSMOUSE_BAD_DATA,
  31. PSMOUSE_GOOD_DATA,
  32. PSMOUSE_FULL_PACKET
  33. } psmouse_ret_t;
  34. enum psmouse_scale {
  35. PSMOUSE_SCALE11,
  36. PSMOUSE_SCALE21
  37. };
  38. struct psmouse {
  39. void *private;
  40. struct input_dev *dev;
  41. struct ps2dev ps2dev;
  42. struct delayed_work resync_work;
  43. char *vendor;
  44. char *name;
  45. unsigned char packet[8];
  46. unsigned char badbyte;
  47. unsigned char pktcnt;
  48. unsigned char pktsize;
  49. unsigned char type;
  50. bool ignore_parity;
  51. bool acks_disable_command;
  52. unsigned int model;
  53. unsigned long last;
  54. unsigned long out_of_sync_cnt;
  55. unsigned long num_resyncs;
  56. enum psmouse_state state;
  57. char devname[64];
  58. char phys[32];
  59. unsigned int rate;
  60. unsigned int resolution;
  61. unsigned int resetafter;
  62. unsigned int resync_time;
  63. bool smartscroll; /* Logitech only */
  64. psmouse_ret_t (*protocol_handler)(struct psmouse *psmouse);
  65. void (*set_rate)(struct psmouse *psmouse, unsigned int rate);
  66. void (*set_resolution)(struct psmouse *psmouse, unsigned int resolution);
  67. void (*set_scale)(struct psmouse *psmouse, enum psmouse_scale scale);
  68. int (*reconnect)(struct psmouse *psmouse);
  69. void (*disconnect)(struct psmouse *psmouse);
  70. void (*cleanup)(struct psmouse *psmouse);
  71. int (*poll)(struct psmouse *psmouse);
  72. void (*pt_activate)(struct psmouse *psmouse);
  73. void (*pt_deactivate)(struct psmouse *psmouse);
  74. };
  75. enum psmouse_type {
  76. PSMOUSE_NONE,
  77. PSMOUSE_PS2,
  78. PSMOUSE_PS2PP,
  79. PSMOUSE_THINKPS,
  80. PSMOUSE_GENPS,
  81. PSMOUSE_IMPS,
  82. PSMOUSE_IMEX,
  83. PSMOUSE_SYNAPTICS,
  84. PSMOUSE_ALPS,
  85. PSMOUSE_LIFEBOOK,
  86. PSMOUSE_TRACKPOINT,
  87. PSMOUSE_TOUCHKIT_PS2,
  88. PSMOUSE_CORTRON,
  89. PSMOUSE_HGPK,
  90. PSMOUSE_ELANTECH,
  91. PSMOUSE_FSP,
  92. PSMOUSE_SYNAPTICS_RELATIVE,
  93. PSMOUSE_CYPRESS,
  94. PSMOUSE_FOCALTECH,
  95. PSMOUSE_VMMOUSE,
  96. PSMOUSE_BYD,
  97. PSMOUSE_AUTO /* This one should always be last */
  98. };
  99. void psmouse_queue_work(struct psmouse *psmouse, struct delayed_work *work,
  100. unsigned long delay);
  101. int psmouse_sliced_command(struct psmouse *psmouse, unsigned char command);
  102. int psmouse_reset(struct psmouse *psmouse);
  103. void psmouse_set_state(struct psmouse *psmouse, enum psmouse_state new_state);
  104. void psmouse_set_resolution(struct psmouse *psmouse, unsigned int resolution);
  105. psmouse_ret_t psmouse_process_byte(struct psmouse *psmouse);
  106. int psmouse_activate(struct psmouse *psmouse);
  107. int psmouse_deactivate(struct psmouse *psmouse);
  108. bool psmouse_matches_pnp_id(struct psmouse *psmouse, const char * const ids[]);
  109. struct psmouse_attribute {
  110. struct device_attribute dattr;
  111. void *data;
  112. ssize_t (*show)(struct psmouse *psmouse, void *data, char *buf);
  113. ssize_t (*set)(struct psmouse *psmouse, void *data,
  114. const char *buf, size_t count);
  115. bool protect;
  116. };
  117. #define to_psmouse_attr(a) container_of((a), struct psmouse_attribute, dattr)
  118. ssize_t psmouse_attr_show_helper(struct device *dev, struct device_attribute *attr,
  119. char *buf);
  120. ssize_t psmouse_attr_set_helper(struct device *dev, struct device_attribute *attr,
  121. const char *buf, size_t count);
  122. #define __PSMOUSE_DEFINE_ATTR_VAR(_name, _mode, _data, _show, _set, _protect) \
  123. static struct psmouse_attribute psmouse_attr_##_name = { \
  124. .dattr = { \
  125. .attr = { \
  126. .name = __stringify(_name), \
  127. .mode = _mode, \
  128. }, \
  129. .show = psmouse_attr_show_helper, \
  130. .store = psmouse_attr_set_helper, \
  131. }, \
  132. .data = _data, \
  133. .show = _show, \
  134. .set = _set, \
  135. .protect = _protect, \
  136. }
  137. #define __PSMOUSE_DEFINE_ATTR(_name, _mode, _data, _show, _set, _protect) \
  138. static ssize_t _show(struct psmouse *, void *, char *); \
  139. static ssize_t _set(struct psmouse *, void *, const char *, size_t); \
  140. __PSMOUSE_DEFINE_ATTR_VAR(_name, _mode, _data, _show, _set, _protect)
  141. #define PSMOUSE_DEFINE_ATTR(_name, _mode, _data, _show, _set) \
  142. __PSMOUSE_DEFINE_ATTR(_name, _mode, _data, _show, _set, true)
  143. #define PSMOUSE_DEFINE_RO_ATTR(_name, _mode, _data, _show) \
  144. static ssize_t _show(struct psmouse *, void *, char *); \
  145. __PSMOUSE_DEFINE_ATTR_VAR(_name, _mode, _data, _show, NULL, true)
  146. #define PSMOUSE_DEFINE_WO_ATTR(_name, _mode, _data, _set) \
  147. static ssize_t _set(struct psmouse *, void *, const char *, size_t); \
  148. __PSMOUSE_DEFINE_ATTR_VAR(_name, _mode, _data, NULL, _set, true)
  149. #ifndef psmouse_fmt
  150. #define psmouse_fmt(fmt) KBUILD_BASENAME ": " fmt
  151. #endif
  152. #define psmouse_dbg(psmouse, format, ...) \
  153. dev_dbg(&(psmouse)->ps2dev.serio->dev, \
  154. psmouse_fmt(format), ##__VA_ARGS__)
  155. #define psmouse_info(psmouse, format, ...) \
  156. dev_info(&(psmouse)->ps2dev.serio->dev, \
  157. psmouse_fmt(format), ##__VA_ARGS__)
  158. #define psmouse_warn(psmouse, format, ...) \
  159. dev_warn(&(psmouse)->ps2dev.serio->dev, \
  160. psmouse_fmt(format), ##__VA_ARGS__)
  161. #define psmouse_err(psmouse, format, ...) \
  162. dev_err(&(psmouse)->ps2dev.serio->dev, \
  163. psmouse_fmt(format), ##__VA_ARGS__)
  164. #define psmouse_notice(psmouse, format, ...) \
  165. dev_notice(&(psmouse)->ps2dev.serio->dev, \
  166. psmouse_fmt(format), ##__VA_ARGS__)
  167. #define psmouse_printk(level, psmouse, format, ...) \
  168. dev_printk(level, \
  169. &(psmouse)->ps2dev.serio->dev, \
  170. psmouse_fmt(format), ##__VA_ARGS__)
  171. #endif /* _PSMOUSE_H */