Linux Kernel  3.7.1
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
se7780.h
Go to the documentation of this file.
1 #ifndef __ASM_SH_SE7780_H
2 #define __ASM_SH_SE7780_H
3 
4 /*
5  * linux/include/asm-sh/se7780.h
6  *
7  * Copyright (C) 2006,2007 Nobuhiro Iwamatsu
8  *
9  * Hitachi UL SolutionEngine 7780 Support.
10  *
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.
14  */
15 #include <linux/sh_intc.h>
16 #include <asm/addrspace.h>
17 
18 /* Box specific addresses. */
19 #define SE_AREA0_WIDTH 4 /* Area0: 32bit */
20 #define PA_ROM 0xa0000000 /* EPROM */
21 #define PA_ROM_SIZE 0x00400000 /* EPROM size 4M 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_SM501 PA_EXT1 /* Graphic IC (SM501) */
27 #define PA_SM501_SIZE PA_EXT1_SIZE /* Graphic IC (SM501) */
28 #define PA_SDRAM 0xa8000000 /* DDR-SDRAM(Area2/3) 128MB */
29 #define PA_SDRAM_SIZE 0x08000000
30 
31 #define PA_EXT4 0xb0000000
32 #define PA_EXT4_SIZE 0x04000000
33 #define PA_EXT_FLASH PA_EXT4 /* Expansion Flash-ROM */
34 
35 #define PA_PERIPHERAL PA_AREA6_IO /* SW6-6=ON */
36 
37 #define PA_LAN (PA_PERIPHERAL + 0) /* SMC LAN91C111 */
38 #define PA_LED_DISP (PA_PERIPHERAL + 0x02000000) /* 8words LED Display */
39 #define DISP_CHAR_RAM (7 << 3)
40 #define DISP_SEL0_ADDR (DISP_CHAR_RAM + 0)
41 #define DISP_SEL1_ADDR (DISP_CHAR_RAM + 1)
42 #define DISP_SEL2_ADDR (DISP_CHAR_RAM + 2)
43 #define DISP_SEL3_ADDR (DISP_CHAR_RAM + 3)
44 #define DISP_SEL4_ADDR (DISP_CHAR_RAM + 4)
45 #define DISP_SEL5_ADDR (DISP_CHAR_RAM + 5)
46 #define DISP_SEL6_ADDR (DISP_CHAR_RAM + 6)
47 #define DISP_SEL7_ADDR (DISP_CHAR_RAM + 7)
48 
49 #define DISP_UDC_RAM (5 << 3)
50 #define PA_FPGA (PA_PERIPHERAL + 0x03000000) /* FPGA base address */
51 
52 /* FPGA register address and bit */
53 #define FPGA_SFTRST (PA_FPGA + 0) /* Soft reset register */
54 #define FPGA_INTMSK1 (PA_FPGA + 2) /* Interrupt Mask register 1 */
55 #define FPGA_INTMSK2 (PA_FPGA + 4) /* Interrupt Mask register 2 */
56 #define FPGA_INTSEL1 (PA_FPGA + 6) /* Interrupt select register 1 */
57 #define FPGA_INTSEL2 (PA_FPGA + 8) /* Interrupt select register 2 */
58 #define FPGA_INTSEL3 (PA_FPGA + 10) /* Interrupt select register 3 */
59 #define FPGA_PCI_INTSEL1 (PA_FPGA + 12) /* PCI Interrupt select register 1 */
60 #define FPGA_PCI_INTSEL2 (PA_FPGA + 14) /* PCI Interrupt select register 2 */
61 #define FPGA_INTSET (PA_FPGA + 16) /* IRQ/IRL select register */
62 #define FPGA_INTSTS1 (PA_FPGA + 18) /* Interrupt status register 1 */
63 #define FPGA_INTSTS2 (PA_FPGA + 20) /* Interrupt status register 2 */
64 #define FPGA_REQSEL (PA_FPGA + 22) /* REQ/GNT select register */
65 #define FPGA_DBG_LED (PA_FPGA + 32) /* Debug LED(D-LED[8:1] */
66 #define PA_LED FPGA_DBG_LED
67 #define FPGA_IVDRID (PA_FPGA + 36) /* iVDR ID Register */
68 #define FPGA_IVDRPW (PA_FPGA + 38) /* iVDR Power ON Register */
69 #define FPGA_MMCID (PA_FPGA + 40) /* MMC ID Register */
70 
71 /* FPGA INTSEL position */
72 /* INTSEL1 */
73 #define IRQPOS_SMC91CX (0 * 4)
74 #define IRQPOS_SM501 (1 * 4)
75 /* INTSEL2 */
76 #define IRQPOS_EXTINT1 (0 * 4)
77 #define IRQPOS_EXTINT2 (1 * 4)
78 #define IRQPOS_EXTINT3 (2 * 4)
79 #define IRQPOS_EXTINT4 (3 * 4)
80 /* INTSEL3 */
81 #define IRQPOS_PCCPW (0 * 4)
82 
83 /* IDE interrupt */
84 #define IRQ_IDE0 evt2irq(0xa60) /* iVDR */
85 
86 /* SMC interrupt */
87 #define SMC_IRQ evt2irq(0x300)
88 
89 /* SM501 interrupt */
90 #define SM501_IRQ evt2irq(0x200)
91 
92 /* interrupt pin */
93 #define IRQPIN_EXTINT1 0 /* IRQ0 pin */
94 #define IRQPIN_EXTINT2 1 /* IRQ1 pin */
95 #define IRQPIN_EXTINT3 2 /* IRQ2 pin */
96 #define IRQPIN_SMC91CX 3 /* IRQ3 pin */
97 #define IRQPIN_EXTINT4 4 /* IRQ4 pin */
98 #define IRQPIN_PCC0 5 /* IRQ5 pin */
99 #define IRQPIN_PCC2 6 /* IRQ6 pin */
100 #define IRQPIN_SM501 7 /* IRQ7 pin */
101 #define IRQPIN_PCCPW 7 /* IRQ7 pin */
102 
103 /* arch/sh/boards/se/7780/irq.c */
104 void init_se7780_IRQ(void);
105 
106 #define __IO_PREFIX se7780
107 #include <asm/io_generic.h>
108 
109 #endif /* __ASM_SH_SE7780_H */