diff options
Diffstat (limited to 'include')
| -rw-r--r-- | include/configs/TQM860L.h | 1 | ||||
| -rw-r--r-- | include/configs/atc.h | 49 | ||||
| -rw-r--r-- | include/pci_ids.h | 1 | ||||
| -rw-r--r-- | include/pcmcia.h | 2 | ||||
| -rw-r--r-- | include/pcmcia/i82365.h | 154 | ||||
| -rw-r--r-- | include/pcmcia/ss.h | 133 | ||||
| -rw-r--r-- | include/pcmcia/ti113x.h | 234 | ||||
| -rw-r--r-- | include/pcmcia/yenta.h | 156 | 
8 files changed, 729 insertions, 1 deletions
| diff --git a/include/configs/TQM860L.h b/include/configs/TQM860L.h index 0d0b8c316..a9d1afffc 100644 --- a/include/configs/TQM860L.h +++ b/include/configs/TQM860L.h @@ -92,6 +92,7 @@  #define CONFIG_COMMANDS	      ( CONFIG_CMD_DFL	| \  				CFG_CMD_ASKENV	| \  				CFG_CMD_DHCP	| \ +				CFG_CMD_ELF	| \  				CFG_CMD_IDE	| \  				CFG_CMD_DATE	) diff --git a/include/configs/atc.h b/include/configs/atc.h index 0651ede32..4f308471a 100644 --- a/include/configs/atc.h +++ b/include/configs/atc.h @@ -125,7 +125,12 @@  #define CONFIG_BOOTP_MASK	(CONFIG_BOOTP_DEFAULT|CONFIG_BOOTP_BOOTFILESIZE) -#define CONFIG_COMMANDS		(CONFIG_CMD_DFL | CFG_CMD_EEPROM) +#define CONFIG_COMMANDS		(CONFIG_CMD_DFL | \ +				 CFG_CMD_EEPROM | \ +				 CFG_CMD_PCI | \ +				 CFG_CMD_PCMCIA | \ +				 CFG_CMD_IDE) +#define CONFIG_DOS_PARTITION  /* this must be included AFTER the definition of CONFIG_COMMANDS (if any) */  #include <cmd_confdefs.h> @@ -149,6 +154,8 @@  #define	CFG_LOAD_ADDR	0x100000	/* default load address	*/ +#define CFG_PIO_MODE		0	/* IDE interface in PIO Mode 0	*/ +  #define	CFG_HZ		1000		/* decrementer freq: 1 ms ticks	*/  #define CFG_BAUDRATE_TABLE	{ 9600, 19200, 38400, 57600, 115200 } @@ -239,6 +246,9 @@  # define CFG_RAMBOOT  #endif +#define	CONFIG_PCI +#define	CONFIG_PCI_PNP +  #if 1  /* environment is in Flash */  #define CFG_ENV_IS_IN_FLASH	1 @@ -441,4 +451,41 @@  #define CFG_PSDMR	 CFG_PSDMR_8COL  #endif /* CFG_RAMBOOT */ +/*----------------------------------------------------------------------- + * PCMCIA stuff + *----------------------------------------------------------------------- + * + */ +#define CONFIG_I82365 + +#define CFG_PCMCIA_MEM_ADDR	0x81000000 +#define CFG_PCMCIA_MEM_SIZE	0x1000 + +/*----------------------------------------------------------------------- + * IDE/ATA stuff (Supports IDE harddisk on PCMCIA Adapter) + *----------------------------------------------------------------------- + */ + +#define CONFIG_IDE_8xx_PCCARD	1	/* Use IDE with PC Card Adapter */ + +#undef	CONFIG_IDE_8xx_DIRECT		/* Direct IDE	 not supported	*/ +#undef	CONFIG_IDE_LED			/* LED	 for ide not supported	*/ +#undef	CONFIG_IDE_RESET		/* reset for ide not supported	*/ + +#define CFG_IDE_MAXBUS		1	/* max. 1 IDE bus		*/ +#define CFG_IDE_MAXDEVICE	1	/* max. 1 drive per IDE bus	*/ + +#define CFG_ATA_IDE0_OFFSET	0x0000 + +#define CFG_ATA_BASE_ADDR	0xa0000000 + +/* Offset for data I/O			*/ +#define CFG_ATA_DATA_OFFSET	0x100 + +/* Offset for normal register accesses	*/ +#define CFG_ATA_REG_OFFSET	0x100 + +/* Offset for alternate registers	*/ +#define CFG_ATA_ALT_OFFSET	0x108 +  #endif	/* __CONFIG_H */ diff --git a/include/pci_ids.h b/include/pci_ids.h index 87de6a9b7..f4fc52fb2 100644 --- a/include/pci_ids.h +++ b/include/pci_ids.h @@ -439,6 +439,7 @@  #define PCI_DEVICE_ID_TI_1211		0xac1e  #define PCI_DEVICE_ID_TI_1251B		0xac1f  #define PCI_DEVICE_ID_TI_1420		0xac51 +#define PCI_DEVICE_ID_TI_1510		0xac56  #define PCI_VENDOR_ID_SONY		0x104d  #define PCI_DEVICE_ID_SONY_CXD3222	0x8039 diff --git a/include/pcmcia.h b/include/pcmcia.h index 16653f35a..1609632be 100644 --- a/include/pcmcia.h +++ b/include/pcmcia.h @@ -62,6 +62,8 @@  # define CONFIG_PCMCIA_SLOT_B  #elif defined(CONFIG_R360MPI)		/* The R360MPI use SLOT_B	*/  # define CONFIG_PCMCIA_SLOT_B +#elif defined(CONFIG_ATC)		/* The ATC use SLOT_A	*/ +# define CONFIG_PCMCIA_SLOT_A  #else  # error "PCMCIA Slot not configured"  #endif diff --git a/include/pcmcia/i82365.h b/include/pcmcia/i82365.h new file mode 100644 index 000000000..27ee5837c --- /dev/null +++ b/include/pcmcia/i82365.h @@ -0,0 +1,154 @@ +/* + * i82365.h 1.21 2001/08/24 12:15:33 + * + * The contents of this file are subject to the Mozilla Public License + * Version 1.1 (the "License"); you may not use this file except in + * compliance with the License. You may obtain a copy of the License + * at http://www.mozilla.org/MPL/ + * + * Software distributed under the License is distributed on an "AS IS" + * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See + * the License for the specific language governing rights and + * limitations under the License.  + * + * The initial developer of the original code is David A. Hinds + * <dahinds@users.sourceforge.net>.  Portions created by David A. Hinds + * are Copyright (C) 1999 David A. Hinds.  All Rights Reserved. + * + * Alternatively, the contents of this file may be used under the + * terms of the GNU General Public License version 2 (the "GPL"), in + * which case the provisions of the GPL are applicable instead of the + * above.  If you wish to allow the use of your version of this file + * only under the terms of the GPL and not to allow others to use + * your version of this file under the MPL, indicate your decision by + * deleting the provisions above and replace them with the notice and + * other provisions required by the GPL.  If you do not delete the + * provisions above, a recipient may use your version of this file + * under either the MPL or the GPL. + */ + +#ifndef _LINUX_I82365_H +#define _LINUX_I82365_H + +/* register definitions for the Intel 82365SL PCMCIA controller */ + +/* Offsets for PCIC registers */ +#define I365_IDENT	0x00	/* Identification and revision */ +#define I365_STATUS	0x01	/* Interface status */ +#define I365_POWER	0x02	/* Power and RESETDRV control */ +#define I365_INTCTL	0x03	/* Interrupt and general control */ +#define I365_CSC	0x04	/* Card status change */ +#define I365_CSCINT	0x05	/* Card status change interrupt control */ +#define I365_ADDRWIN	0x06	/* Address window enable */ +#define I365_IOCTL	0x07	/* I/O control */ +#define I365_GENCTL	0x16	/* Card detect and general control */ +#define I365_GBLCTL	0x1E	/* Global control register */ + +/* Offsets for I/O and memory window registers */ +#define I365_IO(map)	(0x08+((map)<<2)) +#define I365_MEM(map)	(0x10+((map)<<3)) +#define I365_W_START	0 +#define I365_W_STOP	2 +#define I365_W_OFF	4 + +/* Flags for I365_STATUS */ +#define I365_CS_BVD1	0x01 +#define I365_CS_STSCHG	0x01 +#define I365_CS_BVD2	0x02 +#define I365_CS_SPKR	0x02 +#define I365_CS_DETECT	0x0C +#define I365_CS_WRPROT	0x10 +#define I365_CS_READY	0x20	/* Inverted */ +#define I365_CS_POWERON	0x40 +#define I365_CS_GPI	0x80 + +/* Flags for I365_POWER */ +#define I365_PWR_OFF	0x00	/* Turn off the socket */ +#define I365_PWR_OUT	0x80	/* Output enable */ +#define I365_PWR_NORESET 0x40	/* Disable RESETDRV on resume */ +#define I365_PWR_AUTO	0x20	/* Auto pwr switch enable */ +#define I365_VCC_MASK	0x18	/* Mask for turning off Vcc */ +/* There are different layouts for B-step and DF-step chips: the B +   step has independent Vpp1/Vpp2 control, and the DF step has only +   Vpp1 control, plus 3V control */ +#define I365_VCC_5V	0x10	/* Vcc = 5.0v */ +#define I365_VCC_3V	0x18	/* Vcc = 3.3v */ +#define I365_VPP2_MASK	0x0c	/* Mask for turning off Vpp2 */ +#define I365_VPP2_5V	0x04	/* Vpp2 = 5.0v */ +#define I365_VPP2_12V	0x08	/* Vpp2 = 12.0v */ +#define I365_VPP1_MASK	0x03	/* Mask for turning off Vpp1 */ +#define I365_VPP1_5V	0x01	/* Vpp2 = 5.0v */ +#define I365_VPP1_12V	0x02	/* Vpp2 = 12.0v */ + +/* Flags for I365_INTCTL */ +#define I365_RING_ENA	0x80 +#define I365_PC_RESET	0x40 +#define I365_PC_IOCARD	0x20 +#define I365_INTR_ENA	0x10 +#define I365_IRQ_MASK	0x0F + +/* Flags for I365_CSC and I365_CSCINT*/ +#define I365_CSC_BVD1	0x01 +#define I365_CSC_STSCHG	0x01 +#define I365_CSC_BVD2	0x02 +#define I365_CSC_READY	0x04 +#define I365_CSC_DETECT	0x08 +#define I365_CSC_ANY	0x0F +#define I365_CSC_GPI	0x10 + +/* Flags for I365_ADDRWIN */ +#define I365_ADDR_MEMCS16	0x20 +#define I365_ENA_IO(map)	(0x40 << (map)) +#define I365_ENA_MEM(map)	(0x01 << (map)) + +/* Flags for I365_IOCTL */ +#define I365_IOCTL_MASK(map)	(0x0F << (map<<2)) +#define I365_IOCTL_WAIT(map)	(0x08 << (map<<2)) +#define I365_IOCTL_0WS(map)	(0x04 << (map<<2)) +#define I365_IOCTL_IOCS16(map)	(0x02 << (map<<2)) +#define I365_IOCTL_16BIT(map)	(0x01 << (map<<2)) + +/* Flags for I365_GENCTL */ +#define I365_CTL_16DELAY	0x01 +#define I365_CTL_RESET		0x02 +#define I365_CTL_GPI_ENA	0x04 +#define I365_CTL_GPI_CTL	0x08 +#define I365_CTL_RESUME		0x10 +#define I365_CTL_SW_IRQ		0x20 + +/* Flags for I365_GBLCTL */ +#define I365_GBL_PWRDOWN	0x01 +#define I365_GBL_CSC_LEV	0x02 +#define I365_GBL_WRBACK		0x04 +#define I365_GBL_IRQ_0_LEV	0x08 +#define I365_GBL_IRQ_1_LEV	0x10 + +/* Flags for memory window registers */ +#define I365_MEM_16BIT	0x8000	/* In memory start high byte */ +#define I365_MEM_0WS	0x4000 +#define I365_MEM_WS1	0x8000	/* In memory stop high byte */ +#define I365_MEM_WS0	0x4000 +#define I365_MEM_WRPROT	0x8000	/* In offset high byte */ +#define I365_MEM_REG	0x4000 + +#define I365_REG(slot, reg)	(((slot) << 6) | (reg)) + +/* Default ISA interrupt mask */ +#define I365_ISA_IRQ_MASK	0xdeb8	/* irq's 3-5,7,9-12,14,15 */ + +/* Device ID's for PCI-to-PCMCIA bridges */ + +#ifndef PCI_VENDOR_ID_INTEL +#define PCI_VENDOR_ID_INTEL		0x8086 +#endif +#ifndef PCI_DEVICE_ID_INTEL_82092AA_0 +#define PCI_DEVICE_ID_INTEL_82092AA_0	0x1221 +#endif +#ifndef PCI_VENDOR_ID_OMEGA +#define PCI_VENDOR_ID_OMEGA		0x119b +#endif +#ifndef PCI_DEVICE_ID_OMEGA_82C092G +#define PCI_DEVICE_ID_OMEGA_82C092G	0x1221 +#endif + +#endif /* _LINUX_I82365_H */ diff --git a/include/pcmcia/ss.h b/include/pcmcia/ss.h new file mode 100644 index 000000000..d197e42d2 --- /dev/null +++ b/include/pcmcia/ss.h @@ -0,0 +1,133 @@ +/* + * ss.h 1.31 2001/08/24 12:16:13 + * + * The contents of this file are subject to the Mozilla Public License + * Version 1.1 (the "License"); you may not use this file except in + * compliance with the License. You may obtain a copy of the License + * at http://www.mozilla.org/MPL/ + * + * Software distributed under the License is distributed on an "AS IS" + * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See + * the License for the specific language governing rights and + * limitations under the License.  + * + * The initial developer of the original code is David A. Hinds + * <dahinds@users.sourceforge.net>.  Portions created by David A. Hinds + * are Copyright (C) 1999 David A. Hinds.  All Rights Reserved. + * + * Alternatively, the contents of this file may be used under the + * terms of the GNU General Public License version 2 (the "GPL"), in + * which case the provisions of the GPL are applicable instead of the + * above.  If you wish to allow the use of your version of this file + * only under the terms of the GPL and not to allow others to use + * your version of this file under the MPL, indicate your decision by + * deleting the provisions above and replace them with the notice and + * other provisions required by the GPL.  If you do not delete the + * provisions above, a recipient may use your version of this file + * under either the MPL or the GPL. + */ + +#ifndef _LINUX_SS_H +#define _LINUX_SS_H + +/* For RegisterCallback */ +typedef struct ss_callback_t { +    void	(*handler)(void *info, u_int events); +    void	*info; +} ss_callback_t; + +/* Definitions for card status flags for GetStatus */ +#define SS_WRPROT	0x0001 +#define SS_CARDLOCK	0x0002 +#define SS_EJECTION	0x0004 +#define SS_INSERTION	0x0008 +#define SS_BATDEAD	0x0010 +#define SS_BATWARN	0x0020 +#define SS_READY	0x0040 +#define SS_DETECT	0x0080 +#define SS_POWERON	0x0100 +#define SS_GPI		0x0200 +#define SS_STSCHG	0x0400 +#define SS_CARDBUS	0x0800 +#define SS_3VCARD	0x1000 +#define SS_XVCARD	0x2000 +#define SS_PENDING	0x4000 + +/* for InquireSocket */ +typedef struct socket_cap_t { +    u_int	features; +    u_int	irq_mask; +    u_int	map_size; +    u_char	pci_irq; +    u_char	cardbus; +    struct pci_bus *cb_bus; +    struct bus_operations *bus; +} socket_cap_t; + +/* InquireSocket capabilities */ +#define SS_CAP_PAGE_REGS	0x0001 +#define SS_CAP_VIRTUAL_BUS	0x0002 +#define SS_CAP_MEM_ALIGN	0x0004 +#define SS_CAP_STATIC_MAP	0x0008 +#define SS_CAP_PCCARD		0x4000 +#define SS_CAP_CARDBUS		0x8000 + +/* for GetSocket, SetSocket */ +typedef struct socket_state_t { +    u_int	flags; +    u_int	csc_mask; +    u_char	Vcc, Vpp; +    u_char	io_irq; +} socket_state_t; + +/* Socket configuration flags */ +#define SS_PWR_AUTO	0x0010 +#define SS_IOCARD	0x0020 +#define SS_RESET	0x0040 +#define SS_DMA_MODE	0x0080 +#define SS_SPKR_ENA	0x0100 +#define SS_OUTPUT_ENA	0x0200 +#define SS_ZVCARD	0x0400 + +/* Flags for I/O port and memory windows */ +#define MAP_ACTIVE	0x01 +#define MAP_16BIT	0x02 +#define MAP_AUTOSZ	0x04 +#define MAP_0WS		0x08 +#define MAP_WRPROT	0x10 +#define MAP_ATTRIB	0x20 +#define MAP_USE_WAIT	0x40 +#define MAP_PREFETCH	0x80 + +/* Use this just for bridge windows */ +#define MAP_IOSPACE	0x20 + +typedef struct pccard_io_map { +    u_char	map; +    u_char	flags; +    u_short	speed; +    u_short	start, stop; +} pccard_io_map; + +typedef struct pccard_mem_map { +    u_char	map; +    u_char	flags; +    u_short	speed; +    u_long	sys_start, sys_stop; +    u_int	card_start; +} pccard_mem_map; + +typedef struct cb_bridge_map { +    u_char	map; +    u_char	flags; +    u_int	start, stop; +} cb_bridge_map; + +enum ss_service { +    SS_RegisterCallback, SS_InquireSocket, +    SS_GetStatus, SS_GetSocket, SS_SetSocket, +    SS_GetIOMap, SS_SetIOMap, SS_GetMemMap, SS_SetMemMap, +    SS_GetBridge, SS_SetBridge, SS_ProcSetup +}; + +#endif /* _LINUX_SS_H */ diff --git a/include/pcmcia/ti113x.h b/include/pcmcia/ti113x.h new file mode 100644 index 000000000..26c57648e --- /dev/null +++ b/include/pcmcia/ti113x.h @@ -0,0 +1,234 @@ +/* + * ti113x.h 1.31 2002/05/12 18:19:47 + * + * The contents of this file are subject to the Mozilla Public License + * Version 1.1 (the "License"); you may not use this file except in + * compliance with the License. You may obtain a copy of the License + * at http://www.mozilla.org/MPL/ + * + * Software distributed under the License is distributed on an "AS IS" + * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See + * the License for the specific language governing rights and + * limitations under the License.  + * + * The initial developer of the original code is David A. Hinds + * <dahinds@users.sourceforge.net>.  Portions created by David A. Hinds + * are Copyright (C) 1999 David A. Hinds.  All Rights Reserved. + * + * Alternatively, the contents of this file may be used under the + * terms of the GNU General Public License version 2 (the "GPL"), in + * which case the provisions of the GPL are applicable instead of the + * above.  If you wish to allow the use of your version of this file + * only under the terms of the GPL and not to allow others to use + * your version of this file under the MPL, indicate your decision by + * deleting the provisions above and replace them with the notice and + * other provisions required by the GPL.  If you do not delete the + * provisions above, a recipient may use your version of this file + * under either the MPL or the GPL. + */ + +#ifndef _LINUX_TI113X_H +#define _LINUX_TI113X_H + +#ifndef PCI_VENDOR_ID_TI +#define PCI_VENDOR_ID_TI		0x104c +#endif + +#ifndef PCI_DEVICE_ID_TI_1130 +#define PCI_DEVICE_ID_TI_1130		0xac12 +#endif +#ifndef PCI_DEVICE_ID_TI_1031 +#define PCI_DEVICE_ID_TI_1031		0xac13 +#endif +#ifndef PCI_DEVICE_ID_TI_1131 +#define PCI_DEVICE_ID_TI_1131		0xac15 +#endif +#ifndef PCI_DEVICE_ID_TI_1210 +#define PCI_DEVICE_ID_TI_1210		0xac1a +#endif +#ifndef PCI_DEVICE_ID_TI_1211 +#define PCI_DEVICE_ID_TI_1211		0xac1e +#endif +#ifndef PCI_DEVICE_ID_TI_1220 +#define PCI_DEVICE_ID_TI_1220		0xac17 +#endif +#ifndef PCI_DEVICE_ID_TI_1221 +#define PCI_DEVICE_ID_TI_1221		0xac19 +#endif +#ifndef PCI_DEVICE_ID_TI_1250A +#define PCI_DEVICE_ID_TI_1250A		0xac16 +#endif +#ifndef PCI_DEVICE_ID_TI_1225 +#define PCI_DEVICE_ID_TI_1225		0xac1c +#endif +#ifndef PCI_DEVICE_ID_TI_1251A +#define PCI_DEVICE_ID_TI_1251A		0xac1d +#endif +#ifndef PCI_DEVICE_ID_TI_1251B +#define PCI_DEVICE_ID_TI_1251B		0xac1f +#endif +#ifndef PCI_DEVICE_ID_TI_1410 +#define PCI_DEVICE_ID_TI_1410		0xac50 +#endif +#ifndef PCI_DEVICE_ID_TI_1420 +#define PCI_DEVICE_ID_TI_1420		0xac51 +#endif +#ifndef PCI_DEVICE_ID_TI_1450 +#define PCI_DEVICE_ID_TI_1450		0xac1b +#endif +#ifndef PCI_DEVICE_ID_TI_1451 +#define PCI_DEVICE_ID_TI_1451		0xac52 +#endif +#ifndef PCI_DEVICE_ID_TI_1510 +#define PCI_DEVICE_ID_TI_1510		0xac56 +#endif +#ifndef PCI_DEVICE_ID_TI_4410 +#define PCI_DEVICE_ID_TI_4410		0xac41 +#endif +#ifndef PCI_DEVICE_ID_TI_4450 +#define PCI_DEVICE_ID_TI_4450		0xac40 +#endif +#ifndef PCI_DEVICE_ID_TI_4451 +#define PCI_DEVICE_ID_TI_4451		0xac42 +#endif + +/* Register definitions for TI 113X PCI-to-CardBus bridges */ + +/* System Control Register */ +#define TI113X_SYSTEM_CONTROL		0x80	/* 32 bit */ +#define  TI113X_SCR_SMIROUTE		0x04000000 +#define  TI113X_SCR_SMISTATUS		0x02000000 +#define  TI113X_SCR_SMIENB		0x01000000 +#define  TI113X_SCR_VCCPROT		0x00200000 +#define  TI113X_SCR_REDUCEZV		0x00100000 +#define  TI113X_SCR_CDREQEN		0x00080000 +#define  TI113X_SCR_CDMACHAN		0x00070000 +#define  TI113X_SCR_SOCACTIVE		0x00002000 +#define  TI113X_SCR_PWRSTREAM		0x00000800 +#define  TI113X_SCR_DELAYUP		0x00000400 +#define  TI113X_SCR_DELAYDOWN		0x00000200 +#define  TI113X_SCR_INTERROGATE		0x00000100 +#define  TI113X_SCR_CLKRUN_SEL		0x00000080 +#define  TI113X_SCR_PWRSAVINGS		0x00000040 +#define  TI113X_SCR_SUBSYSRW		0x00000020 +#define  TI113X_SCR_CB_DPAR		0x00000010 +#define  TI113X_SCR_CDMA_EN		0x00000008 +#define  TI113X_SCR_ASYNC_IRQ		0x00000004 +#define  TI113X_SCR_KEEPCLK		0x00000002 +#define  TI113X_SCR_CLKRUN_ENA		0x00000001   + +#define  TI122X_SCR_SER_STEP		0xc0000000 +#define  TI122X_SCR_INTRTIE		0x20000000 +#define  TI122X_SCR_P2CCLK		0x08000000 +#define  TI122X_SCR_CBRSVD		0x00400000 +#define  TI122X_SCR_MRBURSTDN		0x00008000 +#define  TI122X_SCR_MRBURSTUP		0x00004000 +#define  TI122X_SCR_RIMUX		0x00000001 + +/* Multimedia Control Register */ +#define TI1250_MULTIMEDIA_CTL		0x84	/* 8 bit */ +#define  TI1250_MMC_ZVOUTEN		0x80 +#define  TI1250_MMC_PORTSEL		0x40 +#define  TI1250_MMC_ZVEN1		0x02 +#define  TI1250_MMC_ZVEN0		0x01 + +#define TI1250_GENERAL_STATUS		0x85	/* 8 bit */ +#define TI1250_GPIO0_CONTROL		0x88	/* 8 bit */ +#define TI1250_GPIO1_CONTROL		0x89	/* 8 bit */ +#define TI1250_GPIO2_CONTROL		0x8a	/* 8 bit */ +#define TI1250_GPIO3_CONTROL		0x8b	/* 8 bit */ +#define TI12XX_IRQMUX			0x8c	/* 32 bit */ + +/* Retry Status Register */ +#define TI113X_RETRY_STATUS		0x90	/* 8 bit */ +#define  TI113X_RSR_PCIRETRY		0x80 +#define  TI113X_RSR_CBRETRY		0x40 +#define  TI113X_RSR_TEXP_CBB		0x20 +#define  TI113X_RSR_MEXP_CBB		0x10 +#define  TI113X_RSR_TEXP_CBA		0x08 +#define  TI113X_RSR_MEXP_CBA		0x04 +#define  TI113X_RSR_TEXP_PCI		0x02 +#define  TI113X_RSR_MEXP_PCI		0x01 + +/* Card Control Register */ +#define TI113X_CARD_CONTROL		0x91	/* 8 bit */ +#define  TI113X_CCR_RIENB		0x80 +#define  TI113X_CCR_ZVENABLE		0x40 +#define  TI113X_CCR_PCI_IRQ_ENA		0x20 +#define  TI113X_CCR_PCI_IREQ		0x10 +#define  TI113X_CCR_PCI_CSC		0x08 +#define  TI113X_CCR_SPKROUTEN		0x02 +#define  TI113X_CCR_IFG			0x01 + +#define  TI1220_CCR_PORT_SEL		0x20 +#define  TI122X_CCR_AUD2MUX		0x04 + +/* Device Control Register */ +#define TI113X_DEVICE_CONTROL		0x92	/* 8 bit */ +#define  TI113X_DCR_5V_FORCE		0x40 +#define  TI113X_DCR_3V_FORCE		0x20 +#define  TI113X_DCR_IMODE_MASK		0x06 +#define  TI113X_DCR_IMODE_ISA		0x02 +#define  TI113X_DCR_IMODE_SERIAL	0x04 + +#define  TI12XX_DCR_IMODE_PCI_ONLY	0x00 +#define  TI12XX_DCR_IMODE_ALL_SERIAL	0x06 + +/* Buffer Control Register */ +#define TI113X_BUFFER_CONTROL		0x93	/* 8 bit */ +#define  TI113X_BCR_CB_READ_DEPTH	0x08 +#define  TI113X_BCR_CB_WRITE_DEPTH	0x04 +#define  TI113X_BCR_PCI_READ_DEPTH	0x02 +#define  TI113X_BCR_PCI_WRITE_DEPTH	0x01 + +/* Diagnostic Register */ +#define TI1250_DIAGNOSTIC		0x93	/* 8 bit */ +#define  TI1250_DIAG_TRUE_VALUE		0x80 +#define  TI1250_DIAG_PCI_IREQ		0x40 +#define  TI1250_DIAG_PCI_CSC		0x20 +#define  TI1250_DIAG_ASYNC_CSC		0x01 + +/* DMA Registers */ +#define TI113X_DMA_0			0x94	/* 32 bit */ +#define TI113X_DMA_1			0x98	/* 32 bit */ + +/* ExCA IO offset registers */ +#define TI113X_IO_OFFSET(map)		(0x36+((map)<<1)) + +/* Data structure for tracking vendor-specific state */ +typedef struct ti113x_state_t { +    u32			sysctl;		/* TI113X_SYSTEM_CONTROL */ +    u8			cardctl;	/* TI113X_CARD_CONTROL */ +    u8			devctl;		/* TI113X_DEVICE_CONTROL */ +    u8			diag;		/* TI1250_DIAGNOSTIC */ +    u32			irqmux;		/* TI12XX_IRQMUX */ +} ti113x_state_t; + +#define TI_PCIC_ID \ +    IS_TI1130, IS_TI1131, IS_TI1031, IS_TI1210, IS_TI1211,	\ +    IS_TI1220, IS_TI1221, IS_TI1225, IS_TI1250A, IS_TI1251A,	\ +    IS_TI1251B, IS_TI1410, IS_TI1420, IS_TI1450, IS_TI1451,	\ +    IS_TI1510, IS_TI4410, IS_TI4450, IS_TI4451 + +#define TI_PCIC_INFO \ +    { "TI 1130",  IS_TI|IS_CARDBUS, ID(TI, 1130) }, \ +    { "TI 1131",  IS_TI|IS_CARDBUS, ID(TI, 1131) }, \ +    { "TI 1031",  IS_TI|IS_CARDBUS, ID(TI, 1031) }, \ +    { "TI 1210",  IS_TI|IS_CARDBUS, ID(TI, 1210) }, \ +    { "TI 1211",  IS_TI|IS_CARDBUS, ID(TI, 1211) }, \ +    { "TI 1220",  IS_TI|IS_CARDBUS, ID(TI, 1220) }, \ +    { "TI 1221",  IS_TI|IS_CARDBUS, ID(TI, 1221) }, \ +    { "TI 1225",  IS_TI|IS_CARDBUS, ID(TI, 1225) }, \ +    { "TI 1250A", IS_TI|IS_CARDBUS, ID(TI, 1250A) }, \ +    { "TI 1251A", IS_TI|IS_CARDBUS, ID(TI, 1251A) }, \ +    { "TI 1251B", IS_TI|IS_CARDBUS, ID(TI, 1251B) }, \ +    { "TI 1410",  IS_TI|IS_CARDBUS, ID(TI, 1410) }, \ +    { "TI 1420",  IS_TI|IS_CARDBUS, ID(TI, 1420) }, \ +    { "TI 1450",  IS_TI|IS_CARDBUS, ID(TI, 1450) }, \ +    { "TI 1451",  IS_TI|IS_CARDBUS, ID(TI, 1451) }, \ +    { "TI 1510",  IS_TI|IS_CARDBUS, ID(TI, 1510) }, \ +    { "TI 4410",  IS_TI|IS_CARDBUS, ID(TI, 4410) }, \ +    { "TI 4450",  IS_TI|IS_CARDBUS, ID(TI, 4450) }, \ +    { "TI 4451",  IS_TI|IS_CARDBUS, ID(TI, 4451) } + +#endif /* _LINUX_TI113X_H */ diff --git a/include/pcmcia/yenta.h b/include/pcmcia/yenta.h new file mode 100644 index 000000000..525d8ecc8 --- /dev/null +++ b/include/pcmcia/yenta.h @@ -0,0 +1,156 @@ +/* + * yenta.h 1.20 2001/08/24 12:15:34 + * + * The contents of this file are subject to the Mozilla Public License + * Version 1.1 (the "License"); you may not use this file except in + * compliance with the License. You may obtain a copy of the License + * at http://www.mozilla.org/MPL/ + * + * Software distributed under the License is distributed on an "AS IS" + * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See + * the License for the specific language governing rights and + * limitations under the License.  + * + * The initial developer of the original code is David A. Hinds + * <dahinds@users.sourceforge.net>.  Portions created by David A. Hinds + * are Copyright (C) 1999 David A. Hinds.  All Rights Reserved. + * + * Alternatively, the contents of this file may be used under the + * terms of the GNU General Public License version 2 (the "GPL"), in + * which case the provisions of the GPL are applicable instead of the + * above.  If you wish to allow the use of your version of this file + * only under the terms of the GPL and not to allow others to use + * your version of this file under the MPL, indicate your decision by + * deleting the provisions above and replace them with the notice and + * other provisions required by the GPL.  If you do not delete the + * provisions above, a recipient may use your version of this file + * under either the MPL or the GPL. + */ + +#ifndef _LINUX_YENTA_H +#define _LINUX_YENTA_H + +/* PCI Configuration Registers */ + +#define PCI_STATUS_CAPLIST		0x10 +#define PCI_CB_CAPABILITY_POINTER	0x14	/* 8 bit */ +#define PCI_CAPABILITY_ID		0x00	/* 8 bit */ +#define  PCI_CAPABILITY_PM		0x01 +#define PCI_NEXT_CAPABILITY		0x01	/* 8 bit */ +#define PCI_PM_CAPABILITIES		0x02	/* 16 bit */ +#define  PCI_PMCAP_PME_D3COLD		0x8000 +#define  PCI_PMCAP_PME_D3HOT		0x4000 +#define  PCI_PMCAP_PME_D2		0x2000 +#define  PCI_PMCAP_PME_D1		0x1000 +#define  PCI_PMCAP_PME_D0		0x0800 +#define  PCI_PMCAP_D2_CAP		0x0400 +#define  PCI_PMCAP_D1_CAP		0x0200 +#define  PCI_PMCAP_DYN_DATA		0x0100 +#define  PCI_PMCAP_DSI			0x0020 +#define  PCI_PMCAP_AUX_PWR		0x0010 +#define  PCI_PMCAP_PMECLK		0x0008 +#define  PCI_PMCAP_VERSION_MASK		0x0007 +#define PCI_PM_CONTROL_STATUS		0x04	/* 16 bit */ +#define  PCI_PMCS_PME_STATUS		0x8000 +#define  PCI_PMCS_DATASCALE_MASK	0x6000 +#define  PCI_PMCS_DATASCALE_SHIFT	13 +#define  PCI_PMCS_DATASEL_MASK		0x1e00 +#define  PCI_PMCS_DATASEL_SHIFT		9 +#define  PCI_PMCS_PME_ENABLE		0x0100 +#define  PCI_PMCS_PWR_STATE_MASK	0x0003 +#define  PCI_PMCS_PWR_STATE_D0		0x0000 +#define  PCI_PMCS_PWR_STATE_D1		0x0001 +#define  PCI_PMCS_PWR_STATE_D2		0x0002 +#define  PCI_PMCS_PWR_STATE_D3		0x0003 +#define PCI_PM_BRIDGE_EXT		0x06	/* 8 bit */ +#define PCI_PM_DATA			0x07	/* 8 bit */ + +#define CB_PRIMARY_BUS			0x18	/* 8 bit */ +#define CB_CARDBUS_BUS			0x19	/* 8 bit */ +#define CB_SUBORD_BUS			0x1a	/* 8 bit */ +#define CB_LATENCY_TIMER		0x1b	/* 8 bit */ + +#define CB_MEM_BASE(m)			(0x1c + 8*(m)) +#define CB_MEM_LIMIT(m)			(0x20 + 8*(m)) +#define CB_IO_BASE(m)			(0x2c + 8*(m)) +#define CB_IO_LIMIT(m)			(0x30 + 8*(m)) + +#define CB_BRIDGE_CONTROL		0x3e	/* 16 bit */ +#define  CB_BCR_PARITY_ENA		0x0001 +#define  CB_BCR_SERR_ENA		0x0002 +#define  CB_BCR_ISA_ENA			0x0004 +#define  CB_BCR_VGA_ENA			0x0008 +#define  CB_BCR_MABORT			0x0020 +#define  CB_BCR_CB_RESET		0x0040 +#define  CB_BCR_ISA_IRQ			0x0080 +#define  CB_BCR_PREFETCH(m)		(0x0100 << (m)) +#define  CB_BCR_WRITE_POST		0x0400 + +#define CB_LEGACY_MODE_BASE		0x44 + +/* Memory mapped registers */ + +#define CB_SOCKET_EVENT			0x0000 +#define  CB_SE_CSTSCHG			0x00000001 +#define  CB_SE_CCD			0x00000006 +#define  CB_SE_CCD1			0x00000002 +#define  CB_SE_CCD2			0x00000004 +#define  CB_SE_PWRCYCLE			0x00000008 + +#define CB_SOCKET_MASK			0x0004 +#define  CB_SM_CSTSCHG			0x00000001 +#define  CB_SM_CCD			0x00000006 +#define  CB_SM_PWRCYCLE			0x00000008 + +#define CB_SOCKET_STATE			0x0008 +#define  CB_SS_CSTSCHG			0x00000001 +#define  CB_SS_CCD			0x00000006 +#define  CB_SS_CCD1			0x00000002 +#define  CB_SS_CCD2			0x00000004 +#define  CB_SS_PWRCYCLE			0x00000008 +#define  CB_SS_16BIT			0x00000010 +#define  CB_SS_32BIT			0x00000020 +#define  CB_SS_CINT			0x00000040 +#define  CB_SS_BADCARD			0x00000080 +#define  CB_SS_DATALOST			0x00000100 +#define  CB_SS_BADVCC			0x00000200 +#define  CB_SS_5VCARD			0x00000400 +#define  CB_SS_3VCARD			0x00000800 +#define  CB_SS_XVCARD			0x00001000 +#define  CB_SS_YVCARD			0x00002000 +#define  CB_SS_VSENSE			0x00003c86 +#define  CB_SS_5VSOCKET			0x10000000 +#define  CB_SS_3VSOCKET			0x20000000 +#define  CB_SS_XVSOCKET			0x40000000 +#define  CB_SS_YVSOCKET			0x80000000 + +#define CB_SOCKET_FORCE			0x000c +#define  CB_SF_CVSTEST			0x00004000 + +#define CB_SOCKET_CONTROL		0x0010 +#define  CB_SC_VPP_MASK			0x00000007 +#define   CB_SC_VPP_OFF			0x00000000 +#define   CB_SC_VPP_12V			0x00000001 +#define   CB_SC_VPP_5V			0x00000002 +#define   CB_SC_VPP_3V			0x00000003 +#define   CB_SC_VPP_XV			0x00000004 +#define   CB_SC_VPP_YV			0x00000005 +#define  CB_SC_VCC_MASK			0x00000070 +#define   CB_SC_VCC_OFF			0x00000000 +#define   CB_SC_VCC_5V			0x00000020 +#define   CB_SC_VCC_3V			0x00000030 +#define   CB_SC_VCC_XV			0x00000040 +#define   CB_SC_VCC_YV			0x00000050 +#define  CB_SC_CCLK_STOP		0x00000080 + +#define CB_SOCKET_POWER			0x0020 +#define  CB_SP_CLK_CTRL			0x00000001 +#define  CB_SP_CLK_CTRL_ENA		0x00010000 +#define  CB_SP_CLK_MODE			0x01000000 +#define  CB_SP_ACCESS			0x02000000 + +/* Address bits 31..24 for memory windows for 16-bit cards, +   accessable only by memory mapping the 16-bit register set */ +#define CB_MEM_PAGE(map)		(0x40 + (map)) + +#endif /* _LINUX_YENTA_H */ |