diff options
author | Dinh Nguyen <Dinh.Nguyen@freescale.com> | 2010-11-15 12:29:59 -0500 |
---|---|---|
committer | Sascha Hauer <s.hauer@pengutronix.de> | 2010-11-24 04:09:04 -0500 |
commit | c0abefd30b2c9db015df4914a95d268ecdb39b00 (patch) | |
tree | 810c6f6e8e00604a78379424a6aae2140d7fadd5 /arch | |
parent | 374daa4f9019f75da1addb3f31a22df1966a5baa (diff) |
ARM: imx: Add core definitions for MX53
Add iomux, clocks, and memory map for Freescale's MX53 SoC.
Add cpu_is_mx53 function to common.h.
Add 3 more banks of gpio's to mxc_gpio_ports.
Add MX53 phys offset address.
Signed-off-by: Dinh Nguyen <Dinh.Nguyen@freescale.com>
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/arm/mach-mx5/Makefile | 2 | ||||
-rw-r--r-- | arch/arm/mach-mx5/clock-mx51-mx53.c (renamed from arch/arm/mach-mx5/clock-mx51.c) | 59 | ||||
-rw-r--r-- | arch/arm/mach-mx5/cpu.c | 43 | ||||
-rw-r--r-- | arch/arm/mach-mx5/crm_regs.h | 6 | ||||
-rw-r--r-- | arch/arm/mach-mx5/devices.c | 27 | ||||
-rw-r--r-- | arch/arm/mach-mx5/mm.c | 17 | ||||
-rw-r--r-- | arch/arm/plat-mxc/include/mach/common.h | 5 | ||||
-rw-r--r-- | arch/arm/plat-mxc/include/mach/hardware.h | 1 | ||||
-rw-r--r-- | arch/arm/plat-mxc/include/mach/iomux-mx53.h | 303 | ||||
-rw-r--r-- | arch/arm/plat-mxc/include/mach/memory.h | 5 | ||||
-rw-r--r-- | arch/arm/plat-mxc/include/mach/mx53.h | 353 | ||||
-rw-r--r-- | arch/arm/plat-mxc/include/mach/mxc.h | 2 |
12 files changed, 797 insertions, 26 deletions
diff --git a/arch/arm/mach-mx5/Makefile b/arch/arm/mach-mx5/Makefile index 462f177eddfe..026cd850df28 100644 --- a/arch/arm/mach-mx5/Makefile +++ b/arch/arm/mach-mx5/Makefile | |||
@@ -3,7 +3,7 @@ | |||
3 | # | 3 | # |
4 | 4 | ||
5 | # Object file lists. | 5 | # Object file lists. |
6 | obj-y := cpu.o mm.o clock-mx51.o devices.o | 6 | obj-y := cpu.o mm.o clock-mx51-mx53.o devices.o |
7 | 7 | ||
8 | obj-$(CONFIG_CPU_FREQ_IMX) += cpu_op-mx51.o | 8 | obj-$(CONFIG_CPU_FREQ_IMX) += cpu_op-mx51.o |
9 | obj-$(CONFIG_MACH_MX51_BABBAGE) += board-mx51_babbage.o | 9 | obj-$(CONFIG_MACH_MX51_BABBAGE) += board-mx51_babbage.o |
diff --git a/arch/arm/mach-mx5/clock-mx51.c b/arch/arm/mach-mx5/clock-mx51-mx53.c index 8ac36d882927..ca4f9d58cfeb 100644 --- a/arch/arm/mach-mx5/clock-mx51.c +++ b/arch/arm/mach-mx5/clock-mx51-mx53.c | |||
@@ -33,6 +33,7 @@ static struct clk pll1_main_clk; | |||
33 | static struct clk pll1_sw_clk; | 33 | static struct clk pll1_sw_clk; |
34 | static struct clk pll2_sw_clk; | 34 | static struct clk pll2_sw_clk; |
35 | static struct clk pll3_sw_clk; | 35 | static struct clk pll3_sw_clk; |
36 | static struct clk mx53_pll4_sw_clk; | ||
36 | static struct clk lp_apm_clk; | 37 | static struct clk lp_apm_clk; |
37 | static struct clk periph_apm_clk; | 38 | static struct clk periph_apm_clk; |
38 | static struct clk ahb_clk; | 39 | static struct clk ahb_clk; |
@@ -131,6 +132,8 @@ static inline void __iomem *_get_pll_base(struct clk *pll) | |||
131 | return MX51_DPLL2_BASE; | 132 | return MX51_DPLL2_BASE; |
132 | else if (pll == &pll3_sw_clk) | 133 | else if (pll == &pll3_sw_clk) |
133 | return MX51_DPLL3_BASE; | 134 | return MX51_DPLL3_BASE; |
135 | else if (pll == &mx53_pll4_sw_clk) | ||
136 | return MX53_DPLL4_BASE; | ||
134 | else | 137 | else |
135 | BUG(); | 138 | BUG(); |
136 | 139 | ||
@@ -514,7 +517,10 @@ static int _clk_max_enable(struct clk *clk) | |||
514 | 517 | ||
515 | /* Handshake with MAX when LPM is entered. */ | 518 | /* Handshake with MAX when LPM is entered. */ |
516 | reg = __raw_readl(MXC_CCM_CLPCR); | 519 | reg = __raw_readl(MXC_CCM_CLPCR); |
517 | reg &= ~MXC_CCM_CLPCR_BYPASS_MAX_LPM_HS; | 520 | if (cpu_is_mx51()) |
521 | reg &= ~MX51_CCM_CLPCR_BYPASS_MAX_LPM_HS; | ||
522 | else if (cpu_is_mx53()) | ||
523 | reg &= ~MX53_CCM_CLPCR_BYPASS_MAX_LPM_HS; | ||
518 | __raw_writel(reg, MXC_CCM_CLPCR); | 524 | __raw_writel(reg, MXC_CCM_CLPCR); |
519 | 525 | ||
520 | return 0; | 526 | return 0; |
@@ -528,7 +534,10 @@ static void _clk_max_disable(struct clk *clk) | |||
528 | 534 | ||
529 | /* No Handshake with MAX when LPM is entered as its disabled. */ | 535 | /* No Handshake with MAX when LPM is entered as its disabled. */ |
530 | reg = __raw_readl(MXC_CCM_CLPCR); | 536 | reg = __raw_readl(MXC_CCM_CLPCR); |
531 | reg |= MXC_CCM_CLPCR_BYPASS_MAX_LPM_HS; | 537 | if (cpu_is_mx51()) |
538 | reg |= MX51_CCM_CLPCR_BYPASS_MAX_LPM_HS; | ||
539 | else if (cpu_is_mx53()) | ||
540 | reg &= ~MX53_CCM_CLPCR_BYPASS_MAX_LPM_HS; | ||
532 | __raw_writel(reg, MXC_CCM_CLPCR); | 541 | __raw_writel(reg, MXC_CCM_CLPCR); |
533 | } | 542 | } |
534 | 543 | ||
@@ -739,6 +748,14 @@ static struct clk pll3_sw_clk = { | |||
739 | .disable = _clk_pll_disable, | 748 | .disable = _clk_pll_disable, |
740 | }; | 749 | }; |
741 | 750 | ||
751 | /* PLL4 SW supplies to LVDS Display Bridge(LDB) */ | ||
752 | static struct clk mx53_pll4_sw_clk = { | ||
753 | .parent = &osc_clk, | ||
754 | .set_rate = _clk_pll_set_rate, | ||
755 | .enable = _clk_pll_enable, | ||
756 | .disable = _clk_pll_disable, | ||
757 | }; | ||
758 | |||
742 | /* Low-power Audio Playback Mode clock */ | 759 | /* Low-power Audio Playback Mode clock */ |
743 | static struct clk lp_apm_clk = { | 760 | static struct clk lp_apm_clk = { |
744 | .parent = &osc_clk, | 761 | .parent = &osc_clk, |
@@ -1053,7 +1070,7 @@ DEFINE_CLOCK_MAX(esdhc2_clk, 1, MXC_CCM_CCGR3, MXC_CCM_CCGRx_CG3_OFFSET, | |||
1053 | .clk = &c, \ | 1070 | .clk = &c, \ |
1054 | }, | 1071 | }, |
1055 | 1072 | ||
1056 | static struct clk_lookup lookups[] = { | 1073 | static struct clk_lookup mx51_lookups[] = { |
1057 | _REGISTER_CLOCK("imx-uart.0", NULL, uart1_clk) | 1074 | _REGISTER_CLOCK("imx-uart.0", NULL, uart1_clk) |
1058 | _REGISTER_CLOCK("imx-uart.1", NULL, uart2_clk) | 1075 | _REGISTER_CLOCK("imx-uart.1", NULL, uart2_clk) |
1059 | _REGISTER_CLOCK("imx-uart.2", NULL, uart3_clk) | 1076 | _REGISTER_CLOCK("imx-uart.2", NULL, uart3_clk) |
@@ -1084,6 +1101,14 @@ static struct clk_lookup lookups[] = { | |||
1084 | _REGISTER_CLOCK(NULL, "cpu_clk", cpu_clk) | 1101 | _REGISTER_CLOCK(NULL, "cpu_clk", cpu_clk) |
1085 | }; | 1102 | }; |
1086 | 1103 | ||
1104 | static struct clk_lookup mx53_lookups[] = { | ||
1105 | _REGISTER_CLOCK("imx-uart.0", NULL, uart1_clk) | ||
1106 | _REGISTER_CLOCK("imx-uart.1", NULL, uart2_clk) | ||
1107 | _REGISTER_CLOCK("imx-uart.2", NULL, uart3_clk) | ||
1108 | _REGISTER_CLOCK(NULL, "gpt", gpt_clk) | ||
1109 | _REGISTER_CLOCK("fec.0", NULL, fec_clk) | ||
1110 | }; | ||
1111 | |||
1087 | static void clk_tree_init(void) | 1112 | static void clk_tree_init(void) |
1088 | { | 1113 | { |
1089 | u32 reg; | 1114 | u32 reg; |
@@ -1114,8 +1139,8 @@ int __init mx51_clocks_init(unsigned long ckil, unsigned long osc, | |||
1114 | ckih2_reference = ckih2; | 1139 | ckih2_reference = ckih2; |
1115 | oscillator_reference = osc; | 1140 | oscillator_reference = osc; |
1116 | 1141 | ||
1117 | for (i = 0; i < ARRAY_SIZE(lookups); i++) | 1142 | for (i = 0; i < ARRAY_SIZE(mx51_lookups); i++) |
1118 | clkdev_add(&lookups[i]); | 1143 | clkdev_add(&mx51_lookups[i]); |
1119 | 1144 | ||
1120 | clk_tree_init(); | 1145 | clk_tree_init(); |
1121 | 1146 | ||
@@ -1138,3 +1163,27 @@ int __init mx51_clocks_init(unsigned long ckil, unsigned long osc, | |||
1138 | MX51_MXC_INT_GPT); | 1163 | MX51_MXC_INT_GPT); |
1139 | return 0; | 1164 | return 0; |
1140 | } | 1165 | } |
1166 | |||
1167 | int __init mx53_clocks_init(unsigned long ckil, unsigned long osc, | ||
1168 | unsigned long ckih1, unsigned long ckih2) | ||
1169 | { | ||
1170 | int i; | ||
1171 | |||
1172 | external_low_reference = ckil; | ||
1173 | external_high_reference = ckih1; | ||
1174 | ckih2_reference = ckih2; | ||
1175 | oscillator_reference = osc; | ||
1176 | |||
1177 | for (i = 0; i < ARRAY_SIZE(mx53_lookups); i++) | ||
1178 | clkdev_add(&mx53_lookups[i]); | ||
1179 | |||
1180 | clk_tree_init(); | ||
1181 | |||
1182 | clk_enable(&cpu_clk); | ||
1183 | clk_enable(&main_bus_clk); | ||
1184 | |||
1185 | /* System timer */ | ||
1186 | mxc_timer_init(&gpt_clk, MX53_IO_ADDRESS(MX53_GPT1_BASE_ADDR), | ||
1187 | MX53_INT_GPT); | ||
1188 | return 0; | ||
1189 | } | ||
diff --git a/arch/arm/mach-mx5/cpu.c b/arch/arm/mach-mx5/cpu.c index 061ab701b6d9..8c9a29e322dc 100644 --- a/arch/arm/mach-mx5/cpu.c +++ b/arch/arm/mach-mx5/cpu.c | |||
@@ -97,24 +97,31 @@ static int __init post_cpu_init(void) | |||
97 | unsigned int reg; | 97 | unsigned int reg; |
98 | void __iomem *base; | 98 | void __iomem *base; |
99 | 99 | ||
100 | if (!cpu_is_mx51()) | 100 | if (cpu_is_mx51() || cpu_is_mx53()) { |
101 | return 0; | 101 | if (cpu_is_mx51()) |
102 | 102 | base = MX51_IO_ADDRESS(MX51_AIPS1_BASE_ADDR); | |
103 | base = MX51_IO_ADDRESS(MX51_AIPS1_BASE_ADDR); | 103 | else |
104 | __raw_writel(0x0, base + 0x40); | 104 | base = MX53_IO_ADDRESS(MX53_AIPS1_BASE_ADDR); |
105 | __raw_writel(0x0, base + 0x44); | 105 | |
106 | __raw_writel(0x0, base + 0x48); | 106 | __raw_writel(0x0, base + 0x40); |
107 | __raw_writel(0x0, base + 0x4C); | 107 | __raw_writel(0x0, base + 0x44); |
108 | reg = __raw_readl(base + 0x50) & 0x00FFFFFF; | 108 | __raw_writel(0x0, base + 0x48); |
109 | __raw_writel(reg, base + 0x50); | 109 | __raw_writel(0x0, base + 0x4C); |
110 | 110 | reg = __raw_readl(base + 0x50) & 0x00FFFFFF; | |
111 | base = MX51_IO_ADDRESS(MX51_AIPS2_BASE_ADDR); | 111 | __raw_writel(reg, base + 0x50); |
112 | __raw_writel(0x0, base + 0x40); | 112 | |
113 | __raw_writel(0x0, base + 0x44); | 113 | if (cpu_is_mx51()) |
114 | __raw_writel(0x0, base + 0x48); | 114 | base = MX51_IO_ADDRESS(MX51_AIPS2_BASE_ADDR); |
115 | __raw_writel(0x0, base + 0x4C); | 115 | else |
116 | reg = __raw_readl(base + 0x50) & 0x00FFFFFF; | 116 | base = MX53_IO_ADDRESS(MX53_AIPS2_BASE_ADDR); |
117 | __raw_writel(reg, base + 0x50); | 117 | |
118 | __raw_writel(0x0, base + 0x40); | ||
119 | __raw_writel(0x0, base + 0x44); | ||
120 | __raw_writel(0x0, base + 0x48); | ||
121 | __raw_writel(0x0, base + 0x4C); | ||
122 | reg = __raw_readl(base + 0x50) & 0x00FFFFFF; | ||
123 | __raw_writel(reg, base + 0x50); | ||
124 | } | ||
118 | 125 | ||
119 | return 0; | 126 | return 0; |
120 | } | 127 | } |
diff --git a/arch/arm/mach-mx5/crm_regs.h b/arch/arm/mach-mx5/crm_regs.h index c776b9af0624..51ff9bb02379 100644 --- a/arch/arm/mach-mx5/crm_regs.h +++ b/arch/arm/mach-mx5/crm_regs.h | |||
@@ -18,6 +18,9 @@ | |||
18 | #define MX51_CORTEXA8_BASE MX51_IO_ADDRESS(MX51_ARM_BASE_ADDR) | 18 | #define MX51_CORTEXA8_BASE MX51_IO_ADDRESS(MX51_ARM_BASE_ADDR) |
19 | #define MX51_GPC_BASE MX51_IO_ADDRESS(MX51_GPC_BASE_ADDR) | 19 | #define MX51_GPC_BASE MX51_IO_ADDRESS(MX51_GPC_BASE_ADDR) |
20 | 20 | ||
21 | /*MX53*/ | ||
22 | #define MX53_DPLL4_BASE MX53_IO_ADDRESS(MX53_PLL3_BASE_ADDR) | ||
23 | |||
21 | /* PLL Register Offsets */ | 24 | /* PLL Register Offsets */ |
22 | #define MXC_PLL_DP_CTL 0x00 | 25 | #define MXC_PLL_DP_CTL 0x00 |
23 | #define MXC_PLL_DP_CONFIG 0x04 | 26 | #define MXC_PLL_DP_CONFIG 0x04 |
@@ -380,7 +383,8 @@ | |||
380 | /* Define the bits in register CLPCR */ | 383 | /* Define the bits in register CLPCR */ |
381 | #define MXC_CCM_CLPCR_BYPASS_HSC_LPM_HS (0x1 << 23) | 384 | #define MXC_CCM_CLPCR_BYPASS_HSC_LPM_HS (0x1 << 23) |
382 | #define MXC_CCM_CLPCR_BYPASS_SCC_LPM_HS (0x1 << 22) | 385 | #define MXC_CCM_CLPCR_BYPASS_SCC_LPM_HS (0x1 << 22) |
383 | #define MXC_CCM_CLPCR_BYPASS_MAX_LPM_HS (0x1 << 21) | 386 | #define MX51_CCM_CLPCR_BYPASS_MAX_LPM_HS (0x1 << 21) |
387 | #define MX53_CCM_CLPCR_BYPASS_MAX_LPM_HS (0x1 << 25) | ||
384 | #define MXC_CCM_CLPCR_BYPASS_SDMA_LPM_HS (0x1 << 20) | 388 | #define MXC_CCM_CLPCR_BYPASS_SDMA_LPM_HS (0x1 << 20) |
385 | #define MXC_CCM_CLPCR_BYPASS_EMI_LPM_HS (0x1 << 19) | 389 | #define MXC_CCM_CLPCR_BYPASS_EMI_LPM_HS (0x1 << 19) |
386 | #define MXC_CCM_CLPCR_BYPASS_IPU_LPM_HS (0x1 << 18) | 390 | #define MXC_CCM_CLPCR_BYPASS_IPU_LPM_HS (0x1 << 18) |
diff --git a/arch/arm/mach-mx5/devices.c b/arch/arm/mach-mx5/devices.c index 4c7be87a7c9d..d926203023ec 100644 --- a/arch/arm/mach-mx5/devices.c +++ b/arch/arm/mach-mx5/devices.c | |||
@@ -160,9 +160,36 @@ static struct mxc_gpio_port mxc_gpio_ports[] = { | |||
160 | .irq_high = MX51_MXC_INT_GPIO4_HIGH, | 160 | .irq_high = MX51_MXC_INT_GPIO4_HIGH, |
161 | .virtual_irq_start = MXC_GPIO_IRQ_START + 32 * 3 | 161 | .virtual_irq_start = MXC_GPIO_IRQ_START + 32 * 3 |
162 | }, | 162 | }, |
163 | { | ||
164 | .chip.label = "gpio-4", | ||
165 | .base = MX53_IO_ADDRESS(MX53_GPIO5_BASE_ADDR), | ||
166 | .irq = MX53_INT_GPIO5_LOW, | ||
167 | .irq_high = MX53_INT_GPIO5_HIGH, | ||
168 | .virtual_irq_start = MXC_GPIO_IRQ_START + 32 * 4 | ||
169 | }, | ||
170 | { | ||
171 | .chip.label = "gpio-5", | ||
172 | .base = MX53_IO_ADDRESS(MX53_GPIO6_BASE_ADDR), | ||
173 | .irq = MX53_INT_GPIO6_LOW, | ||
174 | .irq_high = MX53_INT_GPIO6_HIGH, | ||
175 | .virtual_irq_start = MXC_GPIO_IRQ_START + 32 * 5 | ||
176 | }, | ||
177 | { | ||
178 | .chip.label = "gpio-6", | ||
179 | .base = MX53_IO_ADDRESS(MX53_GPIO7_BASE_ADDR), | ||
180 | .irq = MX53_INT_GPIO7_LOW, | ||
181 | .irq_high = MX53_INT_GPIO7_HIGH, | ||
182 | .virtual_irq_start = MXC_GPIO_IRQ_START + 32 * 6 | ||
183 | }, | ||
163 | }; | 184 | }; |
164 | 185 | ||
165 | int __init imx51_register_gpios(void) | 186 | int __init imx51_register_gpios(void) |
166 | { | 187 | { |
188 | return mxc_gpio_init(mxc_gpio_ports, 4); | ||
189 | } | ||
190 | |||
191 | int __init imx53_register_gpios(void) | ||
192 | { | ||
167 | return mxc_gpio_init(mxc_gpio_ports, ARRAY_SIZE(mxc_gpio_ports)); | 193 | return mxc_gpio_init(mxc_gpio_ports, ARRAY_SIZE(mxc_gpio_ports)); |
168 | } | 194 | } |
195 | |||
diff --git a/arch/arm/mach-mx5/mm.c b/arch/arm/mach-mx5/mm.c index 01dff26c1007..2822d0e6f23a 100644 --- a/arch/arm/mach-mx5/mm.c +++ b/arch/arm/mach-mx5/mm.c | |||
@@ -63,3 +63,20 @@ void __init mx51_init_irq(void) | |||
63 | tzic_init_irq(tzic_virt); | 63 | tzic_init_irq(tzic_virt); |
64 | imx51_register_gpios(); | 64 | imx51_register_gpios(); |
65 | } | 65 | } |
66 | |||
67 | int imx53_register_gpios(void); | ||
68 | |||
69 | void __init mx53_init_irq(void) | ||
70 | { | ||
71 | unsigned long tzic_addr; | ||
72 | void __iomem *tzic_virt; | ||
73 | |||
74 | tzic_addr = MX53_TZIC_BASE_ADDR; | ||
75 | |||
76 | tzic_virt = ioremap(tzic_addr, SZ_16K); | ||
77 | if (!tzic_virt) | ||
78 | panic("unable to map TZIC interrupt controller\n"); | ||
79 | |||
80 | tzic_init_irq(tzic_virt); | ||
81 | imx53_register_gpios(); | ||
82 | } | ||
diff --git a/arch/arm/plat-mxc/include/mach/common.h b/arch/arm/plat-mxc/include/mach/common.h index 05676fbd1d63..9d58ce5816a8 100644 --- a/arch/arm/plat-mxc/include/mach/common.h +++ b/arch/arm/plat-mxc/include/mach/common.h | |||
@@ -21,6 +21,7 @@ extern void mx27_map_io(void); | |||
21 | extern void mx31_map_io(void); | 21 | extern void mx31_map_io(void); |
22 | extern void mx35_map_io(void); | 22 | extern void mx35_map_io(void); |
23 | extern void mx51_map_io(void); | 23 | extern void mx51_map_io(void); |
24 | extern void mx53_map_io(void); | ||
24 | extern void mxc91231_map_io(void); | 25 | extern void mxc91231_map_io(void); |
25 | extern void mxc_init_irq(void __iomem *); | 26 | extern void mxc_init_irq(void __iomem *); |
26 | extern void tzic_init_irq(void __iomem *); | 27 | extern void tzic_init_irq(void __iomem *); |
@@ -31,6 +32,7 @@ extern void mx27_init_irq(void); | |||
31 | extern void mx31_init_irq(void); | 32 | extern void mx31_init_irq(void); |
32 | extern void mx35_init_irq(void); | 33 | extern void mx35_init_irq(void); |
33 | extern void mx51_init_irq(void); | 34 | extern void mx51_init_irq(void); |
35 | extern void mx53_init_irq(void); | ||
34 | extern void mxc91231_init_irq(void); | 36 | extern void mxc91231_init_irq(void); |
35 | extern void epit_timer_init(struct clk *timer_clk, void __iomem *base, int irq); | 37 | extern void epit_timer_init(struct clk *timer_clk, void __iomem *base, int irq); |
36 | extern void mxc_timer_init(struct clk *timer_clk, void __iomem *, int); | 38 | extern void mxc_timer_init(struct clk *timer_clk, void __iomem *, int); |
@@ -42,6 +44,8 @@ extern int mx31_clocks_init(unsigned long fref); | |||
42 | extern int mx35_clocks_init(void); | 44 | extern int mx35_clocks_init(void); |
43 | extern int mx51_clocks_init(unsigned long ckil, unsigned long osc, | 45 | extern int mx51_clocks_init(unsigned long ckil, unsigned long osc, |
44 | unsigned long ckih1, unsigned long ckih2); | 46 | unsigned long ckih1, unsigned long ckih2); |
47 | extern int mx53_clocks_init(unsigned long ckil, unsigned long osc, | ||
48 | unsigned long ckih1, unsigned long ckih2); | ||
45 | extern int mxc91231_clocks_init(unsigned long fref); | 49 | extern int mxc91231_clocks_init(unsigned long fref); |
46 | extern int mxc_register_gpios(void); | 50 | extern int mxc_register_gpios(void); |
47 | extern int mxc_register_device(struct platform_device *pdev, void *data); | 51 | extern int mxc_register_device(struct platform_device *pdev, void *data); |
@@ -51,4 +55,5 @@ extern void mxc91231_power_off(void); | |||
51 | extern void mxc91231_arch_reset(int, const char *); | 55 | extern void mxc91231_arch_reset(int, const char *); |
52 | extern void mxc91231_prepare_idle(void); | 56 | extern void mxc91231_prepare_idle(void); |
53 | extern void mx51_efikamx_reset(void); | 57 | extern void mx51_efikamx_reset(void); |
58 | extern int mx53_revision(void); | ||
54 | #endif | 59 | #endif |
diff --git a/arch/arm/plat-mxc/include/mach/hardware.h b/arch/arm/plat-mxc/include/mach/hardware.h index dde777c10176..f9ed0bae8db3 100644 --- a/arch/arm/plat-mxc/include/mach/hardware.h +++ b/arch/arm/plat-mxc/include/mach/hardware.h | |||
@@ -101,6 +101,7 @@ | |||
101 | 101 | ||
102 | #ifdef CONFIG_ARCH_MX5 | 102 | #ifdef CONFIG_ARCH_MX5 |
103 | #include <mach/mx51.h> | 103 | #include <mach/mx51.h> |
104 | #include <mach/mx53.h> | ||
104 | #endif | 105 | #endif |
105 | 106 | ||
106 | #ifdef CONFIG_ARCH_MX3 | 107 | #ifdef CONFIG_ARCH_MX3 |
diff --git a/arch/arm/plat-mxc/include/mach/iomux-mx53.h b/arch/arm/plat-mxc/include/mach/iomux-mx53.h new file mode 100644 index 000000000000..80cb3c587f92 --- /dev/null +++ b/arch/arm/plat-mxc/include/mach/iomux-mx53.h | |||
@@ -0,0 +1,303 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or modify | ||
5 | * it under the terms of the GNU General Public License as published by | ||
6 | * the Free Software Foundation; either version 2 of the License, or | ||
7 | * (at your option) any later version. | ||
8 | * | ||
9 | * This program is distributed in the hope that it will be useful, | ||
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
12 | * GNU General Public License for more details. | ||
13 | * | ||
14 | * You should have received a copy of the GNU General Public License along | ||
15 | * with this program; if not, write to the Free Software Foundation, Inc.. | ||
16 | * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | ||
17 | */ | ||
18 | |||
19 | #ifndef __MACH_IOMUX_MX53_H__ | ||
20 | #define __MACH_IOMUX_MX53_H__ | ||
21 | |||
22 | #include <mach/iomux-v3.h> | ||
23 | |||
24 | /* | ||
25 | * various IOMUX alternate output functions (1-7) | ||
26 | */ | ||
27 | typedef enum iomux_config { | ||
28 | IOMUX_CONFIG_ALT0, | ||
29 | IOMUX_CONFIG_ALT1, | ||
30 | IOMUX_CONFIG_ALT2, | ||
31 | IOMUX_CONFIG_ALT3, | ||
32 | IOMUX_CONFIG_ALT4, | ||
33 | IOMUX_CONFIG_ALT5, | ||
34 | IOMUX_CONFIG_ALT6, | ||
35 | IOMUX_CONFIG_ALT7, | ||
36 | IOMUX_CONFIG_GPIO, /* added to help user use GPIO mode */ | ||
37 | IOMUX_CONFIG_SION = 0x1 << 4, /* LOOPBACK:MUX SION bit */ | ||
38 | } iomux_pin_cfg_t; | ||
39 | |||
40 | /* These 2 defines are for pins that may not have a mux register, but could | ||
41 | * have a pad setting register, and vice-versa. */ | ||
42 | #define NON_MUX_I 0x00 | ||
43 | #define NON_PAD_I 0x00 | ||
44 | |||
45 | #define MX53_PAD_GPIO_19__GPIO_4_5 IOMUX_PAD(0x348, 0x20,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
46 | #define MX53_PAD_KEY_COL0__GPIO_4_6 IOMUX_PAD(0x34C, 0x24,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
47 | #define MX53_PAD_KEY_ROW0__GPIO_4_7 IOMUX_PAD(0x350, 0x28,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
48 | #define MX53_PAD_KEY_COL1__GPIO_4_8 IOMUX_PAD(0x354, 0x2C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
49 | #define MX53_PAD_KEY_ROW1__GPIO_4_9 IOMUX_PAD(0x358, 0x30,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
50 | #define MX53_PAD_KEY_COL2__GPIO_4_10 IOMUX_PAD(0x35C, 0x34,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
51 | #define MX53_PAD_KEY_ROW2__GPIO_4_11 IOMUX_PAD(0x360, 0x38,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
52 | #define MX53_PAD_KEY_COL3__GPIO_4_12 IOMUX_PAD(0x364, 0x3C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
53 | #define MX53_PAD_KEY_ROW3__GPIO_4_13 IOMUX_PAD(0x368, 0x40,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
54 | #define MX53_PAD_KEY_COL4__GPIO_4_14 IOMUX_PAD(0x36C, 0x44,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
55 | #define MX53_PAD_KEY_ROW4__GPIO_4_15 IOMUX_PAD(0x370, 0x48,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
56 | #define MX53_PAD_NVCC_KEYPAD__NVCC_KEYPAD IOMUX_PAD(0x374, NON_MUX_I,IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
57 | #define MX53_PAD_DI0_DISP_CLK__GPIO_4_16 IOMUX_PAD(0x378, 0x4C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
58 | #define MX53_PAD_DI0_PIN15__GPIO_4_17 IOMUX_PAD(0x37C, 0x50,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
59 | #define MX53_PAD_DI0_PIN2__GPIO_4_18 IOMUX_PAD(0x380, 0x54,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
60 | #define MX53_PAD_DI0_PIN3__GPIO_4_19 IOMUX_PAD(0x384, 0x58,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
61 | #define MX53_PAD_DI0_PIN4__GPIO_4_20 IOMUX_PAD(0x388, 0x5C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
62 | #define MX53_PAD_DISP0_DAT0__GPIO_4_21 IOMUX_PAD(0x38C, 0x60,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
63 | #define MX53_PAD_DISP0_DAT1__GPIO_4_22 IOMUX_PAD(0x390, 0x64,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
64 | #define MX53_PAD_DISP0_DAT2__GPIO_4_23 IOMUX_PAD(0x394, 0x68,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
65 | #define MX53_PAD_DISP0_DAT3__GPIO_4_24 IOMUX_PAD(0x398, 0x6C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
66 | #define MX53_PAD_DISP0_DAT4__GPIO_4_25 IOMUX_PAD(0x39C, 0x70,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
67 | #define MX53_PAD_DISP0_DAT5__GPIO_4_26 IOMUX_PAD(0x3A0, 0x74,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
68 | #define MX53_PAD_DISP0_DAT6__GPIO_4_27 IOMUX_PAD(0x3A4, 0x78,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
69 | #define MX53_PAD_DISP0_DAT7__GPIO_4_28 IOMUX_PAD(0x3A8, 0x7C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
70 | #define MX53_PAD_DISP0_DAT8__GPIO_4_29 IOMUX_PAD(0x3AC, 0x80,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
71 | #define MX53_PAD_DISP0_DAT9__GPIO_4_30 IOMUX_PAD(0x3B0, 0x84,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
72 | #define MX53_PAD_DISP0_DAT10__GPIO_4_31 IOMUX_PAD(0x3B4, 0x88,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
73 | #define MX53_PAD_DISP0_DAT11__GPIO_5_5 IOMUX_PAD(0x3B8, 0x8C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
74 | #define MX53_PAD_DISP0_DAT12__GPIO_5_6 IOMUX_PAD(0x3BC, 0x90,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
75 | #define MX53_PAD_DISP0_DAT13__GPIO_5_7 IOMUX_PAD(0x3C0, 0x94,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
76 | #define MX53_PAD_DISP0_DAT14__GPIO_5_8 IOMUX_PAD(0x3C4, 0x98,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
77 | #define MX53_PAD_DISP0_DAT15__GPIO_5_9 IOMUX_PAD(0x3C8, 0x9C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
78 | #define MX53_PAD_DISP0_DAT16__GPIO_5_10 IOMUX_PAD(0x3CC, 0xA0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
79 | #define MX53_PAD_DISP0_DAT17__GPIO_5_11 IOMUX_PAD(0x3D0, 0xA4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
80 | #define MX53_PAD_DISP0_DAT18__GPIO_5_12 IOMUX_PAD(0x3D4, 0xA8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
81 | #define MX53_PAD_DISP0_DAT19__GPIO_5_13 IOMUX_PAD(0x3D8, 0xAC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
82 | #define MX53_PAD_DISP0_DAT20__GPIO_5_14 IOMUX_PAD(0x3DC, 0xB0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
83 | #define MX53_PAD_DISP0_DAT21__GPIO_5_15 IOMUX_PAD(0x3E0, 0xB4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
84 | #define MX53_PAD_DISP0_DAT22__GPIO_5_16 IOMUX_PAD(0x3E4, 0xB8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
85 | #define MX53_PAD_DISP0_DAT23__GPIO_5_17 IOMUX_PAD(0x3E8, 0xBC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
86 | #define MX53_PAD_CSI0_PIXCLK__GPIO_5_18 IOMUX_PAD(0x3EC, 0xC0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
87 | #define MX53_PAD_CSI0_MCLK__GPIO_5_19 IOMUX_PAD(0x3F0, 0xC4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
88 | #define MX53_PAD_CSI0_DATA_EN__GPIO_5_20 IOMUX_PAD(0x3F4, 0xC8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
89 | #define MX53_PAD_CSI0_VSYNC__GPIO_5_21 IOMUX_PAD(0x3F8, 0xCC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
90 | #define MX53_PAD_CSI0_D4__GPIO_5_22 IOMUX_PAD(0x3FC, 0xD0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
91 | #define MX53_PAD_CSI0_D5__GPIO_5_23 IOMUX_PAD(0x400, 0xD4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
92 | #define MX53_PAD_CSI0_D6__GPIO_5_24 IOMUX_PAD(0x404, 0xD8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
93 | #define MX53_PAD_CSI0_D7__GPIO_5_25 IOMUX_PAD(0x408, 0xDC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
94 | #define MX53_PAD_CSI0_D8__GPIO_5_26 IOMUX_PAD(0x40C, 0xE0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
95 | #define MX53_PAD_CSI0_D9__GPIO_5_27 IOMUX_PAD(0x410, 0xE4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
96 | #define MX53_PAD_CSI0_D10__GPIO_5_28 IOMUX_PAD(0x414, 0xE8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
97 | #define MX53_PAD_CSI0_D11__GPIO_5_29 IOMUX_PAD(0x418, 0xEC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
98 | #define MX53_PAD_CSI0_D12__GPIO_5_30 IOMUX_PAD(0x41C, 0xF0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
99 | #define MX53_PAD_CSI0_D13__GPIO_5_31 IOMUX_PAD(0x420, 0xF4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
100 | #define MX53_PAD_CSI0_D14__GPIO_6_0 IOMUX_PAD(0x424, 0xF8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
101 | #define MX53_PAD_CSI0_D15__GPIO_6_1 IOMUX_PAD(0x428, 0xFC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
102 | #define MX53_PAD_CSI0_D16__GPIO_6_2 IOMUX_PAD(0x42C, 0x100,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
103 | #define MX53_PAD_CSI0_D17__GPIO_6_3 IOMUX_PAD(0x430, 0x104,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
104 | #define MX53_PAD_CSI0_D18__GPIO_6_4 IOMUX_PAD(0x434, 0x108,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
105 | #define MX53_PAD_CSI0_D19__GPIO_6_5 IOMUX_PAD(0x438, 0x10C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
106 | #define MX53_PAD_NVCC_CSI0__NVCC_CSI0 IOMUX_PAD(0x43C, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
107 | #define MX53_PAD_JTAG_TMS__JTAG_TMS IOMUX_PAD(0x440, NON_MUX_I,IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
108 | #define MX53_PAD_JTAG_MOD__JTAG_MOD IOMUX_PAD(0x444, NON_MUX_I,IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
109 | #define MX53_PAD_JTAG_TRSTB__JTAG_TRSTB IOMUX_PAD(0x448, NON_MUX_I,IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
110 | #define MX53_PAD_JTAG_TDI__JTAG_TDI IOMUX_PAD(0x44C, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
111 | #define MX53_PAD_JTAG_TCK__JTAG_TCK IOMUX_PAD(0x450, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
112 | #define MX53_PAD_JTAG_TDO__JTAG_TDO IOMUX_PAD(0x454, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
113 | #define MX53_PAD_EIM_A25__GPIO_5_2 IOMUX_PAD(0x458, 0x110,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
114 | #define MX53_PAD_EIM_EB2__GPIO_2_30 IOMUX_PAD(0x45C, 0x114,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
115 | #define MX53_PAD_EIM_D16__GPIO_3_16 IOMUX_PAD(0x460, 0x118,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
116 | #define MX53_PAD_EIM_D17__GPIO_3_17 IOMUX_PAD(0x464, 0x11C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
117 | #define MX53_PAD_EIM_D18__GPIO_3_18 IOMUX_PAD(0x468, 0x120,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
118 | #define MX53_PAD_EIM_D19__GPIO_3_19 IOMUX_PAD(0x46C, 0x124,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
119 | #define MX53_PAD_EIM_D20__GPIO_3_20 IOMUX_PAD(0x470, 0x128,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
120 | #define MX53_PAD_EIM_D21__GPIO_3_21 IOMUX_PAD(0x474, 0x12C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
121 | #define MX53_PAD_EIM_D22__GPIO_3_22 IOMUX_PAD(0x478, 0x130,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
122 | #define MX53_PAD_EIM_D23__GPIO_3_23 IOMUX_PAD(0x47C, 0x134,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
123 | #define MX53_PAD_EIM_EB3__GPIO_2_31 IOMUX_PAD(0x480, 0x138,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
124 | #define MX53_PAD_EIM_D24__GPIO_3_24 IOMUX_PAD(0x484, 0x13C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
125 | #define MX53_PAD_EIM_D25__GPIO_3_25 IOMUX_PAD(0x488, 0x140,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
126 | #define MX53_PAD_EIM_D26__GPIO_3_26 IOMUX_PAD(0x48C, 0x144,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
127 | #define MX53_PAD_EIM_D27__GPIO_3_27 IOMUX_PAD(0x490, 0x148,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
128 | #define MX53_PAD_EIM_D28__GPIO_3_28 IOMUX_PAD(0x494, 0x14C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
129 | #define MX53_PAD_EIM_D29__GPIO_3_29 IOMUX_PAD(0x498, 0x150,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
130 | #define MX53_PAD_EIM_D30__GPIO_3_30 IOMUX_PAD(0x49C, 0x154,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
131 | #define MX53_PAD_EIM_D31__GPIO_3_31 IOMUX_PAD(0x4A0, 0x158,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
132 | #define MX53_PAD_NVCC_EIM1__NVCC_EIM1 IOMUX_PAD(0x4A4, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
133 | #define MX53_PAD_EIM_A24__GPIO_5_4 IOMUX_PAD(0x4A8, 0x15C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
134 | #define MX53_PAD_EIM_A23__GPIO_6_6 IOMUX_PAD(0x4AC, 0x160,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
135 | #define MX53_PAD_EIM_A22__GPIO_2_16 IOMUX_PAD(0x4B0, 0x164,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
136 | #define MX53_PAD_EIM_A21__GPIO_2_17 IOMUX_PAD(0x4B4, 0x168,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
137 | #define MX53_PAD_EIM_A20__GPIO_2_18 IOMUX_PAD(0x4B8, 0x16C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
138 | #define MX53_PAD_EIM_A19__GPIO_2_19 IOMUX_PAD(0x4BC, 0x170,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
139 | #define MX53_PAD_EIM_A18__GPIO_2_20 IOMUX_PAD(0x4C0, 0x174,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
140 | #define MX53_PAD_EIM_A17__GPIO_2_21 IOMUX_PAD(0x4C4, 0x178,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
141 | #define MX53_PAD_EIM_A16__GPIO_2_22 IOMUX_PAD(0x4C8, 0x17C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
142 | #define MX53_PAD_EIM_CS0__GPIO_2_23 IOMUX_PAD(0x4CC, 0x180,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
143 | #define MX53_PAD_EIM_CS1__GPIO_2_24 IOMUX_PAD(0x4D0, 0x184,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
144 | #define MX53_PAD_EIM_OE__GPIO_2_25 IOMUX_PAD(0x4D4, 0x188,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
145 | #define MX53_PAD_EIM_RW__GPIO_2_26 IOMUX_PAD(0x4D8, 0x18C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
146 | #define MX53_PAD_EIM_LBA__GPIO_2_27 IOMUX_PAD(0x4DC, 0x190,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
147 | #define MX53_PAD_NVCC_EIM4__NVCC_EIM4 IOMUX_PAD(0x4E0, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
148 | #define MX53_PAD_EIM_EB0__GPIO_2_28 IOMUX_PAD(0x4E4, 0x194,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
149 | #define MX53_PAD_EIM_EB1__GPIO_2_29 IOMUX_PAD(0x4E8, 0x198,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
150 | #define MX53_PAD_EIM_DA0__GPIO_3_0 IOMUX_PAD(0x4EC, 0x19C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
151 | #define MX53_PAD_EIM_DA1__GPIO_3_1 IOMUX_PAD(0x4F0, 0x1A0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
152 | #define MX53_PAD_EIM_DA2__GPIO_3_2 IOMUX_PAD(0x4F4, 0x1A4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
153 | #define MX53_PAD_EIM_DA3__GPIO_3_3 IOMUX_PAD(0x4F8, 0x1A8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
154 | #define MX53_PAD_EIM_DA4__GPIO_3_4 IOMUX_PAD(0x4FC, 0x1AC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
155 | #define MX53_PAD_EIM_DA5__GPIO_3_5 IOMUX_PAD(0x500, 0x1B0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
156 | #define MX53_PAD_EIM_DA6__GPIO_3_6 IOMUX_PAD(0x504, 0x1B4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
157 | #define MX53_PAD_EIM_DA7__GPIO_3_7 IOMUX_PAD(0x508, 0x1B8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
158 | #define MX53_PAD_EIM_DA8__GPIO_3_8 IOMUX_PAD(0x50C, 0x1BC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
159 | #define MX53_PAD_EIM_DA9__GPIO_3_9 IOMUX_PAD(0x510, 0x1C0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
160 | #define MX53_PAD_EIM_DA10__GPIO_3_10 IOMUX_PAD(0x514, 0x1C4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
161 | #define MX53_PAD_EIM_DA11__GPIO_3_11 IOMUX_PAD(0x518, 0x1C8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
162 | #define MX53_PAD_EIM_DA12__GPIO_3_12 IOMUX_PAD(0x51C, 0x1CC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
163 | #define MX53_PAD_EIM_DA13__GPIO_3_13 IOMUX_PAD(0x520, 0x1D0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
164 | #define MX53_PAD_EIM_DA14__GPIO_3_14 IOMUX_PAD(0x524, 0x1D4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
165 | #define MX53_PAD_EIM_DA15__GPIO_3_15 IOMUX_PAD(0x528, 0x1D8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
166 | #define MX53_PAD_NANDF_WE_B__GPIO_6_12 IOMUX_PAD(0x52C, 0x1DC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
167 | #define MX53_PAD_NANDF_RE_B__GPIO_6_13 IOMUX_PAD(0x530, 0x1E0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
168 | #define MX53_PAD_EIM_WAIT__GPIO_5_0 IOMUX_PAD(0x534, 0x1E4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
169 | #define MX53_PAD_EIM_BCLK__EIM_BCLK IOMUX_PAD(0x538, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
170 | #define MX53_PAD_NVCC_EIM7__NVCC_EIM7 IOMUX_PAD(0x53C, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
171 | #define MX53_PAD_LVDS1_TX3_P__GPIO_6_22 IOMUX_PAD(NON_PAD_I, 0x1EC, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
172 | #define MX53_PAD_LVDS1_TX2_P__GPIO_6_24 IOMUX_PAD(NON_PAD_I, 0x1F0, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
173 | #define MX53_PAD_LVDS1_CLK_P__GPIO_6_26 IOMUX_PAD(NON_PAD_I, 0x1F4, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
174 | #define MX53_PAD_LVDS1_TX1_P__GPIO_6_28 IOMUX_PAD(NON_PAD_I, 0x1F8, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
175 | #define MX53_PAD_LVDS1_TX0_P__GPIO_6_30 IOMUX_PAD(NON_PAD_I, 0x1FC, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
176 | #define MX53_PAD_LVDS0_TX3_P__GPIO_7_22 IOMUX_PAD(NON_PAD_I, 0x200, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
177 | #define MX53_PAD_LVDS0_CLK_P__GPIO_7_24 IOMUX_PAD(NON_PAD_I, 0x204, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
178 | #define MX53_PAD_LVDS0_TX2_P__GPIO_7_26 IOMUX_PAD(NON_PAD_I, 0x208, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
179 | #define MX53_PAD_LVDS0_TX1_P__GPIO_7_28 IOMUX_PAD(NON_PAD_I, 0x20C, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
180 | #define MX53_PAD_LVDS0_TX0_P__GPIO_7_30 IOMUX_PAD(NON_PAD_I, 0x210, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
181 | #define MX53_PAD_GPIO_10__GPIO_4_0 IOMUX_PAD(0x540, 0x214, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
182 | #define MX53_PAD_GPIO_11__GPIO_4_1 IOMUX_PAD(0x544, 0x218, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
183 | #define MX53_PAD_GPIO_12__GPIO_4_2 IOMUX_PAD(0x548, 0x21C, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
184 | #define MX53_PAD_GPIO_13__GPIO_4_3 IOMUX_PAD(0x54C, 0x220, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
185 | #define MX53_PAD_GPIO_14__GPIO_4_4 IOMUX_PAD(0x550, 0x224, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
186 | #define MX53_PAD_DRAM_DQM3__DRAM_DQM3 IOMUX_PAD(0x554, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
187 | #define MX53_PAD_DRAM_SDQS3__DRAM_SDQS3 IOMUX_PAD(0x558, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
188 | #define MX53_PAD_DRAM_SDCKE1__DRAM_SDCKE1 IOMUX_PAD(0x55C, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
189 | #define MX53_PAD_DRAM_DQM2__DRAM_DQM2 IOMUX_PAD(0x560, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
190 | #define MX53_PAD_DRAM_SDODT1__DRAM_SDODT1 IOMUX_PAD(0x564, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
191 | #define MX53_PAD_DRAM_SDQS2__DRAM_SDQS2 IOMUX_PAD(0x568, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
192 | #define MX53_PAD_DRAM_RESET__DRAM_RESET IOMUX_PAD(0x56C, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
193 | #define MX53_PAD_DRAM_SDCLK1__DRAM_SDCLK1 IOMUX_PAD(0x570, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
194 | #define MX53_PAD_DRAM_CAS__DRAM_CAS IOMUX_PAD(0x574, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
195 | #define MX53_PAD_DRAM_SDCLK0__DRAM_SDCLK0 IOMUX_PAD(0x578, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
196 | #define MX53_PAD_DRAM_SDQS0__DRAM_SDQS0 IOMUX_PAD(0x57C, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
197 | #define MX53_PAD_DRAM_SDODT0__DRAM_SDODT0 IOMUX_PAD(0x580, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
198 | #define MX53_PAD_DRAM_DQM0__DRAM_DQM0 IOMUX_PAD(0x584, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
199 | #define MX53_PAD_DRAM_RAS__DRAM_RAS IOMUX_PAD(0x588, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
200 | #define MX53_PAD_DRAM_SDCKE0__DRAM_SDCKE0 IOMUX_PAD(0x58C, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
201 | #define MX53_PAD_DRAM_SDQS1__DRAM_SDQS1 IOMUX_PAD(0x590, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
202 | #define MX53_PAD_DRAM_DQM1__DRAM_DQM1 IOMUX_PAD(0x594, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
203 | #define MX53_PAD_PMIC_ON_REQ__PMIC_ON_REQ IOMUX_PAD(0x598, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
204 | #define MX53_PAD_PMIC_STBY_REQ__PMIC_STBY_REQ IOMUX_PAD(0x59C, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
205 | #define MX53_PAD_NANDF_CLE__GPIO_6_7 IOMUX_PAD(0x5A0, 0x228,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
206 | #define MX53_PAD_NANDF_ALE__GPIO_6_8 IOMUX_PAD(0x5A4, 0x22C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
207 | #define MX53_PAD_NANDF_WP_B__GPIO_6_9 IOMUX_PAD(0x5A8, 0x230,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
208 | #define MX53_PAD_NANDF_RB0__GPIO_6_10 IOMUX_PAD(0x5AC, 0x234,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
209 | #define MX53_PAD_NANDF_CS0__GPIO_6_11 IOMUX_PAD(0x5B0, 0x238,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
210 | #define MX53_PAD_NANDF_CS1__GPIO_6_14 IOMUX_PAD(0x5B4, 0x23C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
211 | #define MX53_PAD_NANDF_CS2__GPIO_6_15 IOMUX_PAD(0x5B8, 0x240,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
212 | #define MX53_PAD_NANDF_CS3__GPIO_6_16 IOMUX_PAD(0x5BC, 0x244,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
213 | #define MX53_PAD_NVCC_NANDF__NVCC_NANDF IOMUX_PAD(0x5C0, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
214 | #define MX53_PAD_FEC_MDIO__GPIO_1_22 IOMUX_PAD(0x5C4, 0x248,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
215 | #define MX53_PAD_FEC_REF_CLK__GPIO_1_23 IOMUX_PAD(0x5C8, 0x24C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
216 | #define MX53_PAD_FEC_RX_ER__GPIO_1_24 IOMUX_PAD(0x5CC, 0x250,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
217 | #define MX53_PAD_FEC_CRS_DV__GPIO_1_25 IOMUX_PAD(0x5D0, 0x254,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
218 | #define MX53_PAD_FEC_RXD1__GPIO_1_26 IOMUX_PAD(0x5D4, 0x258,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
219 | #define MX53_PAD_FEC_RXD0__GPIO_1_27 IOMUX_PAD(0x5D8, 0x25C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
220 | #define MX53_PAD_FEC_TX_EN__GPIO_1_28 IOMUX_PAD(0x5DC, 0x260,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
221 | #define MX53_PAD_FEC_TXD1__GPIO_1_29 IOMUX_PAD(0x5E0, 0x264,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
222 | #define MX53_PAD_FEC_TXD0__GPIO_1_30 IOMUX_PAD(0x5E4, 0x268,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
223 | #define MX53_PAD_FEC_MDC__GPIO_1_31 IOMUX_PAD(0x5E8, 0x26C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
224 | #define MX53_PAD_NVCC_FEC__NVCC_FEC IOMUX_PAD(0x5EC, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
225 | #define MX53_PAD_ATA_DIOW__GPIO_6_17 IOMUX_PAD(0x5F0, 0x270,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
226 | #define MX53_PAD_ATA_DMACK__GPIO_6_18 IOMUX_PAD(0x5F4, 0x274,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
227 | #define MX53_PAD_ATA_DMARQ__GPIO_7_0 IOMUX_PAD(0x5F8, 0x278,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
228 | #define MX53_PAD_ATA_BUFFER_EN__GPIO_7_1 IOMUX_PAD(0x5FC, 0x27C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
229 | #define MX53_PAD_ATA_INTRQ__GPIO_7_2 IOMUX_PAD(0x600, 0x280,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
230 | #define MX53_PAD_ATA_DIOR__GPIO_7_3 IOMUX_PAD(0x604, 0x284,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
231 | #define MX53_PAD_ATA_RESET_B__GPIO_7_4 IOMUX_PAD(0x608, 0x288,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
232 | #define MX53_PAD_ATA_IORDY__GPIO_7_5 IOMUX_PAD(0x60C, 0x28C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
233 | #define MX53_PAD_ATA_DA_0__GPIO_7_6 IOMUX_PAD(0x610, 0x290,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
234 | #define MX53_PAD_ATA_DA_1__GPIO_7_7 IOMUX_PAD(0x614, 0x294,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
235 | #define MX53_PAD_ATA_DA_2__GPIO_7_8 IOMUX_PAD(0x618, 0x298,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
236 | #define MX53_PAD_ATA_CS_0__GPIO_7_9 IOMUX_PAD(0x61C, 0x29C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
237 | #define MX53_PAD_ATA_CS_1__GPIO_7_10 IOMUX_PAD(0x620, 0x2A0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
238 | #define MX53_PAD_NVCC_ATA2__NVCC_ATA2 IOMUX_PAD(0x624, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
239 | #define MX53_PAD_ATA_DATA0__GPIO_2_0 IOMUX_PAD(0x628, 0x2A4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
240 | #define MX53_PAD_ATA_DATA1__GPIO_2_1 IOMUX_PAD(0x62C, 0x2A8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
241 | #define MX53_PAD_ATA_DATA2__GPIO_2_2 IOMUX_PAD(0x630, 0x2AC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
242 | #define MX53_PAD_ATA_DATA3__GPIO_2_3 IOMUX_PAD(0x634, 0x2B0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
243 | #define MX53_PAD_ATA_DATA4__GPIO_2_4 IOMUX_PAD(0x638, 0x2B4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
244 | #define MX53_PAD_ATA_DATA5__GPIO_2_5 IOMUX_PAD(0x63C, 0x2B8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
245 | #define MX53_PAD_ATA_DATA6__GPIO_2_6 IOMUX_PAD(0x640, 0x2BC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
246 | #define MX53_PAD_ATA_DATA7__GPIO_2_7 IOMUX_PAD(0x644, 0x2C0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
247 | #define MX53_PAD_ATA_DATA8__GPIO_2_8 IOMUX_PAD(0x648, 0x2C4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
248 | #define MX53_PAD_ATA_DATA9__GPIO_2_9 IOMUX_PAD(0x64C, 0x2C8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
249 | #define MX53_PAD_ATA_DATA10__GPIO_2_10 IOMUX_PAD(0x650, 0x2CC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
250 | #define MX53_PAD_ATA_DATA11__GPIO_2_11 IOMUX_PAD(0x654, 0x2D0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
251 | #define MX53_PAD_ATA_DATA12__GPIO_2_12 IOMUX_PAD(0x658, 0x2D4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
252 | #define MX53_PAD_ATA_DATA13__GPIO_2_13 IOMUX_PAD(0x65C, 0x2D8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
253 | #define MX53_PAD_ATA_DATA14__GPIO_2_14 IOMUX_PAD(0x660, 0x2DC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
254 | #define MX53_PAD_ATA_DATA15__GPIO_2_15 IOMUX_PAD(0x664, 0x2E0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
255 | #define MX53_PAD_NVCC_ATA0__NVCC_ATA0 IOMUX_PAD(0x668, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
256 | #define MX53_PAD_SD1_DATA0__GPIO_1_16 IOMUX_PAD(0x66C, 0x2E4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
257 | #define MX53_PAD_SD1_DATA1__GPIO_1_17 IOMUX_PAD(0x670, 0x2E8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
258 | #define MX53_PAD_SD1_CMD__GPIO_1_18 IOMUX_PAD(0x674, 0x2EC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
259 | #define MX53_PAD_SD1_DATA2__GPIO_1_19 IOMUX_PAD(0x678, 0x2F0,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
260 | #define MX53_PAD_SD1_CLK__GPIO_1_20 IOMUX_PAD(0x67C, 0x2F4,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
261 | #define MX53_PAD_SD1_DATA3__GPIO_1_21 IOMUX_PAD(0x680, 0x2F8,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
262 | #define MX53_PAD_NVCC_SD1__NVCC_SD1 IOMUX_PAD(0x684, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
263 | #define MX53_PAD_SD2_CLK__GPIO_1_10 IOMUX_PAD(0x688, 0x2FC,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
264 | #define MX53_PAD_SD2_CMD__GPIO_1_11 IOMUX_PAD(0x68C, 0x300,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
265 | #define MX53_PAD_SD2_DATA3__GPIO_1_12 IOMUX_PAD(0x690, 0x304,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
266 | #define MX53_PAD_SD2_DATA2__GPIO_1_13 IOMUX_PAD(0x694, 0x308,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
267 | #define MX53_PAD_SD2_DATA1__GPIO_1_14 IOMUX_PAD(0x698, 0x30C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
268 | #define MX53_PAD_SD2_DATA0__GPIO_1_15 IOMUX_PAD(0x69C, 0x310,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
269 | #define MX53_PAD_NVCC_SD2__NVCC_SD2 IOMUX_PAD(0x6A0, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
270 | #define MX53_PAD_GPIO_0__GPIO_1_0 IOMUX_PAD(0x6A4, 0x314,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
271 | #define MX53_PAD_GPIO_1__GPIO_1_1 IOMUX_PAD(0x6A8, 0x318,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
272 | #define MX53_PAD_GPIO_9__GPIO_1_9 IOMUX_PAD(0x6AC, 0x31C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
273 | #define MX53_PAD_GPIO_3__GPIO_1_3 IOMUX_PAD(0x6B0, 0x320,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
274 | #define MX53_PAD_GPIO_6__GPIO_1_6 IOMUX_PAD(0x6B4, 0x324,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
275 | #define MX53_PAD_GPIO_2__GPIO_1_2 IOMUX_PAD(0x6B8, 0x328,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
276 | #define MX53_PAD_GPIO_4__GPIO_1_4 IOMUX_PAD(0x6BC, 0x32C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
277 | #define MX53_PAD_GPIO_5__GPIO_1_5 IOMUX_PAD(0x6C0, 0x330,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
278 | #define MX53_PAD_GPIO_7__GPIO_1_7 IOMUX_PAD(0x6C4, 0x334,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
279 | #define MX53_PAD_GPIO_8__GPIO_1_8 IOMUX_PAD(0x6C8, 0x338,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
280 | #define MX53_PAD_GPIO_16__GPIO_7_11 IOMUX_PAD(0x6CC, 0x33C,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
281 | #define MX53_PAD_GPIO_17__GPIO_7_12 IOMUX_PAD(0x6D0, 0x340,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
282 | #define MX53_PAD_GPIO_18__GPIO_7_13 IOMUX_PAD(0x6D4, 0x344,IOMUX_CONFIG_ALT1, 0x0, 0, NO_PAD_CTRL) | ||
283 | #define MX53_PAD_NVCC_GPIO__NVCC_GPIO IOMUX_PAD(0x6D8, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
284 | #define MX53_PAD_POR_B__POR_B IOMUX_PAD(0x6DC, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
285 | #define MX53_PAD_BOOT_MODE1__BOOT_MODE1 IOMUX_PAD(0x6E0, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
286 | #define MX53_PAD_RESET_IN_B__RESET_IN_B IOMUX_PAD(0x6E4, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
287 | #define MX53_PAD_BOOT_MODE0__BOOT_MODE0 IOMUX_PAD(0x6E8, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
288 | #define MX53_PAD_TEST_MODE__TEST_MODE IOMUX_PAD(0x6EC, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
289 | #define MX53_PAD_GRP_ADDDS__GRP_ADDDS IOMUX_PAD(0x6F0, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
290 | #define MX53_PAD_GRP_DDRMODE_CTL__GRP_DDRMODE_CTL IOMUX_PAD(0x6F4, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
291 | #define MX53_PAD_GRP_DDRPKE__GRP_DDRPKE IOMUX_PAD(0x6FC, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
292 | #define MX53_PAD_GRP_DDRPK__GRP_DDRPK IOMUX_PAD(0x708, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
293 | #define MX53_PAD_GRP_TERM_CTL3__GRP_TERM_CTL3 IOMUX_PAD(0x70C, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
294 | #define MX53_PAD_GRP_DDRHYS__GRP_DDRHYS IOMUX_PAD(0x710, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
295 | #define MX53_PAD_GRP_DDRMODE__GRP_DDRMODE IOMUX_PAD(0x714, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
296 | #define MX53_PAD_GRP_B0DS__GRP_B0DS IOMUX_PAD(0x718, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
297 | #define MX53_PAD_GRP_B1DS__GRP_B1DS IOMUX_PAD(0x71C, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
298 | #define MX53_PAD_GRP_CTLDS__GRP_CTLDS IOMUX_PAD(0x720, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
299 | #define MX53_PAD_GRP_DDR_TYPE__GRP_DDR_TYPE IOMUX_PAD(0x724, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
300 | #define MX53_PAD_GRP_B2DS__GRP_B2DS IOMUX_PAD(0x728, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
301 | #define MX53_PAD_GRP_B3DS__GRP_B3DS IOMUX_PAD(0x72C, NON_MUX_I, IOMUX_CONFIG_ALT0, 0x0, 0, NO_PAD_CTRL) | ||
302 | |||
303 | #endif /* __MACH_IOMUX_MX53_H__ */ | ||
diff --git a/arch/arm/plat-mxc/include/mach/memory.h b/arch/arm/plat-mxc/include/mach/memory.h index 564ec9dbc93d..9a9a00060b5a 100644 --- a/arch/arm/plat-mxc/include/mach/memory.h +++ b/arch/arm/plat-mxc/include/mach/memory.h | |||
@@ -17,6 +17,7 @@ | |||
17 | #define MX27_PHYS_OFFSET UL(0xa0000000) | 17 | #define MX27_PHYS_OFFSET UL(0xa0000000) |
18 | #define MX3x_PHYS_OFFSET UL(0x80000000) | 18 | #define MX3x_PHYS_OFFSET UL(0x80000000) |
19 | #define MX51_PHYS_OFFSET UL(0x90000000) | 19 | #define MX51_PHYS_OFFSET UL(0x90000000) |
20 | #define MX53_PHYS_OFFSET UL(0x70000000) | ||
20 | #define MXC91231_PHYS_OFFSET UL(0x90000000) | 21 | #define MXC91231_PHYS_OFFSET UL(0x90000000) |
21 | 22 | ||
22 | #if !defined(CONFIG_RUNTIME_PHYS_OFFSET) | 23 | #if !defined(CONFIG_RUNTIME_PHYS_OFFSET) |
@@ -32,8 +33,10 @@ | |||
32 | # define PHYS_OFFSET MX3x_PHYS_OFFSET | 33 | # define PHYS_OFFSET MX3x_PHYS_OFFSET |
33 | # elif defined CONFIG_ARCH_MXC91231 | 34 | # elif defined CONFIG_ARCH_MXC91231 |
34 | # define PHYS_OFFSET MXC91231_PHYS_OFFSET | 35 | # define PHYS_OFFSET MXC91231_PHYS_OFFSET |
35 | # elif defined CONFIG_ARCH_MX5 | 36 | # elif defined CONFIG_ARCH_MX51 |
36 | # define PHYS_OFFSET MX51_PHYS_OFFSET | 37 | # define PHYS_OFFSET MX51_PHYS_OFFSET |
38 | # elif defined CONFIG_ARCH_MX53 | ||
39 | # define PHYS_OFFSET MX53_PHYS_OFFSET | ||
37 | # endif | 40 | # endif |
38 | #endif | 41 | #endif |
39 | 42 | ||
diff --git a/arch/arm/plat-mxc/include/mach/mx53.h b/arch/arm/plat-mxc/include/mach/mx53.h new file mode 100644 index 000000000000..9577cdbf7fad --- /dev/null +++ b/arch/arm/plat-mxc/include/mach/mx53.h | |||
@@ -0,0 +1,353 @@ | |||
1 | #ifndef __MACH_MX53_H__ | ||
2 | #define __MACH_MX53_H__ | ||
3 | |||
4 | /* | ||
5 | * IROM | ||
6 | */ | ||
7 | #define MX53_IROM_BASE_ADDR 0x0 | ||
8 | #define MX53_IROM_SIZE SZ_64K | ||
9 | |||
10 | /* TZIC */ | ||
11 | #define MX53_TZIC_BASE_ADDR 0x0FFFC000 | ||
12 | |||
13 | /* | ||
14 | * AHCI SATA | ||
15 | */ | ||
16 | #define MX53_SATA_BASE_ADDR 0x10000000 | ||
17 | |||
18 | /* | ||
19 | * NFC | ||
20 | */ | ||
21 | #define MX53_NFC_AXI_BASE_ADDR 0xF7FF0000 /* NAND flash AXI */ | ||
22 | #define MX53_NFC_AXI_SIZE SZ_64K | ||
23 | |||
24 | /* | ||
25 | * IRAM | ||
26 | */ | ||
27 | #define MX53_IRAM_BASE_ADDR 0xF8000000 /* internal ram */ | ||
28 | #define MX53_IRAM_PARTITIONS 16 | ||
29 | #define MX53_IRAM_SIZE (MX53_IRAM_PARTITIONS * SZ_8K) /* 128KB */ | ||
30 | |||
31 | /* | ||
32 | * Graphics Memory of GPU | ||
33 | */ | ||
34 | #define MX53_IPU_CTRL_BASE_ADDR 0x18000000 | ||
35 | #define MX53_GPU2D_BASE_ADDR 0x20000000 | ||
36 | #define MX53_GPU_BASE_ADDR 0x30000000 | ||
37 | #define MX53_GPU_GMEM_BASE_ADDR 0xF8020000 | ||
38 | |||
39 | #define MX53_DEBUG_BASE_ADDR 0x40000000 | ||
40 | #define MX53_DEBUG_SIZE SZ_1M | ||
41 | #define MX53_ETB_BASE_ADDR (MX53_DEBUG_BASE_ADDR + 0x00001000) | ||
42 | #define MX53_ETM_BASE_ADDR (MX53_DEBUG_BASE_ADDR + 0x00002000) | ||
43 | #define MX53_TPIU_BASE_ADDR (MX53_DEBUG_BASE_ADDR + 0x00003000) | ||
44 | #define MX53_CTI0_BASE_ADDR (MX53_DEBUG_BASE_ADDR + 0x00004000) | ||
45 | #define MX53_CTI1_BASE_ADDR (MX53_DEBUG_BASE_ADDR + 0x00005000) | ||
46 | #define MX53_CTI2_BASE_ADDR (MX53_DEBUG_BASE_ADDR + 0x00006000) | ||
47 | #define MX53_CTI3_BASE_ADDR (MX53_DEBUG_BASE_ADDR + 0x00007000) | ||
48 | #define MX53_CORTEX_DBG_BASE_ADDR (MX53_DEBUG_BASE_ADDR + 0x00008000) | ||
49 | |||
50 | /* | ||
51 | * SPBA global module enabled #0 | ||
52 | */ | ||
53 | #define MX53_SPBA0_BASE_ADDR 0x50000000 | ||
54 | #define MX53_SPBA0_SIZE SZ_1M | ||
55 | |||
56 | #define MX53_MMC_SDHC1_BASE_ADDR (MX53_SPBA0_BASE_ADDR + 0x00004000) | ||
57 | #define MX53_MMC_SDHC2_BASE_ADDR (MX53_SPBA0_BASE_ADDR + 0x00008000) | ||
58 | #define MX53_UART3_BASE_ADDR (MX53_SPBA0_BASE_ADDR + 0x0000C000) | ||
59 | #define MX53_CSPI1_BASE_ADDR (MX53_SPBA0_BASE_ADDR + 0x00010000) | ||
60 | #define MX53_SSI2_BASE_ADDR (MX53_SPBA0_BASE_ADDR + 0x00014000) | ||
61 | #define MX53_MMC_SDHC3_BASE_ADDR (MX53_SPBA0_BASE_ADDR + 0x00020000) | ||
62 | #define MX53_MMC_SDHC4_BASE_ADDR (MX53_SPBA0_BASE_ADDR + 0x00024000) | ||
63 | #define MX53_SPDIF_BASE_ADDR (MX53_SPBA0_BASE_ADDR + 0x00028000) | ||
64 | #define MX53_ASRC_BASE_ADDR (MX53_SPBA0_BASE_ADDR + 0x0002C000) | ||
65 | #define MX53_ATA_DMA_BASE_ADDR (MX53_SPBA0_BASE_ADDR + 0x00030000) | ||
66 | #define MX53_SLIM_DMA_BASE_ADDR (MX53_SPBA0_BASE_ADDR + 0x00034000) | ||
67 | #define MX53_HSI2C_DMA_BASE_ADDR (MX53_SPBA0_BASE_ADDR + 0x00038000) | ||
68 | #define MX53_SPBA_CTRL_BASE_ADDR (MX53_SPBA0_BASE_ADDR + 0x0003C000) | ||
69 | |||
70 | /* | ||
71 | * AIPS 1 | ||
72 | */ | ||
73 | #define MX53_AIPS1_BASE_ADDR 0x53F00000 | ||
74 | #define MX53_AIPS1_SIZE SZ_1M | ||
75 | |||
76 | #define MX53_OTG_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x00080000) | ||
77 | #define MX53_GPIO1_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x00084000) | ||
78 | #define MX53_GPIO2_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x00088000) | ||
79 | #define MX53_GPIO3_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x0008C000) | ||
80 | #define MX53_GPIO4_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x00090000) | ||
81 | #define MX53_KPP_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x00094000) | ||
82 | #define MX53_WDOG_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x00098000) | ||
83 | #define MX53_WDOG2_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x0009C000) | ||
84 | #define MX53_GPT1_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000A0000) | ||
85 | #define MX53_SRTC_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000A4000) | ||
86 | #define MX53_IOMUXC_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000A8000) | ||
87 | #define MX53_EPIT1_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000AC000) | ||
88 | #define MX53_EPIT2_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000B0000) | ||
89 | #define MX53_PWM1_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000B4000) | ||
90 | #define MX53_PWM2_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000B8000) | ||
91 | #define MX53_UART1_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000BC000) | ||
92 | #define MX53_UART2_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000C0000) | ||
93 | #define MX53_SRC_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000D0000) | ||
94 | #define MX53_CCM_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000D4000) | ||
95 | #define MX53_GPC_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000D8000) | ||
96 | #define MX53_GPIO5_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000DC000) | ||
97 | #define MX53_GPIO6_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000E0000) | ||
98 | #define MX53_GPIO7_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000E4000) | ||
99 | #define MX53_ATA_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000E8000) | ||
100 | #define MX53_I2C3_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000EC000) | ||
101 | #define MX53_UART4_BASE_ADDR (MX53_AIPS1_BASE_ADDR + 0x000F0000) | ||
102 | |||
103 | /* | ||
104 | * AIPS 2 | ||
105 | */ | ||
106 | #define MX53_AIPS2_BASE_ADDR 0x63F00000 | ||
107 | #define MX53_AIPS2_SIZE SZ_1M | ||
108 | |||
109 | #define MX53_PLL1_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x00080000) | ||
110 | #define MX53_PLL2_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x00084000) | ||
111 | #define MX53_PLL3_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x00088000) | ||
112 | #define MX53_PLL4_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x0008C000) | ||
113 | #define MX53_UART5_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x00090000) | ||
114 | #define MX53_AHBMAX_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x00094000) | ||
115 | #define MX53_IIM_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x00098000) | ||
116 | #define MX53_CSU_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x0009C000) | ||
117 | #define MX53_ARM_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000A0000) | ||
118 | #define MX53_OWIRE_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000A4000) | ||
119 | #define MX53_FIRI_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000A8000) | ||
120 | #define MX53_CSPI2_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000AC000) | ||
121 | #define MX53_SDMA_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000B0000) | ||
122 | #define MX53_SCC_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000B4000) | ||
123 | #define MX53_ROMCP_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000B8000) | ||
124 | #define MX53_RTIC_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000BC000) | ||
125 | #define MX53_CSPI3_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000C0000) | ||
126 | #define MX53_I2C2_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000C4000) | ||
127 | #define MX53_I2C1_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000C8000) | ||
128 | #define MX53_SSI1_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000CC000) | ||
129 | #define MX53_AUDMUX_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000D0000) | ||
130 | #define MX53_RTC_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000D4000) | ||
131 | #define MX53_M4IF_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000D8000) | ||
132 | #define MX53_ESDCTL_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000D9000) | ||
133 | #define MX53_WEIM_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000DA000) | ||
134 | #define MX53_NFC_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000DB000) | ||
135 | #define MX53_EMI_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000DBF00) | ||
136 | #define MX53_MIPI_HSC_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000DC000) | ||
137 | #define MX53_MLB_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000E4000) | ||
138 | #define MX53_SSI3_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000E8000) | ||
139 | #define MX53_MXC_FEC_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000EC000) | ||
140 | #define MX53_TVE_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000F0000) | ||
141 | #define MX53_VPU_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000F4000) | ||
142 | #define MX53_SAHARA_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000F8000) | ||
143 | #define MX53_PTP_BASE_ADDR (MX53_AIPS2_BASE_ADDR + 0x000FC000) | ||
144 | |||
145 | /* | ||
146 | * Memory regions and CS | ||
147 | */ | ||
148 | #define MX53_CSD0_BASE_ADDR 0x90000000 | ||
149 | #define MX53_CSD1_BASE_ADDR 0xA0000000 | ||
150 | #define MX53_CS0_BASE_ADDR 0xB0000000 | ||
151 | #define MX53_CS1_BASE_ADDR 0xB8000000 | ||
152 | #define MX53_CS2_BASE_ADDR 0xC0000000 | ||
153 | #define MX53_CS3_BASE_ADDR 0xC8000000 | ||
154 | #define MX53_CS4_BASE_ADDR 0xCC000000 | ||
155 | #define MX53_CS5_BASE_ADDR 0xCE000000 | ||
156 | |||
157 | #define MX53_IO_P2V(x) IMX_IO_P2V(x) | ||
158 | #define MX53_IO_ADDRESS(x) IOMEM(MX53_IO_P2V(x)) | ||
159 | |||
160 | /* | ||
161 | * defines for SPBA modules | ||
162 | */ | ||
163 | #define MX53_SPBA_SDHC1 0x04 | ||
164 | #define MX53_SPBA_SDHC2 0x08 | ||
165 | #define MX53_SPBA_UART3 0x0C | ||
166 | #define MX53_SPBA_CSPI1 0x10 | ||
167 | #define MX53_SPBA_SSI2 0x14 | ||
168 | #define MX53_SPBA_SDHC3 0x20 | ||
169 | #define MX53_SPBA_SDHC4 0x24 | ||
170 | #define MX53_SPBA_SPDIF 0x28 | ||
171 | #define MX53_SPBA_ATA 0x30 | ||
172 | #define MX53_SPBA_SLIM 0x34 | ||
173 | #define MX53_SPBA_HSI2C 0x38 | ||
174 | #define MX53_SPBA_CTRL 0x3C | ||
175 | |||
176 | /* | ||
177 | * DMA request assignments | ||
178 | */ | ||
179 | #define MX53_DMA_REQ_SSI3_TX1 47 | ||
180 | #define MX53_DMA_REQ_SSI3_RX1 46 | ||
181 | #define MX53_DMA_REQ_SSI3_TX2 45 | ||
182 | #define MX53_DMA_REQ_SSI3_RX2 44 | ||
183 | #define MX53_DMA_REQ_UART3_TX 43 | ||
184 | #define MX53_DMA_REQ_UART3_RX 42 | ||
185 | #define MX53_DMA_REQ_ESAI_TX 41 | ||
186 | #define MX53_DMA_REQ_ESAI_RX 40 | ||
187 | #define MX53_DMA_REQ_CSPI_TX 39 | ||
188 | #define MX53_DMA_REQ_CSPI_RX 38 | ||
189 | #define MX53_DMA_REQ_ASRC_DMA6 37 | ||
190 | #define MX53_DMA_REQ_ASRC_DMA5 36 | ||
191 | #define MX53_DMA_REQ_ASRC_DMA4 35 | ||
192 | #define MX53_DMA_REQ_ASRC_DMA3 34 | ||
193 | #define MX53_DMA_REQ_ASRC_DMA2 33 | ||
194 | #define MX53_DMA_REQ_ASRC_DMA1 32 | ||
195 | #define MX53_DMA_REQ_EMI_WR 31 | ||
196 | #define MX53_DMA_REQ_EMI_RD 30 | ||
197 | #define MX53_DMA_REQ_SSI1_TX1 29 | ||
198 | #define MX53_DMA_REQ_SSI1_RX1 28 | ||
199 | #define MX53_DMA_REQ_SSI1_TX2 27 | ||
200 | #define MX53_DMA_REQ_SSI1_RX2 26 | ||
201 | #define MX53_DMA_REQ_SSI2_TX1 25 | ||
202 | #define MX53_DMA_REQ_SSI2_RX1 24 | ||
203 | #define MX53_DMA_REQ_SSI2_TX2 23 | ||
204 | #define MX53_DMA_REQ_SSI2_RX2 22 | ||
205 | #define MX53_DMA_REQ_I2C2_SDHC2 21 | ||
206 | #define MX53_DMA_REQ_I2C1_SDHC1 20 | ||
207 | #define MX53_DMA_REQ_UART1_TX 19 | ||
208 | #define MX53_DMA_REQ_UART1_RX 18 | ||
209 | #define MX53_DMA_REQ_UART5_TX 17 | ||
210 | #define MX53_DMA_REQ_UART5_RX 16 | ||
211 | #define MX53_DMA_REQ_SPDIF_TX 15 | ||
212 | #define MX53_DMA_REQ_SPDIF_RX 14 | ||
213 | #define MX53_DMA_REQ_UART2_FIRI_TX 13 | ||
214 | #define MX53_DMA_REQ_UART2_FIRI_RX 12 | ||
215 | #define MX53_DMA_REQ_SDHC4 11 | ||
216 | #define MX53_DMA_REQ_I2C3_SDHC3 10 | ||
217 | #define MX53_DMA_REQ_CSPI2_TX 9 | ||
218 | #define MX53_DMA_REQ_CSPI2_RX 8 | ||
219 | #define MX53_DMA_REQ_CSPI1_TX 7 | ||
220 | #define MX53_DMA_REQ_CSPI1_RX 6 | ||
221 | #define MX53_DMA_REQ_IPU 5 | ||
222 | #define MX53_DMA_REQ_ATA_TX_END 4 | ||
223 | #define MX53_DMA_REQ_ATA_UART4_TX 3 | ||
224 | #define MX53_DMA_REQ_ATA_UART4_RX 2 | ||
225 | #define MX53_DMA_REQ_GPC 1 | ||
226 | #define MX53_DMA_REQ_VPU 0 | ||
227 | |||
228 | /* | ||
229 | * Interrupt numbers | ||
230 | */ | ||
231 | #define MX53_INT_RESV0 0 | ||
232 | #define MX53_INT_MMC_SDHC1 1 | ||
233 | #define MX53_INT_MMC_SDHC2 2 | ||
234 | #define MX53_INT_MMC_SDHC3 3 | ||
235 | #define MX53_INT_MMC_SDHC4 4 | ||
236 | #define MX53_INT_RESV5 5 | ||
237 | #define MX53_INT_SDMA 6 | ||
238 | #define MX53_INT_IOMUX 7 | ||
239 | #define MX53_INT_NFC 8 | ||
240 | #define MX53_INT_VPU 9 | ||
241 | #define MX53_INT_IPU_ERR 10 | ||
242 | #define MX53_INT_IPU_SYN 11 | ||
243 | #define MX53_INT_GPU 12 | ||
244 | #define MX53_INT_RESV13 13 | ||
245 | #define MX53_INT_USB_H1 14 | ||
246 | #define MX53_INT_EMI 15 | ||
247 | #define MX53_INT_USB_H2 16 | ||
248 | #define MX53_INT_USB_H3 17 | ||
249 | #define MX53_INT_USB_OTG 18 | ||
250 | #define MX53_INT_SAHARA_H0 19 | ||
251 | #define MX53_INT_SAHARA_H1 20 | ||
252 | #define MX53_INT_SCC_SMN 21 | ||
253 | #define MX53_INT_SCC_STZ 22 | ||
254 | #define MX53_INT_SCC_SCM 23 | ||
255 | #define MX53_INT_SRTC_NTZ 24 | ||
256 | #define MX53_INT_SRTC_TZ 25 | ||
257 | #define MX53_INT_RTIC 26 | ||
258 | #define MX53_INT_CSU 27 | ||
259 | #define MX53_INT_SATA 28 | ||
260 | #define MX53_INT_SSI1 29 | ||
261 | #define MX53_INT_SSI2 30 | ||
262 | #define MX53_INT_UART1 31 | ||
263 | #define MX53_INT_UART2 32 | ||
264 | #define MX53_INT_UART3 33 | ||
265 | #define MX53_INT_RESV34 34 | ||
266 | #define MX53_INT_RESV35 35 | ||
267 | #define MX53_INT_CSPI1 36 | ||
268 | #define MX53_INT_CSPI2 37 | ||
269 | #define MX53_INT_CSPI 38 | ||
270 | #define MX53_INT_GPT 39 | ||
271 | #define MX53_INT_EPIT1 40 | ||
272 | #define MX53_INT_EPIT2 41 | ||
273 | #define MX53_INT_GPIO1_INT7 42 | ||
274 | #define MX53_INT_GPIO1_INT6 43 | ||
275 | #define MX53_INT_GPIO1_INT5 44 | ||
276 | #define MX53_INT_GPIO1_INT4 45 | ||
277 | #define MX53_INT_GPIO1_INT3 46 | ||
278 | #define MX53_INT_GPIO1_INT2 47 | ||
279 | #define MX53_INT_GPIO1_INT1 48 | ||
280 | #define MX53_INT_GPIO1_INT0 49 | ||
281 | #define MX53_INT_GPIO1_LOW 50 | ||
282 | #define MX53_INT_GPIO1_HIGH 51 | ||
283 | #define MX53_INT_GPIO2_LOW 52 | ||
284 | #define MX53_INT_GPIO2_HIGH 53 | ||
285 | #define MX53_INT_GPIO3_LOW 54 | ||
286 | #define MX53_INT_GPIO3_HIGH 55 | ||
287 | #define MX53_INT_GPIO4_LOW 56 | ||
288 | #define MX53_INT_GPIO4_HIGH 57 | ||
289 | #define MX53_INT_WDOG1 58 | ||
290 | #define MX53_INT_WDOG2 59 | ||
291 | #define MX53_INT_KPP 60 | ||
292 | #define MX53_INT_PWM1 61 | ||
293 | #define MX53_INT_I2C1 62 | ||
294 | #define MX53_INT_I2C2 63 | ||
295 | #define MX53_INT_I2C3 64 | ||
296 | #define MX53_INT_RESV65 65 | ||
297 | #define MX53_INT_RESV66 66 | ||
298 | #define MX53_INT_SPDIF 67 | ||
299 | #define MX53_INT_SIM_DAT 68 | ||
300 | #define MX53_INT_IIM 69 | ||
301 | #define MX53_INT_ATA 70 | ||
302 | #define MX53_INT_CCM1 71 | ||
303 | #define MX53_INT_CCM2 72 | ||
304 | #define MX53_INT_GPC1 73 | ||
305 | #define MX53_INT_GPC2 74 | ||
306 | #define MX53_INT_SRC 75 | ||
307 | #define MX53_INT_NM 76 | ||
308 | #define MX53_INT_PMU 77 | ||
309 | #define MX53_INT_CTI_IRQ 78 | ||
310 | #define MX53_INT_CTI1_TG0 79 | ||
311 | #define MX53_INT_CTI1_TG1 80 | ||
312 | #define MX53_INT_ESAI 81 | ||
313 | #define MX53_INT_CAN1 82 | ||
314 | #define MX53_INT_CAN2 83 | ||
315 | #define MX53_INT_GPU2_IRQ 84 | ||
316 | #define MX53_INT_GPU2_BUSY 85 | ||
317 | #define MX53_INT_RESV86 86 | ||
318 | #define MX53_INT_FEC 87 | ||
319 | #define MX53_INT_OWIRE 88 | ||
320 | #define MX53_INT_CTI1_TG2 89 | ||
321 | #define MX53_INT_SJC 90 | ||
322 | #define MX53_INT_TVE 92 | ||
323 | #define MX53_INT_FIRI 93 | ||
324 | #define MX53_INT_PWM2 94 | ||
325 | #define MX53_INT_SLIM_EXP 95 | ||
326 | #define MX53_INT_SSI3 96 | ||
327 | #define MX53_INT_EMI_BOOT 97 | ||
328 | #define MX53_INT_CTI1_TG3 98 | ||
329 | #define MX53_INT_SMC_RX 99 | ||
330 | #define MX53_INT_VPU_IDLE 100 | ||
331 | #define MX53_INT_EMI_NFC 101 | ||
332 | #define MX53_INT_GPU_IDLE 102 | ||
333 | #define MX53_INT_GPIO5_LOW 103 | ||
334 | #define MX53_INT_GPIO5_HIGH 104 | ||
335 | #define MX53_INT_GPIO6_LOW 105 | ||
336 | #define MX53_INT_GPIO6_HIGH 106 | ||
337 | #define MX53_INT_GPIO7_LOW 107 | ||
338 | #define MX53_INT_GPIO7_HIGH 108 | ||
339 | |||
340 | /* silicon revisions specific to i.MX53 */ | ||
341 | #define MX53_CHIP_REV_1_0 0x10 | ||
342 | #define MX53_CHIP_REV_1_1 0x11 | ||
343 | #define MX53_CHIP_REV_1_2 0x12 | ||
344 | #define MX53_CHIP_REV_1_3 0x13 | ||
345 | #define MX53_CHIP_REV_2_0 0x20 | ||
346 | #define MX53_CHIP_REV_2_1 0x21 | ||
347 | #define MX53_CHIP_REV_2_2 0x22 | ||
348 | #define MX53_CHIP_REV_2_3 0x23 | ||
349 | #define MX53_CHIP_REV_3_0 0x30 | ||
350 | #define MX53_CHIP_REV_3_1 0x31 | ||
351 | #define MX53_CHIP_REV_3_2 0x32 | ||
352 | |||
353 | #endif /* ifndef __MACH_MX53_H__ */ | ||
diff --git a/arch/arm/plat-mxc/include/mach/mxc.h b/arch/arm/plat-mxc/include/mach/mxc.h index a42c7207082d..4c17515650b8 100644 --- a/arch/arm/plat-mxc/include/mach/mxc.h +++ b/arch/arm/plat-mxc/include/mach/mxc.h | |||
@@ -33,6 +33,7 @@ | |||
33 | #define MXC_CPU_MX31 31 | 33 | #define MXC_CPU_MX31 31 |
34 | #define MXC_CPU_MX35 35 | 34 | #define MXC_CPU_MX35 35 |
35 | #define MXC_CPU_MX51 51 | 35 | #define MXC_CPU_MX51 51 |
36 | #define MXC_CPU_MX53 53 | ||
36 | #define MXC_CPU_MXC91231 91231 | 37 | #define MXC_CPU_MXC91231 91231 |
37 | 38 | ||
38 | #ifndef __ASSEMBLY__ | 39 | #ifndef __ASSEMBLY__ |
@@ -119,6 +120,7 @@ extern unsigned int __mxc_cpu_type; | |||
119 | # define mxc_cpu_type MXC_CPU_MX51 | 120 | # define mxc_cpu_type MXC_CPU_MX51 |
120 | # endif | 121 | # endif |
121 | # define cpu_is_mx51() (mxc_cpu_type == MXC_CPU_MX51) | 122 | # define cpu_is_mx51() (mxc_cpu_type == MXC_CPU_MX51) |
123 | # define cpu_is_mx53() (mxc_cpu_type == MXC_CPU_MX53) | ||
122 | #else | 124 | #else |
123 | # define cpu_is_mx51() (0) | 125 | # define cpu_is_mx51() (0) |
124 | #endif | 126 | #endif |