blob: ed40415f0067bc189af4f50f2c880df1f1bfeec7 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef _PSMOUSE_H
2#define _PSMOUSE_H
3
4#define PSMOUSE_CMD_SETSCALE11 0x00e6
5#define PSMOUSE_CMD_SETSCALE21 0x00e7
6#define PSMOUSE_CMD_SETRES 0x10e8
7#define PSMOUSE_CMD_GETINFO 0x03e9
8#define PSMOUSE_CMD_SETSTREAM 0x00ea
9#define PSMOUSE_CMD_SETPOLL 0x00f0
Dmitry Torokhovf0d5c6f42006-01-14 00:27:37 -050010#define PSMOUSE_CMD_POLL 0x00eb /* caller sets number of bytes to receive */
Linus Torvalds1da177e2005-04-16 15:20:36 -070011#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
18#define PSMOUSE_RET_BAT 0xaa
19#define PSMOUSE_RET_ID 0x00
20#define PSMOUSE_RET_ACK 0xfa
21#define PSMOUSE_RET_NAK 0xfe
22
23enum psmouse_state {
24 PSMOUSE_IGNORE,
25 PSMOUSE_INITIALIZING,
Dmitry Torokhovf0d5c6f42006-01-14 00:27:37 -050026 PSMOUSE_RESYNCING,
Linus Torvalds1da177e2005-04-16 15:20:36 -070027 PSMOUSE_CMD_MODE,
28 PSMOUSE_ACTIVATED,
29};
30
31/* psmouse protocol handler return codes */
32typedef enum {
33 PSMOUSE_BAD_DATA,
34 PSMOUSE_GOOD_DATA,
35 PSMOUSE_FULL_PACKET
36} psmouse_ret_t;
37
38struct psmouse {
39 void *private;
Dmitry Torokhov2e5b6362005-09-15 02:01:44 -050040 struct input_dev *dev;
Linus Torvalds1da177e2005-04-16 15:20:36 -070041 struct ps2dev ps2dev;
Dmitry Torokhovf0d5c6f42006-01-14 00:27:37 -050042 struct work_struct resync_work;
Linus Torvalds1da177e2005-04-16 15:20:36 -070043 char *vendor;
44 char *name;
45 unsigned char packet[8];
Dmitry Torokhovf0d5c6f42006-01-14 00:27:37 -050046 unsigned char badbyte;
Linus Torvalds1da177e2005-04-16 15:20:36 -070047 unsigned char pktcnt;
48 unsigned char pktsize;
49 unsigned char type;
Dmitry Torokhovf0d5c6f42006-01-14 00:27:37 -050050 unsigned char acks_disable_command;
Linus Torvalds1da177e2005-04-16 15:20:36 -070051 unsigned int model;
52 unsigned long last;
53 unsigned long out_of_sync;
Dmitry Torokhovf0d5c6f42006-01-14 00:27:37 -050054 unsigned long num_resyncs;
Linus Torvalds1da177e2005-04-16 15:20:36 -070055 enum psmouse_state state;
56 char devname[64];
57 char phys[32];
58
59 unsigned int rate;
60 unsigned int resolution;
61 unsigned int resetafter;
Dmitry Torokhovf0d5c6f42006-01-14 00:27:37 -050062 unsigned int resync_time;
Linus Torvalds1da177e2005-04-16 15:20:36 -070063 unsigned int smartscroll; /* Logitech only */
64
David Howells7d12e782006-10-05 14:55:46 +010065 psmouse_ret_t (*protocol_handler)(struct psmouse *psmouse);
Linus Torvalds1da177e2005-04-16 15:20:36 -070066 void (*set_rate)(struct psmouse *psmouse, unsigned int rate);
67 void (*set_resolution)(struct psmouse *psmouse, unsigned int resolution);
68
69 int (*reconnect)(struct psmouse *psmouse);
70 void (*disconnect)(struct psmouse *psmouse);
Dmitry Torokhova1cec062007-02-18 01:40:24 -050071 void (*cleanup)(struct psmouse *psmouse);
Dmitry Torokhovf0d5c6f42006-01-14 00:27:37 -050072 int (*poll)(struct psmouse *psmouse);
Linus Torvalds1da177e2005-04-16 15:20:36 -070073
74 void (*pt_activate)(struct psmouse *psmouse);
75 void (*pt_deactivate)(struct psmouse *psmouse);
76};
77
78enum psmouse_type {
79 PSMOUSE_NONE,
80 PSMOUSE_PS2,
81 PSMOUSE_PS2PP,
82 PSMOUSE_THINKPS,
83 PSMOUSE_GENPS,
84 PSMOUSE_IMPS,
85 PSMOUSE_IMEX,
86 PSMOUSE_SYNAPTICS,
87 PSMOUSE_ALPS,
Kenan Esau02d7f582005-05-29 02:30:22 -050088 PSMOUSE_LIFEBOOK,
Stephen Evanchik541e3162005-08-08 01:26:18 -050089 PSMOUSE_TRACKPOINT,
Stefan Lucke24bf10a2007-02-18 01:49:10 -050090 PSMOUSE_TOUCHKIT_PS2,
Aristeu Rozanskiaea6a462007-05-10 01:47:18 -040091 PSMOUSE_CORTRON,
Dmitry Torokhovdbf4ccd2005-06-01 02:40:01 -050092 PSMOUSE_AUTO /* This one should always be last */
Linus Torvalds1da177e2005-04-16 15:20:36 -070093};
94
95int psmouse_sliced_command(struct psmouse *psmouse, unsigned char command);
96int psmouse_reset(struct psmouse *psmouse);
Andres Salomona48cf5f2008-09-16 12:30:33 -040097void psmouse_set_state(struct psmouse *psmouse, enum psmouse_state new_state);
Linus Torvalds1da177e2005-04-16 15:20:36 -070098void psmouse_set_resolution(struct psmouse *psmouse, unsigned int resolution);
99
Linus Torvalds1da177e2005-04-16 15:20:36 -0700100
Dmitry Torokhovcfe9e882005-09-04 01:40:20 -0500101struct psmouse_attribute {
102 struct device_attribute dattr;
103 void *data;
104 ssize_t (*show)(struct psmouse *psmouse, void *data, char *buf);
105 ssize_t (*set)(struct psmouse *psmouse, void *data,
106 const char *buf, size_t count);
107};
108#define to_psmouse_attr(a) container_of((a), struct psmouse_attribute, dattr)
109
110ssize_t psmouse_attr_show_helper(struct device *dev, struct device_attribute *attr,
111 char *buf);
112ssize_t psmouse_attr_set_helper(struct device *dev, struct device_attribute *attr,
113 const char *buf, size_t count);
114
115#define PSMOUSE_DEFINE_ATTR(_name, _mode, _data, _show, _set) \
116static ssize_t _show(struct psmouse *, void *data, char *); \
117static ssize_t _set(struct psmouse *, void *data, const char *, size_t); \
118static struct psmouse_attribute psmouse_attr_##_name = { \
119 .dattr = { \
120 .attr = { \
121 .name = __stringify(_name), \
122 .mode = _mode, \
Dmitry Torokhovcfe9e882005-09-04 01:40:20 -0500123 }, \
124 .show = psmouse_attr_show_helper, \
125 .store = psmouse_attr_set_helper, \
126 }, \
127 .data = _data, \
128 .show = _show, \
129 .set = _set, \
130}
Linus Torvalds1da177e2005-04-16 15:20:36 -0700131
132#endif /* _PSMOUSE_H */