diff options
Diffstat (limited to 'arch')
88 files changed, 4680 insertions, 852 deletions
diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig index 0063845d2088..139212f38ad5 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig | |||
@@ -260,6 +260,7 @@ config ARCH_INTEGRATOR | |||
260 | select ICST | 260 | select ICST |
261 | select GENERIC_CLOCKEVENTS | 261 | select GENERIC_CLOCKEVENTS |
262 | select PLAT_VERSATILE | 262 | select PLAT_VERSATILE |
263 | select PLAT_VERSATILE_CLOCK | ||
263 | select PLAT_VERSATILE_FPGA_IRQ | 264 | select PLAT_VERSATILE_FPGA_IRQ |
264 | select NEED_MACH_IO_H | 265 | select NEED_MACH_IO_H |
265 | select NEED_MACH_MEMORY_H | 266 | select NEED_MACH_MEMORY_H |
@@ -277,6 +278,7 @@ config ARCH_REALVIEW | |||
277 | select GENERIC_CLOCKEVENTS | 278 | select GENERIC_CLOCKEVENTS |
278 | select ARCH_WANT_OPTIONAL_GPIOLIB | 279 | select ARCH_WANT_OPTIONAL_GPIOLIB |
279 | select PLAT_VERSATILE | 280 | select PLAT_VERSATILE |
281 | select PLAT_VERSATILE_CLOCK | ||
280 | select PLAT_VERSATILE_CLCD | 282 | select PLAT_VERSATILE_CLCD |
281 | select ARM_TIMER_SP804 | 283 | select ARM_TIMER_SP804 |
282 | select GPIO_PL061 if GPIOLIB | 284 | select GPIO_PL061 if GPIOLIB |
@@ -295,6 +297,7 @@ config ARCH_VERSATILE | |||
295 | select ARCH_WANT_OPTIONAL_GPIOLIB | 297 | select ARCH_WANT_OPTIONAL_GPIOLIB |
296 | select NEED_MACH_IO_H if PCI | 298 | select NEED_MACH_IO_H if PCI |
297 | select PLAT_VERSATILE | 299 | select PLAT_VERSATILE |
300 | select PLAT_VERSATILE_CLOCK | ||
298 | select PLAT_VERSATILE_CLCD | 301 | select PLAT_VERSATILE_CLCD |
299 | select PLAT_VERSATILE_FPGA_IRQ | 302 | select PLAT_VERSATILE_FPGA_IRQ |
300 | select ARM_TIMER_SP804 | 303 | select ARM_TIMER_SP804 |
@@ -307,7 +310,7 @@ config ARCH_VEXPRESS | |||
307 | select ARM_AMBA | 310 | select ARM_AMBA |
308 | select ARM_TIMER_SP804 | 311 | select ARM_TIMER_SP804 |
309 | select CLKDEV_LOOKUP | 312 | select CLKDEV_LOOKUP |
310 | select HAVE_MACH_CLKDEV | 313 | select COMMON_CLK |
311 | select GENERIC_CLOCKEVENTS | 314 | select GENERIC_CLOCKEVENTS |
312 | select HAVE_CLK | 315 | select HAVE_CLK |
313 | select HAVE_PATA_PLATFORM | 316 | select HAVE_PATA_PLATFORM |
@@ -315,6 +318,7 @@ config ARCH_VEXPRESS | |||
315 | select NO_IOPORT | 318 | select NO_IOPORT |
316 | select PLAT_VERSATILE | 319 | select PLAT_VERSATILE |
317 | select PLAT_VERSATILE_CLCD | 320 | select PLAT_VERSATILE_CLCD |
321 | select REGULATOR_FIXED_VOLTAGE if REGULATOR | ||
318 | help | 322 | help |
319 | This enables support for the ARM Ltd Versatile Express boards. | 323 | This enables support for the ARM Ltd Versatile Express boards. |
320 | 324 | ||
@@ -567,6 +571,7 @@ config ARCH_LPC32XX | |||
567 | select CLKDEV_LOOKUP | 571 | select CLKDEV_LOOKUP |
568 | select GENERIC_CLOCKEVENTS | 572 | select GENERIC_CLOCKEVENTS |
569 | select USE_OF | 573 | select USE_OF |
574 | select HAVE_PWM | ||
570 | help | 575 | help |
571 | Support for the NXP LPC32XX family of processors | 576 | Support for the NXP LPC32XX family of processors |
572 | 577 | ||
@@ -913,7 +918,7 @@ config ARCH_NOMADIK | |||
913 | select ARM_AMBA | 918 | select ARM_AMBA |
914 | select ARM_VIC | 919 | select ARM_VIC |
915 | select CPU_ARM926T | 920 | select CPU_ARM926T |
916 | select CLKDEV_LOOKUP | 921 | select COMMON_CLK |
917 | select GENERIC_CLOCKEVENTS | 922 | select GENERIC_CLOCKEVENTS |
918 | select PINCTRL | 923 | select PINCTRL |
919 | select MIGHT_HAVE_CACHE_L2X0 | 924 | select MIGHT_HAVE_CACHE_L2X0 |
@@ -1022,8 +1027,6 @@ source "arch/arm/mach-kirkwood/Kconfig" | |||
1022 | 1027 | ||
1023 | source "arch/arm/mach-ks8695/Kconfig" | 1028 | source "arch/arm/mach-ks8695/Kconfig" |
1024 | 1029 | ||
1025 | source "arch/arm/mach-lpc32xx/Kconfig" | ||
1026 | |||
1027 | source "arch/arm/mach-msm/Kconfig" | 1030 | source "arch/arm/mach-msm/Kconfig" |
1028 | 1031 | ||
1029 | source "arch/arm/mach-mv78xx0/Kconfig" | 1032 | source "arch/arm/mach-mv78xx0/Kconfig" |
diff --git a/arch/arm/Kconfig.debug b/arch/arm/Kconfig.debug index 01a134141216..a03b5a7059e2 100644 --- a/arch/arm/Kconfig.debug +++ b/arch/arm/Kconfig.debug | |||
@@ -310,6 +310,32 @@ choice | |||
310 | The uncompressor code port configuration is now handled | 310 | The uncompressor code port configuration is now handled |
311 | by CONFIG_S3C_LOWLEVEL_UART_PORT. | 311 | by CONFIG_S3C_LOWLEVEL_UART_PORT. |
312 | 312 | ||
313 | config DEBUG_VEXPRESS_UART0_DETECT | ||
314 | bool "Autodetect UART0 on Versatile Express Cortex-A core tiles" | ||
315 | depends on ARCH_VEXPRESS && CPU_CP15_MMU | ||
316 | help | ||
317 | This option enables a simple heuristic which tries to determine | ||
318 | the motherboard's memory map variant (original or RS1) and then | ||
319 | choose the relevant UART0 base address. | ||
320 | |||
321 | Note that this will only work with standard A-class core tiles, | ||
322 | and may fail with non-standard SMM or custom software models. | ||
323 | |||
324 | config DEBUG_VEXPRESS_UART0_CA9 | ||
325 | bool "Use PL011 UART0 at 0x10009000 (V2P-CA9 core tile)" | ||
326 | depends on ARCH_VEXPRESS | ||
327 | help | ||
328 | This option selects UART0 at 0x10009000. Except for custom models, | ||
329 | this applies only to the V2P-CA9 tile. | ||
330 | |||
331 | config DEBUG_VEXPRESS_UART0_RS1 | ||
332 | bool "Use PL011 UART0 at 0x1c090000 (RS1 complaint tiles)" | ||
333 | depends on ARCH_VEXPRESS | ||
334 | help | ||
335 | This option selects UART0 at 0x1c090000. This applies to most | ||
336 | of the tiles using the RS1 memory map, including all new A-class | ||
337 | core tiles, FPGA-based SMMs and software models. | ||
338 | |||
313 | config DEBUG_LL_UART_NONE | 339 | config DEBUG_LL_UART_NONE |
314 | bool "No low-level debugging UART" | 340 | bool "No low-level debugging UART" |
315 | help | 341 | help |
diff --git a/arch/arm/boot/dts/ea3250.dts b/arch/arm/boot/dts/ea3250.dts new file mode 100644 index 000000000000..c07ba8c2cc0d --- /dev/null +++ b/arch/arm/boot/dts/ea3250.dts | |||
@@ -0,0 +1,157 @@ | |||
1 | /* | ||
2 | * Embedded Artists LPC3250 board | ||
3 | * | ||
4 | * Copyright 2012 Roland Stigge <stigge@antcom.de> | ||
5 | * | ||
6 | * The code contained herein is licensed under the GNU General Public | ||
7 | * License. You may obtain a copy of the GNU General Public License | ||
8 | * Version 2 or later at the following locations: | ||
9 | * | ||
10 | * http://www.opensource.org/licenses/gpl-license.html | ||
11 | * http://www.gnu.org/copyleft/gpl.html | ||
12 | */ | ||
13 | |||
14 | /dts-v1/; | ||
15 | /include/ "lpc32xx.dtsi" | ||
16 | |||
17 | / { | ||
18 | model = "Embedded Artists LPC3250 board based on NXP LPC3250"; | ||
19 | compatible = "ea,ea3250", "nxp,lpc3250"; | ||
20 | #address-cells = <1>; | ||
21 | #size-cells = <1>; | ||
22 | |||
23 | memory { | ||
24 | device_type = "memory"; | ||
25 | reg = <0 0x4000000>; | ||
26 | }; | ||
27 | |||
28 | ahb { | ||
29 | mac: ethernet@31060000 { | ||
30 | phy-mode = "rmii"; | ||
31 | use-iram; | ||
32 | }; | ||
33 | |||
34 | /* Here, choose exactly one from: ohci, usbd */ | ||
35 | ohci@31020000 { | ||
36 | transceiver = <&isp1301>; | ||
37 | status = "okay"; | ||
38 | }; | ||
39 | |||
40 | /* | ||
41 | usbd@31020000 { | ||
42 | transceiver = <&isp1301>; | ||
43 | status = "okay"; | ||
44 | }; | ||
45 | */ | ||
46 | |||
47 | /* 128MB Flash via SLC NAND controller */ | ||
48 | slc: flash@20020000 { | ||
49 | status = "okay"; | ||
50 | #address-cells = <1>; | ||
51 | #size-cells = <1>; | ||
52 | |||
53 | nxp,wdr-clks = <14>; | ||
54 | nxp,wwidth = <260000000>; | ||
55 | nxp,whold = <104000000>; | ||
56 | nxp,wsetup = <200000000>; | ||
57 | nxp,rdr-clks = <14>; | ||
58 | nxp,rwidth = <34666666>; | ||
59 | nxp,rhold = <104000000>; | ||
60 | nxp,rsetup = <200000000>; | ||
61 | nand-on-flash-bbt; | ||
62 | gpios = <&gpio 5 19 1>; /* GPO_P3 19, active low */ | ||
63 | |||
64 | mtd0@00000000 { | ||
65 | label = "ea3250-boot"; | ||
66 | reg = <0x00000000 0x00080000>; | ||
67 | read-only; | ||
68 | }; | ||
69 | |||
70 | mtd1@00080000 { | ||
71 | label = "ea3250-uboot"; | ||
72 | reg = <0x00080000 0x000c0000>; | ||
73 | read-only; | ||
74 | }; | ||
75 | |||
76 | mtd2@00140000 { | ||
77 | label = "ea3250-kernel"; | ||
78 | reg = <0x00140000 0x00400000>; | ||
79 | }; | ||
80 | |||
81 | mtd3@00540000 { | ||
82 | label = "ea3250-rootfs"; | ||
83 | reg = <0x00540000 0x07ac0000>; | ||
84 | }; | ||
85 | }; | ||
86 | |||
87 | apb { | ||
88 | uart5: serial@40090000 { | ||
89 | status = "okay"; | ||
90 | }; | ||
91 | |||
92 | uart3: serial@40080000 { | ||
93 | status = "okay"; | ||
94 | }; | ||
95 | |||
96 | uart6: serial@40098000 { | ||
97 | status = "okay"; | ||
98 | }; | ||
99 | |||
100 | i2c1: i2c@400A0000 { | ||
101 | clock-frequency = <100000>; | ||
102 | |||
103 | eeprom@50 { | ||
104 | compatible = "at,24c256"; | ||
105 | reg = <0x50>; | ||
106 | }; | ||
107 | |||
108 | eeprom@57 { | ||
109 | compatible = "at,24c64"; | ||
110 | reg = <0x57>; | ||
111 | }; | ||
112 | |||
113 | uda1380: uda1380@18 { | ||
114 | compatible = "nxp,uda1380"; | ||
115 | reg = <0x18>; | ||
116 | power-gpio = <&gpio 0x59 0>; | ||
117 | reset-gpio = <&gpio 0x51 0>; | ||
118 | dac-clk = "wspll"; | ||
119 | }; | ||
120 | |||
121 | pca9532: pca9532@60 { | ||
122 | compatible = "nxp,pca9532"; | ||
123 | gpio-controller; | ||
124 | #gpio-cells = <2>; | ||
125 | reg = <0x60>; | ||
126 | }; | ||
127 | }; | ||
128 | |||
129 | i2c2: i2c@400A8000 { | ||
130 | clock-frequency = <100000>; | ||
131 | }; | ||
132 | |||
133 | i2cusb: i2c@31020300 { | ||
134 | clock-frequency = <100000>; | ||
135 | |||
136 | isp1301: usb-transceiver@2d { | ||
137 | compatible = "nxp,isp1301"; | ||
138 | reg = <0x2d>; | ||
139 | }; | ||
140 | }; | ||
141 | |||
142 | sd@20098000 { | ||
143 | wp-gpios = <&pca9532 5 0>; | ||
144 | cd-gpios = <&pca9532 4 0>; | ||
145 | cd-inverted; | ||
146 | bus-width = <4>; | ||
147 | status = "okay"; | ||
148 | }; | ||
149 | }; | ||
150 | |||
151 | fab { | ||
152 | uart1: serial@40014000 { | ||
153 | status = "okay"; | ||
154 | }; | ||
155 | }; | ||
156 | }; | ||
157 | }; | ||
diff --git a/arch/arm/boot/dts/lpc32xx.dtsi b/arch/arm/boot/dts/lpc32xx.dtsi index 3f5dad801a98..c5f37fbd33e6 100644 --- a/arch/arm/boot/dts/lpc32xx.dtsi +++ b/arch/arm/boot/dts/lpc32xx.dtsi | |||
@@ -35,13 +35,14 @@ | |||
35 | slc: flash@20020000 { | 35 | slc: flash@20020000 { |
36 | compatible = "nxp,lpc3220-slc"; | 36 | compatible = "nxp,lpc3220-slc"; |
37 | reg = <0x20020000 0x1000>; | 37 | reg = <0x20020000 0x1000>; |
38 | status = "disable"; | 38 | status = "disabled"; |
39 | }; | 39 | }; |
40 | 40 | ||
41 | mlc: flash@200B0000 { | 41 | mlc: flash@200a8000 { |
42 | compatible = "nxp,lpc3220-mlc"; | 42 | compatible = "nxp,lpc3220-mlc"; |
43 | reg = <0x200B0000 0x1000>; | 43 | reg = <0x200a8000 0x11000>; |
44 | status = "disable"; | 44 | interrupts = <11 0>; |
45 | status = "disabled"; | ||
45 | }; | 46 | }; |
46 | 47 | ||
47 | dma@31000000 { | 48 | dma@31000000 { |
@@ -57,21 +58,21 @@ | |||
57 | compatible = "nxp,ohci-nxp", "usb-ohci"; | 58 | compatible = "nxp,ohci-nxp", "usb-ohci"; |
58 | reg = <0x31020000 0x300>; | 59 | reg = <0x31020000 0x300>; |
59 | interrupts = <0x3b 0>; | 60 | interrupts = <0x3b 0>; |
60 | status = "disable"; | 61 | status = "disabled"; |
61 | }; | 62 | }; |
62 | 63 | ||
63 | usbd@31020000 { | 64 | usbd@31020000 { |
64 | compatible = "nxp,lpc3220-udc"; | 65 | compatible = "nxp,lpc3220-udc"; |
65 | reg = <0x31020000 0x300>; | 66 | reg = <0x31020000 0x300>; |
66 | interrupts = <0x3d 0>, <0x3e 0>, <0x3c 0>, <0x3a 0>; | 67 | interrupts = <0x3d 0>, <0x3e 0>, <0x3c 0>, <0x3a 0>; |
67 | status = "disable"; | 68 | status = "disabled"; |
68 | }; | 69 | }; |
69 | 70 | ||
70 | clcd@31040000 { | 71 | clcd@31040000 { |
71 | compatible = "arm,pl110", "arm,primecell"; | 72 | compatible = "arm,pl110", "arm,primecell"; |
72 | reg = <0x31040000 0x1000>; | 73 | reg = <0x31040000 0x1000>; |
73 | interrupts = <0x0e 0>; | 74 | interrupts = <0x0e 0>; |
74 | status = "disable"; | 75 | status = "disabled"; |
75 | }; | 76 | }; |
76 | 77 | ||
77 | mac: ethernet@31060000 { | 78 | mac: ethernet@31060000 { |
@@ -114,9 +115,10 @@ | |||
114 | }; | 115 | }; |
115 | 116 | ||
116 | sd@20098000 { | 117 | sd@20098000 { |
117 | compatible = "arm,pl180", "arm,primecell"; | 118 | compatible = "arm,pl18x", "arm,primecell"; |
118 | reg = <0x20098000 0x1000>; | 119 | reg = <0x20098000 0x1000>; |
119 | interrupts = <0x0f 0>, <0x0d 0>; | 120 | interrupts = <0x0f 0>, <0x0d 0>; |
121 | status = "disabled"; | ||
120 | }; | 122 | }; |
121 | 123 | ||
122 | i2s1: i2s@2009C000 { | 124 | i2s1: i2s@2009C000 { |
@@ -124,24 +126,42 @@ | |||
124 | reg = <0x2009C000 0x1000>; | 126 | reg = <0x2009C000 0x1000>; |
125 | }; | 127 | }; |
126 | 128 | ||
129 | /* UART5 first since it is the default console, ttyS0 */ | ||
130 | uart5: serial@40090000 { | ||
131 | /* actually, ns16550a w/ 64 byte fifos! */ | ||
132 | compatible = "nxp,lpc3220-uart"; | ||
133 | reg = <0x40090000 0x1000>; | ||
134 | interrupts = <9 0>; | ||
135 | clock-frequency = <13000000>; | ||
136 | reg-shift = <2>; | ||
137 | status = "disabled"; | ||
138 | }; | ||
139 | |||
127 | uart3: serial@40080000 { | 140 | uart3: serial@40080000 { |
128 | compatible = "nxp,serial"; | 141 | compatible = "nxp,lpc3220-uart"; |
129 | reg = <0x40080000 0x1000>; | 142 | reg = <0x40080000 0x1000>; |
143 | interrupts = <7 0>; | ||
144 | clock-frequency = <13000000>; | ||
145 | reg-shift = <2>; | ||
146 | status = "disabled"; | ||
130 | }; | 147 | }; |
131 | 148 | ||
132 | uart4: serial@40088000 { | 149 | uart4: serial@40088000 { |
133 | compatible = "nxp,serial"; | 150 | compatible = "nxp,lpc3220-uart"; |
134 | reg = <0x40088000 0x1000>; | 151 | reg = <0x40088000 0x1000>; |
135 | }; | 152 | interrupts = <8 0>; |
136 | 153 | clock-frequency = <13000000>; | |
137 | uart5: serial@40090000 { | 154 | reg-shift = <2>; |
138 | compatible = "nxp,serial"; | 155 | status = "disabled"; |
139 | reg = <0x40090000 0x1000>; | ||
140 | }; | 156 | }; |
141 | 157 | ||
142 | uart6: serial@40098000 { | 158 | uart6: serial@40098000 { |
143 | compatible = "nxp,serial"; | 159 | compatible = "nxp,lpc3220-uart"; |
144 | reg = <0x40098000 0x1000>; | 160 | reg = <0x40098000 0x1000>; |
161 | interrupts = <10 0>; | ||
162 | clock-frequency = <13000000>; | ||
163 | reg-shift = <2>; | ||
164 | status = "disabled"; | ||
145 | }; | 165 | }; |
146 | 166 | ||
147 | i2c1: i2c@400A0000 { | 167 | i2c1: i2c@400A0000 { |
@@ -192,18 +212,24 @@ | |||
192 | }; | 212 | }; |
193 | 213 | ||
194 | uart1: serial@40014000 { | 214 | uart1: serial@40014000 { |
195 | compatible = "nxp,serial"; | 215 | compatible = "nxp,lpc3220-hsuart"; |
196 | reg = <0x40014000 0x1000>; | 216 | reg = <0x40014000 0x1000>; |
217 | interrupts = <26 0>; | ||
218 | status = "disabled"; | ||
197 | }; | 219 | }; |
198 | 220 | ||
199 | uart2: serial@40018000 { | 221 | uart2: serial@40018000 { |
200 | compatible = "nxp,serial"; | 222 | compatible = "nxp,lpc3220-hsuart"; |
201 | reg = <0x40018000 0x1000>; | 223 | reg = <0x40018000 0x1000>; |
224 | interrupts = <25 0>; | ||
225 | status = "disabled"; | ||
202 | }; | 226 | }; |
203 | 227 | ||
204 | uart7: serial@4001C000 { | 228 | uart7: serial@4001c000 { |
205 | compatible = "nxp,serial"; | 229 | compatible = "nxp,lpc3220-hsuart"; |
206 | reg = <0x4001C000 0x1000>; | 230 | reg = <0x4001c000 0x1000>; |
231 | interrupts = <24 0>; | ||
232 | status = "disabled"; | ||
207 | }; | 233 | }; |
208 | 234 | ||
209 | rtc@40024000 { | 235 | rtc@40024000 { |
@@ -235,19 +261,21 @@ | |||
235 | compatible = "nxp,lpc3220-adc"; | 261 | compatible = "nxp,lpc3220-adc"; |
236 | reg = <0x40048000 0x1000>; | 262 | reg = <0x40048000 0x1000>; |
237 | interrupts = <0x27 0>; | 263 | interrupts = <0x27 0>; |
238 | status = "disable"; | 264 | status = "disabled"; |
239 | }; | 265 | }; |
240 | 266 | ||
241 | tsc@40048000 { | 267 | tsc@40048000 { |
242 | compatible = "nxp,lpc3220-tsc"; | 268 | compatible = "nxp,lpc3220-tsc"; |
243 | reg = <0x40048000 0x1000>; | 269 | reg = <0x40048000 0x1000>; |
244 | interrupts = <0x27 0>; | 270 | interrupts = <0x27 0>; |
245 | status = "disable"; | 271 | status = "disabled"; |
246 | }; | 272 | }; |
247 | 273 | ||
248 | key@40050000 { | 274 | key@40050000 { |
249 | compatible = "nxp,lpc3220-key"; | 275 | compatible = "nxp,lpc3220-key"; |
250 | reg = <0x40050000 0x1000>; | 276 | reg = <0x40050000 0x1000>; |
277 | interrupts = <54 0>; | ||
278 | status = "disabled"; | ||
251 | }; | 279 | }; |
252 | 280 | ||
253 | }; | 281 | }; |
diff --git a/arch/arm/boot/dts/phy3250.dts b/arch/arm/boot/dts/phy3250.dts index c4ff6d1a018b..802ec5b2fd00 100644 --- a/arch/arm/boot/dts/phy3250.dts +++ b/arch/arm/boot/dts/phy3250.dts | |||
@@ -54,6 +54,17 @@ | |||
54 | #address-cells = <1>; | 54 | #address-cells = <1>; |
55 | #size-cells = <1>; | 55 | #size-cells = <1>; |
56 | 56 | ||
57 | nxp,wdr-clks = <14>; | ||
58 | nxp,wwidth = <40000000>; | ||
59 | nxp,whold = <100000000>; | ||
60 | nxp,wsetup = <100000000>; | ||
61 | nxp,rdr-clks = <14>; | ||
62 | nxp,rwidth = <40000000>; | ||
63 | nxp,rhold = <66666666>; | ||
64 | nxp,rsetup = <100000000>; | ||
65 | nand-on-flash-bbt; | ||
66 | gpios = <&gpio 5 19 1>; /* GPO_P3 19, active low */ | ||
67 | |||
57 | mtd0@00000000 { | 68 | mtd0@00000000 { |
58 | label = "phy3250-boot"; | 69 | label = "phy3250-boot"; |
59 | reg = <0x00000000 0x00064000>; | 70 | reg = <0x00000000 0x00064000>; |
@@ -83,6 +94,14 @@ | |||
83 | }; | 94 | }; |
84 | 95 | ||
85 | apb { | 96 | apb { |
97 | uart5: serial@40090000 { | ||
98 | status = "okay"; | ||
99 | }; | ||
100 | |||
101 | uart3: serial@40080000 { | ||
102 | status = "okay"; | ||
103 | }; | ||
104 | |||
86 | i2c1: i2c@400A0000 { | 105 | i2c1: i2c@400A0000 { |
87 | clock-frequency = <100000>; | 106 | clock-frequency = <100000>; |
88 | 107 | ||
@@ -114,16 +133,58 @@ | |||
114 | }; | 133 | }; |
115 | 134 | ||
116 | ssp0: ssp@20084000 { | 135 | ssp0: ssp@20084000 { |
136 | #address-cells = <1>; | ||
137 | #size-cells = <0>; | ||
138 | pl022,num-chipselects = <1>; | ||
139 | cs-gpios = <&gpio 3 5 0>; | ||
140 | |||
117 | eeprom: at25@0 { | 141 | eeprom: at25@0 { |
142 | pl022,hierarchy = <0>; | ||
143 | pl022,interface = <0>; | ||
144 | pl022,slave-tx-disable = <0>; | ||
145 | pl022,com-mode = <0>; | ||
146 | pl022,rx-level-trig = <1>; | ||
147 | pl022,tx-level-trig = <1>; | ||
148 | pl022,ctrl-len = <11>; | ||
149 | pl022,wait-state = <0>; | ||
150 | pl022,duplex = <0>; | ||
151 | |||
152 | at25,byte-len = <0x8000>; | ||
153 | at25,addr-mode = <2>; | ||
154 | at25,page-size = <64>; | ||
155 | |||
118 | compatible = "atmel,at25"; | 156 | compatible = "atmel,at25"; |
157 | reg = <0>; | ||
158 | spi-max-frequency = <5000000>; | ||
119 | }; | 159 | }; |
120 | }; | 160 | }; |
161 | |||
162 | sd@20098000 { | ||
163 | wp-gpios = <&gpio 3 0 0>; | ||
164 | cd-gpios = <&gpio 3 1 0>; | ||
165 | cd-inverted; | ||
166 | bus-width = <4>; | ||
167 | status = "okay"; | ||
168 | }; | ||
121 | }; | 169 | }; |
122 | 170 | ||
123 | fab { | 171 | fab { |
172 | uart2: serial@40018000 { | ||
173 | status = "okay"; | ||
174 | }; | ||
175 | |||
124 | tsc@40048000 { | 176 | tsc@40048000 { |
125 | status = "okay"; | 177 | status = "okay"; |
126 | }; | 178 | }; |
179 | |||
180 | key@40050000 { | ||
181 | status = "okay"; | ||
182 | keypad,num-rows = <1>; | ||
183 | keypad,num-columns = <1>; | ||
184 | nxp,debounce-delay-ms = <3>; | ||
185 | nxp,scan-delay-ms = <34>; | ||
186 | linux,keymap = <0x00000002>; | ||
187 | }; | ||
127 | }; | 188 | }; |
128 | }; | 189 | }; |
129 | 190 | ||
diff --git a/arch/arm/boot/dts/vexpress-v2m-rs1.dtsi b/arch/arm/boot/dts/vexpress-v2m-rs1.dtsi index 16076e2d0934..d8a827bd2bf3 100644 --- a/arch/arm/boot/dts/vexpress-v2m-rs1.dtsi +++ b/arch/arm/boot/dts/vexpress-v2m-rs1.dtsi | |||
@@ -55,6 +55,8 @@ | |||
55 | reg-io-width = <4>; | 55 | reg-io-width = <4>; |
56 | smsc,irq-active-high; | 56 | smsc,irq-active-high; |
57 | smsc,irq-push-pull; | 57 | smsc,irq-push-pull; |
58 | vdd33a-supply = <&v2m_fixed_3v3>; | ||
59 | vddvario-supply = <&v2m_fixed_3v3>; | ||
58 | }; | 60 | }; |
59 | 61 | ||
60 | usb@2,03000000 { | 62 | usb@2,03000000 { |
@@ -157,6 +159,7 @@ | |||
157 | v2m_timer23: timer@120000 { | 159 | v2m_timer23: timer@120000 { |
158 | compatible = "arm,sp804", "arm,primecell"; | 160 | compatible = "arm,sp804", "arm,primecell"; |
159 | reg = <0x120000 0x1000>; | 161 | reg = <0x120000 0x1000>; |
162 | interrupts = <3>; | ||
160 | }; | 163 | }; |
161 | 164 | ||
162 | /* DVI I2C bus */ | 165 | /* DVI I2C bus */ |
@@ -197,5 +200,13 @@ | |||
197 | interrupts = <14>; | 200 | interrupts = <14>; |
198 | }; | 201 | }; |
199 | }; | 202 | }; |
203 | |||
204 | v2m_fixed_3v3: fixedregulator@0 { | ||
205 | compatible = "regulator-fixed"; | ||
206 | regulator-name = "3V3"; | ||
207 | regulator-min-microvolt = <3300000>; | ||
208 | regulator-max-microvolt = <3300000>; | ||
209 | regulator-always-on; | ||
210 | }; | ||
200 | }; | 211 | }; |
201 | }; | 212 | }; |
diff --git a/arch/arm/boot/dts/vexpress-v2m.dtsi b/arch/arm/boot/dts/vexpress-v2m.dtsi index a6c9c7c82d53..dba53fd026bb 100644 --- a/arch/arm/boot/dts/vexpress-v2m.dtsi +++ b/arch/arm/boot/dts/vexpress-v2m.dtsi | |||
@@ -54,6 +54,8 @@ | |||
54 | reg-io-width = <4>; | 54 | reg-io-width = <4>; |
55 | smsc,irq-active-high; | 55 | smsc,irq-active-high; |
56 | smsc,irq-push-pull; | 56 | smsc,irq-push-pull; |
57 | vdd33a-supply = <&v2m_fixed_3v3>; | ||
58 | vddvario-supply = <&v2m_fixed_3v3>; | ||
57 | }; | 59 | }; |
58 | 60 | ||
59 | usb@3,03000000 { | 61 | usb@3,03000000 { |
@@ -156,6 +158,7 @@ | |||
156 | v2m_timer23: timer@12000 { | 158 | v2m_timer23: timer@12000 { |
157 | compatible = "arm,sp804", "arm,primecell"; | 159 | compatible = "arm,sp804", "arm,primecell"; |
158 | reg = <0x12000 0x1000>; | 160 | reg = <0x12000 0x1000>; |
161 | interrupts = <3>; | ||
159 | }; | 162 | }; |
160 | 163 | ||
161 | /* DVI I2C bus */ | 164 | /* DVI I2C bus */ |
@@ -196,5 +199,13 @@ | |||
196 | interrupts = <14>; | 199 | interrupts = <14>; |
197 | }; | 200 | }; |
198 | }; | 201 | }; |
202 | |||
203 | v2m_fixed_3v3: fixedregulator@0 { | ||
204 | compatible = "regulator-fixed"; | ||
205 | regulator-name = "3V3"; | ||
206 | regulator-min-microvolt = <3300000>; | ||
207 | regulator-max-microvolt = <3300000>; | ||
208 | regulator-always-on; | ||
209 | }; | ||
199 | }; | 210 | }; |
200 | }; | 211 | }; |
diff --git a/arch/arm/boot/dts/vexpress-v2p-ca15-tc1.dts b/arch/arm/boot/dts/vexpress-v2p-ca15-tc1.dts index 7e1091d91af8..d12b34ca0568 100644 --- a/arch/arm/boot/dts/vexpress-v2p-ca15-tc1.dts +++ b/arch/arm/boot/dts/vexpress-v2p-ca15-tc1.dts | |||
@@ -14,8 +14,8 @@ | |||
14 | arm,hbi = <0x237>; | 14 | arm,hbi = <0x237>; |
15 | compatible = "arm,vexpress,v2p-ca15,tc1", "arm,vexpress,v2p-ca15", "arm,vexpress"; | 15 | compatible = "arm,vexpress,v2p-ca15,tc1", "arm,vexpress,v2p-ca15", "arm,vexpress"; |
16 | interrupt-parent = <&gic>; | 16 | interrupt-parent = <&gic>; |
17 | #address-cells = <1>; | 17 | #address-cells = <2>; |
18 | #size-cells = <1>; | 18 | #size-cells = <2>; |
19 | 19 | ||
20 | chosen { }; | 20 | chosen { }; |
21 | 21 | ||
@@ -47,23 +47,23 @@ | |||
47 | 47 | ||
48 | memory@80000000 { | 48 | memory@80000000 { |
49 | device_type = "memory"; | 49 | device_type = "memory"; |
50 | reg = <0x80000000 0x40000000>; | 50 | reg = <0 0x80000000 0 0x40000000>; |
51 | }; | 51 | }; |
52 | 52 | ||
53 | hdlcd@2b000000 { | 53 | hdlcd@2b000000 { |
54 | compatible = "arm,hdlcd"; | 54 | compatible = "arm,hdlcd"; |
55 | reg = <0x2b000000 0x1000>; | 55 | reg = <0 0x2b000000 0 0x1000>; |
56 | interrupts = <0 85 4>; | 56 | interrupts = <0 85 4>; |
57 | }; | 57 | }; |
58 | 58 | ||
59 | memory-controller@2b0a0000 { | 59 | memory-controller@2b0a0000 { |
60 | compatible = "arm,pl341", "arm,primecell"; | 60 | compatible = "arm,pl341", "arm,primecell"; |
61 | reg = <0x2b0a0000 0x1000>; | 61 | reg = <0 0x2b0a0000 0 0x1000>; |
62 | }; | 62 | }; |
63 | 63 | ||
64 | wdt@2b060000 { | 64 | wdt@2b060000 { |
65 | compatible = "arm,sp805", "arm,primecell"; | 65 | compatible = "arm,sp805", "arm,primecell"; |
66 | reg = <0x2b060000 0x1000>; | 66 | reg = <0 0x2b060000 0 0x1000>; |
67 | interrupts = <98>; | 67 | interrupts = <98>; |
68 | }; | 68 | }; |
69 | 69 | ||
@@ -72,23 +72,23 @@ | |||
72 | #interrupt-cells = <3>; | 72 | #interrupt-cells = <3>; |
73 | #address-cells = <0>; | 73 | #address-cells = <0>; |
74 | interrupt-controller; | 74 | interrupt-controller; |
75 | reg = <0x2c001000 0x1000>, | 75 | reg = <0 0x2c001000 0 0x1000>, |
76 | <0x2c002000 0x1000>, | 76 | <0 0x2c002000 0 0x1000>, |
77 | <0x2c004000 0x2000>, | 77 | <0 0x2c004000 0 0x2000>, |
78 | <0x2c006000 0x2000>; | 78 | <0 0x2c006000 0 0x2000>; |
79 | interrupts = <1 9 0xf04>; | 79 | interrupts = <1 9 0xf04>; |
80 | }; | 80 | }; |
81 | 81 | ||
82 | memory-controller@7ffd0000 { | 82 | memory-controller@7ffd0000 { |
83 | compatible = "arm,pl354", "arm,primecell"; | 83 | compatible = "arm,pl354", "arm,primecell"; |
84 | reg = <0x7ffd0000 0x1000>; | 84 | reg = <0 0x7ffd0000 0 0x1000>; |
85 | interrupts = <0 86 4>, | 85 | interrupts = <0 86 4>, |
86 | <0 87 4>; | 86 | <0 87 4>; |
87 | }; | 87 | }; |
88 | 88 | ||
89 | dma@7ffb0000 { | 89 | dma@7ffb0000 { |
90 | compatible = "arm,pl330", "arm,primecell"; | 90 | compatible = "arm,pl330", "arm,primecell"; |
91 | reg = <0x7ffb0000 0x1000>; | 91 | reg = <0 0x7ffb0000 0 0x1000>; |
92 | interrupts = <0 92 4>, | 92 | interrupts = <0 92 4>, |
93 | <0 88 4>, | 93 | <0 88 4>, |
94 | <0 89 4>, | 94 | <0 89 4>, |
@@ -111,12 +111,12 @@ | |||
111 | }; | 111 | }; |
112 | 112 | ||
113 | motherboard { | 113 | motherboard { |
114 | ranges = <0 0 0x08000000 0x04000000>, | 114 | ranges = <0 0 0 0x08000000 0x04000000>, |
115 | <1 0 0x14000000 0x04000000>, | 115 | <1 0 0 0x14000000 0x04000000>, |
116 | <2 0 0x18000000 0x04000000>, | 116 | <2 0 0 0x18000000 0x04000000>, |
117 | <3 0 0x1c000000 0x04000000>, | 117 | <3 0 0 0x1c000000 0x04000000>, |
118 | <4 0 0x0c000000 0x04000000>, | 118 | <4 0 0 0x0c000000 0x04000000>, |
119 | <5 0 0x10000000 0x04000000>; | 119 | <5 0 0 0x10000000 0x04000000>; |
120 | 120 | ||
121 | interrupt-map-mask = <0 0 63>; | 121 | interrupt-map-mask = <0 0 63>; |
122 | interrupt-map = <0 0 0 &gic 0 0 4>, | 122 | interrupt-map = <0 0 0 &gic 0 0 4>, |
diff --git a/arch/arm/boot/dts/vexpress-v2p-ca15_a7.dts b/arch/arm/boot/dts/vexpress-v2p-ca15_a7.dts new file mode 100644 index 000000000000..4890a81c5467 --- /dev/null +++ b/arch/arm/boot/dts/vexpress-v2p-ca15_a7.dts | |||
@@ -0,0 +1,188 @@ | |||
1 | /* | ||
2 | * ARM Ltd. Versatile Express | ||
3 | * | ||
4 | * CoreTile Express A15x2 A7x3 | ||
5 | * Cortex-A15_A7 MPCore (V2P-CA15_A7) | ||
6 | * | ||
7 | * HBI-0249A | ||
8 | */ | ||
9 | |||
10 | /dts-v1/; | ||
11 | |||
12 | / { | ||
13 | model = "V2P-CA15_CA7"; | ||
14 | arm,hbi = <0x249>; | ||
15 | compatible = "arm,vexpress,v2p-ca15_a7", "arm,vexpress"; | ||
16 | interrupt-parent = <&gic>; | ||
17 | #address-cells = <2>; | ||
18 | #size-cells = <2>; | ||
19 | |||
20 | chosen { }; | ||
21 | |||
22 | aliases { | ||
23 | serial0 = &v2m_serial0; | ||
24 | serial1 = &v2m_serial1; | ||
25 | serial2 = &v2m_serial2; | ||
26 | serial3 = &v2m_serial3; | ||
27 | i2c0 = &v2m_i2c_dvi; | ||
28 | i2c1 = &v2m_i2c_pcie; | ||
29 | }; | ||
30 | |||
31 | cpus { | ||
32 | #address-cells = <1>; | ||
33 | #size-cells = <0>; | ||
34 | |||
35 | cpu0: cpu@0 { | ||
36 | device_type = "cpu"; | ||
37 | compatible = "arm,cortex-a15"; | ||
38 | reg = <0>; | ||
39 | }; | ||
40 | |||
41 | cpu1: cpu@1 { | ||
42 | device_type = "cpu"; | ||
43 | compatible = "arm,cortex-a15"; | ||
44 | reg = <1>; | ||
45 | }; | ||
46 | |||
47 | /* A7s disabled till big.LITTLE patches are available... | ||
48 | cpu2: cpu@2 { | ||
49 | device_type = "cpu"; | ||
50 | compatible = "arm,cortex-a7"; | ||
51 | reg = <0x100>; | ||
52 | }; | ||
53 | |||
54 | cpu3: cpu@3 { | ||
55 | device_type = "cpu"; | ||
56 | compatible = "arm,cortex-a7"; | ||
57 | reg = <0x101>; | ||
58 | }; | ||
59 | |||
60 | cpu4: cpu@4 { | ||
61 | device_type = "cpu"; | ||
62 | compatible = "arm,cortex-a7"; | ||
63 | reg = <0x102>; | ||
64 | }; | ||
65 | */ | ||
66 | }; | ||
67 | |||
68 | memory@80000000 { | ||
69 | device_type = "memory"; | ||
70 | reg = <0 0x80000000 0 0x40000000>; | ||
71 | }; | ||
72 | |||
73 | wdt@2a490000 { | ||
74 | compatible = "arm,sp805", "arm,primecell"; | ||
75 | reg = <0 0x2a490000 0 0x1000>; | ||
76 | interrupts = <98>; | ||
77 | }; | ||
78 | |||
79 | hdlcd@2b000000 { | ||
80 | compatible = "arm,hdlcd"; | ||
81 | reg = <0 0x2b000000 0 0x1000>; | ||
82 | interrupts = <0 85 4>; | ||
83 | }; | ||
84 | |||
85 | memory-controller@2b0a0000 { | ||
86 | compatible = "arm,pl341", "arm,primecell"; | ||
87 | reg = <0 0x2b0a0000 0 0x1000>; | ||
88 | }; | ||
89 | |||
90 | gic: interrupt-controller@2c001000 { | ||
91 | compatible = "arm,cortex-a15-gic", "arm,cortex-a9-gic"; | ||
92 | #interrupt-cells = <3>; | ||
93 | #address-cells = <0>; | ||
94 | interrupt-controller; | ||
95 | reg = <0 0x2c001000 0 0x1000>, | ||
96 | <0 0x2c002000 0 0x1000>, | ||
97 | <0 0x2c004000 0 0x2000>, | ||
98 | <0 0x2c006000 0 0x2000>; | ||
99 | interrupts = <1 9 0xf04>; | ||
100 | }; | ||
101 | |||
102 | memory-controller@7ffd0000 { | ||
103 | compatible = "arm,pl354", "arm,primecell"; | ||
104 | reg = <0 0x7ffd0000 0 0x1000>; | ||
105 | interrupts = <0 86 4>, | ||
106 | <0 87 4>; | ||
107 | }; | ||
108 | |||
109 | dma@7ff00000 { | ||
110 | compatible = "arm,pl330", "arm,primecell"; | ||
111 | reg = <0 0x7ff00000 0 0x1000>; | ||
112 | interrupts = <0 92 4>, | ||
113 | <0 88 4>, | ||
114 | <0 89 4>, | ||
115 | <0 90 4>, | ||
116 | <0 91 4>; | ||
117 | }; | ||
118 | |||
119 | timer { | ||
120 | compatible = "arm,armv7-timer"; | ||
121 | interrupts = <1 13 0xf08>, | ||
122 | <1 14 0xf08>, | ||
123 | <1 11 0xf08>, | ||
124 | <1 10 0xf08>; | ||
125 | }; | ||
126 | |||
127 | pmu { | ||
128 | compatible = "arm,cortex-a15-pmu", "arm,cortex-a9-pmu"; | ||
129 | interrupts = <0 68 4>, | ||
130 | <0 69 4>; | ||
131 | }; | ||
132 | |||
133 | motherboard { | ||
134 | ranges = <0 0 0 0x08000000 0x04000000>, | ||
135 | <1 0 0 0x14000000 0x04000000>, | ||
136 | <2 0 0 0x18000000 0x04000000>, | ||
137 | <3 0 0 0x1c000000 0x04000000>, | ||
138 | <4 0 0 0x0c000000 0x04000000>, | ||
139 | <5 0 0 0x10000000 0x04000000>; | ||
140 | |||
141 | interrupt-map-mask = <0 0 63>; | ||
142 | interrupt-map = <0 0 0 &gic 0 0 4>, | ||
143 | <0 0 1 &gic 0 1 4>, | ||
144 | <0 0 2 &gic 0 2 4>, | ||
145 | <0 0 3 &gic 0 3 4>, | ||
146 | <0 0 4 &gic 0 4 4>, | ||
147 | <0 0 5 &gic 0 5 4>, | ||
148 | <0 0 6 &gic 0 6 4>, | ||
149 | <0 0 7 &gic 0 7 4>, | ||
150 | <0 0 8 &gic 0 8 4>, | ||
151 | <0 0 9 &gic 0 9 4>, | ||
152 | <0 0 10 &gic 0 10 4>, | ||
153 | <0 0 11 &gic 0 11 4>, | ||
154 | <0 0 12 &gic 0 12 4>, | ||
155 | <0 0 13 &gic 0 13 4>, | ||
156 | <0 0 14 &gic 0 14 4>, | ||
157 | <0 0 15 &gic 0 15 4>, | ||
158 | <0 0 16 &gic 0 16 4>, | ||
159 | <0 0 17 &gic 0 17 4>, | ||
160 | <0 0 18 &gic 0 18 4>, | ||
161 | <0 0 19 &gic 0 19 4>, | ||
162 | <0 0 20 &gic 0 20 4>, | ||
163 | <0 0 21 &gic 0 21 4>, | ||
164 | <0 0 22 &gic 0 22 4>, | ||
165 | <0 0 23 &gic 0 23 4>, | ||
166 | <0 0 24 &gic 0 24 4>, | ||
167 | <0 0 25 &gic 0 25 4>, | ||
168 | <0 0 26 &gic 0 26 4>, | ||
169 | <0 0 27 &gic 0 27 4>, | ||
170 | <0 0 28 &gic 0 28 4>, | ||
171 | <0 0 29 &gic 0 29 4>, | ||
172 | <0 0 30 &gic 0 30 4>, | ||
173 | <0 0 31 &gic 0 31 4>, | ||
174 | <0 0 32 &gic 0 32 4>, | ||
175 | <0 0 33 &gic 0 33 4>, | ||
176 | <0 0 34 &gic 0 34 4>, | ||
177 | <0 0 35 &gic 0 35 4>, | ||
178 | <0 0 36 &gic 0 36 4>, | ||
179 | <0 0 37 &gic 0 37 4>, | ||
180 | <0 0 38 &gic 0 38 4>, | ||
181 | <0 0 39 &gic 0 39 4>, | ||
182 | <0 0 40 &gic 0 40 4>, | ||
183 | <0 0 41 &gic 0 41 4>, | ||
184 | <0 0 42 &gic 0 42 4>; | ||
185 | }; | ||
186 | }; | ||
187 | |||
188 | /include/ "vexpress-v2m-rs1.dtsi" | ||
diff --git a/arch/arm/configs/lpc32xx_defconfig b/arch/arm/configs/lpc32xx_defconfig index 4fa60547494a..eceed186a3c1 100644 --- a/arch/arm/configs/lpc32xx_defconfig +++ b/arch/arm/configs/lpc32xx_defconfig | |||
@@ -1,5 +1,7 @@ | |||
1 | CONFIG_EXPERIMENTAL=y | 1 | CONFIG_EXPERIMENTAL=y |
2 | CONFIG_SYSVIPC=y | 2 | CONFIG_SYSVIPC=y |
3 | CONFIG_NO_HZ=y | ||
4 | CONFIG_HIGH_RES_TIMERS=y | ||
3 | CONFIG_IKCONFIG=y | 5 | CONFIG_IKCONFIG=y |
4 | CONFIG_IKCONFIG_PROC=y | 6 | CONFIG_IKCONFIG_PROC=y |
5 | CONFIG_LOG_BUF_SHIFT=16 | 7 | CONFIG_LOG_BUF_SHIFT=16 |
@@ -16,8 +18,6 @@ CONFIG_MODULE_UNLOAD=y | |||
16 | # CONFIG_BLK_DEV_BSG is not set | 18 | # CONFIG_BLK_DEV_BSG is not set |
17 | CONFIG_PARTITION_ADVANCED=y | 19 | CONFIG_PARTITION_ADVANCED=y |
18 | CONFIG_ARCH_LPC32XX=y | 20 | CONFIG_ARCH_LPC32XX=y |
19 | CONFIG_NO_HZ=y | ||
20 | CONFIG_HIGH_RES_TIMERS=y | ||
21 | CONFIG_PREEMPT=y | 21 | CONFIG_PREEMPT=y |
22 | CONFIG_AEABI=y | 22 | CONFIG_AEABI=y |
23 | CONFIG_ZBOOT_ROM_TEXT=0x0 | 23 | CONFIG_ZBOOT_ROM_TEXT=0x0 |
@@ -52,13 +52,17 @@ CONFIG_MTD=y | |||
52 | CONFIG_MTD_CMDLINE_PARTS=y | 52 | CONFIG_MTD_CMDLINE_PARTS=y |
53 | CONFIG_MTD_CHAR=y | 53 | CONFIG_MTD_CHAR=y |
54 | CONFIG_MTD_BLOCK=y | 54 | CONFIG_MTD_BLOCK=y |
55 | CONFIG_MTD_M25P80=y | ||
55 | CONFIG_MTD_NAND=y | 56 | CONFIG_MTD_NAND=y |
56 | CONFIG_MTD_NAND_MUSEUM_IDS=y | 57 | CONFIG_MTD_NAND_MUSEUM_IDS=y |
58 | CONFIG_MTD_NAND_SLC_LPC32XX=y | ||
59 | CONFIG_MTD_NAND_MLC_LPC32XX=y | ||
57 | CONFIG_BLK_DEV_LOOP=y | 60 | CONFIG_BLK_DEV_LOOP=y |
58 | CONFIG_BLK_DEV_CRYPTOLOOP=y | 61 | CONFIG_BLK_DEV_CRYPTOLOOP=y |
59 | CONFIG_BLK_DEV_RAM=y | 62 | CONFIG_BLK_DEV_RAM=y |
60 | CONFIG_BLK_DEV_RAM_COUNT=1 | 63 | CONFIG_BLK_DEV_RAM_COUNT=1 |
61 | CONFIG_BLK_DEV_RAM_SIZE=16384 | 64 | CONFIG_BLK_DEV_RAM_SIZE=16384 |
65 | CONFIG_EEPROM_AT24=y | ||
62 | CONFIG_EEPROM_AT25=y | 66 | CONFIG_EEPROM_AT25=y |
63 | CONFIG_SCSI=y | 67 | CONFIG_SCSI=y |
64 | CONFIG_BLK_DEV_SD=y | 68 | CONFIG_BLK_DEV_SD=y |
@@ -79,16 +83,22 @@ CONFIG_LPC_ENET=y | |||
79 | # CONFIG_NET_VENDOR_STMICRO is not set | 83 | # CONFIG_NET_VENDOR_STMICRO is not set |
80 | CONFIG_SMSC_PHY=y | 84 | CONFIG_SMSC_PHY=y |
81 | # CONFIG_WLAN is not set | 85 | # CONFIG_WLAN is not set |
86 | CONFIG_INPUT_MATRIXKMAP=y | ||
82 | # CONFIG_INPUT_MOUSEDEV_PSAUX is not set | 87 | # CONFIG_INPUT_MOUSEDEV_PSAUX is not set |
83 | CONFIG_INPUT_MOUSEDEV_SCREEN_X=240 | 88 | CONFIG_INPUT_MOUSEDEV_SCREEN_X=240 |
84 | CONFIG_INPUT_MOUSEDEV_SCREEN_Y=320 | 89 | CONFIG_INPUT_MOUSEDEV_SCREEN_Y=320 |
85 | CONFIG_INPUT_EVDEV=y | 90 | CONFIG_INPUT_EVDEV=y |
91 | # CONFIG_KEYBOARD_ATKBD is not set | ||
92 | CONFIG_KEYBOARD_LPC32XX=y | ||
86 | # CONFIG_INPUT_MOUSE is not set | 93 | # CONFIG_INPUT_MOUSE is not set |
87 | CONFIG_INPUT_TOUCHSCREEN=y | 94 | CONFIG_INPUT_TOUCHSCREEN=y |
88 | CONFIG_TOUCHSCREEN_LPC32XX=y | 95 | CONFIG_TOUCHSCREEN_LPC32XX=y |
96 | CONFIG_SERIO_LIBPS2=y | ||
89 | # CONFIG_LEGACY_PTYS is not set | 97 | # CONFIG_LEGACY_PTYS is not set |
90 | CONFIG_SERIAL_8250=y | 98 | CONFIG_SERIAL_8250=y |
91 | CONFIG_SERIAL_8250_CONSOLE=y | 99 | CONFIG_SERIAL_8250_CONSOLE=y |
100 | CONFIG_SERIAL_HS_LPC32XX=y | ||
101 | CONFIG_SERIAL_OF_PLATFORM=y | ||
92 | # CONFIG_HW_RANDOM is not set | 102 | # CONFIG_HW_RANDOM is not set |
93 | CONFIG_I2C=y | 103 | CONFIG_I2C=y |
94 | CONFIG_I2C_CHARDEV=y | 104 | CONFIG_I2C_CHARDEV=y |
@@ -96,7 +106,8 @@ CONFIG_I2C_PNX=y | |||
96 | CONFIG_SPI=y | 106 | CONFIG_SPI=y |
97 | CONFIG_SPI_PL022=y | 107 | CONFIG_SPI_PL022=y |
98 | CONFIG_GPIO_SYSFS=y | 108 | CONFIG_GPIO_SYSFS=y |
99 | # CONFIG_HWMON is not set | 109 | CONFIG_SENSORS_DS620=y |
110 | CONFIG_SENSORS_MAX6639=y | ||
100 | CONFIG_WATCHDOG=y | 111 | CONFIG_WATCHDOG=y |
101 | CONFIG_PNX4008_WATCHDOG=y | 112 | CONFIG_PNX4008_WATCHDOG=y |
102 | CONFIG_FB=y | 113 | CONFIG_FB=y |
@@ -133,6 +144,8 @@ CONFIG_MMC=y | |||
133 | CONFIG_MMC_ARMMMCI=y | 144 | CONFIG_MMC_ARMMMCI=y |
134 | CONFIG_NEW_LEDS=y | 145 | CONFIG_NEW_LEDS=y |
135 | CONFIG_LEDS_CLASS=y | 146 | CONFIG_LEDS_CLASS=y |
147 | CONFIG_LEDS_PCA9532=y | ||
148 | CONFIG_LEDS_PCA9532_GPIO=y | ||
136 | CONFIG_LEDS_GPIO=y | 149 | CONFIG_LEDS_GPIO=y |
137 | CONFIG_LEDS_TRIGGERS=y | 150 | CONFIG_LEDS_TRIGGERS=y |
138 | CONFIG_LEDS_TRIGGER_TIMER=y | 151 | CONFIG_LEDS_TRIGGER_TIMER=y |
@@ -146,10 +159,10 @@ CONFIG_RTC_DRV_DS1374=y | |||
146 | CONFIG_RTC_DRV_PCF8563=y | 159 | CONFIG_RTC_DRV_PCF8563=y |
147 | CONFIG_RTC_DRV_LPC32XX=y | 160 | CONFIG_RTC_DRV_LPC32XX=y |
148 | CONFIG_DMADEVICES=y | 161 | CONFIG_DMADEVICES=y |
149 | CONFIG_AMBA_PL08X=y | ||
150 | CONFIG_STAGING=y | 162 | CONFIG_STAGING=y |
151 | CONFIG_IIO=y | ||
152 | CONFIG_LPC32XX_ADC=y | 163 | CONFIG_LPC32XX_ADC=y |
164 | CONFIG_MAX517=y | ||
165 | CONFIG_IIO=y | ||
153 | CONFIG_EXT2_FS=y | 166 | CONFIG_EXT2_FS=y |
154 | CONFIG_AUTOFS4_FS=y | 167 | CONFIG_AUTOFS4_FS=y |
155 | CONFIG_MSDOS_FS=y | 168 | CONFIG_MSDOS_FS=y |
@@ -159,7 +172,6 @@ CONFIG_JFFS2_FS=y | |||
159 | CONFIG_JFFS2_FS_WBUF_VERIFY=y | 172 | CONFIG_JFFS2_FS_WBUF_VERIFY=y |
160 | CONFIG_CRAMFS=y | 173 | CONFIG_CRAMFS=y |
161 | CONFIG_NFS_FS=y | 174 | CONFIG_NFS_FS=y |
162 | CONFIG_NFS_V3=y | ||
163 | CONFIG_ROOT_NFS=y | 175 | CONFIG_ROOT_NFS=y |
164 | CONFIG_NLS_CODEPAGE_437=y | 176 | CONFIG_NLS_CODEPAGE_437=y |
165 | CONFIG_NLS_ASCII=y | 177 | CONFIG_NLS_ASCII=y |
diff --git a/arch/arm/mach-davinci/Kconfig b/arch/arm/mach-davinci/Kconfig index 32d837d8eab9..2ce1ef07c13d 100644 --- a/arch/arm/mach-davinci/Kconfig +++ b/arch/arm/mach-davinci/Kconfig | |||
@@ -4,6 +4,7 @@ config AINTC | |||
4 | bool | 4 | bool |
5 | 5 | ||
6 | config CP_INTC | 6 | config CP_INTC |
7 | select IRQ_DOMAIN | ||
7 | bool | 8 | bool |
8 | 9 | ||
9 | config ARCH_DAVINCI_DMx | 10 | config ARCH_DAVINCI_DMx |
diff --git a/arch/arm/mach-davinci/Makefile b/arch/arm/mach-davinci/Makefile index 2db78bd5c835..2227effcb0e9 100644 --- a/arch/arm/mach-davinci/Makefile +++ b/arch/arm/mach-davinci/Makefile | |||
@@ -39,3 +39,4 @@ obj-$(CONFIG_MACH_OMAPL138_HAWKBOARD) += board-omapl138-hawk.o | |||
39 | obj-$(CONFIG_CPU_FREQ) += cpufreq.o | 39 | obj-$(CONFIG_CPU_FREQ) += cpufreq.o |
40 | obj-$(CONFIG_CPU_IDLE) += cpuidle.o | 40 | obj-$(CONFIG_CPU_IDLE) += cpuidle.o |
41 | obj-$(CONFIG_SUSPEND) += pm.o sleep.o | 41 | obj-$(CONFIG_SUSPEND) += pm.o sleep.o |
42 | obj-$(CONFIG_HAVE_CLK) += pm_domain.o | ||
diff --git a/arch/arm/mach-davinci/cp_intc.c b/arch/arm/mach-davinci/cp_intc.c index f83152d643c5..45d52567ced7 100644 --- a/arch/arm/mach-davinci/cp_intc.c +++ b/arch/arm/mach-davinci/cp_intc.c | |||
@@ -9,8 +9,10 @@ | |||
9 | * kind, whether express or implied. | 9 | * kind, whether express or implied. |
10 | */ | 10 | */ |
11 | 11 | ||
12 | #include <linux/export.h> | ||
12 | #include <linux/init.h> | 13 | #include <linux/init.h> |
13 | #include <linux/irq.h> | 14 | #include <linux/irq.h> |
15 | #include <linux/irqdomain.h> | ||
14 | #include <linux/io.h> | 16 | #include <linux/io.h> |
15 | 17 | ||
16 | #include <mach/common.h> | 18 | #include <mach/common.h> |
@@ -28,7 +30,7 @@ static inline void cp_intc_write(unsigned long value, unsigned offset) | |||
28 | 30 | ||
29 | static void cp_intc_ack_irq(struct irq_data *d) | 31 | static void cp_intc_ack_irq(struct irq_data *d) |
30 | { | 32 | { |
31 | cp_intc_write(d->irq, CP_INTC_SYS_STAT_IDX_CLR); | 33 | cp_intc_write(d->hwirq, CP_INTC_SYS_STAT_IDX_CLR); |
32 | } | 34 | } |
33 | 35 | ||
34 | /* Disable interrupt */ | 36 | /* Disable interrupt */ |
@@ -36,20 +38,20 @@ static void cp_intc_mask_irq(struct irq_data *d) | |||
36 | { | 38 | { |
37 | /* XXX don't know why we need to disable nIRQ here... */ | 39 | /* XXX don't know why we need to disable nIRQ here... */ |
38 | cp_intc_write(1, CP_INTC_HOST_ENABLE_IDX_CLR); | 40 | cp_intc_write(1, CP_INTC_HOST_ENABLE_IDX_CLR); |
39 | cp_intc_write(d->irq, CP_INTC_SYS_ENABLE_IDX_CLR); | 41 | cp_intc_write(d->hwirq, CP_INTC_SYS_ENABLE_IDX_CLR); |
40 | cp_intc_write(1, CP_INTC_HOST_ENABLE_IDX_SET); | 42 | cp_intc_write(1, CP_INTC_HOST_ENABLE_IDX_SET); |
41 | } | 43 | } |
42 | 44 | ||
43 | /* Enable interrupt */ | 45 | /* Enable interrupt */ |
44 | static void cp_intc_unmask_irq(struct irq_data *d) | 46 | static void cp_intc_unmask_irq(struct irq_data *d) |
45 | { | 47 | { |
46 | cp_intc_write(d->irq, CP_INTC_SYS_ENABLE_IDX_SET); | 48 | cp_intc_write(d->hwirq, CP_INTC_SYS_ENABLE_IDX_SET); |
47 | } | 49 | } |
48 | 50 | ||
49 | static int cp_intc_set_irq_type(struct irq_data *d, unsigned int flow_type) | 51 | static int cp_intc_set_irq_type(struct irq_data *d, unsigned int flow_type) |
50 | { | 52 | { |
51 | unsigned reg = BIT_WORD(d->irq); | 53 | unsigned reg = BIT_WORD(d->hwirq); |
52 | unsigned mask = BIT_MASK(d->irq); | 54 | unsigned mask = BIT_MASK(d->hwirq); |
53 | unsigned polarity = cp_intc_read(CP_INTC_SYS_POLARITY(reg)); | 55 | unsigned polarity = cp_intc_read(CP_INTC_SYS_POLARITY(reg)); |
54 | unsigned type = cp_intc_read(CP_INTC_SYS_TYPE(reg)); | 56 | unsigned type = cp_intc_read(CP_INTC_SYS_TYPE(reg)); |
55 | 57 | ||
@@ -99,18 +101,36 @@ static struct irq_chip cp_intc_irq_chip = { | |||
99 | .irq_set_wake = cp_intc_set_wake, | 101 | .irq_set_wake = cp_intc_set_wake, |
100 | }; | 102 | }; |
101 | 103 | ||
102 | void __init cp_intc_init(void) | 104 | static struct irq_domain *cp_intc_domain; |
105 | |||
106 | static int cp_intc_host_map(struct irq_domain *h, unsigned int virq, | ||
107 | irq_hw_number_t hw) | ||
108 | { | ||
109 | pr_debug("cp_intc_host_map(%d, 0x%lx)\n", virq, hw); | ||
110 | |||
111 | irq_set_chip(virq, &cp_intc_irq_chip); | ||
112 | set_irq_flags(virq, IRQF_VALID | IRQF_PROBE); | ||
113 | irq_set_handler(virq, handle_edge_irq); | ||
114 | return 0; | ||
115 | } | ||
116 | |||
117 | static const struct irq_domain_ops cp_intc_host_ops = { | ||
118 | .map = cp_intc_host_map, | ||
119 | .xlate = irq_domain_xlate_onetwocell, | ||
120 | }; | ||
121 | |||
122 | int __init __cp_intc_init(struct device_node *node) | ||
103 | { | 123 | { |
104 | unsigned long num_irq = davinci_soc_info.intc_irq_num; | 124 | u32 num_irq = davinci_soc_info.intc_irq_num; |
105 | u8 *irq_prio = davinci_soc_info.intc_irq_prios; | 125 | u8 *irq_prio = davinci_soc_info.intc_irq_prios; |
106 | u32 *host_map = davinci_soc_info.intc_host_map; | 126 | u32 *host_map = davinci_soc_info.intc_host_map; |
107 | unsigned num_reg = BITS_TO_LONGS(num_irq); | 127 | unsigned num_reg = BITS_TO_LONGS(num_irq); |
108 | int i; | 128 | int i, irq_base; |
109 | 129 | ||
110 | davinci_intc_type = DAVINCI_INTC_TYPE_CP_INTC; | 130 | davinci_intc_type = DAVINCI_INTC_TYPE_CP_INTC; |
111 | davinci_intc_base = ioremap(davinci_soc_info.intc_base, SZ_8K); | 131 | davinci_intc_base = ioremap(davinci_soc_info.intc_base, SZ_8K); |
112 | if (WARN_ON(!davinci_intc_base)) | 132 | if (WARN_ON(!davinci_intc_base)) |
113 | return; | 133 | return -EINVAL; |
114 | 134 | ||
115 | cp_intc_write(0, CP_INTC_GLOBAL_ENABLE); | 135 | cp_intc_write(0, CP_INTC_GLOBAL_ENABLE); |
116 | 136 | ||
@@ -165,13 +185,28 @@ void __init cp_intc_init(void) | |||
165 | for (i = 0; host_map[i] != -1; i++) | 185 | for (i = 0; host_map[i] != -1; i++) |
166 | cp_intc_write(host_map[i], CP_INTC_HOST_MAP(i)); | 186 | cp_intc_write(host_map[i], CP_INTC_HOST_MAP(i)); |
167 | 187 | ||
168 | /* Set up genirq dispatching for cp_intc */ | 188 | irq_base = irq_alloc_descs(-1, 0, num_irq, 0); |
169 | for (i = 0; i < num_irq; i++) { | 189 | if (irq_base < 0) { |
170 | irq_set_chip(i, &cp_intc_irq_chip); | 190 | pr_warn("Couldn't allocate IRQ numbers\n"); |
171 | set_irq_flags(i, IRQF_VALID | IRQF_PROBE); | 191 | irq_base = 0; |
172 | irq_set_handler(i, handle_edge_irq); | 192 | } |
193 | |||
194 | /* create a legacy host */ | ||
195 | cp_intc_domain = irq_domain_add_legacy(node, num_irq, | ||
196 | irq_base, 0, &cp_intc_host_ops, NULL); | ||
197 | |||
198 | if (!cp_intc_domain) { | ||
199 | pr_err("cp_intc: failed to allocate irq host!\n"); | ||
200 | return -EINVAL; | ||
173 | } | 201 | } |
174 | 202 | ||
175 | /* Enable global interrupt */ | 203 | /* Enable global interrupt */ |
176 | cp_intc_write(1, CP_INTC_GLOBAL_ENABLE); | 204 | cp_intc_write(1, CP_INTC_GLOBAL_ENABLE); |
205 | |||
206 | return 0; | ||
207 | } | ||
208 | |||
209 | void __init cp_intc_init(void) | ||
210 | { | ||
211 | __cp_intc_init(NULL); | ||
177 | } | 212 | } |
diff --git a/arch/arm/mach-davinci/pm_domain.c b/arch/arm/mach-davinci/pm_domain.c new file mode 100644 index 000000000000..00946e23c1ee --- /dev/null +++ b/arch/arm/mach-davinci/pm_domain.c | |||
@@ -0,0 +1,64 @@ | |||
1 | /* | ||
2 | * Runtime PM support code for DaVinci | ||
3 | * | ||
4 | * Author: Kevin Hilman | ||
5 | * | ||
6 | * Copyright (C) 2012 Texas Instruments, Inc. | ||
7 | * | ||
8 | * This file is licensed under the terms of the GNU General Public | ||
9 | * License version 2. This program is licensed "as is" without any | ||
10 | * warranty of any kind, whether express or implied. | ||
11 | */ | ||
12 | #include <linux/init.h> | ||
13 | #include <linux/pm_runtime.h> | ||
14 | #include <linux/pm_clock.h> | ||
15 | #include <linux/platform_device.h> | ||
16 | |||
17 | #ifdef CONFIG_PM_RUNTIME | ||
18 | static int davinci_pm_runtime_suspend(struct device *dev) | ||
19 | { | ||
20 | int ret; | ||
21 | |||
22 | dev_dbg(dev, "%s\n", __func__); | ||
23 | |||
24 | ret = pm_generic_runtime_suspend(dev); | ||
25 | if (ret) | ||
26 | return ret; | ||
27 | |||
28 | ret = pm_clk_suspend(dev); | ||
29 | if (ret) { | ||
30 | pm_generic_runtime_resume(dev); | ||
31 | return ret; | ||
32 | } | ||
33 | |||
34 | return 0; | ||
35 | } | ||
36 | |||
37 | static int davinci_pm_runtime_resume(struct device *dev) | ||
38 | { | ||
39 | dev_dbg(dev, "%s\n", __func__); | ||
40 | |||
41 | pm_clk_resume(dev); | ||
42 | return pm_generic_runtime_resume(dev); | ||
43 | } | ||
44 | #endif | ||
45 | |||
46 | static struct dev_pm_domain davinci_pm_domain = { | ||
47 | .ops = { | ||
48 | SET_RUNTIME_PM_OPS(davinci_pm_runtime_suspend, | ||
49 | davinci_pm_runtime_resume, NULL) | ||
50 | USE_PLATFORM_PM_SLEEP_OPS | ||
51 | }, | ||
52 | }; | ||
53 | |||
54 | static struct pm_clk_notifier_block platform_bus_notifier = { | ||
55 | .pm_domain = &davinci_pm_domain, | ||
56 | }; | ||
57 | |||
58 | static int __init davinci_pm_runtime_init(void) | ||
59 | { | ||
60 | pm_clk_add_notifier(&platform_bus_type, &platform_bus_notifier); | ||
61 | |||
62 | return 0; | ||
63 | } | ||
64 | core_initcall(davinci_pm_runtime_init); | ||
diff --git a/arch/arm/mach-ep93xx/core.c b/arch/arm/mach-ep93xx/core.c index 4dd07a0e3604..4afe52aaaff3 100644 --- a/arch/arm/mach-ep93xx/core.c +++ b/arch/arm/mach-ep93xx/core.c | |||
@@ -797,6 +797,102 @@ static struct platform_device ep93xx_wdt_device = { | |||
797 | .resource = ep93xx_wdt_resources, | 797 | .resource = ep93xx_wdt_resources, |
798 | }; | 798 | }; |
799 | 799 | ||
800 | /************************************************************************* | ||
801 | * EP93xx IDE | ||
802 | *************************************************************************/ | ||
803 | static struct resource ep93xx_ide_resources[] = { | ||
804 | DEFINE_RES_MEM(EP93XX_IDE_PHYS_BASE, 0x38), | ||
805 | DEFINE_RES_IRQ(IRQ_EP93XX_EXT3), | ||
806 | }; | ||
807 | |||
808 | static struct platform_device ep93xx_ide_device = { | ||
809 | .name = "ep93xx-ide", | ||
810 | .id = -1, | ||
811 | .dev = { | ||
812 | .dma_mask = &ep93xx_ide_device.dev.coherent_dma_mask, | ||
813 | .coherent_dma_mask = DMA_BIT_MASK(32), | ||
814 | }, | ||
815 | .num_resources = ARRAY_SIZE(ep93xx_ide_resources), | ||
816 | .resource = ep93xx_ide_resources, | ||
817 | }; | ||
818 | |||
819 | void __init ep93xx_register_ide(void) | ||
820 | { | ||
821 | platform_device_register(&ep93xx_ide_device); | ||
822 | } | ||
823 | |||
824 | int ep93xx_ide_acquire_gpio(struct platform_device *pdev) | ||
825 | { | ||
826 | int err; | ||
827 | int i; | ||
828 | |||
829 | err = gpio_request(EP93XX_GPIO_LINE_EGPIO2, dev_name(&pdev->dev)); | ||
830 | if (err) | ||
831 | return err; | ||
832 | err = gpio_request(EP93XX_GPIO_LINE_EGPIO15, dev_name(&pdev->dev)); | ||
833 | if (err) | ||
834 | goto fail_egpio15; | ||
835 | for (i = 2; i < 8; i++) { | ||
836 | err = gpio_request(EP93XX_GPIO_LINE_E(i), dev_name(&pdev->dev)); | ||
837 | if (err) | ||
838 | goto fail_gpio_e; | ||
839 | } | ||
840 | for (i = 4; i < 8; i++) { | ||
841 | err = gpio_request(EP93XX_GPIO_LINE_G(i), dev_name(&pdev->dev)); | ||
842 | if (err) | ||
843 | goto fail_gpio_g; | ||
844 | } | ||
845 | for (i = 0; i < 8; i++) { | ||
846 | err = gpio_request(EP93XX_GPIO_LINE_H(i), dev_name(&pdev->dev)); | ||
847 | if (err) | ||
848 | goto fail_gpio_h; | ||
849 | } | ||
850 | |||
851 | /* GPIO ports E[7:2], G[7:4] and H used by IDE */ | ||
852 | ep93xx_devcfg_clear_bits(EP93XX_SYSCON_DEVCFG_EONIDE | | ||
853 | EP93XX_SYSCON_DEVCFG_GONIDE | | ||
854 | EP93XX_SYSCON_DEVCFG_HONIDE); | ||
855 | return 0; | ||
856 | |||
857 | fail_gpio_h: | ||
858 | for (--i; i >= 0; --i) | ||
859 | gpio_free(EP93XX_GPIO_LINE_H(i)); | ||
860 | i = 8; | ||
861 | fail_gpio_g: | ||
862 | for (--i; i >= 4; --i) | ||
863 | gpio_free(EP93XX_GPIO_LINE_G(i)); | ||
864 | i = 8; | ||
865 | fail_gpio_e: | ||
866 | for (--i; i >= 2; --i) | ||
867 | gpio_free(EP93XX_GPIO_LINE_E(i)); | ||
868 | gpio_free(EP93XX_GPIO_LINE_EGPIO15); | ||
869 | fail_egpio15: | ||
870 | gpio_free(EP93XX_GPIO_LINE_EGPIO2); | ||
871 | return err; | ||
872 | } | ||
873 | EXPORT_SYMBOL(ep93xx_ide_acquire_gpio); | ||
874 | |||
875 | void ep93xx_ide_release_gpio(struct platform_device *pdev) | ||
876 | { | ||
877 | int i; | ||
878 | |||
879 | for (i = 2; i < 8; i++) | ||
880 | gpio_free(EP93XX_GPIO_LINE_E(i)); | ||
881 | for (i = 4; i < 8; i++) | ||
882 | gpio_free(EP93XX_GPIO_LINE_G(i)); | ||
883 | for (i = 0; i < 8; i++) | ||
884 | gpio_free(EP93XX_GPIO_LINE_H(i)); | ||
885 | gpio_free(EP93XX_GPIO_LINE_EGPIO15); | ||
886 | gpio_free(EP93XX_GPIO_LINE_EGPIO2); | ||
887 | |||
888 | |||
889 | /* GPIO ports E[7:2], G[7:4] and H used by GPIO */ | ||
890 | ep93xx_devcfg_set_bits(EP93XX_SYSCON_DEVCFG_EONIDE | | ||
891 | EP93XX_SYSCON_DEVCFG_GONIDE | | ||
892 | EP93XX_SYSCON_DEVCFG_HONIDE); | ||
893 | } | ||
894 | EXPORT_SYMBOL(ep93xx_ide_release_gpio); | ||
895 | |||
800 | void __init ep93xx_init_devices(void) | 896 | void __init ep93xx_init_devices(void) |
801 | { | 897 | { |
802 | /* Disallow access to MaverickCrunch initially */ | 898 | /* Disallow access to MaverickCrunch initially */ |
diff --git a/arch/arm/mach-ep93xx/edb93xx.c b/arch/arm/mach-ep93xx/edb93xx.c index 3bb8e56969a5..337ab7cf4c16 100644 --- a/arch/arm/mach-ep93xx/edb93xx.c +++ b/arch/arm/mach-ep93xx/edb93xx.c | |||
@@ -233,6 +233,29 @@ static void __init edb93xx_register_fb(void) | |||
233 | } | 233 | } |
234 | 234 | ||
235 | 235 | ||
236 | /************************************************************************* | ||
237 | * EDB93xx IDE | ||
238 | *************************************************************************/ | ||
239 | static int __init edb93xx_has_ide(void) | ||
240 | { | ||
241 | /* | ||
242 | * Although EDB9312 and EDB9315 do have IDE capability, they have | ||
243 | * INTRQ line wired as pull-up, which makes using IDE interface | ||
244 | * problematic. | ||
245 | */ | ||
246 | return machine_is_edb9312() || machine_is_edb9315() || | ||
247 | machine_is_edb9315a(); | ||
248 | } | ||
249 | |||
250 | static void __init edb93xx_register_ide(void) | ||
251 | { | ||
252 | if (!edb93xx_has_ide()) | ||
253 | return; | ||
254 | |||
255 | ep93xx_register_ide(); | ||
256 | } | ||
257 | |||
258 | |||
236 | static void __init edb93xx_init_machine(void) | 259 | static void __init edb93xx_init_machine(void) |
237 | { | 260 | { |
238 | ep93xx_init_devices(); | 261 | ep93xx_init_devices(); |
@@ -243,6 +266,7 @@ static void __init edb93xx_init_machine(void) | |||
243 | edb93xx_register_i2s(); | 266 | edb93xx_register_i2s(); |
244 | edb93xx_register_pwm(); | 267 | edb93xx_register_pwm(); |
245 | edb93xx_register_fb(); | 268 | edb93xx_register_fb(); |
269 | edb93xx_register_ide(); | ||
246 | } | 270 | } |
247 | 271 | ||
248 | 272 | ||
diff --git a/arch/arm/mach-ep93xx/include/mach/platform.h b/arch/arm/mach-ep93xx/include/mach/platform.h index 1ecb040d98bf..33a5122c6dc8 100644 --- a/arch/arm/mach-ep93xx/include/mach/platform.h +++ b/arch/arm/mach-ep93xx/include/mach/platform.h | |||
@@ -48,6 +48,9 @@ void ep93xx_register_i2s(void); | |||
48 | int ep93xx_i2s_acquire(void); | 48 | int ep93xx_i2s_acquire(void); |
49 | void ep93xx_i2s_release(void); | 49 | void ep93xx_i2s_release(void); |
50 | void ep93xx_register_ac97(void); | 50 | void ep93xx_register_ac97(void); |
51 | void ep93xx_register_ide(void); | ||
52 | int ep93xx_ide_acquire_gpio(struct platform_device *pdev); | ||
53 | void ep93xx_ide_release_gpio(struct platform_device *pdev); | ||
51 | 54 | ||
52 | void ep93xx_init_devices(void); | 55 | void ep93xx_init_devices(void); |
53 | extern struct sys_timer ep93xx_timer; | 56 | extern struct sys_timer ep93xx_timer; |
diff --git a/arch/arm/mach-ep93xx/soc.h b/arch/arm/mach-ep93xx/soc.h index 979fba722926..7bf7ff8beae7 100644 --- a/arch/arm/mach-ep93xx/soc.h +++ b/arch/arm/mach-ep93xx/soc.h | |||
@@ -69,6 +69,7 @@ | |||
69 | 69 | ||
70 | #define EP93XX_BOOT_ROM_BASE EP93XX_AHB_IOMEM(0x00090000) | 70 | #define EP93XX_BOOT_ROM_BASE EP93XX_AHB_IOMEM(0x00090000) |
71 | 71 | ||
72 | #define EP93XX_IDE_PHYS_BASE EP93XX_AHB_PHYS(0x000a0000) | ||
72 | #define EP93XX_IDE_BASE EP93XX_AHB_IOMEM(0x000a0000) | 73 | #define EP93XX_IDE_BASE EP93XX_AHB_IOMEM(0x000a0000) |
73 | 74 | ||
74 | #define EP93XX_VIC1_BASE EP93XX_AHB_IOMEM(0x000b0000) | 75 | #define EP93XX_VIC1_BASE EP93XX_AHB_IOMEM(0x000b0000) |
diff --git a/arch/arm/mach-exynos/common.c b/arch/arm/mach-exynos/common.c index 0ec1a91388c7..4eb39cdf75ea 100644 --- a/arch/arm/mach-exynos/common.c +++ b/arch/arm/mach-exynos/common.c | |||
@@ -540,7 +540,8 @@ static struct irq_domain_ops combiner_irq_domain_ops = { | |||
540 | .map = combiner_irq_domain_map, | 540 | .map = combiner_irq_domain_map, |
541 | }; | 541 | }; |
542 | 542 | ||
543 | void __init combiner_init(void __iomem *combiner_base, struct device_node *np) | 543 | static void __init combiner_init(void __iomem *combiner_base, |
544 | struct device_node *np) | ||
544 | { | 545 | { |
545 | int i, irq, irq_base; | 546 | int i, irq, irq_base; |
546 | unsigned int max_nr, nr_irq; | 547 | unsigned int max_nr, nr_irq; |
diff --git a/arch/arm/mach-exynos/include/mach/regs-pmu.h b/arch/arm/mach-exynos/include/mach/regs-pmu.h index 43a99e6f56ab..d4e392b811a3 100644 --- a/arch/arm/mach-exynos/include/mach/regs-pmu.h +++ b/arch/arm/mach-exynos/include/mach/regs-pmu.h | |||
@@ -232,6 +232,11 @@ | |||
232 | 232 | ||
233 | #define EXYNOS5_USB_CFG S5P_PMUREG(0x0230) | 233 | #define EXYNOS5_USB_CFG S5P_PMUREG(0x0230) |
234 | 234 | ||
235 | #define EXYNOS5_AUTO_WDTRESET_DISABLE S5P_PMUREG(0x0408) | ||
236 | #define EXYNOS5_MASK_WDTRESET_REQUEST S5P_PMUREG(0x040C) | ||
237 | |||
238 | #define EXYNOS5_SYS_WDTRESET (1 << 20) | ||
239 | |||
235 | #define EXYNOS5_ARM_CORE0_SYS_PWR_REG S5P_PMUREG(0x1000) | 240 | #define EXYNOS5_ARM_CORE0_SYS_PWR_REG S5P_PMUREG(0x1000) |
236 | #define EXYNOS5_DIS_IRQ_ARM_CORE0_LOCAL_SYS_PWR_REG S5P_PMUREG(0x1004) | 241 | #define EXYNOS5_DIS_IRQ_ARM_CORE0_LOCAL_SYS_PWR_REG S5P_PMUREG(0x1004) |
237 | #define EXYNOS5_DIS_IRQ_ARM_CORE0_CENTRAL_SYS_PWR_REG S5P_PMUREG(0x1008) | 242 | #define EXYNOS5_DIS_IRQ_ARM_CORE0_CENTRAL_SYS_PWR_REG S5P_PMUREG(0x1008) |
diff --git a/arch/arm/mach-exynos/include/mach/regs-usb-phy.h b/arch/arm/mach-exynos/include/mach/regs-usb-phy.h index c337cf3a71bf..07277735252e 100644 --- a/arch/arm/mach-exynos/include/mach/regs-usb-phy.h +++ b/arch/arm/mach-exynos/include/mach/regs-usb-phy.h | |||
@@ -35,11 +35,21 @@ | |||
35 | #define PHY1_COMMON_ON_N (1 << 7) | 35 | #define PHY1_COMMON_ON_N (1 << 7) |
36 | #define PHY0_COMMON_ON_N (1 << 4) | 36 | #define PHY0_COMMON_ON_N (1 << 4) |
37 | #define PHY0_ID_PULLUP (1 << 2) | 37 | #define PHY0_ID_PULLUP (1 << 2) |
38 | #define CLKSEL_MASK (0x3 << 0) | 38 | |
39 | #define CLKSEL_SHIFT (0) | 39 | #define EXYNOS4_CLKSEL_SHIFT (0) |
40 | #define CLKSEL_48M (0x0 << 0) | 40 | |
41 | #define CLKSEL_12M (0x2 << 0) | 41 | #define EXYNOS4210_CLKSEL_MASK (0x3 << 0) |
42 | #define CLKSEL_24M (0x3 << 0) | 42 | #define EXYNOS4210_CLKSEL_48M (0x0 << 0) |
43 | #define EXYNOS4210_CLKSEL_12M (0x2 << 0) | ||
44 | #define EXYNOS4210_CLKSEL_24M (0x3 << 0) | ||
45 | |||
46 | #define EXYNOS4X12_CLKSEL_MASK (0x7 << 0) | ||
47 | #define EXYNOS4X12_CLKSEL_9600K (0x0 << 0) | ||
48 | #define EXYNOS4X12_CLKSEL_10M (0x1 << 0) | ||
49 | #define EXYNOS4X12_CLKSEL_12M (0x2 << 0) | ||
50 | #define EXYNOS4X12_CLKSEL_19200K (0x3 << 0) | ||
51 | #define EXYNOS4X12_CLKSEL_20M (0x4 << 0) | ||
52 | #define EXYNOS4X12_CLKSEL_24M (0x5 << 0) | ||
43 | 53 | ||
44 | #define EXYNOS4_RSTCON EXYNOS4_HSOTG_PHYREG(0x08) | 54 | #define EXYNOS4_RSTCON EXYNOS4_HSOTG_PHYREG(0x08) |
45 | #define HOST_LINK_PORT_SWRST_MASK (0xf << 6) | 55 | #define HOST_LINK_PORT_SWRST_MASK (0xf << 6) |
diff --git a/arch/arm/mach-exynos/pmu.c b/arch/arm/mach-exynos/pmu.c index 4aacb66f7161..3a48c852be6c 100644 --- a/arch/arm/mach-exynos/pmu.c +++ b/arch/arm/mach-exynos/pmu.c | |||
@@ -315,7 +315,7 @@ static struct exynos_pmu_conf exynos5250_pmu_config[] = { | |||
315 | { PMU_TABLE_END,}, | 315 | { PMU_TABLE_END,}, |
316 | }; | 316 | }; |
317 | 317 | ||
318 | void __iomem *exynos5_list_both_cnt_feed[] = { | 318 | static void __iomem *exynos5_list_both_cnt_feed[] = { |
319 | EXYNOS5_ARM_CORE0_OPTION, | 319 | EXYNOS5_ARM_CORE0_OPTION, |
320 | EXYNOS5_ARM_CORE1_OPTION, | 320 | EXYNOS5_ARM_CORE1_OPTION, |
321 | EXYNOS5_ARM_COMMON_OPTION, | 321 | EXYNOS5_ARM_COMMON_OPTION, |
@@ -329,7 +329,7 @@ void __iomem *exynos5_list_both_cnt_feed[] = { | |||
329 | EXYNOS5_TOP_PWR_SYSMEM_OPTION, | 329 | EXYNOS5_TOP_PWR_SYSMEM_OPTION, |
330 | }; | 330 | }; |
331 | 331 | ||
332 | void __iomem *exynos5_list_diable_wfi_wfe[] = { | 332 | static void __iomem *exynos5_list_diable_wfi_wfe[] = { |
333 | EXYNOS5_ARM_CORE1_OPTION, | 333 | EXYNOS5_ARM_CORE1_OPTION, |
334 | EXYNOS5_FSYS_ARM_OPTION, | 334 | EXYNOS5_FSYS_ARM_OPTION, |
335 | EXYNOS5_ISP_ARM_OPTION, | 335 | EXYNOS5_ISP_ARM_OPTION, |
@@ -390,6 +390,8 @@ void exynos_sys_powerdown_conf(enum sys_powerdown mode) | |||
390 | 390 | ||
391 | static int __init exynos_pmu_init(void) | 391 | static int __init exynos_pmu_init(void) |
392 | { | 392 | { |
393 | unsigned int value; | ||
394 | |||
393 | exynos_pmu_config = exynos4210_pmu_config; | 395 | exynos_pmu_config = exynos4210_pmu_config; |
394 | 396 | ||
395 | if (soc_is_exynos4210()) { | 397 | if (soc_is_exynos4210()) { |
@@ -399,6 +401,18 @@ static int __init exynos_pmu_init(void) | |||
399 | exynos_pmu_config = exynos4x12_pmu_config; | 401 | exynos_pmu_config = exynos4x12_pmu_config; |
400 | pr_info("EXYNOS4x12 PMU Initialize\n"); | 402 | pr_info("EXYNOS4x12 PMU Initialize\n"); |
401 | } else if (soc_is_exynos5250()) { | 403 | } else if (soc_is_exynos5250()) { |
404 | /* | ||
405 | * When SYS_WDTRESET is set, watchdog timer reset request | ||
406 | * is ignored by power management unit. | ||
407 | */ | ||
408 | value = __raw_readl(EXYNOS5_AUTO_WDTRESET_DISABLE); | ||
409 | value &= ~EXYNOS5_SYS_WDTRESET; | ||
410 | __raw_writel(value, EXYNOS5_AUTO_WDTRESET_DISABLE); | ||
411 | |||
412 | value = __raw_readl(EXYNOS5_MASK_WDTRESET_REQUEST); | ||
413 | value &= ~EXYNOS5_SYS_WDTRESET; | ||
414 | __raw_writel(value, EXYNOS5_MASK_WDTRESET_REQUEST); | ||
415 | |||
402 | exynos_pmu_config = exynos5250_pmu_config; | 416 | exynos_pmu_config = exynos5250_pmu_config; |
403 | pr_info("EXYNOS5250 PMU Initialize\n"); | 417 | pr_info("EXYNOS5250 PMU Initialize\n"); |
404 | } else { | 418 | } else { |
diff --git a/arch/arm/mach-exynos/setup-usb-phy.c b/arch/arm/mach-exynos/setup-usb-phy.c index 1af0a7f44e00..b81cc569a8dd 100644 --- a/arch/arm/mach-exynos/setup-usb-phy.c +++ b/arch/arm/mach-exynos/setup-usb-phy.c | |||
@@ -31,27 +31,55 @@ static void exynos4210_usb_phy_clkset(struct platform_device *pdev) | |||
31 | struct clk *xusbxti_clk; | 31 | struct clk *xusbxti_clk; |
32 | u32 phyclk; | 32 | u32 phyclk; |
33 | 33 | ||
34 | /* set clock frequency for PLL */ | ||
35 | phyclk = readl(EXYNOS4_PHYCLK) & ~CLKSEL_MASK; | ||
36 | |||
37 | xusbxti_clk = clk_get(&pdev->dev, "xusbxti"); | 34 | xusbxti_clk = clk_get(&pdev->dev, "xusbxti"); |
38 | if (xusbxti_clk && !IS_ERR(xusbxti_clk)) { | 35 | if (xusbxti_clk && !IS_ERR(xusbxti_clk)) { |
39 | switch (clk_get_rate(xusbxti_clk)) { | 36 | if (soc_is_exynos4210()) { |
40 | case 12 * MHZ: | 37 | /* set clock frequency for PLL */ |
41 | phyclk |= CLKSEL_12M; | 38 | phyclk = readl(EXYNOS4_PHYCLK) & ~EXYNOS4210_CLKSEL_MASK; |
42 | break; | 39 | |
43 | case 24 * MHZ: | 40 | switch (clk_get_rate(xusbxti_clk)) { |
44 | phyclk |= CLKSEL_24M; | 41 | case 12 * MHZ: |
45 | break; | 42 | phyclk |= EXYNOS4210_CLKSEL_12M; |
46 | default: | 43 | break; |
47 | case 48 * MHZ: | 44 | case 48 * MHZ: |
48 | /* default reference clock */ | 45 | phyclk |= EXYNOS4210_CLKSEL_48M; |
49 | break; | 46 | break; |
47 | default: | ||
48 | case 24 * MHZ: | ||
49 | phyclk |= EXYNOS4210_CLKSEL_24M; | ||
50 | break; | ||
51 | } | ||
52 | writel(phyclk, EXYNOS4_PHYCLK); | ||
53 | } else if (soc_is_exynos4212() || soc_is_exynos4412()) { | ||
54 | /* set clock frequency for PLL */ | ||
55 | phyclk = readl(EXYNOS4_PHYCLK) & ~EXYNOS4X12_CLKSEL_MASK; | ||
56 | |||
57 | switch (clk_get_rate(xusbxti_clk)) { | ||
58 | case 9600 * KHZ: | ||
59 | phyclk |= EXYNOS4X12_CLKSEL_9600K; | ||
60 | break; | ||
61 | case 10 * MHZ: | ||
62 | phyclk |= EXYNOS4X12_CLKSEL_10M; | ||
63 | break; | ||
64 | case 12 * MHZ: | ||
65 | phyclk |= EXYNOS4X12_CLKSEL_12M; | ||
66 | break; | ||
67 | case 19200 * KHZ: | ||
68 | phyclk |= EXYNOS4X12_CLKSEL_19200K; | ||
69 | break; | ||
70 | case 20 * MHZ: | ||
71 | phyclk |= EXYNOS4X12_CLKSEL_20M; | ||
72 | break; | ||
73 | default: | ||
74 | case 24 * MHZ: | ||
75 | /* default reference clock */ | ||
76 | phyclk |= EXYNOS4X12_CLKSEL_24M; | ||
77 | break; | ||
78 | } | ||
79 | writel(phyclk, EXYNOS4_PHYCLK); | ||
50 | } | 80 | } |
51 | clk_put(xusbxti_clk); | 81 | clk_put(xusbxti_clk); |
52 | } | 82 | } |
53 | |||
54 | writel(phyclk, EXYNOS4_PHYCLK); | ||
55 | } | 83 | } |
56 | 84 | ||
57 | static int exynos4210_usb_phy0_init(struct platform_device *pdev) | 85 | static int exynos4210_usb_phy0_init(struct platform_device *pdev) |
diff --git a/arch/arm/mach-imx/Kconfig b/arch/arm/mach-imx/Kconfig index 0da882a3c063..1bba37c6598b 100644 --- a/arch/arm/mach-imx/Kconfig +++ b/arch/arm/mach-imx/Kconfig | |||
@@ -73,7 +73,7 @@ config SOC_IMX31 | |||
73 | 73 | ||
74 | config SOC_IMX35 | 74 | config SOC_IMX35 |
75 | bool | 75 | bool |
76 | select CPU_V6 | 76 | select CPU_V6K |
77 | select ARCH_MXC_IOMUX_V3 | 77 | select ARCH_MXC_IOMUX_V3 |
78 | select COMMON_CLK | 78 | select COMMON_CLK |
79 | select HAVE_EPIT | 79 | select HAVE_EPIT |
@@ -588,6 +588,7 @@ config MACH_MX35_3DS | |||
588 | select IMX_HAVE_PLATFORM_IPU_CORE | 588 | select IMX_HAVE_PLATFORM_IPU_CORE |
589 | select IMX_HAVE_PLATFORM_MXC_EHCI | 589 | select IMX_HAVE_PLATFORM_MXC_EHCI |
590 | select IMX_HAVE_PLATFORM_MXC_NAND | 590 | select IMX_HAVE_PLATFORM_MXC_NAND |
591 | select IMX_HAVE_PLATFORM_MXC_RTC | ||
591 | select IMX_HAVE_PLATFORM_SDHCI_ESDHC_IMX | 592 | select IMX_HAVE_PLATFORM_SDHCI_ESDHC_IMX |
592 | help | 593 | help |
593 | Include support for MX35PDK platform. This includes specific | 594 | Include support for MX35PDK platform. This includes specific |
diff --git a/arch/arm/mach-imx/devices-imx35.h b/arch/arm/mach-imx/devices-imx35.h index 27245ce9cab2..4815be1ee675 100644 --- a/arch/arm/mach-imx/devices-imx35.h +++ b/arch/arm/mach-imx/devices-imx35.h | |||
@@ -68,6 +68,10 @@ extern const struct imx_mxc_nand_data imx35_mxc_nand_data; | |||
68 | #define imx35_add_mxc_nand(pdata) \ | 68 | #define imx35_add_mxc_nand(pdata) \ |
69 | imx_add_mxc_nand(&imx35_mxc_nand_data, pdata) | 69 | imx_add_mxc_nand(&imx35_mxc_nand_data, pdata) |
70 | 70 | ||
71 | extern const struct imx_mxc_rtc_data imx35_mxc_rtc_data; | ||
72 | #define imx35_add_mxc_rtc() \ | ||
73 | imx_add_mxc_rtc(&imx35_mxc_rtc_data) | ||
74 | |||
71 | extern const struct imx_mxc_w1_data imx35_mxc_w1_data; | 75 | extern const struct imx_mxc_w1_data imx35_mxc_w1_data; |
72 | #define imx35_add_mxc_w1() \ | 76 | #define imx35_add_mxc_w1() \ |
73 | imx_add_mxc_w1(&imx35_mxc_w1_data) | 77 | imx_add_mxc_w1(&imx35_mxc_w1_data) |
diff --git a/arch/arm/mach-imx/ehci-imx25.c b/arch/arm/mach-imx/ehci-imx25.c index 865daf0b09e9..05bb41d99728 100644 --- a/arch/arm/mach-imx/ehci-imx25.c +++ b/arch/arm/mach-imx/ehci-imx25.c | |||
@@ -24,14 +24,18 @@ | |||
24 | #define MX25_OTG_SIC_SHIFT 29 | 24 | #define MX25_OTG_SIC_SHIFT 29 |
25 | #define MX25_OTG_SIC_MASK (0x3 << MX25_OTG_SIC_SHIFT) | 25 | #define MX25_OTG_SIC_MASK (0x3 << MX25_OTG_SIC_SHIFT) |
26 | #define MX25_OTG_PM_BIT (1 << 24) | 26 | #define MX25_OTG_PM_BIT (1 << 24) |
27 | #define MX25_OTG_PP_BIT (1 << 11) | ||
28 | #define MX25_OTG_OCPOL_BIT (1 << 3) | ||
27 | 29 | ||
28 | #define MX25_H1_SIC_SHIFT 21 | 30 | #define MX25_H1_SIC_SHIFT 21 |
29 | #define MX25_H1_SIC_MASK (0x3 << MX25_H1_SIC_SHIFT) | 31 | #define MX25_H1_SIC_MASK (0x3 << MX25_H1_SIC_SHIFT) |
32 | #define MX25_H1_PP_BIT (1 << 18) | ||
30 | #define MX25_H1_PM_BIT (1 << 8) | 33 | #define MX25_H1_PM_BIT (1 << 8) |
31 | #define MX25_H1_IPPUE_UP_BIT (1 << 7) | 34 | #define MX25_H1_IPPUE_UP_BIT (1 << 7) |
32 | #define MX25_H1_IPPUE_DOWN_BIT (1 << 6) | 35 | #define MX25_H1_IPPUE_DOWN_BIT (1 << 6) |
33 | #define MX25_H1_TLL_BIT (1 << 5) | 36 | #define MX25_H1_TLL_BIT (1 << 5) |
34 | #define MX25_H1_USBTE_BIT (1 << 4) | 37 | #define MX25_H1_USBTE_BIT (1 << 4) |
38 | #define MX25_H1_OCPOL_BIT (1 << 2) | ||
35 | 39 | ||
36 | int mx25_initialize_usb_hw(int port, unsigned int flags) | 40 | int mx25_initialize_usb_hw(int port, unsigned int flags) |
37 | { | 41 | { |
@@ -41,21 +45,35 @@ int mx25_initialize_usb_hw(int port, unsigned int flags) | |||
41 | 45 | ||
42 | switch (port) { | 46 | switch (port) { |
43 | case 0: /* OTG port */ | 47 | case 0: /* OTG port */ |
44 | v &= ~(MX25_OTG_SIC_MASK | MX25_OTG_PM_BIT); | 48 | v &= ~(MX25_OTG_SIC_MASK | MX25_OTG_PM_BIT | MX25_OTG_PP_BIT | |
49 | MX25_OTG_OCPOL_BIT); | ||
45 | v |= (flags & MXC_EHCI_INTERFACE_MASK) << MX25_OTG_SIC_SHIFT; | 50 | v |= (flags & MXC_EHCI_INTERFACE_MASK) << MX25_OTG_SIC_SHIFT; |
46 | 51 | ||
47 | if (!(flags & MXC_EHCI_POWER_PINS_ENABLED)) | 52 | if (!(flags & MXC_EHCI_POWER_PINS_ENABLED)) |
48 | v |= MX25_OTG_PM_BIT; | 53 | v |= MX25_OTG_PM_BIT; |
49 | 54 | ||
55 | if (flags & MXC_EHCI_PWR_PIN_ACTIVE_HIGH) | ||
56 | v |= MX25_OTG_PP_BIT; | ||
57 | |||
58 | if (!(flags & MXC_EHCI_OC_PIN_ACTIVE_LOW)) | ||
59 | v |= MX25_OTG_OCPOL_BIT; | ||
60 | |||
50 | break; | 61 | break; |
51 | case 1: /* H1 port */ | 62 | case 1: /* H1 port */ |
52 | v &= ~(MX25_H1_SIC_MASK | MX25_H1_PM_BIT | MX25_H1_TLL_BIT | | 63 | v &= ~(MX25_H1_SIC_MASK | MX25_H1_PM_BIT | MX25_H1_PP_BIT | |
53 | MX25_H1_USBTE_BIT | MX25_H1_IPPUE_DOWN_BIT | MX25_H1_IPPUE_UP_BIT); | 64 | MX25_H1_OCPOL_BIT | MX25_H1_TLL_BIT | MX25_H1_USBTE_BIT | |
65 | MX25_H1_IPPUE_DOWN_BIT | MX25_H1_IPPUE_UP_BIT); | ||
54 | v |= (flags & MXC_EHCI_INTERFACE_MASK) << MX25_H1_SIC_SHIFT; | 66 | v |= (flags & MXC_EHCI_INTERFACE_MASK) << MX25_H1_SIC_SHIFT; |
55 | 67 | ||
56 | if (!(flags & MXC_EHCI_POWER_PINS_ENABLED)) | 68 | if (!(flags & MXC_EHCI_POWER_PINS_ENABLED)) |
57 | v |= MX25_H1_PM_BIT; | 69 | v |= MX25_H1_PM_BIT; |
58 | 70 | ||
71 | if (flags & MXC_EHCI_PWR_PIN_ACTIVE_HIGH) | ||
72 | v |= MX25_H1_PP_BIT; | ||
73 | |||
74 | if (!(flags & MXC_EHCI_OC_PIN_ACTIVE_LOW)) | ||
75 | v |= MX25_H1_OCPOL_BIT; | ||
76 | |||
59 | if (!(flags & MXC_EHCI_TTL_ENABLED)) | 77 | if (!(flags & MXC_EHCI_TTL_ENABLED)) |
60 | v |= MX25_H1_TLL_BIT; | 78 | v |= MX25_H1_TLL_BIT; |
61 | 79 | ||
diff --git a/arch/arm/mach-imx/ehci-imx35.c b/arch/arm/mach-imx/ehci-imx35.c index 001ec3971f5d..73574c30cf50 100644 --- a/arch/arm/mach-imx/ehci-imx35.c +++ b/arch/arm/mach-imx/ehci-imx35.c | |||
@@ -24,14 +24,18 @@ | |||
24 | #define MX35_OTG_SIC_SHIFT 29 | 24 | #define MX35_OTG_SIC_SHIFT 29 |
25 | #define MX35_OTG_SIC_MASK (0x3 << MX35_OTG_SIC_SHIFT) | 25 | #define MX35_OTG_SIC_MASK (0x3 << MX35_OTG_SIC_SHIFT) |
26 | #define MX35_OTG_PM_BIT (1 << 24) | 26 | #define MX35_OTG_PM_BIT (1 << 24) |
27 | #define MX35_OTG_PP_BIT (1 << 11) | ||
28 | #define MX35_OTG_OCPOL_BIT (1 << 3) | ||
27 | 29 | ||
28 | #define MX35_H1_SIC_SHIFT 21 | 30 | #define MX35_H1_SIC_SHIFT 21 |
29 | #define MX35_H1_SIC_MASK (0x3 << MX35_H1_SIC_SHIFT) | 31 | #define MX35_H1_SIC_MASK (0x3 << MX35_H1_SIC_SHIFT) |
32 | #define MX35_H1_PP_BIT (1 << 18) | ||
30 | #define MX35_H1_PM_BIT (1 << 8) | 33 | #define MX35_H1_PM_BIT (1 << 8) |
31 | #define MX35_H1_IPPUE_UP_BIT (1 << 7) | 34 | #define MX35_H1_IPPUE_UP_BIT (1 << 7) |
32 | #define MX35_H1_IPPUE_DOWN_BIT (1 << 6) | 35 | #define MX35_H1_IPPUE_DOWN_BIT (1 << 6) |
33 | #define MX35_H1_TLL_BIT (1 << 5) | 36 | #define MX35_H1_TLL_BIT (1 << 5) |
34 | #define MX35_H1_USBTE_BIT (1 << 4) | 37 | #define MX35_H1_USBTE_BIT (1 << 4) |
38 | #define MX35_H1_OCPOL_BIT (1 << 2) | ||
35 | 39 | ||
36 | int mx35_initialize_usb_hw(int port, unsigned int flags) | 40 | int mx35_initialize_usb_hw(int port, unsigned int flags) |
37 | { | 41 | { |
@@ -41,21 +45,35 @@ int mx35_initialize_usb_hw(int port, unsigned int flags) | |||
41 | 45 | ||
42 | switch (port) { | 46 | switch (port) { |
43 | case 0: /* OTG port */ | 47 | case 0: /* OTG port */ |
44 | v &= ~(MX35_OTG_SIC_MASK | MX35_OTG_PM_BIT); | 48 | v &= ~(MX35_OTG_SIC_MASK | MX35_OTG_PM_BIT | MX35_OTG_PP_BIT | |
49 | MX35_OTG_OCPOL_BIT); | ||
45 | v |= (flags & MXC_EHCI_INTERFACE_MASK) << MX35_OTG_SIC_SHIFT; | 50 | v |= (flags & MXC_EHCI_INTERFACE_MASK) << MX35_OTG_SIC_SHIFT; |
46 | 51 | ||
47 | if (!(flags & MXC_EHCI_POWER_PINS_ENABLED)) | 52 | if (!(flags & MXC_EHCI_POWER_PINS_ENABLED)) |
48 | v |= MX35_OTG_PM_BIT; | 53 | v |= MX35_OTG_PM_BIT; |
49 | 54 | ||
55 | if (flags & MXC_EHCI_PWR_PIN_ACTIVE_HIGH) | ||
56 | v |= MX35_OTG_PP_BIT; | ||
57 | |||
58 | if (!(flags & MXC_EHCI_OC_PIN_ACTIVE_LOW)) | ||
59 | v |= MX35_OTG_OCPOL_BIT; | ||
60 | |||
50 | break; | 61 | break; |
51 | case 1: /* H1 port */ | 62 | case 1: /* H1 port */ |
52 | v &= ~(MX35_H1_SIC_MASK | MX35_H1_PM_BIT | MX35_H1_TLL_BIT | | 63 | v &= ~(MX35_H1_SIC_MASK | MX35_H1_PM_BIT | MX35_H1_PP_BIT | |
53 | MX35_H1_USBTE_BIT | MX35_H1_IPPUE_DOWN_BIT | MX35_H1_IPPUE_UP_BIT); | 64 | MX35_H1_OCPOL_BIT | MX35_H1_TLL_BIT | MX35_H1_USBTE_BIT | |
65 | MX35_H1_IPPUE_DOWN_BIT | MX35_H1_IPPUE_UP_BIT); | ||
54 | v |= (flags & MXC_EHCI_INTERFACE_MASK) << MX35_H1_SIC_SHIFT; | 66 | v |= (flags & MXC_EHCI_INTERFACE_MASK) << MX35_H1_SIC_SHIFT; |
55 | 67 | ||
56 | if (!(flags & MXC_EHCI_POWER_PINS_ENABLED)) | 68 | if (!(flags & MXC_EHCI_POWER_PINS_ENABLED)) |
57 | v |= MX35_H1_PM_BIT; | 69 | v |= MX35_H1_PM_BIT; |
58 | 70 | ||
71 | if (flags & MXC_EHCI_PWR_PIN_ACTIVE_HIGH) | ||
72 | v |= MX35_H1_PP_BIT; | ||
73 | |||
74 | if (!(flags & MXC_EHCI_OC_PIN_ACTIVE_LOW)) | ||
75 | v |= MX35_H1_OCPOL_BIT; | ||
76 | |||
59 | if (!(flags & MXC_EHCI_TTL_ENABLED)) | 77 | if (!(flags & MXC_EHCI_TTL_ENABLED)) |
60 | v |= MX35_H1_TLL_BIT; | 78 | v |= MX35_H1_TLL_BIT; |
61 | 79 | ||
diff --git a/arch/arm/mach-imx/ehci-imx5.c b/arch/arm/mach-imx/ehci-imx5.c index c17fa131728b..a6a4afb0ad62 100644 --- a/arch/arm/mach-imx/ehci-imx5.c +++ b/arch/arm/mach-imx/ehci-imx5.c | |||
@@ -28,11 +28,14 @@ | |||
28 | #define MXC_OTG_UCTRL_OPM_BIT (1 << 24) /* OTG power mask */ | 28 | #define MXC_OTG_UCTRL_OPM_BIT (1 << 24) /* OTG power mask */ |
29 | #define MXC_H1_UCTRL_H1UIE_BIT (1 << 12) /* Host1 ULPI interrupt enable */ | 29 | #define MXC_H1_UCTRL_H1UIE_BIT (1 << 12) /* Host1 ULPI interrupt enable */ |
30 | #define MXC_H1_UCTRL_H1WIE_BIT (1 << 11) /* HOST1 wakeup intr enable */ | 30 | #define MXC_H1_UCTRL_H1WIE_BIT (1 << 11) /* HOST1 wakeup intr enable */ |
31 | #define MXC_H1_UCTRL_H1PM_BIT (1 << 8) /* HOST1 power mask */ | 31 | #define MXC_H1_UCTRL_H1PM_BIT (1 << 8) /* HOST1 power mask */ |
32 | 32 | ||
33 | /* USB_PHY_CTRL_FUNC */ | 33 | /* USB_PHY_CTRL_FUNC */ |
34 | #define MXC_OTG_PHYCTRL_OC_POL_BIT (1 << 9) /* OTG Polarity of Overcurrent */ | ||
34 | #define MXC_OTG_PHYCTRL_OC_DIS_BIT (1 << 8) /* OTG Disable Overcurrent Event */ | 35 | #define MXC_OTG_PHYCTRL_OC_DIS_BIT (1 << 8) /* OTG Disable Overcurrent Event */ |
36 | #define MXC_H1_OC_POL_BIT (1 << 6) /* UH1 Polarity of Overcurrent */ | ||
35 | #define MXC_H1_OC_DIS_BIT (1 << 5) /* UH1 Disable Overcurrent Event */ | 37 | #define MXC_H1_OC_DIS_BIT (1 << 5) /* UH1 Disable Overcurrent Event */ |
38 | #define MXC_OTG_PHYCTRL_PWR_POL_BIT (1 << 3) /* OTG Power Pin Polarity */ | ||
36 | 39 | ||
37 | /* USBH2CTRL */ | 40 | /* USBH2CTRL */ |
38 | #define MXC_H2_UCTRL_H2UIE_BIT (1 << 8) | 41 | #define MXC_H2_UCTRL_H2UIE_BIT (1 << 8) |
@@ -80,13 +83,21 @@ int mx51_initialize_usb_hw(int port, unsigned int flags) | |||
80 | if (flags & MXC_EHCI_INTERNAL_PHY) { | 83 | if (flags & MXC_EHCI_INTERNAL_PHY) { |
81 | v = __raw_readl(usbother_base + MXC_USB_PHY_CTR_FUNC_OFFSET); | 84 | v = __raw_readl(usbother_base + MXC_USB_PHY_CTR_FUNC_OFFSET); |
82 | 85 | ||
86 | if (flags & MXC_EHCI_OC_PIN_ACTIVE_LOW) | ||
87 | v |= MXC_OTG_PHYCTRL_OC_POL_BIT; | ||
88 | else | ||
89 | v &= ~MXC_OTG_PHYCTRL_OC_POL_BIT; | ||
83 | if (flags & MXC_EHCI_POWER_PINS_ENABLED) { | 90 | if (flags & MXC_EHCI_POWER_PINS_ENABLED) { |
84 | /* OC/USBPWR is not used */ | ||
85 | v |= MXC_OTG_PHYCTRL_OC_DIS_BIT; | ||
86 | } else { | ||
87 | /* OC/USBPWR is used */ | 91 | /* OC/USBPWR is used */ |
88 | v &= ~MXC_OTG_PHYCTRL_OC_DIS_BIT; | 92 | v &= ~MXC_OTG_PHYCTRL_OC_DIS_BIT; |
93 | } else { | ||
94 | /* OC/USBPWR is not used */ | ||
95 | v |= MXC_OTG_PHYCTRL_OC_DIS_BIT; | ||
89 | } | 96 | } |
97 | if (flags & MXC_EHCI_PWR_PIN_ACTIVE_HIGH) | ||
98 | v |= MXC_OTG_PHYCTRL_PWR_POL_BIT; | ||
99 | else | ||
100 | v &= ~MXC_OTG_PHYCTRL_PWR_POL_BIT; | ||
90 | __raw_writel(v, usbother_base + MXC_USB_PHY_CTR_FUNC_OFFSET); | 101 | __raw_writel(v, usbother_base + MXC_USB_PHY_CTR_FUNC_OFFSET); |
91 | 102 | ||
92 | v = __raw_readl(usbother_base + MXC_USBCTRL_OFFSET); | 103 | v = __raw_readl(usbother_base + MXC_USBCTRL_OFFSET); |
@@ -95,9 +106,9 @@ int mx51_initialize_usb_hw(int port, unsigned int flags) | |||
95 | else | 106 | else |
96 | v &= ~MXC_OTG_UCTRL_OWIE_BIT;/* OTG wakeup disable */ | 107 | v &= ~MXC_OTG_UCTRL_OWIE_BIT;/* OTG wakeup disable */ |
97 | if (flags & MXC_EHCI_POWER_PINS_ENABLED) | 108 | if (flags & MXC_EHCI_POWER_PINS_ENABLED) |
98 | v |= MXC_OTG_UCTRL_OPM_BIT; | ||
99 | else | ||
100 | v &= ~MXC_OTG_UCTRL_OPM_BIT; | 109 | v &= ~MXC_OTG_UCTRL_OPM_BIT; |
110 | else | ||
111 | v |= MXC_OTG_UCTRL_OPM_BIT; | ||
101 | __raw_writel(v, usbother_base + MXC_USBCTRL_OFFSET); | 112 | __raw_writel(v, usbother_base + MXC_USBCTRL_OFFSET); |
102 | } | 113 | } |
103 | break; | 114 | break; |
@@ -113,12 +124,16 @@ int mx51_initialize_usb_hw(int port, unsigned int flags) | |||
113 | } | 124 | } |
114 | 125 | ||
115 | if (flags & MXC_EHCI_POWER_PINS_ENABLED) | 126 | if (flags & MXC_EHCI_POWER_PINS_ENABLED) |
116 | v &= ~MXC_H1_UCTRL_H1PM_BIT; /* HOST1 power mask used*/ | 127 | v &= ~MXC_H1_UCTRL_H1PM_BIT; /* HOST1 power mask unused*/ |
117 | else | 128 | else |
118 | v |= MXC_H1_UCTRL_H1PM_BIT; /* HOST1 power mask used*/ | 129 | v |= MXC_H1_UCTRL_H1PM_BIT; /* HOST1 power mask used*/ |
119 | __raw_writel(v, usbother_base + MXC_USBCTRL_OFFSET); | 130 | __raw_writel(v, usbother_base + MXC_USBCTRL_OFFSET); |
120 | 131 | ||
121 | v = __raw_readl(usbother_base + MXC_USB_PHY_CTR_FUNC_OFFSET); | 132 | v = __raw_readl(usbother_base + MXC_USB_PHY_CTR_FUNC_OFFSET); |
133 | if (flags & MXC_EHCI_OC_PIN_ACTIVE_LOW) | ||
134 | v |= MXC_H1_OC_POL_BIT; | ||
135 | else | ||
136 | v &= ~MXC_H1_OC_POL_BIT; | ||
122 | if (flags & MXC_EHCI_POWER_PINS_ENABLED) | 137 | if (flags & MXC_EHCI_POWER_PINS_ENABLED) |
123 | v &= ~MXC_H1_OC_DIS_BIT; /* OC is used */ | 138 | v &= ~MXC_H1_OC_DIS_BIT; /* OC is used */ |
124 | else | 139 | else |
@@ -142,7 +157,7 @@ int mx51_initialize_usb_hw(int port, unsigned int flags) | |||
142 | } | 157 | } |
143 | 158 | ||
144 | if (flags & MXC_EHCI_POWER_PINS_ENABLED) | 159 | if (flags & MXC_EHCI_POWER_PINS_ENABLED) |
145 | v &= ~MXC_H2_UCTRL_H2PM_BIT; /* HOST2 power mask used*/ | 160 | v &= ~MXC_H2_UCTRL_H2PM_BIT; /* HOST2 power mask unused*/ |
146 | else | 161 | else |
147 | v |= MXC_H2_UCTRL_H2PM_BIT; /* HOST2 power mask used*/ | 162 | v |= MXC_H2_UCTRL_H2PM_BIT; /* HOST2 power mask used*/ |
148 | __raw_writel(v, usbother_base + MXC_USBH2CTRL_OFFSET); | 163 | __raw_writel(v, usbother_base + MXC_USBH2CTRL_OFFSET); |
diff --git a/arch/arm/mach-imx/mach-mx35_3ds.c b/arch/arm/mach-imx/mach-mx35_3ds.c index 6bff87907317..69018e5c52de 100644 --- a/arch/arm/mach-imx/mach-mx35_3ds.c +++ b/arch/arm/mach-imx/mach-mx35_3ds.c | |||
@@ -572,6 +572,7 @@ static void __init mx35_3ds_init(void) | |||
572 | 572 | ||
573 | imx35_add_fec(NULL); | 573 | imx35_add_fec(NULL); |
574 | imx35_add_imx2_wdt(); | 574 | imx35_add_imx2_wdt(); |
575 | imx35_add_mxc_rtc(); | ||
575 | platform_add_devices(devices, ARRAY_SIZE(devices)); | 576 | platform_add_devices(devices, ARRAY_SIZE(devices)); |
576 | 577 | ||
577 | imx35_add_imx_uart0(&uart_pdata); | 578 | imx35_add_imx_uart0(&uart_pdata); |
diff --git a/arch/arm/mach-lpc32xx/Kconfig b/arch/arm/mach-lpc32xx/Kconfig deleted file mode 100644 index e0b3eee83834..000000000000 --- a/arch/arm/mach-lpc32xx/Kconfig +++ /dev/null | |||
@@ -1,32 +0,0 @@ | |||
1 | if ARCH_LPC32XX | ||
2 | |||
3 | menu "Individual UART enable selections" | ||
4 | |||
5 | config ARCH_LPC32XX_UART3_SELECT | ||
6 | bool "Add support for standard UART3" | ||
7 | help | ||
8 | Adds support for standard UART 3 when the 8250 serial support | ||
9 | is enabled. | ||
10 | |||
11 | config ARCH_LPC32XX_UART4_SELECT | ||
12 | bool "Add support for standard UART4" | ||
13 | help | ||
14 | Adds support for standard UART 4 when the 8250 serial support | ||
15 | is enabled. | ||
16 | |||
17 | config ARCH_LPC32XX_UART5_SELECT | ||
18 | bool "Add support for standard UART5" | ||
19 | default y | ||
20 | help | ||
21 | Adds support for standard UART 5 when the 8250 serial support | ||
22 | is enabled. | ||
23 | |||
24 | config ARCH_LPC32XX_UART6_SELECT | ||
25 | bool "Add support for standard UART6" | ||
26 | help | ||
27 | Adds support for standard UART 6 when the 8250 serial support | ||
28 | is enabled. | ||
29 | |||
30 | endmenu | ||
31 | |||
32 | endif | ||
diff --git a/arch/arm/mach-lpc32xx/Makefile.boot b/arch/arm/mach-lpc32xx/Makefile.boot index 2cfe0ee635c5..697323b5f92d 100644 --- a/arch/arm/mach-lpc32xx/Makefile.boot +++ b/arch/arm/mach-lpc32xx/Makefile.boot | |||
@@ -2,3 +2,4 @@ | |||
2 | params_phys-y := 0x80000100 | 2 | params_phys-y := 0x80000100 |
3 | initrd_phys-y := 0x82000000 | 3 | initrd_phys-y := 0x82000000 |
4 | 4 | ||
5 | dtb-$(CONFIG_ARCH_LPC32XX) += ea3250.dtb phy3250.dtb | ||
diff --git a/arch/arm/mach-lpc32xx/clock.c b/arch/arm/mach-lpc32xx/clock.c index f6a3ffec1f4b..f48c2e961b84 100644 --- a/arch/arm/mach-lpc32xx/clock.c +++ b/arch/arm/mach-lpc32xx/clock.c | |||
@@ -607,6 +607,19 @@ static struct clk clk_dma = { | |||
607 | .get_rate = local_return_parent_rate, | 607 | .get_rate = local_return_parent_rate, |
608 | }; | 608 | }; |
609 | 609 | ||
610 | static struct clk clk_pwm = { | ||
611 | .parent = &clk_pclk, | ||
612 | .enable = local_onoff_enable, | ||
613 | .enable_reg = LPC32XX_CLKPWR_PWM_CLK_CTRL, | ||
614 | .enable_mask = LPC32XX_CLKPWR_PWMCLK_PWM1CLK_EN | | ||
615 | LPC32XX_CLKPWR_PWMCLK_PWM1SEL_PCLK | | ||
616 | LPC32XX_CLKPWR_PWMCLK_PWM1_DIV(1) | | ||
617 | LPC32XX_CLKPWR_PWMCLK_PWM2CLK_EN | | ||
618 | LPC32XX_CLKPWR_PWMCLK_PWM2SEL_PCLK | | ||
619 | LPC32XX_CLKPWR_PWMCLK_PWM2_DIV(1), | ||
620 | .get_rate = local_return_parent_rate, | ||
621 | }; | ||
622 | |||
610 | static struct clk clk_uart3 = { | 623 | static struct clk clk_uart3 = { |
611 | .parent = &clk_pclk, | 624 | .parent = &clk_pclk, |
612 | .enable = local_onoff_enable, | 625 | .enable = local_onoff_enable, |
@@ -691,10 +704,21 @@ static struct clk clk_nand = { | |||
691 | .parent = &clk_hclk, | 704 | .parent = &clk_hclk, |
692 | .enable = local_onoff_enable, | 705 | .enable = local_onoff_enable, |
693 | .enable_reg = LPC32XX_CLKPWR_NAND_CLK_CTRL, | 706 | .enable_reg = LPC32XX_CLKPWR_NAND_CLK_CTRL, |
694 | .enable_mask = LPC32XX_CLKPWR_NANDCLK_SLCCLK_EN, | 707 | .enable_mask = LPC32XX_CLKPWR_NANDCLK_SLCCLK_EN | |
708 | LPC32XX_CLKPWR_NANDCLK_SEL_SLC, | ||
695 | .get_rate = local_return_parent_rate, | 709 | .get_rate = local_return_parent_rate, |
696 | }; | 710 | }; |
697 | 711 | ||
712 | static struct clk clk_nand_mlc = { | ||
713 | .parent = &clk_hclk, | ||
714 | .enable = local_onoff_enable, | ||
715 | .enable_reg = LPC32XX_CLKPWR_NAND_CLK_CTRL, | ||
716 | .enable_mask = LPC32XX_CLKPWR_NANDCLK_MLCCLK_EN | | ||
717 | LPC32XX_CLKPWR_NANDCLK_DMA_INT | | ||
718 | LPC32XX_CLKPWR_NANDCLK_INTSEL_MLC, | ||
719 | .get_rate = local_return_parent_rate, | ||
720 | }; | ||
721 | |||
698 | static struct clk clk_i2s0 = { | 722 | static struct clk clk_i2s0 = { |
699 | .parent = &clk_hclk, | 723 | .parent = &clk_hclk, |
700 | .enable = local_onoff_enable, | 724 | .enable = local_onoff_enable, |
@@ -707,7 +731,8 @@ static struct clk clk_i2s1 = { | |||
707 | .parent = &clk_hclk, | 731 | .parent = &clk_hclk, |
708 | .enable = local_onoff_enable, | 732 | .enable = local_onoff_enable, |
709 | .enable_reg = LPC32XX_CLKPWR_I2S_CLK_CTRL, | 733 | .enable_reg = LPC32XX_CLKPWR_I2S_CLK_CTRL, |
710 | .enable_mask = LPC32XX_CLKPWR_I2SCTRL_I2SCLK1_EN, | 734 | .enable_mask = LPC32XX_CLKPWR_I2SCTRL_I2SCLK1_EN | |
735 | LPC32XX_CLKPWR_I2SCTRL_I2S1_USE_DMA, | ||
711 | .get_rate = local_return_parent_rate, | 736 | .get_rate = local_return_parent_rate, |
712 | }; | 737 | }; |
713 | 738 | ||
@@ -727,14 +752,77 @@ static struct clk clk_rtc = { | |||
727 | .get_rate = local_return_parent_rate, | 752 | .get_rate = local_return_parent_rate, |
728 | }; | 753 | }; |
729 | 754 | ||
755 | static int local_usb_enable(struct clk *clk, int enable) | ||
756 | { | ||
757 | u32 tmp; | ||
758 | |||
759 | if (enable) { | ||
760 | /* Set up I2C pull levels */ | ||
761 | tmp = __raw_readl(LPC32XX_CLKPWR_I2C_CLK_CTRL); | ||
762 | tmp |= LPC32XX_CLKPWR_I2CCLK_USBI2CHI_DRIVE; | ||
763 | __raw_writel(tmp, LPC32XX_CLKPWR_I2C_CLK_CTRL); | ||
764 | } | ||
765 | |||
766 | return local_onoff_enable(clk, enable); | ||
767 | } | ||
768 | |||
730 | static struct clk clk_usbd = { | 769 | static struct clk clk_usbd = { |
731 | .parent = &clk_usbpll, | 770 | .parent = &clk_usbpll, |
732 | .enable = local_onoff_enable, | 771 | .enable = local_usb_enable, |
733 | .enable_reg = LPC32XX_CLKPWR_USB_CTRL, | 772 | .enable_reg = LPC32XX_CLKPWR_USB_CTRL, |
734 | .enable_mask = LPC32XX_CLKPWR_USBCTRL_HCLK_EN, | 773 | .enable_mask = LPC32XX_CLKPWR_USBCTRL_HCLK_EN, |
735 | .get_rate = local_return_parent_rate, | 774 | .get_rate = local_return_parent_rate, |
736 | }; | 775 | }; |
737 | 776 | ||
777 | #define OTG_ALWAYS_MASK (LPC32XX_USB_OTG_OTG_CLOCK_ON | \ | ||
778 | LPC32XX_USB_OTG_I2C_CLOCK_ON) | ||
779 | |||
780 | static int local_usb_otg_enable(struct clk *clk, int enable) | ||
781 | { | ||
782 | int to = 1000; | ||
783 | |||
784 | if (enable) { | ||
785 | __raw_writel(clk->enable_mask, clk->enable_reg); | ||
786 | |||
787 | while (((__raw_readl(LPC32XX_USB_OTG_CLK_STAT) & | ||
788 | clk->enable_mask) != clk->enable_mask) && (to > 0)) | ||
789 | to--; | ||
790 | } else { | ||
791 | __raw_writel(OTG_ALWAYS_MASK, clk->enable_reg); | ||
792 | |||
793 | while (((__raw_readl(LPC32XX_USB_OTG_CLK_STAT) & | ||
794 | OTG_ALWAYS_MASK) != OTG_ALWAYS_MASK) && (to > 0)) | ||
795 | to--; | ||
796 | } | ||
797 | |||
798 | if (to) | ||
799 | return 0; | ||
800 | else | ||
801 | return -1; | ||
802 | } | ||
803 | |||
804 | static struct clk clk_usb_otg_dev = { | ||
805 | .parent = &clk_usbpll, | ||
806 | .enable = local_usb_otg_enable, | ||
807 | .enable_reg = LPC32XX_USB_OTG_CLK_CTRL, | ||
808 | .enable_mask = LPC32XX_USB_OTG_AHB_M_CLOCK_ON | | ||
809 | LPC32XX_USB_OTG_OTG_CLOCK_ON | | ||
810 | LPC32XX_USB_OTG_DEV_CLOCK_ON | | ||
811 | LPC32XX_USB_OTG_I2C_CLOCK_ON, | ||
812 | .get_rate = local_return_parent_rate, | ||
813 | }; | ||
814 | |||
815 | static struct clk clk_usb_otg_host = { | ||
816 | .parent = &clk_usbpll, | ||
817 | .enable = local_usb_otg_enable, | ||
818 | .enable_reg = LPC32XX_USB_OTG_CLK_CTRL, | ||
819 | .enable_mask = LPC32XX_USB_OTG_AHB_M_CLOCK_ON | | ||
820 | LPC32XX_USB_OTG_OTG_CLOCK_ON | | ||
821 | LPC32XX_USB_OTG_HOST_CLOCK_ON | | ||
822 | LPC32XX_USB_OTG_I2C_CLOCK_ON, | ||
823 | .get_rate = local_return_parent_rate, | ||
824 | }; | ||
825 | |||
738 | static int tsc_onoff_enable(struct clk *clk, int enable) | 826 | static int tsc_onoff_enable(struct clk *clk, int enable) |
739 | { | 827 | { |
740 | u32 tmp; | 828 | u32 tmp; |
@@ -800,11 +888,17 @@ static int mmc_onoff_enable(struct clk *clk, int enable) | |||
800 | u32 tmp; | 888 | u32 tmp; |
801 | 889 | ||
802 | tmp = __raw_readl(LPC32XX_CLKPWR_MS_CTRL) & | 890 | tmp = __raw_readl(LPC32XX_CLKPWR_MS_CTRL) & |
803 | ~LPC32XX_CLKPWR_MSCARD_SDCARD_EN; | 891 | ~(LPC32XX_CLKPWR_MSCARD_SDCARD_EN | |
892 | LPC32XX_CLKPWR_MSCARD_MSDIO_PU_EN | | ||
893 | LPC32XX_CLKPWR_MSCARD_MSDIO_PIN_DIS | | ||
894 | LPC32XX_CLKPWR_MSCARD_MSDIO0_DIS | | ||
895 | LPC32XX_CLKPWR_MSCARD_MSDIO1_DIS | | ||
896 | LPC32XX_CLKPWR_MSCARD_MSDIO23_DIS); | ||
804 | 897 | ||
805 | /* If rate is 0, disable clock */ | 898 | /* If rate is 0, disable clock */ |
806 | if (enable != 0) | 899 | if (enable != 0) |
807 | tmp |= LPC32XX_CLKPWR_MSCARD_SDCARD_EN; | 900 | tmp |= LPC32XX_CLKPWR_MSCARD_SDCARD_EN | |
901 | LPC32XX_CLKPWR_MSCARD_MSDIO_PU_EN; | ||
808 | 902 | ||
809 | __raw_writel(tmp, LPC32XX_CLKPWR_MS_CTRL); | 903 | __raw_writel(tmp, LPC32XX_CLKPWR_MS_CTRL); |
810 | 904 | ||
@@ -853,7 +947,7 @@ static unsigned long mmc_round_rate(struct clk *clk, unsigned long rate) | |||
853 | 947 | ||
854 | static int mmc_set_rate(struct clk *clk, unsigned long rate) | 948 | static int mmc_set_rate(struct clk *clk, unsigned long rate) |
855 | { | 949 | { |
856 | u32 oldclk, tmp; | 950 | u32 tmp; |
857 | unsigned long prate, div, crate = mmc_round_rate(clk, rate); | 951 | unsigned long prate, div, crate = mmc_round_rate(clk, rate); |
858 | 952 | ||
859 | prate = clk->parent->get_rate(clk->parent); | 953 | prate = clk->parent->get_rate(clk->parent); |
@@ -861,16 +955,12 @@ static int mmc_set_rate(struct clk *clk, unsigned long rate) | |||
861 | div = prate / crate; | 955 | div = prate / crate; |
862 | 956 | ||
863 | /* The MMC clock must be on when accessing an MMC register */ | 957 | /* The MMC clock must be on when accessing an MMC register */ |
864 | oldclk = __raw_readl(LPC32XX_CLKPWR_MS_CTRL); | ||
865 | __raw_writel(oldclk | LPC32XX_CLKPWR_MSCARD_SDCARD_EN, | ||
866 | LPC32XX_CLKPWR_MS_CTRL); | ||
867 | tmp = __raw_readl(LPC32XX_CLKPWR_MS_CTRL) & | 958 | tmp = __raw_readl(LPC32XX_CLKPWR_MS_CTRL) & |
868 | ~LPC32XX_CLKPWR_MSCARD_SDCARD_DIV(0xf); | 959 | ~LPC32XX_CLKPWR_MSCARD_SDCARD_DIV(0xf); |
869 | tmp |= LPC32XX_CLKPWR_MSCARD_SDCARD_DIV(div); | 960 | tmp |= LPC32XX_CLKPWR_MSCARD_SDCARD_DIV(div) | |
961 | LPC32XX_CLKPWR_MSCARD_SDCARD_EN; | ||
870 | __raw_writel(tmp, LPC32XX_CLKPWR_MS_CTRL); | 962 | __raw_writel(tmp, LPC32XX_CLKPWR_MS_CTRL); |
871 | 963 | ||
872 | __raw_writel(oldclk, LPC32XX_CLKPWR_MS_CTRL); | ||
873 | |||
874 | return 0; | 964 | return 0; |
875 | } | 965 | } |
876 | 966 | ||
@@ -1111,6 +1201,7 @@ static struct clk_lookup lookups[] = { | |||
1111 | CLKDEV_INIT(NULL, "vfp9_ck", &clk_vfp9), | 1201 | CLKDEV_INIT(NULL, "vfp9_ck", &clk_vfp9), |
1112 | CLKDEV_INIT("pl08xdmac", NULL, &clk_dma), | 1202 | CLKDEV_INIT("pl08xdmac", NULL, &clk_dma), |
1113 | CLKDEV_INIT("4003c000.watchdog", NULL, &clk_wdt), | 1203 | CLKDEV_INIT("4003c000.watchdog", NULL, &clk_wdt), |
1204 | CLKDEV_INIT("4005c000.pwm", NULL, &clk_pwm), | ||
1114 | CLKDEV_INIT(NULL, "uart3_ck", &clk_uart3), | 1205 | CLKDEV_INIT(NULL, "uart3_ck", &clk_uart3), |
1115 | CLKDEV_INIT(NULL, "uart4_ck", &clk_uart4), | 1206 | CLKDEV_INIT(NULL, "uart4_ck", &clk_uart4), |
1116 | CLKDEV_INIT(NULL, "uart5_ck", &clk_uart5), | 1207 | CLKDEV_INIT(NULL, "uart5_ck", &clk_uart5), |
@@ -1120,8 +1211,9 @@ static struct clk_lookup lookups[] = { | |||
1120 | CLKDEV_INIT("31020300.i2c", NULL, &clk_i2c2), | 1211 | CLKDEV_INIT("31020300.i2c", NULL, &clk_i2c2), |
1121 | CLKDEV_INIT("dev:ssp0", NULL, &clk_ssp0), | 1212 | CLKDEV_INIT("dev:ssp0", NULL, &clk_ssp0), |
1122 | CLKDEV_INIT("dev:ssp1", NULL, &clk_ssp1), | 1213 | CLKDEV_INIT("dev:ssp1", NULL, &clk_ssp1), |
1123 | CLKDEV_INIT("lpc32xx_keys.0", NULL, &clk_kscan), | 1214 | CLKDEV_INIT("40050000.key", NULL, &clk_kscan), |
1124 | CLKDEV_INIT("lpc32xx-nand.0", "nand_ck", &clk_nand), | 1215 | CLKDEV_INIT("20020000.flash", NULL, &clk_nand), |
1216 | CLKDEV_INIT("200a8000.flash", NULL, &clk_nand_mlc), | ||
1125 | CLKDEV_INIT("40048000.adc", NULL, &clk_adc), | 1217 | CLKDEV_INIT("40048000.adc", NULL, &clk_adc), |
1126 | CLKDEV_INIT(NULL, "i2s0_ck", &clk_i2s0), | 1218 | CLKDEV_INIT(NULL, "i2s0_ck", &clk_i2s0), |
1127 | CLKDEV_INIT(NULL, "i2s1_ck", &clk_i2s1), | 1219 | CLKDEV_INIT(NULL, "i2s1_ck", &clk_i2s1), |
@@ -1130,6 +1222,9 @@ static struct clk_lookup lookups[] = { | |||
1130 | CLKDEV_INIT("31060000.ethernet", NULL, &clk_net), | 1222 | CLKDEV_INIT("31060000.ethernet", NULL, &clk_net), |
1131 | CLKDEV_INIT("dev:clcd", NULL, &clk_lcd), | 1223 | CLKDEV_INIT("dev:clcd", NULL, &clk_lcd), |
1132 | CLKDEV_INIT("31020000.usbd", "ck_usbd", &clk_usbd), | 1224 | CLKDEV_INIT("31020000.usbd", "ck_usbd", &clk_usbd), |
1225 | CLKDEV_INIT("31020000.ohci", "ck_usbd", &clk_usbd), | ||
1226 | CLKDEV_INIT("31020000.usbd", "ck_usb_otg", &clk_usb_otg_dev), | ||
1227 | CLKDEV_INIT("31020000.ohci", "ck_usb_otg", &clk_usb_otg_host), | ||
1133 | CLKDEV_INIT("lpc32xx_rtc", NULL, &clk_rtc), | 1228 | CLKDEV_INIT("lpc32xx_rtc", NULL, &clk_rtc), |
1134 | }; | 1229 | }; |
1135 | 1230 | ||
diff --git a/arch/arm/mach-lpc32xx/common.c b/arch/arm/mach-lpc32xx/common.c index 5c96057b6d78..a48dc2dec485 100644 --- a/arch/arm/mach-lpc32xx/common.c +++ b/arch/arm/mach-lpc32xx/common.c | |||
@@ -26,6 +26,7 @@ | |||
26 | #include <linux/io.h> | 26 | #include <linux/io.h> |
27 | 27 | ||
28 | #include <asm/mach/map.h> | 28 | #include <asm/mach/map.h> |
29 | #include <asm/system_info.h> | ||
29 | 30 | ||
30 | #include <mach/hardware.h> | 31 | #include <mach/hardware.h> |
31 | #include <mach/platform.h> | 32 | #include <mach/platform.h> |
@@ -224,7 +225,7 @@ void lpc23xx_restart(char mode, const char *cmd) | |||
224 | ; | 225 | ; |
225 | } | 226 | } |
226 | 227 | ||
227 | static int __init lpc32xx_display_uid(void) | 228 | static int __init lpc32xx_check_uid(void) |
228 | { | 229 | { |
229 | u32 uid[4]; | 230 | u32 uid[4]; |
230 | 231 | ||
@@ -233,6 +234,11 @@ static int __init lpc32xx_display_uid(void) | |||
233 | printk(KERN_INFO "LPC32XX unique ID: %08x%08x%08x%08x\n", | 234 | printk(KERN_INFO "LPC32XX unique ID: %08x%08x%08x%08x\n", |
234 | uid[3], uid[2], uid[1], uid[0]); | 235 | uid[3], uid[2], uid[1], uid[0]); |
235 | 236 | ||
237 | if (!system_serial_low && !system_serial_high) { | ||
238 | system_serial_low = uid[0]; | ||
239 | system_serial_high = uid[1]; | ||
240 | } | ||
241 | |||
236 | return 1; | 242 | return 1; |
237 | } | 243 | } |
238 | arch_initcall(lpc32xx_display_uid); | 244 | arch_initcall(lpc32xx_check_uid); |
diff --git a/arch/arm/mach-lpc32xx/include/mach/gpio.h b/arch/arm/mach-lpc32xx/include/mach/gpio.h index 2ba6ca412bef..0052e7a76179 100644 --- a/arch/arm/mach-lpc32xx/include/mach/gpio.h +++ b/arch/arm/mach-lpc32xx/include/mach/gpio.h | |||
@@ -3,6 +3,4 @@ | |||
3 | 3 | ||
4 | #include "gpio-lpc32xx.h" | 4 | #include "gpio-lpc32xx.h" |
5 | 5 | ||
6 | #define ARCH_NR_GPIOS (LPC32XX_GPO_P3_GRP + LPC32XX_GPO_P3_MAX) | ||
7 | |||
8 | #endif /* __MACH_GPIO_H */ | 6 | #endif /* __MACH_GPIO_H */ |
diff --git a/arch/arm/mach-lpc32xx/include/mach/platform.h b/arch/arm/mach-lpc32xx/include/mach/platform.h index c584f5bb164f..acc4aabf1c7b 100644 --- a/arch/arm/mach-lpc32xx/include/mach/platform.h +++ b/arch/arm/mach-lpc32xx/include/mach/platform.h | |||
@@ -694,4 +694,18 @@ | |||
694 | #define LPC32XX_GPIO_P2_MUX_CLR _GPREG(0x02C) | 694 | #define LPC32XX_GPIO_P2_MUX_CLR _GPREG(0x02C) |
695 | #define LPC32XX_GPIO_P2_MUX_STATE _GPREG(0x030) | 695 | #define LPC32XX_GPIO_P2_MUX_STATE _GPREG(0x030) |
696 | 696 | ||
697 | /* | ||
698 | * USB Otg Registers | ||
699 | */ | ||
700 | #define _OTGREG(x) io_p2v(LPC32XX_USB_OTG_BASE + (x)) | ||
701 | #define LPC32XX_USB_OTG_CLK_CTRL _OTGREG(0xFF4) | ||
702 | #define LPC32XX_USB_OTG_CLK_STAT _OTGREG(0xFF8) | ||
703 | |||
704 | /* USB OTG CLK CTRL bit defines */ | ||
705 | #define LPC32XX_USB_OTG_AHB_M_CLOCK_ON _BIT(4) | ||
706 | #define LPC32XX_USB_OTG_OTG_CLOCK_ON _BIT(3) | ||
707 | #define LPC32XX_USB_OTG_I2C_CLOCK_ON _BIT(2) | ||
708 | #define LPC32XX_USB_OTG_DEV_CLOCK_ON _BIT(1) | ||
709 | #define LPC32XX_USB_OTG_HOST_CLOCK_ON _BIT(0) | ||
710 | |||
697 | #endif | 711 | #endif |
diff --git a/arch/arm/mach-lpc32xx/phy3250.c b/arch/arm/mach-lpc32xx/phy3250.c index 540106cdb9ec..b07dcc90829d 100644 --- a/arch/arm/mach-lpc32xx/phy3250.c +++ b/arch/arm/mach-lpc32xx/phy3250.c | |||
@@ -30,12 +30,13 @@ | |||
30 | #include <linux/amba/bus.h> | 30 | #include <linux/amba/bus.h> |
31 | #include <linux/amba/clcd.h> | 31 | #include <linux/amba/clcd.h> |
32 | #include <linux/amba/pl022.h> | 32 | #include <linux/amba/pl022.h> |
33 | #include <linux/amba/pl08x.h> | ||
34 | #include <linux/amba/mmci.h> | ||
33 | #include <linux/of.h> | 35 | #include <linux/of.h> |
34 | #include <linux/of_address.h> | 36 | #include <linux/of_address.h> |
35 | #include <linux/of_irq.h> | 37 | #include <linux/of_irq.h> |
36 | #include <linux/of_platform.h> | 38 | #include <linux/of_platform.h> |
37 | #include <linux/clk.h> | 39 | #include <linux/clk.h> |
38 | #include <linux/amba/pl08x.h> | ||
39 | 40 | ||
40 | #include <asm/setup.h> | 41 | #include <asm/setup.h> |
41 | #include <asm/mach-types.h> | 42 | #include <asm/mach-types.h> |
@@ -50,9 +51,9 @@ | |||
50 | /* | 51 | /* |
51 | * Mapped GPIOLIB GPIOs | 52 | * Mapped GPIOLIB GPIOs |
52 | */ | 53 | */ |
53 | #define SPI0_CS_GPIO LPC32XX_GPIO(LPC32XX_GPIO_P3_GRP, 5) | 54 | #define LCD_POWER_GPIO LPC32XX_GPIO(LPC32XX_GPO_P3_GRP, 0) |
54 | #define LCD_POWER_GPIO LPC32XX_GPIO(LPC32XX_GPO_P3_GRP, 0) | 55 | #define BKL_POWER_GPIO LPC32XX_GPIO(LPC32XX_GPO_P3_GRP, 4) |
55 | #define BKL_POWER_GPIO LPC32XX_GPIO(LPC32XX_GPO_P3_GRP, 4) | 56 | #define MMC_PWR_ENABLE_GPIO LPC32XX_GPIO(LPC32XX_GPO_P3_GRP, 5) |
56 | 57 | ||
57 | /* | 58 | /* |
58 | * AMBA LCD controller | 59 | * AMBA LCD controller |
@@ -158,24 +159,6 @@ static struct clcd_board lpc32xx_clcd_data = { | |||
158 | /* | 159 | /* |
159 | * AMBA SSP (SPI) | 160 | * AMBA SSP (SPI) |
160 | */ | 161 | */ |
161 | static void phy3250_spi_cs_set(u32 control) | ||
162 | { | ||
163 | gpio_set_value(SPI0_CS_GPIO, (int) control); | ||
164 | } | ||
165 | |||
166 | static struct pl022_config_chip spi0_chip_info = { | ||
167 | .com_mode = INTERRUPT_TRANSFER, | ||
168 | .iface = SSP_INTERFACE_MOTOROLA_SPI, | ||
169 | .hierarchy = SSP_MASTER, | ||
170 | .slave_tx_disable = 0, | ||
171 | .rx_lev_trig = SSP_RX_4_OR_MORE_ELEM, | ||
172 | .tx_lev_trig = SSP_TX_4_OR_MORE_EMPTY_LOC, | ||
173 | .ctrl_len = SSP_BITS_8, | ||
174 | .wait_state = SSP_MWIRE_WAIT_ZERO, | ||
175 | .duplex = SSP_MICROWIRE_CHANNEL_FULL_DUPLEX, | ||
176 | .cs_control = phy3250_spi_cs_set, | ||
177 | }; | ||
178 | |||
179 | static struct pl022_ssp_controller lpc32xx_ssp0_data = { | 162 | static struct pl022_ssp_controller lpc32xx_ssp0_data = { |
180 | .bus_id = 0, | 163 | .bus_id = 0, |
181 | .num_chipselect = 1, | 164 | .num_chipselect = 1, |
@@ -188,45 +171,56 @@ static struct pl022_ssp_controller lpc32xx_ssp1_data = { | |||
188 | .enable_dma = 0, | 171 | .enable_dma = 0, |
189 | }; | 172 | }; |
190 | 173 | ||
191 | /* AT25 driver registration */ | 174 | static struct pl08x_channel_data pl08x_slave_channels[] = { |
192 | static int __init phy3250_spi_board_register(void) | 175 | { |
176 | .bus_id = "nand-slc", | ||
177 | .min_signal = 1, /* SLC NAND Flash */ | ||
178 | .max_signal = 1, | ||
179 | .periph_buses = PL08X_AHB1, | ||
180 | }, | ||
181 | { | ||
182 | .bus_id = "nand-mlc", | ||
183 | .min_signal = 12, /* MLC NAND Flash */ | ||
184 | .max_signal = 12, | ||
185 | .periph_buses = PL08X_AHB1, | ||
186 | }, | ||
187 | }; | ||
188 | |||
189 | static int pl08x_get_signal(const struct pl08x_channel_data *cd) | ||
190 | { | ||
191 | return cd->min_signal; | ||
192 | } | ||
193 | |||
194 | static void pl08x_put_signal(const struct pl08x_channel_data *cd, int ch) | ||
193 | { | 195 | { |
194 | #if defined(CONFIG_SPI_SPIDEV) || defined(CONFIG_SPI_SPIDEV_MODULE) | ||
195 | static struct spi_board_info info[] = { | ||
196 | { | ||
197 | .modalias = "spidev", | ||
198 | .max_speed_hz = 5000000, | ||
199 | .bus_num = 0, | ||
200 | .chip_select = 0, | ||
201 | .controller_data = &spi0_chip_info, | ||
202 | }, | ||
203 | }; | ||
204 | |||
205 | #else | ||
206 | static struct spi_eeprom eeprom = { | ||
207 | .name = "at25256a", | ||
208 | .byte_len = 0x8000, | ||
209 | .page_size = 64, | ||
210 | .flags = EE_ADDR2, | ||
211 | }; | ||
212 | |||
213 | static struct spi_board_info info[] = { | ||
214 | { | ||
215 | .modalias = "at25", | ||
216 | .max_speed_hz = 5000000, | ||
217 | .bus_num = 0, | ||
218 | .chip_select = 0, | ||
219 | .mode = SPI_MODE_0, | ||
220 | .platform_data = &eeprom, | ||
221 | .controller_data = &spi0_chip_info, | ||
222 | }, | ||
223 | }; | ||
224 | #endif | ||
225 | return spi_register_board_info(info, ARRAY_SIZE(info)); | ||
226 | } | 196 | } |
227 | arch_initcall(phy3250_spi_board_register); | ||
228 | 197 | ||
229 | static struct pl08x_platform_data pl08x_pd = { | 198 | static struct pl08x_platform_data pl08x_pd = { |
199 | .slave_channels = &pl08x_slave_channels[0], | ||
200 | .num_slave_channels = ARRAY_SIZE(pl08x_slave_channels), | ||
201 | .get_signal = pl08x_get_signal, | ||
202 | .put_signal = pl08x_put_signal, | ||
203 | .lli_buses = PL08X_AHB1, | ||
204 | .mem_buses = PL08X_AHB1, | ||
205 | }; | ||
206 | |||
207 | static int mmc_handle_ios(struct device *dev, struct mmc_ios *ios) | ||
208 | { | ||
209 | /* Only on and off are supported */ | ||
210 | if (ios->power_mode == MMC_POWER_OFF) | ||
211 | gpio_set_value(MMC_PWR_ENABLE_GPIO, 0); | ||
212 | else | ||
213 | gpio_set_value(MMC_PWR_ENABLE_GPIO, 1); | ||
214 | return 0; | ||
215 | } | ||
216 | |||
217 | static struct mmci_platform_data lpc32xx_mmci_data = { | ||
218 | .ocr_mask = MMC_VDD_30_31 | MMC_VDD_31_32 | | ||
219 | MMC_VDD_32_33 | MMC_VDD_33_34, | ||
220 | .ios_handler = mmc_handle_ios, | ||
221 | .dma_filter = NULL, | ||
222 | /* No DMA for now since AMBA PL080 dmaengine driver only does scatter | ||
223 | * gather, and the MMCI driver doesn't do it this way */ | ||
230 | }; | 224 | }; |
231 | 225 | ||
232 | static const struct of_dev_auxdata lpc32xx_auxdata_lookup[] __initconst = { | 226 | static const struct of_dev_auxdata lpc32xx_auxdata_lookup[] __initconst = { |
@@ -234,6 +228,8 @@ static const struct of_dev_auxdata lpc32xx_auxdata_lookup[] __initconst = { | |||
234 | OF_DEV_AUXDATA("arm,pl022", 0x2008C000, "dev:ssp1", &lpc32xx_ssp1_data), | 228 | OF_DEV_AUXDATA("arm,pl022", 0x2008C000, "dev:ssp1", &lpc32xx_ssp1_data), |
235 | OF_DEV_AUXDATA("arm,pl110", 0x31040000, "dev:clcd", &lpc32xx_clcd_data), | 229 | OF_DEV_AUXDATA("arm,pl110", 0x31040000, "dev:clcd", &lpc32xx_clcd_data), |
236 | OF_DEV_AUXDATA("arm,pl080", 0x31000000, "pl08xdmac", &pl08x_pd), | 230 | OF_DEV_AUXDATA("arm,pl080", 0x31000000, "pl08xdmac", &pl08x_pd), |
231 | OF_DEV_AUXDATA("arm,pl18x", 0x20098000, "20098000.sd", | ||
232 | &lpc32xx_mmci_data), | ||
237 | { } | 233 | { } |
238 | }; | 234 | }; |
239 | 235 | ||
@@ -241,10 +237,6 @@ static void __init lpc3250_machine_init(void) | |||
241 | { | 237 | { |
242 | u32 tmp; | 238 | u32 tmp; |
243 | 239 | ||
244 | /* Setup SLC NAND controller muxing */ | ||
245 | __raw_writel(LPC32XX_CLKPWR_NANDCLK_SEL_SLC, | ||
246 | LPC32XX_CLKPWR_NAND_CLK_CTRL); | ||
247 | |||
248 | /* Setup LCD muxing to RGB565 */ | 240 | /* Setup LCD muxing to RGB565 */ |
249 | tmp = __raw_readl(LPC32XX_CLKPWR_LCDCLK_CTRL) & | 241 | tmp = __raw_readl(LPC32XX_CLKPWR_LCDCLK_CTRL) & |
250 | ~(LPC32XX_CLKPWR_LCDCTRL_LCDTYPE_MSK | | 242 | ~(LPC32XX_CLKPWR_LCDCTRL_LCDTYPE_MSK | |
@@ -252,47 +244,8 @@ static void __init lpc3250_machine_init(void) | |||
252 | tmp |= LPC32XX_CLKPWR_LCDCTRL_LCDTYPE_TFT16; | 244 | tmp |= LPC32XX_CLKPWR_LCDCTRL_LCDTYPE_TFT16; |
253 | __raw_writel(tmp, LPC32XX_CLKPWR_LCDCLK_CTRL); | 245 | __raw_writel(tmp, LPC32XX_CLKPWR_LCDCLK_CTRL); |
254 | 246 | ||
255 | /* Set up USB power */ | ||
256 | tmp = __raw_readl(LPC32XX_CLKPWR_USB_CTRL); | ||
257 | tmp |= LPC32XX_CLKPWR_USBCTRL_HCLK_EN | | ||
258 | LPC32XX_CLKPWR_USBCTRL_USBI2C_EN; | ||
259 | __raw_writel(tmp, LPC32XX_CLKPWR_USB_CTRL); | ||
260 | |||
261 | /* Set up I2C pull levels */ | ||
262 | tmp = __raw_readl(LPC32XX_CLKPWR_I2C_CLK_CTRL); | ||
263 | tmp |= LPC32XX_CLKPWR_I2CCLK_USBI2CHI_DRIVE | | ||
264 | LPC32XX_CLKPWR_I2CCLK_I2C2HI_DRIVE; | ||
265 | __raw_writel(tmp, LPC32XX_CLKPWR_I2C_CLK_CTRL); | ||
266 | |||
267 | /* Disable IrDA pulsing support on UART6 */ | ||
268 | tmp = __raw_readl(LPC32XX_UARTCTL_CTRL); | ||
269 | tmp |= LPC32XX_UART_UART6_IRDAMOD_BYPASS; | ||
270 | __raw_writel(tmp, LPC32XX_UARTCTL_CTRL); | ||
271 | |||
272 | /* Enable DMA for I2S1 channel */ | ||
273 | tmp = __raw_readl(LPC32XX_CLKPWR_I2S_CLK_CTRL); | ||
274 | tmp = LPC32XX_CLKPWR_I2SCTRL_I2S1_USE_DMA; | ||
275 | __raw_writel(tmp, LPC32XX_CLKPWR_I2S_CLK_CTRL); | ||
276 | |||
277 | lpc32xx_serial_init(); | 247 | lpc32xx_serial_init(); |
278 | 248 | ||
279 | /* | ||
280 | * AMBA peripheral clocks need to be enabled prior to AMBA device | ||
281 | * detection or a data fault will occur, so enable the clocks | ||
282 | * here. | ||
283 | */ | ||
284 | tmp = __raw_readl(LPC32XX_CLKPWR_LCDCLK_CTRL); | ||
285 | __raw_writel((tmp | LPC32XX_CLKPWR_LCDCTRL_CLK_EN), | ||
286 | LPC32XX_CLKPWR_LCDCLK_CTRL); | ||
287 | |||
288 | tmp = __raw_readl(LPC32XX_CLKPWR_SSP_CLK_CTRL); | ||
289 | __raw_writel((tmp | LPC32XX_CLKPWR_SSPCTRL_SSPCLK0_EN), | ||
290 | LPC32XX_CLKPWR_SSP_CLK_CTRL); | ||
291 | |||
292 | tmp = __raw_readl(LPC32XX_CLKPWR_DMA_CLK_CTRL); | ||
293 | __raw_writel((tmp | LPC32XX_CLKPWR_DMACLKCTRL_CLK_EN), | ||
294 | LPC32XX_CLKPWR_DMA_CLK_CTRL); | ||
295 | |||
296 | /* Test clock needed for UDA1380 initial init */ | 249 | /* Test clock needed for UDA1380 initial init */ |
297 | __raw_writel(LPC32XX_CLKPWR_TESTCLK2_SEL_MOSC | | 250 | __raw_writel(LPC32XX_CLKPWR_TESTCLK2_SEL_MOSC | |
298 | LPC32XX_CLKPWR_TESTCLK_TESTCLK2_EN, | 251 | LPC32XX_CLKPWR_TESTCLK_TESTCLK2_EN, |
@@ -302,12 +255,10 @@ static void __init lpc3250_machine_init(void) | |||
302 | lpc32xx_auxdata_lookup, NULL); | 255 | lpc32xx_auxdata_lookup, NULL); |
303 | 256 | ||
304 | /* Register GPIOs used on this board */ | 257 | /* Register GPIOs used on this board */ |
305 | if (gpio_request(SPI0_CS_GPIO, "spi0 cs")) | 258 | if (gpio_request(MMC_PWR_ENABLE_GPIO, "mmc_power_en")) |
306 | printk(KERN_ERR "Error requesting gpio %u", | 259 | pr_err("Error requesting gpio %u", MMC_PWR_ENABLE_GPIO); |
307 | SPI0_CS_GPIO); | 260 | else if (gpio_direction_output(MMC_PWR_ENABLE_GPIO, 1)) |
308 | else if (gpio_direction_output(SPI0_CS_GPIO, 1)) | 261 | pr_err("Error setting gpio %u to output", MMC_PWR_ENABLE_GPIO); |
309 | printk(KERN_ERR "Error setting gpio %u to output", | ||
310 | SPI0_CS_GPIO); | ||
311 | } | 262 | } |
312 | 263 | ||
313 | static char const *lpc32xx_dt_compat[] __initdata = { | 264 | static char const *lpc32xx_dt_compat[] __initdata = { |
diff --git a/arch/arm/mach-lpc32xx/serial.c b/arch/arm/mach-lpc32xx/serial.c index f2735281616a..05621a29fba2 100644 --- a/arch/arm/mach-lpc32xx/serial.c +++ b/arch/arm/mach-lpc32xx/serial.c | |||
@@ -31,59 +31,6 @@ | |||
31 | 31 | ||
32 | #define LPC32XX_SUART_FIFO_SIZE 64 | 32 | #define LPC32XX_SUART_FIFO_SIZE 64 |
33 | 33 | ||
34 | /* Standard 8250/16550 compatible serial ports */ | ||
35 | static struct plat_serial8250_port serial_std_platform_data[] = { | ||
36 | #ifdef CONFIG_ARCH_LPC32XX_UART5_SELECT | ||
37 | { | ||
38 | .membase = io_p2v(LPC32XX_UART5_BASE), | ||
39 | .mapbase = LPC32XX_UART5_BASE, | ||
40 | .irq = IRQ_LPC32XX_UART_IIR5, | ||
41 | .uartclk = LPC32XX_MAIN_OSC_FREQ, | ||
42 | .regshift = 2, | ||
43 | .iotype = UPIO_MEM32, | ||
44 | .flags = UPF_BOOT_AUTOCONF | UPF_BUGGY_UART | | ||
45 | UPF_SKIP_TEST, | ||
46 | }, | ||
47 | #endif | ||
48 | #ifdef CONFIG_ARCH_LPC32XX_UART3_SELECT | ||
49 | { | ||
50 | .membase = io_p2v(LPC32XX_UART3_BASE), | ||
51 | .mapbase = LPC32XX_UART3_BASE, | ||
52 | .irq = IRQ_LPC32XX_UART_IIR3, | ||
53 | .uartclk = LPC32XX_MAIN_OSC_FREQ, | ||
54 | .regshift = 2, | ||
55 | .iotype = UPIO_MEM32, | ||
56 | .flags = UPF_BOOT_AUTOCONF | UPF_BUGGY_UART | | ||
57 | UPF_SKIP_TEST, | ||
58 | }, | ||
59 | #endif | ||
60 | #ifdef CONFIG_ARCH_LPC32XX_UART4_SELECT | ||
61 | { | ||
62 | .membase = io_p2v(LPC32XX_UART4_BASE), | ||
63 | .mapbase = LPC32XX_UART4_BASE, | ||
64 | .irq = IRQ_LPC32XX_UART_IIR4, | ||
65 | .uartclk = LPC32XX_MAIN_OSC_FREQ, | ||
66 | .regshift = 2, | ||
67 | .iotype = UPIO_MEM32, | ||
68 | .flags = UPF_BOOT_AUTOCONF | UPF_BUGGY_UART | | ||
69 | UPF_SKIP_TEST, | ||
70 | }, | ||
71 | #endif | ||
72 | #ifdef CONFIG_ARCH_LPC32XX_UART6_SELECT | ||
73 | { | ||
74 | .membase = io_p2v(LPC32XX_UART6_BASE), | ||
75 | .mapbase = LPC32XX_UART6_BASE, | ||
76 | .irq = IRQ_LPC32XX_UART_IIR6, | ||
77 | .uartclk = LPC32XX_MAIN_OSC_FREQ, | ||
78 | .regshift = 2, | ||
79 | .iotype = UPIO_MEM32, | ||
80 | .flags = UPF_BOOT_AUTOCONF | UPF_BUGGY_UART | | ||
81 | UPF_SKIP_TEST, | ||
82 | }, | ||
83 | #endif | ||
84 | { }, | ||
85 | }; | ||
86 | |||
87 | struct uartinit { | 34 | struct uartinit { |
88 | char *uart_ck_name; | 35 | char *uart_ck_name; |
89 | u32 ck_mode_mask; | 36 | u32 ck_mode_mask; |
@@ -92,7 +39,6 @@ struct uartinit { | |||
92 | }; | 39 | }; |
93 | 40 | ||
94 | static struct uartinit uartinit_data[] __initdata = { | 41 | static struct uartinit uartinit_data[] __initdata = { |
95 | #ifdef CONFIG_ARCH_LPC32XX_UART5_SELECT | ||
96 | { | 42 | { |
97 | .uart_ck_name = "uart5_ck", | 43 | .uart_ck_name = "uart5_ck", |
98 | .ck_mode_mask = | 44 | .ck_mode_mask = |
@@ -100,8 +46,6 @@ static struct uartinit uartinit_data[] __initdata = { | |||
100 | .pdiv_clk_reg = LPC32XX_CLKPWR_UART5_CLK_CTRL, | 46 | .pdiv_clk_reg = LPC32XX_CLKPWR_UART5_CLK_CTRL, |
101 | .mapbase = LPC32XX_UART5_BASE, | 47 | .mapbase = LPC32XX_UART5_BASE, |
102 | }, | 48 | }, |
103 | #endif | ||
104 | #ifdef CONFIG_ARCH_LPC32XX_UART3_SELECT | ||
105 | { | 49 | { |
106 | .uart_ck_name = "uart3_ck", | 50 | .uart_ck_name = "uart3_ck", |
107 | .ck_mode_mask = | 51 | .ck_mode_mask = |
@@ -109,8 +53,6 @@ static struct uartinit uartinit_data[] __initdata = { | |||
109 | .pdiv_clk_reg = LPC32XX_CLKPWR_UART3_CLK_CTRL, | 53 | .pdiv_clk_reg = LPC32XX_CLKPWR_UART3_CLK_CTRL, |
110 | .mapbase = LPC32XX_UART3_BASE, | 54 | .mapbase = LPC32XX_UART3_BASE, |
111 | }, | 55 | }, |
112 | #endif | ||
113 | #ifdef CONFIG_ARCH_LPC32XX_UART4_SELECT | ||
114 | { | 56 | { |
115 | .uart_ck_name = "uart4_ck", | 57 | .uart_ck_name = "uart4_ck", |
116 | .ck_mode_mask = | 58 | .ck_mode_mask = |
@@ -118,8 +60,6 @@ static struct uartinit uartinit_data[] __initdata = { | |||
118 | .pdiv_clk_reg = LPC32XX_CLKPWR_UART4_CLK_CTRL, | 60 | .pdiv_clk_reg = LPC32XX_CLKPWR_UART4_CLK_CTRL, |
119 | .mapbase = LPC32XX_UART4_BASE, | 61 | .mapbase = LPC32XX_UART4_BASE, |
120 | }, | 62 | }, |
121 | #endif | ||
122 | #ifdef CONFIG_ARCH_LPC32XX_UART6_SELECT | ||
123 | { | 63 | { |
124 | .uart_ck_name = "uart6_ck", | 64 | .uart_ck_name = "uart6_ck", |
125 | .ck_mode_mask = | 65 | .ck_mode_mask = |
@@ -127,19 +67,6 @@ static struct uartinit uartinit_data[] __initdata = { | |||
127 | .pdiv_clk_reg = LPC32XX_CLKPWR_UART6_CLK_CTRL, | 67 | .pdiv_clk_reg = LPC32XX_CLKPWR_UART6_CLK_CTRL, |
128 | .mapbase = LPC32XX_UART6_BASE, | 68 | .mapbase = LPC32XX_UART6_BASE, |
129 | }, | 69 | }, |
130 | #endif | ||
131 | }; | ||
132 | |||
133 | static struct platform_device serial_std_platform_device = { | ||
134 | .name = "serial8250", | ||
135 | .id = 0, | ||
136 | .dev = { | ||
137 | .platform_data = serial_std_platform_data, | ||
138 | }, | ||
139 | }; | ||
140 | |||
141 | static struct platform_device *lpc32xx_serial_devs[] __initdata = { | ||
142 | &serial_std_platform_device, | ||
143 | }; | 70 | }; |
144 | 71 | ||
145 | void __init lpc32xx_serial_init(void) | 72 | void __init lpc32xx_serial_init(void) |
@@ -156,15 +83,8 @@ void __init lpc32xx_serial_init(void) | |||
156 | clk = clk_get(NULL, uartinit_data[i].uart_ck_name); | 83 | clk = clk_get(NULL, uartinit_data[i].uart_ck_name); |
157 | if (!IS_ERR(clk)) { | 84 | if (!IS_ERR(clk)) { |
158 | clk_enable(clk); | 85 | clk_enable(clk); |
159 | serial_std_platform_data[i].uartclk = | ||
160 | clk_get_rate(clk); | ||
161 | } | 86 | } |
162 | 87 | ||
163 | /* Fall back on main osc rate if clock rate return fails */ | ||
164 | if (serial_std_platform_data[i].uartclk == 0) | ||
165 | serial_std_platform_data[i].uartclk = | ||
166 | LPC32XX_MAIN_OSC_FREQ; | ||
167 | |||
168 | /* Setup UART clock modes for all UARTs, disable autoclock */ | 88 | /* Setup UART clock modes for all UARTs, disable autoclock */ |
169 | clkmodes |= uartinit_data[i].ck_mode_mask; | 89 | clkmodes |= uartinit_data[i].ck_mode_mask; |
170 | 90 | ||
@@ -189,7 +109,7 @@ void __init lpc32xx_serial_init(void) | |||
189 | __raw_writel(clkmodes, LPC32XX_UARTCTL_CLKMODE); | 109 | __raw_writel(clkmodes, LPC32XX_UARTCTL_CLKMODE); |
190 | for (i = 0; i < ARRAY_SIZE(uartinit_data); i++) { | 110 | for (i = 0; i < ARRAY_SIZE(uartinit_data); i++) { |
191 | /* Force a flush of the RX FIFOs to work around a HW bug */ | 111 | /* Force a flush of the RX FIFOs to work around a HW bug */ |
192 | puart = serial_std_platform_data[i].mapbase; | 112 | puart = uartinit_data[i].mapbase; |
193 | __raw_writel(0xC1, LPC32XX_UART_IIR_FCR(puart)); | 113 | __raw_writel(0xC1, LPC32XX_UART_IIR_FCR(puart)); |
194 | __raw_writel(0x00, LPC32XX_UART_DLL_FIFO(puart)); | 114 | __raw_writel(0x00, LPC32XX_UART_DLL_FIFO(puart)); |
195 | j = LPC32XX_SUART_FIFO_SIZE; | 115 | j = LPC32XX_SUART_FIFO_SIZE; |
@@ -198,11 +118,13 @@ void __init lpc32xx_serial_init(void) | |||
198 | __raw_writel(0, LPC32XX_UART_IIR_FCR(puart)); | 118 | __raw_writel(0, LPC32XX_UART_IIR_FCR(puart)); |
199 | } | 119 | } |
200 | 120 | ||
121 | /* Disable IrDA pulsing support on UART6 */ | ||
122 | tmp = __raw_readl(LPC32XX_UARTCTL_CTRL); | ||
123 | tmp |= LPC32XX_UART_UART6_IRDAMOD_BYPASS; | ||
124 | __raw_writel(tmp, LPC32XX_UARTCTL_CTRL); | ||
125 | |||
201 | /* Disable UART5->USB transparent mode or USB won't work */ | 126 | /* Disable UART5->USB transparent mode or USB won't work */ |
202 | tmp = __raw_readl(LPC32XX_UARTCTL_CTRL); | 127 | tmp = __raw_readl(LPC32XX_UARTCTL_CTRL); |
203 | tmp &= ~LPC32XX_UART_U5_ROUTE_TO_USB; | 128 | tmp &= ~LPC32XX_UART_U5_ROUTE_TO_USB; |
204 | __raw_writel(tmp, LPC32XX_UARTCTL_CTRL); | 129 | __raw_writel(tmp, LPC32XX_UARTCTL_CTRL); |
205 | |||
206 | platform_add_devices(lpc32xx_serial_devs, | ||
207 | ARRAY_SIZE(lpc32xx_serial_devs)); | ||
208 | } | 130 | } |
diff --git a/arch/arm/mach-nomadik/Makefile b/arch/arm/mach-nomadik/Makefile index a6bbd1a7b4e7..a42c9a33d3bf 100644 --- a/arch/arm/mach-nomadik/Makefile +++ b/arch/arm/mach-nomadik/Makefile | |||
@@ -7,8 +7,6 @@ | |||
7 | 7 | ||
8 | # Object file lists. | 8 | # Object file lists. |
9 | 9 | ||
10 | obj-y += clock.o | ||
11 | |||
12 | # Cpu revision | 10 | # Cpu revision |
13 | obj-$(CONFIG_NOMADIK_8815) += cpu-8815.o | 11 | obj-$(CONFIG_NOMADIK_8815) += cpu-8815.o |
14 | 12 | ||
diff --git a/arch/arm/mach-nomadik/board-nhk8815.c b/arch/arm/mach-nomadik/board-nhk8815.c index 2e8d3e176bc7..f4535a7dadf5 100644 --- a/arch/arm/mach-nomadik/board-nhk8815.c +++ b/arch/arm/mach-nomadik/board-nhk8815.c | |||
@@ -14,12 +14,14 @@ | |||
14 | #include <linux/init.h> | 14 | #include <linux/init.h> |
15 | #include <linux/platform_device.h> | 15 | #include <linux/platform_device.h> |
16 | #include <linux/amba/bus.h> | 16 | #include <linux/amba/bus.h> |
17 | #include <linux/amba/mmci.h> | ||
17 | #include <linux/interrupt.h> | 18 | #include <linux/interrupt.h> |
18 | #include <linux/gpio.h> | 19 | #include <linux/gpio.h> |
19 | #include <linux/mtd/mtd.h> | 20 | #include <linux/mtd/mtd.h> |
20 | #include <linux/mtd/nand.h> | 21 | #include <linux/mtd/nand.h> |
21 | #include <linux/mtd/onenand.h> | 22 | #include <linux/mtd/onenand.h> |
22 | #include <linux/mtd/partitions.h> | 23 | #include <linux/mtd/partitions.h> |
24 | #include <linux/i2c.h> | ||
23 | #include <linux/io.h> | 25 | #include <linux/io.h> |
24 | #include <asm/hardware/vic.h> | 26 | #include <asm/hardware/vic.h> |
25 | #include <asm/sizes.h> | 27 | #include <asm/sizes.h> |
@@ -185,16 +187,28 @@ static void __init nhk8815_onenand_init(void) | |||
185 | #endif | 187 | #endif |
186 | } | 188 | } |
187 | 189 | ||
188 | static AMBA_APB_DEVICE(uart0, "uart0", 0, NOMADIK_UART0_BASE, | 190 | static struct mmci_platform_data mmcsd_plat_data = { |
189 | { IRQ_UART0 }, NULL); | 191 | .ocr_mask = MMC_VDD_29_30, |
192 | .f_max = 48000000, | ||
193 | .gpio_wp = -1, | ||
194 | .gpio_cd = 111, | ||
195 | .cd_invert = true, | ||
196 | .capabilities = MMC_CAP_MMC_HIGHSPEED | | ||
197 | MMC_CAP_SD_HIGHSPEED | MMC_CAP_4_BIT_DATA, | ||
198 | }; | ||
190 | 199 | ||
191 | static AMBA_APB_DEVICE(uart1, "uart1", 0, NOMADIK_UART1_BASE, | 200 | static int __init nhk8815_mmcsd_init(void) |
192 | { IRQ_UART1 }, NULL); | 201 | { |
202 | int ret; | ||
193 | 203 | ||
194 | static struct amba_device *amba_devs[] __initdata = { | 204 | ret = gpio_request(112, "card detect bias"); |
195 | &uart0_device, | 205 | if (ret) |
196 | &uart1_device, | 206 | return ret; |
197 | }; | 207 | gpio_direction_output(112, 0); |
208 | amba_apb_device_add(NULL, "mmci", NOMADIK_SDI_BASE, SZ_4K, IRQ_SDMMC, 0, &mmcsd_plat_data, 0x10180180); | ||
209 | return 0; | ||
210 | } | ||
211 | module_init(nhk8815_mmcsd_init); | ||
198 | 212 | ||
199 | static struct resource nhk8815_eth_resources[] = { | 213 | static struct resource nhk8815_eth_resources[] = { |
200 | { | 214 | { |
@@ -253,17 +267,46 @@ static struct sys_timer nomadik_timer = { | |||
253 | .init = nomadik_timer_init, | 267 | .init = nomadik_timer_init, |
254 | }; | 268 | }; |
255 | 269 | ||
270 | static struct i2c_board_info __initdata nhk8815_i2c0_devices[] = { | ||
271 | { | ||
272 | I2C_BOARD_INFO("stw4811", 0x2d), | ||
273 | }, | ||
274 | }; | ||
275 | |||
276 | static struct i2c_board_info __initdata nhk8815_i2c1_devices[] = { | ||
277 | { | ||
278 | I2C_BOARD_INFO("camera", 0x10), | ||
279 | }, | ||
280 | { | ||
281 | I2C_BOARD_INFO("stw5095", 0x1a), | ||
282 | }, | ||
283 | { | ||
284 | I2C_BOARD_INFO("lis3lv02dl", 0x1d), | ||
285 | }, | ||
286 | }; | ||
287 | |||
288 | static struct i2c_board_info __initdata nhk8815_i2c2_devices[] = { | ||
289 | { | ||
290 | I2C_BOARD_INFO("stw4811-usb", 0x2d), | ||
291 | }, | ||
292 | }; | ||
293 | |||
256 | static void __init nhk8815_platform_init(void) | 294 | static void __init nhk8815_platform_init(void) |
257 | { | 295 | { |
258 | int i; | ||
259 | |||
260 | cpu8815_platform_init(); | 296 | cpu8815_platform_init(); |
261 | nhk8815_onenand_init(); | 297 | nhk8815_onenand_init(); |
262 | platform_add_devices(nhk8815_platform_devices, | 298 | platform_add_devices(nhk8815_platform_devices, |
263 | ARRAY_SIZE(nhk8815_platform_devices)); | 299 | ARRAY_SIZE(nhk8815_platform_devices)); |
264 | 300 | ||
265 | for (i = 0; i < ARRAY_SIZE(amba_devs); i++) | 301 | amba_apb_device_add(NULL, "uart0", NOMADIK_UART0_BASE, SZ_4K, IRQ_UART0, 0, NULL, 0); |
266 | amba_device_register(amba_devs[i], &iomem_resource); | 302 | amba_apb_device_add(NULL, "uart1", NOMADIK_UART1_BASE, SZ_4K, IRQ_UART1, 0, NULL, 0); |
303 | |||
304 | i2c_register_board_info(0, nhk8815_i2c0_devices, | ||
305 | ARRAY_SIZE(nhk8815_i2c0_devices)); | ||
306 | i2c_register_board_info(1, nhk8815_i2c1_devices, | ||
307 | ARRAY_SIZE(nhk8815_i2c1_devices)); | ||
308 | i2c_register_board_info(2, nhk8815_i2c2_devices, | ||
309 | ARRAY_SIZE(nhk8815_i2c2_devices)); | ||
267 | } | 310 | } |
268 | 311 | ||
269 | MACHINE_START(NOMADIK, "NHK8815") | 312 | MACHINE_START(NOMADIK, "NHK8815") |
diff --git a/arch/arm/mach-nomadik/clock.c b/arch/arm/mach-nomadik/clock.c deleted file mode 100644 index 48a59f24e10c..000000000000 --- a/arch/arm/mach-nomadik/clock.c +++ /dev/null | |||
@@ -1,75 +0,0 @@ | |||
1 | /* | ||
2 | * linux/arch/arm/mach-nomadik/clock.c | ||
3 | * | ||
4 | * Copyright (C) 2009 Alessandro Rubini | ||
5 | */ | ||
6 | #include <linux/kernel.h> | ||
7 | #include <linux/module.h> | ||
8 | #include <linux/errno.h> | ||
9 | #include <linux/clk.h> | ||
10 | #include <linux/clkdev.h> | ||
11 | #include "clock.h" | ||
12 | |||
13 | /* | ||
14 | * The nomadik board uses generic clocks, but the serial pl011 file | ||
15 | * calls clk_enable(), clk_disable(), clk_get_rate(), so we provide them | ||
16 | */ | ||
17 | unsigned long clk_get_rate(struct clk *clk) | ||
18 | { | ||
19 | return clk->rate; | ||
20 | } | ||
21 | EXPORT_SYMBOL(clk_get_rate); | ||
22 | |||
23 | /* enable and disable do nothing */ | ||
24 | int clk_enable(struct clk *clk) | ||
25 | { | ||
26 | return 0; | ||
27 | } | ||
28 | EXPORT_SYMBOL(clk_enable); | ||
29 | |||
30 | void clk_disable(struct clk *clk) | ||
31 | { | ||
32 | } | ||
33 | EXPORT_SYMBOL(clk_disable); | ||
34 | |||
35 | static struct clk clk_24 = { | ||
36 | .rate = 2400000, | ||
37 | }; | ||
38 | |||
39 | static struct clk clk_48 = { | ||
40 | .rate = 48 * 1000 * 1000, | ||
41 | }; | ||
42 | |||
43 | /* | ||
44 | * Catch-all default clock to satisfy drivers using the clk API. We don't | ||
45 | * model the actual hardware clocks yet. | ||
46 | */ | ||
47 | static struct clk clk_default; | ||
48 | |||
49 | #define CLK(_clk, dev) \ | ||
50 | { \ | ||
51 | .clk = _clk, \ | ||
52 | .dev_id = dev, \ | ||
53 | } | ||
54 | |||
55 | static struct clk_lookup lookups[] = { | ||
56 | { | ||
57 | .con_id = "apb_pclk", | ||
58 | .clk = &clk_default, | ||
59 | }, | ||
60 | CLK(&clk_24, "mtu0"), | ||
61 | CLK(&clk_24, "mtu1"), | ||
62 | CLK(&clk_48, "uart0"), | ||
63 | CLK(&clk_48, "uart1"), | ||
64 | CLK(&clk_default, "gpio.0"), | ||
65 | CLK(&clk_default, "gpio.1"), | ||
66 | CLK(&clk_default, "gpio.2"), | ||
67 | CLK(&clk_default, "gpio.3"), | ||
68 | CLK(&clk_default, "rng"), | ||
69 | }; | ||
70 | |||
71 | int __init clk_init(void) | ||
72 | { | ||
73 | clkdev_add_table(lookups, ARRAY_SIZE(lookups)); | ||
74 | return 0; | ||
75 | } | ||
diff --git a/arch/arm/mach-nomadik/clock.h b/arch/arm/mach-nomadik/clock.h deleted file mode 100644 index 78da2e7c3985..000000000000 --- a/arch/arm/mach-nomadik/clock.h +++ /dev/null | |||
@@ -1,15 +0,0 @@ | |||
1 | |||
2 | /* | ||
3 | * linux/arch/arm/mach-nomadik/clock.h | ||
4 | * | ||
5 | * Copyright (C) 2009 Alessandro Rubini | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License version 2 as | ||
9 | * published by the Free Software Foundation. | ||
10 | */ | ||
11 | struct clk { | ||
12 | unsigned long rate; | ||
13 | }; | ||
14 | |||
15 | int __init clk_init(void); | ||
diff --git a/arch/arm/mach-nomadik/cpu-8815.c b/arch/arm/mach-nomadik/cpu-8815.c index 27f43a46985e..6fd8e46567a4 100644 --- a/arch/arm/mach-nomadik/cpu-8815.c +++ b/arch/arm/mach-nomadik/cpu-8815.c | |||
@@ -22,6 +22,10 @@ | |||
22 | #include <linux/amba/bus.h> | 22 | #include <linux/amba/bus.h> |
23 | #include <linux/platform_device.h> | 23 | #include <linux/platform_device.h> |
24 | #include <linux/io.h> | 24 | #include <linux/io.h> |
25 | #include <linux/slab.h> | ||
26 | #include <linux/irq.h> | ||
27 | #include <linux/dma-mapping.h> | ||
28 | #include <linux/platform_data/clk-nomadik.h> | ||
25 | 29 | ||
26 | #include <plat/gpio-nomadik.h> | 30 | #include <plat/gpio-nomadik.h> |
27 | #include <mach/hardware.h> | 31 | #include <mach/hardware.h> |
@@ -32,91 +36,63 @@ | |||
32 | #include <asm/cacheflush.h> | 36 | #include <asm/cacheflush.h> |
33 | #include <asm/hardware/cache-l2x0.h> | 37 | #include <asm/hardware/cache-l2x0.h> |
34 | 38 | ||
35 | #include "clock.h" | ||
36 | #include "cpu-8815.h" | 39 | #include "cpu-8815.h" |
37 | 40 | ||
38 | #define __MEM_4K_RESOURCE(x) \ | ||
39 | .res = {.start = (x), .end = (x) + SZ_4K - 1, .flags = IORESOURCE_MEM} | ||
40 | |||
41 | /* The 8815 has 4 GPIO blocks, let's register them immediately */ | 41 | /* The 8815 has 4 GPIO blocks, let's register them immediately */ |
42 | 42 | static resource_size_t __initdata cpu8815_gpio_base[] = { | |
43 | #define GPIO_RESOURCE(block) \ | 43 | NOMADIK_GPIO0_BASE, |
44 | { \ | 44 | NOMADIK_GPIO1_BASE, |
45 | .start = NOMADIK_GPIO##block##_BASE, \ | 45 | NOMADIK_GPIO2_BASE, |
46 | .end = NOMADIK_GPIO##block##_BASE + SZ_4K - 1, \ | 46 | NOMADIK_GPIO3_BASE, |
47 | .flags = IORESOURCE_MEM, \ | ||
48 | }, \ | ||
49 | { \ | ||
50 | .start = IRQ_GPIO##block, \ | ||
51 | .end = IRQ_GPIO##block, \ | ||
52 | .flags = IORESOURCE_IRQ, \ | ||
53 | } | ||
54 | |||
55 | #define GPIO_DEVICE(block) \ | ||
56 | { \ | ||
57 | .name = "gpio", \ | ||
58 | .id = block, \ | ||
59 | .num_resources = 2, \ | ||
60 | .resource = &cpu8815_gpio_resources[block * 2], \ | ||
61 | .dev = { \ | ||
62 | .platform_data = &cpu8815_gpio[block], \ | ||
63 | }, \ | ||
64 | } | ||
65 | |||
66 | static struct nmk_gpio_platform_data cpu8815_gpio[] = { | ||
67 | { | ||
68 | .name = "GPIO-0-31", | ||
69 | .first_gpio = 0, | ||
70 | .first_irq = NOMADIK_GPIO_TO_IRQ(0), | ||
71 | }, { | ||
72 | .name = "GPIO-32-63", | ||
73 | .first_gpio = 32, | ||
74 | .first_irq = NOMADIK_GPIO_TO_IRQ(32), | ||
75 | }, { | ||
76 | .name = "GPIO-64-95", | ||
77 | .first_gpio = 64, | ||
78 | .first_irq = NOMADIK_GPIO_TO_IRQ(64), | ||
79 | }, { | ||
80 | .name = "GPIO-96-127", /* 124..127 not routed to pin */ | ||
81 | .first_gpio = 96, | ||
82 | .first_irq = NOMADIK_GPIO_TO_IRQ(96), | ||
83 | } | ||
84 | }; | 47 | }; |
85 | 48 | ||
86 | static struct resource cpu8815_gpio_resources[] = { | 49 | static struct platform_device * |
87 | GPIO_RESOURCE(0), | 50 | cpu8815_add_gpio(int id, resource_size_t addr, int irq, |
88 | GPIO_RESOURCE(1), | 51 | struct nmk_gpio_platform_data *pdata) |
89 | GPIO_RESOURCE(2), | 52 | { |
90 | GPIO_RESOURCE(3), | 53 | struct resource resources[] = { |
91 | }; | 54 | { |
92 | 55 | .start = addr, | |
93 | static struct platform_device cpu8815_platform_gpio[] = { | 56 | .end = addr + 127, |
94 | GPIO_DEVICE(0), | 57 | .flags = IORESOURCE_MEM, |
95 | GPIO_DEVICE(1), | 58 | }, |
96 | GPIO_DEVICE(2), | 59 | { |
97 | GPIO_DEVICE(3), | 60 | .start = irq, |
98 | }; | 61 | .end = irq, |
62 | .flags = IORESOURCE_IRQ, | ||
63 | } | ||
64 | }; | ||
65 | |||
66 | return platform_device_register_resndata(NULL, "gpio", id, | ||
67 | resources, ARRAY_SIZE(resources), | ||
68 | pdata, sizeof(*pdata)); | ||
69 | } | ||
99 | 70 | ||
100 | static AMBA_APB_DEVICE(cpu8815_amba_rng, "rng", 0, NOMADIK_RNG_BASE, { }, NULL); | 71 | void cpu8815_add_gpios(resource_size_t *base, int num, int irq, |
72 | struct nmk_gpio_platform_data *pdata) | ||
73 | { | ||
74 | int first = 0; | ||
75 | int i; | ||
101 | 76 | ||
102 | static struct platform_device *platform_devs[] __initdata = { | 77 | for (i = 0; i < num; i++, first += 32, irq++) { |
103 | cpu8815_platform_gpio + 0, | 78 | pdata->first_gpio = first; |
104 | cpu8815_platform_gpio + 1, | 79 | pdata->first_irq = NOMADIK_GPIO_TO_IRQ(first); |
105 | cpu8815_platform_gpio + 2, | 80 | pdata->num_gpio = 32; |
106 | cpu8815_platform_gpio + 3, | ||
107 | }; | ||
108 | 81 | ||
109 | static struct amba_device *amba_devs[] __initdata = { | 82 | cpu8815_add_gpio(i, base[i], irq, pdata); |
110 | &cpu8815_amba_rng_device | 83 | } |
111 | }; | 84 | } |
112 | 85 | ||
113 | static int __init cpu8815_init(void) | 86 | static int __init cpu8815_init(void) |
114 | { | 87 | { |
115 | int i; | 88 | struct nmk_gpio_platform_data pdata = { |
116 | 89 | /* No custom data yet */ | |
117 | platform_add_devices(platform_devs, ARRAY_SIZE(platform_devs)); | 90 | }; |
118 | for (i = 0; i < ARRAY_SIZE(amba_devs); i++) | 91 | |
119 | amba_device_register(amba_devs[i], &iomem_resource); | 92 | cpu8815_add_gpios(cpu8815_gpio_base, ARRAY_SIZE(cpu8815_gpio_base), |
93 | IRQ_GPIO0, &pdata); | ||
94 | amba_apb_device_add(NULL, "rng", NOMADIK_RNG_BASE, SZ_4K, 0, 0, NULL, 0); | ||
95 | amba_apb_device_add(NULL, "rtc-pl031", NOMADIK_RTC_BASE, SZ_4K, IRQ_RTC_RTT, 0, NULL, 0); | ||
120 | return 0; | 96 | return 0; |
121 | } | 97 | } |
122 | arch_initcall(cpu8815_init); | 98 | arch_initcall(cpu8815_init); |
@@ -147,7 +123,7 @@ void __init cpu8815_init_irq(void) | |||
147 | * Init clocks here so that they are available for system timer | 123 | * Init clocks here so that they are available for system timer |
148 | * initialization. | 124 | * initialization. |
149 | */ | 125 | */ |
150 | clk_init(); | 126 | nomadik_clk_init(); |
151 | } | 127 | } |
152 | 128 | ||
153 | /* | 129 | /* |
diff --git a/arch/arm/mach-nomadik/i2c-8815nhk.c b/arch/arm/mach-nomadik/i2c-8815nhk.c index 0fc2f6f1cc97..6d14454d4609 100644 --- a/arch/arm/mach-nomadik/i2c-8815nhk.c +++ b/arch/arm/mach-nomadik/i2c-8815nhk.c | |||
@@ -5,6 +5,7 @@ | |||
5 | #include <linux/i2c-gpio.h> | 5 | #include <linux/i2c-gpio.h> |
6 | #include <linux/platform_device.h> | 6 | #include <linux/platform_device.h> |
7 | #include <plat/gpio-nomadik.h> | 7 | #include <plat/gpio-nomadik.h> |
8 | #include <plat/pincfg.h> | ||
8 | 9 | ||
9 | /* | 10 | /* |
10 | * There are two busses in the 8815NHK. | 11 | * There are two busses in the 8815NHK. |
@@ -12,19 +13,27 @@ | |||
12 | * use bit-bang through GPIO by now, to keep things simple | 13 | * use bit-bang through GPIO by now, to keep things simple |
13 | */ | 14 | */ |
14 | 15 | ||
16 | /* I2C0 connected to the STw4811 power management chip */ | ||
15 | static struct i2c_gpio_platform_data nhk8815_i2c_data0 = { | 17 | static struct i2c_gpio_platform_data nhk8815_i2c_data0 = { |
16 | /* keep defaults for timeouts; pins are push-pull bidirectional */ | 18 | /* keep defaults for timeouts; pins are push-pull bidirectional */ |
17 | .scl_pin = 62, | 19 | .scl_pin = 62, |
18 | .sda_pin = 63, | 20 | .sda_pin = 63, |
19 | }; | 21 | }; |
20 | 22 | ||
23 | /* I2C1 connected to various sensors */ | ||
21 | static struct i2c_gpio_platform_data nhk8815_i2c_data1 = { | 24 | static struct i2c_gpio_platform_data nhk8815_i2c_data1 = { |
22 | /* keep defaults for timeouts; pins are push-pull bidirectional */ | 25 | /* keep defaults for timeouts; pins are push-pull bidirectional */ |
23 | .scl_pin = 53, | 26 | .scl_pin = 53, |
24 | .sda_pin = 54, | 27 | .sda_pin = 54, |
25 | }; | 28 | }; |
26 | 29 | ||
27 | /* first bus: GPIO XX and YY */ | 30 | /* I2C2 connected to the USB portions of the STw4811 only */ |
31 | static struct i2c_gpio_platform_data nhk8815_i2c_data2 = { | ||
32 | /* keep defaults for timeouts; pins are push-pull bidirectional */ | ||
33 | .scl_pin = 73, | ||
34 | .sda_pin = 74, | ||
35 | }; | ||
36 | |||
28 | static struct platform_device nhk8815_i2c_dev0 = { | 37 | static struct platform_device nhk8815_i2c_dev0 = { |
29 | .name = "i2c-gpio", | 38 | .name = "i2c-gpio", |
30 | .id = 0, | 39 | .id = 0, |
@@ -32,7 +41,7 @@ static struct platform_device nhk8815_i2c_dev0 = { | |||
32 | .platform_data = &nhk8815_i2c_data0, | 41 | .platform_data = &nhk8815_i2c_data0, |
33 | }, | 42 | }, |
34 | }; | 43 | }; |
35 | /* second bus: GPIO XX and YY */ | 44 | |
36 | static struct platform_device nhk8815_i2c_dev1 = { | 45 | static struct platform_device nhk8815_i2c_dev1 = { |
37 | .name = "i2c-gpio", | 46 | .name = "i2c-gpio", |
38 | .id = 1, | 47 | .id = 1, |
@@ -41,15 +50,29 @@ static struct platform_device nhk8815_i2c_dev1 = { | |||
41 | }, | 50 | }, |
42 | }; | 51 | }; |
43 | 52 | ||
53 | static struct platform_device nhk8815_i2c_dev2 = { | ||
54 | .name = "i2c-gpio", | ||
55 | .id = 2, | ||
56 | .dev = { | ||
57 | .platform_data = &nhk8815_i2c_data2, | ||
58 | }, | ||
59 | }; | ||
60 | |||
61 | static pin_cfg_t cpu8815_pins_i2c[] = { | ||
62 | PIN_CFG_INPUT(62, GPIO, PULLUP), | ||
63 | PIN_CFG_INPUT(63, GPIO, PULLUP), | ||
64 | PIN_CFG_INPUT(53, GPIO, PULLUP), | ||
65 | PIN_CFG_INPUT(54, GPIO, PULLUP), | ||
66 | PIN_CFG_INPUT(73, GPIO, PULLUP), | ||
67 | PIN_CFG_INPUT(74, GPIO, PULLUP), | ||
68 | }; | ||
69 | |||
44 | static int __init nhk8815_i2c_init(void) | 70 | static int __init nhk8815_i2c_init(void) |
45 | { | 71 | { |
46 | nmk_gpio_set_mode(nhk8815_i2c_data0.scl_pin, NMK_GPIO_ALT_GPIO); | 72 | nmk_config_pins(cpu8815_pins_i2c, ARRAY_SIZE(cpu8815_pins_i2c)); |
47 | nmk_gpio_set_mode(nhk8815_i2c_data0.sda_pin, NMK_GPIO_ALT_GPIO); | ||
48 | platform_device_register(&nhk8815_i2c_dev0); | 73 | platform_device_register(&nhk8815_i2c_dev0); |
49 | |||
50 | nmk_gpio_set_mode(nhk8815_i2c_data1.scl_pin, NMK_GPIO_ALT_GPIO); | ||
51 | nmk_gpio_set_mode(nhk8815_i2c_data1.sda_pin, NMK_GPIO_ALT_GPIO); | ||
52 | platform_device_register(&nhk8815_i2c_dev1); | 74 | platform_device_register(&nhk8815_i2c_dev1); |
75 | platform_device_register(&nhk8815_i2c_dev2); | ||
53 | 76 | ||
54 | return 0; | 77 | return 0; |
55 | } | 78 | } |
@@ -58,6 +81,7 @@ static void __exit nhk8815_i2c_exit(void) | |||
58 | { | 81 | { |
59 | platform_device_unregister(&nhk8815_i2c_dev0); | 82 | platform_device_unregister(&nhk8815_i2c_dev0); |
60 | platform_device_unregister(&nhk8815_i2c_dev1); | 83 | platform_device_unregister(&nhk8815_i2c_dev1); |
84 | platform_device_unregister(&nhk8815_i2c_dev2); | ||
61 | return; | 85 | return; |
62 | } | 86 | } |
63 | 87 | ||
diff --git a/arch/arm/mach-nomadik/include/mach/irqs.h b/arch/arm/mach-nomadik/include/mach/irqs.h index 8faabc560398..a118e615f865 100644 --- a/arch/arm/mach-nomadik/include/mach/irqs.h +++ b/arch/arm/mach-nomadik/include/mach/irqs.h | |||
@@ -22,56 +22,56 @@ | |||
22 | 22 | ||
23 | #include <mach/hardware.h> | 23 | #include <mach/hardware.h> |
24 | 24 | ||
25 | #define IRQ_VIC_START 0 /* first VIC interrupt is 0 */ | 25 | #define IRQ_VIC_START 1 /* first VIC interrupt is 1 */ |
26 | 26 | ||
27 | /* | 27 | /* |
28 | * Interrupt numbers generic for all Nomadik Chip cuts | 28 | * Interrupt numbers generic for all Nomadik Chip cuts |
29 | */ | 29 | */ |
30 | #define IRQ_WATCHDOG 0 | 30 | #define IRQ_WATCHDOG 1 |
31 | #define IRQ_SOFTINT 1 | 31 | #define IRQ_SOFTINT 2 |
32 | #define IRQ_CRYPTO 2 | 32 | #define IRQ_CRYPTO 3 |
33 | #define IRQ_OWM 3 | 33 | #define IRQ_OWM 4 |
34 | #define IRQ_MTU0 4 | 34 | #define IRQ_MTU0 5 |
35 | #define IRQ_MTU1 5 | 35 | #define IRQ_MTU1 6 |
36 | #define IRQ_GPIO0 6 | 36 | #define IRQ_GPIO0 7 |
37 | #define IRQ_GPIO1 7 | 37 | #define IRQ_GPIO1 8 |
38 | #define IRQ_GPIO2 8 | 38 | #define IRQ_GPIO2 9 |
39 | #define IRQ_GPIO3 9 | 39 | #define IRQ_GPIO3 10 |
40 | #define IRQ_RTC_RTT 10 | 40 | #define IRQ_RTC_RTT 11 |
41 | #define IRQ_SSP 11 | 41 | #define IRQ_SSP 12 |
42 | #define IRQ_UART0 12 | 42 | #define IRQ_UART0 13 |
43 | #define IRQ_DMA1 13 | 43 | #define IRQ_DMA1 14 |
44 | #define IRQ_CLCD_MDIF 14 | 44 | #define IRQ_CLCD_MDIF 15 |
45 | #define IRQ_DMA0 15 | 45 | #define IRQ_DMA0 16 |
46 | #define IRQ_PWRFAIL 16 | 46 | #define IRQ_PWRFAIL 17 |
47 | #define IRQ_UART1 17 | 47 | #define IRQ_UART1 18 |
48 | #define IRQ_FIRDA 18 | 48 | #define IRQ_FIRDA 19 |
49 | #define IRQ_MSP0 19 | 49 | #define IRQ_MSP0 20 |
50 | #define IRQ_I2C0 20 | 50 | #define IRQ_I2C0 21 |
51 | #define IRQ_I2C1 21 | 51 | #define IRQ_I2C1 22 |
52 | #define IRQ_SDMMC 22 | 52 | #define IRQ_SDMMC 23 |
53 | #define IRQ_USBOTG 23 | 53 | #define IRQ_USBOTG 24 |
54 | #define IRQ_SVA_IT0 24 | 54 | #define IRQ_SVA_IT0 25 |
55 | #define IRQ_SVA_IT1 25 | 55 | #define IRQ_SVA_IT1 26 |
56 | #define IRQ_SAA_IT0 26 | 56 | #define IRQ_SAA_IT0 27 |
57 | #define IRQ_SAA_IT1 27 | 57 | #define IRQ_SAA_IT1 28 |
58 | #define IRQ_UART2 28 | 58 | #define IRQ_UART2 29 |
59 | #define IRQ_MSP2 31 | 59 | #define IRQ_MSP2 30 |
60 | #define IRQ_L2CC 48 | 60 | #define IRQ_L2CC 49 |
61 | #define IRQ_HPI 49 | 61 | #define IRQ_HPI 50 |
62 | #define IRQ_SKE 50 | 62 | #define IRQ_SKE 51 |
63 | #define IRQ_KP 51 | 63 | #define IRQ_KP 52 |
64 | #define IRQ_MEMST 54 | 64 | #define IRQ_MEMST 55 |
65 | #define IRQ_SGA_IT 58 | 65 | #define IRQ_SGA_IT 59 |
66 | #define IRQ_USBM 60 | 66 | #define IRQ_USBM 61 |
67 | #define IRQ_MSP1 62 | 67 | #define IRQ_MSP1 63 |
68 | 68 | ||
69 | #define NOMADIK_SOC_NR_IRQS 64 | 69 | #define NOMADIK_GPIO_OFFSET (IRQ_VIC_START+64) |
70 | 70 | ||
71 | /* After chip-specific IRQ numbers we have the GPIO ones */ | 71 | /* After chip-specific IRQ numbers we have the GPIO ones */ |
72 | #define NOMADIK_NR_GPIO 128 /* last 4 not wired to pins */ | 72 | #define NOMADIK_NR_GPIO 128 /* last 4 not wired to pins */ |
73 | #define NOMADIK_GPIO_TO_IRQ(gpio) ((gpio) + NOMADIK_SOC_NR_IRQS) | 73 | #define NOMADIK_GPIO_TO_IRQ(gpio) ((gpio) + NOMADIK_GPIO_OFFSET) |
74 | #define NOMADIK_IRQ_TO_GPIO(irq) ((irq) - NOMADIK_SOC_NR_IRQS) | 74 | #define NOMADIK_IRQ_TO_GPIO(irq) ((irq) - NOMADIK_GPIO_OFFSET) |
75 | #define NR_IRQS NOMADIK_GPIO_TO_IRQ(NOMADIK_NR_GPIO) | 75 | #define NR_IRQS NOMADIK_GPIO_TO_IRQ(NOMADIK_NR_GPIO) |
76 | 76 | ||
77 | /* Following two are used by entry_macro.S, to access our dual-vic */ | 77 | /* Following two are used by entry_macro.S, to access our dual-vic */ |
@@ -79,4 +79,3 @@ | |||
79 | #define VIC_REG_IRQSR1 0x20 | 79 | #define VIC_REG_IRQSR1 0x20 |
80 | 80 | ||
81 | #endif /* __ASM_ARCH_IRQS_H */ | 81 | #endif /* __ASM_ARCH_IRQS_H */ |
82 | |||
diff --git a/arch/arm/mach-omap2/Makefile b/arch/arm/mach-omap2/Makefile index 8e8ef8200bf0..821794fd03d6 100644 --- a/arch/arm/mach-omap2/Makefile +++ b/arch/arm/mach-omap2/Makefile | |||
@@ -93,6 +93,7 @@ obj-$(CONFIG_ARCH_OMAP3) += vc3xxx_data.o vp3xxx_data.o | |||
93 | obj-$(CONFIG_ARCH_OMAP4) += prcm.o cminst44xx.o cm44xx.o | 93 | obj-$(CONFIG_ARCH_OMAP4) += prcm.o cminst44xx.o cm44xx.o |
94 | obj-$(CONFIG_ARCH_OMAP4) += prcm_mpu44xx.o prminst44xx.o | 94 | obj-$(CONFIG_ARCH_OMAP4) += prcm_mpu44xx.o prminst44xx.o |
95 | obj-$(CONFIG_ARCH_OMAP4) += vc44xx_data.o vp44xx_data.o prm44xx.o | 95 | obj-$(CONFIG_ARCH_OMAP4) += vc44xx_data.o vp44xx_data.o prm44xx.o |
96 | obj-$(CONFIG_SOC_AM33XX) += prcm.o prm33xx.o cm33xx.o | ||
96 | 97 | ||
97 | # OMAP voltage domains | 98 | # OMAP voltage domains |
98 | voltagedomain-common := voltage.o vc.o vp.o | 99 | voltagedomain-common := voltage.o vc.o vp.o |
@@ -102,6 +103,7 @@ obj-$(CONFIG_ARCH_OMAP3) += $(voltagedomain-common) | |||
102 | obj-$(CONFIG_ARCH_OMAP3) += voltagedomains3xxx_data.o | 103 | obj-$(CONFIG_ARCH_OMAP3) += voltagedomains3xxx_data.o |
103 | obj-$(CONFIG_ARCH_OMAP4) += $(voltagedomain-common) | 104 | obj-$(CONFIG_ARCH_OMAP4) += $(voltagedomain-common) |
104 | obj-$(CONFIG_ARCH_OMAP4) += voltagedomains44xx_data.o | 105 | obj-$(CONFIG_ARCH_OMAP4) += voltagedomains44xx_data.o |
106 | obj-$(CONFIG_SOC_AM33XX) += voltagedomains33xx_data.o | ||
105 | 107 | ||
106 | # OMAP powerdomain framework | 108 | # OMAP powerdomain framework |
107 | powerdomain-common += powerdomain.o powerdomain-common.o | 109 | powerdomain-common += powerdomain.o powerdomain-common.o |
@@ -116,6 +118,8 @@ obj-$(CONFIG_ARCH_OMAP3) += powerdomains2xxx_3xxx_data.o | |||
116 | obj-$(CONFIG_ARCH_OMAP4) += $(powerdomain-common) | 118 | obj-$(CONFIG_ARCH_OMAP4) += $(powerdomain-common) |
117 | obj-$(CONFIG_ARCH_OMAP4) += powerdomain44xx.o | 119 | obj-$(CONFIG_ARCH_OMAP4) += powerdomain44xx.o |
118 | obj-$(CONFIG_ARCH_OMAP4) += powerdomains44xx_data.o | 120 | obj-$(CONFIG_ARCH_OMAP4) += powerdomains44xx_data.o |
121 | obj-$(CONFIG_SOC_AM33XX) += powerdomain33xx.o | ||
122 | obj-$(CONFIG_SOC_AM33XX) += powerdomains33xx_data.o | ||
119 | 123 | ||
120 | # PRCM clockdomain control | 124 | # PRCM clockdomain control |
121 | clockdomain-common += clockdomain.o | 125 | clockdomain-common += clockdomain.o |
@@ -131,6 +135,8 @@ obj-$(CONFIG_ARCH_OMAP3) += clockdomains3xxx_data.o | |||
131 | obj-$(CONFIG_ARCH_OMAP4) += $(clockdomain-common) | 135 | obj-$(CONFIG_ARCH_OMAP4) += $(clockdomain-common) |
132 | obj-$(CONFIG_ARCH_OMAP4) += clockdomain44xx.o | 136 | obj-$(CONFIG_ARCH_OMAP4) += clockdomain44xx.o |
133 | obj-$(CONFIG_ARCH_OMAP4) += clockdomains44xx_data.o | 137 | obj-$(CONFIG_ARCH_OMAP4) += clockdomains44xx_data.o |
138 | obj-$(CONFIG_SOC_AM33XX) += clockdomain33xx.o | ||
139 | obj-$(CONFIG_SOC_AM33XX) += clockdomains33xx_data.o | ||
134 | 140 | ||
135 | # Clock framework | 141 | # Clock framework |
136 | obj-$(CONFIG_ARCH_OMAP2) += $(clock-common) clock2xxx.o | 142 | obj-$(CONFIG_ARCH_OMAP2) += $(clock-common) clock2xxx.o |
diff --git a/arch/arm/mach-omap2/board-generic.c b/arch/arm/mach-omap2/board-generic.c index 202934657867..2f2abfb82d84 100644 --- a/arch/arm/mach-omap2/board-generic.c +++ b/arch/arm/mach-omap2/board-generic.c | |||
@@ -112,6 +112,24 @@ DT_MACHINE_START(OMAP3_DT, "Generic OMAP3 (Flattened Device Tree)") | |||
112 | MACHINE_END | 112 | MACHINE_END |
113 | #endif | 113 | #endif |
114 | 114 | ||
115 | #ifdef CONFIG_SOC_AM33XX | ||
116 | static const char *am33xx_boards_compat[] __initdata = { | ||
117 | "ti,am33xx", | ||
118 | NULL, | ||
119 | }; | ||
120 | |||
121 | DT_MACHINE_START(AM33XX_DT, "Generic AM33XX (Flattened Device Tree)") | ||
122 | .reserve = omap_reserve, | ||
123 | .map_io = am33xx_map_io, | ||
124 | .init_early = am33xx_init_early, | ||
125 | .init_irq = omap_init_irq, | ||
126 | .handle_irq = omap3_intc_handle_irq, | ||
127 | .init_machine = omap_generic_init, | ||
128 | .timer = &omap3_am33xx_timer, | ||
129 | .dt_compat = am33xx_boards_compat, | ||
130 | MACHINE_END | ||
131 | #endif | ||
132 | |||
115 | #ifdef CONFIG_ARCH_OMAP4 | 133 | #ifdef CONFIG_ARCH_OMAP4 |
116 | static const char *omap4_boards_compat[] __initdata = { | 134 | static const char *omap4_boards_compat[] __initdata = { |
117 | "ti,omap4", | 135 | "ti,omap4", |
diff --git a/arch/arm/mach-omap2/clockdomain.h b/arch/arm/mach-omap2/clockdomain.h index c9523c6164b0..5601dc13785e 100644 --- a/arch/arm/mach-omap2/clockdomain.h +++ b/arch/arm/mach-omap2/clockdomain.h | |||
@@ -199,6 +199,7 @@ int clkdm_hwmod_disable(struct clockdomain *clkdm, struct omap_hwmod *oh); | |||
199 | extern void __init omap242x_clockdomains_init(void); | 199 | extern void __init omap242x_clockdomains_init(void); |
200 | extern void __init omap243x_clockdomains_init(void); | 200 | extern void __init omap243x_clockdomains_init(void); |
201 | extern void __init omap3xxx_clockdomains_init(void); | 201 | extern void __init omap3xxx_clockdomains_init(void); |
202 | extern void __init am33xx_clockdomains_init(void); | ||
202 | extern void __init omap44xx_clockdomains_init(void); | 203 | extern void __init omap44xx_clockdomains_init(void); |
203 | extern void _clkdm_add_autodeps(struct clockdomain *clkdm); | 204 | extern void _clkdm_add_autodeps(struct clockdomain *clkdm); |
204 | extern void _clkdm_del_autodeps(struct clockdomain *clkdm); | 205 | extern void _clkdm_del_autodeps(struct clockdomain *clkdm); |
@@ -206,6 +207,7 @@ extern void _clkdm_del_autodeps(struct clockdomain *clkdm); | |||
206 | extern struct clkdm_ops omap2_clkdm_operations; | 207 | extern struct clkdm_ops omap2_clkdm_operations; |
207 | extern struct clkdm_ops omap3_clkdm_operations; | 208 | extern struct clkdm_ops omap3_clkdm_operations; |
208 | extern struct clkdm_ops omap4_clkdm_operations; | 209 | extern struct clkdm_ops omap4_clkdm_operations; |
210 | extern struct clkdm_ops am33xx_clkdm_operations; | ||
209 | 211 | ||
210 | extern struct clkdm_dep gfx_24xx_wkdeps[]; | 212 | extern struct clkdm_dep gfx_24xx_wkdeps[]; |
211 | extern struct clkdm_dep dsp_24xx_wkdeps[]; | 213 | extern struct clkdm_dep dsp_24xx_wkdeps[]; |
diff --git a/arch/arm/mach-omap2/clockdomain33xx.c b/arch/arm/mach-omap2/clockdomain33xx.c new file mode 100644 index 000000000000..aca6388fad76 --- /dev/null +++ b/arch/arm/mach-omap2/clockdomain33xx.c | |||
@@ -0,0 +1,74 @@ | |||
1 | /* | ||
2 | * AM33XX clockdomain control | ||
3 | * | ||
4 | * Copyright (C) 2011-2012 Texas Instruments Incorporated - http://www.ti.com/ | ||
5 | * Vaibhav Hiremath <hvaibhav@ti.com> | ||
6 | * | ||
7 | * Derived from mach-omap2/clockdomain44xx.c written by Rajendra Nayak | ||
8 | * | ||
9 | * This program is free software; you can redistribute it and/or | ||
10 | * modify it under the terms of the GNU General Public License as | ||
11 | * published by the Free Software Foundation version 2. | ||
12 | * | ||
13 | * This program is distributed "as is" WITHOUT ANY WARRANTY of any | ||
14 | * kind, whether express or implied; without even the implied warranty | ||
15 | * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
16 | * GNU General Public License for more details. | ||
17 | */ | ||
18 | |||
19 | #include <linux/kernel.h> | ||
20 | |||
21 | #include "clockdomain.h" | ||
22 | #include "cm33xx.h" | ||
23 | |||
24 | |||
25 | static int am33xx_clkdm_sleep(struct clockdomain *clkdm) | ||
26 | { | ||
27 | am33xx_cm_clkdm_force_sleep(clkdm->cm_inst, clkdm->clkdm_offs); | ||
28 | return 0; | ||
29 | } | ||
30 | |||
31 | static int am33xx_clkdm_wakeup(struct clockdomain *clkdm) | ||
32 | { | ||
33 | am33xx_cm_clkdm_force_wakeup(clkdm->cm_inst, clkdm->clkdm_offs); | ||
34 | return 0; | ||
35 | } | ||
36 | |||
37 | static void am33xx_clkdm_allow_idle(struct clockdomain *clkdm) | ||
38 | { | ||
39 | am33xx_cm_clkdm_enable_hwsup(clkdm->cm_inst, clkdm->clkdm_offs); | ||
40 | } | ||
41 | |||
42 | static void am33xx_clkdm_deny_idle(struct clockdomain *clkdm) | ||
43 | { | ||
44 | am33xx_cm_clkdm_disable_hwsup(clkdm->cm_inst, clkdm->clkdm_offs); | ||
45 | } | ||
46 | |||
47 | static int am33xx_clkdm_clk_enable(struct clockdomain *clkdm) | ||
48 | { | ||
49 | if (clkdm->flags & CLKDM_CAN_FORCE_WAKEUP) | ||
50 | return am33xx_clkdm_wakeup(clkdm); | ||
51 | |||
52 | return 0; | ||
53 | } | ||
54 | |||
55 | static int am33xx_clkdm_clk_disable(struct clockdomain *clkdm) | ||
56 | { | ||
57 | bool hwsup = false; | ||
58 | |||
59 | hwsup = am33xx_cm_is_clkdm_in_hwsup(clkdm->cm_inst, clkdm->clkdm_offs); | ||
60 | |||
61 | if (!hwsup && (clkdm->flags & CLKDM_CAN_FORCE_SLEEP)) | ||
62 | am33xx_clkdm_sleep(clkdm); | ||
63 | |||
64 | return 0; | ||
65 | } | ||
66 | |||
67 | struct clkdm_ops am33xx_clkdm_operations = { | ||
68 | .clkdm_sleep = am33xx_clkdm_sleep, | ||
69 | .clkdm_wakeup = am33xx_clkdm_wakeup, | ||
70 | .clkdm_allow_idle = am33xx_clkdm_allow_idle, | ||
71 | .clkdm_deny_idle = am33xx_clkdm_deny_idle, | ||
72 | .clkdm_clk_enable = am33xx_clkdm_clk_enable, | ||
73 | .clkdm_clk_disable = am33xx_clkdm_clk_disable, | ||
74 | }; | ||
diff --git a/arch/arm/mach-omap2/clockdomains33xx_data.c b/arch/arm/mach-omap2/clockdomains33xx_data.c new file mode 100644 index 000000000000..32c90fd9eba2 --- /dev/null +++ b/arch/arm/mach-omap2/clockdomains33xx_data.c | |||
@@ -0,0 +1,196 @@ | |||
1 | /* | ||
2 | * AM33XX Clock Domain data. | ||
3 | * | ||
4 | * Copyright (C) 2011-2012 Texas Instruments Incorporated - http://www.ti.com/ | ||
5 | * Vaibhav Hiremath <hvaibhav@ti.com> | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or | ||
8 | * modify it under the terms of the GNU General Public License as | ||
9 | * published by the Free Software Foundation version 2. | ||
10 | * | ||
11 | * This program is distributed "as is" WITHOUT ANY WARRANTY of any | ||
12 | * kind, whether express or implied; without even the implied warranty | ||
13 | * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
14 | * GNU General Public License for more details. | ||
15 | */ | ||
16 | |||
17 | #include <linux/kernel.h> | ||
18 | #include <linux/io.h> | ||
19 | |||
20 | #include "clockdomain.h" | ||
21 | #include "cm.h" | ||
22 | #include "cm33xx.h" | ||
23 | #include "cm-regbits-33xx.h" | ||
24 | |||
25 | static struct clockdomain l4ls_am33xx_clkdm = { | ||
26 | .name = "l4ls_clkdm", | ||
27 | .pwrdm = { .name = "per_pwrdm" }, | ||
28 | .cm_inst = AM33XX_CM_PER_MOD, | ||
29 | .clkdm_offs = AM33XX_CM_PER_L4LS_CLKSTCTRL_OFFSET, | ||
30 | .flags = CLKDM_CAN_SWSUP, | ||
31 | }; | ||
32 | |||
33 | static struct clockdomain l3s_am33xx_clkdm = { | ||
34 | .name = "l3s_clkdm", | ||
35 | .pwrdm = { .name = "per_pwrdm" }, | ||
36 | .cm_inst = AM33XX_CM_PER_MOD, | ||
37 | .clkdm_offs = AM33XX_CM_PER_L3S_CLKSTCTRL_OFFSET, | ||
38 | .flags = CLKDM_CAN_SWSUP, | ||
39 | }; | ||
40 | |||
41 | static struct clockdomain l4fw_am33xx_clkdm = { | ||
42 | .name = "l4fw_clkdm", | ||
43 | .pwrdm = { .name = "per_pwrdm" }, | ||
44 | .cm_inst = AM33XX_CM_PER_MOD, | ||
45 | .clkdm_offs = AM33XX_CM_PER_L4FW_CLKSTCTRL_OFFSET, | ||
46 | .flags = CLKDM_CAN_SWSUP, | ||
47 | }; | ||
48 | |||
49 | static struct clockdomain l3_am33xx_clkdm = { | ||
50 | .name = "l3_clkdm", | ||
51 | .pwrdm = { .name = "per_pwrdm" }, | ||
52 | .cm_inst = AM33XX_CM_PER_MOD, | ||
53 | .clkdm_offs = AM33XX_CM_PER_L3_CLKSTCTRL_OFFSET, | ||
54 | .flags = CLKDM_CAN_SWSUP, | ||
55 | }; | ||
56 | |||
57 | static struct clockdomain l4hs_am33xx_clkdm = { | ||
58 | .name = "l4hs_clkdm", | ||
59 | .pwrdm = { .name = "per_pwrdm" }, | ||
60 | .cm_inst = AM33XX_CM_PER_MOD, | ||
61 | .clkdm_offs = AM33XX_CM_PER_L4HS_CLKSTCTRL_OFFSET, | ||
62 | .flags = CLKDM_CAN_SWSUP, | ||
63 | }; | ||
64 | |||
65 | static struct clockdomain ocpwp_l3_am33xx_clkdm = { | ||
66 | .name = "ocpwp_l3_clkdm", | ||
67 | .pwrdm = { .name = "per_pwrdm" }, | ||
68 | .cm_inst = AM33XX_CM_PER_MOD, | ||
69 | .clkdm_offs = AM33XX_CM_PER_OCPWP_L3_CLKSTCTRL_OFFSET, | ||
70 | .flags = CLKDM_CAN_SWSUP, | ||
71 | }; | ||
72 | |||
73 | static struct clockdomain pruss_ocp_am33xx_clkdm = { | ||
74 | .name = "pruss_ocp_clkdm", | ||
75 | .pwrdm = { .name = "per_pwrdm" }, | ||
76 | .cm_inst = AM33XX_CM_PER_MOD, | ||
77 | .clkdm_offs = AM33XX_CM_PER_PRUSS_CLKSTCTRL_OFFSET, | ||
78 | .flags = CLKDM_CAN_SWSUP, | ||
79 | }; | ||
80 | |||
81 | static struct clockdomain cpsw_125mhz_am33xx_clkdm = { | ||
82 | .name = "cpsw_125mhz_clkdm", | ||
83 | .pwrdm = { .name = "per_pwrdm" }, | ||
84 | .cm_inst = AM33XX_CM_PER_MOD, | ||
85 | .clkdm_offs = AM33XX_CM_PER_CPSW_CLKSTCTRL_OFFSET, | ||
86 | .flags = CLKDM_CAN_SWSUP, | ||
87 | }; | ||
88 | |||
89 | static struct clockdomain lcdc_am33xx_clkdm = { | ||
90 | .name = "lcdc_clkdm", | ||
91 | .pwrdm = { .name = "per_pwrdm" }, | ||
92 | .cm_inst = AM33XX_CM_PER_MOD, | ||
93 | .clkdm_offs = AM33XX_CM_PER_LCDC_CLKSTCTRL_OFFSET, | ||
94 | .flags = CLKDM_CAN_SWSUP, | ||
95 | }; | ||
96 | |||
97 | static struct clockdomain clk_24mhz_am33xx_clkdm = { | ||
98 | .name = "clk_24mhz_clkdm", | ||
99 | .pwrdm = { .name = "per_pwrdm" }, | ||
100 | .cm_inst = AM33XX_CM_PER_MOD, | ||
101 | .clkdm_offs = AM33XX_CM_PER_CLK_24MHZ_CLKSTCTRL_OFFSET, | ||
102 | .flags = CLKDM_CAN_SWSUP, | ||
103 | }; | ||
104 | |||
105 | static struct clockdomain l4_wkup_am33xx_clkdm = { | ||
106 | .name = "l4_wkup_clkdm", | ||
107 | .pwrdm = { .name = "wkup_pwrdm" }, | ||
108 | .cm_inst = AM33XX_CM_WKUP_MOD, | ||
109 | .clkdm_offs = AM33XX_CM_WKUP_CLKSTCTRL_OFFSET, | ||
110 | .flags = CLKDM_CAN_SWSUP, | ||
111 | }; | ||
112 | |||
113 | static struct clockdomain l3_aon_am33xx_clkdm = { | ||
114 | .name = "l3_aon_clkdm", | ||
115 | .pwrdm = { .name = "wkup_pwrdm" }, | ||
116 | .cm_inst = AM33XX_CM_WKUP_MOD, | ||
117 | .clkdm_offs = AM33XX_CM_L3_AON_CLKSTCTRL_OFFSET, | ||
118 | .flags = CLKDM_CAN_SWSUP, | ||
119 | }; | ||
120 | |||
121 | static struct clockdomain l4_wkup_aon_am33xx_clkdm = { | ||
122 | .name = "l4_wkup_aon_clkdm", | ||
123 | .pwrdm = { .name = "wkup_pwrdm" }, | ||
124 | .cm_inst = AM33XX_CM_WKUP_MOD, | ||
125 | .clkdm_offs = AM33XX_CM_L4_WKUP_AON_CLKSTCTRL_OFFSET, | ||
126 | .flags = CLKDM_CAN_SWSUP, | ||
127 | }; | ||
128 | |||
129 | static struct clockdomain mpu_am33xx_clkdm = { | ||
130 | .name = "mpu_clkdm", | ||
131 | .pwrdm = { .name = "mpu_pwrdm" }, | ||
132 | .cm_inst = AM33XX_CM_MPU_MOD, | ||
133 | .clkdm_offs = AM33XX_CM_MPU_CLKSTCTRL_OFFSET, | ||
134 | .flags = CLKDM_CAN_SWSUP, | ||
135 | }; | ||
136 | |||
137 | static struct clockdomain l4_rtc_am33xx_clkdm = { | ||
138 | .name = "l4_rtc_clkdm", | ||
139 | .pwrdm = { .name = "rtc_pwrdm" }, | ||
140 | .cm_inst = AM33XX_CM_RTC_MOD, | ||
141 | .clkdm_offs = AM33XX_CM_RTC_CLKSTCTRL_OFFSET, | ||
142 | .flags = CLKDM_CAN_SWSUP, | ||
143 | }; | ||
144 | |||
145 | static struct clockdomain gfx_l3_am33xx_clkdm = { | ||
146 | .name = "gfx_l3_clkdm", | ||
147 | .pwrdm = { .name = "gfx_pwrdm" }, | ||
148 | .cm_inst = AM33XX_CM_GFX_MOD, | ||
149 | .clkdm_offs = AM33XX_CM_GFX_L3_CLKSTCTRL_OFFSET, | ||
150 | .flags = CLKDM_CAN_SWSUP, | ||
151 | }; | ||
152 | |||
153 | static struct clockdomain gfx_l4ls_gfx_am33xx_clkdm = { | ||
154 | .name = "gfx_l4ls_gfx_clkdm", | ||
155 | .pwrdm = { .name = "gfx_pwrdm" }, | ||
156 | .cm_inst = AM33XX_CM_GFX_MOD, | ||
157 | .clkdm_offs = AM33XX_CM_GFX_L4LS_GFX_CLKSTCTRL__1_OFFSET, | ||
158 | .flags = CLKDM_CAN_SWSUP, | ||
159 | }; | ||
160 | |||
161 | static struct clockdomain l4_cefuse_am33xx_clkdm = { | ||
162 | .name = "l4_cefuse_clkdm", | ||
163 | .pwrdm = { .name = "cefuse_pwrdm" }, | ||
164 | .cm_inst = AM33XX_CM_CEFUSE_MOD, | ||
165 | .clkdm_offs = AM33XX_CM_CEFUSE_CLKSTCTRL_OFFSET, | ||
166 | .flags = CLKDM_CAN_SWSUP, | ||
167 | }; | ||
168 | |||
169 | static struct clockdomain *clockdomains_am33xx[] __initdata = { | ||
170 | &l4ls_am33xx_clkdm, | ||
171 | &l3s_am33xx_clkdm, | ||
172 | &l4fw_am33xx_clkdm, | ||
173 | &l3_am33xx_clkdm, | ||
174 | &l4hs_am33xx_clkdm, | ||
175 | &ocpwp_l3_am33xx_clkdm, | ||
176 | &pruss_ocp_am33xx_clkdm, | ||
177 | &cpsw_125mhz_am33xx_clkdm, | ||
178 | &lcdc_am33xx_clkdm, | ||
179 | &clk_24mhz_am33xx_clkdm, | ||
180 | &l4_wkup_am33xx_clkdm, | ||
181 | &l3_aon_am33xx_clkdm, | ||
182 | &l4_wkup_aon_am33xx_clkdm, | ||
183 | &mpu_am33xx_clkdm, | ||
184 | &l4_rtc_am33xx_clkdm, | ||
185 | &gfx_l3_am33xx_clkdm, | ||
186 | &gfx_l4ls_gfx_am33xx_clkdm, | ||
187 | &l4_cefuse_am33xx_clkdm, | ||
188 | NULL, | ||
189 | }; | ||
190 | |||
191 | void __init am33xx_clockdomains_init(void) | ||
192 | { | ||
193 | clkdm_register_platform_funcs(&am33xx_clkdm_operations); | ||
194 | clkdm_register_clkdms(clockdomains_am33xx); | ||
195 | clkdm_complete_init(); | ||
196 | } | ||
diff --git a/arch/arm/mach-omap2/cm-regbits-33xx.h b/arch/arm/mach-omap2/cm-regbits-33xx.h new file mode 100644 index 000000000000..532027ee3d8d --- /dev/null +++ b/arch/arm/mach-omap2/cm-regbits-33xx.h | |||
@@ -0,0 +1,687 @@ | |||
1 | /* | ||
2 | * AM33XX Power Management register bits | ||
3 | * | ||
4 | * This file is automatically generated from the AM33XX hardware databases. | ||
5 | * Vaibhav Hiremath <hvaibhav@ti.com> | ||
6 | * | ||
7 | * Copyright (C) 2011-2012 Texas Instruments Incorporated - http://www.ti.com/ | ||
8 | * | ||
9 | * This program is free software; you can redistribute it and/or | ||
10 | * modify it under the terms of the GNU General Public License as | ||
11 | * published by the Free Software Foundation version 2. | ||
12 | * | ||
13 | * This program is distributed "as is" WITHOUT ANY WARRANTY of any | ||
14 | * kind, whether express or implied; without even the implied warranty | ||
15 | * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
16 | * GNU General Public License for more details. | ||
17 | */ | ||
18 | |||
19 | |||
20 | #ifndef __ARCH_ARM_MACH_OMAP2_CM_REGBITS_33XX_H | ||
21 | #define __ARCH_ARM_MACH_OMAP2_CM_REGBITS_33XX_H | ||
22 | |||
23 | /* | ||
24 | * Used by CM_AUTOIDLE_DPLL_CORE, CM_AUTOIDLE_DPLL_DDR, CM_AUTOIDLE_DPLL_DISP, | ||
25 | * CM_AUTOIDLE_DPLL_MPU, CM_AUTOIDLE_DPLL_PER | ||
26 | */ | ||
27 | #define AM33XX_AUTO_DPLL_MODE_SHIFT 0 | ||
28 | #define AM33XX_AUTO_DPLL_MODE_MASK (0x7 << 0) | ||
29 | |||
30 | /* Used by CM_WKUP_CLKSTCTRL */ | ||
31 | #define AM33XX_CLKACTIVITY_ADC_FCLK_SHIFT 14 | ||
32 | #define AM33XX_CLKACTIVITY_ADC_FCLK_MASK (1 << 16) | ||
33 | |||
34 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
35 | #define AM33XX_CLKACTIVITY_CAN_CLK_SHIFT 11 | ||
36 | #define AM33XX_CLKACTIVITY_CAN_CLK_MASK (1 << 11) | ||
37 | |||
38 | /* Used by CM_PER_CLK_24MHZ_CLKSTCTRL */ | ||
39 | #define AM33XX_CLKACTIVITY_CLK_24MHZ_GCLK_SHIFT 4 | ||
40 | #define AM33XX_CLKACTIVITY_CLK_24MHZ_GCLK_MASK (1 << 4) | ||
41 | |||
42 | /* Used by CM_PER_CPSW_CLKSTCTRL */ | ||
43 | #define AM33XX_CLKACTIVITY_CPSW_125MHZ_GCLK_SHIFT 4 | ||
44 | #define AM33XX_CLKACTIVITY_CPSW_125MHZ_GCLK_MASK (1 << 4) | ||
45 | |||
46 | /* Used by CM_PER_L4HS_CLKSTCTRL */ | ||
47 | #define AM33XX_CLKACTIVITY_CPSW_250MHZ_GCLK_SHIFT 4 | ||
48 | #define AM33XX_CLKACTIVITY_CPSW_250MHZ_GCLK_MASK (1 << 4) | ||
49 | |||
50 | /* Used by CM_PER_L4HS_CLKSTCTRL */ | ||
51 | #define AM33XX_CLKACTIVITY_CPSW_50MHZ_GCLK_SHIFT 5 | ||
52 | #define AM33XX_CLKACTIVITY_CPSW_50MHZ_GCLK_MASK (1 << 5) | ||
53 | |||
54 | /* Used by CM_PER_L4HS_CLKSTCTRL */ | ||
55 | #define AM33XX_CLKACTIVITY_CPSW_5MHZ_GCLK_SHIFT 6 | ||
56 | #define AM33XX_CLKACTIVITY_CPSW_5MHZ_GCLK_MASK (1 << 6) | ||
57 | |||
58 | /* Used by CM_PER_L3_CLKSTCTRL */ | ||
59 | #define AM33XX_CLKACTIVITY_CPTS_RFT_GCLK_SHIFT 6 | ||
60 | #define AM33XX_CLKACTIVITY_CPTS_RFT_GCLK_MASK (1 << 6) | ||
61 | |||
62 | /* Used by CM_CEFUSE_CLKSTCTRL */ | ||
63 | #define AM33XX_CLKACTIVITY_CUST_EFUSE_SYS_CLK_SHIFT 9 | ||
64 | #define AM33XX_CLKACTIVITY_CUST_EFUSE_SYS_CLK_MASK (1 << 9) | ||
65 | |||
66 | /* Used by CM_L3_AON_CLKSTCTRL */ | ||
67 | #define AM33XX_CLKACTIVITY_DBGSYSCLK_SHIFT 2 | ||
68 | #define AM33XX_CLKACTIVITY_DBGSYSCLK_MASK (1 << 2) | ||
69 | |||
70 | /* Used by CM_L3_AON_CLKSTCTRL */ | ||
71 | #define AM33XX_CLKACTIVITY_DEBUG_CLKA_SHIFT 4 | ||
72 | #define AM33XX_CLKACTIVITY_DEBUG_CLKA_MASK (1 << 4) | ||
73 | |||
74 | /* Used by CM_PER_L3_CLKSTCTRL */ | ||
75 | #define AM33XX_CLKACTIVITY_EMIF_GCLK_SHIFT 2 | ||
76 | #define AM33XX_CLKACTIVITY_EMIF_GCLK_MASK (1 << 2) | ||
77 | |||
78 | /* Used by CM_GFX_L3_CLKSTCTRL */ | ||
79 | #define AM33XX_CLKACTIVITY_GFX_FCLK_SHIFT 9 | ||
80 | #define AM33XX_CLKACTIVITY_GFX_FCLK_MASK (1 << 9) | ||
81 | |||
82 | /* Used by CM_GFX_L3_CLKSTCTRL */ | ||
83 | #define AM33XX_CLKACTIVITY_GFX_L3_GCLK_SHIFT 8 | ||
84 | #define AM33XX_CLKACTIVITY_GFX_L3_GCLK_MASK (1 << 8) | ||
85 | |||
86 | /* Used by CM_WKUP_CLKSTCTRL */ | ||
87 | #define AM33XX_CLKACTIVITY_GPIO0_GDBCLK_SHIFT 8 | ||
88 | #define AM33XX_CLKACTIVITY_GPIO0_GDBCLK_MASK (1 << 8) | ||
89 | |||
90 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
91 | #define AM33XX_CLKACTIVITY_GPIO_1_GDBCLK_SHIFT 19 | ||
92 | #define AM33XX_CLKACTIVITY_GPIO_1_GDBCLK_MASK (1 << 19) | ||
93 | |||
94 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
95 | #define AM33XX_CLKACTIVITY_GPIO_2_GDBCLK_SHIFT 20 | ||
96 | #define AM33XX_CLKACTIVITY_GPIO_2_GDBCLK_MASK (1 << 20) | ||
97 | |||
98 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
99 | #define AM33XX_CLKACTIVITY_GPIO_3_GDBCLK_SHIFT 21 | ||
100 | #define AM33XX_CLKACTIVITY_GPIO_3_GDBCLK_MASK (1 << 21) | ||
101 | |||
102 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
103 | #define AM33XX_CLKACTIVITY_GPIO_4_GDBCLK_SHIFT 22 | ||
104 | #define AM33XX_CLKACTIVITY_GPIO_4_GDBCLK_MASK (1 << 22) | ||
105 | |||
106 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
107 | #define AM33XX_CLKACTIVITY_GPIO_5_GDBCLK_SHIFT 26 | ||
108 | #define AM33XX_CLKACTIVITY_GPIO_5_GDBCLK_MASK (1 << 26) | ||
109 | |||
110 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
111 | #define AM33XX_CLKACTIVITY_GPIO_6_GDBCLK_SHIFT 18 | ||
112 | #define AM33XX_CLKACTIVITY_GPIO_6_GDBCLK_MASK (1 << 18) | ||
113 | |||
114 | /* Used by CM_WKUP_CLKSTCTRL */ | ||
115 | #define AM33XX_CLKACTIVITY_I2C0_GFCLK_SHIFT 11 | ||
116 | #define AM33XX_CLKACTIVITY_I2C0_GFCLK_MASK (1 << 11) | ||
117 | |||
118 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
119 | #define AM33XX_CLKACTIVITY_I2C_FCLK_SHIFT 24 | ||
120 | #define AM33XX_CLKACTIVITY_I2C_FCLK_MASK (1 << 24) | ||
121 | |||
122 | /* Used by CM_PER_PRUSS_CLKSTCTRL */ | ||
123 | #define AM33XX_CLKACTIVITY_PRUSS_IEP_GCLK_SHIFT 5 | ||
124 | #define AM33XX_CLKACTIVITY_PRUSS_IEP_GCLK_MASK (1 << 5) | ||
125 | |||
126 | /* Used by CM_PER_PRUSS_CLKSTCTRL */ | ||
127 | #define AM33XX_CLKACTIVITY_PRUSS_OCP_GCLK_SHIFT 4 | ||
128 | #define AM33XX_CLKACTIVITY_PRUSS_OCP_GCLK_MASK (1 << 4) | ||
129 | |||
130 | /* Used by CM_PER_PRUSS_CLKSTCTRL */ | ||
131 | #define AM33XX_CLKACTIVITY_PRUSS_UART_GCLK_SHIFT 6 | ||
132 | #define AM33XX_CLKACTIVITY_PRUSS_UART_GCLK_MASK (1 << 6) | ||
133 | |||
134 | /* Used by CM_PER_L3S_CLKSTCTRL */ | ||
135 | #define AM33XX_CLKACTIVITY_L3S_GCLK_SHIFT 3 | ||
136 | #define AM33XX_CLKACTIVITY_L3S_GCLK_MASK (1 << 3) | ||
137 | |||
138 | /* Used by CM_L3_AON_CLKSTCTRL */ | ||
139 | #define AM33XX_CLKACTIVITY_L3_AON_GCLK_SHIFT 3 | ||
140 | #define AM33XX_CLKACTIVITY_L3_AON_GCLK_MASK (1 << 3) | ||
141 | |||
142 | /* Used by CM_PER_L3_CLKSTCTRL */ | ||
143 | #define AM33XX_CLKACTIVITY_L3_GCLK_SHIFT 4 | ||
144 | #define AM33XX_CLKACTIVITY_L3_GCLK_MASK (1 << 4) | ||
145 | |||
146 | /* Used by CM_PER_L4FW_CLKSTCTRL */ | ||
147 | #define AM33XX_CLKACTIVITY_L4FW_GCLK_SHIFT 8 | ||
148 | #define AM33XX_CLKACTIVITY_L4FW_GCLK_MASK (1 << 8) | ||
149 | |||
150 | /* Used by CM_PER_L4HS_CLKSTCTRL */ | ||
151 | #define AM33XX_CLKACTIVITY_L4HS_GCLK_SHIFT 3 | ||
152 | #define AM33XX_CLKACTIVITY_L4HS_GCLK_MASK (1 << 3) | ||
153 | |||
154 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
155 | #define AM33XX_CLKACTIVITY_L4LS_GCLK_SHIFT 8 | ||
156 | #define AM33XX_CLKACTIVITY_L4LS_GCLK_MASK (1 << 8) | ||
157 | |||
158 | /* Used by CM_GFX_L4LS_GFX_CLKSTCTRL__1 */ | ||
159 | #define AM33XX_CLKACTIVITY_L4LS_GFX_GCLK_SHIFT 8 | ||
160 | #define AM33XX_CLKACTIVITY_L4LS_GFX_GCLK_MASK (1 << 8) | ||
161 | |||
162 | /* Used by CM_CEFUSE_CLKSTCTRL */ | ||
163 | #define AM33XX_CLKACTIVITY_L4_CEFUSE_GICLK_SHIFT 8 | ||
164 | #define AM33XX_CLKACTIVITY_L4_CEFUSE_GICLK_MASK (1 << 8) | ||
165 | |||
166 | /* Used by CM_RTC_CLKSTCTRL */ | ||
167 | #define AM33XX_CLKACTIVITY_L4_RTC_GCLK_SHIFT 8 | ||
168 | #define AM33XX_CLKACTIVITY_L4_RTC_GCLK_MASK (1 << 8) | ||
169 | |||
170 | /* Used by CM_L4_WKUP_AON_CLKSTCTRL */ | ||
171 | #define AM33XX_CLKACTIVITY_L4_WKUP_AON_GCLK_SHIFT 2 | ||
172 | #define AM33XX_CLKACTIVITY_L4_WKUP_AON_GCLK_MASK (1 << 2) | ||
173 | |||
174 | /* Used by CM_WKUP_CLKSTCTRL */ | ||
175 | #define AM33XX_CLKACTIVITY_L4_WKUP_GCLK_SHIFT 2 | ||
176 | #define AM33XX_CLKACTIVITY_L4_WKUP_GCLK_MASK (1 << 2) | ||
177 | |||
178 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
179 | #define AM33XX_CLKACTIVITY_LCDC_GCLK_SHIFT 17 | ||
180 | #define AM33XX_CLKACTIVITY_LCDC_GCLK_MASK (1 << 17) | ||
181 | |||
182 | /* Used by CM_PER_LCDC_CLKSTCTRL */ | ||
183 | #define AM33XX_CLKACTIVITY_LCDC_L3_OCP_GCLK_SHIFT 4 | ||
184 | #define AM33XX_CLKACTIVITY_LCDC_L3_OCP_GCLK_MASK (1 << 4) | ||
185 | |||
186 | /* Used by CM_PER_LCDC_CLKSTCTRL */ | ||
187 | #define AM33XX_CLKACTIVITY_LCDC_L4_OCP_GCLK_SHIFT 5 | ||
188 | #define AM33XX_CLKACTIVITY_LCDC_L4_OCP_GCLK_MASK (1 << 5) | ||
189 | |||
190 | /* Used by CM_PER_L3_CLKSTCTRL */ | ||
191 | #define AM33XX_CLKACTIVITY_MCASP_GCLK_SHIFT 7 | ||
192 | #define AM33XX_CLKACTIVITY_MCASP_GCLK_MASK (1 << 7) | ||
193 | |||
194 | /* Used by CM_PER_L3_CLKSTCTRL */ | ||
195 | #define AM33XX_CLKACTIVITY_MMC_FCLK_SHIFT 3 | ||
196 | #define AM33XX_CLKACTIVITY_MMC_FCLK_MASK (1 << 3) | ||
197 | |||
198 | /* Used by CM_MPU_CLKSTCTRL */ | ||
199 | #define AM33XX_CLKACTIVITY_MPU_CLK_SHIFT 2 | ||
200 | #define AM33XX_CLKACTIVITY_MPU_CLK_MASK (1 << 2) | ||
201 | |||
202 | /* Used by CM_PER_OCPWP_L3_CLKSTCTRL */ | ||
203 | #define AM33XX_CLKACTIVITY_OCPWP_L3_GCLK_SHIFT 4 | ||
204 | #define AM33XX_CLKACTIVITY_OCPWP_L3_GCLK_MASK (1 << 4) | ||
205 | |||
206 | /* Used by CM_PER_OCPWP_L3_CLKSTCTRL */ | ||
207 | #define AM33XX_CLKACTIVITY_OCPWP_L4_GCLK_SHIFT 5 | ||
208 | #define AM33XX_CLKACTIVITY_OCPWP_L4_GCLK_MASK (1 << 5) | ||
209 | |||
210 | /* Used by CM_RTC_CLKSTCTRL */ | ||
211 | #define AM33XX_CLKACTIVITY_RTC_32KCLK_SHIFT 9 | ||
212 | #define AM33XX_CLKACTIVITY_RTC_32KCLK_MASK (1 << 9) | ||
213 | |||
214 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
215 | #define AM33XX_CLKACTIVITY_SPI_GCLK_SHIFT 25 | ||
216 | #define AM33XX_CLKACTIVITY_SPI_GCLK_MASK (1 << 25) | ||
217 | |||
218 | /* Used by CM_WKUP_CLKSTCTRL */ | ||
219 | #define AM33XX_CLKACTIVITY_SR_SYSCLK_SHIFT 3 | ||
220 | #define AM33XX_CLKACTIVITY_SR_SYSCLK_MASK (1 << 3) | ||
221 | |||
222 | /* Used by CM_WKUP_CLKSTCTRL */ | ||
223 | #define AM33XX_CLKACTIVITY_TIMER0_GCLK_SHIFT 10 | ||
224 | #define AM33XX_CLKACTIVITY_TIMER0_GCLK_MASK (1 << 10) | ||
225 | |||
226 | /* Used by CM_WKUP_CLKSTCTRL */ | ||
227 | #define AM33XX_CLKACTIVITY_TIMER1_GCLK_SHIFT 13 | ||
228 | #define AM33XX_CLKACTIVITY_TIMER1_GCLK_MASK (1 << 13) | ||
229 | |||
230 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
231 | #define AM33XX_CLKACTIVITY_TIMER2_GCLK_SHIFT 14 | ||
232 | #define AM33XX_CLKACTIVITY_TIMER2_GCLK_MASK (1 << 14) | ||
233 | |||
234 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
235 | #define AM33XX_CLKACTIVITY_TIMER3_GCLK_SHIFT 15 | ||
236 | #define AM33XX_CLKACTIVITY_TIMER3_GCLK_MASK (1 << 15) | ||
237 | |||
238 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
239 | #define AM33XX_CLKACTIVITY_TIMER4_GCLK_SHIFT 16 | ||
240 | #define AM33XX_CLKACTIVITY_TIMER4_GCLK_MASK (1 << 16) | ||
241 | |||
242 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
243 | #define AM33XX_CLKACTIVITY_TIMER5_GCLK_SHIFT 27 | ||
244 | #define AM33XX_CLKACTIVITY_TIMER5_GCLK_MASK (1 << 27) | ||
245 | |||
246 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
247 | #define AM33XX_CLKACTIVITY_TIMER6_GCLK_SHIFT 28 | ||
248 | #define AM33XX_CLKACTIVITY_TIMER6_GCLK_MASK (1 << 28) | ||
249 | |||
250 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
251 | #define AM33XX_CLKACTIVITY_TIMER7_GCLK_SHIFT 13 | ||
252 | #define AM33XX_CLKACTIVITY_TIMER7_GCLK_MASK (1 << 13) | ||
253 | |||
254 | /* Used by CM_WKUP_CLKSTCTRL */ | ||
255 | #define AM33XX_CLKACTIVITY_UART0_GFCLK_SHIFT 12 | ||
256 | #define AM33XX_CLKACTIVITY_UART0_GFCLK_MASK (1 << 12) | ||
257 | |||
258 | /* Used by CM_PER_L4LS_CLKSTCTRL */ | ||
259 | #define AM33XX_CLKACTIVITY_UART_GFCLK_SHIFT 10 | ||
260 | #define AM33XX_CLKACTIVITY_UART_GFCLK_MASK (1 << 10) | ||
261 | |||
262 | /* Used by CM_WKUP_CLKSTCTRL */ | ||
263 | #define AM33XX_CLKACTIVITY_WDT0_GCLK_SHIFT 9 | ||
264 | #define AM33XX_CLKACTIVITY_WDT0_GCLK_MASK (1 << 9) | ||
265 | |||
266 | /* Used by CM_WKUP_CLKSTCTRL */ | ||
267 | #define AM33XX_CLKACTIVITY_WDT1_GCLK_SHIFT 4 | ||
268 | #define AM33XX_CLKACTIVITY_WDT1_GCLK_MASK (1 << 4) | ||
269 | |||
270 | /* Used by CLKSEL_GFX_FCLK */ | ||
271 | #define AM33XX_CLKDIV_SEL_GFX_FCLK_SHIFT 0 | ||
272 | #define AM33XX_CLKDIV_SEL_GFX_FCLK_MASK (1 << 0) | ||
273 | |||
274 | /* Used by CM_CLKOUT_CTRL */ | ||
275 | #define AM33XX_CLKOUT2DIV_SHIFT 3 | ||
276 | #define AM33XX_CLKOUT2DIV_MASK (0x05 << 3) | ||
277 | |||
278 | /* Used by CM_CLKOUT_CTRL */ | ||
279 | #define AM33XX_CLKOUT2EN_SHIFT 7 | ||
280 | #define AM33XX_CLKOUT2EN_MASK (1 << 7) | ||
281 | |||
282 | /* Used by CM_CLKOUT_CTRL */ | ||
283 | #define AM33XX_CLKOUT2SOURCE_SHIFT 0 | ||
284 | #define AM33XX_CLKOUT2SOURCE_MASK (0x02 << 0) | ||
285 | |||
286 | /* | ||
287 | * Used by CLKSEL_GPIO0_DBCLK, CLKSEL_LCDC_PIXEL_CLK, CLKSEL_TIMER2_CLK, | ||
288 | * CLKSEL_TIMER3_CLK, CLKSEL_TIMER4_CLK, CLKSEL_TIMER5_CLK, CLKSEL_TIMER6_CLK, | ||
289 | * CLKSEL_TIMER7_CLK | ||
290 | */ | ||
291 | #define AM33XX_CLKSEL_SHIFT 0 | ||
292 | #define AM33XX_CLKSEL_MASK (0x01 << 0) | ||
293 | |||
294 | /* | ||
295 | * Renamed from CLKSEL Used by CLKSEL_PRUSS_OCP_CLK, CLKSEL_WDT1_CLK, | ||
296 | * CM_CPTS_RFT_CLKSEL | ||
297 | */ | ||
298 | #define AM33XX_CLKSEL_0_0_SHIFT 0 | ||
299 | #define AM33XX_CLKSEL_0_0_MASK (1 << 0) | ||
300 | |||
301 | #define AM33XX_CLKSEL_0_1_SHIFT 0 | ||
302 | #define AM33XX_CLKSEL_0_1_MASK (3 << 0) | ||
303 | |||
304 | /* Renamed from CLKSEL Used by CLKSEL_TIMER1MS_CLK */ | ||
305 | #define AM33XX_CLKSEL_0_2_SHIFT 0 | ||
306 | #define AM33XX_CLKSEL_0_2_MASK (7 << 0) | ||
307 | |||
308 | /* Used by CLKSEL_GFX_FCLK */ | ||
309 | #define AM33XX_CLKSEL_GFX_FCLK_SHIFT 1 | ||
310 | #define AM33XX_CLKSEL_GFX_FCLK_MASK (1 << 1) | ||
311 | |||
312 | /* | ||
313 | * Used by CM_MPU_CLKSTCTRL, CM_RTC_CLKSTCTRL, CM_PER_CLK_24MHZ_CLKSTCTRL, | ||
314 | * CM_PER_CPSW_CLKSTCTRL, CM_PER_PRUSS_CLKSTCTRL, CM_PER_L3S_CLKSTCTRL, | ||
315 | * CM_PER_L3_CLKSTCTRL, CM_PER_L4FW_CLKSTCTRL, CM_PER_L4HS_CLKSTCTRL, | ||
316 | * CM_PER_L4LS_CLKSTCTRL, CM_PER_LCDC_CLKSTCTRL, CM_PER_OCPWP_L3_CLKSTCTRL, | ||
317 | * CM_L3_AON_CLKSTCTRL, CM_L4_WKUP_AON_CLKSTCTRL, CM_WKUP_CLKSTCTRL, | ||
318 | * CM_GFX_L3_CLKSTCTRL, CM_GFX_L4LS_GFX_CLKSTCTRL__1, CM_CEFUSE_CLKSTCTRL | ||
319 | */ | ||
320 | #define AM33XX_CLKTRCTRL_SHIFT 0 | ||
321 | #define AM33XX_CLKTRCTRL_MASK (0x3 << 0) | ||
322 | |||
323 | /* | ||
324 | * Used by CM_SSC_DELTAMSTEP_DPLL_CORE, CM_SSC_DELTAMSTEP_DPLL_DDR, | ||
325 | * CM_SSC_DELTAMSTEP_DPLL_DISP, CM_SSC_DELTAMSTEP_DPLL_MPU, | ||
326 | * CM_SSC_DELTAMSTEP_DPLL_PER | ||
327 | */ | ||
328 | #define AM33XX_DELTAMSTEP_SHIFT 0 | ||
329 | #define AM33XX_DELTAMSTEP_MASK (0x19 << 0) | ||
330 | |||
331 | /* Used by CM_CLKSEL_DPLL_DDR, CM_CLKSEL_DPLL_DISP, CM_CLKSEL_DPLL_MPU */ | ||
332 | #define AM33XX_DPLL_BYP_CLKSEL_SHIFT 23 | ||
333 | #define AM33XX_DPLL_BYP_CLKSEL_MASK (1 << 23) | ||
334 | |||
335 | /* Used by CM_CLKDCOLDO_DPLL_PER */ | ||
336 | #define AM33XX_DPLL_CLKDCOLDO_GATE_CTRL_SHIFT 8 | ||
337 | #define AM33XX_DPLL_CLKDCOLDO_GATE_CTRL_MASK (1 << 8) | ||
338 | |||
339 | /* Used by CM_CLKDCOLDO_DPLL_PER */ | ||
340 | #define AM33XX_DPLL_CLKDCOLDO_PWDN_SHIFT 12 | ||
341 | #define AM33XX_DPLL_CLKDCOLDO_PWDN_MASK (1 << 12) | ||
342 | |||
343 | /* Used by CM_DIV_M2_DPLL_DDR, CM_DIV_M2_DPLL_DISP, CM_DIV_M2_DPLL_MPU */ | ||
344 | #define AM33XX_DPLL_CLKOUT_DIV_SHIFT 0 | ||
345 | #define AM33XX_DPLL_CLKOUT_DIV_MASK (0x1f << 0) | ||
346 | |||
347 | /* Renamed from DPLL_CLKOUT_DIV Used by CM_DIV_M2_DPLL_PER */ | ||
348 | #define AM33XX_DPLL_CLKOUT_DIV_0_6_SHIFT 0 | ||
349 | #define AM33XX_DPLL_CLKOUT_DIV_0_6_MASK (0x06 << 0) | ||
350 | |||
351 | /* Used by CM_DIV_M2_DPLL_DDR, CM_DIV_M2_DPLL_DISP, CM_DIV_M2_DPLL_MPU */ | ||
352 | #define AM33XX_DPLL_CLKOUT_DIVCHACK_SHIFT 5 | ||
353 | #define AM33XX_DPLL_CLKOUT_DIVCHACK_MASK (1 << 5) | ||
354 | |||
355 | /* Renamed from DPLL_CLKOUT_DIVCHACK Used by CM_DIV_M2_DPLL_PER */ | ||
356 | #define AM33XX_DPLL_CLKOUT_DIVCHACK_M2_PER_SHIFT 7 | ||
357 | #define AM33XX_DPLL_CLKOUT_DIVCHACK_M2_PER_MASK (1 << 7) | ||
358 | |||
359 | /* | ||
360 | * Used by CM_DIV_M2_DPLL_DDR, CM_DIV_M2_DPLL_DISP, CM_DIV_M2_DPLL_MPU, | ||
361 | * CM_DIV_M2_DPLL_PER | ||
362 | */ | ||
363 | #define AM33XX_DPLL_CLKOUT_GATE_CTRL_SHIFT 8 | ||
364 | #define AM33XX_DPLL_CLKOUT_GATE_CTRL_MASK (1 << 8) | ||
365 | |||
366 | /* | ||
367 | * Used by CM_CLKSEL_DPLL_CORE, CM_CLKSEL_DPLL_DDR, CM_CLKSEL_DPLL_DISP, | ||
368 | * CM_CLKSEL_DPLL_MPU | ||
369 | */ | ||
370 | #define AM33XX_DPLL_DIV_SHIFT 0 | ||
371 | #define AM33XX_DPLL_DIV_MASK (0x7f << 0) | ||
372 | |||
373 | #define AM33XX_DPLL_PER_DIV_MASK (0xff << 0) | ||
374 | |||
375 | /* Renamed from DPLL_DIV Used by CM_CLKSEL_DPLL_PERIPH */ | ||
376 | #define AM33XX_DPLL_DIV_0_7_SHIFT 0 | ||
377 | #define AM33XX_DPLL_DIV_0_7_MASK (0x07 << 0) | ||
378 | |||
379 | /* | ||
380 | * Used by CM_CLKMODE_DPLL_CORE, CM_CLKMODE_DPLL_DDR, CM_CLKMODE_DPLL_DISP, | ||
381 | * CM_CLKMODE_DPLL_MPU | ||
382 | */ | ||
383 | #define AM33XX_DPLL_DRIFTGUARD_EN_SHIFT 8 | ||
384 | #define AM33XX_DPLL_DRIFTGUARD_EN_MASK (1 << 8) | ||
385 | |||
386 | /* | ||
387 | * Used by CM_CLKMODE_DPLL_CORE, CM_CLKMODE_DPLL_DDR, CM_CLKMODE_DPLL_DISP, | ||
388 | * CM_CLKMODE_DPLL_MPU, CM_CLKMODE_DPLL_PER | ||
389 | */ | ||
390 | #define AM33XX_DPLL_EN_SHIFT 0 | ||
391 | #define AM33XX_DPLL_EN_MASK (0x7 << 0) | ||
392 | |||
393 | /* | ||
394 | * Used by CM_CLKMODE_DPLL_CORE, CM_CLKMODE_DPLL_DDR, CM_CLKMODE_DPLL_DISP, | ||
395 | * CM_CLKMODE_DPLL_MPU | ||
396 | */ | ||
397 | #define AM33XX_DPLL_LPMODE_EN_SHIFT 10 | ||
398 | #define AM33XX_DPLL_LPMODE_EN_MASK (1 << 10) | ||
399 | |||
400 | /* | ||
401 | * Used by CM_CLKSEL_DPLL_CORE, CM_CLKSEL_DPLL_DDR, CM_CLKSEL_DPLL_DISP, | ||
402 | * CM_CLKSEL_DPLL_MPU | ||
403 | */ | ||
404 | #define AM33XX_DPLL_MULT_SHIFT 8 | ||
405 | #define AM33XX_DPLL_MULT_MASK (0x7ff << 8) | ||
406 | |||
407 | /* Renamed from DPLL_MULT Used by CM_CLKSEL_DPLL_PERIPH */ | ||
408 | #define AM33XX_DPLL_MULT_PERIPH_SHIFT 8 | ||
409 | #define AM33XX_DPLL_MULT_PERIPH_MASK (0xfff << 8) | ||
410 | |||
411 | /* | ||
412 | * Used by CM_CLKMODE_DPLL_CORE, CM_CLKMODE_DPLL_DDR, CM_CLKMODE_DPLL_DISP, | ||
413 | * CM_CLKMODE_DPLL_MPU | ||
414 | */ | ||
415 | #define AM33XX_DPLL_REGM4XEN_SHIFT 11 | ||
416 | #define AM33XX_DPLL_REGM4XEN_MASK (1 << 11) | ||
417 | |||
418 | /* Used by CM_CLKSEL_DPLL_PERIPH */ | ||
419 | #define AM33XX_DPLL_SD_DIV_SHIFT 24 | ||
420 | #define AM33XX_DPLL_SD_DIV_MASK (24, 31) | ||
421 | |||
422 | /* | ||
423 | * Used by CM_CLKMODE_DPLL_CORE, CM_CLKMODE_DPLL_DDR, CM_CLKMODE_DPLL_DISP, | ||
424 | * CM_CLKMODE_DPLL_MPU, CM_CLKMODE_DPLL_PER | ||
425 | */ | ||
426 | #define AM33XX_DPLL_SSC_ACK_SHIFT 13 | ||
427 | #define AM33XX_DPLL_SSC_ACK_MASK (1 << 13) | ||
428 | |||
429 | /* | ||
430 | * Used by CM_CLKMODE_DPLL_CORE, CM_CLKMODE_DPLL_DDR, CM_CLKMODE_DPLL_DISP, | ||
431 | * CM_CLKMODE_DPLL_MPU, CM_CLKMODE_DPLL_PER | ||
432 | */ | ||
433 | #define AM33XX_DPLL_SSC_DOWNSPREAD_SHIFT 14 | ||
434 | #define AM33XX_DPLL_SSC_DOWNSPREAD_MASK (1 << 14) | ||
435 | |||
436 | /* | ||
437 | * Used by CM_CLKMODE_DPLL_CORE, CM_CLKMODE_DPLL_DDR, CM_CLKMODE_DPLL_DISP, | ||
438 | * CM_CLKMODE_DPLL_MPU, CM_CLKMODE_DPLL_PER | ||
439 | */ | ||
440 | #define AM33XX_DPLL_SSC_EN_SHIFT 12 | ||
441 | #define AM33XX_DPLL_SSC_EN_MASK (1 << 12) | ||
442 | |||
443 | /* Used by CM_DIV_M4_DPLL_CORE */ | ||
444 | #define AM33XX_HSDIVIDER_CLKOUT1_DIV_SHIFT 0 | ||
445 | #define AM33XX_HSDIVIDER_CLKOUT1_DIV_MASK (0x1f << 0) | ||
446 | |||
447 | /* Used by CM_DIV_M4_DPLL_CORE */ | ||
448 | #define AM33XX_HSDIVIDER_CLKOUT1_DIVCHACK_SHIFT 5 | ||
449 | #define AM33XX_HSDIVIDER_CLKOUT1_DIVCHACK_MASK (1 << 5) | ||
450 | |||
451 | /* Used by CM_DIV_M4_DPLL_CORE */ | ||
452 | #define AM33XX_HSDIVIDER_CLKOUT1_GATE_CTRL_SHIFT 8 | ||
453 | #define AM33XX_HSDIVIDER_CLKOUT1_GATE_CTRL_MASK (1 << 8) | ||
454 | |||
455 | /* Used by CM_DIV_M4_DPLL_CORE */ | ||
456 | #define AM33XX_HSDIVIDER_CLKOUT1_PWDN_SHIFT 12 | ||
457 | #define AM33XX_HSDIVIDER_CLKOUT1_PWDN_MASK (1 << 12) | ||
458 | |||
459 | /* Used by CM_DIV_M5_DPLL_CORE */ | ||
460 | #define AM33XX_HSDIVIDER_CLKOUT2_DIV_SHIFT 0 | ||
461 | #define AM33XX_HSDIVIDER_CLKOUT2_DIV_MASK (0x1f << 0) | ||
462 | |||
463 | /* Used by CM_DIV_M5_DPLL_CORE */ | ||
464 | #define AM33XX_HSDIVIDER_CLKOUT2_DIVCHACK_SHIFT 5 | ||
465 | #define AM33XX_HSDIVIDER_CLKOUT2_DIVCHACK_MASK (1 << 5) | ||
466 | |||
467 | /* Used by CM_DIV_M5_DPLL_CORE */ | ||
468 | #define AM33XX_HSDIVIDER_CLKOUT2_GATE_CTRL_SHIFT 8 | ||
469 | #define AM33XX_HSDIVIDER_CLKOUT2_GATE_CTRL_MASK (1 << 8) | ||
470 | |||
471 | /* Used by CM_DIV_M5_DPLL_CORE */ | ||
472 | #define AM33XX_HSDIVIDER_CLKOUT2_PWDN_SHIFT 12 | ||
473 | #define AM33XX_HSDIVIDER_CLKOUT2_PWDN_MASK (1 << 12) | ||
474 | |||
475 | /* Used by CM_DIV_M6_DPLL_CORE */ | ||
476 | #define AM33XX_HSDIVIDER_CLKOUT3_DIV_SHIFT 0 | ||
477 | #define AM33XX_HSDIVIDER_CLKOUT3_DIV_MASK (0x04 << 0) | ||
478 | |||
479 | /* Used by CM_DIV_M6_DPLL_CORE */ | ||
480 | #define AM33XX_HSDIVIDER_CLKOUT3_DIVCHACK_SHIFT 5 | ||
481 | #define AM33XX_HSDIVIDER_CLKOUT3_DIVCHACK_MASK (1 << 5) | ||
482 | |||
483 | /* Used by CM_DIV_M6_DPLL_CORE */ | ||
484 | #define AM33XX_HSDIVIDER_CLKOUT3_GATE_CTRL_SHIFT 8 | ||
485 | #define AM33XX_HSDIVIDER_CLKOUT3_GATE_CTRL_MASK (1 << 8) | ||
486 | |||
487 | /* Used by CM_DIV_M6_DPLL_CORE */ | ||
488 | #define AM33XX_HSDIVIDER_CLKOUT3_PWDN_SHIFT 12 | ||
489 | #define AM33XX_HSDIVIDER_CLKOUT3_PWDN_MASK (1 << 12) | ||
490 | |||
491 | /* | ||
492 | * Used by CM_MPU_MPU_CLKCTRL, CM_RTC_RTC_CLKCTRL, CM_PER_AES0_CLKCTRL, | ||
493 | * CM_PER_AES1_CLKCTRL, CM_PER_CLKDIV32K_CLKCTRL, CM_PER_CPGMAC0_CLKCTRL, | ||
494 | * CM_PER_DCAN0_CLKCTRL, CM_PER_DCAN1_CLKCTRL, CM_PER_DES_CLKCTRL, | ||
495 | * CM_PER_ELM_CLKCTRL, CM_PER_EMIF_CLKCTRL, CM_PER_EMIF_FW_CLKCTRL, | ||
496 | * CM_PER_EPWMSS0_CLKCTRL, CM_PER_EPWMSS1_CLKCTRL, CM_PER_EPWMSS2_CLKCTRL, | ||
497 | * CM_PER_GPIO1_CLKCTRL, CM_PER_GPIO2_CLKCTRL, CM_PER_GPIO3_CLKCTRL, | ||
498 | * CM_PER_GPIO4_CLKCTRL, CM_PER_GPIO5_CLKCTRL, CM_PER_GPIO6_CLKCTRL, | ||
499 | * CM_PER_GPMC_CLKCTRL, CM_PER_I2C1_CLKCTRL, CM_PER_I2C2_CLKCTRL, | ||
500 | * CM_PER_PRUSS_CLKCTRL, CM_PER_IEEE5000_CLKCTRL, CM_PER_L3_CLKCTRL, | ||
501 | * CM_PER_L3_INSTR_CLKCTRL, CM_PER_L4FW_CLKCTRL, CM_PER_L4HS_CLKCTRL, | ||
502 | * CM_PER_L4LS_CLKCTRL, CM_PER_LCDC_CLKCTRL, CM_PER_MAILBOX0_CLKCTRL, | ||
503 | * CM_PER_MAILBOX1_CLKCTRL, CM_PER_MCASP0_CLKCTRL, CM_PER_MCASP1_CLKCTRL, | ||
504 | * CM_PER_MCASP2_CLKCTRL, CM_PER_MLB_CLKCTRL, CM_PER_MMC0_CLKCTRL, | ||
505 | * CM_PER_MMC1_CLKCTRL, CM_PER_MMC2_CLKCTRL, CM_PER_MSTR_EXPS_CLKCTRL, | ||
506 | * CM_PER_OCMCRAM_CLKCTRL, CM_PER_OCPWP_CLKCTRL, CM_PER_PCIE_CLKCTRL, | ||
507 | * CM_PER_PKA_CLKCTRL, CM_PER_RNG_CLKCTRL, CM_PER_SHA0_CLKCTRL, | ||
508 | * CM_PER_SLV_EXPS_CLKCTRL, CM_PER_SPARE0_CLKCTRL, CM_PER_SPARE1_CLKCTRL, | ||
509 | * CM_PER_SPARE_CLKCTRL, CM_PER_SPI0_CLKCTRL, CM_PER_SPI1_CLKCTRL, | ||
510 | * CM_PER_SPI2_CLKCTRL, CM_PER_SPI3_CLKCTRL, CM_PER_SPINLOCK_CLKCTRL, | ||
511 | * CM_PER_TIMER2_CLKCTRL, CM_PER_TIMER3_CLKCTRL, CM_PER_TIMER4_CLKCTRL, | ||
512 | * CM_PER_TIMER5_CLKCTRL, CM_PER_TIMER6_CLKCTRL, CM_PER_TIMER7_CLKCTRL, | ||
513 | * CM_PER_TPCC_CLKCTRL, CM_PER_TPTC0_CLKCTRL, CM_PER_TPTC1_CLKCTRL, | ||
514 | * CM_PER_TPTC2_CLKCTRL, CM_PER_UART1_CLKCTRL, CM_PER_UART2_CLKCTRL, | ||
515 | * CM_PER_UART3_CLKCTRL, CM_PER_UART4_CLKCTRL, CM_PER_UART5_CLKCTRL, | ||
516 | * CM_PER_USB0_CLKCTRL, CM_WKUP_ADC_TSC_CLKCTRL, CM_WKUP_CONTROL_CLKCTRL, | ||
517 | * CM_WKUP_DEBUGSS_CLKCTRL, CM_WKUP_GPIO0_CLKCTRL, CM_WKUP_I2C0_CLKCTRL, | ||
518 | * CM_WKUP_L4WKUP_CLKCTRL, CM_WKUP_SMARTREFLEX0_CLKCTRL, | ||
519 | * CM_WKUP_SMARTREFLEX1_CLKCTRL, CM_WKUP_TIMER0_CLKCTRL, | ||
520 | * CM_WKUP_TIMER1_CLKCTRL, CM_WKUP_UART0_CLKCTRL, CM_WKUP_WDT0_CLKCTRL, | ||
521 | * CM_WKUP_WDT1_CLKCTRL, CM_GFX_BITBLT_CLKCTRL, CM_GFX_GFX_CLKCTRL, | ||
522 | * CM_GFX_MMUCFG_CLKCTRL, CM_GFX_MMUDATA_CLKCTRL, CM_CEFUSE_CEFUSE_CLKCTRL | ||
523 | */ | ||
524 | #define AM33XX_IDLEST_SHIFT 16 | ||
525 | #define AM33XX_IDLEST_MASK (0x3 << 16) | ||
526 | #define AM33XX_IDLEST_VAL 0x3 | ||
527 | |||
528 | /* Used by CM_MAC_CLKSEL */ | ||
529 | #define AM33XX_MII_CLK_SEL_SHIFT 2 | ||
530 | #define AM33XX_MII_CLK_SEL_MASK (1 << 2) | ||
531 | |||
532 | /* | ||
533 | * Used by CM_SSC_MODFREQDIV_DPLL_CORE, CM_SSC_MODFREQDIV_DPLL_DDR, | ||
534 | * CM_SSC_MODFREQDIV_DPLL_DISP, CM_SSC_MODFREQDIV_DPLL_MPU, | ||
535 | * CM_SSC_MODFREQDIV_DPLL_PER | ||
536 | */ | ||
537 | #define AM33XX_MODFREQDIV_EXPONENT_SHIFT 8 | ||
538 | #define AM33XX_MODFREQDIV_EXPONENT_MASK (0x10 << 8) | ||
539 | |||
540 | /* | ||
541 | * Used by CM_SSC_MODFREQDIV_DPLL_CORE, CM_SSC_MODFREQDIV_DPLL_DDR, | ||
542 | * CM_SSC_MODFREQDIV_DPLL_DISP, CM_SSC_MODFREQDIV_DPLL_MPU, | ||
543 | * CM_SSC_MODFREQDIV_DPLL_PER | ||
544 | */ | ||
545 | #define AM33XX_MODFREQDIV_MANTISSA_SHIFT 0 | ||
546 | #define AM33XX_MODFREQDIV_MANTISSA_MASK (0x06 << 0) | ||
547 | |||
548 | /* | ||
549 | * Used by CM_MPU_MPU_CLKCTRL, CM_RTC_RTC_CLKCTRL, CM_PER_AES0_CLKCTRL, | ||
550 | * CM_PER_AES1_CLKCTRL, CM_PER_CLKDIV32K_CLKCTRL, CM_PER_CPGMAC0_CLKCTRL, | ||
551 | * CM_PER_DCAN0_CLKCTRL, CM_PER_DCAN1_CLKCTRL, CM_PER_DES_CLKCTRL, | ||
552 | * CM_PER_ELM_CLKCTRL, CM_PER_EMIF_CLKCTRL, CM_PER_EMIF_FW_CLKCTRL, | ||
553 | * CM_PER_EPWMSS0_CLKCTRL, CM_PER_EPWMSS1_CLKCTRL, CM_PER_EPWMSS2_CLKCTRL, | ||
554 | * CM_PER_GPIO1_CLKCTRL, CM_PER_GPIO2_CLKCTRL, CM_PER_GPIO3_CLKCTRL, | ||
555 | * CM_PER_GPIO4_CLKCTRL, CM_PER_GPIO5_CLKCTRL, CM_PER_GPIO6_CLKCTRL, | ||
556 | * CM_PER_GPMC_CLKCTRL, CM_PER_I2C1_CLKCTRL, CM_PER_I2C2_CLKCTRL, | ||
557 | * CM_PER_PRUSS_CLKCTRL, CM_PER_IEEE5000_CLKCTRL, CM_PER_L3_CLKCTRL, | ||
558 | * CM_PER_L3_INSTR_CLKCTRL, CM_PER_L4FW_CLKCTRL, CM_PER_L4HS_CLKCTRL, | ||
559 | * CM_PER_L4LS_CLKCTRL, CM_PER_LCDC_CLKCTRL, CM_PER_MAILBOX0_CLKCTRL, | ||
560 | * CM_PER_MAILBOX1_CLKCTRL, CM_PER_MCASP0_CLKCTRL, CM_PER_MCASP1_CLKCTRL, | ||
561 | * CM_PER_MCASP2_CLKCTRL, CM_PER_MLB_CLKCTRL, CM_PER_MMC0_CLKCTRL, | ||
562 | * CM_PER_MMC1_CLKCTRL, CM_PER_MMC2_CLKCTRL, CM_PER_MSTR_EXPS_CLKCTRL, | ||
563 | * CM_PER_OCMCRAM_CLKCTRL, CM_PER_OCPWP_CLKCTRL, CM_PER_PCIE_CLKCTRL, | ||
564 | * CM_PER_PKA_CLKCTRL, CM_PER_RNG_CLKCTRL, CM_PER_SHA0_CLKCTRL, | ||
565 | * CM_PER_SLV_EXPS_CLKCTRL, CM_PER_SPARE0_CLKCTRL, CM_PER_SPARE1_CLKCTRL, | ||
566 | * CM_PER_SPARE_CLKCTRL, CM_PER_SPI0_CLKCTRL, CM_PER_SPI1_CLKCTRL, | ||
567 | * CM_PER_SPI2_CLKCTRL, CM_PER_SPI3_CLKCTRL, CM_PER_SPINLOCK_CLKCTRL, | ||
568 | * CM_PER_TIMER2_CLKCTRL, CM_PER_TIMER3_CLKCTRL, CM_PER_TIMER4_CLKCTRL, | ||
569 | * CM_PER_TIMER5_CLKCTRL, CM_PER_TIMER6_CLKCTRL, CM_PER_TIMER7_CLKCTRL, | ||
570 | * CM_PER_TPCC_CLKCTRL, CM_PER_TPTC0_CLKCTRL, CM_PER_TPTC1_CLKCTRL, | ||
571 | * CM_PER_TPTC2_CLKCTRL, CM_PER_UART1_CLKCTRL, CM_PER_UART2_CLKCTRL, | ||
572 | * CM_PER_UART3_CLKCTRL, CM_PER_UART4_CLKCTRL, CM_PER_UART5_CLKCTRL, | ||
573 | * CM_PER_USB0_CLKCTRL, CM_WKUP_ADC_TSC_CLKCTRL, CM_WKUP_CONTROL_CLKCTRL, | ||
574 | * CM_WKUP_DEBUGSS_CLKCTRL, CM_WKUP_GPIO0_CLKCTRL, CM_WKUP_I2C0_CLKCTRL, | ||
575 | * CM_WKUP_L4WKUP_CLKCTRL, CM_WKUP_SMARTREFLEX0_CLKCTRL, | ||
576 | * CM_WKUP_SMARTREFLEX1_CLKCTRL, CM_WKUP_TIMER0_CLKCTRL, | ||
577 | * CM_WKUP_TIMER1_CLKCTRL, CM_WKUP_UART0_CLKCTRL, CM_WKUP_WDT0_CLKCTRL, | ||
578 | * CM_WKUP_WDT1_CLKCTRL, CM_WKUP_WKUP_M3_CLKCTRL, CM_GFX_BITBLT_CLKCTRL, | ||
579 | * CM_GFX_GFX_CLKCTRL, CM_GFX_MMUCFG_CLKCTRL, CM_GFX_MMUDATA_CLKCTRL, | ||
580 | * CM_CEFUSE_CEFUSE_CLKCTRL | ||
581 | */ | ||
582 | #define AM33XX_MODULEMODE_SHIFT 0 | ||
583 | #define AM33XX_MODULEMODE_MASK (0x3 << 0) | ||
584 | |||
585 | /* Used by CM_WKUP_DEBUGSS_CLKCTRL */ | ||
586 | #define AM33XX_OPTCLK_DEBUG_CLKA_SHIFT 30 | ||
587 | #define AM33XX_OPTCLK_DEBUG_CLKA_MASK (1 << 30) | ||
588 | |||
589 | /* Used by CM_WKUP_DEBUGSS_CLKCTRL */ | ||
590 | #define AM33XX_OPTFCLKEN_DBGSYSCLK_SHIFT 19 | ||
591 | #define AM33XX_OPTFCLKEN_DBGSYSCLK_MASK (1 << 19) | ||
592 | |||
593 | /* Used by CM_WKUP_GPIO0_CLKCTRL */ | ||
594 | #define AM33XX_OPTFCLKEN_GPIO0_GDBCLK_SHIFT 18 | ||
595 | #define AM33XX_OPTFCLKEN_GPIO0_GDBCLK_MASK (1 << 18) | ||
596 | |||
597 | /* Used by CM_PER_GPIO1_CLKCTRL */ | ||
598 | #define AM33XX_OPTFCLKEN_GPIO_1_GDBCLK_SHIFT 18 | ||
599 | #define AM33XX_OPTFCLKEN_GPIO_1_GDBCLK_MASK (1 << 18) | ||
600 | |||
601 | /* Used by CM_PER_GPIO2_CLKCTRL */ | ||
602 | #define AM33XX_OPTFCLKEN_GPIO_2_GDBCLK_SHIFT 18 | ||
603 | #define AM33XX_OPTFCLKEN_GPIO_2_GDBCLK_MASK (1 << 18) | ||
604 | |||
605 | /* Used by CM_PER_GPIO3_CLKCTRL */ | ||
606 | #define AM33XX_OPTFCLKEN_GPIO_3_GDBCLK_SHIFT 18 | ||
607 | #define AM33XX_OPTFCLKEN_GPIO_3_GDBCLK_MASK (1 << 18) | ||
608 | |||
609 | /* Used by CM_PER_GPIO4_CLKCTRL */ | ||
610 | #define AM33XX_OPTFCLKEN_GPIO_4_GDBCLK_SHIFT 18 | ||
611 | #define AM33XX_OPTFCLKEN_GPIO_4_GDBCLK_MASK (1 << 18) | ||
612 | |||
613 | /* Used by CM_PER_GPIO5_CLKCTRL */ | ||
614 | #define AM33XX_OPTFCLKEN_GPIO_5_GDBCLK_SHIFT 18 | ||
615 | #define AM33XX_OPTFCLKEN_GPIO_5_GDBCLK_MASK (1 << 18) | ||
616 | |||
617 | /* Used by CM_PER_GPIO6_CLKCTRL */ | ||
618 | #define AM33XX_OPTFCLKEN_GPIO_6_GDBCLK_SHIFT 18 | ||
619 | #define AM33XX_OPTFCLKEN_GPIO_6_GDBCLK_MASK (1 << 18) | ||
620 | |||
621 | /* | ||
622 | * Used by CM_MPU_MPU_CLKCTRL, CM_PER_CPGMAC0_CLKCTRL, CM_PER_PRUSS_CLKCTRL, | ||
623 | * CM_PER_IEEE5000_CLKCTRL, CM_PER_LCDC_CLKCTRL, CM_PER_MLB_CLKCTRL, | ||
624 | * CM_PER_MSTR_EXPS_CLKCTRL, CM_PER_OCPWP_CLKCTRL, CM_PER_PCIE_CLKCTRL, | ||
625 | * CM_PER_SPARE_CLKCTRL, CM_PER_TPTC0_CLKCTRL, CM_PER_TPTC1_CLKCTRL, | ||
626 | * CM_PER_TPTC2_CLKCTRL, CM_PER_USB0_CLKCTRL, CM_WKUP_DEBUGSS_CLKCTRL, | ||
627 | * CM_WKUP_WKUP_M3_CLKCTRL, CM_GFX_BITBLT_CLKCTRL, CM_GFX_GFX_CLKCTRL | ||
628 | */ | ||
629 | #define AM33XX_STBYST_SHIFT 18 | ||
630 | #define AM33XX_STBYST_MASK (1 << 18) | ||
631 | |||
632 | /* Used by CM_WKUP_DEBUGSS_CLKCTRL */ | ||
633 | #define AM33XX_STM_PMD_CLKDIVSEL_SHIFT 27 | ||
634 | #define AM33XX_STM_PMD_CLKDIVSEL_MASK (0x29 << 27) | ||
635 | |||
636 | /* Used by CM_WKUP_DEBUGSS_CLKCTRL */ | ||
637 | #define AM33XX_STM_PMD_CLKSEL_SHIFT 22 | ||
638 | #define AM33XX_STM_PMD_CLKSEL_MASK (0x23 << 22) | ||
639 | |||
640 | /* | ||
641 | * Used by CM_IDLEST_DPLL_CORE, CM_IDLEST_DPLL_DDR, CM_IDLEST_DPLL_DISP, | ||
642 | * CM_IDLEST_DPLL_MPU, CM_IDLEST_DPLL_PER | ||
643 | */ | ||
644 | #define AM33XX_ST_DPLL_CLK_SHIFT 0 | ||
645 | #define AM33XX_ST_DPLL_CLK_MASK (1 << 0) | ||
646 | |||
647 | /* Used by CM_CLKDCOLDO_DPLL_PER */ | ||
648 | #define AM33XX_ST_DPLL_CLKDCOLDO_SHIFT 8 | ||
649 | #define AM33XX_ST_DPLL_CLKDCOLDO_MASK (1 << 8) | ||
650 | |||
651 | /* | ||
652 | * Used by CM_DIV_M2_DPLL_DDR, CM_DIV_M2_DPLL_DISP, CM_DIV_M2_DPLL_MPU, | ||
653 | * CM_DIV_M2_DPLL_PER | ||
654 | */ | ||
655 | #define AM33XX_ST_DPLL_CLKOUT_SHIFT 9 | ||
656 | #define AM33XX_ST_DPLL_CLKOUT_MASK (1 << 9) | ||
657 | |||
658 | /* Used by CM_DIV_M4_DPLL_CORE */ | ||
659 | #define AM33XX_ST_HSDIVIDER_CLKOUT1_SHIFT 9 | ||
660 | #define AM33XX_ST_HSDIVIDER_CLKOUT1_MASK (1 << 9) | ||
661 | |||
662 | /* Used by CM_DIV_M5_DPLL_CORE */ | ||
663 | #define AM33XX_ST_HSDIVIDER_CLKOUT2_SHIFT 9 | ||
664 | #define AM33XX_ST_HSDIVIDER_CLKOUT2_MASK (1 << 9) | ||
665 | |||
666 | /* Used by CM_DIV_M6_DPLL_CORE */ | ||
667 | #define AM33XX_ST_HSDIVIDER_CLKOUT3_SHIFT 9 | ||
668 | #define AM33XX_ST_HSDIVIDER_CLKOUT3_MASK (1 << 9) | ||
669 | |||
670 | /* | ||
671 | * Used by CM_IDLEST_DPLL_CORE, CM_IDLEST_DPLL_DDR, CM_IDLEST_DPLL_DISP, | ||
672 | * CM_IDLEST_DPLL_MPU, CM_IDLEST_DPLL_PER | ||
673 | */ | ||
674 | #define AM33XX_ST_MN_BYPASS_SHIFT 8 | ||
675 | #define AM33XX_ST_MN_BYPASS_MASK (1 << 8) | ||
676 | |||
677 | /* Used by CM_WKUP_DEBUGSS_CLKCTRL */ | ||
678 | #define AM33XX_TRC_PMD_CLKDIVSEL_SHIFT 24 | ||
679 | #define AM33XX_TRC_PMD_CLKDIVSEL_MASK (0x26 << 24) | ||
680 | |||
681 | /* Used by CM_WKUP_DEBUGSS_CLKCTRL */ | ||
682 | #define AM33XX_TRC_PMD_CLKSEL_SHIFT 20 | ||
683 | #define AM33XX_TRC_PMD_CLKSEL_MASK (0x21 << 20) | ||
684 | |||
685 | /* Used by CONTROL_SEC_CLK_CTRL */ | ||
686 | #define AM33XX_TIMER0_CLKSEL_MASK (0x3 << 4) | ||
687 | #endif | ||
diff --git a/arch/arm/mach-omap2/cm33xx.c b/arch/arm/mach-omap2/cm33xx.c new file mode 100644 index 000000000000..13f56eafef03 --- /dev/null +++ b/arch/arm/mach-omap2/cm33xx.c | |||
@@ -0,0 +1,313 @@ | |||
1 | /* | ||
2 | * AM33XX CM functions | ||
3 | * | ||
4 | * Copyright (C) 2011-2012 Texas Instruments Incorporated - http://www.ti.com/ | ||
5 | * Vaibhav Hiremath <hvaibhav@ti.com> | ||
6 | * | ||
7 | * Reference taken from from OMAP4 cminst44xx.c | ||
8 | * | ||
9 | * This program is free software; you can redistribute it and/or | ||
10 | * modify it under the terms of the GNU General Public License as | ||
11 | * published by the Free Software Foundation version 2. | ||
12 | * | ||
13 | * This program is distributed "as is" WITHOUT ANY WARRANTY of any | ||
14 | * kind, whether express or implied; without even the implied warranty | ||
15 | * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
16 | * GNU General Public License for more details. | ||
17 | */ | ||
18 | |||
19 | #include <linux/kernel.h> | ||
20 | #include <linux/types.h> | ||
21 | #include <linux/errno.h> | ||
22 | #include <linux/err.h> | ||
23 | #include <linux/io.h> | ||
24 | |||
25 | #include <plat/common.h> | ||
26 | |||
27 | #include "cm.h" | ||
28 | #include "cm33xx.h" | ||
29 | #include "cm-regbits-34xx.h" | ||
30 | #include "cm-regbits-33xx.h" | ||
31 | #include "prm33xx.h" | ||
32 | |||
33 | /* | ||
34 | * CLKCTRL_IDLEST_*: possible values for the CM_*_CLKCTRL.IDLEST bitfield: | ||
35 | * | ||
36 | * 0x0 func: Module is fully functional, including OCP | ||
37 | * 0x1 trans: Module is performing transition: wakeup, or sleep, or sleep | ||
38 | * abortion | ||
39 | * 0x2 idle: Module is in Idle mode (only OCP part). It is functional if | ||
40 | * using separate functional clock | ||
41 | * 0x3 disabled: Module is disabled and cannot be accessed | ||
42 | * | ||
43 | */ | ||
44 | #define CLKCTRL_IDLEST_FUNCTIONAL 0x0 | ||
45 | #define CLKCTRL_IDLEST_INTRANSITION 0x1 | ||
46 | #define CLKCTRL_IDLEST_INTERFACE_IDLE 0x2 | ||
47 | #define CLKCTRL_IDLEST_DISABLED 0x3 | ||
48 | |||
49 | /* Private functions */ | ||
50 | |||
51 | /* Read a register in a CM instance */ | ||
52 | static inline u32 am33xx_cm_read_reg(s16 inst, u16 idx) | ||
53 | { | ||
54 | return __raw_readl(cm_base + inst + idx); | ||
55 | } | ||
56 | |||
57 | /* Write into a register in a CM */ | ||
58 | static inline void am33xx_cm_write_reg(u32 val, s16 inst, u16 idx) | ||
59 | { | ||
60 | __raw_writel(val, cm_base + inst + idx); | ||
61 | } | ||
62 | |||
63 | /* Read-modify-write a register in CM */ | ||
64 | static inline u32 am33xx_cm_rmw_reg_bits(u32 mask, u32 bits, s16 inst, s16 idx) | ||
65 | { | ||
66 | u32 v; | ||
67 | |||
68 | v = am33xx_cm_read_reg(inst, idx); | ||
69 | v &= ~mask; | ||
70 | v |= bits; | ||
71 | am33xx_cm_write_reg(v, inst, idx); | ||
72 | |||
73 | return v; | ||
74 | } | ||
75 | |||
76 | static inline u32 am33xx_cm_set_reg_bits(u32 bits, s16 inst, s16 idx) | ||
77 | { | ||
78 | return am33xx_cm_rmw_reg_bits(bits, bits, inst, idx); | ||
79 | } | ||
80 | |||
81 | static inline u32 am33xx_cm_clear_reg_bits(u32 bits, s16 inst, s16 idx) | ||
82 | { | ||
83 | return am33xx_cm_rmw_reg_bits(bits, 0x0, inst, idx); | ||
84 | } | ||
85 | |||
86 | static inline u32 am33xx_cm_read_reg_bits(u16 inst, s16 idx, u32 mask) | ||
87 | { | ||
88 | u32 v; | ||
89 | |||
90 | v = am33xx_cm_read_reg(inst, idx); | ||
91 | v &= mask; | ||
92 | v >>= __ffs(mask); | ||
93 | |||
94 | return v; | ||
95 | } | ||
96 | |||
97 | /** | ||
98 | * _clkctrl_idlest - read a CM_*_CLKCTRL register; mask & shift IDLEST bitfield | ||
99 | * @inst: CM instance register offset (*_INST macro) | ||
100 | * @cdoffs: Clockdomain register offset (*_CDOFFS macro) | ||
101 | * @clkctrl_offs: Module clock control register offset (*_CLKCTRL macro) | ||
102 | * | ||
103 | * Return the IDLEST bitfield of a CM_*_CLKCTRL register, shifted down to | ||
104 | * bit 0. | ||
105 | */ | ||
106 | static u32 _clkctrl_idlest(u16 inst, s16 cdoffs, u16 clkctrl_offs) | ||
107 | { | ||
108 | u32 v = am33xx_cm_read_reg(inst, clkctrl_offs); | ||
109 | v &= AM33XX_IDLEST_MASK; | ||
110 | v >>= AM33XX_IDLEST_SHIFT; | ||
111 | return v; | ||
112 | } | ||
113 | |||
114 | /** | ||
115 | * _is_module_ready - can module registers be accessed without causing an abort? | ||
116 | * @inst: CM instance register offset (*_INST macro) | ||
117 | * @cdoffs: Clockdomain register offset (*_CDOFFS macro) | ||
118 | * @clkctrl_offs: Module clock control register offset (*_CLKCTRL macro) | ||
119 | * | ||
120 | * Returns true if the module's CM_*_CLKCTRL.IDLEST bitfield is either | ||
121 | * *FUNCTIONAL or *INTERFACE_IDLE; false otherwise. | ||
122 | */ | ||
123 | static bool _is_module_ready(u16 inst, s16 cdoffs, u16 clkctrl_offs) | ||
124 | { | ||
125 | u32 v; | ||
126 | |||
127 | v = _clkctrl_idlest(inst, cdoffs, clkctrl_offs); | ||
128 | |||
129 | return (v == CLKCTRL_IDLEST_FUNCTIONAL || | ||
130 | v == CLKCTRL_IDLEST_INTERFACE_IDLE) ? true : false; | ||
131 | } | ||
132 | |||
133 | /** | ||
134 | * _clktrctrl_write - write @c to a CM_CLKSTCTRL.CLKTRCTRL register bitfield | ||
135 | * @c: CLKTRCTRL register bitfield (LSB = bit 0, i.e., unshifted) | ||
136 | * @inst: CM instance register offset (*_INST macro) | ||
137 | * @cdoffs: Clockdomain register offset (*_CDOFFS macro) | ||
138 | * | ||
139 | * @c must be the unshifted value for CLKTRCTRL - i.e., this function | ||
140 | * will handle the shift itself. | ||
141 | */ | ||
142 | static void _clktrctrl_write(u8 c, s16 inst, u16 cdoffs) | ||
143 | { | ||
144 | u32 v; | ||
145 | |||
146 | v = am33xx_cm_read_reg(inst, cdoffs); | ||
147 | v &= ~AM33XX_CLKTRCTRL_MASK; | ||
148 | v |= c << AM33XX_CLKTRCTRL_SHIFT; | ||
149 | am33xx_cm_write_reg(v, inst, cdoffs); | ||
150 | } | ||
151 | |||
152 | /* Public functions */ | ||
153 | |||
154 | /** | ||
155 | * am33xx_cm_is_clkdm_in_hwsup - is a clockdomain in hwsup idle mode? | ||
156 | * @inst: CM instance register offset (*_INST macro) | ||
157 | * @cdoffs: Clockdomain register offset (*_CDOFFS macro) | ||
158 | * | ||
159 | * Returns true if the clockdomain referred to by (@inst, @cdoffs) | ||
160 | * is in hardware-supervised idle mode, or 0 otherwise. | ||
161 | */ | ||
162 | bool am33xx_cm_is_clkdm_in_hwsup(s16 inst, u16 cdoffs) | ||
163 | { | ||
164 | u32 v; | ||
165 | |||
166 | v = am33xx_cm_read_reg(inst, cdoffs); | ||
167 | v &= AM33XX_CLKTRCTRL_MASK; | ||
168 | v >>= AM33XX_CLKTRCTRL_SHIFT; | ||
169 | |||
170 | return (v == OMAP34XX_CLKSTCTRL_ENABLE_AUTO) ? true : false; | ||
171 | } | ||
172 | |||
173 | /** | ||
174 | * am33xx_cm_clkdm_enable_hwsup - put a clockdomain in hwsup-idle mode | ||
175 | * @inst: CM instance register offset (*_INST macro) | ||
176 | * @cdoffs: Clockdomain register offset (*_CDOFFS macro) | ||
177 | * | ||
178 | * Put a clockdomain referred to by (@inst, @cdoffs) into | ||
179 | * hardware-supervised idle mode. No return value. | ||
180 | */ | ||
181 | void am33xx_cm_clkdm_enable_hwsup(s16 inst, u16 cdoffs) | ||
182 | { | ||
183 | _clktrctrl_write(OMAP34XX_CLKSTCTRL_ENABLE_AUTO, inst, cdoffs); | ||
184 | } | ||
185 | |||
186 | /** | ||
187 | * am33xx_cm_clkdm_disable_hwsup - put a clockdomain in swsup-idle mode | ||
188 | * @inst: CM instance register offset (*_INST macro) | ||
189 | * @cdoffs: Clockdomain register offset (*_CDOFFS macro) | ||
190 | * | ||
191 | * Put a clockdomain referred to by (@inst, @cdoffs) into | ||
192 | * software-supervised idle mode, i.e., controlled manually by the | ||
193 | * Linux OMAP clockdomain code. No return value. | ||
194 | */ | ||
195 | void am33xx_cm_clkdm_disable_hwsup(s16 inst, u16 cdoffs) | ||
196 | { | ||
197 | _clktrctrl_write(OMAP34XX_CLKSTCTRL_DISABLE_AUTO, inst, cdoffs); | ||
198 | } | ||
199 | |||
200 | /** | ||
201 | * am33xx_cm_clkdm_force_sleep - try to put a clockdomain into idle | ||
202 | * @inst: CM instance register offset (*_INST macro) | ||
203 | * @cdoffs: Clockdomain register offset (*_CDOFFS macro) | ||
204 | * | ||
205 | * Put a clockdomain referred to by (@inst, @cdoffs) into idle | ||
206 | * No return value. | ||
207 | */ | ||
208 | void am33xx_cm_clkdm_force_sleep(s16 inst, u16 cdoffs) | ||
209 | { | ||
210 | _clktrctrl_write(OMAP34XX_CLKSTCTRL_FORCE_SLEEP, inst, cdoffs); | ||
211 | } | ||
212 | |||
213 | /** | ||
214 | * am33xx_cm_clkdm_force_wakeup - try to take a clockdomain out of idle | ||
215 | * @inst: CM instance register offset (*_INST macro) | ||
216 | * @cdoffs: Clockdomain register offset (*_CDOFFS macro) | ||
217 | * | ||
218 | * Take a clockdomain referred to by (@inst, @cdoffs) out of idle, | ||
219 | * waking it up. No return value. | ||
220 | */ | ||
221 | void am33xx_cm_clkdm_force_wakeup(s16 inst, u16 cdoffs) | ||
222 | { | ||
223 | _clktrctrl_write(OMAP34XX_CLKSTCTRL_FORCE_WAKEUP, inst, cdoffs); | ||
224 | } | ||
225 | |||
226 | /* | ||
227 | * | ||
228 | */ | ||
229 | |||
230 | /** | ||
231 | * am33xx_cm_wait_module_ready - wait for a module to be in 'func' state | ||
232 | * @inst: CM instance register offset (*_INST macro) | ||
233 | * @cdoffs: Clockdomain register offset (*_CDOFFS macro) | ||
234 | * @clkctrl_offs: Module clock control register offset (*_CLKCTRL macro) | ||
235 | * | ||
236 | * Wait for the module IDLEST to be functional. If the idle state is in any | ||
237 | * the non functional state (trans, idle or disabled), module and thus the | ||
238 | * sysconfig cannot be accessed and will probably lead to an "imprecise | ||
239 | * external abort" | ||
240 | */ | ||
241 | int am33xx_cm_wait_module_ready(u16 inst, s16 cdoffs, u16 clkctrl_offs) | ||
242 | { | ||
243 | int i = 0; | ||
244 | |||
245 | if (!clkctrl_offs) | ||
246 | return 0; | ||
247 | |||
248 | omap_test_timeout(_is_module_ready(inst, cdoffs, clkctrl_offs), | ||
249 | MAX_MODULE_READY_TIME, i); | ||
250 | |||
251 | return (i < MAX_MODULE_READY_TIME) ? 0 : -EBUSY; | ||
252 | } | ||
253 | |||
254 | /** | ||
255 | * am33xx_cm_wait_module_idle - wait for a module to be in 'disabled' | ||
256 | * state | ||
257 | * @inst: CM instance register offset (*_INST macro) | ||
258 | * @cdoffs: Clockdomain register offset (*_CDOFFS macro) | ||
259 | * @clkctrl_offs: Module clock control register offset (*_CLKCTRL macro) | ||
260 | * | ||
261 | * Wait for the module IDLEST to be disabled. Some PRCM transition, | ||
262 | * like reset assertion or parent clock de-activation must wait the | ||
263 | * module to be fully disabled. | ||
264 | */ | ||
265 | int am33xx_cm_wait_module_idle(u16 inst, s16 cdoffs, u16 clkctrl_offs) | ||
266 | { | ||
267 | int i = 0; | ||
268 | |||
269 | if (!clkctrl_offs) | ||
270 | return 0; | ||
271 | |||
272 | omap_test_timeout((_clkctrl_idlest(inst, cdoffs, clkctrl_offs) == | ||
273 | CLKCTRL_IDLEST_DISABLED), | ||
274 | MAX_MODULE_READY_TIME, i); | ||
275 | |||
276 | return (i < MAX_MODULE_READY_TIME) ? 0 : -EBUSY; | ||
277 | } | ||
278 | |||
279 | /** | ||
280 | * am33xx_cm_module_enable - Enable the modulemode inside CLKCTRL | ||
281 | * @mode: Module mode (SW or HW) | ||
282 | * @inst: CM instance register offset (*_INST macro) | ||
283 | * @cdoffs: Clockdomain register offset (*_CDOFFS macro) | ||
284 | * @clkctrl_offs: Module clock control register offset (*_CLKCTRL macro) | ||
285 | * | ||
286 | * No return value. | ||
287 | */ | ||
288 | void am33xx_cm_module_enable(u8 mode, u16 inst, s16 cdoffs, u16 clkctrl_offs) | ||
289 | { | ||
290 | u32 v; | ||
291 | |||
292 | v = am33xx_cm_read_reg(inst, clkctrl_offs); | ||
293 | v &= ~AM33XX_MODULEMODE_MASK; | ||
294 | v |= mode << AM33XX_MODULEMODE_SHIFT; | ||
295 | am33xx_cm_write_reg(v, inst, clkctrl_offs); | ||
296 | } | ||
297 | |||
298 | /** | ||
299 | * am33xx_cm_module_disable - Disable the module inside CLKCTRL | ||
300 | * @inst: CM instance register offset (*_INST macro) | ||
301 | * @cdoffs: Clockdomain register offset (*_CDOFFS macro) | ||
302 | * @clkctrl_offs: Module clock control register offset (*_CLKCTRL macro) | ||
303 | * | ||
304 | * No return value. | ||
305 | */ | ||
306 | void am33xx_cm_module_disable(u16 inst, s16 cdoffs, u16 clkctrl_offs) | ||
307 | { | ||
308 | u32 v; | ||
309 | |||
310 | v = am33xx_cm_read_reg(inst, clkctrl_offs); | ||
311 | v &= ~AM33XX_MODULEMODE_MASK; | ||
312 | am33xx_cm_write_reg(v, inst, clkctrl_offs); | ||
313 | } | ||
diff --git a/arch/arm/mach-omap2/cm33xx.h b/arch/arm/mach-omap2/cm33xx.h new file mode 100644 index 000000000000..5fa0b62e1a79 --- /dev/null +++ b/arch/arm/mach-omap2/cm33xx.h | |||
@@ -0,0 +1,420 @@ | |||
1 | /* | ||
2 | * AM33XX CM offset macros | ||
3 | * | ||
4 | * Copyright (C) 2011-2012 Texas Instruments Incorporated - http://www.ti.com/ | ||
5 | * Vaibhav Hiremath <hvaibhav@ti.com> | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or | ||
8 | * modify it under the terms of the GNU General Public License as | ||
9 | * published by the Free Software Foundation version 2. | ||
10 | * | ||
11 | * This program is distributed "as is" WITHOUT ANY WARRANTY of any | ||
12 | * kind, whether express or implied; without even the implied warranty | ||
13 | * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
14 | * GNU General Public License for more details. | ||
15 | */ | ||
16 | |||
17 | #ifndef __ARCH_ARM_MACH_OMAP2_CM_33XX_H | ||
18 | #define __ARCH_ARM_MACH_OMAP2_CM_33XX_H | ||
19 | |||
20 | #include <linux/delay.h> | ||
21 | #include <linux/errno.h> | ||
22 | #include <linux/err.h> | ||
23 | #include <linux/io.h> | ||
24 | |||
25 | #include "common.h" | ||
26 | |||
27 | #include "cm.h" | ||
28 | #include "cm-regbits-33xx.h" | ||
29 | #include "cm33xx.h" | ||
30 | |||
31 | /* CM base address */ | ||
32 | #define AM33XX_CM_BASE 0x44e00000 | ||
33 | |||
34 | #define AM33XX_CM_REGADDR(inst, reg) \ | ||
35 | AM33XX_L4_WK_IO_ADDRESS(AM33XX_CM_BASE + (inst) + (reg)) | ||
36 | |||
37 | /* CM instances */ | ||
38 | #define AM33XX_CM_PER_MOD 0x0000 | ||
39 | #define AM33XX_CM_WKUP_MOD 0x0400 | ||
40 | #define AM33XX_CM_DPLL_MOD 0x0500 | ||
41 | #define AM33XX_CM_MPU_MOD 0x0600 | ||
42 | #define AM33XX_CM_DEVICE_MOD 0x0700 | ||
43 | #define AM33XX_CM_RTC_MOD 0x0800 | ||
44 | #define AM33XX_CM_GFX_MOD 0x0900 | ||
45 | #define AM33XX_CM_CEFUSE_MOD 0x0A00 | ||
46 | |||
47 | /* CM */ | ||
48 | |||
49 | /* CM.PER_CM register offsets */ | ||
50 | #define AM33XX_CM_PER_L4LS_CLKSTCTRL_OFFSET 0x0000 | ||
51 | #define AM33XX_CM_PER_L4LS_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0000) | ||
52 | #define AM33XX_CM_PER_L3S_CLKSTCTRL_OFFSET 0x0004 | ||
53 | #define AM33XX_CM_PER_L3S_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0004) | ||
54 | #define AM33XX_CM_PER_L4FW_CLKSTCTRL_OFFSET 0x0008 | ||
55 | #define AM33XX_CM_PER_L4FW_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0008) | ||
56 | #define AM33XX_CM_PER_L3_CLKSTCTRL_OFFSET 0x000c | ||
57 | #define AM33XX_CM_PER_L3_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x000c) | ||
58 | #define AM33XX_CM_PER_CPGMAC0_CLKCTRL_OFFSET 0x0014 | ||
59 | #define AM33XX_CM_PER_CPGMAC0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0014) | ||
60 | #define AM33XX_CM_PER_LCDC_CLKCTRL_OFFSET 0x0018 | ||
61 | #define AM33XX_CM_PER_LCDC_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0018) | ||
62 | #define AM33XX_CM_PER_USB0_CLKCTRL_OFFSET 0x001c | ||
63 | #define AM33XX_CM_PER_USB0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x001c) | ||
64 | #define AM33XX_CM_PER_MLB_CLKCTRL_OFFSET 0x0020 | ||
65 | #define AM33XX_CM_PER_MLB_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0020) | ||
66 | #define AM33XX_CM_PER_TPTC0_CLKCTRL_OFFSET 0x0024 | ||
67 | #define AM33XX_CM_PER_TPTC0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0024) | ||
68 | #define AM33XX_CM_PER_EMIF_CLKCTRL_OFFSET 0x0028 | ||
69 | #define AM33XX_CM_PER_EMIF_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0028) | ||
70 | #define AM33XX_CM_PER_OCMCRAM_CLKCTRL_OFFSET 0x002c | ||
71 | #define AM33XX_CM_PER_OCMCRAM_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x002c) | ||
72 | #define AM33XX_CM_PER_GPMC_CLKCTRL_OFFSET 0x0030 | ||
73 | #define AM33XX_CM_PER_GPMC_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0030) | ||
74 | #define AM33XX_CM_PER_MCASP0_CLKCTRL_OFFSET 0x0034 | ||
75 | #define AM33XX_CM_PER_MCASP0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0034) | ||
76 | #define AM33XX_CM_PER_UART5_CLKCTRL_OFFSET 0x0038 | ||
77 | #define AM33XX_CM_PER_UART5_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0038) | ||
78 | #define AM33XX_CM_PER_MMC0_CLKCTRL_OFFSET 0x003c | ||
79 | #define AM33XX_CM_PER_MMC0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x003c) | ||
80 | #define AM33XX_CM_PER_ELM_CLKCTRL_OFFSET 0x0040 | ||
81 | #define AM33XX_CM_PER_ELM_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0040) | ||
82 | #define AM33XX_CM_PER_I2C2_CLKCTRL_OFFSET 0x0044 | ||
83 | #define AM33XX_CM_PER_I2C2_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0044) | ||
84 | #define AM33XX_CM_PER_I2C1_CLKCTRL_OFFSET 0x0048 | ||
85 | #define AM33XX_CM_PER_I2C1_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0048) | ||
86 | #define AM33XX_CM_PER_SPI0_CLKCTRL_OFFSET 0x004c | ||
87 | #define AM33XX_CM_PER_SPI0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x004c) | ||
88 | #define AM33XX_CM_PER_SPI1_CLKCTRL_OFFSET 0x0050 | ||
89 | #define AM33XX_CM_PER_SPI1_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0050) | ||
90 | #define AM33XX_CM_PER_SPI2_CLKCTRL_OFFSET 0x0054 | ||
91 | #define AM33XX_CM_PER_SPI2_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0054) | ||
92 | #define AM33XX_CM_PER_SPI3_CLKCTRL_OFFSET 0x0058 | ||
93 | #define AM33XX_CM_PER_SPI3_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0058) | ||
94 | #define AM33XX_CM_PER_L4LS_CLKCTRL_OFFSET 0x0060 | ||
95 | #define AM33XX_CM_PER_L4LS_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0060) | ||
96 | #define AM33XX_CM_PER_L4FW_CLKCTRL_OFFSET 0x0064 | ||
97 | #define AM33XX_CM_PER_L4FW_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0064) | ||
98 | #define AM33XX_CM_PER_MCASP1_CLKCTRL_OFFSET 0x0068 | ||
99 | #define AM33XX_CM_PER_MCASP1_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0068) | ||
100 | #define AM33XX_CM_PER_UART1_CLKCTRL_OFFSET 0x006c | ||
101 | #define AM33XX_CM_PER_UART1_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x006c) | ||
102 | #define AM33XX_CM_PER_UART2_CLKCTRL_OFFSET 0x0070 | ||
103 | #define AM33XX_CM_PER_UART2_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0070) | ||
104 | #define AM33XX_CM_PER_UART3_CLKCTRL_OFFSET 0x0074 | ||
105 | #define AM33XX_CM_PER_UART3_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0074) | ||
106 | #define AM33XX_CM_PER_UART4_CLKCTRL_OFFSET 0x0078 | ||
107 | #define AM33XX_CM_PER_UART4_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0078) | ||
108 | #define AM33XX_CM_PER_TIMER7_CLKCTRL_OFFSET 0x007c | ||
109 | #define AM33XX_CM_PER_TIMER7_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x007c) | ||
110 | #define AM33XX_CM_PER_TIMER2_CLKCTRL_OFFSET 0x0080 | ||
111 | #define AM33XX_CM_PER_TIMER2_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0080) | ||
112 | #define AM33XX_CM_PER_TIMER3_CLKCTRL_OFFSET 0x0084 | ||
113 | #define AM33XX_CM_PER_TIMER3_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0084) | ||
114 | #define AM33XX_CM_PER_TIMER4_CLKCTRL_OFFSET 0x0088 | ||
115 | #define AM33XX_CM_PER_TIMER4_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0088) | ||
116 | #define AM33XX_CM_PER_MCASP2_CLKCTRL_OFFSET 0x008c | ||
117 | #define AM33XX_CM_PER_MCASP2_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x008c) | ||
118 | #define AM33XX_CM_PER_RNG_CLKCTRL_OFFSET 0x0090 | ||
119 | #define AM33XX_CM_PER_RNG_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0090) | ||
120 | #define AM33XX_CM_PER_AES0_CLKCTRL_OFFSET 0x0094 | ||
121 | #define AM33XX_CM_PER_AES0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0094) | ||
122 | #define AM33XX_CM_PER_AES1_CLKCTRL_OFFSET 0x0098 | ||
123 | #define AM33XX_CM_PER_AES1_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0098) | ||
124 | #define AM33XX_CM_PER_DES_CLKCTRL_OFFSET 0x009c | ||
125 | #define AM33XX_CM_PER_DES_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x009c) | ||
126 | #define AM33XX_CM_PER_SHA0_CLKCTRL_OFFSET 0x00a0 | ||
127 | #define AM33XX_CM_PER_SHA0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00a0) | ||
128 | #define AM33XX_CM_PER_PKA_CLKCTRL_OFFSET 0x00a4 | ||
129 | #define AM33XX_CM_PER_PKA_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00a4) | ||
130 | #define AM33XX_CM_PER_GPIO6_CLKCTRL_OFFSET 0x00a8 | ||
131 | #define AM33XX_CM_PER_GPIO6_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00a8) | ||
132 | #define AM33XX_CM_PER_GPIO1_CLKCTRL_OFFSET 0x00ac | ||
133 | #define AM33XX_CM_PER_GPIO1_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00ac) | ||
134 | #define AM33XX_CM_PER_GPIO2_CLKCTRL_OFFSET 0x00b0 | ||
135 | #define AM33XX_CM_PER_GPIO2_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00b0) | ||
136 | #define AM33XX_CM_PER_GPIO3_CLKCTRL_OFFSET 0x00b4 | ||
137 | #define AM33XX_CM_PER_GPIO3_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00b4) | ||
138 | #define AM33XX_CM_PER_GPIO4_CLKCTRL_OFFSET 0x00b8 | ||
139 | #define AM33XX_CM_PER_GPIO4_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00b8) | ||
140 | #define AM33XX_CM_PER_TPCC_CLKCTRL_OFFSET 0x00bc | ||
141 | #define AM33XX_CM_PER_TPCC_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00bc) | ||
142 | #define AM33XX_CM_PER_DCAN0_CLKCTRL_OFFSET 0x00c0 | ||
143 | #define AM33XX_CM_PER_DCAN0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00c0) | ||
144 | #define AM33XX_CM_PER_DCAN1_CLKCTRL_OFFSET 0x00c4 | ||
145 | #define AM33XX_CM_PER_DCAN1_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00c4) | ||
146 | #define AM33XX_CM_PER_EPWMSS1_CLKCTRL_OFFSET 0x00cc | ||
147 | #define AM33XX_CM_PER_EPWMSS1_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00cc) | ||
148 | #define AM33XX_CM_PER_EMIF_FW_CLKCTRL_OFFSET 0x00d0 | ||
149 | #define AM33XX_CM_PER_EMIF_FW_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00d0) | ||
150 | #define AM33XX_CM_PER_EPWMSS0_CLKCTRL_OFFSET 0x00d4 | ||
151 | #define AM33XX_CM_PER_EPWMSS0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00d4) | ||
152 | #define AM33XX_CM_PER_EPWMSS2_CLKCTRL_OFFSET 0x00d8 | ||
153 | #define AM33XX_CM_PER_EPWMSS2_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00d8) | ||
154 | #define AM33XX_CM_PER_L3_INSTR_CLKCTRL_OFFSET 0x00dc | ||
155 | #define AM33XX_CM_PER_L3_INSTR_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00dc) | ||
156 | #define AM33XX_CM_PER_L3_CLKCTRL_OFFSET 0x00e0 | ||
157 | #define AM33XX_CM_PER_L3_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00e0) | ||
158 | #define AM33XX_CM_PER_IEEE5000_CLKCTRL_OFFSET 0x00e4 | ||
159 | #define AM33XX_CM_PER_IEEE5000_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00e4) | ||
160 | #define AM33XX_CM_PER_PRUSS_CLKCTRL_OFFSET 0x00e8 | ||
161 | #define AM33XX_CM_PER_PRUSS_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00e8) | ||
162 | #define AM33XX_CM_PER_TIMER5_CLKCTRL_OFFSET 0x00ec | ||
163 | #define AM33XX_CM_PER_TIMER5_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00ec) | ||
164 | #define AM33XX_CM_PER_TIMER6_CLKCTRL_OFFSET 0x00f0 | ||
165 | #define AM33XX_CM_PER_TIMER6_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00f0) | ||
166 | #define AM33XX_CM_PER_MMC1_CLKCTRL_OFFSET 0x00f4 | ||
167 | #define AM33XX_CM_PER_MMC1_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00f4) | ||
168 | #define AM33XX_CM_PER_MMC2_CLKCTRL_OFFSET 0x00f8 | ||
169 | #define AM33XX_CM_PER_MMC2_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00f8) | ||
170 | #define AM33XX_CM_PER_TPTC1_CLKCTRL_OFFSET 0x00fc | ||
171 | #define AM33XX_CM_PER_TPTC1_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x00fc) | ||
172 | #define AM33XX_CM_PER_TPTC2_CLKCTRL_OFFSET 0x0100 | ||
173 | #define AM33XX_CM_PER_TPTC2_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0100) | ||
174 | #define AM33XX_CM_PER_GPIO5_CLKCTRL_OFFSET 0x0104 | ||
175 | #define AM33XX_CM_PER_GPIO5_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0104) | ||
176 | #define AM33XX_CM_PER_SPINLOCK_CLKCTRL_OFFSET 0x010c | ||
177 | #define AM33XX_CM_PER_SPINLOCK_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x010c) | ||
178 | #define AM33XX_CM_PER_MAILBOX0_CLKCTRL_OFFSET 0x0110 | ||
179 | #define AM33XX_CM_PER_MAILBOX0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0110) | ||
180 | #define AM33XX_CM_PER_L4HS_CLKSTCTRL_OFFSET 0x011c | ||
181 | #define AM33XX_CM_PER_L4HS_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x011c) | ||
182 | #define AM33XX_CM_PER_L4HS_CLKCTRL_OFFSET 0x0120 | ||
183 | #define AM33XX_CM_PER_L4HS_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0120) | ||
184 | #define AM33XX_CM_PER_MSTR_EXPS_CLKCTRL_OFFSET 0x0124 | ||
185 | #define AM33XX_CM_PER_MSTR_EXPS_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0124) | ||
186 | #define AM33XX_CM_PER_SLV_EXPS_CLKCTRL_OFFSET 0x0128 | ||
187 | #define AM33XX_CM_PER_SLV_EXPS_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0128) | ||
188 | #define AM33XX_CM_PER_OCPWP_L3_CLKSTCTRL_OFFSET 0x012c | ||
189 | #define AM33XX_CM_PER_OCPWP_L3_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x012c) | ||
190 | #define AM33XX_CM_PER_OCPWP_CLKCTRL_OFFSET 0x0130 | ||
191 | #define AM33XX_CM_PER_OCPWP_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0130) | ||
192 | #define AM33XX_CM_PER_MAILBOX1_CLKCTRL_OFFSET 0x0134 | ||
193 | #define AM33XX_CM_PER_MAILBOX1_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0134) | ||
194 | #define AM33XX_CM_PER_PRUSS_CLKSTCTRL_OFFSET 0x0140 | ||
195 | #define AM33XX_CM_PER_PRUSS_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0140) | ||
196 | #define AM33XX_CM_PER_CPSW_CLKSTCTRL_OFFSET 0x0144 | ||
197 | #define AM33XX_CM_PER_CPSW_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0144) | ||
198 | #define AM33XX_CM_PER_LCDC_CLKSTCTRL_OFFSET 0x0148 | ||
199 | #define AM33XX_CM_PER_LCDC_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0148) | ||
200 | #define AM33XX_CM_PER_CLKDIV32K_CLKCTRL_OFFSET 0x014c | ||
201 | #define AM33XX_CM_PER_CLKDIV32K_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x014c) | ||
202 | #define AM33XX_CM_PER_CLK_24MHZ_CLKSTCTRL_OFFSET 0x0150 | ||
203 | #define AM33XX_CM_PER_CLK_24MHZ_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_PER_MOD, 0x0150) | ||
204 | |||
205 | /* CM.WKUP_CM register offsets */ | ||
206 | #define AM33XX_CM_WKUP_CLKSTCTRL_OFFSET 0x0000 | ||
207 | #define AM33XX_CM_WKUP_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0000) | ||
208 | #define AM33XX_CM_WKUP_CONTROL_CLKCTRL_OFFSET 0x0004 | ||
209 | #define AM33XX_CM_WKUP_CONTROL_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0004) | ||
210 | #define AM33XX_CM_WKUP_GPIO0_CLKCTRL_OFFSET 0x0008 | ||
211 | #define AM33XX_CM_WKUP_GPIO0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0008) | ||
212 | #define AM33XX_CM_WKUP_L4WKUP_CLKCTRL_OFFSET 0x000c | ||
213 | #define AM33XX_CM_WKUP_L4WKUP_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x000c) | ||
214 | #define AM33XX_CM_WKUP_TIMER0_CLKCTRL_OFFSET 0x0010 | ||
215 | #define AM33XX_CM_WKUP_TIMER0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0010) | ||
216 | #define AM33XX_CM_WKUP_DEBUGSS_CLKCTRL_OFFSET 0x0014 | ||
217 | #define AM33XX_CM_WKUP_DEBUGSS_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0014) | ||
218 | #define AM33XX_CM_L3_AON_CLKSTCTRL_OFFSET 0x0018 | ||
219 | #define AM33XX_CM_L3_AON_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0018) | ||
220 | #define AM33XX_CM_AUTOIDLE_DPLL_MPU_OFFSET 0x001c | ||
221 | #define AM33XX_CM_AUTOIDLE_DPLL_MPU AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x001c) | ||
222 | #define AM33XX_CM_IDLEST_DPLL_MPU_OFFSET 0x0020 | ||
223 | #define AM33XX_CM_IDLEST_DPLL_MPU AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0020) | ||
224 | #define AM33XX_CM_SSC_DELTAMSTEP_DPLL_MPU_OFFSET 0x0024 | ||
225 | #define AM33XX_CM_SSC_DELTAMSTEP_DPLL_MPU AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0024) | ||
226 | #define AM33XX_CM_SSC_MODFREQDIV_DPLL_MPU_OFFSET 0x0028 | ||
227 | #define AM33XX_CM_SSC_MODFREQDIV_DPLL_MPU AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0028) | ||
228 | #define AM33XX_CM_CLKSEL_DPLL_MPU_OFFSET 0x002c | ||
229 | #define AM33XX_CM_CLKSEL_DPLL_MPU AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x002c) | ||
230 | #define AM33XX_CM_AUTOIDLE_DPLL_DDR_OFFSET 0x0030 | ||
231 | #define AM33XX_CM_AUTOIDLE_DPLL_DDR AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0030) | ||
232 | #define AM33XX_CM_IDLEST_DPLL_DDR_OFFSET 0x0034 | ||
233 | #define AM33XX_CM_IDLEST_DPLL_DDR AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0034) | ||
234 | #define AM33XX_CM_SSC_DELTAMSTEP_DPLL_DDR_OFFSET 0x0038 | ||
235 | #define AM33XX_CM_SSC_DELTAMSTEP_DPLL_DDR AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0038) | ||
236 | #define AM33XX_CM_SSC_MODFREQDIV_DPLL_DDR_OFFSET 0x003c | ||
237 | #define AM33XX_CM_SSC_MODFREQDIV_DPLL_DDR AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x003c) | ||
238 | #define AM33XX_CM_CLKSEL_DPLL_DDR_OFFSET 0x0040 | ||
239 | #define AM33XX_CM_CLKSEL_DPLL_DDR AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0040) | ||
240 | #define AM33XX_CM_AUTOIDLE_DPLL_DISP_OFFSET 0x0044 | ||
241 | #define AM33XX_CM_AUTOIDLE_DPLL_DISP AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0044) | ||
242 | #define AM33XX_CM_IDLEST_DPLL_DISP_OFFSET 0x0048 | ||
243 | #define AM33XX_CM_IDLEST_DPLL_DISP AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0048) | ||
244 | #define AM33XX_CM_SSC_DELTAMSTEP_DPLL_DISP_OFFSET 0x004c | ||
245 | #define AM33XX_CM_SSC_DELTAMSTEP_DPLL_DISP AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x004c) | ||
246 | #define AM33XX_CM_SSC_MODFREQDIV_DPLL_DISP_OFFSET 0x0050 | ||
247 | #define AM33XX_CM_SSC_MODFREQDIV_DPLL_DISP AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0050) | ||
248 | #define AM33XX_CM_CLKSEL_DPLL_DISP_OFFSET 0x0054 | ||
249 | #define AM33XX_CM_CLKSEL_DPLL_DISP AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0054) | ||
250 | #define AM33XX_CM_AUTOIDLE_DPLL_CORE_OFFSET 0x0058 | ||
251 | #define AM33XX_CM_AUTOIDLE_DPLL_CORE AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0058) | ||
252 | #define AM33XX_CM_IDLEST_DPLL_CORE_OFFSET 0x005c | ||
253 | #define AM33XX_CM_IDLEST_DPLL_CORE AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x005c) | ||
254 | #define AM33XX_CM_SSC_DELTAMSTEP_DPLL_CORE_OFFSET 0x0060 | ||
255 | #define AM33XX_CM_SSC_DELTAMSTEP_DPLL_CORE AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0060) | ||
256 | #define AM33XX_CM_SSC_MODFREQDIV_DPLL_CORE_OFFSET 0x0064 | ||
257 | #define AM33XX_CM_SSC_MODFREQDIV_DPLL_CORE AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0064) | ||
258 | #define AM33XX_CM_CLKSEL_DPLL_CORE_OFFSET 0x0068 | ||
259 | #define AM33XX_CM_CLKSEL_DPLL_CORE AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0068) | ||
260 | #define AM33XX_CM_AUTOIDLE_DPLL_PER_OFFSET 0x006c | ||
261 | #define AM33XX_CM_AUTOIDLE_DPLL_PER AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x006c) | ||
262 | #define AM33XX_CM_IDLEST_DPLL_PER_OFFSET 0x0070 | ||
263 | #define AM33XX_CM_IDLEST_DPLL_PER AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0070) | ||
264 | #define AM33XX_CM_SSC_DELTAMSTEP_DPLL_PER_OFFSET 0x0074 | ||
265 | #define AM33XX_CM_SSC_DELTAMSTEP_DPLL_PER AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0074) | ||
266 | #define AM33XX_CM_SSC_MODFREQDIV_DPLL_PER_OFFSET 0x0078 | ||
267 | #define AM33XX_CM_SSC_MODFREQDIV_DPLL_PER AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0078) | ||
268 | #define AM33XX_CM_CLKDCOLDO_DPLL_PER_OFFSET 0x007c | ||
269 | #define AM33XX_CM_CLKDCOLDO_DPLL_PER AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x007c) | ||
270 | #define AM33XX_CM_DIV_M4_DPLL_CORE_OFFSET 0x0080 | ||
271 | #define AM33XX_CM_DIV_M4_DPLL_CORE AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0080) | ||
272 | #define AM33XX_CM_DIV_M5_DPLL_CORE_OFFSET 0x0084 | ||
273 | #define AM33XX_CM_DIV_M5_DPLL_CORE AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0084) | ||
274 | #define AM33XX_CM_CLKMODE_DPLL_MPU_OFFSET 0x0088 | ||
275 | #define AM33XX_CM_CLKMODE_DPLL_MPU AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0088) | ||
276 | #define AM33XX_CM_CLKMODE_DPLL_PER_OFFSET 0x008c | ||
277 | #define AM33XX_CM_CLKMODE_DPLL_PER AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x008c) | ||
278 | #define AM33XX_CM_CLKMODE_DPLL_CORE_OFFSET 0x0090 | ||
279 | #define AM33XX_CM_CLKMODE_DPLL_CORE AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0090) | ||
280 | #define AM33XX_CM_CLKMODE_DPLL_DDR_OFFSET 0x0094 | ||
281 | #define AM33XX_CM_CLKMODE_DPLL_DDR AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0094) | ||
282 | #define AM33XX_CM_CLKMODE_DPLL_DISP_OFFSET 0x0098 | ||
283 | #define AM33XX_CM_CLKMODE_DPLL_DISP AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x0098) | ||
284 | #define AM33XX_CM_CLKSEL_DPLL_PERIPH_OFFSET 0x009c | ||
285 | #define AM33XX_CM_CLKSEL_DPLL_PERIPH AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x009c) | ||
286 | #define AM33XX_CM_DIV_M2_DPLL_DDR_OFFSET 0x00a0 | ||
287 | #define AM33XX_CM_DIV_M2_DPLL_DDR AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x00a0) | ||
288 | #define AM33XX_CM_DIV_M2_DPLL_DISP_OFFSET 0x00a4 | ||
289 | #define AM33XX_CM_DIV_M2_DPLL_DISP AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x00a4) | ||
290 | #define AM33XX_CM_DIV_M2_DPLL_MPU_OFFSET 0x00a8 | ||
291 | #define AM33XX_CM_DIV_M2_DPLL_MPU AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x00a8) | ||
292 | #define AM33XX_CM_DIV_M2_DPLL_PER_OFFSET 0x00ac | ||
293 | #define AM33XX_CM_DIV_M2_DPLL_PER AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x00ac) | ||
294 | #define AM33XX_CM_WKUP_WKUP_M3_CLKCTRL_OFFSET 0x00b0 | ||
295 | #define AM33XX_CM_WKUP_WKUP_M3_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x00b0) | ||
296 | #define AM33XX_CM_WKUP_UART0_CLKCTRL_OFFSET 0x00b4 | ||
297 | #define AM33XX_CM_WKUP_UART0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x00b4) | ||
298 | #define AM33XX_CM_WKUP_I2C0_CLKCTRL_OFFSET 0x00b8 | ||
299 | #define AM33XX_CM_WKUP_I2C0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x00b8) | ||
300 | #define AM33XX_CM_WKUP_ADC_TSC_CLKCTRL_OFFSET 0x00bc | ||
301 | #define AM33XX_CM_WKUP_ADC_TSC_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x00bc) | ||
302 | #define AM33XX_CM_WKUP_SMARTREFLEX0_CLKCTRL_OFFSET 0x00c0 | ||
303 | #define AM33XX_CM_WKUP_SMARTREFLEX0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x00c0) | ||
304 | #define AM33XX_CM_WKUP_TIMER1_CLKCTRL_OFFSET 0x00c4 | ||
305 | #define AM33XX_CM_WKUP_TIMER1_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x00c4) | ||
306 | #define AM33XX_CM_WKUP_SMARTREFLEX1_CLKCTRL_OFFSET 0x00c8 | ||
307 | #define AM33XX_CM_WKUP_SMARTREFLEX1_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x00c8) | ||
308 | #define AM33XX_CM_L4_WKUP_AON_CLKSTCTRL_OFFSET 0x00cc | ||
309 | #define AM33XX_CM_L4_WKUP_AON_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x00cc) | ||
310 | #define AM33XX_CM_WKUP_WDT0_CLKCTRL_OFFSET 0x00d0 | ||
311 | #define AM33XX_CM_WKUP_WDT0_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x00d0) | ||
312 | #define AM33XX_CM_WKUP_WDT1_CLKCTRL_OFFSET 0x00d4 | ||
313 | #define AM33XX_CM_WKUP_WDT1_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x00d4) | ||
314 | #define AM33XX_CM_DIV_M6_DPLL_CORE_OFFSET 0x00d8 | ||
315 | #define AM33XX_CM_DIV_M6_DPLL_CORE AM33XX_CM_REGADDR(AM33XX_CM_WKUP_MOD, 0x00d8) | ||
316 | |||
317 | /* CM.DPLL_CM register offsets */ | ||
318 | #define AM33XX_CLKSEL_TIMER7_CLK_OFFSET 0x0004 | ||
319 | #define AM33XX_CLKSEL_TIMER7_CLK AM33XX_CM_REGADDR(AM33XX_CM_DPLL_MOD, 0x0004) | ||
320 | #define AM33XX_CLKSEL_TIMER2_CLK_OFFSET 0x0008 | ||
321 | #define AM33XX_CLKSEL_TIMER2_CLK AM33XX_CM_REGADDR(AM33XX_CM_DPLL_MOD, 0x0008) | ||
322 | #define AM33XX_CLKSEL_TIMER3_CLK_OFFSET 0x000c | ||
323 | #define AM33XX_CLKSEL_TIMER3_CLK AM33XX_CM_REGADDR(AM33XX_CM_DPLL_MOD, 0x000c) | ||
324 | #define AM33XX_CLKSEL_TIMER4_CLK_OFFSET 0x0010 | ||
325 | #define AM33XX_CLKSEL_TIMER4_CLK AM33XX_CM_REGADDR(AM33XX_CM_DPLL_MOD, 0x0010) | ||
326 | #define AM33XX_CM_MAC_CLKSEL_OFFSET 0x0014 | ||
327 | #define AM33XX_CM_MAC_CLKSEL AM33XX_CM_REGADDR(AM33XX_CM_DPLL_MOD, 0x0014) | ||
328 | #define AM33XX_CLKSEL_TIMER5_CLK_OFFSET 0x0018 | ||
329 | #define AM33XX_CLKSEL_TIMER5_CLK AM33XX_CM_REGADDR(AM33XX_CM_DPLL_MOD, 0x0018) | ||
330 | #define AM33XX_CLKSEL_TIMER6_CLK_OFFSET 0x001c | ||
331 | #define AM33XX_CLKSEL_TIMER6_CLK AM33XX_CM_REGADDR(AM33XX_CM_DPLL_MOD, 0x001c) | ||
332 | #define AM33XX_CM_CPTS_RFT_CLKSEL_OFFSET 0x0020 | ||
333 | #define AM33XX_CM_CPTS_RFT_CLKSEL AM33XX_CM_REGADDR(AM33XX_CM_DPLL_MOD, 0x0020) | ||
334 | #define AM33XX_CLKSEL_TIMER1MS_CLK_OFFSET 0x0028 | ||
335 | #define AM33XX_CLKSEL_TIMER1MS_CLK AM33XX_CM_REGADDR(AM33XX_CM_DPLL_MOD, 0x0028) | ||
336 | #define AM33XX_CLKSEL_GFX_FCLK_OFFSET 0x002c | ||
337 | #define AM33XX_CLKSEL_GFX_FCLK AM33XX_CM_REGADDR(AM33XX_CM_DPLL_MOD, 0x002c) | ||
338 | #define AM33XX_CLKSEL_PRUSS_OCP_CLK_OFFSET 0x0030 | ||
339 | #define AM33XX_CLKSEL_PRUSS_OCP_CLK AM33XX_CM_REGADDR(AM33XX_CM_DPLL_MOD, 0x0030) | ||
340 | #define AM33XX_CLKSEL_LCDC_PIXEL_CLK_OFFSET 0x0034 | ||
341 | #define AM33XX_CLKSEL_LCDC_PIXEL_CLK AM33XX_CM_REGADDR(AM33XX_CM_DPLL_MOD, 0x0034) | ||
342 | #define AM33XX_CLKSEL_WDT1_CLK_OFFSET 0x0038 | ||
343 | #define AM33XX_CLKSEL_WDT1_CLK AM33XX_CM_REGADDR(AM33XX_CM_DPLL_MOD, 0x0038) | ||
344 | #define AM33XX_CLKSEL_GPIO0_DBCLK_OFFSET 0x003c | ||
345 | #define AM33XX_CLKSEL_GPIO0_DBCLK AM33XX_CM_REGADDR(AM33XX_CM_DPLL_MOD, 0x003c) | ||
346 | |||
347 | /* CM.MPU_CM register offsets */ | ||
348 | #define AM33XX_CM_MPU_CLKSTCTRL_OFFSET 0x0000 | ||
349 | #define AM33XX_CM_MPU_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_MPU_MOD, 0x0000) | ||
350 | #define AM33XX_CM_MPU_MPU_CLKCTRL_OFFSET 0x0004 | ||
351 | #define AM33XX_CM_MPU_MPU_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_MPU_MOD, 0x0004) | ||
352 | |||
353 | /* CM.DEVICE_CM register offsets */ | ||
354 | #define AM33XX_CM_CLKOUT_CTRL_OFFSET 0x0000 | ||
355 | #define AM33XX_CM_CLKOUT_CTRL AM33XX_CM_REGADDR(AM33XX_CM_DEVICE_MOD, 0x0000) | ||
356 | |||
357 | /* CM.RTC_CM register offsets */ | ||
358 | #define AM33XX_CM_RTC_RTC_CLKCTRL_OFFSET 0x0000 | ||
359 | #define AM33XX_CM_RTC_RTC_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_RTC_MOD, 0x0000) | ||
360 | #define AM33XX_CM_RTC_CLKSTCTRL_OFFSET 0x0004 | ||
361 | #define AM33XX_CM_RTC_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_RTC_MOD, 0x0004) | ||
362 | |||
363 | /* CM.GFX_CM register offsets */ | ||
364 | #define AM33XX_CM_GFX_L3_CLKSTCTRL_OFFSET 0x0000 | ||
365 | #define AM33XX_CM_GFX_L3_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_GFX_MOD, 0x0000) | ||
366 | #define AM33XX_CM_GFX_GFX_CLKCTRL_OFFSET 0x0004 | ||
367 | #define AM33XX_CM_GFX_GFX_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_GFX_MOD, 0x0004) | ||
368 | #define AM33XX_CM_GFX_BITBLT_CLKCTRL_OFFSET 0x0008 | ||
369 | #define AM33XX_CM_GFX_BITBLT_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_GFX_MOD, 0x0008) | ||
370 | #define AM33XX_CM_GFX_L4LS_GFX_CLKSTCTRL__1_OFFSET 0x000c | ||
371 | #define AM33XX_CM_GFX_L4LS_GFX_CLKSTCTRL__1 AM33XX_CM_REGADDR(AM33XX_CM_GFX_MOD, 0x000c) | ||
372 | #define AM33XX_CM_GFX_MMUCFG_CLKCTRL_OFFSET 0x0010 | ||
373 | #define AM33XX_CM_GFX_MMUCFG_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_GFX_MOD, 0x0010) | ||
374 | #define AM33XX_CM_GFX_MMUDATA_CLKCTRL_OFFSET 0x0014 | ||
375 | #define AM33XX_CM_GFX_MMUDATA_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_GFX_MOD, 0x0014) | ||
376 | |||
377 | /* CM.CEFUSE_CM register offsets */ | ||
378 | #define AM33XX_CM_CEFUSE_CLKSTCTRL_OFFSET 0x0000 | ||
379 | #define AM33XX_CM_CEFUSE_CLKSTCTRL AM33XX_CM_REGADDR(AM33XX_CM_CEFUSE_MOD, 0x0000) | ||
380 | #define AM33XX_CM_CEFUSE_CEFUSE_CLKCTRL_OFFSET 0x0020 | ||
381 | #define AM33XX_CM_CEFUSE_CEFUSE_CLKCTRL AM33XX_CM_REGADDR(AM33XX_CM_CEFUSE_MOD, 0x0020) | ||
382 | |||
383 | |||
384 | extern bool am33xx_cm_is_clkdm_in_hwsup(s16 inst, u16 cdoffs); | ||
385 | extern void am33xx_cm_clkdm_enable_hwsup(s16 inst, u16 cdoffs); | ||
386 | extern void am33xx_cm_clkdm_disable_hwsup(s16 inst, u16 cdoffs); | ||
387 | extern void am33xx_cm_clkdm_force_sleep(s16 inst, u16 cdoffs); | ||
388 | extern void am33xx_cm_clkdm_force_wakeup(s16 inst, u16 cdoffs); | ||
389 | |||
390 | #ifdef CONFIG_SOC_AM33XX | ||
391 | extern int am33xx_cm_wait_module_idle(u16 inst, s16 cdoffs, | ||
392 | u16 clkctrl_offs); | ||
393 | extern void am33xx_cm_module_enable(u8 mode, u16 inst, s16 cdoffs, | ||
394 | u16 clkctrl_offs); | ||
395 | extern void am33xx_cm_module_disable(u16 inst, s16 cdoffs, | ||
396 | u16 clkctrl_offs); | ||
397 | extern int am33xx_cm_wait_module_ready(u16 inst, s16 cdoffs, | ||
398 | u16 clkctrl_offs); | ||
399 | #else | ||
400 | static inline int am33xx_cm_wait_module_idle(u16 inst, s16 cdoffs, | ||
401 | u16 clkctrl_offs) | ||
402 | { | ||
403 | return 0; | ||
404 | } | ||
405 | static inline void am33xx_cm_module_enable(u8 mode, u16 inst, s16 cdoffs, | ||
406 | u16 clkctrl_offs) | ||
407 | { | ||
408 | } | ||
409 | static inline void am33xx_cm_module_disable(u16 inst, s16 cdoffs, | ||
410 | u16 clkctrl_offs) | ||
411 | { | ||
412 | } | ||
413 | static inline int am33xx_cm_wait_module_ready(u16 inst, s16 cdoffs, | ||
414 | u16 clkctrl_offs) | ||
415 | { | ||
416 | return 0; | ||
417 | } | ||
418 | #endif | ||
419 | |||
420 | #endif | ||
diff --git a/arch/arm/mach-omap2/common.h b/arch/arm/mach-omap2/common.h index be9dfd1abe60..5d99c1b2cb48 100644 --- a/arch/arm/mach-omap2/common.h +++ b/arch/arm/mach-omap2/common.h | |||
@@ -120,6 +120,7 @@ extern void omap2_init_common_infrastructure(void); | |||
120 | extern struct sys_timer omap2_timer; | 120 | extern struct sys_timer omap2_timer; |
121 | extern struct sys_timer omap3_timer; | 121 | extern struct sys_timer omap3_timer; |
122 | extern struct sys_timer omap3_secure_timer; | 122 | extern struct sys_timer omap3_secure_timer; |
123 | extern struct sys_timer omap3_am33xx_timer; | ||
123 | extern struct sys_timer omap4_timer; | 124 | extern struct sys_timer omap4_timer; |
124 | 125 | ||
125 | void omap2420_init_early(void); | 126 | void omap2420_init_early(void); |
@@ -128,8 +129,10 @@ void omap3430_init_early(void); | |||
128 | void omap35xx_init_early(void); | 129 | void omap35xx_init_early(void); |
129 | void omap3630_init_early(void); | 130 | void omap3630_init_early(void); |
130 | void omap3_init_early(void); /* Do not use this one */ | 131 | void omap3_init_early(void); /* Do not use this one */ |
132 | void am33xx_init_early(void); | ||
131 | void am35xx_init_early(void); | 133 | void am35xx_init_early(void); |
132 | void ti81xx_init_early(void); | 134 | void ti81xx_init_early(void); |
135 | void am33xx_init_early(void); | ||
133 | void omap4430_init_early(void); | 136 | void omap4430_init_early(void); |
134 | void omap3_init_late(void); /* Do not use this one */ | 137 | void omap3_init_late(void); /* Do not use this one */ |
135 | void omap4430_init_late(void); | 138 | void omap4430_init_late(void); |
diff --git a/arch/arm/mach-omap2/control.h b/arch/arm/mach-omap2/control.h index fcc98f822d9d..5baf305386e9 100644 --- a/arch/arm/mach-omap2/control.h +++ b/arch/arm/mach-omap2/control.h | |||
@@ -21,6 +21,8 @@ | |||
21 | #include <mach/ctrl_module_pad_core_44xx.h> | 21 | #include <mach/ctrl_module_pad_core_44xx.h> |
22 | #include <mach/ctrl_module_pad_wkup_44xx.h> | 22 | #include <mach/ctrl_module_pad_wkup_44xx.h> |
23 | 23 | ||
24 | #include <plat/am33xx.h> | ||
25 | |||
24 | #ifndef __ASSEMBLY__ | 26 | #ifndef __ASSEMBLY__ |
25 | #define OMAP242X_CTRL_REGADDR(reg) \ | 27 | #define OMAP242X_CTRL_REGADDR(reg) \ |
26 | OMAP2_L4_IO_ADDRESS(OMAP242X_CTRL_BASE + (reg)) | 28 | OMAP2_L4_IO_ADDRESS(OMAP242X_CTRL_BASE + (reg)) |
@@ -28,6 +30,8 @@ | |||
28 | OMAP2_L4_IO_ADDRESS(OMAP243X_CTRL_BASE + (reg)) | 30 | OMAP2_L4_IO_ADDRESS(OMAP243X_CTRL_BASE + (reg)) |
29 | #define OMAP343X_CTRL_REGADDR(reg) \ | 31 | #define OMAP343X_CTRL_REGADDR(reg) \ |
30 | OMAP2_L4_IO_ADDRESS(OMAP343X_CTRL_BASE + (reg)) | 32 | OMAP2_L4_IO_ADDRESS(OMAP343X_CTRL_BASE + (reg)) |
33 | #define AM33XX_CTRL_REGADDR(reg) \ | ||
34 | AM33XX_L4_WK_IO_ADDRESS(AM33XX_SCM_BASE + (reg)) | ||
31 | #else | 35 | #else |
32 | #define OMAP242X_CTRL_REGADDR(reg) \ | 36 | #define OMAP242X_CTRL_REGADDR(reg) \ |
33 | OMAP2_L4_IO_ADDRESS(OMAP242X_CTRL_BASE + (reg)) | 37 | OMAP2_L4_IO_ADDRESS(OMAP242X_CTRL_BASE + (reg)) |
@@ -35,6 +39,8 @@ | |||
35 | OMAP2_L4_IO_ADDRESS(OMAP243X_CTRL_BASE + (reg)) | 39 | OMAP2_L4_IO_ADDRESS(OMAP243X_CTRL_BASE + (reg)) |
36 | #define OMAP343X_CTRL_REGADDR(reg) \ | 40 | #define OMAP343X_CTRL_REGADDR(reg) \ |
37 | OMAP2_L4_IO_ADDRESS(OMAP343X_CTRL_BASE + (reg)) | 41 | OMAP2_L4_IO_ADDRESS(OMAP343X_CTRL_BASE + (reg)) |
42 | #define AM33XX_CTRL_REGADDR(reg) \ | ||
43 | AM33XX_L4_WK_IO_ADDRESS(AM33XX_SCM_BASE + (reg)) | ||
38 | #endif /* __ASSEMBLY__ */ | 44 | #endif /* __ASSEMBLY__ */ |
39 | 45 | ||
40 | /* | 46 | /* |
@@ -312,15 +318,15 @@ | |||
312 | OMAP343X_SCRATCHPAD + reg) | 318 | OMAP343X_SCRATCHPAD + reg) |
313 | 319 | ||
314 | /* AM35XX_CONTROL_IPSS_CLK_CTRL bits */ | 320 | /* AM35XX_CONTROL_IPSS_CLK_CTRL bits */ |
315 | #define AM35XX_USBOTG_VBUSP_CLK_SHIFT 0 | 321 | #define AM35XX_USBOTG_VBUSP_CLK_SHIFT 0 |
316 | #define AM35XX_CPGMAC_VBUSP_CLK_SHIFT 1 | 322 | #define AM35XX_CPGMAC_VBUSP_CLK_SHIFT 1 |
317 | #define AM35XX_VPFE_VBUSP_CLK_SHIFT 2 | 323 | #define AM35XX_VPFE_VBUSP_CLK_SHIFT 2 |
318 | #define AM35XX_HECC_VBUSP_CLK_SHIFT 3 | 324 | #define AM35XX_HECC_VBUSP_CLK_SHIFT 3 |
319 | #define AM35XX_USBOTG_FCLK_SHIFT 8 | 325 | #define AM35XX_USBOTG_FCLK_SHIFT 8 |
320 | #define AM35XX_CPGMAC_FCLK_SHIFT 9 | 326 | #define AM35XX_CPGMAC_FCLK_SHIFT 9 |
321 | #define AM35XX_VPFE_FCLK_SHIFT 10 | 327 | #define AM35XX_VPFE_FCLK_SHIFT 10 |
322 | 328 | ||
323 | /*AM35XX CONTROL_LVL_INTR_CLEAR bits*/ | 329 | /* AM35XX CONTROL_LVL_INTR_CLEAR bits */ |
324 | #define AM35XX_CPGMAC_C0_MISC_PULSE_CLR BIT(0) | 330 | #define AM35XX_CPGMAC_C0_MISC_PULSE_CLR BIT(0) |
325 | #define AM35XX_CPGMAC_C0_RX_PULSE_CLR BIT(1) | 331 | #define AM35XX_CPGMAC_C0_RX_PULSE_CLR BIT(1) |
326 | #define AM35XX_CPGMAC_C0_RX_THRESH_CLR BIT(2) | 332 | #define AM35XX_CPGMAC_C0_RX_THRESH_CLR BIT(2) |
@@ -330,21 +336,22 @@ | |||
330 | #define AM35XX_VPFE_CCDC_VD1_INT_CLR BIT(6) | 336 | #define AM35XX_VPFE_CCDC_VD1_INT_CLR BIT(6) |
331 | #define AM35XX_VPFE_CCDC_VD2_INT_CLR BIT(7) | 337 | #define AM35XX_VPFE_CCDC_VD2_INT_CLR BIT(7) |
332 | 338 | ||
333 | /*AM35XX CONTROL_IP_SW_RESET bits*/ | 339 | /* AM35XX CONTROL_IP_SW_RESET bits */ |
334 | #define AM35XX_USBOTGSS_SW_RST BIT(0) | 340 | #define AM35XX_USBOTGSS_SW_RST BIT(0) |
335 | #define AM35XX_CPGMACSS_SW_RST BIT(1) | 341 | #define AM35XX_CPGMACSS_SW_RST BIT(1) |
336 | #define AM35XX_VPFE_VBUSP_SW_RST BIT(2) | 342 | #define AM35XX_VPFE_VBUSP_SW_RST BIT(2) |
337 | #define AM35XX_HECC_SW_RST BIT(3) | 343 | #define AM35XX_HECC_SW_RST BIT(3) |
338 | #define AM35XX_VPFE_PCLK_SW_RST BIT(4) | 344 | #define AM35XX_VPFE_PCLK_SW_RST BIT(4) |
339 | 345 | ||
340 | /* | 346 | /* AM33XX CONTROL_STATUS register */ |
341 | * CONTROL AM33XX STATUS register | ||
342 | */ | ||
343 | #define AM33XX_CONTROL_STATUS 0x040 | 347 | #define AM33XX_CONTROL_STATUS 0x040 |
348 | #define AM33XX_CONTROL_SEC_CLK_CTRL 0x1bc | ||
344 | 349 | ||
345 | /* | 350 | /* AM33XX CONTROL_STATUS bitfields (partial) */ |
346 | * CONTROL OMAP STATUS register to identify OMAP3 features | 351 | #define AM33XX_CONTROL_STATUS_SYSBOOT1_SHIFT 22 |
347 | */ | 352 | #define AM33XX_CONTROL_STATUS_SYSBOOT1_MASK (0x3 << 22) |
353 | |||
354 | /* CONTROL OMAP STATUS register to identify OMAP3 features */ | ||
348 | #define OMAP3_CONTROL_OMAP_STATUS 0x044c | 355 | #define OMAP3_CONTROL_OMAP_STATUS 0x044c |
349 | 356 | ||
350 | #define OMAP3_SGX_SHIFT 13 | 357 | #define OMAP3_SGX_SHIFT 13 |
diff --git a/arch/arm/mach-omap2/include/mach/debug-macro.S b/arch/arm/mach-omap2/include/mach/debug-macro.S index cdfc2a1f0e75..d7f844a99a7b 100644 --- a/arch/arm/mach-omap2/include/mach/debug-macro.S +++ b/arch/arm/mach-omap2/include/mach/debug-macro.S | |||
@@ -72,6 +72,8 @@ omap_uart_lsr: .word 0 | |||
72 | beq 82f @ configure UART2 | 72 | beq 82f @ configure UART2 |
73 | cmp \rp, #TI81XXUART3 @ ti81Xx UART offsets different | 73 | cmp \rp, #TI81XXUART3 @ ti81Xx UART offsets different |
74 | beq 83f @ configure UART3 | 74 | beq 83f @ configure UART3 |
75 | cmp \rp, #AM33XXUART1 @ AM33XX UART offsets different | ||
76 | beq 84f @ configure UART1 | ||
75 | cmp \rp, #ZOOM_UART @ only on zoom2/3 | 77 | cmp \rp, #ZOOM_UART @ only on zoom2/3 |
76 | beq 95f @ configure ZOOM_UART | 78 | beq 95f @ configure ZOOM_UART |
77 | 79 | ||
@@ -100,7 +102,9 @@ omap_uart_lsr: .word 0 | |||
100 | b 98f | 102 | b 98f |
101 | 83: mov \rp, #UART_OFFSET(TI81XX_UART3_BASE) | 103 | 83: mov \rp, #UART_OFFSET(TI81XX_UART3_BASE) |
102 | b 98f | 104 | b 98f |
103 | 105 | 84: ldr \rp, =AM33XX_UART1_BASE | |
106 | and \rp, \rp, #0x00ffffff | ||
107 | b 97f | ||
104 | 95: ldr \rp, =ZOOM_UART_BASE | 108 | 95: ldr \rp, =ZOOM_UART_BASE |
105 | str \rp, [\tmp, #0] @ omap_uart_phys | 109 | str \rp, [\tmp, #0] @ omap_uart_phys |
106 | ldr \rp, =ZOOM_UART_VIRT | 110 | ldr \rp, =ZOOM_UART_VIRT |
@@ -109,6 +113,17 @@ omap_uart_lsr: .word 0 | |||
109 | str \rp, [\tmp, #8] @ omap_uart_lsr | 113 | str \rp, [\tmp, #8] @ omap_uart_lsr |
110 | b 10b | 114 | b 10b |
111 | 115 | ||
116 | /* AM33XX: Store both phys and virt address for the uart */ | ||
117 | 97: add \rp, \rp, #0x44000000 @ phys base | ||
118 | str \rp, [\tmp, #0] @ omap_uart_phys | ||
119 | sub \rp, \rp, #0x44000000 @ phys base | ||
120 | add \rp, \rp, #0xf9000000 @ virt base | ||
121 | str \rp, [\tmp, #4] @ omap_uart_virt | ||
122 | mov \rp, #(UART_LSR << OMAP_PORT_SHIFT) | ||
123 | str \rp, [\tmp, #8] @ omap_uart_lsr | ||
124 | |||
125 | b 10b | ||
126 | |||
112 | /* Store both phys and virt address for the uart */ | 127 | /* Store both phys and virt address for the uart */ |
113 | 98: add \rp, \rp, #0x48000000 @ phys base | 128 | 98: add \rp, \rp, #0x48000000 @ phys base |
114 | str \rp, [\tmp, #0] @ omap_uart_phys | 129 | str \rp, [\tmp, #0] @ omap_uart_phys |
diff --git a/arch/arm/mach-omap2/io.c b/arch/arm/mach-omap2/io.c index 8d014ba04abc..cb6c11cd8df9 100644 --- a/arch/arm/mach-omap2/io.c +++ b/arch/arm/mach-omap2/io.c | |||
@@ -477,6 +477,19 @@ void __init ti81xx_init_late(void) | |||
477 | } | 477 | } |
478 | #endif | 478 | #endif |
479 | 479 | ||
480 | #ifdef CONFIG_SOC_AM33XX | ||
481 | void __init am33xx_init_early(void) | ||
482 | { | ||
483 | omap2_set_globals_am33xx(); | ||
484 | omap3xxx_check_revision(); | ||
485 | ti81xx_check_features(); | ||
486 | omap_common_init_early(); | ||
487 | am33xx_voltagedomains_init(); | ||
488 | am33xx_powerdomains_init(); | ||
489 | am33xx_clockdomains_init(); | ||
490 | } | ||
491 | #endif | ||
492 | |||
480 | #ifdef CONFIG_ARCH_OMAP4 | 493 | #ifdef CONFIG_ARCH_OMAP4 |
481 | void __init omap4430_init_early(void) | 494 | void __init omap4430_init_early(void) |
482 | { | 495 | { |
diff --git a/arch/arm/mach-omap2/irq.c b/arch/arm/mach-omap2/irq.c index 4c35366c7e4d..a9c26b12cad2 100644 --- a/arch/arm/mach-omap2/irq.c +++ b/arch/arm/mach-omap2/irq.c | |||
@@ -280,7 +280,7 @@ int __init omap_intc_of_init(struct device_node *node, | |||
280 | return 0; | 280 | return 0; |
281 | } | 281 | } |
282 | 282 | ||
283 | #ifdef CONFIG_ARCH_OMAP3 | 283 | #if defined(CONFIG_ARCH_OMAP3) || defined(CONFIG_SOC_AM33XX) |
284 | static struct omap3_intc_regs intc_context[ARRAY_SIZE(irq_banks)]; | 284 | static struct omap3_intc_regs intc_context[ARRAY_SIZE(irq_banks)]; |
285 | 285 | ||
286 | void omap_intc_save_context(void) | 286 | void omap_intc_save_context(void) |
diff --git a/arch/arm/mach-omap2/powerdomain.h b/arch/arm/mach-omap2/powerdomain.h index 8f88d65c46ea..a8a95184243d 100644 --- a/arch/arm/mach-omap2/powerdomain.h +++ b/arch/arm/mach-omap2/powerdomain.h | |||
@@ -67,9 +67,9 @@ | |||
67 | 67 | ||
68 | /* | 68 | /* |
69 | * Maximum number of clockdomains that can be associated with a powerdomain. | 69 | * Maximum number of clockdomains that can be associated with a powerdomain. |
70 | * CORE powerdomain on OMAP4 is the worst case | 70 | * PER powerdomain on AM33XX is the worst case |
71 | */ | 71 | */ |
72 | #define PWRDM_MAX_CLKDMS 9 | 72 | #define PWRDM_MAX_CLKDMS 11 |
73 | 73 | ||
74 | /* XXX A completely arbitrary number. What is reasonable here? */ | 74 | /* XXX A completely arbitrary number. What is reasonable here? */ |
75 | #define PWRDM_TRANSITION_BAILOUT 100000 | 75 | #define PWRDM_TRANSITION_BAILOUT 100000 |
@@ -92,6 +92,15 @@ struct powerdomain; | |||
92 | * @pwrdm_clkdms: Clockdomains in this powerdomain | 92 | * @pwrdm_clkdms: Clockdomains in this powerdomain |
93 | * @node: list_head linking all powerdomains | 93 | * @node: list_head linking all powerdomains |
94 | * @voltdm_node: list_head linking all powerdomains in a voltagedomain | 94 | * @voltdm_node: list_head linking all powerdomains in a voltagedomain |
95 | * @pwrstctrl_offs: (AM33XX only) XXX_PWRSTCTRL reg offset from prcm_offs | ||
96 | * @pwrstst_offs: (AM33XX only) XXX_PWRSTST reg offset from prcm_offs | ||
97 | * @logicretstate_mask: (AM33XX only) mask for logic retention bitfield | ||
98 | * in @pwrstctrl_offs | ||
99 | * @mem_on_mask: (AM33XX only) mask for mem on bitfield in @pwrstctrl_offs | ||
100 | * @mem_ret_mask: (AM33XX only) mask for mem ret bitfield in @pwrstctrl_offs | ||
101 | * @mem_pwrst_mask: (AM33XX only) mask for mem state bitfield in @pwrstst_offs | ||
102 | * @mem_retst_mask: (AM33XX only) mask for mem retention state bitfield | ||
103 | * in @pwrstctrl_offs | ||
95 | * @state: | 104 | * @state: |
96 | * @state_counter: | 105 | * @state_counter: |
97 | * @timer: | 106 | * @timer: |
@@ -121,6 +130,14 @@ struct powerdomain { | |||
121 | unsigned ret_logic_off_counter; | 130 | unsigned ret_logic_off_counter; |
122 | unsigned ret_mem_off_counter[PWRDM_MAX_MEM_BANKS]; | 131 | unsigned ret_mem_off_counter[PWRDM_MAX_MEM_BANKS]; |
123 | 132 | ||
133 | const u8 pwrstctrl_offs; | ||
134 | const u8 pwrstst_offs; | ||
135 | const u32 logicretstate_mask; | ||
136 | const u32 mem_on_mask[PWRDM_MAX_MEM_BANKS]; | ||
137 | const u32 mem_ret_mask[PWRDM_MAX_MEM_BANKS]; | ||
138 | const u32 mem_pwrst_mask[PWRDM_MAX_MEM_BANKS]; | ||
139 | const u32 mem_retst_mask[PWRDM_MAX_MEM_BANKS]; | ||
140 | |||
124 | #ifdef CONFIG_PM_DEBUG | 141 | #ifdef CONFIG_PM_DEBUG |
125 | s64 timer; | 142 | s64 timer; |
126 | s64 state_timer[PWRDM_MAX_PWRSTS]; | 143 | s64 state_timer[PWRDM_MAX_PWRSTS]; |
@@ -222,10 +239,12 @@ bool pwrdm_can_ever_lose_context(struct powerdomain *pwrdm); | |||
222 | extern void omap242x_powerdomains_init(void); | 239 | extern void omap242x_powerdomains_init(void); |
223 | extern void omap243x_powerdomains_init(void); | 240 | extern void omap243x_powerdomains_init(void); |
224 | extern void omap3xxx_powerdomains_init(void); | 241 | extern void omap3xxx_powerdomains_init(void); |
242 | extern void am33xx_powerdomains_init(void); | ||
225 | extern void omap44xx_powerdomains_init(void); | 243 | extern void omap44xx_powerdomains_init(void); |
226 | 244 | ||
227 | extern struct pwrdm_ops omap2_pwrdm_operations; | 245 | extern struct pwrdm_ops omap2_pwrdm_operations; |
228 | extern struct pwrdm_ops omap3_pwrdm_operations; | 246 | extern struct pwrdm_ops omap3_pwrdm_operations; |
247 | extern struct pwrdm_ops am33xx_pwrdm_operations; | ||
229 | extern struct pwrdm_ops omap4_pwrdm_operations; | 248 | extern struct pwrdm_ops omap4_pwrdm_operations; |
230 | 249 | ||
231 | /* Common Internal functions used across OMAP rev's */ | 250 | /* Common Internal functions used across OMAP rev's */ |
diff --git a/arch/arm/mach-omap2/powerdomain33xx.c b/arch/arm/mach-omap2/powerdomain33xx.c new file mode 100644 index 000000000000..67c5663899b6 --- /dev/null +++ b/arch/arm/mach-omap2/powerdomain33xx.c | |||
@@ -0,0 +1,229 @@ | |||
1 | /* | ||
2 | * AM33XX Powerdomain control | ||
3 | * | ||
4 | * Copyright (C) 2011-2012 Texas Instruments Incorporated - http://www.ti.com/ | ||
5 | * | ||
6 | * Derived from mach-omap2/powerdomain44xx.c written by Rajendra Nayak | ||
7 | * <rnayak@ti.com> | ||
8 | * | ||
9 | * This program is free software; you can redistribute it and/or | ||
10 | * modify it under the terms of the GNU General Public License as | ||
11 | * published by the Free Software Foundation version 2. | ||
12 | * | ||
13 | * This program is distributed "as is" WITHOUT ANY WARRANTY of any | ||
14 | * kind, whether express or implied; without even the implied warranty | ||
15 | * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
16 | * GNU General Public License for more details. | ||
17 | */ | ||
18 | |||
19 | #include <linux/io.h> | ||
20 | #include <linux/errno.h> | ||
21 | #include <linux/delay.h> | ||
22 | |||
23 | #include <plat/prcm.h> | ||
24 | |||
25 | #include "powerdomain.h" | ||
26 | #include "prm33xx.h" | ||
27 | #include "prm-regbits-33xx.h" | ||
28 | |||
29 | |||
30 | static int am33xx_pwrdm_set_next_pwrst(struct powerdomain *pwrdm, u8 pwrst) | ||
31 | { | ||
32 | am33xx_prm_rmw_reg_bits(OMAP_POWERSTATE_MASK, | ||
33 | (pwrst << OMAP_POWERSTATE_SHIFT), | ||
34 | pwrdm->prcm_offs, pwrdm->pwrstctrl_offs); | ||
35 | return 0; | ||
36 | } | ||
37 | |||
38 | static int am33xx_pwrdm_read_next_pwrst(struct powerdomain *pwrdm) | ||
39 | { | ||
40 | u32 v; | ||
41 | |||
42 | v = am33xx_prm_read_reg(pwrdm->prcm_offs, pwrdm->pwrstctrl_offs); | ||
43 | v &= OMAP_POWERSTATE_MASK; | ||
44 | v >>= OMAP_POWERSTATE_SHIFT; | ||
45 | |||
46 | return v; | ||
47 | } | ||
48 | |||
49 | static int am33xx_pwrdm_read_pwrst(struct powerdomain *pwrdm) | ||
50 | { | ||
51 | u32 v; | ||
52 | |||
53 | v = am33xx_prm_read_reg(pwrdm->prcm_offs, pwrdm->pwrstst_offs); | ||
54 | v &= OMAP_POWERSTATEST_MASK; | ||
55 | v >>= OMAP_POWERSTATEST_SHIFT; | ||
56 | |||
57 | return v; | ||
58 | } | ||
59 | |||
60 | static int am33xx_pwrdm_read_prev_pwrst(struct powerdomain *pwrdm) | ||
61 | { | ||
62 | u32 v; | ||
63 | |||
64 | v = am33xx_prm_read_reg(pwrdm->prcm_offs, pwrdm->pwrstst_offs); | ||
65 | v &= AM33XX_LASTPOWERSTATEENTERED_MASK; | ||
66 | v >>= AM33XX_LASTPOWERSTATEENTERED_SHIFT; | ||
67 | |||
68 | return v; | ||
69 | } | ||
70 | |||
71 | static int am33xx_pwrdm_set_lowpwrstchange(struct powerdomain *pwrdm) | ||
72 | { | ||
73 | am33xx_prm_rmw_reg_bits(AM33XX_LOWPOWERSTATECHANGE_MASK, | ||
74 | (1 << AM33XX_LOWPOWERSTATECHANGE_SHIFT), | ||
75 | pwrdm->prcm_offs, pwrdm->pwrstctrl_offs); | ||
76 | return 0; | ||
77 | } | ||
78 | |||
79 | static int am33xx_pwrdm_clear_all_prev_pwrst(struct powerdomain *pwrdm) | ||
80 | { | ||
81 | am33xx_prm_rmw_reg_bits(AM33XX_LASTPOWERSTATEENTERED_MASK, | ||
82 | AM33XX_LASTPOWERSTATEENTERED_MASK, | ||
83 | pwrdm->prcm_offs, pwrdm->pwrstst_offs); | ||
84 | return 0; | ||
85 | } | ||
86 | |||
87 | static int am33xx_pwrdm_set_logic_retst(struct powerdomain *pwrdm, u8 pwrst) | ||
88 | { | ||
89 | u32 m; | ||
90 | |||
91 | m = pwrdm->logicretstate_mask; | ||
92 | if (!m) | ||
93 | return -EINVAL; | ||
94 | |||
95 | am33xx_prm_rmw_reg_bits(m, (pwrst << __ffs(m)), | ||
96 | pwrdm->prcm_offs, pwrdm->pwrstctrl_offs); | ||
97 | |||
98 | return 0; | ||
99 | } | ||
100 | |||
101 | static int am33xx_pwrdm_read_logic_pwrst(struct powerdomain *pwrdm) | ||
102 | { | ||
103 | u32 v; | ||
104 | |||
105 | v = am33xx_prm_read_reg(pwrdm->prcm_offs, pwrdm->pwrstst_offs); | ||
106 | v &= AM33XX_LOGICSTATEST_MASK; | ||
107 | v >>= AM33XX_LOGICSTATEST_SHIFT; | ||
108 | |||
109 | return v; | ||
110 | } | ||
111 | |||
112 | static int am33xx_pwrdm_read_logic_retst(struct powerdomain *pwrdm) | ||
113 | { | ||
114 | u32 v, m; | ||
115 | |||
116 | m = pwrdm->logicretstate_mask; | ||
117 | if (!m) | ||
118 | return -EINVAL; | ||
119 | |||
120 | v = am33xx_prm_read_reg(pwrdm->prcm_offs, pwrdm->pwrstctrl_offs); | ||
121 | v &= m; | ||
122 | v >>= __ffs(m); | ||
123 | |||
124 | return v; | ||
125 | } | ||
126 | |||
127 | static int am33xx_pwrdm_set_mem_onst(struct powerdomain *pwrdm, u8 bank, | ||
128 | u8 pwrst) | ||
129 | { | ||
130 | u32 m; | ||
131 | |||
132 | m = pwrdm->mem_on_mask[bank]; | ||
133 | if (!m) | ||
134 | return -EINVAL; | ||
135 | |||
136 | am33xx_prm_rmw_reg_bits(m, (pwrst << __ffs(m)), | ||
137 | pwrdm->prcm_offs, pwrdm->pwrstctrl_offs); | ||
138 | |||
139 | return 0; | ||
140 | } | ||
141 | |||
142 | static int am33xx_pwrdm_set_mem_retst(struct powerdomain *pwrdm, u8 bank, | ||
143 | u8 pwrst) | ||
144 | { | ||
145 | u32 m; | ||
146 | |||
147 | m = pwrdm->mem_ret_mask[bank]; | ||
148 | if (!m) | ||
149 | return -EINVAL; | ||
150 | |||
151 | am33xx_prm_rmw_reg_bits(m, (pwrst << __ffs(m)), | ||
152 | pwrdm->prcm_offs, pwrdm->pwrstctrl_offs); | ||
153 | |||
154 | return 0; | ||
155 | } | ||
156 | |||
157 | static int am33xx_pwrdm_read_mem_pwrst(struct powerdomain *pwrdm, u8 bank) | ||
158 | { | ||
159 | u32 m, v; | ||
160 | |||
161 | m = pwrdm->mem_pwrst_mask[bank]; | ||
162 | if (!m) | ||
163 | return -EINVAL; | ||
164 | |||
165 | v = am33xx_prm_read_reg(pwrdm->prcm_offs, pwrdm->pwrstst_offs); | ||
166 | v &= m; | ||
167 | v >>= __ffs(m); | ||
168 | |||
169 | return v; | ||
170 | } | ||
171 | |||
172 | static int am33xx_pwrdm_read_mem_retst(struct powerdomain *pwrdm, u8 bank) | ||
173 | { | ||
174 | u32 m, v; | ||
175 | |||
176 | m = pwrdm->mem_retst_mask[bank]; | ||
177 | if (!m) | ||
178 | return -EINVAL; | ||
179 | |||
180 | v = am33xx_prm_read_reg(pwrdm->prcm_offs, pwrdm->pwrstctrl_offs); | ||
181 | v &= m; | ||
182 | v >>= __ffs(m); | ||
183 | |||
184 | return v; | ||
185 | } | ||
186 | |||
187 | static int am33xx_pwrdm_wait_transition(struct powerdomain *pwrdm) | ||
188 | { | ||
189 | u32 c = 0; | ||
190 | |||
191 | /* | ||
192 | * REVISIT: pwrdm_wait_transition() may be better implemented | ||
193 | * via a callback and a periodic timer check -- how long do we expect | ||
194 | * powerdomain transitions to take? | ||
195 | */ | ||
196 | |||
197 | /* XXX Is this udelay() value meaningful? */ | ||
198 | while ((am33xx_prm_read_reg(pwrdm->prcm_offs, pwrdm->pwrstst_offs) | ||
199 | & OMAP_INTRANSITION_MASK) && | ||
200 | (c++ < PWRDM_TRANSITION_BAILOUT)) | ||
201 | udelay(1); | ||
202 | |||
203 | if (c > PWRDM_TRANSITION_BAILOUT) { | ||
204 | pr_err("powerdomain: %s: waited too long to complete transition\n", | ||
205 | pwrdm->name); | ||
206 | return -EAGAIN; | ||
207 | } | ||
208 | |||
209 | pr_debug("powerdomain: completed transition in %d loops\n", c); | ||
210 | |||
211 | return 0; | ||
212 | } | ||
213 | |||
214 | struct pwrdm_ops am33xx_pwrdm_operations = { | ||
215 | .pwrdm_set_next_pwrst = am33xx_pwrdm_set_next_pwrst, | ||
216 | .pwrdm_read_next_pwrst = am33xx_pwrdm_read_next_pwrst, | ||
217 | .pwrdm_read_pwrst = am33xx_pwrdm_read_pwrst, | ||
218 | .pwrdm_read_prev_pwrst = am33xx_pwrdm_read_prev_pwrst, | ||
219 | .pwrdm_set_logic_retst = am33xx_pwrdm_set_logic_retst, | ||
220 | .pwrdm_read_logic_pwrst = am33xx_pwrdm_read_logic_pwrst, | ||
221 | .pwrdm_read_logic_retst = am33xx_pwrdm_read_logic_retst, | ||
222 | .pwrdm_clear_all_prev_pwrst = am33xx_pwrdm_clear_all_prev_pwrst, | ||
223 | .pwrdm_set_lowpwrstchange = am33xx_pwrdm_set_lowpwrstchange, | ||
224 | .pwrdm_read_mem_pwrst = am33xx_pwrdm_read_mem_pwrst, | ||
225 | .pwrdm_read_mem_retst = am33xx_pwrdm_read_mem_retst, | ||
226 | .pwrdm_set_mem_onst = am33xx_pwrdm_set_mem_onst, | ||
227 | .pwrdm_set_mem_retst = am33xx_pwrdm_set_mem_retst, | ||
228 | .pwrdm_wait_transition = am33xx_pwrdm_wait_transition, | ||
229 | }; | ||
diff --git a/arch/arm/mach-omap2/powerdomains33xx_data.c b/arch/arm/mach-omap2/powerdomains33xx_data.c new file mode 100644 index 000000000000..869adb82569e --- /dev/null +++ b/arch/arm/mach-omap2/powerdomains33xx_data.c | |||
@@ -0,0 +1,185 @@ | |||
1 | /* | ||
2 | * AM33XX Power domain data | ||
3 | * | ||
4 | * Copyright (C) 2011-2012 Texas Instruments Incorporated - http://www.ti.com/ | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or | ||
7 | * modify it under the terms of the GNU General Public License as | ||
8 | * published by the Free Software Foundation version 2. | ||
9 | * | ||
10 | * This program is distributed "as is" WITHOUT ANY WARRANTY of any | ||
11 | * kind, whether express or implied; without even the implied warranty | ||
12 | * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
13 | * GNU General Public License for more details. | ||
14 | */ | ||
15 | |||
16 | #include <linux/kernel.h> | ||
17 | #include <linux/init.h> | ||
18 | |||
19 | #include "powerdomain.h" | ||
20 | #include "prcm-common.h" | ||
21 | #include "prm-regbits-33xx.h" | ||
22 | #include "prm33xx.h" | ||
23 | |||
24 | static struct powerdomain gfx_33xx_pwrdm = { | ||
25 | .name = "gfx_pwrdm", | ||
26 | .voltdm = { .name = "core" }, | ||
27 | .prcm_offs = AM33XX_PRM_GFX_MOD, | ||
28 | .pwrstctrl_offs = AM33XX_PM_GFX_PWRSTCTRL_OFFSET, | ||
29 | .pwrstst_offs = AM33XX_PM_GFX_PWRSTST_OFFSET, | ||
30 | .pwrsts = PWRSTS_OFF_RET_ON, | ||
31 | .pwrsts_logic_ret = PWRSTS_OFF_RET, | ||
32 | .flags = PWRDM_HAS_LOWPOWERSTATECHANGE, | ||
33 | .banks = 1, | ||
34 | .logicretstate_mask = AM33XX_LOGICRETSTATE_MASK, | ||
35 | .mem_on_mask = { | ||
36 | [0] = AM33XX_GFX_MEM_ONSTATE_MASK, /* gfx_mem */ | ||
37 | }, | ||
38 | .mem_ret_mask = { | ||
39 | [0] = AM33XX_GFX_MEM_RETSTATE_MASK, /* gfx_mem */ | ||
40 | }, | ||
41 | .mem_pwrst_mask = { | ||
42 | [0] = AM33XX_GFX_MEM_STATEST_MASK, /* gfx_mem */ | ||
43 | }, | ||
44 | .mem_retst_mask = { | ||
45 | [0] = AM33XX_GFX_MEM_RETSTATE_MASK, /* gfx_mem */ | ||
46 | }, | ||
47 | .pwrsts_mem_ret = { | ||
48 | [0] = PWRSTS_OFF_RET, /* gfx_mem */ | ||
49 | }, | ||
50 | .pwrsts_mem_on = { | ||
51 | [0] = PWRSTS_ON, /* gfx_mem */ | ||
52 | }, | ||
53 | }; | ||
54 | |||
55 | static struct powerdomain rtc_33xx_pwrdm = { | ||
56 | .name = "rtc_pwrdm", | ||
57 | .voltdm = { .name = "rtc" }, | ||
58 | .prcm_offs = AM33XX_PRM_RTC_MOD, | ||
59 | .pwrstctrl_offs = AM33XX_PM_RTC_PWRSTCTRL_OFFSET, | ||
60 | .pwrstst_offs = AM33XX_PM_RTC_PWRSTST_OFFSET, | ||
61 | .pwrsts = PWRSTS_ON, | ||
62 | .logicretstate_mask = AM33XX_LOGICRETSTATE_MASK, | ||
63 | }; | ||
64 | |||
65 | static struct powerdomain wkup_33xx_pwrdm = { | ||
66 | .name = "wkup_pwrdm", | ||
67 | .voltdm = { .name = "core" }, | ||
68 | .prcm_offs = AM33XX_PRM_WKUP_MOD, | ||
69 | .pwrstctrl_offs = AM33XX_PM_WKUP_PWRSTCTRL_OFFSET, | ||
70 | .pwrstst_offs = AM33XX_PM_WKUP_PWRSTST_OFFSET, | ||
71 | .pwrsts = PWRSTS_ON, | ||
72 | .logicretstate_mask = AM33XX_LOGICRETSTATE_3_3_MASK, | ||
73 | }; | ||
74 | |||
75 | static struct powerdomain per_33xx_pwrdm = { | ||
76 | .name = "per_pwrdm", | ||
77 | .voltdm = { .name = "core" }, | ||
78 | .prcm_offs = AM33XX_PRM_PER_MOD, | ||
79 | .pwrstctrl_offs = AM33XX_PM_PER_PWRSTCTRL_OFFSET, | ||
80 | .pwrstst_offs = AM33XX_PM_PER_PWRSTST_OFFSET, | ||
81 | .pwrsts = PWRSTS_OFF_RET_ON, | ||
82 | .pwrsts_logic_ret = PWRSTS_OFF_RET, | ||
83 | .flags = PWRDM_HAS_LOWPOWERSTATECHANGE, | ||
84 | .banks = 3, | ||
85 | .logicretstate_mask = AM33XX_LOGICRETSTATE_3_3_MASK, | ||
86 | .mem_on_mask = { | ||
87 | [0] = AM33XX_PRUSS_MEM_ONSTATE_MASK, /* pruss_mem */ | ||
88 | [1] = AM33XX_PER_MEM_ONSTATE_MASK, /* per_mem */ | ||
89 | [2] = AM33XX_RAM_MEM_ONSTATE_MASK, /* ram_mem */ | ||
90 | }, | ||
91 | .mem_ret_mask = { | ||
92 | [0] = AM33XX_PRUSS_MEM_RETSTATE_MASK, /* pruss_mem */ | ||
93 | [1] = AM33XX_PER_MEM_RETSTATE_MASK, /* per_mem */ | ||
94 | [2] = AM33XX_RAM_MEM_RETSTATE_MASK, /* ram_mem */ | ||
95 | }, | ||
96 | .mem_pwrst_mask = { | ||
97 | [0] = AM33XX_PRUSS_MEM_STATEST_MASK, /* pruss_mem */ | ||
98 | [1] = AM33XX_PER_MEM_STATEST_MASK, /* per_mem */ | ||
99 | [2] = AM33XX_RAM_MEM_STATEST_MASK, /* ram_mem */ | ||
100 | }, | ||
101 | .mem_retst_mask = { | ||
102 | [0] = AM33XX_PRUSS_MEM_RETSTATE_MASK, /* pruss_mem */ | ||
103 | [1] = AM33XX_PER_MEM_RETSTATE_MASK, /* per_mem */ | ||
104 | [2] = AM33XX_RAM_MEM_RETSTATE_MASK, /* ram_mem */ | ||
105 | }, | ||
106 | .pwrsts_mem_ret = { | ||
107 | [0] = PWRSTS_OFF_RET, /* pruss_mem */ | ||
108 | [1] = PWRSTS_OFF_RET, /* per_mem */ | ||
109 | [2] = PWRSTS_OFF_RET, /* ram_mem */ | ||
110 | }, | ||
111 | .pwrsts_mem_on = { | ||
112 | [0] = PWRSTS_ON, /* pruss_mem */ | ||
113 | [1] = PWRSTS_ON, /* per_mem */ | ||
114 | [2] = PWRSTS_ON, /* ram_mem */ | ||
115 | }, | ||
116 | }; | ||
117 | |||
118 | static struct powerdomain mpu_33xx_pwrdm = { | ||
119 | .name = "mpu_pwrdm", | ||
120 | .voltdm = { .name = "mpu" }, | ||
121 | .prcm_offs = AM33XX_PRM_MPU_MOD, | ||
122 | .pwrstctrl_offs = AM33XX_PM_MPU_PWRSTCTRL_OFFSET, | ||
123 | .pwrstst_offs = AM33XX_PM_MPU_PWRSTST_OFFSET, | ||
124 | .pwrsts = PWRSTS_OFF_RET_ON, | ||
125 | .pwrsts_logic_ret = PWRSTS_OFF_RET, | ||
126 | .flags = PWRDM_HAS_LOWPOWERSTATECHANGE, | ||
127 | .banks = 3, | ||
128 | .logicretstate_mask = AM33XX_LOGICRETSTATE_MASK, | ||
129 | .mem_on_mask = { | ||
130 | [0] = AM33XX_MPU_L1_ONSTATE_MASK, /* mpu_l1 */ | ||
131 | [1] = AM33XX_MPU_L2_ONSTATE_MASK, /* mpu_l2 */ | ||
132 | [2] = AM33XX_MPU_RAM_ONSTATE_MASK, /* mpu_ram */ | ||
133 | }, | ||
134 | .mem_ret_mask = { | ||
135 | [0] = AM33XX_MPU_L1_RETSTATE_MASK, /* mpu_l1 */ | ||
136 | [1] = AM33XX_MPU_L2_RETSTATE_MASK, /* mpu_l2 */ | ||
137 | [2] = AM33XX_MPU_RAM_RETSTATE_MASK, /* mpu_ram */ | ||
138 | }, | ||
139 | .mem_pwrst_mask = { | ||
140 | [0] = AM33XX_MPU_L1_STATEST_MASK, /* mpu_l1 */ | ||
141 | [1] = AM33XX_MPU_L2_STATEST_MASK, /* mpu_l2 */ | ||
142 | [2] = AM33XX_MPU_RAM_STATEST_MASK, /* mpu_ram */ | ||
143 | }, | ||
144 | .mem_retst_mask = { | ||
145 | [0] = AM33XX_MPU_L1_RETSTATE_MASK, /* mpu_l1 */ | ||
146 | [1] = AM33XX_MPU_L2_RETSTATE_MASK, /* mpu_l2 */ | ||
147 | [2] = AM33XX_MPU_RAM_RETSTATE_MASK, /* mpu_ram */ | ||
148 | }, | ||
149 | .pwrsts_mem_ret = { | ||
150 | [0] = PWRSTS_OFF_RET, /* mpu_l1 */ | ||
151 | [1] = PWRSTS_OFF_RET, /* mpu_l2 */ | ||
152 | [2] = PWRSTS_OFF_RET, /* mpu_ram */ | ||
153 | }, | ||
154 | .pwrsts_mem_on = { | ||
155 | [0] = PWRSTS_ON, /* mpu_l1 */ | ||
156 | [1] = PWRSTS_ON, /* mpu_l2 */ | ||
157 | [2] = PWRSTS_ON, /* mpu_ram */ | ||
158 | }, | ||
159 | }; | ||
160 | |||
161 | static struct powerdomain cefuse_33xx_pwrdm = { | ||
162 | .name = "cefuse_pwrdm", | ||
163 | .voltdm = { .name = "core" }, | ||
164 | .prcm_offs = AM33XX_PRM_CEFUSE_MOD, | ||
165 | .pwrstctrl_offs = AM33XX_PM_CEFUSE_PWRSTCTRL_OFFSET, | ||
166 | .pwrstst_offs = AM33XX_PM_CEFUSE_PWRSTST_OFFSET, | ||
167 | .pwrsts = PWRSTS_OFF_ON, | ||
168 | }; | ||
169 | |||
170 | static struct powerdomain *powerdomains_am33xx[] __initdata = { | ||
171 | &gfx_33xx_pwrdm, | ||
172 | &rtc_33xx_pwrdm, | ||
173 | &wkup_33xx_pwrdm, | ||
174 | &per_33xx_pwrdm, | ||
175 | &mpu_33xx_pwrdm, | ||
176 | &cefuse_33xx_pwrdm, | ||
177 | NULL, | ||
178 | }; | ||
179 | |||
180 | void __init am33xx_powerdomains_init(void) | ||
181 | { | ||
182 | pwrdm_register_platform_funcs(&am33xx_pwrdm_operations); | ||
183 | pwrdm_register_pwrdms(powerdomains_am33xx); | ||
184 | pwrdm_complete_init(); | ||
185 | } | ||
diff --git a/arch/arm/mach-omap2/prm-regbits-33xx.h b/arch/arm/mach-omap2/prm-regbits-33xx.h new file mode 100644 index 000000000000..0221b5c20e87 --- /dev/null +++ b/arch/arm/mach-omap2/prm-regbits-33xx.h | |||
@@ -0,0 +1,357 @@ | |||
1 | /* | ||
2 | * AM33XX PRM_XXX register bits | ||
3 | * | ||
4 | * Copyright (C) 2011-2012 Texas Instruments Incorporated - http://www.ti.com/ | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or | ||
7 | * modify it under the terms of the GNU General Public License as | ||
8 | * published by the Free Software Foundation version 2. | ||
9 | * | ||
10 | * This program is distributed "as is" WITHOUT ANY WARRANTY of any | ||
11 | * kind, whether express or implied; without even the implied warranty | ||
12 | * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
13 | * GNU General Public License for more details. | ||
14 | */ | ||
15 | |||
16 | #ifndef __ARCH_ARM_MACH_OMAP2_PRM_REGBITS_33XX_H | ||
17 | #define __ARCH_ARM_MACH_OMAP2_PRM_REGBITS_33XX_H | ||
18 | |||
19 | #include "prm.h" | ||
20 | |||
21 | /* Used by PRM_LDO_SRAM_CORE_SETUP, PRM_LDO_SRAM_MPU_SETUP */ | ||
22 | #define AM33XX_ABBOFF_ACT_EXPORT_SHIFT 1 | ||
23 | #define AM33XX_ABBOFF_ACT_EXPORT_MASK (1 << 1) | ||
24 | |||
25 | /* Used by PRM_LDO_SRAM_CORE_SETUP, PRM_LDO_SRAM_MPU_SETUP */ | ||
26 | #define AM33XX_ABBOFF_SLEEP_EXPORT_SHIFT 2 | ||
27 | #define AM33XX_ABBOFF_SLEEP_EXPORT_MASK (1 << 2) | ||
28 | |||
29 | /* Used by PRM_LDO_SRAM_CORE_SETUP, PRM_LDO_SRAM_MPU_SETUP */ | ||
30 | #define AM33XX_AIPOFF_SHIFT 8 | ||
31 | #define AM33XX_AIPOFF_MASK (1 << 8) | ||
32 | |||
33 | /* Used by PM_WKUP_PWRSTST */ | ||
34 | #define AM33XX_DEBUGSS_MEM_STATEST_SHIFT 17 | ||
35 | #define AM33XX_DEBUGSS_MEM_STATEST_MASK (0x3 << 17) | ||
36 | |||
37 | /* Used by PRM_LDO_SRAM_CORE_SETUP, PRM_LDO_SRAM_MPU_SETUP */ | ||
38 | #define AM33XX_DISABLE_RTA_EXPORT_SHIFT 0 | ||
39 | #define AM33XX_DISABLE_RTA_EXPORT_MASK (1 << 0) | ||
40 | |||
41 | /* Used by PRM_IRQENABLE_M3, PRM_IRQENABLE_MPU */ | ||
42 | #define AM33XX_DPLL_CORE_RECAL_EN_SHIFT 12 | ||
43 | #define AM33XX_DPLL_CORE_RECAL_EN_MASK (1 << 12) | ||
44 | |||
45 | /* Used by PRM_IRQSTATUS_M3, PRM_IRQSTATUS_MPU */ | ||
46 | #define AM33XX_DPLL_CORE_RECAL_ST_SHIFT 12 | ||
47 | #define AM33XX_DPLL_CORE_RECAL_ST_MASK (1 << 12) | ||
48 | |||
49 | /* Used by PRM_IRQENABLE_M3, PRM_IRQENABLE_MPU */ | ||
50 | #define AM33XX_DPLL_DDR_RECAL_EN_SHIFT 14 | ||
51 | #define AM33XX_DPLL_DDR_RECAL_EN_MASK (1 << 14) | ||
52 | |||
53 | /* Used by PRM_IRQSTATUS_M3, PRM_IRQSTATUS_MPU */ | ||
54 | #define AM33XX_DPLL_DDR_RECAL_ST_SHIFT 14 | ||
55 | #define AM33XX_DPLL_DDR_RECAL_ST_MASK (1 << 14) | ||
56 | |||
57 | /* Used by PRM_IRQENABLE_M3, PRM_IRQENABLE_MPU */ | ||
58 | #define AM33XX_DPLL_DISP_RECAL_EN_SHIFT 15 | ||
59 | #define AM33XX_DPLL_DISP_RECAL_EN_MASK (1 << 15) | ||
60 | |||
61 | /* Used by PRM_IRQSTATUS_M3, PRM_IRQSTATUS_MPU */ | ||
62 | #define AM33XX_DPLL_DISP_RECAL_ST_SHIFT 13 | ||
63 | #define AM33XX_DPLL_DISP_RECAL_ST_MASK (1 << 13) | ||
64 | |||
65 | /* Used by PRM_IRQENABLE_M3, PRM_IRQENABLE_MPU */ | ||
66 | #define AM33XX_DPLL_MPU_RECAL_EN_SHIFT 11 | ||
67 | #define AM33XX_DPLL_MPU_RECAL_EN_MASK (1 << 11) | ||
68 | |||
69 | /* Used by PRM_IRQSTATUS_M3, PRM_IRQSTATUS_MPU */ | ||
70 | #define AM33XX_DPLL_MPU_RECAL_ST_SHIFT 11 | ||
71 | #define AM33XX_DPLL_MPU_RECAL_ST_MASK (1 << 11) | ||
72 | |||
73 | /* Used by PRM_IRQENABLE_M3, PRM_IRQENABLE_MPU */ | ||
74 | #define AM33XX_DPLL_PER_RECAL_EN_SHIFT 13 | ||
75 | #define AM33XX_DPLL_PER_RECAL_EN_MASK (1 << 13) | ||
76 | |||
77 | /* Used by PRM_IRQSTATUS_M3, PRM_IRQSTATUS_MPU */ | ||
78 | #define AM33XX_DPLL_PER_RECAL_ST_SHIFT 15 | ||
79 | #define AM33XX_DPLL_PER_RECAL_ST_MASK (1 << 15) | ||
80 | |||
81 | /* Used by RM_WKUP_RSTST */ | ||
82 | #define AM33XX_EMULATION_M3_RST_SHIFT 6 | ||
83 | #define AM33XX_EMULATION_M3_RST_MASK (1 << 6) | ||
84 | |||
85 | /* Used by RM_MPU_RSTST */ | ||
86 | #define AM33XX_EMULATION_MPU_RST_SHIFT 5 | ||
87 | #define AM33XX_EMULATION_MPU_RST_MASK (1 << 5) | ||
88 | |||
89 | /* Used by PRM_LDO_SRAM_CORE_SETUP, PRM_LDO_SRAM_MPU_SETUP */ | ||
90 | #define AM33XX_ENFUNC1_EXPORT_SHIFT 3 | ||
91 | #define AM33XX_ENFUNC1_EXPORT_MASK (1 << 3) | ||
92 | |||
93 | /* Used by PRM_LDO_SRAM_CORE_SETUP, PRM_LDO_SRAM_MPU_SETUP */ | ||
94 | #define AM33XX_ENFUNC3_EXPORT_SHIFT 5 | ||
95 | #define AM33XX_ENFUNC3_EXPORT_MASK (1 << 5) | ||
96 | |||
97 | /* Used by PRM_LDO_SRAM_CORE_SETUP, PRM_LDO_SRAM_MPU_SETUP */ | ||
98 | #define AM33XX_ENFUNC4_SHIFT 6 | ||
99 | #define AM33XX_ENFUNC4_MASK (1 << 6) | ||
100 | |||
101 | /* Used by PRM_LDO_SRAM_CORE_SETUP, PRM_LDO_SRAM_MPU_SETUP */ | ||
102 | #define AM33XX_ENFUNC5_SHIFT 7 | ||
103 | #define AM33XX_ENFUNC5_MASK (1 << 7) | ||
104 | |||
105 | /* Used by PRM_RSTST */ | ||
106 | #define AM33XX_EXTERNAL_WARM_RST_SHIFT 5 | ||
107 | #define AM33XX_EXTERNAL_WARM_RST_MASK (1 << 5) | ||
108 | |||
109 | /* Used by PRM_IRQENABLE_M3, PRM_IRQENABLE_MPU */ | ||
110 | #define AM33XX_FORCEWKUP_EN_SHIFT 10 | ||
111 | #define AM33XX_FORCEWKUP_EN_MASK (1 << 10) | ||
112 | |||
113 | /* Used by PRM_IRQSTATUS_M3, PRM_IRQSTATUS_MPU */ | ||
114 | #define AM33XX_FORCEWKUP_ST_SHIFT 10 | ||
115 | #define AM33XX_FORCEWKUP_ST_MASK (1 << 10) | ||
116 | |||
117 | /* Used by PM_GFX_PWRSTCTRL */ | ||
118 | #define AM33XX_GFX_MEM_ONSTATE_SHIFT 17 | ||
119 | #define AM33XX_GFX_MEM_ONSTATE_MASK (0x3 << 17) | ||
120 | |||
121 | /* Used by PM_GFX_PWRSTCTRL */ | ||
122 | #define AM33XX_GFX_MEM_RETSTATE_SHIFT 6 | ||
123 | #define AM33XX_GFX_MEM_RETSTATE_MASK (1 << 6) | ||
124 | |||
125 | /* Used by PM_GFX_PWRSTST */ | ||
126 | #define AM33XX_GFX_MEM_STATEST_SHIFT 4 | ||
127 | #define AM33XX_GFX_MEM_STATEST_MASK (0x3 << 4) | ||
128 | |||
129 | /* Used by RM_GFX_RSTCTRL, RM_GFX_RSTST */ | ||
130 | #define AM33XX_GFX_RST_SHIFT 0 | ||
131 | #define AM33XX_GFX_RST_MASK (1 << 0) | ||
132 | |||
133 | /* Used by PRM_RSTST */ | ||
134 | #define AM33XX_GLOBAL_COLD_RST_SHIFT 0 | ||
135 | #define AM33XX_GLOBAL_COLD_RST_MASK (1 << 0) | ||
136 | |||
137 | /* Used by PRM_RSTST */ | ||
138 | #define AM33XX_GLOBAL_WARM_SW_RST_SHIFT 1 | ||
139 | #define AM33XX_GLOBAL_WARM_SW_RST_MASK (1 << 1) | ||
140 | |||
141 | /* Used by RM_WKUP_RSTST */ | ||
142 | #define AM33XX_ICECRUSHER_M3_RST_SHIFT 7 | ||
143 | #define AM33XX_ICECRUSHER_M3_RST_MASK (1 << 7) | ||
144 | |||
145 | /* Used by RM_MPU_RSTST */ | ||
146 | #define AM33XX_ICECRUSHER_MPU_RST_SHIFT 6 | ||
147 | #define AM33XX_ICECRUSHER_MPU_RST_MASK (1 << 6) | ||
148 | |||
149 | /* Used by PRM_RSTST */ | ||
150 | #define AM33XX_ICEPICK_RST_SHIFT 9 | ||
151 | #define AM33XX_ICEPICK_RST_MASK (1 << 9) | ||
152 | |||
153 | /* Used by RM_PER_RSTCTRL */ | ||
154 | #define AM33XX_PRUSS_LRST_SHIFT 1 | ||
155 | #define AM33XX_PRUSS_LRST_MASK (1 << 1) | ||
156 | |||
157 | /* Used by PM_PER_PWRSTCTRL */ | ||
158 | #define AM33XX_PRUSS_MEM_ONSTATE_SHIFT 5 | ||
159 | #define AM33XX_PRUSS_MEM_ONSTATE_MASK (0x3 << 5) | ||
160 | |||
161 | /* Used by PM_PER_PWRSTCTRL */ | ||
162 | #define AM33XX_PRUSS_MEM_RETSTATE_SHIFT 7 | ||
163 | #define AM33XX_PRUSS_MEM_RETSTATE_MASK (1 << 7) | ||
164 | |||
165 | /* Used by PM_PER_PWRSTST */ | ||
166 | #define AM33XX_PRUSS_MEM_STATEST_SHIFT 23 | ||
167 | #define AM33XX_PRUSS_MEM_STATEST_MASK (0x3 << 23) | ||
168 | |||
169 | /* | ||
170 | * Used by PM_GFX_PWRSTST, PM_CEFUSE_PWRSTST, PM_PER_PWRSTST, PM_MPU_PWRSTST, | ||
171 | * PM_WKUP_PWRSTST, PM_RTC_PWRSTST | ||
172 | */ | ||
173 | #define AM33XX_INTRANSITION_SHIFT 20 | ||
174 | #define AM33XX_INTRANSITION_MASK (1 << 20) | ||
175 | |||
176 | /* Used by PM_CEFUSE_PWRSTST */ | ||
177 | #define AM33XX_LASTPOWERSTATEENTERED_SHIFT 24 | ||
178 | #define AM33XX_LASTPOWERSTATEENTERED_MASK (0x3 << 24) | ||
179 | |||
180 | /* Used by PM_GFX_PWRSTCTRL, PM_MPU_PWRSTCTRL, PM_RTC_PWRSTCTRL */ | ||
181 | #define AM33XX_LOGICRETSTATE_SHIFT 2 | ||
182 | #define AM33XX_LOGICRETSTATE_MASK (1 << 2) | ||
183 | |||
184 | /* Renamed from LOGICRETSTATE Used by PM_PER_PWRSTCTRL, PM_WKUP_PWRSTCTRL */ | ||
185 | #define AM33XX_LOGICRETSTATE_3_3_SHIFT 3 | ||
186 | #define AM33XX_LOGICRETSTATE_3_3_MASK (1 << 3) | ||
187 | |||
188 | /* | ||
189 | * Used by PM_GFX_PWRSTST, PM_CEFUSE_PWRSTST, PM_PER_PWRSTST, PM_MPU_PWRSTST, | ||
190 | * PM_WKUP_PWRSTST, PM_RTC_PWRSTST | ||
191 | */ | ||
192 | #define AM33XX_LOGICSTATEST_SHIFT 2 | ||
193 | #define AM33XX_LOGICSTATEST_MASK (1 << 2) | ||
194 | |||
195 | /* | ||
196 | * Used by PM_GFX_PWRSTCTRL, PM_CEFUSE_PWRSTCTRL, PM_PER_PWRSTCTRL, | ||
197 | * PM_MPU_PWRSTCTRL, PM_WKUP_PWRSTCTRL, PM_RTC_PWRSTCTRL | ||
198 | */ | ||
199 | #define AM33XX_LOWPOWERSTATECHANGE_SHIFT 4 | ||
200 | #define AM33XX_LOWPOWERSTATECHANGE_MASK (1 << 4) | ||
201 | |||
202 | /* Used by PM_MPU_PWRSTCTRL */ | ||
203 | #define AM33XX_MPU_L1_ONSTATE_SHIFT 18 | ||
204 | #define AM33XX_MPU_L1_ONSTATE_MASK (0x3 << 18) | ||
205 | |||
206 | /* Used by PM_MPU_PWRSTCTRL */ | ||
207 | #define AM33XX_MPU_L1_RETSTATE_SHIFT 22 | ||
208 | #define AM33XX_MPU_L1_RETSTATE_MASK (1 << 22) | ||
209 | |||
210 | /* Used by PM_MPU_PWRSTST */ | ||
211 | #define AM33XX_MPU_L1_STATEST_SHIFT 6 | ||
212 | #define AM33XX_MPU_L1_STATEST_MASK (0x3 << 6) | ||
213 | |||
214 | /* Used by PM_MPU_PWRSTCTRL */ | ||
215 | #define AM33XX_MPU_L2_ONSTATE_SHIFT 20 | ||
216 | #define AM33XX_MPU_L2_ONSTATE_MASK (0x3 << 20) | ||
217 | |||
218 | /* Used by PM_MPU_PWRSTCTRL */ | ||
219 | #define AM33XX_MPU_L2_RETSTATE_SHIFT 23 | ||
220 | #define AM33XX_MPU_L2_RETSTATE_MASK (1 << 23) | ||
221 | |||
222 | /* Used by PM_MPU_PWRSTST */ | ||
223 | #define AM33XX_MPU_L2_STATEST_SHIFT 8 | ||
224 | #define AM33XX_MPU_L2_STATEST_MASK (0x3 << 8) | ||
225 | |||
226 | /* Used by PM_MPU_PWRSTCTRL */ | ||
227 | #define AM33XX_MPU_RAM_ONSTATE_SHIFT 16 | ||
228 | #define AM33XX_MPU_RAM_ONSTATE_MASK (0x3 << 16) | ||
229 | |||
230 | /* Used by PM_MPU_PWRSTCTRL */ | ||
231 | #define AM33XX_MPU_RAM_RETSTATE_SHIFT 24 | ||
232 | #define AM33XX_MPU_RAM_RETSTATE_MASK (1 << 24) | ||
233 | |||
234 | /* Used by PM_MPU_PWRSTST */ | ||
235 | #define AM33XX_MPU_RAM_STATEST_SHIFT 4 | ||
236 | #define AM33XX_MPU_RAM_STATEST_MASK (0x3 << 4) | ||
237 | |||
238 | /* Used by PRM_RSTST */ | ||
239 | #define AM33XX_MPU_SECURITY_VIOL_RST_SHIFT 2 | ||
240 | #define AM33XX_MPU_SECURITY_VIOL_RST_MASK (1 << 2) | ||
241 | |||
242 | /* Used by PRM_SRAM_COUNT */ | ||
243 | #define AM33XX_PCHARGECNT_VALUE_SHIFT 0 | ||
244 | #define AM33XX_PCHARGECNT_VALUE_MASK (0x3f << 0) | ||
245 | |||
246 | /* Used by RM_PER_RSTCTRL */ | ||
247 | #define AM33XX_PCI_LRST_SHIFT 0 | ||
248 | #define AM33XX_PCI_LRST_MASK (1 << 0) | ||
249 | |||
250 | /* Renamed from PCI_LRST Used by RM_PER_RSTST */ | ||
251 | #define AM33XX_PCI_LRST_5_5_SHIFT 5 | ||
252 | #define AM33XX_PCI_LRST_5_5_MASK (1 << 5) | ||
253 | |||
254 | /* Used by PM_PER_PWRSTCTRL */ | ||
255 | #define AM33XX_PER_MEM_ONSTATE_SHIFT 25 | ||
256 | #define AM33XX_PER_MEM_ONSTATE_MASK (0x3 << 25) | ||
257 | |||
258 | /* Used by PM_PER_PWRSTCTRL */ | ||
259 | #define AM33XX_PER_MEM_RETSTATE_SHIFT 29 | ||
260 | #define AM33XX_PER_MEM_RETSTATE_MASK (1 << 29) | ||
261 | |||
262 | /* Used by PM_PER_PWRSTST */ | ||
263 | #define AM33XX_PER_MEM_STATEST_SHIFT 17 | ||
264 | #define AM33XX_PER_MEM_STATEST_MASK (0x3 << 17) | ||
265 | |||
266 | /* | ||
267 | * Used by PM_GFX_PWRSTCTRL, PM_CEFUSE_PWRSTCTRL, PM_PER_PWRSTCTRL, | ||
268 | * PM_MPU_PWRSTCTRL | ||
269 | */ | ||
270 | #define AM33XX_POWERSTATE_SHIFT 0 | ||
271 | #define AM33XX_POWERSTATE_MASK (0x3 << 0) | ||
272 | |||
273 | /* Used by PM_GFX_PWRSTST, PM_CEFUSE_PWRSTST, PM_PER_PWRSTST, PM_MPU_PWRSTST */ | ||
274 | #define AM33XX_POWERSTATEST_SHIFT 0 | ||
275 | #define AM33XX_POWERSTATEST_MASK (0x3 << 0) | ||
276 | |||
277 | /* Used by PM_PER_PWRSTCTRL */ | ||
278 | #define AM33XX_RAM_MEM_ONSTATE_SHIFT 30 | ||
279 | #define AM33XX_RAM_MEM_ONSTATE_MASK (0x3 << 30) | ||
280 | |||
281 | /* Used by PM_PER_PWRSTCTRL */ | ||
282 | #define AM33XX_RAM_MEM_RETSTATE_SHIFT 27 | ||
283 | #define AM33XX_RAM_MEM_RETSTATE_MASK (1 << 27) | ||
284 | |||
285 | /* Used by PM_PER_PWRSTST */ | ||
286 | #define AM33XX_RAM_MEM_STATEST_SHIFT 21 | ||
287 | #define AM33XX_RAM_MEM_STATEST_MASK (0x3 << 21) | ||
288 | |||
289 | /* Used by PRM_LDO_SRAM_CORE_CTRL, PRM_LDO_SRAM_MPU_CTRL */ | ||
290 | #define AM33XX_RETMODE_ENABLE_SHIFT 0 | ||
291 | #define AM33XX_RETMODE_ENABLE_MASK (1 << 0) | ||
292 | |||
293 | /* Used by REVISION_PRM */ | ||
294 | #define AM33XX_REV_SHIFT 0 | ||
295 | #define AM33XX_REV_MASK (0xff << 0) | ||
296 | |||
297 | /* Used by PRM_RSTTIME */ | ||
298 | #define AM33XX_RSTTIME1_SHIFT 0 | ||
299 | #define AM33XX_RSTTIME1_MASK (0xff << 0) | ||
300 | |||
301 | /* Used by PRM_RSTTIME */ | ||
302 | #define AM33XX_RSTTIME2_SHIFT 8 | ||
303 | #define AM33XX_RSTTIME2_MASK (0x1f << 8) | ||
304 | |||
305 | /* Used by PRM_RSTCTRL */ | ||
306 | #define AM33XX_RST_GLOBAL_COLD_SW_SHIFT 1 | ||
307 | #define AM33XX_RST_GLOBAL_COLD_SW_MASK (1 << 1) | ||
308 | |||
309 | /* Used by PRM_RSTCTRL */ | ||
310 | #define AM33XX_RST_GLOBAL_WARM_SW_SHIFT 0 | ||
311 | #define AM33XX_RST_GLOBAL_WARM_SW_MASK (1 << 0) | ||
312 | |||
313 | /* Used by PRM_SRAM_COUNT */ | ||
314 | #define AM33XX_SLPCNT_VALUE_SHIFT 16 | ||
315 | #define AM33XX_SLPCNT_VALUE_MASK (0xff << 16) | ||
316 | |||
317 | /* Used by PRM_LDO_SRAM_CORE_CTRL, PRM_LDO_SRAM_MPU_CTRL */ | ||
318 | #define AM33XX_SRAMLDO_STATUS_SHIFT 8 | ||
319 | #define AM33XX_SRAMLDO_STATUS_MASK (1 << 8) | ||
320 | |||
321 | /* Used by PRM_LDO_SRAM_CORE_CTRL, PRM_LDO_SRAM_MPU_CTRL */ | ||
322 | #define AM33XX_SRAM_IN_TRANSITION_SHIFT 9 | ||
323 | #define AM33XX_SRAM_IN_TRANSITION_MASK (1 << 9) | ||
324 | |||
325 | /* Used by PRM_SRAM_COUNT */ | ||
326 | #define AM33XX_STARTUP_COUNT_SHIFT 24 | ||
327 | #define AM33XX_STARTUP_COUNT_MASK (0xff << 24) | ||
328 | |||
329 | /* Used by PRM_IRQENABLE_M3, PRM_IRQENABLE_MPU */ | ||
330 | #define AM33XX_TRANSITION_EN_SHIFT 8 | ||
331 | #define AM33XX_TRANSITION_EN_MASK (1 << 8) | ||
332 | |||
333 | /* Used by PRM_IRQSTATUS_M3, PRM_IRQSTATUS_MPU */ | ||
334 | #define AM33XX_TRANSITION_ST_SHIFT 8 | ||
335 | #define AM33XX_TRANSITION_ST_MASK (1 << 8) | ||
336 | |||
337 | /* Used by PRM_SRAM_COUNT */ | ||
338 | #define AM33XX_VSETUPCNT_VALUE_SHIFT 8 | ||
339 | #define AM33XX_VSETUPCNT_VALUE_MASK (0xff << 8) | ||
340 | |||
341 | /* Used by PRM_RSTST */ | ||
342 | #define AM33XX_WDT0_RST_SHIFT 3 | ||
343 | #define AM33XX_WDT0_RST_MASK (1 << 3) | ||
344 | |||
345 | /* Used by PRM_RSTST */ | ||
346 | #define AM33XX_WDT1_RST_SHIFT 4 | ||
347 | #define AM33XX_WDT1_RST_MASK (1 << 4) | ||
348 | |||
349 | /* Used by RM_WKUP_RSTCTRL */ | ||
350 | #define AM33XX_WKUP_M3_LRST_SHIFT 3 | ||
351 | #define AM33XX_WKUP_M3_LRST_MASK (1 << 3) | ||
352 | |||
353 | /* Renamed from WKUP_M3_LRST Used by RM_WKUP_RSTST */ | ||
354 | #define AM33XX_WKUP_M3_LRST_5_5_SHIFT 5 | ||
355 | #define AM33XX_WKUP_M3_LRST_5_5_MASK (1 << 5) | ||
356 | |||
357 | #endif | ||
diff --git a/arch/arm/mach-omap2/prm33xx.c b/arch/arm/mach-omap2/prm33xx.c new file mode 100644 index 000000000000..e7dbb6cf1255 --- /dev/null +++ b/arch/arm/mach-omap2/prm33xx.c | |||
@@ -0,0 +1,135 @@ | |||
1 | /* | ||
2 | * AM33XX PRM functions | ||
3 | * | ||
4 | * Copyright (C) 2011-2012 Texas Instruments Incorporated - http://www.ti.com/ | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or | ||
7 | * modify it under the terms of the GNU General Public License as | ||
8 | * published by the Free Software Foundation version 2. | ||
9 | * | ||
10 | * This program is distributed "as is" WITHOUT ANY WARRANTY of any | ||
11 | * kind, whether express or implied; without even the implied warranty | ||
12 | * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
13 | * GNU General Public License for more details. | ||
14 | */ | ||
15 | |||
16 | #include <linux/kernel.h> | ||
17 | #include <linux/types.h> | ||
18 | #include <linux/errno.h> | ||
19 | #include <linux/err.h> | ||
20 | #include <linux/io.h> | ||
21 | |||
22 | #include <plat/common.h> | ||
23 | |||
24 | #include "common.h" | ||
25 | #include "prm33xx.h" | ||
26 | #include "prm-regbits-33xx.h" | ||
27 | |||
28 | /* Read a register in a PRM instance */ | ||
29 | u32 am33xx_prm_read_reg(s16 inst, u16 idx) | ||
30 | { | ||
31 | return __raw_readl(prm_base + inst + idx); | ||
32 | } | ||
33 | |||
34 | /* Write into a register in a PRM instance */ | ||
35 | void am33xx_prm_write_reg(u32 val, s16 inst, u16 idx) | ||
36 | { | ||
37 | __raw_writel(val, prm_base + inst + idx); | ||
38 | } | ||
39 | |||
40 | /* Read-modify-write a register in PRM. Caller must lock */ | ||
41 | u32 am33xx_prm_rmw_reg_bits(u32 mask, u32 bits, s16 inst, s16 idx) | ||
42 | { | ||
43 | u32 v; | ||
44 | |||
45 | v = am33xx_prm_read_reg(inst, idx); | ||
46 | v &= ~mask; | ||
47 | v |= bits; | ||
48 | am33xx_prm_write_reg(v, inst, idx); | ||
49 | |||
50 | return v; | ||
51 | } | ||
52 | |||
53 | /** | ||
54 | * am33xx_prm_is_hardreset_asserted - read the HW reset line state of | ||
55 | * submodules contained in the hwmod module | ||
56 | * @shift: register bit shift corresponding to the reset line to check | ||
57 | * @inst: CM instance register offset (*_INST macro) | ||
58 | * @rstctrl_offs: RM_RSTCTRL register address offset for this module | ||
59 | * | ||
60 | * Returns 1 if the (sub)module hardreset line is currently asserted, | ||
61 | * 0 if the (sub)module hardreset line is not currently asserted, or | ||
62 | * -EINVAL upon parameter error. | ||
63 | */ | ||
64 | int am33xx_prm_is_hardreset_asserted(u8 shift, s16 inst, u16 rstctrl_offs) | ||
65 | { | ||
66 | u32 v; | ||
67 | |||
68 | v = am33xx_prm_read_reg(inst, rstctrl_offs); | ||
69 | v &= 1 << shift; | ||
70 | v >>= shift; | ||
71 | |||
72 | return v; | ||
73 | } | ||
74 | |||
75 | /** | ||
76 | * am33xx_prm_assert_hardreset - assert the HW reset line of a submodule | ||
77 | * @shift: register bit shift corresponding to the reset line to assert | ||
78 | * @inst: CM instance register offset (*_INST macro) | ||
79 | * @rstctrl_reg: RM_RSTCTRL register address for this module | ||
80 | * | ||
81 | * Some IPs like dsp, ipu or iva contain processors that require an HW | ||
82 | * reset line to be asserted / deasserted in order to fully enable the | ||
83 | * IP. These modules may have multiple hard-reset lines that reset | ||
84 | * different 'submodules' inside the IP block. This function will | ||
85 | * place the submodule into reset. Returns 0 upon success or -EINVAL | ||
86 | * upon an argument error. | ||
87 | */ | ||
88 | int am33xx_prm_assert_hardreset(u8 shift, s16 inst, u16 rstctrl_offs) | ||
89 | { | ||
90 | u32 mask = 1 << shift; | ||
91 | |||
92 | am33xx_prm_rmw_reg_bits(mask, mask, inst, rstctrl_offs); | ||
93 | |||
94 | return 0; | ||
95 | } | ||
96 | |||
97 | /** | ||
98 | * am33xx_prm_deassert_hardreset - deassert a submodule hardreset line and | ||
99 | * wait | ||
100 | * @shift: register bit shift corresponding to the reset line to deassert | ||
101 | * @inst: CM instance register offset (*_INST macro) | ||
102 | * @rstctrl_reg: RM_RSTCTRL register address for this module | ||
103 | * @rstst_reg: RM_RSTST register address for this module | ||
104 | * | ||
105 | * Some IPs like dsp, ipu or iva contain processors that require an HW | ||
106 | * reset line to be asserted / deasserted in order to fully enable the | ||
107 | * IP. These modules may have multiple hard-reset lines that reset | ||
108 | * different 'submodules' inside the IP block. This function will | ||
109 | * take the submodule out of reset and wait until the PRCM indicates | ||
110 | * that the reset has completed before returning. Returns 0 upon success or | ||
111 | * -EINVAL upon an argument error, -EEXIST if the submodule was already out | ||
112 | * of reset, or -EBUSY if the submodule did not exit reset promptly. | ||
113 | */ | ||
114 | int am33xx_prm_deassert_hardreset(u8 shift, s16 inst, | ||
115 | u16 rstctrl_offs, u16 rstst_offs) | ||
116 | { | ||
117 | int c; | ||
118 | u32 mask = 1 << shift; | ||
119 | |||
120 | /* Check the current status to avoid de-asserting the line twice */ | ||
121 | if (am33xx_prm_is_hardreset_asserted(shift, inst, rstctrl_offs) == 0) | ||
122 | return -EEXIST; | ||
123 | |||
124 | /* Clear the reset status by writing 1 to the status bit */ | ||
125 | am33xx_prm_rmw_reg_bits(0xffffffff, mask, inst, rstst_offs); | ||
126 | /* de-assert the reset control line */ | ||
127 | am33xx_prm_rmw_reg_bits(mask, 0, inst, rstctrl_offs); | ||
128 | /* wait the status to be set */ | ||
129 | |||
130 | omap_test_timeout(am33xx_prm_is_hardreset_asserted(shift, inst, | ||
131 | rstst_offs), | ||
132 | MAX_MODULE_HARDRESET_WAIT, c); | ||
133 | |||
134 | return (c == MAX_MODULE_HARDRESET_WAIT) ? -EBUSY : 0; | ||
135 | } | ||
diff --git a/arch/arm/mach-omap2/prm33xx.h b/arch/arm/mach-omap2/prm33xx.h new file mode 100644 index 000000000000..3f25c563a821 --- /dev/null +++ b/arch/arm/mach-omap2/prm33xx.h | |||
@@ -0,0 +1,129 @@ | |||
1 | /* | ||
2 | * AM33XX PRM instance offset macros | ||
3 | * | ||
4 | * Copyright (C) 2011-2012 Texas Instruments Incorporated - http://www.ti.com/ | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or | ||
7 | * modify it under the terms of the GNU General Public License as | ||
8 | * published by the Free Software Foundation version 2. | ||
9 | * | ||
10 | * This program is distributed "as is" WITHOUT ANY WARRANTY of any | ||
11 | * kind, whether express or implied; without even the implied warranty | ||
12 | * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
13 | * GNU General Public License for more details. | ||
14 | */ | ||
15 | |||
16 | #ifndef __ARCH_ARM_MACH_OMAP2_PRM33XX_H | ||
17 | #define __ARCH_ARM_MACH_OMAP2_PRM33XX_H | ||
18 | |||
19 | #include "prcm-common.h" | ||
20 | #include "prm.h" | ||
21 | |||
22 | #define AM33XX_PRM_BASE 0x44E00000 | ||
23 | |||
24 | #define AM33XX_PRM_REGADDR(inst, reg) \ | ||
25 | AM33XX_L4_WK_IO_ADDRESS(AM33XX_PRM_BASE + (inst) + (reg)) | ||
26 | |||
27 | |||
28 | /* PRM instances */ | ||
29 | #define AM33XX_PRM_OCP_SOCKET_MOD 0x0B00 | ||
30 | #define AM33XX_PRM_PER_MOD 0x0C00 | ||
31 | #define AM33XX_PRM_WKUP_MOD 0x0D00 | ||
32 | #define AM33XX_PRM_MPU_MOD 0x0E00 | ||
33 | #define AM33XX_PRM_DEVICE_MOD 0x0F00 | ||
34 | #define AM33XX_PRM_RTC_MOD 0x1000 | ||
35 | #define AM33XX_PRM_GFX_MOD 0x1100 | ||
36 | #define AM33XX_PRM_CEFUSE_MOD 0x1200 | ||
37 | |||
38 | /* PRM */ | ||
39 | |||
40 | /* PRM.OCP_SOCKET_PRM register offsets */ | ||
41 | #define AM33XX_REVISION_PRM_OFFSET 0x0000 | ||
42 | #define AM33XX_REVISION_PRM AM33XX_PRM_REGADDR(AM33XX_PRM_OCP_SOCKET_MOD, 0x0000) | ||
43 | #define AM33XX_PRM_IRQSTATUS_MPU_OFFSET 0x0004 | ||
44 | #define AM33XX_PRM_IRQSTATUS_MPU AM33XX_PRM_REGADDR(AM33XX_PRM_OCP_SOCKET_MOD, 0x0004) | ||
45 | #define AM33XX_PRM_IRQENABLE_MPU_OFFSET 0x0008 | ||
46 | #define AM33XX_PRM_IRQENABLE_MPU AM33XX_PRM_REGADDR(AM33XX_PRM_OCP_SOCKET_MOD, 0x0008) | ||
47 | #define AM33XX_PRM_IRQSTATUS_M3_OFFSET 0x000c | ||
48 | #define AM33XX_PRM_IRQSTATUS_M3 AM33XX_PRM_REGADDR(AM33XX_PRM_OCP_SOCKET_MOD, 0x000c) | ||
49 | #define AM33XX_PRM_IRQENABLE_M3_OFFSET 0x0010 | ||
50 | #define AM33XX_PRM_IRQENABLE_M3 AM33XX_PRM_REGADDR(AM33XX_PRM_OCP_SOCKET_MOD, 0x0010) | ||
51 | |||
52 | /* PRM.PER_PRM register offsets */ | ||
53 | #define AM33XX_RM_PER_RSTCTRL_OFFSET 0x0000 | ||
54 | #define AM33XX_RM_PER_RSTCTRL AM33XX_PRM_REGADDR(AM33XX_PRM_PER_MOD, 0x0000) | ||
55 | #define AM33XX_RM_PER_RSTST_OFFSET 0x0004 | ||
56 | #define AM33XX_RM_PER_RSTST AM33XX_PRM_REGADDR(AM33XX_PRM_PER_MOD, 0x0004) | ||
57 | #define AM33XX_PM_PER_PWRSTST_OFFSET 0x0008 | ||
58 | #define AM33XX_PM_PER_PWRSTST AM33XX_PRM_REGADDR(AM33XX_PRM_PER_MOD, 0x0008) | ||
59 | #define AM33XX_PM_PER_PWRSTCTRL_OFFSET 0x000c | ||
60 | #define AM33XX_PM_PER_PWRSTCTRL AM33XX_PRM_REGADDR(AM33XX_PRM_PER_MOD, 0x000c) | ||
61 | |||
62 | /* PRM.WKUP_PRM register offsets */ | ||
63 | #define AM33XX_RM_WKUP_RSTCTRL_OFFSET 0x0000 | ||
64 | #define AM33XX_RM_WKUP_RSTCTRL AM33XX_PRM_REGADDR(AM33XX_PRM_WKUP_MOD, 0x0000) | ||
65 | #define AM33XX_PM_WKUP_PWRSTCTRL_OFFSET 0x0004 | ||
66 | #define AM33XX_PM_WKUP_PWRSTCTRL AM33XX_PRM_REGADDR(AM33XX_PRM_WKUP_MOD, 0x0004) | ||
67 | #define AM33XX_PM_WKUP_PWRSTST_OFFSET 0x0008 | ||
68 | #define AM33XX_PM_WKUP_PWRSTST AM33XX_PRM_REGADDR(AM33XX_PRM_WKUP_MOD, 0x0008) | ||
69 | #define AM33XX_RM_WKUP_RSTST_OFFSET 0x000c | ||
70 | #define AM33XX_RM_WKUP_RSTST AM33XX_PRM_REGADDR(AM33XX_PRM_WKUP_MOD, 0x000c) | ||
71 | |||
72 | /* PRM.MPU_PRM register offsets */ | ||
73 | #define AM33XX_PM_MPU_PWRSTCTRL_OFFSET 0x0000 | ||
74 | #define AM33XX_PM_MPU_PWRSTCTRL AM33XX_PRM_REGADDR(AM33XX_PRM_MPU_MOD, 0x0000) | ||
75 | #define AM33XX_PM_MPU_PWRSTST_OFFSET 0x0004 | ||
76 | #define AM33XX_PM_MPU_PWRSTST AM33XX_PRM_REGADDR(AM33XX_PRM_MPU_MOD, 0x0004) | ||
77 | #define AM33XX_RM_MPU_RSTST_OFFSET 0x0008 | ||
78 | #define AM33XX_RM_MPU_RSTST AM33XX_PRM_REGADDR(AM33XX_PRM_MPU_MOD, 0x0008) | ||
79 | |||
80 | /* PRM.DEVICE_PRM register offsets */ | ||
81 | #define AM33XX_PRM_RSTCTRL_OFFSET 0x0000 | ||
82 | #define AM33XX_PRM_RSTCTRL AM33XX_PRM_REGADDR(AM33XX_PRM_DEVICE_MOD, 0x0000) | ||
83 | #define AM33XX_PRM_RSTTIME_OFFSET 0x0004 | ||
84 | #define AM33XX_PRM_RSTTIME AM33XX_PRM_REGADDR(AM33XX_PRM_DEVICE_MOD, 0x0004) | ||
85 | #define AM33XX_PRM_RSTST_OFFSET 0x0008 | ||
86 | #define AM33XX_PRM_RSTST AM33XX_PRM_REGADDR(AM33XX_PRM_DEVICE_MOD, 0x0008) | ||
87 | #define AM33XX_PRM_SRAM_COUNT_OFFSET 0x000c | ||
88 | #define AM33XX_PRM_SRAM_COUNT AM33XX_PRM_REGADDR(AM33XX_PRM_DEVICE_MOD, 0x000c) | ||
89 | #define AM33XX_PRM_LDO_SRAM_CORE_SETUP_OFFSET 0x0010 | ||
90 | #define AM33XX_PRM_LDO_SRAM_CORE_SETUP AM33XX_PRM_REGADDR(AM33XX_PRM_DEVICE_MOD, 0x0010) | ||
91 | #define AM33XX_PRM_LDO_SRAM_CORE_CTRL_OFFSET 0x0014 | ||
92 | #define AM33XX_PRM_LDO_SRAM_CORE_CTRL AM33XX_PRM_REGADDR(AM33XX_PRM_DEVICE_MOD, 0x0014) | ||
93 | #define AM33XX_PRM_LDO_SRAM_MPU_SETUP_OFFSET 0x0018 | ||
94 | #define AM33XX_PRM_LDO_SRAM_MPU_SETUP AM33XX_PRM_REGADDR(AM33XX_PRM_DEVICE_MOD, 0x0018) | ||
95 | #define AM33XX_PRM_LDO_SRAM_MPU_CTRL_OFFSET 0x001c | ||
96 | #define AM33XX_PRM_LDO_SRAM_MPU_CTRL AM33XX_PRM_REGADDR(AM33XX_PRM_DEVICE_MOD, 0x001c) | ||
97 | |||
98 | /* PRM.RTC_PRM register offsets */ | ||
99 | #define AM33XX_PM_RTC_PWRSTCTRL_OFFSET 0x0000 | ||
100 | #define AM33XX_PM_RTC_PWRSTCTRL AM33XX_PRM_REGADDR(AM33XX_PRM_RTC_MOD, 0x0000) | ||
101 | #define AM33XX_PM_RTC_PWRSTST_OFFSET 0x0004 | ||
102 | #define AM33XX_PM_RTC_PWRSTST AM33XX_PRM_REGADDR(AM33XX_PRM_RTC_MOD, 0x0004) | ||
103 | |||
104 | /* PRM.GFX_PRM register offsets */ | ||
105 | #define AM33XX_PM_GFX_PWRSTCTRL_OFFSET 0x0000 | ||
106 | #define AM33XX_PM_GFX_PWRSTCTRL AM33XX_PRM_REGADDR(AM33XX_PRM_GFX_MOD, 0x0000) | ||
107 | #define AM33XX_RM_GFX_RSTCTRL_OFFSET 0x0004 | ||
108 | #define AM33XX_RM_GFX_RSTCTRL AM33XX_PRM_REGADDR(AM33XX_PRM_GFX_MOD, 0x0004) | ||
109 | #define AM33XX_PM_GFX_PWRSTST_OFFSET 0x0010 | ||
110 | #define AM33XX_PM_GFX_PWRSTST AM33XX_PRM_REGADDR(AM33XX_PRM_GFX_MOD, 0x0010) | ||
111 | #define AM33XX_RM_GFX_RSTST_OFFSET 0x0014 | ||
112 | #define AM33XX_RM_GFX_RSTST AM33XX_PRM_REGADDR(AM33XX_PRM_GFX_MOD, 0x0014) | ||
113 | |||
114 | /* PRM.CEFUSE_PRM register offsets */ | ||
115 | #define AM33XX_PM_CEFUSE_PWRSTCTRL_OFFSET 0x0000 | ||
116 | #define AM33XX_PM_CEFUSE_PWRSTCTRL AM33XX_PRM_REGADDR(AM33XX_PRM_CEFUSE_MOD, 0x0000) | ||
117 | #define AM33XX_PM_CEFUSE_PWRSTST_OFFSET 0x0004 | ||
118 | #define AM33XX_PM_CEFUSE_PWRSTST AM33XX_PRM_REGADDR(AM33XX_PRM_CEFUSE_MOD, 0x0004) | ||
119 | |||
120 | extern u32 am33xx_prm_read_reg(s16 inst, u16 idx); | ||
121 | extern void am33xx_prm_write_reg(u32 val, s16 inst, u16 idx); | ||
122 | extern u32 am33xx_prm_rmw_reg_bits(u32 mask, u32 bits, s16 inst, s16 idx); | ||
123 | extern void am33xx_prm_global_warm_sw_reset(void); | ||
124 | extern int am33xx_prm_is_hardreset_asserted(u8 shift, s16 inst, | ||
125 | u16 rstctrl_offs); | ||
126 | extern int am33xx_prm_assert_hardreset(u8 shift, s16 inst, u16 rstctrl_offs); | ||
127 | extern int am33xx_prm_deassert_hardreset(u8 shift, s16 inst, | ||
128 | u16 rstctrl_offs, u16 rstst_offs); | ||
129 | #endif | ||
diff --git a/arch/arm/mach-omap2/timer.c b/arch/arm/mach-omap2/timer.c index 840929bd9dae..ea6a0eb13f05 100644 --- a/arch/arm/mach-omap2/timer.c +++ b/arch/arm/mach-omap2/timer.c | |||
@@ -368,6 +368,11 @@ OMAP_SYS_TIMER_INIT(3_secure, OMAP3_SECURE_TIMER, OMAP3_CLKEV_SOURCE, | |||
368 | OMAP_SYS_TIMER(3_secure) | 368 | OMAP_SYS_TIMER(3_secure) |
369 | #endif | 369 | #endif |
370 | 370 | ||
371 | #ifdef CONFIG_SOC_AM33XX | ||
372 | OMAP_SYS_TIMER_INIT(3_am33xx, 1, OMAP4_MPU_SOURCE, 2, OMAP4_MPU_SOURCE) | ||
373 | OMAP_SYS_TIMER(3_am33xx) | ||
374 | #endif | ||
375 | |||
371 | #ifdef CONFIG_ARCH_OMAP4 | 376 | #ifdef CONFIG_ARCH_OMAP4 |
372 | #ifdef CONFIG_LOCAL_TIMERS | 377 | #ifdef CONFIG_LOCAL_TIMERS |
373 | static DEFINE_TWD_LOCAL_TIMER(twd_local_timer, | 378 | static DEFINE_TWD_LOCAL_TIMER(twd_local_timer, |
diff --git a/arch/arm/mach-omap2/voltage.h b/arch/arm/mach-omap2/voltage.h index 16a1b092cf36..a7c43c1042be 100644 --- a/arch/arm/mach-omap2/voltage.h +++ b/arch/arm/mach-omap2/voltage.h | |||
@@ -156,6 +156,7 @@ int omap_voltage_late_init(void); | |||
156 | 156 | ||
157 | extern void omap2xxx_voltagedomains_init(void); | 157 | extern void omap2xxx_voltagedomains_init(void); |
158 | extern void omap3xxx_voltagedomains_init(void); | 158 | extern void omap3xxx_voltagedomains_init(void); |
159 | extern void am33xx_voltagedomains_init(void); | ||
159 | extern void omap44xx_voltagedomains_init(void); | 160 | extern void omap44xx_voltagedomains_init(void); |
160 | 161 | ||
161 | struct voltagedomain *voltdm_lookup(const char *name); | 162 | struct voltagedomain *voltdm_lookup(const char *name); |
diff --git a/arch/arm/mach-omap2/voltagedomains33xx_data.c b/arch/arm/mach-omap2/voltagedomains33xx_data.c new file mode 100644 index 000000000000..965458dc0cb9 --- /dev/null +++ b/arch/arm/mach-omap2/voltagedomains33xx_data.c | |||
@@ -0,0 +1,43 @@ | |||
1 | /* | ||
2 | * AM33XX voltage domain data | ||
3 | * | ||
4 | * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/ | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or | ||
7 | * modify it under the terms of the GNU General Public License as | ||
8 | * published by the Free Software Foundation version 2. | ||
9 | * | ||
10 | * This program is distributed "as is" WITHOUT ANY WARRANTY of any | ||
11 | * kind, whether express or implied; without even the implied warranty | ||
12 | * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
13 | * GNU General Public License for more details. | ||
14 | */ | ||
15 | |||
16 | #include <linux/kernel.h> | ||
17 | #include <linux/init.h> | ||
18 | |||
19 | #include "voltage.h" | ||
20 | |||
21 | static struct voltagedomain am33xx_voltdm_mpu = { | ||
22 | .name = "mpu", | ||
23 | }; | ||
24 | |||
25 | static struct voltagedomain am33xx_voltdm_core = { | ||
26 | .name = "core", | ||
27 | }; | ||
28 | |||
29 | static struct voltagedomain am33xx_voltdm_rtc = { | ||
30 | .name = "rtc", | ||
31 | }; | ||
32 | |||
33 | static struct voltagedomain *voltagedomains_am33xx[] __initdata = { | ||
34 | &am33xx_voltdm_mpu, | ||
35 | &am33xx_voltdm_core, | ||
36 | &am33xx_voltdm_rtc, | ||
37 | NULL, | ||
38 | }; | ||
39 | |||
40 | void __init am33xx_voltagedomains_init(void) | ||
41 | { | ||
42 | voltdm_init(voltagedomains_am33xx); | ||
43 | } | ||
diff --git a/arch/arm/mach-tegra/Makefile b/arch/arm/mach-tegra/Makefile index 35253fdd1ba7..90aae34245cd 100644 --- a/arch/arm/mach-tegra/Makefile +++ b/arch/arm/mach-tegra/Makefile | |||
@@ -9,6 +9,7 @@ obj-y += fuse.o | |||
9 | obj-y += pmc.o | 9 | obj-y += pmc.o |
10 | obj-y += flowctrl.o | 10 | obj-y += flowctrl.o |
11 | obj-y += powergate.o | 11 | obj-y += powergate.o |
12 | obj-y += apbio.o | ||
12 | obj-$(CONFIG_CPU_IDLE) += cpuidle.o | 13 | obj-$(CONFIG_CPU_IDLE) += cpuidle.o |
13 | obj-$(CONFIG_CPU_IDLE) += sleep.o | 14 | obj-$(CONFIG_CPU_IDLE) += sleep.o |
14 | obj-$(CONFIG_ARCH_TEGRA_2x_SOC) += tegra2_clocks.o | 15 | obj-$(CONFIG_ARCH_TEGRA_2x_SOC) += tegra2_clocks.o |
@@ -18,7 +19,7 @@ obj-$(CONFIG_ARCH_TEGRA_3x_SOC) += tegra30_clocks.o | |||
18 | obj-$(CONFIG_SMP) += platsmp.o headsmp.o | 19 | obj-$(CONFIG_SMP) += platsmp.o headsmp.o |
19 | obj-$(CONFIG_SMP) += reset.o | 20 | obj-$(CONFIG_SMP) += reset.o |
20 | obj-$(CONFIG_HOTPLUG_CPU) += hotplug.o | 21 | obj-$(CONFIG_HOTPLUG_CPU) += hotplug.o |
21 | obj-$(CONFIG_TEGRA_SYSTEM_DMA) += dma.o apbio.o | 22 | obj-$(CONFIG_TEGRA_SYSTEM_DMA) += dma.o |
22 | obj-$(CONFIG_CPU_FREQ) += cpu-tegra.o | 23 | obj-$(CONFIG_CPU_FREQ) += cpu-tegra.o |
23 | obj-$(CONFIG_TEGRA_PCI) += pcie.o | 24 | obj-$(CONFIG_TEGRA_PCI) += pcie.o |
24 | obj-$(CONFIG_USB_SUPPORT) += usb_phy.o | 25 | obj-$(CONFIG_USB_SUPPORT) += usb_phy.o |
diff --git a/arch/arm/mach-tegra/apbio.c b/arch/arm/mach-tegra/apbio.c index e75451e517bd..dc0fe389be56 100644 --- a/arch/arm/mach-tegra/apbio.c +++ b/arch/arm/mach-tegra/apbio.c | |||
@@ -15,6 +15,9 @@ | |||
15 | 15 | ||
16 | #include <linux/kernel.h> | 16 | #include <linux/kernel.h> |
17 | #include <linux/io.h> | 17 | #include <linux/io.h> |
18 | #include <mach/iomap.h> | ||
19 | #include <linux/of.h> | ||
20 | #include <linux/dmaengine.h> | ||
18 | #include <linux/dma-mapping.h> | 21 | #include <linux/dma-mapping.h> |
19 | #include <linux/spinlock.h> | 22 | #include <linux/spinlock.h> |
20 | #include <linux/completion.h> | 23 | #include <linux/completion.h> |
@@ -22,17 +25,21 @@ | |||
22 | #include <linux/mutex.h> | 25 | #include <linux/mutex.h> |
23 | 26 | ||
24 | #include <mach/dma.h> | 27 | #include <mach/dma.h> |
25 | #include <mach/iomap.h> | ||
26 | 28 | ||
27 | #include "apbio.h" | 29 | #include "apbio.h" |
28 | 30 | ||
31 | #if defined(CONFIG_TEGRA_SYSTEM_DMA) || defined(CONFIG_TEGRA20_APB_DMA) | ||
29 | static DEFINE_MUTEX(tegra_apb_dma_lock); | 32 | static DEFINE_MUTEX(tegra_apb_dma_lock); |
30 | |||
31 | static struct tegra_dma_channel *tegra_apb_dma; | ||
32 | static u32 *tegra_apb_bb; | 33 | static u32 *tegra_apb_bb; |
33 | static dma_addr_t tegra_apb_bb_phys; | 34 | static dma_addr_t tegra_apb_bb_phys; |
34 | static DECLARE_COMPLETION(tegra_apb_wait); | 35 | static DECLARE_COMPLETION(tegra_apb_wait); |
35 | 36 | ||
37 | static u32 tegra_apb_readl_direct(unsigned long offset); | ||
38 | static void tegra_apb_writel_direct(u32 value, unsigned long offset); | ||
39 | |||
40 | #if defined(CONFIG_TEGRA_SYSTEM_DMA) | ||
41 | static struct tegra_dma_channel *tegra_apb_dma; | ||
42 | |||
36 | bool tegra_apb_init(void) | 43 | bool tegra_apb_init(void) |
37 | { | 44 | { |
38 | struct tegra_dma_channel *ch; | 45 | struct tegra_dma_channel *ch; |
@@ -72,13 +79,13 @@ static void apb_dma_complete(struct tegra_dma_req *req) | |||
72 | complete(&tegra_apb_wait); | 79 | complete(&tegra_apb_wait); |
73 | } | 80 | } |
74 | 81 | ||
75 | u32 tegra_apb_readl(unsigned long offset) | 82 | static u32 tegra_apb_readl_using_dma(unsigned long offset) |
76 | { | 83 | { |
77 | struct tegra_dma_req req; | 84 | struct tegra_dma_req req; |
78 | int ret; | 85 | int ret; |
79 | 86 | ||
80 | if (!tegra_apb_dma && !tegra_apb_init()) | 87 | if (!tegra_apb_dma && !tegra_apb_init()) |
81 | return readl(IO_TO_VIRT(offset)); | 88 | return tegra_apb_readl_direct(offset); |
82 | 89 | ||
83 | mutex_lock(&tegra_apb_dma_lock); | 90 | mutex_lock(&tegra_apb_dma_lock); |
84 | req.complete = apb_dma_complete; | 91 | req.complete = apb_dma_complete; |
@@ -108,13 +115,13 @@ u32 tegra_apb_readl(unsigned long offset) | |||
108 | return *((u32 *)tegra_apb_bb); | 115 | return *((u32 *)tegra_apb_bb); |
109 | } | 116 | } |
110 | 117 | ||
111 | void tegra_apb_writel(u32 value, unsigned long offset) | 118 | static void tegra_apb_writel_using_dma(u32 value, unsigned long offset) |
112 | { | 119 | { |
113 | struct tegra_dma_req req; | 120 | struct tegra_dma_req req; |
114 | int ret; | 121 | int ret; |
115 | 122 | ||
116 | if (!tegra_apb_dma && !tegra_apb_init()) { | 123 | if (!tegra_apb_dma && !tegra_apb_init()) { |
117 | writel(value, IO_TO_VIRT(offset)); | 124 | tegra_apb_writel_direct(value, offset); |
118 | return; | 125 | return; |
119 | } | 126 | } |
120 | 127 | ||
@@ -143,3 +150,176 @@ void tegra_apb_writel(u32 value, unsigned long offset) | |||
143 | 150 | ||
144 | mutex_unlock(&tegra_apb_dma_lock); | 151 | mutex_unlock(&tegra_apb_dma_lock); |
145 | } | 152 | } |
153 | |||
154 | #else | ||
155 | static struct dma_chan *tegra_apb_dma_chan; | ||
156 | static struct dma_slave_config dma_sconfig; | ||
157 | |||
158 | bool tegra_apb_dma_init(void) | ||
159 | { | ||
160 | dma_cap_mask_t mask; | ||
161 | |||
162 | mutex_lock(&tegra_apb_dma_lock); | ||
163 | |||
164 | /* Check to see if we raced to setup */ | ||
165 | if (tegra_apb_dma_chan) | ||
166 | goto skip_init; | ||
167 | |||
168 | dma_cap_zero(mask); | ||
169 | dma_cap_set(DMA_SLAVE, mask); | ||
170 | tegra_apb_dma_chan = dma_request_channel(mask, NULL, NULL); | ||
171 | if (!tegra_apb_dma_chan) { | ||
172 | /* | ||
173 | * This is common until the device is probed, so don't | ||
174 | * shout about it. | ||
175 | */ | ||
176 | pr_debug("%s: can not allocate dma channel\n", __func__); | ||
177 | goto err_dma_alloc; | ||
178 | } | ||
179 | |||
180 | tegra_apb_bb = dma_alloc_coherent(NULL, sizeof(u32), | ||
181 | &tegra_apb_bb_phys, GFP_KERNEL); | ||
182 | if (!tegra_apb_bb) { | ||
183 | pr_err("%s: can not allocate bounce buffer\n", __func__); | ||
184 | goto err_buff_alloc; | ||
185 | } | ||
186 | |||
187 | dma_sconfig.src_addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES; | ||
188 | dma_sconfig.dst_addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES; | ||
189 | dma_sconfig.slave_id = TEGRA_DMA_REQ_SEL_CNTR; | ||
190 | dma_sconfig.src_maxburst = 1; | ||
191 | dma_sconfig.dst_maxburst = 1; | ||
192 | |||
193 | skip_init: | ||
194 | mutex_unlock(&tegra_apb_dma_lock); | ||
195 | return true; | ||
196 | |||
197 | err_buff_alloc: | ||
198 | dma_release_channel(tegra_apb_dma_chan); | ||
199 | tegra_apb_dma_chan = NULL; | ||
200 | |||
201 | err_dma_alloc: | ||
202 | mutex_unlock(&tegra_apb_dma_lock); | ||
203 | return false; | ||
204 | } | ||
205 | |||
206 | static void apb_dma_complete(void *args) | ||
207 | { | ||
208 | complete(&tegra_apb_wait); | ||
209 | } | ||
210 | |||
211 | static int do_dma_transfer(unsigned long apb_add, | ||
212 | enum dma_transfer_direction dir) | ||
213 | { | ||
214 | struct dma_async_tx_descriptor *dma_desc; | ||
215 | int ret; | ||
216 | |||
217 | if (dir == DMA_DEV_TO_MEM) | ||
218 | dma_sconfig.src_addr = apb_add; | ||
219 | else | ||
220 | dma_sconfig.dst_addr = apb_add; | ||
221 | |||
222 | ret = dmaengine_slave_config(tegra_apb_dma_chan, &dma_sconfig); | ||
223 | if (ret) | ||
224 | return ret; | ||
225 | |||
226 | dma_desc = dmaengine_prep_slave_single(tegra_apb_dma_chan, | ||
227 | tegra_apb_bb_phys, sizeof(u32), dir, | ||
228 | DMA_PREP_INTERRUPT | DMA_CTRL_ACK); | ||
229 | if (!dma_desc) | ||
230 | return -EINVAL; | ||
231 | |||
232 | dma_desc->callback = apb_dma_complete; | ||
233 | dma_desc->callback_param = NULL; | ||
234 | |||
235 | INIT_COMPLETION(tegra_apb_wait); | ||
236 | |||
237 | dmaengine_submit(dma_desc); | ||
238 | dma_async_issue_pending(tegra_apb_dma_chan); | ||
239 | ret = wait_for_completion_timeout(&tegra_apb_wait, | ||
240 | msecs_to_jiffies(50)); | ||
241 | |||
242 | if (WARN(ret == 0, "apb read dma timed out")) { | ||
243 | dmaengine_terminate_all(tegra_apb_dma_chan); | ||
244 | return -EFAULT; | ||
245 | } | ||
246 | return 0; | ||
247 | } | ||
248 | |||
249 | static u32 tegra_apb_readl_using_dma(unsigned long offset) | ||
250 | { | ||
251 | int ret; | ||
252 | |||
253 | if (!tegra_apb_dma_chan && !tegra_apb_dma_init()) | ||
254 | return tegra_apb_readl_direct(offset); | ||
255 | |||
256 | mutex_lock(&tegra_apb_dma_lock); | ||
257 | ret = do_dma_transfer(offset, DMA_DEV_TO_MEM); | ||
258 | if (ret < 0) { | ||
259 | pr_err("error in reading offset 0x%08lx using dma\n", offset); | ||
260 | *(u32 *)tegra_apb_bb = 0; | ||
261 | } | ||
262 | mutex_unlock(&tegra_apb_dma_lock); | ||
263 | return *((u32 *)tegra_apb_bb); | ||
264 | } | ||
265 | |||
266 | static void tegra_apb_writel_using_dma(u32 value, unsigned long offset) | ||
267 | { | ||
268 | int ret; | ||
269 | |||
270 | if (!tegra_apb_dma_chan && !tegra_apb_dma_init()) { | ||
271 | tegra_apb_writel_direct(value, offset); | ||
272 | return; | ||
273 | } | ||
274 | |||
275 | mutex_lock(&tegra_apb_dma_lock); | ||
276 | *((u32 *)tegra_apb_bb) = value; | ||
277 | ret = do_dma_transfer(offset, DMA_MEM_TO_DEV); | ||
278 | if (ret < 0) | ||
279 | pr_err("error in writing offset 0x%08lx using dma\n", offset); | ||
280 | mutex_unlock(&tegra_apb_dma_lock); | ||
281 | } | ||
282 | #endif | ||
283 | #else | ||
284 | #define tegra_apb_readl_using_dma tegra_apb_readl_direct | ||
285 | #define tegra_apb_writel_using_dma tegra_apb_writel_direct | ||
286 | #endif | ||
287 | |||
288 | typedef u32 (*apbio_read_fptr)(unsigned long offset); | ||
289 | typedef void (*apbio_write_fptr)(u32 value, unsigned long offset); | ||
290 | |||
291 | static apbio_read_fptr apbio_read; | ||
292 | static apbio_write_fptr apbio_write; | ||
293 | |||
294 | static u32 tegra_apb_readl_direct(unsigned long offset) | ||
295 | { | ||
296 | return readl(IO_TO_VIRT(offset)); | ||
297 | } | ||
298 | |||
299 | static void tegra_apb_writel_direct(u32 value, unsigned long offset) | ||
300 | { | ||
301 | writel(value, IO_TO_VIRT(offset)); | ||
302 | } | ||
303 | |||
304 | void tegra_apb_io_init(void) | ||
305 | { | ||
306 | /* Need to use dma only when it is Tegra20 based platform */ | ||
307 | if (of_machine_is_compatible("nvidia,tegra20") || | ||
308 | !of_have_populated_dt()) { | ||
309 | apbio_read = tegra_apb_readl_using_dma; | ||
310 | apbio_write = tegra_apb_writel_using_dma; | ||
311 | } else { | ||
312 | apbio_read = tegra_apb_readl_direct; | ||
313 | apbio_write = tegra_apb_writel_direct; | ||
314 | } | ||
315 | } | ||
316 | |||
317 | u32 tegra_apb_readl(unsigned long offset) | ||
318 | { | ||
319 | return apbio_read(offset); | ||
320 | } | ||
321 | |||
322 | void tegra_apb_writel(u32 value, unsigned long offset) | ||
323 | { | ||
324 | apbio_write(value, offset); | ||
325 | } | ||
diff --git a/arch/arm/mach-tegra/apbio.h b/arch/arm/mach-tegra/apbio.h index 8b49e8c89a64..f05d71c303c7 100644 --- a/arch/arm/mach-tegra/apbio.h +++ b/arch/arm/mach-tegra/apbio.h | |||
@@ -16,24 +16,7 @@ | |||
16 | #ifndef __MACH_TEGRA_APBIO_H | 16 | #ifndef __MACH_TEGRA_APBIO_H |
17 | #define __MACH_TEGRA_APBIO_H | 17 | #define __MACH_TEGRA_APBIO_H |
18 | 18 | ||
19 | #ifdef CONFIG_TEGRA_SYSTEM_DMA | 19 | void tegra_apb_io_init(void); |
20 | |||
21 | u32 tegra_apb_readl(unsigned long offset); | 20 | u32 tegra_apb_readl(unsigned long offset); |
22 | void tegra_apb_writel(u32 value, unsigned long offset); | 21 | void tegra_apb_writel(u32 value, unsigned long offset); |
23 | |||
24 | #else | ||
25 | #include <asm/io.h> | ||
26 | #include <mach/io.h> | ||
27 | |||
28 | static inline u32 tegra_apb_readl(unsigned long offset) | ||
29 | { | ||
30 | return readl(IO_TO_VIRT(offset)); | ||
31 | } | ||
32 | |||
33 | static inline void tegra_apb_writel(u32 value, unsigned long offset) | ||
34 | { | ||
35 | writel(value, IO_TO_VIRT(offset)); | ||
36 | } | ||
37 | #endif | ||
38 | |||
39 | #endif | 22 | #endif |
diff --git a/arch/arm/mach-tegra/common.c b/arch/arm/mach-tegra/common.c index 204a5c8b0b57..96fef6bcc651 100644 --- a/arch/arm/mach-tegra/common.c +++ b/arch/arm/mach-tegra/common.c | |||
@@ -33,6 +33,7 @@ | |||
33 | #include "clock.h" | 33 | #include "clock.h" |
34 | #include "fuse.h" | 34 | #include "fuse.h" |
35 | #include "pmc.h" | 35 | #include "pmc.h" |
36 | #include "apbio.h" | ||
36 | 37 | ||
37 | /* | 38 | /* |
38 | * Storage for debug-macro.S's state. | 39 | * Storage for debug-macro.S's state. |
@@ -127,6 +128,7 @@ static void __init tegra_init_cache(u32 tag_latency, u32 data_latency) | |||
127 | #ifdef CONFIG_ARCH_TEGRA_2x_SOC | 128 | #ifdef CONFIG_ARCH_TEGRA_2x_SOC |
128 | void __init tegra20_init_early(void) | 129 | void __init tegra20_init_early(void) |
129 | { | 130 | { |
131 | tegra_apb_io_init(); | ||
130 | tegra_init_fuse(); | 132 | tegra_init_fuse(); |
131 | tegra2_init_clocks(); | 133 | tegra2_init_clocks(); |
132 | tegra_clk_init_from_table(tegra20_clk_init_table); | 134 | tegra_clk_init_from_table(tegra20_clk_init_table); |
@@ -138,6 +140,7 @@ void __init tegra20_init_early(void) | |||
138 | #ifdef CONFIG_ARCH_TEGRA_3x_SOC | 140 | #ifdef CONFIG_ARCH_TEGRA_3x_SOC |
139 | void __init tegra30_init_early(void) | 141 | void __init tegra30_init_early(void) |
140 | { | 142 | { |
143 | tegra_apb_io_init(); | ||
141 | tegra_init_fuse(); | 144 | tegra_init_fuse(); |
142 | tegra30_init_clocks(); | 145 | tegra30_init_clocks(); |
143 | tegra_clk_init_from_table(tegra30_clk_init_table); | 146 | tegra_clk_init_from_table(tegra30_clk_init_table); |
diff --git a/arch/arm/mach-vexpress/Kconfig b/arch/arm/mach-vexpress/Kconfig index cf8730d35e70..fc3730f01650 100644 --- a/arch/arm/mach-vexpress/Kconfig +++ b/arch/arm/mach-vexpress/Kconfig | |||
@@ -2,7 +2,8 @@ menu "Versatile Express platform type" | |||
2 | depends on ARCH_VEXPRESS | 2 | depends on ARCH_VEXPRESS |
3 | 3 | ||
4 | config ARCH_VEXPRESS_CORTEX_A5_A9_ERRATA | 4 | config ARCH_VEXPRESS_CORTEX_A5_A9_ERRATA |
5 | bool | 5 | bool "Enable A5 and A9 only errata work-arounds" |
6 | default y | ||
6 | select ARM_ERRATA_720789 | 7 | select ARM_ERRATA_720789 |
7 | select ARM_ERRATA_751472 | 8 | select ARM_ERRATA_751472 |
8 | select PL310_ERRATA_753970 if CACHE_PL310 | 9 | select PL310_ERRATA_753970 if CACHE_PL310 |
@@ -14,7 +15,6 @@ config ARCH_VEXPRESS_CORTEX_A5_A9_ERRATA | |||
14 | 15 | ||
15 | config ARCH_VEXPRESS_CA9X4 | 16 | config ARCH_VEXPRESS_CA9X4 |
16 | bool "Versatile Express Cortex-A9x4 tile" | 17 | bool "Versatile Express Cortex-A9x4 tile" |
17 | select ARCH_VEXPRESS_CORTEX_A5_A9_ERRATA | ||
18 | select ARM_GIC | 18 | select ARM_GIC |
19 | select CPU_V7 | 19 | select CPU_V7 |
20 | select HAVE_SMP | 20 | select HAVE_SMP |
@@ -22,7 +22,6 @@ config ARCH_VEXPRESS_CA9X4 | |||
22 | 22 | ||
23 | config ARCH_VEXPRESS_DT | 23 | config ARCH_VEXPRESS_DT |
24 | bool "Device Tree support for Versatile Express platforms" | 24 | bool "Device Tree support for Versatile Express platforms" |
25 | select ARCH_VEXPRESS_CORTEX_A5_A9_ERRATA | ||
26 | select ARM_GIC | 25 | select ARM_GIC |
27 | select ARM_PATCH_PHYS_VIRT | 26 | select ARM_PATCH_PHYS_VIRT |
28 | select AUTO_ZRELADDR | 27 | select AUTO_ZRELADDR |
diff --git a/arch/arm/mach-vexpress/Makefile.boot b/arch/arm/mach-vexpress/Makefile.boot index 909f85ebf5f4..318d308dfb93 100644 --- a/arch/arm/mach-vexpress/Makefile.boot +++ b/arch/arm/mach-vexpress/Makefile.boot | |||
@@ -6,4 +6,5 @@ initrd_phys-y := 0x60800000 | |||
6 | 6 | ||
7 | dtb-$(CONFIG_ARCH_VEXPRESS_DT) += vexpress-v2p-ca5s.dtb \ | 7 | dtb-$(CONFIG_ARCH_VEXPRESS_DT) += vexpress-v2p-ca5s.dtb \ |
8 | vexpress-v2p-ca9.dtb \ | 8 | vexpress-v2p-ca9.dtb \ |
9 | vexpress-v2p-ca15-tc1.dtb | 9 | vexpress-v2p-ca15-tc1.dtb \ |
10 | vexpress-v2p-ca15_a7.dtb | ||
diff --git a/arch/arm/mach-vexpress/ct-ca9x4.c b/arch/arm/mach-vexpress/ct-ca9x4.c index c65cc3b462a5..61c492403b05 100644 --- a/arch/arm/mach-vexpress/ct-ca9x4.c +++ b/arch/arm/mach-vexpress/ct-ca9x4.c | |||
@@ -66,8 +66,15 @@ static void __init ct_ca9x4_init_irq(void) | |||
66 | 66 | ||
67 | static void ct_ca9x4_clcd_enable(struct clcd_fb *fb) | 67 | static void ct_ca9x4_clcd_enable(struct clcd_fb *fb) |
68 | { | 68 | { |
69 | v2m_cfg_write(SYS_CFG_MUXFPGA | SYS_CFG_SITE_DB1, 0); | 69 | u32 site = v2m_get_master_site(); |
70 | v2m_cfg_write(SYS_CFG_DVIMODE | SYS_CFG_SITE_DB1, 2); | 70 | |
71 | /* | ||
72 | * Old firmware was using the "site" component of the command | ||
73 | * to control the DVI muxer (while it should be always 0 ie. MB). | ||
74 | * Newer firmware uses the data register. Keep both for compatibility. | ||
75 | */ | ||
76 | v2m_cfg_write(SYS_CFG_MUXFPGA | SYS_CFG_SITE(site), site); | ||
77 | v2m_cfg_write(SYS_CFG_DVIMODE | SYS_CFG_SITE(SYS_CFG_SITE_MB), 2); | ||
71 | } | 78 | } |
72 | 79 | ||
73 | static int ct_ca9x4_clcd_setup(struct clcd_fb *fb) | 80 | static int ct_ca9x4_clcd_setup(struct clcd_fb *fb) |
@@ -105,43 +112,11 @@ static struct amba_device *ct_ca9x4_amba_devs[] __initdata = { | |||
105 | }; | 112 | }; |
106 | 113 | ||
107 | 114 | ||
108 | static long ct_round(struct clk *clk, unsigned long rate) | 115 | static struct v2m_osc ct_osc1 = { |
109 | { | 116 | .osc = 1, |
110 | return rate; | 117 | .rate_min = 10000000, |
111 | } | 118 | .rate_max = 80000000, |
112 | 119 | .rate_default = 23750000, | |
113 | static int ct_set(struct clk *clk, unsigned long rate) | ||
114 | { | ||
115 | return v2m_cfg_write(SYS_CFG_OSC | SYS_CFG_SITE_DB1 | 1, rate); | ||
116 | } | ||
117 | |||
118 | static const struct clk_ops osc1_clk_ops = { | ||
119 | .round = ct_round, | ||
120 | .set = ct_set, | ||
121 | }; | ||
122 | |||
123 | static struct clk osc1_clk = { | ||
124 | .ops = &osc1_clk_ops, | ||
125 | .rate = 24000000, | ||
126 | }; | ||
127 | |||
128 | static struct clk ct_sp804_clk = { | ||
129 | .rate = 1000000, | ||
130 | }; | ||
131 | |||
132 | static struct clk_lookup lookups[] = { | ||
133 | { /* CLCD */ | ||
134 | .dev_id = "ct:clcd", | ||
135 | .clk = &osc1_clk, | ||
136 | }, { /* SP804 timers */ | ||
137 | .dev_id = "sp804", | ||
138 | .con_id = "ct-timer0", | ||
139 | .clk = &ct_sp804_clk, | ||
140 | }, { /* SP804 timers */ | ||
141 | .dev_id = "sp804", | ||
142 | .con_id = "ct-timer1", | ||
143 | .clk = &ct_sp804_clk, | ||
144 | }, | ||
145 | }; | 120 | }; |
146 | 121 | ||
147 | static struct resource pmu_resources[] = { | 122 | static struct resource pmu_resources[] = { |
@@ -174,14 +149,10 @@ static struct platform_device pmu_device = { | |||
174 | .resource = pmu_resources, | 149 | .resource = pmu_resources, |
175 | }; | 150 | }; |
176 | 151 | ||
177 | static void __init ct_ca9x4_init_early(void) | ||
178 | { | ||
179 | clkdev_add_table(lookups, ARRAY_SIZE(lookups)); | ||
180 | } | ||
181 | |||
182 | static void __init ct_ca9x4_init(void) | 152 | static void __init ct_ca9x4_init(void) |
183 | { | 153 | { |
184 | int i; | 154 | int i; |
155 | struct clk *clk; | ||
185 | 156 | ||
186 | #ifdef CONFIG_CACHE_L2X0 | 157 | #ifdef CONFIG_CACHE_L2X0 |
187 | void __iomem *l2x0_base = ioremap(CT_CA9X4_L2CC, SZ_4K); | 158 | void __iomem *l2x0_base = ioremap(CT_CA9X4_L2CC, SZ_4K); |
@@ -193,6 +164,10 @@ static void __init ct_ca9x4_init(void) | |||
193 | l2x0_init(l2x0_base, 0x00400000, 0xfe0fffff); | 164 | l2x0_init(l2x0_base, 0x00400000, 0xfe0fffff); |
194 | #endif | 165 | #endif |
195 | 166 | ||
167 | ct_osc1.site = v2m_get_master_site(); | ||
168 | clk = v2m_osc_register("ct:osc1", &ct_osc1); | ||
169 | clk_register_clkdev(clk, NULL, "ct:clcd"); | ||
170 | |||
196 | for (i = 0; i < ARRAY_SIZE(ct_ca9x4_amba_devs); i++) | 171 | for (i = 0; i < ARRAY_SIZE(ct_ca9x4_amba_devs); i++) |
197 | amba_device_register(ct_ca9x4_amba_devs[i], &iomem_resource); | 172 | amba_device_register(ct_ca9x4_amba_devs[i], &iomem_resource); |
198 | 173 | ||
@@ -234,7 +209,6 @@ struct ct_desc ct_ca9x4_desc __initdata = { | |||
234 | .id = V2M_CT_ID_CA9, | 209 | .id = V2M_CT_ID_CA9, |
235 | .name = "CA9x4", | 210 | .name = "CA9x4", |
236 | .map_io = ct_ca9x4_map_io, | 211 | .map_io = ct_ca9x4_map_io, |
237 | .init_early = ct_ca9x4_init_early, | ||
238 | .init_irq = ct_ca9x4_init_irq, | 212 | .init_irq = ct_ca9x4_init_irq, |
239 | .init_tile = ct_ca9x4_init, | 213 | .init_tile = ct_ca9x4_init, |
240 | #ifdef CONFIG_SMP | 214 | #ifdef CONFIG_SMP |
diff --git a/arch/arm/mach-vexpress/include/mach/clkdev.h b/arch/arm/mach-vexpress/include/mach/clkdev.h deleted file mode 100644 index 3f8307d73cad..000000000000 --- a/arch/arm/mach-vexpress/include/mach/clkdev.h +++ /dev/null | |||
@@ -1,15 +0,0 @@ | |||
1 | #ifndef __ASM_MACH_CLKDEV_H | ||
2 | #define __ASM_MACH_CLKDEV_H | ||
3 | |||
4 | #include <plat/clock.h> | ||
5 | |||
6 | struct clk { | ||
7 | const struct clk_ops *ops; | ||
8 | unsigned long rate; | ||
9 | const struct icst_params *params; | ||
10 | }; | ||
11 | |||
12 | #define __clk_get(clk) ({ 1; }) | ||
13 | #define __clk_put(clk) do { } while (0) | ||
14 | |||
15 | #endif | ||
diff --git a/arch/arm/mach-vexpress/include/mach/debug-macro.S b/arch/arm/mach-vexpress/include/mach/debug-macro.S index fa8224794e0b..9f509f55d078 100644 --- a/arch/arm/mach-vexpress/include/mach/debug-macro.S +++ b/arch/arm/mach-vexpress/include/mach/debug-macro.S | |||
@@ -18,6 +18,8 @@ | |||
18 | 18 | ||
19 | #define DEBUG_LL_VIRT_BASE 0xf8000000 | 19 | #define DEBUG_LL_VIRT_BASE 0xf8000000 |
20 | 20 | ||
21 | #if defined(CONFIG_DEBUG_VEXPRESS_UART0_DETECT) | ||
22 | |||
21 | .macro addruart,rp,rv,tmp | 23 | .macro addruart,rp,rv,tmp |
22 | 24 | ||
23 | @ Make an educated guess regarding the memory map: | 25 | @ Make an educated guess regarding the memory map: |
@@ -41,3 +43,42 @@ | |||
41 | .endm | 43 | .endm |
42 | 44 | ||
43 | #include <asm/hardware/debug-pl01x.S> | 45 | #include <asm/hardware/debug-pl01x.S> |
46 | |||
47 | #elif defined(CONFIG_DEBUG_VEXPRESS_UART0_CA9) | ||
48 | |||
49 | .macro addruart,rp,rv,tmp | ||
50 | mov \rp, #DEBUG_LL_UART_OFFSET | ||
51 | orr \rv, \rp, #DEBUG_LL_VIRT_BASE | ||
52 | orr \rp, \rp, #DEBUG_LL_PHYS_BASE | ||
53 | .endm | ||
54 | |||
55 | #include <asm/hardware/debug-pl01x.S> | ||
56 | |||
57 | #elif defined(CONFIG_DEBUG_VEXPRESS_UART0_RS1) | ||
58 | |||
59 | .macro addruart,rp,rv,tmp | ||
60 | mov \rp, #DEBUG_LL_UART_OFFSET_RS1 | ||
61 | orr \rv, \rp, #DEBUG_LL_VIRT_BASE | ||
62 | orr \rp, \rp, #DEBUG_LL_PHYS_BASE_RS1 | ||
63 | .endm | ||
64 | |||
65 | #include <asm/hardware/debug-pl01x.S> | ||
66 | |||
67 | #else /* CONFIG_DEBUG_LL_UART_NONE */ | ||
68 | |||
69 | .macro addruart, rp, rv, tmp | ||
70 | /* Safe dummy values */ | ||
71 | mov \rp, #0 | ||
72 | mov \rv, #DEBUG_LL_VIRT_BASE | ||
73 | .endm | ||
74 | |||
75 | .macro senduart,rd,rx | ||
76 | .endm | ||
77 | |||
78 | .macro waituart,rd,rx | ||
79 | .endm | ||
80 | |||
81 | .macro busyuart,rd,rx | ||
82 | .endm | ||
83 | |||
84 | #endif | ||
diff --git a/arch/arm/mach-vexpress/include/mach/motherboard.h b/arch/arm/mach-vexpress/include/mach/motherboard.h index 31a92890893d..1e388c7bf4d7 100644 --- a/arch/arm/mach-vexpress/include/mach/motherboard.h +++ b/arch/arm/mach-vexpress/include/mach/motherboard.h | |||
@@ -1,6 +1,8 @@ | |||
1 | #ifndef __MACH_MOTHERBOARD_H | 1 | #ifndef __MACH_MOTHERBOARD_H |
2 | #define __MACH_MOTHERBOARD_H | 2 | #define __MACH_MOTHERBOARD_H |
3 | 3 | ||
4 | #include <linux/clk-provider.h> | ||
5 | |||
4 | /* | 6 | /* |
5 | * Physical addresses, offset from V2M_PA_CS0-3 | 7 | * Physical addresses, offset from V2M_PA_CS0-3 |
6 | */ | 8 | */ |
@@ -104,9 +106,10 @@ | |||
104 | #define SYS_CFG_REBOOT (9 << 20) | 106 | #define SYS_CFG_REBOOT (9 << 20) |
105 | #define SYS_CFG_DVIMODE (11 << 20) | 107 | #define SYS_CFG_DVIMODE (11 << 20) |
106 | #define SYS_CFG_POWER (12 << 20) | 108 | #define SYS_CFG_POWER (12 << 20) |
107 | #define SYS_CFG_SITE_MB (0 << 16) | 109 | #define SYS_CFG_SITE(n) ((n) << 16) |
108 | #define SYS_CFG_SITE_DB1 (1 << 16) | 110 | #define SYS_CFG_SITE_MB 0 |
109 | #define SYS_CFG_SITE_DB2 (2 << 16) | 111 | #define SYS_CFG_SITE_DB1 1 |
112 | #define SYS_CFG_SITE_DB2 2 | ||
110 | #define SYS_CFG_STACK(n) ((n) << 12) | 113 | #define SYS_CFG_STACK(n) ((n) << 12) |
111 | 114 | ||
112 | #define SYS_CFG_ERR (1 << 1) | 115 | #define SYS_CFG_ERR (1 << 1) |
@@ -122,6 +125,8 @@ void v2m_flags_set(u32 data); | |||
122 | #define SYS_MISC_MASTERSITE (1 << 14) | 125 | #define SYS_MISC_MASTERSITE (1 << 14) |
123 | #define SYS_PROCIDx_HBI_MASK 0xfff | 126 | #define SYS_PROCIDx_HBI_MASK 0xfff |
124 | 127 | ||
128 | int v2m_get_master_site(void); | ||
129 | |||
125 | /* | 130 | /* |
126 | * Core tile IDs | 131 | * Core tile IDs |
127 | */ | 132 | */ |
@@ -144,4 +149,21 @@ struct ct_desc { | |||
144 | 149 | ||
145 | extern struct ct_desc *ct_desc; | 150 | extern struct ct_desc *ct_desc; |
146 | 151 | ||
152 | /* | ||
153 | * OSC clock provider | ||
154 | */ | ||
155 | struct v2m_osc { | ||
156 | struct clk_hw hw; | ||
157 | u8 site; /* 0 = motherboard, 1 = site 1, 2 = site 2 */ | ||
158 | u8 stack; /* board stack position */ | ||
159 | u16 osc; | ||
160 | unsigned long rate_min; | ||
161 | unsigned long rate_max; | ||
162 | unsigned long rate_default; | ||
163 | }; | ||
164 | |||
165 | #define to_v2m_osc(osc) container_of(osc, struct v2m_osc, hw) | ||
166 | |||
167 | struct clk *v2m_osc_register(const char *name, struct v2m_osc *osc); | ||
168 | |||
147 | #endif | 169 | #endif |
diff --git a/arch/arm/mach-vexpress/include/mach/uncompress.h b/arch/arm/mach-vexpress/include/mach/uncompress.h index 7dab5596b868..1e472eb0bbdc 100644 --- a/arch/arm/mach-vexpress/include/mach/uncompress.h +++ b/arch/arm/mach-vexpress/include/mach/uncompress.h | |||
@@ -27,6 +27,7 @@ | |||
27 | 27 | ||
28 | static unsigned long get_uart_base(void) | 28 | static unsigned long get_uart_base(void) |
29 | { | 29 | { |
30 | #if defined(CONFIG_DEBUG_VEXPRESS_UART0_DETECT) | ||
30 | unsigned long mpcore_periph; | 31 | unsigned long mpcore_periph; |
31 | 32 | ||
32 | /* | 33 | /* |
@@ -42,6 +43,13 @@ static unsigned long get_uart_base(void) | |||
42 | return UART_BASE; | 43 | return UART_BASE; |
43 | else | 44 | else |
44 | return UART_BASE_RS1; | 45 | return UART_BASE_RS1; |
46 | #elif defined(CONFIG_DEBUG_VEXPRESS_UART0_CA9) | ||
47 | return UART_BASE; | ||
48 | #elif defined(CONFIG_DEBUG_VEXPRESS_UART0_RS1) | ||
49 | return UART_BASE_RS1; | ||
50 | #else | ||
51 | return 0; | ||
52 | #endif | ||
45 | } | 53 | } |
46 | 54 | ||
47 | /* | 55 | /* |
@@ -51,6 +59,9 @@ static inline void putc(int c) | |||
51 | { | 59 | { |
52 | unsigned long base = get_uart_base(); | 60 | unsigned long base = get_uart_base(); |
53 | 61 | ||
62 | if (!base) | ||
63 | return; | ||
64 | |||
54 | while (AMBA_UART_FR(base) & (1 << 5)) | 65 | while (AMBA_UART_FR(base) & (1 << 5)) |
55 | barrier(); | 66 | barrier(); |
56 | 67 | ||
@@ -61,6 +72,9 @@ static inline void flush(void) | |||
61 | { | 72 | { |
62 | unsigned long base = get_uart_base(); | 73 | unsigned long base = get_uart_base(); |
63 | 74 | ||
75 | if (!base) | ||
76 | return; | ||
77 | |||
64 | while (AMBA_UART_FR(base) & (1 << 3)) | 78 | while (AMBA_UART_FR(base) & (1 << 3)) |
65 | barrier(); | 79 | barrier(); |
66 | } | 80 | } |
diff --git a/arch/arm/mach-vexpress/v2m.c b/arch/arm/mach-vexpress/v2m.c index fde26adaef32..37608f22ee31 100644 --- a/arch/arm/mach-vexpress/v2m.c +++ b/arch/arm/mach-vexpress/v2m.c | |||
@@ -16,7 +16,10 @@ | |||
16 | #include <linux/spinlock.h> | 16 | #include <linux/spinlock.h> |
17 | #include <linux/usb/isp1760.h> | 17 | #include <linux/usb/isp1760.h> |
18 | #include <linux/clkdev.h> | 18 | #include <linux/clkdev.h> |
19 | #include <linux/clk-provider.h> | ||
19 | #include <linux/mtd/physmap.h> | 20 | #include <linux/mtd/physmap.h> |
21 | #include <linux/regulator/fixed.h> | ||
22 | #include <linux/regulator/machine.h> | ||
20 | 23 | ||
21 | #include <asm/arch_timer.h> | 24 | #include <asm/arch_timer.h> |
22 | #include <asm/mach-types.h> | 25 | #include <asm/mach-types.h> |
@@ -81,16 +84,6 @@ static void __init v2m_sp804_init(void __iomem *base, unsigned int irq) | |||
81 | sp804_clockevents_init(base + TIMER_1_BASE, irq, "v2m-timer0"); | 84 | sp804_clockevents_init(base + TIMER_1_BASE, irq, "v2m-timer0"); |
82 | } | 85 | } |
83 | 86 | ||
84 | static void __init v2m_timer_init(void) | ||
85 | { | ||
86 | v2m_sysctl_init(ioremap(V2M_SYSCTL, SZ_4K)); | ||
87 | v2m_sp804_init(ioremap(V2M_TIMER01, SZ_4K), IRQ_V2M_TIMER0); | ||
88 | } | ||
89 | |||
90 | static struct sys_timer v2m_timer = { | ||
91 | .init = v2m_timer_init, | ||
92 | }; | ||
93 | |||
94 | 87 | ||
95 | static DEFINE_SPINLOCK(v2m_cfg_lock); | 88 | static DEFINE_SPINLOCK(v2m_cfg_lock); |
96 | 89 | ||
@@ -147,6 +140,13 @@ void __init v2m_flags_set(u32 data) | |||
147 | writel(data, v2m_sysreg_base + V2M_SYS_FLAGSSET); | 140 | writel(data, v2m_sysreg_base + V2M_SYS_FLAGSSET); |
148 | } | 141 | } |
149 | 142 | ||
143 | int v2m_get_master_site(void) | ||
144 | { | ||
145 | u32 misc = readl(v2m_sysreg_base + V2M_SYS_MISC); | ||
146 | |||
147 | return misc & SYS_MISC_MASTERSITE ? SYS_CFG_SITE_DB2 : SYS_CFG_SITE_DB1; | ||
148 | } | ||
149 | |||
150 | 150 | ||
151 | static struct resource v2m_pcie_i2c_resource = { | 151 | static struct resource v2m_pcie_i2c_resource = { |
152 | .start = V2M_SERIAL_BUS_PCI, | 152 | .start = V2M_SERIAL_BUS_PCI, |
@@ -201,6 +201,11 @@ static struct platform_device v2m_eth_device = { | |||
201 | .dev.platform_data = &v2m_eth_config, | 201 | .dev.platform_data = &v2m_eth_config, |
202 | }; | 202 | }; |
203 | 203 | ||
204 | static struct regulator_consumer_supply v2m_eth_supplies[] = { | ||
205 | REGULATOR_SUPPLY("vddvario", "smsc911x"), | ||
206 | REGULATOR_SUPPLY("vdd33a", "smsc911x"), | ||
207 | }; | ||
208 | |||
204 | static struct resource v2m_usb_resources[] = { | 209 | static struct resource v2m_usb_resources[] = { |
205 | { | 210 | { |
206 | .start = V2M_ISP1761, | 211 | .start = V2M_ISP1761, |
@@ -319,98 +324,145 @@ static struct amba_device *v2m_amba_devs[] __initdata = { | |||
319 | }; | 324 | }; |
320 | 325 | ||
321 | 326 | ||
322 | static long v2m_osc_round(struct clk *clk, unsigned long rate) | 327 | static unsigned long v2m_osc_recalc_rate(struct clk_hw *hw, |
328 | unsigned long parent_rate) | ||
329 | { | ||
330 | struct v2m_osc *osc = to_v2m_osc(hw); | ||
331 | |||
332 | return !parent_rate ? osc->rate_default : parent_rate; | ||
333 | } | ||
334 | |||
335 | static long v2m_osc_round_rate(struct clk_hw *hw, unsigned long rate, | ||
336 | unsigned long *parent_rate) | ||
323 | { | 337 | { |
338 | struct v2m_osc *osc = to_v2m_osc(hw); | ||
339 | |||
340 | if (WARN_ON(rate < osc->rate_min)) | ||
341 | rate = osc->rate_min; | ||
342 | |||
343 | if (WARN_ON(rate > osc->rate_max)) | ||
344 | rate = osc->rate_max; | ||
345 | |||
324 | return rate; | 346 | return rate; |
325 | } | 347 | } |
326 | 348 | ||
327 | static int v2m_osc1_set(struct clk *clk, unsigned long rate) | 349 | static int v2m_osc_set_rate(struct clk_hw *hw, unsigned long rate, |
350 | unsigned long parent_rate) | ||
328 | { | 351 | { |
329 | return v2m_cfg_write(SYS_CFG_OSC | SYS_CFG_SITE_MB | 1, rate); | 352 | struct v2m_osc *osc = to_v2m_osc(hw); |
353 | |||
354 | v2m_cfg_write(SYS_CFG_OSC | SYS_CFG_SITE(osc->site) | | ||
355 | SYS_CFG_STACK(osc->stack) | osc->osc, rate); | ||
356 | |||
357 | return 0; | ||
330 | } | 358 | } |
331 | 359 | ||
332 | static const struct clk_ops osc1_clk_ops = { | 360 | static struct clk_ops v2m_osc_ops = { |
333 | .round = v2m_osc_round, | 361 | .recalc_rate = v2m_osc_recalc_rate, |
334 | .set = v2m_osc1_set, | 362 | .round_rate = v2m_osc_round_rate, |
335 | }; | 363 | .set_rate = v2m_osc_set_rate, |
336 | 364 | }; | |
337 | static struct clk osc1_clk = { | 365 | |
338 | .ops = &osc1_clk_ops, | 366 | struct clk * __init v2m_osc_register(const char *name, struct v2m_osc *osc) |
339 | .rate = 24000000, | 367 | { |
340 | }; | 368 | struct clk_init_data init; |
341 | 369 | ||
342 | static struct clk osc2_clk = { | 370 | WARN_ON(osc->site > 2); |
343 | .rate = 24000000, | 371 | WARN_ON(osc->stack > 15); |
344 | }; | 372 | WARN_ON(osc->osc > 4095); |
345 | 373 | ||
346 | static struct clk v2m_sp804_clk = { | 374 | init.name = name; |
347 | .rate = 1000000, | 375 | init.ops = &v2m_osc_ops; |
348 | }; | 376 | init.flags = CLK_IS_ROOT; |
349 | 377 | init.num_parents = 0; | |
350 | static struct clk v2m_ref_clk = { | 378 | |
351 | .rate = 32768, | 379 | osc->hw.init = &init; |
352 | }; | 380 | |
353 | 381 | return clk_register(NULL, &osc->hw); | |
354 | static struct clk dummy_apb_pclk; | 382 | } |
355 | 383 | ||
356 | static struct clk_lookup v2m_lookups[] = { | 384 | static struct v2m_osc v2m_mb_osc1 = { |
357 | { /* AMBA bus clock */ | 385 | .site = SYS_CFG_SITE_MB, |
358 | .con_id = "apb_pclk", | 386 | .osc = 1, |
359 | .clk = &dummy_apb_pclk, | 387 | .rate_min = 23750000, |
360 | }, { /* UART0 */ | 388 | .rate_max = 63500000, |
361 | .dev_id = "mb:uart0", | 389 | .rate_default = 23750000, |
362 | .clk = &osc2_clk, | 390 | }; |
363 | }, { /* UART1 */ | 391 | |
364 | .dev_id = "mb:uart1", | 392 | static const char *v2m_ref_clk_periphs[] __initconst = { |
365 | .clk = &osc2_clk, | 393 | "mb:wdt", "1000f000.wdt", "1c0f0000.wdt", /* SP805 WDT */ |
366 | }, { /* UART2 */ | 394 | }; |
367 | .dev_id = "mb:uart2", | 395 | |
368 | .clk = &osc2_clk, | 396 | static const char *v2m_osc1_periphs[] __initconst = { |
369 | }, { /* UART3 */ | 397 | "mb:clcd", "1001f000.clcd", "1c1f0000.clcd", /* PL111 CLCD */ |
370 | .dev_id = "mb:uart3", | 398 | }; |
371 | .clk = &osc2_clk, | 399 | |
372 | }, { /* KMI0 */ | 400 | static const char *v2m_osc2_periphs[] __initconst = { |
373 | .dev_id = "mb:kmi0", | 401 | "mb:mmci", "10005000.mmci", "1c050000.mmci", /* PL180 MMCI */ |
374 | .clk = &osc2_clk, | 402 | "mb:kmi0", "10006000.kmi", "1c060000.kmi", /* PL050 KMI0 */ |
375 | }, { /* KMI1 */ | 403 | "mb:kmi1", "10007000.kmi", "1c070000.kmi", /* PL050 KMI1 */ |
376 | .dev_id = "mb:kmi1", | 404 | "mb:uart0", "10009000.uart", "1c090000.uart", /* PL011 UART0 */ |
377 | .clk = &osc2_clk, | 405 | "mb:uart1", "1000a000.uart", "1c0a0000.uart", /* PL011 UART1 */ |
378 | }, { /* MMC0 */ | 406 | "mb:uart2", "1000b000.uart", "1c0b0000.uart", /* PL011 UART2 */ |
379 | .dev_id = "mb:mmci", | 407 | "mb:uart3", "1000c000.uart", "1c0c0000.uart", /* PL011 UART3 */ |
380 | .clk = &osc2_clk, | 408 | }; |
381 | }, { /* CLCD */ | 409 | |
382 | .dev_id = "mb:clcd", | 410 | static void __init v2m_clk_init(void) |
383 | .clk = &osc1_clk, | 411 | { |
384 | }, { /* SP805 WDT */ | 412 | struct clk *clk; |
385 | .dev_id = "mb:wdt", | 413 | int i; |
386 | .clk = &v2m_ref_clk, | 414 | |
387 | }, { /* SP804 timers */ | 415 | clk = clk_register_fixed_rate(NULL, "dummy_apb_pclk", NULL, |
388 | .dev_id = "sp804", | 416 | CLK_IS_ROOT, 0); |
389 | .con_id = "v2m-timer0", | 417 | WARN_ON(clk_register_clkdev(clk, "apb_pclk", NULL)); |
390 | .clk = &v2m_sp804_clk, | 418 | |
391 | }, { /* SP804 timers */ | 419 | clk = clk_register_fixed_rate(NULL, "mb:ref_clk", NULL, |
392 | .dev_id = "sp804", | 420 | CLK_IS_ROOT, 32768); |
393 | .con_id = "v2m-timer1", | 421 | for (i = 0; i < ARRAY_SIZE(v2m_ref_clk_periphs); i++) |
394 | .clk = &v2m_sp804_clk, | 422 | WARN_ON(clk_register_clkdev(clk, NULL, v2m_ref_clk_periphs[i])); |
395 | }, | 423 | |
424 | clk = clk_register_fixed_rate(NULL, "mb:sp804_clk", NULL, | ||
425 | CLK_IS_ROOT, 1000000); | ||
426 | WARN_ON(clk_register_clkdev(clk, "v2m-timer0", "sp804")); | ||
427 | WARN_ON(clk_register_clkdev(clk, "v2m-timer1", "sp804")); | ||
428 | |||
429 | clk = v2m_osc_register("mb:osc1", &v2m_mb_osc1); | ||
430 | for (i = 0; i < ARRAY_SIZE(v2m_osc1_periphs); i++) | ||
431 | WARN_ON(clk_register_clkdev(clk, NULL, v2m_osc1_periphs[i])); | ||
432 | |||
433 | clk = clk_register_fixed_rate(NULL, "mb:osc2", NULL, | ||
434 | CLK_IS_ROOT, 24000000); | ||
435 | for (i = 0; i < ARRAY_SIZE(v2m_osc2_periphs); i++) | ||
436 | WARN_ON(clk_register_clkdev(clk, NULL, v2m_osc2_periphs[i])); | ||
437 | } | ||
438 | |||
439 | static void __init v2m_timer_init(void) | ||
440 | { | ||
441 | v2m_sysctl_init(ioremap(V2M_SYSCTL, SZ_4K)); | ||
442 | v2m_clk_init(); | ||
443 | v2m_sp804_init(ioremap(V2M_TIMER01, SZ_4K), IRQ_V2M_TIMER0); | ||
444 | } | ||
445 | |||
446 | static struct sys_timer v2m_timer = { | ||
447 | .init = v2m_timer_init, | ||
396 | }; | 448 | }; |
397 | 449 | ||
398 | static void __init v2m_init_early(void) | 450 | static void __init v2m_init_early(void) |
399 | { | 451 | { |
400 | ct_desc->init_early(); | 452 | if (ct_desc->init_early) |
401 | clkdev_add_table(v2m_lookups, ARRAY_SIZE(v2m_lookups)); | 453 | ct_desc->init_early(); |
402 | versatile_sched_clock_init(v2m_sysreg_base + V2M_SYS_24MHZ, 24000000); | 454 | versatile_sched_clock_init(v2m_sysreg_base + V2M_SYS_24MHZ, 24000000); |
403 | } | 455 | } |
404 | 456 | ||
405 | static void v2m_power_off(void) | 457 | static void v2m_power_off(void) |
406 | { | 458 | { |
407 | if (v2m_cfg_write(SYS_CFG_SHUTDOWN | SYS_CFG_SITE_MB, 0)) | 459 | if (v2m_cfg_write(SYS_CFG_SHUTDOWN | SYS_CFG_SITE(SYS_CFG_SITE_MB), 0)) |
408 | printk(KERN_EMERG "Unable to shutdown\n"); | 460 | printk(KERN_EMERG "Unable to shutdown\n"); |
409 | } | 461 | } |
410 | 462 | ||
411 | static void v2m_restart(char str, const char *cmd) | 463 | static void v2m_restart(char str, const char *cmd) |
412 | { | 464 | { |
413 | if (v2m_cfg_write(SYS_CFG_REBOOT | SYS_CFG_SITE_MB, 0)) | 465 | if (v2m_cfg_write(SYS_CFG_REBOOT | SYS_CFG_SITE(SYS_CFG_SITE_MB), 0)) |
414 | printk(KERN_EMERG "Unable to reboot\n"); | 466 | printk(KERN_EMERG "Unable to reboot\n"); |
415 | } | 467 | } |
416 | 468 | ||
@@ -458,6 +510,9 @@ static void __init v2m_init(void) | |||
458 | { | 510 | { |
459 | int i; | 511 | int i; |
460 | 512 | ||
513 | regulator_register_fixed(0, v2m_eth_supplies, | ||
514 | ARRAY_SIZE(v2m_eth_supplies)); | ||
515 | |||
461 | platform_device_register(&v2m_pcie_i2c_device); | 516 | platform_device_register(&v2m_pcie_i2c_device); |
462 | platform_device_register(&v2m_ddc_i2c_device); | 517 | platform_device_register(&v2m_ddc_i2c_device); |
463 | platform_device_register(&v2m_flash_device); | 518 | platform_device_register(&v2m_flash_device); |
@@ -522,77 +577,6 @@ void __init v2m_dt_map_io(void) | |||
522 | #endif | 577 | #endif |
523 | } | 578 | } |
524 | 579 | ||
525 | static struct clk_lookup v2m_dt_lookups[] = { | ||
526 | { /* AMBA bus clock */ | ||
527 | .con_id = "apb_pclk", | ||
528 | .clk = &dummy_apb_pclk, | ||
529 | }, { /* SP804 timers */ | ||
530 | .dev_id = "sp804", | ||
531 | .con_id = "v2m-timer0", | ||
532 | .clk = &v2m_sp804_clk, | ||
533 | }, { /* SP804 timers */ | ||
534 | .dev_id = "sp804", | ||
535 | .con_id = "v2m-timer1", | ||
536 | .clk = &v2m_sp804_clk, | ||
537 | }, { /* PL180 MMCI */ | ||
538 | .dev_id = "mb:mmci", /* 10005000.mmci */ | ||
539 | .clk = &osc2_clk, | ||
540 | }, { /* PL050 KMI0 */ | ||
541 | .dev_id = "10006000.kmi", | ||
542 | .clk = &osc2_clk, | ||
543 | }, { /* PL050 KMI1 */ | ||
544 | .dev_id = "10007000.kmi", | ||
545 | .clk = &osc2_clk, | ||
546 | }, { /* PL011 UART0 */ | ||
547 | .dev_id = "10009000.uart", | ||
548 | .clk = &osc2_clk, | ||
549 | }, { /* PL011 UART1 */ | ||
550 | .dev_id = "1000a000.uart", | ||
551 | .clk = &osc2_clk, | ||
552 | }, { /* PL011 UART2 */ | ||
553 | .dev_id = "1000b000.uart", | ||
554 | .clk = &osc2_clk, | ||
555 | }, { /* PL011 UART3 */ | ||
556 | .dev_id = "1000c000.uart", | ||
557 | .clk = &osc2_clk, | ||
558 | }, { /* SP805 WDT */ | ||
559 | .dev_id = "1000f000.wdt", | ||
560 | .clk = &v2m_ref_clk, | ||
561 | }, { /* PL111 CLCD */ | ||
562 | .dev_id = "1001f000.clcd", | ||
563 | .clk = &osc1_clk, | ||
564 | }, | ||
565 | /* RS1 memory map */ | ||
566 | { /* PL180 MMCI */ | ||
567 | .dev_id = "mb:mmci", /* 1c050000.mmci */ | ||
568 | .clk = &osc2_clk, | ||
569 | }, { /* PL050 KMI0 */ | ||
570 | .dev_id = "1c060000.kmi", | ||
571 | .clk = &osc2_clk, | ||
572 | }, { /* PL050 KMI1 */ | ||
573 | .dev_id = "1c070000.kmi", | ||
574 | .clk = &osc2_clk, | ||
575 | }, { /* PL011 UART0 */ | ||
576 | .dev_id = "1c090000.uart", | ||
577 | .clk = &osc2_clk, | ||
578 | }, { /* PL011 UART1 */ | ||
579 | .dev_id = "1c0a0000.uart", | ||
580 | .clk = &osc2_clk, | ||
581 | }, { /* PL011 UART2 */ | ||
582 | .dev_id = "1c0b0000.uart", | ||
583 | .clk = &osc2_clk, | ||
584 | }, { /* PL011 UART3 */ | ||
585 | .dev_id = "1c0c0000.uart", | ||
586 | .clk = &osc2_clk, | ||
587 | }, { /* SP805 WDT */ | ||
588 | .dev_id = "1c0f0000.wdt", | ||
589 | .clk = &v2m_ref_clk, | ||
590 | }, { /* PL111 CLCD */ | ||
591 | .dev_id = "1c1f0000.clcd", | ||
592 | .clk = &osc1_clk, | ||
593 | }, | ||
594 | }; | ||
595 | |||
596 | void __init v2m_dt_init_early(void) | 580 | void __init v2m_dt_init_early(void) |
597 | { | 581 | { |
598 | struct device_node *node; | 582 | struct device_node *node; |
@@ -605,8 +589,8 @@ void __init v2m_dt_init_early(void) | |||
605 | 589 | ||
606 | /* Confirm board type against DT property, if available */ | 590 | /* Confirm board type against DT property, if available */ |
607 | if (of_property_read_u32(allnodes, "arm,hbi", &dt_hbi) == 0) { | 591 | if (of_property_read_u32(allnodes, "arm,hbi", &dt_hbi) == 0) { |
608 | u32 misc = readl(v2m_sysreg_base + V2M_SYS_MISC); | 592 | int site = v2m_get_master_site(); |
609 | u32 id = readl(v2m_sysreg_base + (misc & SYS_MISC_MASTERSITE ? | 593 | u32 id = readl(v2m_sysreg_base + (site == SYS_CFG_SITE_DB2 ? |
610 | V2M_SYS_PROCID1 : V2M_SYS_PROCID0)); | 594 | V2M_SYS_PROCID1 : V2M_SYS_PROCID0)); |
611 | u32 hbi = id & SYS_PROCIDx_HBI_MASK; | 595 | u32 hbi = id & SYS_PROCIDx_HBI_MASK; |
612 | 596 | ||
@@ -614,8 +598,6 @@ void __init v2m_dt_init_early(void) | |||
614 | pr_warning("vexpress: DT HBI (%x) is not matching " | 598 | pr_warning("vexpress: DT HBI (%x) is not matching " |
615 | "hardware (%x)!\n", dt_hbi, hbi); | 599 | "hardware (%x)!\n", dt_hbi, hbi); |
616 | } | 600 | } |
617 | |||
618 | clkdev_add_table(v2m_dt_lookups, ARRAY_SIZE(v2m_dt_lookups)); | ||
619 | } | 601 | } |
620 | 602 | ||
621 | static struct of_device_id vexpress_irq_match[] __initdata = { | 603 | static struct of_device_id vexpress_irq_match[] __initdata = { |
@@ -637,6 +619,8 @@ static void __init v2m_dt_timer_init(void) | |||
637 | node = of_find_compatible_node(NULL, NULL, "arm,sp810"); | 619 | node = of_find_compatible_node(NULL, NULL, "arm,sp810"); |
638 | v2m_sysctl_init(of_iomap(node, 0)); | 620 | v2m_sysctl_init(of_iomap(node, 0)); |
639 | 621 | ||
622 | v2m_clk_init(); | ||
623 | |||
640 | err = of_property_read_string(of_aliases, "arm,v2m_timer", &path); | 624 | err = of_property_read_string(of_aliases, "arm,v2m_timer", &path); |
641 | if (WARN_ON(err)) | 625 | if (WARN_ON(err)) |
642 | return; | 626 | return; |
diff --git a/arch/arm/plat-mxc/devices/platform-mxc_rtc.c b/arch/arm/plat-mxc/devices/platform-mxc_rtc.c index 16d0ec4df5f6..a5c9ad5721c2 100644 --- a/arch/arm/plat-mxc/devices/platform-mxc_rtc.c +++ b/arch/arm/plat-mxc/devices/platform-mxc_rtc.c | |||
@@ -20,6 +20,11 @@ const struct imx_mxc_rtc_data imx31_mxc_rtc_data __initconst = | |||
20 | imx_mxc_rtc_data_entry_single(MX31); | 20 | imx_mxc_rtc_data_entry_single(MX31); |
21 | #endif /* ifdef CONFIG_SOC_IMX31 */ | 21 | #endif /* ifdef CONFIG_SOC_IMX31 */ |
22 | 22 | ||
23 | #ifdef CONFIG_SOC_IMX35 | ||
24 | const struct imx_mxc_rtc_data imx35_mxc_rtc_data __initconst = | ||
25 | imx_mxc_rtc_data_entry_single(MX35); | ||
26 | #endif /* ifdef CONFIG_SOC_IMX35 */ | ||
27 | |||
23 | struct platform_device *__init imx_add_mxc_rtc( | 28 | struct platform_device *__init imx_add_mxc_rtc( |
24 | const struct imx_mxc_rtc_data *data) | 29 | const struct imx_mxc_rtc_data *data) |
25 | { | 30 | { |
diff --git a/arch/arm/plat-mxc/include/mach/iomux-mx51.h b/arch/arm/plat-mxc/include/mach/iomux-mx51.h index 36c8989d9de6..2623e7a2e190 100644 --- a/arch/arm/plat-mxc/include/mach/iomux-mx51.h +++ b/arch/arm/plat-mxc/include/mach/iomux-mx51.h | |||
@@ -107,11 +107,13 @@ | |||
107 | #define MX51_PAD_EIM_D25__UART2_CTS IOMUX_PAD(0x414, 0x080, 4, __NA_, 0, MX51_UART_PAD_CTRL) | 107 | #define MX51_PAD_EIM_D25__UART2_CTS IOMUX_PAD(0x414, 0x080, 4, __NA_, 0, MX51_UART_PAD_CTRL) |
108 | #define MX51_PAD_EIM_D25__UART3_RXD IOMUX_PAD(0x414, 0x080, 3, 0x9f4, 0, MX51_UART_PAD_CTRL) | 108 | #define MX51_PAD_EIM_D25__UART3_RXD IOMUX_PAD(0x414, 0x080, 3, 0x9f4, 0, MX51_UART_PAD_CTRL) |
109 | #define MX51_PAD_EIM_D25__USBOTG_DATA1 IOMUX_PAD(0x414, 0x080, 2, __NA_, 0, NO_PAD_CTRL) | 109 | #define MX51_PAD_EIM_D25__USBOTG_DATA1 IOMUX_PAD(0x414, 0x080, 2, __NA_, 0, NO_PAD_CTRL) |
110 | #define MX51_PAD_EIM_D25__GPT_CMPOUT1 IOMUX_PAD(0x414, 0x080, 5, __NA_, 0, NO_PAD_CTRL) | ||
110 | #define MX51_PAD_EIM_D26__EIM_D26 IOMUX_PAD(0x418, 0x084, 0, __NA_, 0, NO_PAD_CTRL) | 111 | #define MX51_PAD_EIM_D26__EIM_D26 IOMUX_PAD(0x418, 0x084, 0, __NA_, 0, NO_PAD_CTRL) |
111 | #define MX51_PAD_EIM_D26__KEY_COL7 IOMUX_PAD(0x418, 0x084, 1, 0x9cc, 0, NO_PAD_CTRL) | 112 | #define MX51_PAD_EIM_D26__KEY_COL7 IOMUX_PAD(0x418, 0x084, 1, 0x9cc, 0, NO_PAD_CTRL) |
112 | #define MX51_PAD_EIM_D26__UART2_RTS IOMUX_PAD(0x418, 0x084, 4, 0x9e8, 3, MX51_UART_PAD_CTRL) | 113 | #define MX51_PAD_EIM_D26__UART2_RTS IOMUX_PAD(0x418, 0x084, 4, 0x9e8, 3, MX51_UART_PAD_CTRL) |
113 | #define MX51_PAD_EIM_D26__UART3_TXD IOMUX_PAD(0x418, 0x084, 3, __NA_, 0, MX51_UART_PAD_CTRL) | 114 | #define MX51_PAD_EIM_D26__UART3_TXD IOMUX_PAD(0x418, 0x084, 3, __NA_, 0, MX51_UART_PAD_CTRL) |
114 | #define MX51_PAD_EIM_D26__USBOTG_DATA2 IOMUX_PAD(0x418, 0x084, 2, __NA_, 0, NO_PAD_CTRL) | 115 | #define MX51_PAD_EIM_D26__USBOTG_DATA2 IOMUX_PAD(0x418, 0x084, 2, __NA_, 0, NO_PAD_CTRL) |
116 | #define MX51_PAD_EIM_D26__GPT_CMPOUT2 IOMUX_PAD(0x418, 0x084, 5, __NA_, 0, NO_PAD_CTRL) | ||
115 | #define MX51_PAD_EIM_D27__AUD6_RXC IOMUX_PAD(0x41c, 0x088, 5, 0x8f4, 0, NO_PAD_CTRL) | 117 | #define MX51_PAD_EIM_D27__AUD6_RXC IOMUX_PAD(0x41c, 0x088, 5, 0x8f4, 0, NO_PAD_CTRL) |
116 | #define MX51_PAD_EIM_D27__EIM_D27 IOMUX_PAD(0x41c, 0x088, 0, __NA_, 0, NO_PAD_CTRL) | 118 | #define MX51_PAD_EIM_D27__EIM_D27 IOMUX_PAD(0x41c, 0x088, 0, __NA_, 0, NO_PAD_CTRL) |
117 | #define MX51_PAD_EIM_D27__GPIO2_9 IOMUX_PAD(0x41c, 0x088, 1, __NA_, 0, MX51_GPIO_PAD_CTRL) | 119 | #define MX51_PAD_EIM_D27__GPIO2_9 IOMUX_PAD(0x41c, 0x088, 1, __NA_, 0, MX51_GPIO_PAD_CTRL) |
@@ -228,6 +230,7 @@ | |||
228 | #define MX51_PAD_EIM_CRE__EIM_CRE IOMUX_PAD(0x4a0, 0x100, 0, __NA_, 0, NO_PAD_CTRL) | 230 | #define MX51_PAD_EIM_CRE__EIM_CRE IOMUX_PAD(0x4a0, 0x100, 0, __NA_, 0, NO_PAD_CTRL) |
229 | #define MX51_PAD_EIM_CRE__GPIO3_2 IOMUX_PAD(0x4a0, 0x100, 1, 0x97c, 0, MX51_GPIO_PAD_CTRL) | 231 | #define MX51_PAD_EIM_CRE__GPIO3_2 IOMUX_PAD(0x4a0, 0x100, 1, 0x97c, 0, MX51_GPIO_PAD_CTRL) |
230 | #define MX51_PAD_DRAM_CS1__DRAM_CS1 IOMUX_PAD(0x4d0, 0x104, 0, __NA_, 0, NO_PAD_CTRL) | 232 | #define MX51_PAD_DRAM_CS1__DRAM_CS1 IOMUX_PAD(0x4d0, 0x104, 0, __NA_, 0, NO_PAD_CTRL) |
233 | #define MX51_PAD_DRAM_CS1__CCM_CLKO IOMUX_PAD(0x4d0, 0x104, 1, __NA_, 0, NO_PAD_CTRL) | ||
231 | #define MX51_PAD_NANDF_WE_B__GPIO3_3 IOMUX_PAD(0x4e4, 0x108, 3, 0x980, 0, MX51_GPIO_PAD_CTRL) | 234 | #define MX51_PAD_NANDF_WE_B__GPIO3_3 IOMUX_PAD(0x4e4, 0x108, 3, 0x980, 0, MX51_GPIO_PAD_CTRL) |
232 | #define MX51_PAD_NANDF_WE_B__NANDF_WE_B IOMUX_PAD(0x4e4, 0x108, 0, __NA_, 0, NO_PAD_CTRL) | 235 | #define MX51_PAD_NANDF_WE_B__NANDF_WE_B IOMUX_PAD(0x4e4, 0x108, 0, __NA_, 0, NO_PAD_CTRL) |
233 | #define MX51_PAD_NANDF_WE_B__PATA_DIOW IOMUX_PAD(0x4e4, 0x108, 1, __NA_, 0, NO_PAD_CTRL) | 236 | #define MX51_PAD_NANDF_WE_B__PATA_DIOW IOMUX_PAD(0x4e4, 0x108, 1, __NA_, 0, NO_PAD_CTRL) |
@@ -256,12 +259,14 @@ | |||
256 | #define MX51_PAD_NANDF_RB1__GPIO3_9 IOMUX_PAD(0x4fc, 0x120, 3, __NA_, 0, MX51_GPIO_PAD_CTRL) | 259 | #define MX51_PAD_NANDF_RB1__GPIO3_9 IOMUX_PAD(0x4fc, 0x120, 3, __NA_, 0, MX51_GPIO_PAD_CTRL) |
257 | #define MX51_PAD_NANDF_RB1__NANDF_RB1 IOMUX_PAD(0x4fc, 0x120, 0, __NA_, 0, NO_PAD_CTRL) | 260 | #define MX51_PAD_NANDF_RB1__NANDF_RB1 IOMUX_PAD(0x4fc, 0x120, 0, __NA_, 0, NO_PAD_CTRL) |
258 | #define MX51_PAD_NANDF_RB1__PATA_IORDY IOMUX_PAD(0x4fc, 0x120, 1, __NA_, 0, NO_PAD_CTRL) | 261 | #define MX51_PAD_NANDF_RB1__PATA_IORDY IOMUX_PAD(0x4fc, 0x120, 1, __NA_, 0, NO_PAD_CTRL) |
262 | #define MX51_PAD_NANDF_RB1__GPT_CMPOUT2 IOMUX_PAD(0x4fc, 0x120, 4, __NA_, 0, NO_PAD_CTRL) | ||
259 | #define MX51_PAD_NANDF_RB1__SD4_CMD IOMUX_PAD(0x4fc, 0x120, 0x15, __NA_, 0, MX51_SDHCI_PAD_CTRL) | 263 | #define MX51_PAD_NANDF_RB1__SD4_CMD IOMUX_PAD(0x4fc, 0x120, 0x15, __NA_, 0, MX51_SDHCI_PAD_CTRL) |
260 | #define MX51_PAD_NANDF_RB2__DISP2_WAIT IOMUX_PAD(0x500, 0x124, 5, 0x9a8, 0, NO_PAD_CTRL) | 264 | #define MX51_PAD_NANDF_RB2__DISP2_WAIT IOMUX_PAD(0x500, 0x124, 5, 0x9a8, 0, NO_PAD_CTRL) |
261 | #define MX51_PAD_NANDF_RB2__ECSPI2_SCLK IOMUX_PAD(0x500, 0x124, 2, __NA_, 0, MX51_ECSPI_PAD_CTRL) | 265 | #define MX51_PAD_NANDF_RB2__ECSPI2_SCLK IOMUX_PAD(0x500, 0x124, 2, __NA_, 0, MX51_ECSPI_PAD_CTRL) |
262 | #define MX51_PAD_NANDF_RB2__FEC_COL IOMUX_PAD(0x500, 0x124, 1, 0x94c, 0, MX51_PAD_CTRL_2) | 266 | #define MX51_PAD_NANDF_RB2__FEC_COL IOMUX_PAD(0x500, 0x124, 1, 0x94c, 0, MX51_PAD_CTRL_2) |
263 | #define MX51_PAD_NANDF_RB2__GPIO3_10 IOMUX_PAD(0x500, 0x124, 3, __NA_, 0, MX51_GPIO_PAD_CTRL) | 267 | #define MX51_PAD_NANDF_RB2__GPIO3_10 IOMUX_PAD(0x500, 0x124, 3, __NA_, 0, MX51_GPIO_PAD_CTRL) |
264 | #define MX51_PAD_NANDF_RB2__NANDF_RB2 IOMUX_PAD(0x500, 0x124, 0, __NA_, 0, NO_PAD_CTRL) | 268 | #define MX51_PAD_NANDF_RB2__NANDF_RB2 IOMUX_PAD(0x500, 0x124, 0, __NA_, 0, NO_PAD_CTRL) |
269 | #define MX51_PAD_NANDF_RB2__GPT_CMPOUT3 IOMUX_PAD(0x500, 0x124, 4, __NA_, 0, NO_PAD_CTRL) | ||
265 | #define MX51_PAD_NANDF_RB2__USBH3_H3_DP IOMUX_PAD(0x500, 0x124, 0x17, __NA_, 0, NO_PAD_CTRL) | 270 | #define MX51_PAD_NANDF_RB2__USBH3_H3_DP IOMUX_PAD(0x500, 0x124, 0x17, __NA_, 0, NO_PAD_CTRL) |
266 | #define MX51_PAD_NANDF_RB2__USBH3_NXT IOMUX_PAD(0x500, 0x124, 6, 0xa20, 0, NO_PAD_CTRL) | 271 | #define MX51_PAD_NANDF_RB2__USBH3_NXT IOMUX_PAD(0x500, 0x124, 6, 0xa20, 0, NO_PAD_CTRL) |
267 | #define MX51_PAD_NANDF_RB3__DISP1_WAIT IOMUX_PAD(0x504, 0x128, 5, __NA_, 0, NO_PAD_CTRL) | 272 | #define MX51_PAD_NANDF_RB3__DISP1_WAIT IOMUX_PAD(0x504, 0x128, 5, __NA_, 0, NO_PAD_CTRL) |
@@ -637,7 +642,9 @@ | |||
637 | #define MX51_PAD_DISP1_DAT23__DISP2_DAT17 IOMUX_PAD(0x728, 0x328, 5, __NA_, 0, NO_PAD_CTRL) | 642 | #define MX51_PAD_DISP1_DAT23__DISP2_DAT17 IOMUX_PAD(0x728, 0x328, 5, __NA_, 0, NO_PAD_CTRL) |
638 | #define MX51_PAD_DISP1_DAT23__DISP2_SER_CS IOMUX_PAD(0x728, 0x328, 4, __NA_, 0, NO_PAD_CTRL) | 643 | #define MX51_PAD_DISP1_DAT23__DISP2_SER_CS IOMUX_PAD(0x728, 0x328, 4, __NA_, 0, NO_PAD_CTRL) |
639 | #define MX51_PAD_DI1_PIN3__DI1_PIN3 IOMUX_PAD(0x72c, 0x32c, 0, __NA_, 0, NO_PAD_CTRL) | 644 | #define MX51_PAD_DI1_PIN3__DI1_PIN3 IOMUX_PAD(0x72c, 0x32c, 0, __NA_, 0, NO_PAD_CTRL) |
645 | #define MX51_PAD_DI1_DISP_CLK__DI1_DISP_CLK IOMUX_PAD(0x730, __NA_, 0, __NA_, 0, NO_PAD_CTRL) | ||
640 | #define MX51_PAD_DI1_PIN2__DI1_PIN2 IOMUX_PAD(0x734, 0x330, 0, __NA_, 0, NO_PAD_CTRL) | 646 | #define MX51_PAD_DI1_PIN2__DI1_PIN2 IOMUX_PAD(0x734, 0x330, 0, __NA_, 0, NO_PAD_CTRL) |
647 | #define MX51_PAD_DI1_PIN15__DI1_PIN15 IOMUX_PAD(0x738, __NA_, 0, __NA_, 0, NO_PAD_CTRL) | ||
641 | #define MX51_PAD_DI_GP2__DISP1_SER_CLK IOMUX_PAD(0x740, 0x338, 0, __NA_, 0, NO_PAD_CTRL) | 648 | #define MX51_PAD_DI_GP2__DISP1_SER_CLK IOMUX_PAD(0x740, 0x338, 0, __NA_, 0, NO_PAD_CTRL) |
642 | #define MX51_PAD_DI_GP2__DISP2_WAIT IOMUX_PAD(0x740, 0x338, 2, 0x9a8, 1, NO_PAD_CTRL) | 649 | #define MX51_PAD_DI_GP2__DISP2_WAIT IOMUX_PAD(0x740, 0x338, 2, 0x9a8, 1, NO_PAD_CTRL) |
643 | #define MX51_PAD_DI_GP3__CSI1_DATA_EN IOMUX_PAD(0x744, 0x33c, 3, 0x9a0, 1, NO_PAD_CTRL) | 650 | #define MX51_PAD_DI_GP3__CSI1_DATA_EN IOMUX_PAD(0x744, 0x33c, 3, 0x9a0, 1, NO_PAD_CTRL) |
@@ -780,6 +787,8 @@ | |||
780 | #define MX51_PAD_GPIO1_2__PWM1_PWMO IOMUX_PAD(0x7d4, 0x3cc, 1, __NA_, 0, NO_PAD_CTRL) | 787 | #define MX51_PAD_GPIO1_2__PWM1_PWMO IOMUX_PAD(0x7d4, 0x3cc, 1, __NA_, 0, NO_PAD_CTRL) |
781 | #define MX51_PAD_GPIO1_3__GPIO1_3 IOMUX_PAD(0x7d8, 0x3d0, 0, __NA_, 0, MX51_GPIO_PAD_CTRL) | 788 | #define MX51_PAD_GPIO1_3__GPIO1_3 IOMUX_PAD(0x7d8, 0x3d0, 0, __NA_, 0, MX51_GPIO_PAD_CTRL) |
782 | #define MX51_PAD_GPIO1_3__I2C2_SDA IOMUX_PAD(0x7d8, 0x3d0, 0x12, 0x9bc, 3, MX51_I2C_PAD_CTRL) | 789 | #define MX51_PAD_GPIO1_3__I2C2_SDA IOMUX_PAD(0x7d8, 0x3d0, 0x12, 0x9bc, 3, MX51_I2C_PAD_CTRL) |
790 | #define MX51_PAD_GPIO1_3__CCM_CLKO2 IOMUX_PAD(0x7d8, 0x3d0, 5, __NA_, 0, NO_PAD_CTRL) | ||
791 | #define MX51_PAD_GPIO1_3__GPT_CLKIN IOMUX_PAD(0x7d8, 0x3d0, 6, __NA_, 0, NO_PAD_CTRL) | ||
783 | #define MX51_PAD_GPIO1_3__PLL2_BYP IOMUX_PAD(0x7d8, 0x3d0, 7, 0x910, 1, NO_PAD_CTRL) | 792 | #define MX51_PAD_GPIO1_3__PLL2_BYP IOMUX_PAD(0x7d8, 0x3d0, 7, 0x910, 1, NO_PAD_CTRL) |
784 | #define MX51_PAD_GPIO1_3__PWM2_PWMO IOMUX_PAD(0x7d8, 0x3d0, 1, __NA_, 0, NO_PAD_CTRL) | 793 | #define MX51_PAD_GPIO1_3__PWM2_PWMO IOMUX_PAD(0x7d8, 0x3d0, 1, __NA_, 0, NO_PAD_CTRL) |
785 | #define MX51_PAD_PMIC_INT_REQ__PMIC_INT_REQ IOMUX_PAD(0x7fc, 0x3d4, 0, __NA_, 0, NO_PAD_CTRL) | 794 | #define MX51_PAD_PMIC_INT_REQ__PMIC_INT_REQ IOMUX_PAD(0x7fc, 0x3d4, 0, __NA_, 0, NO_PAD_CTRL) |
@@ -788,13 +797,16 @@ | |||
788 | #define MX51_PAD_GPIO1_4__EIM_RDY IOMUX_PAD(0x804, 0x3d8, 3, 0x938, 1, NO_PAD_CTRL) | 797 | #define MX51_PAD_GPIO1_4__EIM_RDY IOMUX_PAD(0x804, 0x3d8, 3, 0x938, 1, NO_PAD_CTRL) |
789 | #define MX51_PAD_GPIO1_4__GPIO1_4 IOMUX_PAD(0x804, 0x3d8, 0, __NA_, 0, MX51_GPIO_PAD_CTRL) | 798 | #define MX51_PAD_GPIO1_4__GPIO1_4 IOMUX_PAD(0x804, 0x3d8, 0, __NA_, 0, MX51_GPIO_PAD_CTRL) |
790 | #define MX51_PAD_GPIO1_4__WDOG1_WDOG_B IOMUX_PAD(0x804, 0x3d8, 2, __NA_, 0, NO_PAD_CTRL) | 799 | #define MX51_PAD_GPIO1_4__WDOG1_WDOG_B IOMUX_PAD(0x804, 0x3d8, 2, __NA_, 0, NO_PAD_CTRL) |
800 | #define MX51_PAD_GPIO1_4__GPT_CAPIN1 IOMUX_PAD(0x804, 0x3d8, 6, __NA_, 0, NO_PAD_CTRL) | ||
791 | #define MX51_PAD_GPIO1_5__CSI2_MCLK IOMUX_PAD(0x808, 0x3dc, 6, __NA_, 0, NO_PAD_CTRL) | 801 | #define MX51_PAD_GPIO1_5__CSI2_MCLK IOMUX_PAD(0x808, 0x3dc, 6, __NA_, 0, NO_PAD_CTRL) |
792 | #define MX51_PAD_GPIO1_5__DISP2_PIN16 IOMUX_PAD(0x808, 0x3dc, 3, __NA_, 0, NO_PAD_CTRL) | 802 | #define MX51_PAD_GPIO1_5__DISP2_PIN16 IOMUX_PAD(0x808, 0x3dc, 3, __NA_, 0, NO_PAD_CTRL) |
793 | #define MX51_PAD_GPIO1_5__GPIO1_5 IOMUX_PAD(0x808, 0x3dc, 0, __NA_, 0, MX51_GPIO_PAD_CTRL) | 803 | #define MX51_PAD_GPIO1_5__GPIO1_5 IOMUX_PAD(0x808, 0x3dc, 0, __NA_, 0, MX51_GPIO_PAD_CTRL) |
794 | #define MX51_PAD_GPIO1_5__WDOG2_WDOG_B IOMUX_PAD(0x808, 0x3dc, 2, __NA_, 0, NO_PAD_CTRL) | 804 | #define MX51_PAD_GPIO1_5__WDOG2_WDOG_B IOMUX_PAD(0x808, 0x3dc, 2, __NA_, 0, NO_PAD_CTRL) |
805 | #define MX51_PAD_GPIO1_5__CCM_CLKO IOMUX_PAD(0x808, 0x3dc, 5, __NA_, 0, NO_PAD_CTRL) | ||
795 | #define MX51_PAD_GPIO1_6__DISP2_PIN17 IOMUX_PAD(0x80c, 0x3e0, 4, __NA_, 0, NO_PAD_CTRL) | 806 | #define MX51_PAD_GPIO1_6__DISP2_PIN17 IOMUX_PAD(0x80c, 0x3e0, 4, __NA_, 0, NO_PAD_CTRL) |
796 | #define MX51_PAD_GPIO1_6__GPIO1_6 IOMUX_PAD(0x80c, 0x3e0, 0, __NA_, 0, MX51_GPIO_PAD_CTRL) | 807 | #define MX51_PAD_GPIO1_6__GPIO1_6 IOMUX_PAD(0x80c, 0x3e0, 0, __NA_, 0, MX51_GPIO_PAD_CTRL) |
797 | #define MX51_PAD_GPIO1_6__REF_EN_B IOMUX_PAD(0x80c, 0x3e0, 3, __NA_, 0, NO_PAD_CTRL) | 808 | #define MX51_PAD_GPIO1_6__REF_EN_B IOMUX_PAD(0x80c, 0x3e0, 3, __NA_, 0, NO_PAD_CTRL) |
809 | #define MX51_PAD_GPIO1_6__GPT_CAPIN2 IOMUX_PAD(0x80c, 0x3e0, 6, __NA_, 0, NO_PAD_CTRL) | ||
798 | #define MX51_PAD_GPIO1_7__CCM_OUT_0 IOMUX_PAD(0x810, 0x3e4, 3, __NA_, 0, NO_PAD_CTRL) | 810 | #define MX51_PAD_GPIO1_7__CCM_OUT_0 IOMUX_PAD(0x810, 0x3e4, 3, __NA_, 0, NO_PAD_CTRL) |
799 | #define MX51_PAD_GPIO1_7__GPIO1_7 IOMUX_PAD(0x810, 0x3e4, 0, __NA_, 0, MX51_GPIO_PAD_CTRL) | 811 | #define MX51_PAD_GPIO1_7__GPIO1_7 IOMUX_PAD(0x810, 0x3e4, 0, __NA_, 0, MX51_GPIO_PAD_CTRL) |
800 | #define MX51_PAD_GPIO1_7__SD2_WP IOMUX_PAD(0x810, 0x3e4, 6, __NA_, 0, MX51_ESDHC_PAD_CTRL) | 812 | #define MX51_PAD_GPIO1_7__SD2_WP IOMUX_PAD(0x810, 0x3e4, 6, __NA_, 0, MX51_ESDHC_PAD_CTRL) |
@@ -803,11 +815,13 @@ | |||
803 | #define MX51_PAD_GPIO1_8__GPIO1_8 IOMUX_PAD(0x814, 0x3e8, 0, __NA_, 0, MX51_GPIO_PAD_CTRL) | 815 | #define MX51_PAD_GPIO1_8__GPIO1_8 IOMUX_PAD(0x814, 0x3e8, 0, __NA_, 0, MX51_GPIO_PAD_CTRL) |
804 | #define MX51_PAD_GPIO1_8__SD2_CD IOMUX_PAD(0x814, 0x3e8, 6, __NA_, 0, MX51_ESDHC_PAD_CTRL) | 816 | #define MX51_PAD_GPIO1_8__SD2_CD IOMUX_PAD(0x814, 0x3e8, 6, __NA_, 0, MX51_ESDHC_PAD_CTRL) |
805 | #define MX51_PAD_GPIO1_8__USBH3_PWR IOMUX_PAD(0x814, 0x3e8, 1, __NA_, 0, NO_PAD_CTRL) | 817 | #define MX51_PAD_GPIO1_8__USBH3_PWR IOMUX_PAD(0x814, 0x3e8, 1, __NA_, 0, NO_PAD_CTRL) |
818 | #define MX51_PAD_GPIO1_8__CCM_CLKO2 IOMUX_PAD(0x814, 0x3e8, 4, __NA_, 0, NO_PAD_CTRL) | ||
806 | #define MX51_PAD_GPIO1_9__CCM_OUT_1 IOMUX_PAD(0x818, 0x3ec, 3, __NA_, 0, NO_PAD_CTRL) | 819 | #define MX51_PAD_GPIO1_9__CCM_OUT_1 IOMUX_PAD(0x818, 0x3ec, 3, __NA_, 0, NO_PAD_CTRL) |
807 | #define MX51_PAD_GPIO1_9__DISP2_D1_CS IOMUX_PAD(0x818, 0x3ec, 2, __NA_, 0, NO_PAD_CTRL) | 820 | #define MX51_PAD_GPIO1_9__DISP2_D1_CS IOMUX_PAD(0x818, 0x3ec, 2, __NA_, 0, NO_PAD_CTRL) |
808 | #define MX51_PAD_GPIO1_9__DISP2_SER_CS IOMUX_PAD(0x818, 0x3ec, 7, __NA_, 0, NO_PAD_CTRL) | 821 | #define MX51_PAD_GPIO1_9__DISP2_SER_CS IOMUX_PAD(0x818, 0x3ec, 7, __NA_, 0, NO_PAD_CTRL) |
809 | #define MX51_PAD_GPIO1_9__GPIO1_9 IOMUX_PAD(0x818, 0x3ec, 0, __NA_, 0, MX51_GPIO_PAD_CTRL) | 822 | #define MX51_PAD_GPIO1_9__GPIO1_9 IOMUX_PAD(0x818, 0x3ec, 0, __NA_, 0, MX51_GPIO_PAD_CTRL) |
810 | #define MX51_PAD_GPIO1_9__SD2_LCTL IOMUX_PAD(0x818, 0x3ec, 6, __NA_, 0, NO_PAD_CTRL) | 823 | #define MX51_PAD_GPIO1_9__SD2_LCTL IOMUX_PAD(0x818, 0x3ec, 6, __NA_, 0, NO_PAD_CTRL) |
811 | #define MX51_PAD_GPIO1_9__USBH3_OC IOMUX_PAD(0x818, 0x3ec, 1, __NA_, 0, NO_PAD_CTRL) | 824 | #define MX51_PAD_GPIO1_9__USBH3_OC IOMUX_PAD(0x818, 0x3ec, 1, __NA_, 0, NO_PAD_CTRL) |
825 | #define MX51_PAD_GPIO1_9__CCM_CLKO IOMUX_PAD(0x818, 0x3ec, 4, __NA_, 0, NO_PAD_CTRL) | ||
812 | 826 | ||
813 | #endif /* __MACH_IOMUX_MX51_H__ */ | 827 | #endif /* __MACH_IOMUX_MX51_H__ */ |
diff --git a/arch/arm/plat-mxc/include/mach/mxc_ehci.h b/arch/arm/plat-mxc/include/mach/mxc_ehci.h index 9ffd1bbe615f..7eb9d1329671 100644 --- a/arch/arm/plat-mxc/include/mach/mxc_ehci.h +++ b/arch/arm/plat-mxc/include/mach/mxc_ehci.h | |||
@@ -20,13 +20,15 @@ | |||
20 | #define MXC_EHCI_INTERFACE_MASK (0xf) | 20 | #define MXC_EHCI_INTERFACE_MASK (0xf) |
21 | 21 | ||
22 | #define MXC_EHCI_POWER_PINS_ENABLED (1 << 5) | 22 | #define MXC_EHCI_POWER_PINS_ENABLED (1 << 5) |
23 | #define MXC_EHCI_TTL_ENABLED (1 << 6) | 23 | #define MXC_EHCI_PWR_PIN_ACTIVE_HIGH (1 << 6) |
24 | 24 | #define MXC_EHCI_OC_PIN_ACTIVE_LOW (1 << 7) | |
25 | #define MXC_EHCI_INTERNAL_PHY (1 << 7) | 25 | #define MXC_EHCI_TTL_ENABLED (1 << 8) |
26 | #define MXC_EHCI_IPPUE_DOWN (1 << 8) | 26 | |
27 | #define MXC_EHCI_IPPUE_UP (1 << 9) | 27 | #define MXC_EHCI_INTERNAL_PHY (1 << 9) |
28 | #define MXC_EHCI_WAKEUP_ENABLED (1 << 10) | 28 | #define MXC_EHCI_IPPUE_DOWN (1 << 10) |
29 | #define MXC_EHCI_ITC_NO_THRESHOLD (1 << 11) | 29 | #define MXC_EHCI_IPPUE_UP (1 << 11) |
30 | #define MXC_EHCI_WAKEUP_ENABLED (1 << 12) | ||
31 | #define MXC_EHCI_ITC_NO_THRESHOLD (1 << 13) | ||
30 | 32 | ||
31 | #define MXC_USBCTRL_OFFSET 0 | 33 | #define MXC_USBCTRL_OFFSET 0 |
32 | #define MXC_USB_PHY_CTR_FUNC_OFFSET 0x8 | 34 | #define MXC_USB_PHY_CTR_FUNC_OFFSET 0x8 |
diff --git a/arch/arm/plat-omap/include/plat/serial.h b/arch/arm/plat-omap/include/plat/serial.h index b073e5f2b190..28e2d250c2fd 100644 --- a/arch/arm/plat-omap/include/plat/serial.h +++ b/arch/arm/plat-omap/include/plat/serial.h | |||
@@ -60,6 +60,9 @@ | |||
60 | /* AM3505/3517 UART4 */ | 60 | /* AM3505/3517 UART4 */ |
61 | #define AM35XX_UART4_BASE 0x4809E000 /* Only on AM3505/3517 */ | 61 | #define AM35XX_UART4_BASE 0x4809E000 /* Only on AM3505/3517 */ |
62 | 62 | ||
63 | /* AM33XX serial port */ | ||
64 | #define AM33XX_UART1_BASE 0x44E09000 | ||
65 | |||
63 | /* External port on Zoom2/3 */ | 66 | /* External port on Zoom2/3 */ |
64 | #define ZOOM_UART_BASE 0x10000000 | 67 | #define ZOOM_UART_BASE 0x10000000 |
65 | #define ZOOM_UART_VIRT 0xfa400000 | 68 | #define ZOOM_UART_VIRT 0xfa400000 |
@@ -93,6 +96,7 @@ | |||
93 | #define TI81XXUART1 81 | 96 | #define TI81XXUART1 81 |
94 | #define TI81XXUART2 82 | 97 | #define TI81XXUART2 82 |
95 | #define TI81XXUART3 83 | 98 | #define TI81XXUART3 83 |
99 | #define AM33XXUART1 84 | ||
96 | #define ZOOM_UART 95 /* Only on zoom2/3 */ | 100 | #define ZOOM_UART 95 /* Only on zoom2/3 */ |
97 | 101 | ||
98 | /* This is only used by 8250.c for omap1510 */ | 102 | /* This is only used by 8250.c for omap1510 */ |
diff --git a/arch/arm/plat-omap/include/plat/uncompress.h b/arch/arm/plat-omap/include/plat/uncompress.h index cc3f11ba7a99..ac4323390213 100644 --- a/arch/arm/plat-omap/include/plat/uncompress.h +++ b/arch/arm/plat-omap/include/plat/uncompress.h | |||
@@ -103,6 +103,10 @@ static inline void flush(void) | |||
103 | _DEBUG_LL_ENTRY(mach, TI81XX_UART##p##_BASE, OMAP_PORT_SHIFT, \ | 103 | _DEBUG_LL_ENTRY(mach, TI81XX_UART##p##_BASE, OMAP_PORT_SHIFT, \ |
104 | TI81XXUART##p) | 104 | TI81XXUART##p) |
105 | 105 | ||
106 | #define DEBUG_LL_AM33XX(p, mach) \ | ||
107 | _DEBUG_LL_ENTRY(mach, AM33XX_UART##p##_BASE, OMAP_PORT_SHIFT, \ | ||
108 | AM33XXUART##p) | ||
109 | |||
106 | static inline void __arch_decomp_setup(unsigned long arch_id) | 110 | static inline void __arch_decomp_setup(unsigned long arch_id) |
107 | { | 111 | { |
108 | int port = 0; | 112 | int port = 0; |
@@ -183,6 +187,8 @@ static inline void __arch_decomp_setup(unsigned long arch_id) | |||
183 | /* TI8148 base boards using UART1 */ | 187 | /* TI8148 base boards using UART1 */ |
184 | DEBUG_LL_TI81XX(1, ti8148evm); | 188 | DEBUG_LL_TI81XX(1, ti8148evm); |
185 | 189 | ||
190 | /* AM33XX base boards using UART1 */ | ||
191 | DEBUG_LL_AM33XX(1, am335xevm); | ||
186 | } while (0); | 192 | } while (0); |
187 | } | 193 | } |
188 | 194 | ||
diff --git a/arch/arm/plat-samsung/Kconfig b/arch/arm/plat-samsung/Kconfig index ffc84acb7e97..7aca31c1df1f 100644 --- a/arch/arm/plat-samsung/Kconfig +++ b/arch/arm/plat-samsung/Kconfig | |||
@@ -78,6 +78,10 @@ config S5P_HRT | |||
78 | 78 | ||
79 | # clock options | 79 | # clock options |
80 | 80 | ||
81 | config SAMSUNG_CLOCK | ||
82 | bool | ||
83 | default y if !COMMON_CLK | ||
84 | |||
81 | config SAMSUNG_CLKSRC | 85 | config SAMSUNG_CLKSRC |
82 | bool | 86 | bool |
83 | help | 87 | help |
diff --git a/arch/arm/plat-samsung/Makefile b/arch/arm/plat-samsung/Makefile index 4bb58c2dc704..b78717496677 100644 --- a/arch/arm/plat-samsung/Makefile +++ b/arch/arm/plat-samsung/Makefile | |||
@@ -15,8 +15,8 @@ obj-y += init.o cpu.o | |||
15 | obj-$(CONFIG_ARCH_USES_GETTIMEOFFSET) += time.o | 15 | obj-$(CONFIG_ARCH_USES_GETTIMEOFFSET) += time.o |
16 | obj-$(CONFIG_S5P_HRT) += s5p-time.o | 16 | obj-$(CONFIG_S5P_HRT) += s5p-time.o |
17 | 17 | ||
18 | obj-y += clock.o | 18 | obj-$(CONFIG_SAMSUNG_CLOCK) += clock.o |
19 | obj-y += pwm-clock.o | 19 | obj-$(CONFIG_SAMSUNG_CLOCK) += pwm-clock.o |
20 | 20 | ||
21 | obj-$(CONFIG_SAMSUNG_CLKSRC) += clock-clksrc.o | 21 | obj-$(CONFIG_SAMSUNG_CLKSRC) += clock-clksrc.o |
22 | obj-$(CONFIG_S5P_CLOCK) += s5p-clock.o | 22 | obj-$(CONFIG_S5P_CLOCK) += s5p-clock.o |
diff --git a/arch/arm/plat-samsung/include/plat/cpu.h b/arch/arm/plat-samsung/include/plat/cpu.h index 0721293fad63..ace4451b7651 100644 --- a/arch/arm/plat-samsung/include/plat/cpu.h +++ b/arch/arm/plat-samsung/include/plat/cpu.h | |||
@@ -132,6 +132,10 @@ IS_SAMSUNG_CPU(exynos5250, EXYNOS5250_SOC_ID, EXYNOS5_SOC_MASK) | |||
132 | 132 | ||
133 | #define IODESC_ENT(x) { (unsigned long)S3C24XX_VA_##x, __phys_to_pfn(S3C24XX_PA_##x), S3C24XX_SZ_##x, MT_DEVICE } | 133 | #define IODESC_ENT(x) { (unsigned long)S3C24XX_VA_##x, __phys_to_pfn(S3C24XX_PA_##x), S3C24XX_SZ_##x, MT_DEVICE } |
134 | 134 | ||
135 | #ifndef KHZ | ||
136 | #define KHZ (1000) | ||
137 | #endif | ||
138 | |||
135 | #ifndef MHZ | 139 | #ifndef MHZ |
136 | #define MHZ (1000*1000) | 140 | #define MHZ (1000*1000) |
137 | #endif | 141 | #endif |
diff --git a/arch/arm/plat-versatile/Kconfig b/arch/arm/plat-versatile/Kconfig index 81ee7cc34457..8d5c10a5084d 100644 --- a/arch/arm/plat-versatile/Kconfig +++ b/arch/arm/plat-versatile/Kconfig | |||
@@ -1,5 +1,8 @@ | |||
1 | if PLAT_VERSATILE | 1 | if PLAT_VERSATILE |
2 | 2 | ||
3 | config PLAT_VERSATILE_CLOCK | ||
4 | bool | ||
5 | |||
3 | config PLAT_VERSATILE_CLCD | 6 | config PLAT_VERSATILE_CLCD |
4 | bool | 7 | bool |
5 | 8 | ||
diff --git a/arch/arm/plat-versatile/Makefile b/arch/arm/plat-versatile/Makefile index a5cb1945bdcc..272769a8a7d6 100644 --- a/arch/arm/plat-versatile/Makefile +++ b/arch/arm/plat-versatile/Makefile | |||
@@ -1,4 +1,4 @@ | |||
1 | obj-y := clock.o | 1 | obj-$(CONFIG_PLAT_VERSATILE_CLOCK) += clock.o |
2 | obj-$(CONFIG_PLAT_VERSATILE_CLCD) += clcd.o | 2 | obj-$(CONFIG_PLAT_VERSATILE_CLCD) += clcd.o |
3 | obj-$(CONFIG_PLAT_VERSATILE_FPGA_IRQ) += fpga-irq.o | 3 | obj-$(CONFIG_PLAT_VERSATILE_FPGA_IRQ) += fpga-irq.o |
4 | obj-$(CONFIG_PLAT_VERSATILE_LEDS) += leds.o | 4 | obj-$(CONFIG_PLAT_VERSATILE_LEDS) += leds.o |