1 /*
2  * Definitions for ADB (Apple Desktop Bus) support.
3  */
4 #ifndef __ADB_H
5 #define __ADB_H
6 
7 /* ADB commands */
8 #define ADB_BUSRESET		0
9 #define ADB_FLUSH(id)		(0x01 | ((id) << 4))
10 #define ADB_WRITEREG(id, reg)	(0x08 | (reg) | ((id) << 4))
11 #define ADB_READREG(id, reg)	(0x0C | (reg) | ((id) << 4))
12 
13 /* ADB default device IDs (upper 4 bits of ADB command byte) */
14 #define ADB_DONGLE	1	/* "software execution control" devices */
15 #define ADB_KEYBOARD	2
16 #define ADB_MOUSE	3
17 #define ADB_TABLET	4
18 #define ADB_MODEM	5
19 #define ADB_MISC	7	/* maybe a monitor */
20 
21 #define ADB_RET_OK	0
22 #define ADB_RET_TIMEOUT	3
23 
24 /* The kind of ADB request. The controller may emulate some
25    or all of those CUDA/PMU packet kinds */
26 #define ADB_PACKET	0
27 #define CUDA_PACKET	1
28 #define ERROR_PACKET	2
29 #define TIMER_PACKET	3
30 #define POWER_PACKET	4
31 #define MACIIC_PACKET	5
32 #define PMU_PACKET	6
33 #define ADB_QUERY	7
34 
35 /* ADB queries */
36 
37 /* ADB_QUERY_GETDEVINFO
38  * Query ADB slot for device presence
39  * data[2] = id, rep[0] = orig addr, rep[1] = handler_id
40  */
41 #define ADB_QUERY_GETDEVINFO	1
42 
43 #ifdef __KERNEL__
44 
45 struct adb_request {
46 	unsigned char data[32];
47 	int nbytes;
48 	unsigned char reply[32];
49 	int reply_len;
50 	unsigned char reply_expected;
51 	unsigned char sent;
52 	unsigned char complete;
53 	void (*done)(struct adb_request *);
54 	void *arg;
55 	struct adb_request *next;
56 };
57 
58 struct adb_ids {
59 	int nids;
60 	unsigned char id[16];
61 };
62 
63 /* Structure which encapsulates a low-level ADB driver */
64 
65 struct adb_driver {
66 	char name[16];
67 	int (*probe)(void);
68 	int (*init)(void);
69 	int (*send_request)(struct adb_request *req, int sync);
70 	int (*autopoll)(int devs);
71 	void (*poll)(void);
72 	int (*reset_bus)(void);
73 };
74 
75 /* Values for adb_request flags */
76 #define ADBREQ_REPLY	1	/* expect reply */
77 #define ADBREQ_SYNC	2	/* poll until done */
78 #define ADBREQ_NOSEND	4	/* build the request, but don't send it */
79 
80 /* Messages sent thru the client_list notifier. You should NOT stop
81    the operation, at least not with this version */
82 enum adb_message {
83     ADB_MSG_POWERDOWN,	/* Currently called before sleep only */
84     ADB_MSG_PRE_RESET,	/* Called before resetting the bus */
85     ADB_MSG_POST_RESET	/* Called after resetting the bus (re-do init & register) */
86 };
87 extern struct blocking_notifier_head adb_client_list;
88 
89 int adb_request(struct adb_request *req, void (*done)(struct adb_request *),
90 		int flags, int nbytes, ...);
91 int adb_register(int default_id,int handler_id,struct adb_ids *ids,
92 		 void (*handler)(unsigned char *, int, int));
93 int adb_unregister(int index);
94 void adb_poll(void);
95 void adb_input(unsigned char *, int, int);
96 int adb_reset_bus(void);
97 
98 int adb_try_handler_change(int address, int new_id);
99 int adb_get_infos(int address, int *original_address, int *handler_id);
100 
101 #endif /* __KERNEL__ */
102 
103 #endif /* __ADB_H */
104