diff options
Diffstat (limited to 'arch/x86/include/asm/olpc.h')
| -rw-r--r-- | arch/x86/include/asm/olpc.h | 58 | 
1 files changed, 36 insertions, 22 deletions
diff --git a/arch/x86/include/asm/olpc.h b/arch/x86/include/asm/olpc.h index 42a978c0c1b..72f9adf6eca 100644 --- a/arch/x86/include/asm/olpc.h +++ b/arch/x86/include/asm/olpc.h @@ -13,6 +13,7 @@ struct olpc_platform_t {  #define OLPC_F_PRESENT		0x01  #define OLPC_F_DCON		0x02 +#define OLPC_F_EC_WIDE_SCI	0x04  #ifdef CONFIG_OLPC @@ -20,7 +21,7 @@ extern struct olpc_platform_t olpc_platform_info;  /*   * OLPC board IDs contain the major build number within the mask 0x0ff0, - * and the minor build number withing 0x000f.  Pre-builds have a minor + * and the minor build number within 0x000f.  Pre-builds have a minor   * number less than 8, and normal builds start at 8.  For example, 0x0B10   * is a PreB1, and 0x0C18 is a C1.   */ @@ -62,6 +63,13 @@ static inline int olpc_board_at_least(uint32_t rev)  	return olpc_platform_info.boardrev >= rev;  } +extern void olpc_ec_wakeup_set(u16 value); +extern void olpc_ec_wakeup_clear(u16 value); +extern bool olpc_ec_wakeup_available(void); + +extern int olpc_ec_mask_write(u16 bits); +extern int olpc_ec_sci_query(u16 *sci_value); +  #else  static inline int machine_is_olpc(void) @@ -74,23 +82,23 @@ static inline int olpc_has_dcon(void)  	return 0;  } -#endif - -extern int pci_olpc_init(void); - -/* EC related functions */ +static inline void olpc_ec_wakeup_set(u16 value) { } +static inline void olpc_ec_wakeup_clear(u16 value) { } -extern int olpc_ec_cmd(unsigned char cmd, unsigned char *inbuf, size_t inlen, -		unsigned char *outbuf, size_t outlen); +static inline bool olpc_ec_wakeup_available(void) +{ +	return false; +} -extern int olpc_ec_mask_set(uint8_t bits); -extern int olpc_ec_mask_unset(uint8_t bits); +#endif -/* EC commands */ +#ifdef CONFIG_OLPC_XO1_PM +extern void do_olpc_suspend_lowlevel(void); +extern void olpc_xo1_pm_wakeup_set(u16 value); +extern void olpc_xo1_pm_wakeup_clear(u16 value); +#endif -#define EC_FIRMWARE_REV		0x08 -#define EC_WLAN_ENTER_RESET	0x35 -#define EC_WLAN_LEAVE_RESET	0x25 +extern int pci_olpc_init(void);  /* SCI source values */ @@ -99,20 +107,26 @@ extern int olpc_ec_mask_unset(uint8_t bits);  #define EC_SCI_SRC_BATTERY	0x02  #define EC_SCI_SRC_BATSOC	0x04  #define EC_SCI_SRC_BATERR	0x08 -#define EC_SCI_SRC_EBOOK	0x10 -#define EC_SCI_SRC_WLAN		0x20 +#define EC_SCI_SRC_EBOOK	0x10	/* XO-1 only */ +#define EC_SCI_SRC_WLAN		0x20	/* XO-1 only */  #define EC_SCI_SRC_ACPWR	0x40 -#define EC_SCI_SRC_ALL		0x7F +#define EC_SCI_SRC_BATCRIT	0x80 +#define EC_SCI_SRC_GPWAKE	0x100	/* XO-1.5 only */ +#define EC_SCI_SRC_ALL		0x1FF  /* GPIO assignments */  #define OLPC_GPIO_MIC_AC	1 -#define OLPC_GPIO_DCON_IRQ	geode_gpio(7) +#define OLPC_GPIO_DCON_STAT0	5 +#define OLPC_GPIO_DCON_STAT1	6 +#define OLPC_GPIO_DCON_IRQ	7  #define OLPC_GPIO_THRM_ALRM	geode_gpio(10) -#define OLPC_GPIO_SMB_CLK	geode_gpio(14) -#define OLPC_GPIO_SMB_DATA	geode_gpio(15) +#define OLPC_GPIO_DCON_LOAD    11 +#define OLPC_GPIO_DCON_BLANK   12 +#define OLPC_GPIO_SMB_CLK      14 +#define OLPC_GPIO_SMB_DATA     15  #define OLPC_GPIO_WORKAUX	geode_gpio(24) -#define OLPC_GPIO_LID		geode_gpio(26) -#define OLPC_GPIO_ECSCI		geode_gpio(27) +#define OLPC_GPIO_LID		26 +#define OLPC_GPIO_ECSCI		27  #endif /* _ASM_X86_OLPC_H */  | 
