Merge branch 'upstream-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jgarzi...
[wrt350n-kernel.git] / include / asm-sh / se7722.h
blobe0e89fcb8388846ea3b228485bba339e622b051d
1 #ifndef __ASM_SH_SE7722_H
2 #define __ASM_SH_SE7722_H
4 /*
5 * linux/include/asm-sh/se7722.h
7 * Copyright (C) 2007 Nobuhiro Iwamatsu
9 * Hitachi UL SolutionEngine 7722 Support.
11 * This file is subject to the terms and conditions of the GNU General Public
12 * License. See the file "COPYING" in the main directory of this archive
13 * for more details.
16 #include <asm/addrspace.h>
18 /* Box specific addresses. */
19 #define SE_AREA0_WIDTH 4 /* Area0: 32bit */
20 #define PA_ROM 0xa0000000 /* EPROM */
21 #define PA_ROM_SIZE 0x00200000 /* EPROM size 2M byte */
22 #define PA_FROM 0xa1000000 /* Flash-ROM */
23 #define PA_FROM_SIZE 0x01000000 /* Flash-ROM size 16M byte */
24 #define PA_EXT1 0xa4000000
25 #define PA_EXT1_SIZE 0x04000000
26 #define PA_SDRAM 0xaC000000 /* DDR-SDRAM(Area3) 64MB */
27 #define PA_SDRAM_SIZE 0x04000000
29 #define PA_EXT4 0xb0000000
30 #define PA_EXT4_SIZE 0x04000000
32 #define PA_PERIPHERAL 0xB0000000
34 #define PA_PCIC PA_PERIPHERAL /* MR-SHPC-01 PCMCIA */
35 #define PA_MRSHPC (PA_PERIPHERAL + 0x003fffe0) /* MR-SHPC-01 PCMCIA controller */
36 #define PA_MRSHPC_MW1 (PA_PERIPHERAL + 0x00400000) /* MR-SHPC-01 memory window base */
37 #define PA_MRSHPC_MW2 (PA_PERIPHERAL + 0x00500000) /* MR-SHPC-01 attribute window base */
38 #define PA_MRSHPC_IO (PA_PERIPHERAL + 0x00600000) /* MR-SHPC-01 I/O window base */
39 #define MRSHPC_OPTION (PA_MRSHPC + 6)
40 #define MRSHPC_CSR (PA_MRSHPC + 8)
41 #define MRSHPC_ISR (PA_MRSHPC + 10)
42 #define MRSHPC_ICR (PA_MRSHPC + 12)
43 #define MRSHPC_CPWCR (PA_MRSHPC + 14)
44 #define MRSHPC_MW0CR1 (PA_MRSHPC + 16)
45 #define MRSHPC_MW1CR1 (PA_MRSHPC + 18)
46 #define MRSHPC_IOWCR1 (PA_MRSHPC + 20)
47 #define MRSHPC_MW0CR2 (PA_MRSHPC + 22)
48 #define MRSHPC_MW1CR2 (PA_MRSHPC + 24)
49 #define MRSHPC_IOWCR2 (PA_MRSHPC + 26)
50 #define MRSHPC_CDCR (PA_MRSHPC + 28)
51 #define MRSHPC_PCIC_INFO (PA_MRSHPC + 30)
53 #define PA_LED (PA_PERIPHERAL + 0x00800000) /* 8bit LED */
54 #define PA_FPGA (PA_PERIPHERAL + 0x01800000) /* FPGA base address */
56 #define PA_LAN (PA_AREA6_IO + 0) /* SMC LAN91C111 */
57 /* GPIO */
58 #define MSTPCR0 0xA4150030UL
59 #define MSTPCR1 0xA4150034UL
60 #define MSTPCR2 0xA4150038UL
62 #define FPGA_IN 0xb1840000UL
63 #define FPGA_OUT 0xb1840004UL
65 #define PORT_PECR 0xA4050108UL
66 #define PORT_PJCR 0xA4050110UL
67 #define PORT_PSELD 0xA4050154UL
68 #define PORT_PSELB 0xA4050150UL
70 #define PORT_PSELC 0xA4050152UL
71 #define PORT_PKCR 0xA4050112UL
72 #define PORT_PHCR 0xA405010EUL
73 #define PORT_PLCR 0xA4050114UL
74 #define PORT_PMCR 0xA4050116UL
75 #define PORT_PRCR 0xA405011CUL
76 #define PORT_PXCR 0xA4050148UL
77 #define PORT_PSELA 0xA405014EUL
78 #define PORT_PYCR 0xA405014AUL
79 #define PORT_PZCR 0xA405014CUL
81 /* IRQ */
82 #define IRQ0_IRQ 32
83 #define IRQ1_IRQ 33
85 #define IRQ01_MODE 0xb1800000
86 #define IRQ01_STS 0xb1800004
87 #define IRQ01_MASK 0xb1800008
89 /* Bits in IRQ01_* registers */
91 #define SE7722_FPGA_IRQ_USB 0 /* IRQ0 */
92 #define SE7722_FPGA_IRQ_SMC 1 /* IRQ0 */
93 #define SE7722_FPGA_IRQ_MRSHPC0 2 /* IRQ1 */
94 #define SE7722_FPGA_IRQ_MRSHPC1 3 /* IRQ1 */
95 #define SE7722_FPGA_IRQ_MRSHPC2 4 /* IRQ1 */
96 #define SE7722_FPGA_IRQ_MRSHPC3 5 /* IRQ1 */
98 #define SE7722_FPGA_IRQ_NR 6
99 #define SE7722_FPGA_IRQ_BASE 110
101 #define MRSHPC_IRQ3 (SE7722_FPGA_IRQ_BASE + SE7722_FPGA_IRQ_MRSHPC3)
102 #define MRSHPC_IRQ2 (SE7722_FPGA_IRQ_BASE + SE7722_FPGA_IRQ_MRSHPC2)
103 #define MRSHPC_IRQ1 (SE7722_FPGA_IRQ_BASE + SE7722_FPGA_IRQ_MRSHPC1)
104 #define MRSHPC_IRQ0 (SE7722_FPGA_IRQ_BASE + SE7722_FPGA_IRQ_MRSHPC0)
105 #define SMC_IRQ (SE7722_FPGA_IRQ_BASE + SE7722_FPGA_IRQ_SMC)
106 #define USB_IRQ (SE7722_FPGA_IRQ_BASE + SE7722_FPGA_IRQ_USB)
108 /* arch/sh/boards/se/7722/irq.c */
109 void init_se7722_IRQ(void);
111 #define __IO_PREFIX se7722
112 #include <asm/io_generic.h>
114 #endif /* __ASM_SH_SE7722_H */