diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-08-02 14:52:39 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-08-02 14:52:39 -0400 |
commit | fc6bdb59a501740b28ed3b616641a22c8dc5dd31 (patch) | |
tree | 00ddba349c7e96b03af0913da1a74eae8a94a2db /include | |
parent | 44d82e2963551eafa378a3fc7a923df7853af4e2 (diff) | |
parent | 1fcfd08bd0704e1888bd73153e8d2ca3640e22f2 (diff) |
Merge branch 'for-linus-3.6' of git://dev.laptop.org/users/dilinger/linux-olpc
Pull OLPC platform updates from Andres Salomon:
"These move the OLPC Embedded Controller driver out of
arch/x86/platform and into drivers/platform/olpc.
OLPC machines are now ARM-based (which means lots of x86 and ARM
changes), but are typically pretty self-contained.. so it makes more
sense to go through a separate OLPC tree after getting the appropriate
review/ACKs."
* 'for-linus-3.6' of git://dev.laptop.org/users/dilinger/linux-olpc:
x86: OLPC: move s/r-related EC cmds to EC driver
Platform: OLPC: move global variables into priv struct
Platform: OLPC: move debugfs support from x86 EC driver
x86: OLPC: switch over to using new EC driver on x86
Platform: OLPC: add a suspended flag to the EC driver
Platform: OLPC: turn EC driver into a platform_driver
Platform: OLPC: allow EC cmd to be overridden, and create a workqueue to call it
drivers: OLPC: update various drivers to include olpc-ec.h
Platform: OLPC: add a stub to drivers/platform/ for the OLPC EC driver
Diffstat (limited to 'include')
-rw-r--r-- | include/linux/olpc-ec.h | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/include/linux/olpc-ec.h b/include/linux/olpc-ec.h new file mode 100644 index 000000000000..5bb6e760aa61 --- /dev/null +++ b/include/linux/olpc-ec.h | |||
@@ -0,0 +1,41 @@ | |||
1 | #ifndef _LINUX_OLPC_EC_H | ||
2 | #define _LINUX_OLPC_EC_H | ||
3 | |||
4 | /* XO-1 EC commands */ | ||
5 | #define EC_FIRMWARE_REV 0x08 | ||
6 | #define EC_WRITE_SCI_MASK 0x1b | ||
7 | #define EC_WAKE_UP_WLAN 0x24 | ||
8 | #define EC_WLAN_LEAVE_RESET 0x25 | ||
9 | #define EC_READ_EB_MODE 0x2a | ||
10 | #define EC_SET_SCI_INHIBIT 0x32 | ||
11 | #define EC_SET_SCI_INHIBIT_RELEASE 0x34 | ||
12 | #define EC_WLAN_ENTER_RESET 0x35 | ||
13 | #define EC_WRITE_EXT_SCI_MASK 0x38 | ||
14 | #define EC_SCI_QUERY 0x84 | ||
15 | #define EC_EXT_SCI_QUERY 0x85 | ||
16 | |||
17 | struct platform_device; | ||
18 | |||
19 | struct olpc_ec_driver { | ||
20 | int (*probe)(struct platform_device *); | ||
21 | int (*suspend)(struct platform_device *); | ||
22 | int (*resume)(struct platform_device *); | ||
23 | |||
24 | int (*ec_cmd)(u8, u8 *, size_t, u8 *, size_t, void *); | ||
25 | }; | ||
26 | |||
27 | #ifdef CONFIG_OLPC | ||
28 | |||
29 | extern void olpc_ec_driver_register(struct olpc_ec_driver *drv, void *arg); | ||
30 | |||
31 | extern int olpc_ec_cmd(u8 cmd, u8 *inbuf, size_t inlen, u8 *outbuf, | ||
32 | size_t outlen); | ||
33 | |||
34 | #else | ||
35 | |||
36 | static inline int olpc_ec_cmd(u8 cmd, u8 *inbuf, size_t inlen, u8 *outbuf, | ||
37 | size_t outlen) { return -ENODEV; } | ||
38 | |||
39 | #endif /* CONFIG_OLPC */ | ||
40 | |||
41 | #endif /* _LINUX_OLPC_EC_H */ | ||