xref: /linux/arch/sh/drivers/pci/pci-sh7780.h (revision 959f85f8a3223c116bbe95dd8a9b207790b5d4d3)
15283ecb5SPaul Mundt /*
25283ecb5SPaul Mundt  *	Low-Level PCI Support for SH7780 targets
35283ecb5SPaul Mundt  *
45283ecb5SPaul Mundt  *  Dustin McIntire (dustin@sensoria.com) (c) 2001
55283ecb5SPaul Mundt  *  Paul Mundt (lethal@linux-sh.org) (c) 2003
65283ecb5SPaul Mundt  *
75283ecb5SPaul Mundt  *  May be copied or modified under the terms of the GNU General Public
85283ecb5SPaul Mundt  *  License.  See linux/COPYING for more information.
95283ecb5SPaul Mundt  *
105283ecb5SPaul Mundt  */
115283ecb5SPaul Mundt 
125283ecb5SPaul Mundt #ifndef _PCI_SH7780_H_
135283ecb5SPaul Mundt #define _PCI_SH7780_H_
145283ecb5SPaul Mundt 
155283ecb5SPaul Mundt /* Platform Specific Values */
165283ecb5SPaul Mundt #define SH7780_VENDOR_ID	0x1912
175283ecb5SPaul Mundt #define SH7780_DEVICE_ID	0x0002
185283ecb5SPaul Mundt #define SH7781_DEVICE_ID	0x0001
195283ecb5SPaul Mundt 
205283ecb5SPaul Mundt /* SH7780 Control Registers */
215283ecb5SPaul Mundt #define	SH7780_PCI_VCR0		0xFE000000
225283ecb5SPaul Mundt #define	SH7780_PCI_VCR1		0xFE000004
235283ecb5SPaul Mundt #define	SH7780_PCI_VCR2		0xFE000008
245283ecb5SPaul Mundt 
255283ecb5SPaul Mundt /* SH7780 Specific Values */
265283ecb5SPaul Mundt #define SH7780_PCI_CONFIG_BASE	0xFD000000	/* Config space base addr */
275283ecb5SPaul Mundt #define SH7780_PCI_CONFIG_SIZE	0x01000000	/* Config space size */
28*959f85f8SPaul Mundt 
295283ecb5SPaul Mundt #define SH7780_PCI_MEMORY_BASE	0xFD000000	/* Memory space base addr */
305283ecb5SPaul Mundt #define SH7780_PCI_MEM_SIZE	0x01000000	/* Size of Memory window */
31*959f85f8SPaul Mundt 
325283ecb5SPaul Mundt #define SH7780_PCI_IO_BASE	0xFE400000	/* IO space base address */
335283ecb5SPaul Mundt #define SH7780_PCI_IO_SIZE	0x00400000	/* Size of IO window */
345283ecb5SPaul Mundt 
355283ecb5SPaul Mundt #define SH7780_PCIREG_BASE	0xFE040000	/* PCI regs base address */
365283ecb5SPaul Mundt #define PCI_REG(n)		(SH7780_PCIREG_BASE+n)
375283ecb5SPaul Mundt 
385283ecb5SPaul Mundt /* SH7780 PCI Config Registers */
395283ecb5SPaul Mundt #define SH7780_PCIVID		0x000		/* Vendor ID */
405283ecb5SPaul Mundt #define SH7780_PCIDID		0x002		/* Device ID */
415283ecb5SPaul Mundt #define SH7780_PCICMD		0x004		/* Command */
425283ecb5SPaul Mundt #define SH7780_PCISTATUS	0x006		/* Status */
435283ecb5SPaul Mundt #define SH7780_PCIRID		0x008		/* Revision ID */
445283ecb5SPaul Mundt #define SH7780_PCIPIF		0x009		/* Program Interface */
455283ecb5SPaul Mundt #define SH7780_PCISUB		0x00a		/* Sub class code */
465283ecb5SPaul Mundt #define SH7780_PCIBCC		0x00b		/* Base class code */
475283ecb5SPaul Mundt #define SH7780_PCICLS		0x00c		/* Cache line size */
485283ecb5SPaul Mundt #define SH7780_PCILTM		0x00d		/* latency timer */
495283ecb5SPaul Mundt #define SH7780_PCIHDR		0x00e		/* Header type */
505283ecb5SPaul Mundt #define SH7780_PCIBIST		0x00f		/* BIST */
515283ecb5SPaul Mundt #define SH7780_PCIIBAR		0x010		/* IO Base address */
525283ecb5SPaul Mundt #define SH7780_PCIMBAR0		0x014		/* Memory base address0 */
535283ecb5SPaul Mundt #define SH7780_PCIMBAR1		0x018		/* Memory base address1 */
545283ecb5SPaul Mundt #define SH7780_PCISVID		0x02c		/* Sub system vendor ID */
555283ecb5SPaul Mundt #define SH7780_PCISID		0x02e		/* Sub system ID */
565283ecb5SPaul Mundt #define SH7780_PCICP		0x034
575283ecb5SPaul Mundt #define SH7780_PCIINTLINE	0x03c		/* Interrupt line */
585283ecb5SPaul Mundt #define SH7780_PCIINTPIN	0x03d		/* Interrupt pin */
595283ecb5SPaul Mundt #define SH7780_PCIMINGNT	0x03e		/* Minumum grand */
605283ecb5SPaul Mundt #define SH7780_PCIMAXLAT	0x03f		/* Maxmum latency */
615283ecb5SPaul Mundt #define SH7780_PCICID		0x040
625283ecb5SPaul Mundt #define SH7780_PCINIP		0x041
635283ecb5SPaul Mundt #define SH7780_PCIPMC		0x042
645283ecb5SPaul Mundt #define SH7780_PCIPMCSR		0x044
655283ecb5SPaul Mundt #define SH7780_PCIPMCSR_BSE	0x046
665283ecb5SPaul Mundt #define SH7780_PCICDD		0x047
675283ecb5SPaul Mundt 
68*959f85f8SPaul Mundt #define SH7780_PCIMBR0		0x1E0
69*959f85f8SPaul Mundt #define SH7780_PCIMBMR0		0x1E4
70*959f85f8SPaul Mundt #define SH7780_PCIMBR2		0x1F0
71*959f85f8SPaul Mundt #define SH7780_PCIMBMR2		0x1F4
72*959f85f8SPaul Mundt #define SH7780_PCIIOBR		0x1F8
73*959f85f8SPaul Mundt #define SH7780_PCIIOBMR		0x1FC
745283ecb5SPaul Mundt #define SH7780_PCICSCR0		0x210		/* Cache Snoop1 Cnt. Register */
755283ecb5SPaul Mundt #define SH7780_PCICSCR1		0x214		/* Cache Snoop2 Cnt. Register */
765283ecb5SPaul Mundt #define SH7780_PCICSAR0		0x218	/* Cache Snoop1 Addr. Register */
775283ecb5SPaul Mundt #define SH7780_PCICSAR1		0x21C	/* Cache Snoop2 Addr. Register */
785283ecb5SPaul Mundt 
795283ecb5SPaul Mundt /* General Memory Config Addresses */
805283ecb5SPaul Mundt #define SH7780_CS0_BASE_ADDR	0x0
815283ecb5SPaul Mundt #define SH7780_MEM_REGION_SIZE	0x04000000
825283ecb5SPaul Mundt #define SH7780_CS1_BASE_ADDR	(SH7780_CS0_BASE_ADDR + SH7780_MEM_REGION_SIZE)
835283ecb5SPaul Mundt #define SH7780_CS2_BASE_ADDR	(SH7780_CS1_BASE_ADDR + SH7780_MEM_REGION_SIZE)
845283ecb5SPaul Mundt #define SH7780_CS3_BASE_ADDR	(SH7780_CS2_BASE_ADDR + SH7780_MEM_REGION_SIZE)
855283ecb5SPaul Mundt #define SH7780_CS4_BASE_ADDR	(SH7780_CS3_BASE_ADDR + SH7780_MEM_REGION_SIZE)
865283ecb5SPaul Mundt #define SH7780_CS5_BASE_ADDR	(SH7780_CS4_BASE_ADDR + SH7780_MEM_REGION_SIZE)
875283ecb5SPaul Mundt #define SH7780_CS6_BASE_ADDR	(SH7780_CS5_BASE_ADDR + SH7780_MEM_REGION_SIZE)
885283ecb5SPaul Mundt 
89*959f85f8SPaul Mundt struct sh4_pci_address_map;
905283ecb5SPaul Mundt 
915283ecb5SPaul Mundt /* arch/sh/drivers/pci/pci-sh7780.c */
92*959f85f8SPaul Mundt int sh7780_pcic_init(struct sh4_pci_address_map *map);
935283ecb5SPaul Mundt 
945283ecb5SPaul Mundt #endif /* _PCI_SH7780_H_ */
95