Merge tag 'v3.3.7' into 3.3/master
[zen-stable.git] / arch / mips / include / asm / mach-db1x00 / db1200.h
blobb2a8319521e5ed253d4f18d6c513968dd8cd1b7d
1 /*
2 * AMD Alchemy DBAu1200 Reference Board
3 * Board register defines.
5 * ########################################################################
7 * This program is free software; you can distribute it and/or modify it
8 * under the terms of the GNU General Public License (Version 2) as
9 * published by the Free Software Foundation.
11 * This program is distributed in the hope it will be useful, but WITHOUT
12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 * for more details.
16 * You should have received a copy of the GNU General Public License along
17 * with this program; if not, write to the Free Software Foundation, Inc.,
18 * 59 Temple Place - Suite 330, Boston MA 02111-1307, USA.
20 * ########################################################################
24 #ifndef __ASM_DB1200_H
25 #define __ASM_DB1200_H
27 #include <linux/types.h>
28 #include <asm/mach-au1x00/au1000.h>
29 #include <asm/mach-au1x00/au1xxx_psc.h>
31 /* Bit positions for the different interrupt sources */
32 #define BCSR_INT_IDE 0x0001
33 #define BCSR_INT_ETH 0x0002
34 #define BCSR_INT_PC0 0x0004
35 #define BCSR_INT_PC0STSCHG 0x0008
36 #define BCSR_INT_PC1 0x0010
37 #define BCSR_INT_PC1STSCHG 0x0020
38 #define BCSR_INT_DC 0x0040
39 #define BCSR_INT_FLASHBUSY 0x0080
40 #define BCSR_INT_PC0INSERT 0x0100
41 #define BCSR_INT_PC0EJECT 0x0200
42 #define BCSR_INT_PC1INSERT 0x0400
43 #define BCSR_INT_PC1EJECT 0x0800
44 #define BCSR_INT_SD0INSERT 0x1000
45 #define BCSR_INT_SD0EJECT 0x2000
46 #define BCSR_INT_SD1INSERT 0x4000
47 #define BCSR_INT_SD1EJECT 0x8000
49 #define IDE_REG_SHIFT 5
51 #define DB1200_IDE_PHYS_ADDR 0x18800000
52 #define DB1200_IDE_PHYS_LEN (16 << IDE_REG_SHIFT)
53 #define DB1200_ETH_PHYS_ADDR 0x19000300
54 #define DB1200_NAND_PHYS_ADDR 0x20000000
56 #define PB1200_IDE_PHYS_ADDR 0x0C800000
57 #define PB1200_ETH_PHYS_ADDR 0x0D000300
58 #define PB1200_NAND_PHYS_ADDR 0x1C000000
61 * External Interrupts for DBAu1200 as of 8/6/2004.
62 * Bit positions in the CPLD registers can be calculated by taking
63 * the interrupt define and subtracting the DB1200_INT_BEGIN value.
65 * Example: IDE bis pos is = 64 - 64
66 * ETH bit pos is = 65 - 64
68 enum external_db1200_ints {
69 DB1200_INT_BEGIN = AU1000_MAX_INTR + 1,
71 DB1200_IDE_INT = DB1200_INT_BEGIN,
72 DB1200_ETH_INT,
73 DB1200_PC0_INT,
74 DB1200_PC0_STSCHG_INT,
75 DB1200_PC1_INT,
76 DB1200_PC1_STSCHG_INT,
77 DB1200_DC_INT,
78 DB1200_FLASHBUSY_INT,
79 DB1200_PC0_INSERT_INT,
80 DB1200_PC0_EJECT_INT,
81 DB1200_PC1_INSERT_INT,
82 DB1200_PC1_EJECT_INT,
83 DB1200_SD0_INSERT_INT,
84 DB1200_SD0_EJECT_INT,
85 PB1200_SD1_INSERT_INT,
86 PB1200_SD1_EJECT_INT,
88 DB1200_INT_END = DB1200_INT_BEGIN + 15,
91 #endif /* __ASM_DB1200_H */