psmouse.h 7.2 KB

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