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
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
,
74 DB1200_PC0_STSCHG_INT
,
76 DB1200_PC1_STSCHG_INT
,
79 DB1200_PC0_INSERT_INT
,
81 DB1200_PC1_INSERT_INT
,
83 DB1200_SD0_INSERT_INT
,
85 PB1200_SD1_INSERT_INT
,
88 DB1200_INT_END
= DB1200_INT_BEGIN
+ 15,
91 #endif /* __ASM_DB1200_H */