imx31reg.h revision 1.2 1 /* $NetBSD: imx31reg.h,v 1.2 2008/04/27 18:58:44 matt Exp $ */
2 /*-
3 * Copyright (c) 2007 The NetBSD Foundation, Inc.
4 * All rights reserved.
5 *
6 * This code is derived from software contributed to The NetBSD Foundation
7 * by Matt Thomas.
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions
11 * are met:
12 * 1. Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in the
16 * documentation and/or other materials provided with the distribution.
17 * 3. All advertising materials mentioning features or use of this software
18 * must display the following acknowledgement:
19 * This product includes software developed by the NetBSD
20 * Foundation, Inc. and its contributors.
21 * 4. Neither the name of The NetBSD Foundation nor the names of its
22 * contributors may be used to endorse or promote products derived
23 * from this software without specific prior written permission.
24 *
25 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
26 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
27 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
29 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
30 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
31 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
32 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
33 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
34 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
35 * POSSIBILITY OF SUCH DAMAGE.
36 */
37
38 #ifndef _ARM_IMX_IMX31REG_H_
39 #define _ARM_IMX_IMX31REG_H_
40
41 #define I2C1_BASE 0x43f80000
42 #define I2C2_BASE 0x43f90000
43 #define I2C3_BASE 0x43f84000
44
45 #define I2C_IADR 0x0000 /* I2C Address */
46 #define I2C_IFDR 0x0004 /* I2C Frequency Divider */
47 #define I2C_I2CR 0x0008 /* I2C Control */
48 #define I2C_I2SR 0x000c /* I2C Status */
49 #define I2C_I2DR 0x0010 /* I2C Data I/O */
50
51 #define ATA_BASE 0x43f8c000
52 #define ATA_DMA_BASE 0x50020000
53
54 #define UART1_BASE 0x43f90000
55 #define UART2_BASE 0x43f94000
56 #define UART3_BASE 0x5000c000
57 #define UART4_BASE 0x43fb0000
58 #define UART5_BASE 0x43fb4000
59
60 #define CSPI1_BASE 0x43fa4000
61 #define CSPI2_BASE 0x50010000
62
63 #define GPIO1_BASE 0x53fcc000
64 #define GPIO2_BASE 0x53fd0000
65 #define GPIO3_BASE 0x53fa4000
66
67 #define GPIO_SIZE 0x0100 /* Size of GPIO registers */
68
69 #define GPIO_DR 0x0000 /* GPIO Data (RW) */
70 #define GPIO_DIR 0x0004 /* GPIO Direction (RW), 1=Output */
71 #define GPIO_PSR 0x0008 /* GPIO Pad Status (R) */
72 #define GPIO_ICR1 0x000c /* GPIO Interrupt Configuration 1 (RW) */
73 #define GPIO_ICR2 0x0010 /* GPIO Interrupt Configuration 2 (RW) */
74 #define GPIO_IMR 0x0014 /* GPIO Interrupt Mask (RW) */
75 #define GPIO_ISR 0x0018 /* GPIO Interrupt Status (RW, W1C) */
76
77 #define GPIO_ICR_LEVEL_LOW 0
78 #define GPIO_ICR_LEVEL_HIGH 1
79 #define GPIO_ICR_EDGE_RISING 2
80 #define GPIO_ICR_EDGE_FALLING 3
81
82 #define INTC_BASE 0x68000000
83 #define INTC_SIZE 0x0400
84 #define IMX31_INTCNTL 0x0000 /* Interrupt Control (RW) */
85 #define IMX31_NIMASK 0x0004 /* Normal Interrupt Mask (RW) */
86 #define IMX31_INTENNUM 0x0008 /* Interrupt Enable Number (RW) */
87 #define IMX31_INTDISNUM 0x000c /* Interrupt Disable Number (RW) */
88 #define IMX31_INTENABLEH 0x0010 /* Interrupt Enable High (RW) */
89 #define IMX31_INTENABLEL 0x0014 /* Interrupt Enable Low (RW) */
90 #define IMX31_INTTYPEH 0x0018 /* Interrupt Type High (RW) */
91 #define IMX31_INTTYPEL 0x001c /* Interrupt Type Low (RW) */
92 #define IMX31_NIPRIORITY7 0x0020 /* Normal Intr Priority Level 7 (RW) */
93 #define IMX31_NIPRIORITY6 0x0024 /* Normal Intr Priority Level 6 (RW) */
94 #define IMX31_NIPRIORITY5 0x0028 /* Normal Intr Priority Level 5 (RW) */
95 #define IMX31_NIPRIORITY4 0x002c /* Normal Intr Priority Level 4 (RW) */
96 #define IMX31_NIPRIORITY3 0x0030 /* Normal Intr Priority Level 3 (RW) */
97 #define IMX31_NIPRIORITY2 0x0034 /* Normal Intr Priority Level 2 (RW) */
98 #define IMX31_NIPRIORITY1 0x0038 /* Normal Intr Priority Level 1 (RW) */
99 #define IMX31_NIPRIORITY0 0x003c /* Normal Intr Priority Level 0 (RW) */
100 #define IMX31_NIVECSR 0x0040 /* Normal Interrupt Vector Status (R) */
101 #define IMX31_FIVECSR 0x0044 /* Fast Interrupt Vector Status (R) */
102 #define IMX31_INTSRCH 0x0048 /* Interrupt Source High (R) */
103 #define IMX31_INTSRCL 0x004c /* Interrupt Source Low (R) */
104 #define IMX31_INTFRCH 0x0050 /* Interrupt Force High (RW) */
105 #define IMX31_INTFRCL 0x0054 /* Interrupt Force Low (RW) */
106 #define IMX31_NIPNDH 0x0058 /* Normal Intr Pending High (R) */
107 #define IMX31_NIPNDL 0x005c /* Normal Intr Pending Low (R) */
108 #define IMX31_FIPNDH 0x0060 /* Fast Intr Pending High (R) */
109 #define IMX31_FIPNDL 0x0064 /* Fast Intr Pending Low (R) */
110
111 #define IMX31_VECTOR(n) (0x0100 + (n) * 4) /* Vector [N] */
112
113 #define INTCNTL_ABFLAG (1 << 25) /* Core Arb. Priorty Risen (W1C) */
114 #define INTCNTL_ABFEN (1 << 24) /* ABFLAG Sticky Enable */
115 #define INTCNTL_NIDIS (1 << 22) /* Normal Intr. Disable */
116 #define INTCNTL_FIDIS (1 << 21) /* Fast Intr. Disable */
117 #define INTCNTL_NIAD (1 << 20) /* Normal Intr. Arbiter Rise ARM Lvl */
118 #define INTCNTL_FIAD (1 << 19) /* Fast Intr. Arbiter Rise ARM Level */
119 #define INTCNTL_NM (1 << 18) /* Normal Intr. Mode Control (1=AVIC) */
120
121 #define NIMASK_DIS_NONE -1
122
123 /*
124 * INTTYPE (0 = IRQ, 1 = FIQ)
125 */
126
127 #endif /* _ARM_IMX_IMX31REG_H_ */
128