| /* |
| * Definitions for ADB (Apple Desktop Bus) support. |
| */ |
| #ifndef __ADB_H |
| #define __ADB_H |
| |
| /* ADB commands */ |
| #define ADB_BUSRESET 0 |
| #define ADB_FLUSH(id) (0x01 | ((id) << 4)) |
| #define ADB_WRITEREG(id, reg) (0x08 | (reg) | ((id) << 4)) |
| #define ADB_READREG(id, reg) (0x0C | (reg) | ((id) << 4)) |
| |
| /* ADB default device IDs (upper 4 bits of ADB command byte) */ |
| #define ADB_DONGLE 1 /* "software execution control" devices */ |
| #define ADB_KEYBOARD 2 |
| #define ADB_MOUSE 3 |
| #define ADB_TABLET 4 |
| #define ADB_MODEM 5 |
| #define ADB_MISC 7 /* maybe a monitor */ |
| |
| #define ADB_RET_OK 0 |
| #define ADB_RET_TIMEOUT 3 |
| |
| /* The kind of ADB request. The controller may emulate some |
| or all of those CUDA/PMU packet kinds */ |
| #define ADB_PACKET 0 |
| #define CUDA_PACKET 1 |
| #define ERROR_PACKET 2 |
| #define TIMER_PACKET 3 |
| #define POWER_PACKET 4 |
| #define MACIIC_PACKET 5 |
| #define PMU_PACKET 6 |
| #define ADB_QUERY 7 |
| |
| /* ADB queries */ |
| |
| /* ADB_QUERY_GETDEVINFO |
| * Query ADB slot for device presence |
| * data[2] = id, rep[0] = orig addr, rep[1] = handler_id |
| */ |
| #define ADB_QUERY_GETDEVINFO 1 |
| |
| #ifdef __KERNEL__ |
| |
| struct adb_request { |
| unsigned char data[32]; |
| int nbytes; |
| unsigned char reply[32]; |
| int reply_len; |
| unsigned char reply_expected; |
| unsigned char sent; |
| unsigned char complete; |
| void (*done)(struct adb_request *); |
| void *arg; |
| struct adb_request *next; |
| }; |
| |
| struct adb_ids { |
| int nids; |
| unsigned char id[16]; |
| }; |
| |
| /* Structure which encapsulates a low-level ADB driver */ |
| |
| struct adb_driver { |
| char name[16]; |
| int (*probe)(void); |
| int (*init)(void); |
| int (*send_request)(struct adb_request *req, int sync); |
| int (*autopoll)(int devs); |
| void (*poll)(void); |
| int (*reset_bus)(void); |
| }; |
| |
| /* Values for adb_request flags */ |
| #define ADBREQ_REPLY 1 /* expect reply */ |
| #define ADBREQ_SYNC 2 /* poll until done */ |
| #define ADBREQ_NOSEND 4 /* build the request, but don't send it */ |
| |
| /* Messages sent thru the client_list notifier. You should NOT stop |
| the operation, at least not with this version */ |
| enum adb_message { |
| ADB_MSG_POWERDOWN, /* Currently called before sleep only */ |
| ADB_MSG_PRE_RESET, /* Called before resetting the bus */ |
| ADB_MSG_POST_RESET /* Called after resetting the bus (re-do init & register) */ |
| }; |
| extern struct adb_driver *adb_controller; |
| extern struct blocking_notifier_head adb_client_list; |
| |
| int adb_request(struct adb_request *req, void (*done)(struct adb_request *), |
| int flags, int nbytes, ...); |
| int adb_register(int default_id,int handler_id,struct adb_ids *ids, |
| void (*handler)(unsigned char *, int, struct pt_regs *, int)); |
| int adb_unregister(int index); |
| void adb_poll(void); |
| void adb_input(unsigned char *, int, struct pt_regs *, int); |
| int adb_reset_bus(void); |
| |
| int adb_try_handler_change(int address, int new_id); |
| int adb_get_infos(int address, int *original_address, int *handler_id); |
| |
| #endif /* __KERNEL__ */ |
| |
| #endif /* __ADB_H */ |