blob: 4d9107fba6a10e8da641a3b5e5630924b66fe110 [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
65 psmouse_ret_t (*protocol_handler)(struct psmouse *psmouse, struct pt_regs *regs);
66 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 Torokhovf0d5c6f42006-01-14 00:27:37 -050071 int (*poll)(struct psmouse *psmouse);
Linus Torvalds1da177e2005-04-16 15:20:36 -070072
73 void (*pt_activate)(struct psmouse *psmouse);
74 void (*pt_deactivate)(struct psmouse *psmouse);
75};
76
77enum psmouse_type {
78 PSMOUSE_NONE,
79 PSMOUSE_PS2,
80 PSMOUSE_PS2PP,
81 PSMOUSE_THINKPS,
82 PSMOUSE_GENPS,
83 PSMOUSE_IMPS,
84 PSMOUSE_IMEX,
85 PSMOUSE_SYNAPTICS,
86 PSMOUSE_ALPS,
Kenan Esau02d7f582005-05-29 02:30:22 -050087 PSMOUSE_LIFEBOOK,
Stephen Evanchik541e3162005-08-08 01:26:18 -050088 PSMOUSE_TRACKPOINT,
Dmitry Torokhovdbf4ccd2005-06-01 02:40:01 -050089 PSMOUSE_AUTO /* This one should always be last */
Linus Torvalds1da177e2005-04-16 15:20:36 -070090};
91
92int psmouse_sliced_command(struct psmouse *psmouse, unsigned char command);
93int psmouse_reset(struct psmouse *psmouse);
94void psmouse_set_resolution(struct psmouse *psmouse, unsigned int resolution);
95
Linus Torvalds1da177e2005-04-16 15:20:36 -070096
Dmitry Torokhovcfe9e882005-09-04 01:40:20 -050097struct psmouse_attribute {
98 struct device_attribute dattr;
99 void *data;
100 ssize_t (*show)(struct psmouse *psmouse, void *data, char *buf);
101 ssize_t (*set)(struct psmouse *psmouse, void *data,
102 const char *buf, size_t count);
103};
104#define to_psmouse_attr(a) container_of((a), struct psmouse_attribute, dattr)
105
106ssize_t psmouse_attr_show_helper(struct device *dev, struct device_attribute *attr,
107 char *buf);
108ssize_t psmouse_attr_set_helper(struct device *dev, struct device_attribute *attr,
109 const char *buf, size_t count);
110
111#define PSMOUSE_DEFINE_ATTR(_name, _mode, _data, _show, _set) \
112static ssize_t _show(struct psmouse *, void *data, char *); \
113static ssize_t _set(struct psmouse *, void *data, const char *, size_t); \
114static struct psmouse_attribute psmouse_attr_##_name = { \
115 .dattr = { \
116 .attr = { \
117 .name = __stringify(_name), \
118 .mode = _mode, \
119 .owner = THIS_MODULE, \
120 }, \
121 .show = psmouse_attr_show_helper, \
122 .store = psmouse_attr_set_helper, \
123 }, \
124 .data = _data, \
125 .show = _show, \
126 .set = _set, \
127}
Linus Torvalds1da177e2005-04-16 15:20:36 -0700128
129#endif /* _PSMOUSE_H */