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