diff options
Diffstat (limited to 'arch/arm')
171 files changed, 3143 insertions, 7797 deletions
diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig index 62079d434581..1e31dac36a5f 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig | |||
@@ -689,12 +689,15 @@ config ARCH_SA1100 | |||
689 | config ARCH_S3C24XX | 689 | config ARCH_S3C24XX |
690 | bool "Samsung S3C24XX SoCs" | 690 | bool "Samsung S3C24XX SoCs" |
691 | select ARCH_HAS_CPUFREQ | 691 | select ARCH_HAS_CPUFREQ |
692 | select ARCH_USES_GETTIMEOFFSET | 692 | select ARCH_REQUIRE_GPIOLIB |
693 | select CLKDEV_LOOKUP | 693 | select CLKDEV_LOOKUP |
694 | select CLKSRC_MMIO | ||
695 | select GENERIC_CLOCKEVENTS | ||
694 | select HAVE_CLK | 696 | select HAVE_CLK |
695 | select HAVE_S3C2410_I2C if I2C | 697 | select HAVE_S3C2410_I2C if I2C |
696 | select HAVE_S3C2410_WATCHDOG if WATCHDOG | 698 | select HAVE_S3C2410_WATCHDOG if WATCHDOG |
697 | select HAVE_S3C_RTC if RTC_CLASS | 699 | select HAVE_S3C_RTC if RTC_CLASS |
700 | select MULTI_IRQ_HANDLER | ||
698 | select NEED_MACH_GPIO_H | 701 | select NEED_MACH_GPIO_H |
699 | select NEED_MACH_IO_H | 702 | select NEED_MACH_IO_H |
700 | help | 703 | help |
@@ -707,10 +710,11 @@ config ARCH_S3C64XX | |||
707 | bool "Samsung S3C64XX" | 710 | bool "Samsung S3C64XX" |
708 | select ARCH_HAS_CPUFREQ | 711 | select ARCH_HAS_CPUFREQ |
709 | select ARCH_REQUIRE_GPIOLIB | 712 | select ARCH_REQUIRE_GPIOLIB |
710 | select ARCH_USES_GETTIMEOFFSET | ||
711 | select ARM_VIC | 713 | select ARM_VIC |
712 | select CLKDEV_LOOKUP | 714 | select CLKDEV_LOOKUP |
715 | select CLKSRC_MMIO | ||
713 | select CPU_V6 | 716 | select CPU_V6 |
717 | select GENERIC_CLOCKEVENTS | ||
714 | select HAVE_CLK | 718 | select HAVE_CLK |
715 | select HAVE_S3C2410_I2C if I2C | 719 | select HAVE_S3C2410_I2C if I2C |
716 | select HAVE_S3C2410_WATCHDOG if WATCHDOG | 720 | select HAVE_S3C2410_WATCHDOG if WATCHDOG |
@@ -744,9 +748,11 @@ config ARCH_S5P64X0 | |||
744 | 748 | ||
745 | config ARCH_S5PC100 | 749 | config ARCH_S5PC100 |
746 | bool "Samsung S5PC100" | 750 | bool "Samsung S5PC100" |
747 | select ARCH_USES_GETTIMEOFFSET | 751 | select ARCH_REQUIRE_GPIOLIB |
748 | select CLKDEV_LOOKUP | 752 | select CLKDEV_LOOKUP |
753 | select CLKSRC_MMIO | ||
749 | select CPU_V7 | 754 | select CPU_V7 |
755 | select GENERIC_CLOCKEVENTS | ||
750 | select HAVE_CLK | 756 | select HAVE_CLK |
751 | select HAVE_S3C2410_I2C if I2C | 757 | select HAVE_S3C2410_I2C if I2C |
752 | select HAVE_S3C2410_WATCHDOG if WATCHDOG | 758 | select HAVE_S3C2410_WATCHDOG if WATCHDOG |
@@ -779,6 +785,7 @@ config ARCH_EXYNOS | |||
779 | select ARCH_HAS_HOLES_MEMORYMODEL | 785 | select ARCH_HAS_HOLES_MEMORYMODEL |
780 | select ARCH_SPARSEMEM_ENABLE | 786 | select ARCH_SPARSEMEM_ENABLE |
781 | select CLKDEV_LOOKUP | 787 | select CLKDEV_LOOKUP |
788 | select COMMON_CLK | ||
782 | select CPU_V7 | 789 | select CPU_V7 |
783 | select GENERIC_CLOCKEVENTS | 790 | select GENERIC_CLOCKEVENTS |
784 | select HAVE_CLK | 791 | select HAVE_CLK |
@@ -1552,7 +1559,8 @@ config ARCH_NR_GPIO | |||
1552 | default 1024 if ARCH_SHMOBILE || ARCH_TEGRA | 1559 | default 1024 if ARCH_SHMOBILE || ARCH_TEGRA |
1553 | default 512 if SOC_OMAP5 | 1560 | default 512 if SOC_OMAP5 |
1554 | default 392 if ARCH_U8500 | 1561 | default 392 if ARCH_U8500 |
1555 | default 288 if ARCH_VT8500 || ARCH_SUNXI | 1562 | default 352 if ARCH_VT8500 |
1563 | default 288 if ARCH_SUNXI | ||
1556 | default 264 if MACH_H4700 | 1564 | default 264 if MACH_H4700 |
1557 | default 0 | 1565 | default 0 |
1558 | help | 1566 | help |
diff --git a/arch/arm/boot/dts/Makefile b/arch/arm/boot/dts/Makefile index 20358fb43450..55196639211d 100644 --- a/arch/arm/boot/dts/Makefile +++ b/arch/arm/boot/dts/Makefile | |||
@@ -49,7 +49,10 @@ dtb-$(CONFIG_ARCH_DOVE) += dove-cm-a510.dtb \ | |||
49 | dtb-$(CONFIG_ARCH_EXYNOS) += exynos4210-origen.dtb \ | 49 | dtb-$(CONFIG_ARCH_EXYNOS) += exynos4210-origen.dtb \ |
50 | exynos4210-smdkv310.dtb \ | 50 | exynos4210-smdkv310.dtb \ |
51 | exynos4210-trats.dtb \ | 51 | exynos4210-trats.dtb \ |
52 | exynos4412-odroidx.dtb \ | ||
52 | exynos4412-smdk4412.dtb \ | 53 | exynos4412-smdk4412.dtb \ |
54 | exynos4412-origen.dtb \ | ||
55 | exynos5250-arndale.dtb \ | ||
53 | exynos5250-smdk5250.dtb \ | 56 | exynos5250-smdk5250.dtb \ |
54 | exynos5250-snow.dtb \ | 57 | exynos5250-snow.dtb \ |
55 | exynos5440-ssdk5440.dtb | 58 | exynos5440-ssdk5440.dtb |
diff --git a/arch/arm/boot/dts/cros5250-common.dtsi b/arch/arm/boot/dts/cros5250-common.dtsi index 46c098017036..62eceb4f0d3f 100644 --- a/arch/arm/boot/dts/cros5250-common.dtsi +++ b/arch/arm/boot/dts/cros5250-common.dtsi | |||
@@ -24,6 +24,144 @@ | |||
24 | samsung,i2c-max-bus-freq = <378000>; | 24 | samsung,i2c-max-bus-freq = <378000>; |
25 | gpios = <&gpb3 0 2 3 0>, | 25 | gpios = <&gpb3 0 2 3 0>, |
26 | <&gpb3 1 2 3 0>; | 26 | <&gpb3 1 2 3 0>; |
27 | |||
28 | max77686@09 { | ||
29 | compatible = "maxim,max77686"; | ||
30 | reg = <0x09>; | ||
31 | |||
32 | voltage-regulators { | ||
33 | ldo1_reg: LDO1 { | ||
34 | regulator-name = "P1.0V_LDO_OUT1"; | ||
35 | regulator-min-microvolt = <1000000>; | ||
36 | regulator-max-microvolt = <1000000>; | ||
37 | regulator-always-on; | ||
38 | }; | ||
39 | |||
40 | ldo2_reg: LDO2 { | ||
41 | regulator-name = "P1.8V_LDO_OUT2"; | ||
42 | regulator-min-microvolt = <1800000>; | ||
43 | regulator-max-microvolt = <1800000>; | ||
44 | regulator-always-on; | ||
45 | }; | ||
46 | |||
47 | ldo3_reg: LDO3 { | ||
48 | regulator-name = "P1.8V_LDO_OUT3"; | ||
49 | regulator-min-microvolt = <1800000>; | ||
50 | regulator-max-microvolt = <1800000>; | ||
51 | regulator-always-on; | ||
52 | }; | ||
53 | |||
54 | ldo7_reg: LDO7 { | ||
55 | regulator-name = "P1.1V_LDO_OUT7"; | ||
56 | regulator-min-microvolt = <1100000>; | ||
57 | regulator-max-microvolt = <1100000>; | ||
58 | regulator-always-on; | ||
59 | }; | ||
60 | |||
61 | ldo8_reg: LDO8 { | ||
62 | regulator-name = "P1.0V_LDO_OUT8"; | ||
63 | regulator-min-microvolt = <1000000>; | ||
64 | regulator-max-microvolt = <1000000>; | ||
65 | regulator-always-on; | ||
66 | }; | ||
67 | |||
68 | ldo10_reg: LDO10 { | ||
69 | regulator-name = "P1.8V_LDO_OUT10"; | ||
70 | regulator-min-microvolt = <1800000>; | ||
71 | regulator-max-microvolt = <1800000>; | ||
72 | regulator-always-on; | ||
73 | }; | ||
74 | |||
75 | ldo12_reg: LDO12 { | ||
76 | regulator-name = "P3.0V_LDO_OUT12"; | ||
77 | regulator-min-microvolt = <3000000>; | ||
78 | regulator-max-microvolt = <3000000>; | ||
79 | regulator-always-on; | ||
80 | }; | ||
81 | |||
82 | ldo14_reg: LDO14 { | ||
83 | regulator-name = "P1.8V_LDO_OUT14"; | ||
84 | regulator-min-microvolt = <1800000>; | ||
85 | regulator-max-microvolt = <1800000>; | ||
86 | regulator-always-on; | ||
87 | }; | ||
88 | |||
89 | ldo15_reg: LDO15 { | ||
90 | regulator-name = "P1.0V_LDO_OUT15"; | ||
91 | regulator-min-microvolt = <1000000>; | ||
92 | regulator-max-microvolt = <1000000>; | ||
93 | regulator-always-on; | ||
94 | }; | ||
95 | |||
96 | ldo16_reg: LDO16 { | ||
97 | regulator-name = "P1.8V_LDO_OUT16"; | ||
98 | regulator-min-microvolt = <1800000>; | ||
99 | regulator-max-microvolt = <1800000>; | ||
100 | regulator-always-on; | ||
101 | }; | ||
102 | |||
103 | buck1_reg: BUCK1 { | ||
104 | regulator-name = "vdd_mif"; | ||
105 | regulator-min-microvolt = <950000>; | ||
106 | regulator-max-microvolt = <1300000>; | ||
107 | regulator-always-on; | ||
108 | regulator-boot-on; | ||
109 | }; | ||
110 | |||
111 | buck2_reg: BUCK2 { | ||
112 | regulator-name = "vdd_arm"; | ||
113 | regulator-min-microvolt = <850000>; | ||
114 | regulator-max-microvolt = <1350000>; | ||
115 | regulator-always-on; | ||
116 | regulator-boot-on; | ||
117 | }; | ||
118 | |||
119 | buck3_reg: BUCK3 { | ||
120 | regulator-name = "vdd_int"; | ||
121 | regulator-min-microvolt = <900000>; | ||
122 | regulator-max-microvolt = <1200000>; | ||
123 | regulator-always-on; | ||
124 | regulator-boot-on; | ||
125 | }; | ||
126 | |||
127 | buck4_reg: BUCK4 { | ||
128 | regulator-name = "vdd_g3d"; | ||
129 | regulator-min-microvolt = <850000>; | ||
130 | regulator-max-microvolt = <1300000>; | ||
131 | regulator-always-on; | ||
132 | regulator-boot-on; | ||
133 | }; | ||
134 | |||
135 | buck5_reg: BUCK5 { | ||
136 | regulator-name = "P1.8V_BUCK_OUT5"; | ||
137 | regulator-min-microvolt = <1800000>; | ||
138 | regulator-max-microvolt = <1800000>; | ||
139 | regulator-always-on; | ||
140 | regulator-boot-on; | ||
141 | }; | ||
142 | |||
143 | buck6_reg: BUCK6 { | ||
144 | regulator-name = "P1.35V_BUCK_OUT6"; | ||
145 | regulator-min-microvolt = <1350000>; | ||
146 | regulator-max-microvolt = <1350000>; | ||
147 | regulator-always-on; | ||
148 | }; | ||
149 | |||
150 | buck7_reg: BUCK7 { | ||
151 | regulator-name = "P2.0V_BUCK_OUT7"; | ||
152 | regulator-min-microvolt = <2000000>; | ||
153 | regulator-max-microvolt = <2000000>; | ||
154 | regulator-always-on; | ||
155 | }; | ||
156 | |||
157 | buck8_reg: BUCK8 { | ||
158 | regulator-name = "P2.85V_BUCK_OUT8"; | ||
159 | regulator-min-microvolt = <2850000>; | ||
160 | regulator-max-microvolt = <2850000>; | ||
161 | regulator-always-on; | ||
162 | }; | ||
163 | }; | ||
164 | }; | ||
27 | }; | 165 | }; |
28 | 166 | ||
29 | i2c@12C70000 { | 167 | i2c@12C70000 { |
diff --git a/arch/arm/boot/dts/exynos4.dtsi b/arch/arm/boot/dts/exynos4.dtsi index 1a62bcf18aa3..9ac47d51c407 100644 --- a/arch/arm/boot/dts/exynos4.dtsi +++ b/arch/arm/boot/dts/exynos4.dtsi | |||
@@ -86,6 +86,8 @@ | |||
86 | compatible = "samsung,s3c2410-wdt"; | 86 | compatible = "samsung,s3c2410-wdt"; |
87 | reg = <0x10060000 0x100>; | 87 | reg = <0x10060000 0x100>; |
88 | interrupts = <0 43 0>; | 88 | interrupts = <0 43 0>; |
89 | clocks = <&clock 345>; | ||
90 | clock-names = "watchdog"; | ||
89 | status = "disabled"; | 91 | status = "disabled"; |
90 | }; | 92 | }; |
91 | 93 | ||
@@ -93,6 +95,8 @@ | |||
93 | compatible = "samsung,s3c6410-rtc"; | 95 | compatible = "samsung,s3c6410-rtc"; |
94 | reg = <0x10070000 0x100>; | 96 | reg = <0x10070000 0x100>; |
95 | interrupts = <0 44 0>, <0 45 0>; | 97 | interrupts = <0 44 0>, <0 45 0>; |
98 | clocks = <&clock 346>; | ||
99 | clock-names = "rtc"; | ||
96 | status = "disabled"; | 100 | status = "disabled"; |
97 | }; | 101 | }; |
98 | 102 | ||
@@ -100,6 +104,8 @@ | |||
100 | compatible = "samsung,s5pv210-keypad"; | 104 | compatible = "samsung,s5pv210-keypad"; |
101 | reg = <0x100A0000 0x100>; | 105 | reg = <0x100A0000 0x100>; |
102 | interrupts = <0 109 0>; | 106 | interrupts = <0 109 0>; |
107 | clocks = <&clock 347>; | ||
108 | clock-names = "keypad"; | ||
103 | status = "disabled"; | 109 | status = "disabled"; |
104 | }; | 110 | }; |
105 | 111 | ||
@@ -107,6 +113,8 @@ | |||
107 | compatible = "samsung,exynos4210-sdhci"; | 113 | compatible = "samsung,exynos4210-sdhci"; |
108 | reg = <0x12510000 0x100>; | 114 | reg = <0x12510000 0x100>; |
109 | interrupts = <0 73 0>; | 115 | interrupts = <0 73 0>; |
116 | clocks = <&clock 297>, <&clock 145>; | ||
117 | clock-names = "hsmmc", "mmc_busclk.2"; | ||
110 | status = "disabled"; | 118 | status = "disabled"; |
111 | }; | 119 | }; |
112 | 120 | ||
@@ -114,6 +122,8 @@ | |||
114 | compatible = "samsung,exynos4210-sdhci"; | 122 | compatible = "samsung,exynos4210-sdhci"; |
115 | reg = <0x12520000 0x100>; | 123 | reg = <0x12520000 0x100>; |
116 | interrupts = <0 74 0>; | 124 | interrupts = <0 74 0>; |
125 | clocks = <&clock 298>, <&clock 146>; | ||
126 | clock-names = "hsmmc", "mmc_busclk.2"; | ||
117 | status = "disabled"; | 127 | status = "disabled"; |
118 | }; | 128 | }; |
119 | 129 | ||
@@ -121,6 +131,8 @@ | |||
121 | compatible = "samsung,exynos4210-sdhci"; | 131 | compatible = "samsung,exynos4210-sdhci"; |
122 | reg = <0x12530000 0x100>; | 132 | reg = <0x12530000 0x100>; |
123 | interrupts = <0 75 0>; | 133 | interrupts = <0 75 0>; |
134 | clocks = <&clock 299>, <&clock 147>; | ||
135 | clock-names = "hsmmc", "mmc_busclk.2"; | ||
124 | status = "disabled"; | 136 | status = "disabled"; |
125 | }; | 137 | }; |
126 | 138 | ||
@@ -128,6 +140,16 @@ | |||
128 | compatible = "samsung,exynos4210-sdhci"; | 140 | compatible = "samsung,exynos4210-sdhci"; |
129 | reg = <0x12540000 0x100>; | 141 | reg = <0x12540000 0x100>; |
130 | interrupts = <0 76 0>; | 142 | interrupts = <0 76 0>; |
143 | clocks = <&clock 300>, <&clock 148>; | ||
144 | clock-names = "hsmmc", "mmc_busclk.2"; | ||
145 | status = "disabled"; | ||
146 | }; | ||
147 | |||
148 | mfc: codec@13400000 { | ||
149 | compatible = "samsung,mfc-v5"; | ||
150 | reg = <0x13400000 0x10000>; | ||
151 | interrupts = <0 94 0>; | ||
152 | samsung,power-domain = <&pd_mfc>; | ||
131 | status = "disabled"; | 153 | status = "disabled"; |
132 | }; | 154 | }; |
133 | 155 | ||
@@ -135,6 +157,8 @@ | |||
135 | compatible = "samsung,exynos4210-uart"; | 157 | compatible = "samsung,exynos4210-uart"; |
136 | reg = <0x13800000 0x100>; | 158 | reg = <0x13800000 0x100>; |
137 | interrupts = <0 52 0>; | 159 | interrupts = <0 52 0>; |
160 | clocks = <&clock 312>, <&clock 151>; | ||
161 | clock-names = "uart", "clk_uart_baud0"; | ||
138 | status = "disabled"; | 162 | status = "disabled"; |
139 | }; | 163 | }; |
140 | 164 | ||
@@ -142,6 +166,8 @@ | |||
142 | compatible = "samsung,exynos4210-uart"; | 166 | compatible = "samsung,exynos4210-uart"; |
143 | reg = <0x13810000 0x100>; | 167 | reg = <0x13810000 0x100>; |
144 | interrupts = <0 53 0>; | 168 | interrupts = <0 53 0>; |
169 | clocks = <&clock 313>, <&clock 152>; | ||
170 | clock-names = "uart", "clk_uart_baud0"; | ||
145 | status = "disabled"; | 171 | status = "disabled"; |
146 | }; | 172 | }; |
147 | 173 | ||
@@ -149,6 +175,8 @@ | |||
149 | compatible = "samsung,exynos4210-uart"; | 175 | compatible = "samsung,exynos4210-uart"; |
150 | reg = <0x13820000 0x100>; | 176 | reg = <0x13820000 0x100>; |
151 | interrupts = <0 54 0>; | 177 | interrupts = <0 54 0>; |
178 | clocks = <&clock 314>, <&clock 153>; | ||
179 | clock-names = "uart", "clk_uart_baud0"; | ||
152 | status = "disabled"; | 180 | status = "disabled"; |
153 | }; | 181 | }; |
154 | 182 | ||
@@ -156,6 +184,8 @@ | |||
156 | compatible = "samsung,exynos4210-uart"; | 184 | compatible = "samsung,exynos4210-uart"; |
157 | reg = <0x13830000 0x100>; | 185 | reg = <0x13830000 0x100>; |
158 | interrupts = <0 55 0>; | 186 | interrupts = <0 55 0>; |
187 | clocks = <&clock 315>, <&clock 154>; | ||
188 | clock-names = "uart", "clk_uart_baud0"; | ||
159 | status = "disabled"; | 189 | status = "disabled"; |
160 | }; | 190 | }; |
161 | 191 | ||
@@ -165,6 +195,8 @@ | |||
165 | compatible = "samsung,s3c2440-i2c"; | 195 | compatible = "samsung,s3c2440-i2c"; |
166 | reg = <0x13860000 0x100>; | 196 | reg = <0x13860000 0x100>; |
167 | interrupts = <0 58 0>; | 197 | interrupts = <0 58 0>; |
198 | clocks = <&clock 317>; | ||
199 | clock-names = "i2c"; | ||
168 | status = "disabled"; | 200 | status = "disabled"; |
169 | }; | 201 | }; |
170 | 202 | ||
@@ -174,6 +206,8 @@ | |||
174 | compatible = "samsung,s3c2440-i2c"; | 206 | compatible = "samsung,s3c2440-i2c"; |
175 | reg = <0x13870000 0x100>; | 207 | reg = <0x13870000 0x100>; |
176 | interrupts = <0 59 0>; | 208 | interrupts = <0 59 0>; |
209 | clocks = <&clock 318>; | ||
210 | clock-names = "i2c"; | ||
177 | status = "disabled"; | 211 | status = "disabled"; |
178 | }; | 212 | }; |
179 | 213 | ||
@@ -183,6 +217,8 @@ | |||
183 | compatible = "samsung,s3c2440-i2c"; | 217 | compatible = "samsung,s3c2440-i2c"; |
184 | reg = <0x13880000 0x100>; | 218 | reg = <0x13880000 0x100>; |
185 | interrupts = <0 60 0>; | 219 | interrupts = <0 60 0>; |
220 | clocks = <&clock 319>; | ||
221 | clock-names = "i2c"; | ||
186 | status = "disabled"; | 222 | status = "disabled"; |
187 | }; | 223 | }; |
188 | 224 | ||
@@ -192,6 +228,8 @@ | |||
192 | compatible = "samsung,s3c2440-i2c"; | 228 | compatible = "samsung,s3c2440-i2c"; |
193 | reg = <0x13890000 0x100>; | 229 | reg = <0x13890000 0x100>; |
194 | interrupts = <0 61 0>; | 230 | interrupts = <0 61 0>; |
231 | clocks = <&clock 320>; | ||
232 | clock-names = "i2c"; | ||
195 | status = "disabled"; | 233 | status = "disabled"; |
196 | }; | 234 | }; |
197 | 235 | ||
@@ -201,6 +239,8 @@ | |||
201 | compatible = "samsung,s3c2440-i2c"; | 239 | compatible = "samsung,s3c2440-i2c"; |
202 | reg = <0x138A0000 0x100>; | 240 | reg = <0x138A0000 0x100>; |
203 | interrupts = <0 62 0>; | 241 | interrupts = <0 62 0>; |
242 | clocks = <&clock 321>; | ||
243 | clock-names = "i2c"; | ||
204 | status = "disabled"; | 244 | status = "disabled"; |
205 | }; | 245 | }; |
206 | 246 | ||
@@ -210,6 +250,8 @@ | |||
210 | compatible = "samsung,s3c2440-i2c"; | 250 | compatible = "samsung,s3c2440-i2c"; |
211 | reg = <0x138B0000 0x100>; | 251 | reg = <0x138B0000 0x100>; |
212 | interrupts = <0 63 0>; | 252 | interrupts = <0 63 0>; |
253 | clocks = <&clock 322>; | ||
254 | clock-names = "i2c"; | ||
213 | status = "disabled"; | 255 | status = "disabled"; |
214 | }; | 256 | }; |
215 | 257 | ||
@@ -219,6 +261,8 @@ | |||
219 | compatible = "samsung,s3c2440-i2c"; | 261 | compatible = "samsung,s3c2440-i2c"; |
220 | reg = <0x138C0000 0x100>; | 262 | reg = <0x138C0000 0x100>; |
221 | interrupts = <0 64 0>; | 263 | interrupts = <0 64 0>; |
264 | clocks = <&clock 323>; | ||
265 | clock-names = "i2c"; | ||
222 | status = "disabled"; | 266 | status = "disabled"; |
223 | }; | 267 | }; |
224 | 268 | ||
@@ -228,6 +272,8 @@ | |||
228 | compatible = "samsung,s3c2440-i2c"; | 272 | compatible = "samsung,s3c2440-i2c"; |
229 | reg = <0x138D0000 0x100>; | 273 | reg = <0x138D0000 0x100>; |
230 | interrupts = <0 65 0>; | 274 | interrupts = <0 65 0>; |
275 | clocks = <&clock 324>; | ||
276 | clock-names = "i2c"; | ||
231 | status = "disabled"; | 277 | status = "disabled"; |
232 | }; | 278 | }; |
233 | 279 | ||
@@ -239,6 +285,8 @@ | |||
239 | rx-dma-channel = <&pdma0 6>; /* preliminary */ | 285 | rx-dma-channel = <&pdma0 6>; /* preliminary */ |
240 | #address-cells = <1>; | 286 | #address-cells = <1>; |
241 | #size-cells = <0>; | 287 | #size-cells = <0>; |
288 | clocks = <&clock 327>, <&clock 159>; | ||
289 | clock-names = "spi", "spi_busclk0"; | ||
242 | status = "disabled"; | 290 | status = "disabled"; |
243 | }; | 291 | }; |
244 | 292 | ||
@@ -250,6 +298,8 @@ | |||
250 | rx-dma-channel = <&pdma1 6>; /* preliminary */ | 298 | rx-dma-channel = <&pdma1 6>; /* preliminary */ |
251 | #address-cells = <1>; | 299 | #address-cells = <1>; |
252 | #size-cells = <0>; | 300 | #size-cells = <0>; |
301 | clocks = <&clock 328>, <&clock 160>; | ||
302 | clock-names = "spi", "spi_busclk0"; | ||
253 | status = "disabled"; | 303 | status = "disabled"; |
254 | }; | 304 | }; |
255 | 305 | ||
@@ -261,6 +311,8 @@ | |||
261 | rx-dma-channel = <&pdma0 8>; /* preliminary */ | 311 | rx-dma-channel = <&pdma0 8>; /* preliminary */ |
262 | #address-cells = <1>; | 312 | #address-cells = <1>; |
263 | #size-cells = <0>; | 313 | #size-cells = <0>; |
314 | clocks = <&clock 329>, <&clock 161>; | ||
315 | clock-names = "spi", "spi_busclk0"; | ||
264 | status = "disabled"; | 316 | status = "disabled"; |
265 | }; | 317 | }; |
266 | 318 | ||
@@ -275,6 +327,8 @@ | |||
275 | compatible = "arm,pl330", "arm,primecell"; | 327 | compatible = "arm,pl330", "arm,primecell"; |
276 | reg = <0x12680000 0x1000>; | 328 | reg = <0x12680000 0x1000>; |
277 | interrupts = <0 35 0>; | 329 | interrupts = <0 35 0>; |
330 | clocks = <&clock 292>; | ||
331 | clock-names = "apb_pclk"; | ||
278 | #dma-cells = <1>; | 332 | #dma-cells = <1>; |
279 | #dma-channels = <8>; | 333 | #dma-channels = <8>; |
280 | #dma-requests = <32>; | 334 | #dma-requests = <32>; |
@@ -284,6 +338,8 @@ | |||
284 | compatible = "arm,pl330", "arm,primecell"; | 338 | compatible = "arm,pl330", "arm,primecell"; |
285 | reg = <0x12690000 0x1000>; | 339 | reg = <0x12690000 0x1000>; |
286 | interrupts = <0 36 0>; | 340 | interrupts = <0 36 0>; |
341 | clocks = <&clock 293>; | ||
342 | clock-names = "apb_pclk"; | ||
287 | #dma-cells = <1>; | 343 | #dma-cells = <1>; |
288 | #dma-channels = <8>; | 344 | #dma-channels = <8>; |
289 | #dma-requests = <32>; | 345 | #dma-requests = <32>; |
@@ -293,6 +349,8 @@ | |||
293 | compatible = "arm,pl330", "arm,primecell"; | 349 | compatible = "arm,pl330", "arm,primecell"; |
294 | reg = <0x12850000 0x1000>; | 350 | reg = <0x12850000 0x1000>; |
295 | interrupts = <0 34 0>; | 351 | interrupts = <0 34 0>; |
352 | clocks = <&clock 279>; | ||
353 | clock-names = "apb_pclk"; | ||
296 | #dma-cells = <1>; | 354 | #dma-cells = <1>; |
297 | #dma-channels = <8>; | 355 | #dma-channels = <8>; |
298 | #dma-requests = <1>; | 356 | #dma-requests = <1>; |
diff --git a/arch/arm/boot/dts/exynos4210-origen.dts b/arch/arm/boot/dts/exynos4210-origen.dts index f2710018e84e..1b30bc8e2654 100644 --- a/arch/arm/boot/dts/exynos4210-origen.dts +++ b/arch/arm/boot/dts/exynos4210-origen.dts | |||
@@ -57,6 +57,12 @@ | |||
57 | status = "okay"; | 57 | status = "okay"; |
58 | }; | 58 | }; |
59 | 59 | ||
60 | codec@13400000 { | ||
61 | samsung,mfc-r = <0x43000000 0x800000>; | ||
62 | samsung,mfc-l = <0x51000000 0x800000>; | ||
63 | status = "okay"; | ||
64 | }; | ||
65 | |||
60 | serial@13800000 { | 66 | serial@13800000 { |
61 | status = "okay"; | 67 | status = "okay"; |
62 | }; | 68 | }; |
@@ -121,4 +127,16 @@ | |||
121 | linux,default-trigger = "heartbeat"; | 127 | linux,default-trigger = "heartbeat"; |
122 | }; | 128 | }; |
123 | }; | 129 | }; |
130 | |||
131 | fixed-rate-clocks { | ||
132 | xxti { | ||
133 | compatible = "samsung,clock-xxti"; | ||
134 | clock-frequency = <0>; | ||
135 | }; | ||
136 | |||
137 | xusbxti { | ||
138 | compatible = "samsung,clock-xusbxti"; | ||
139 | clock-frequency = <24000000>; | ||
140 | }; | ||
141 | }; | ||
124 | }; | 142 | }; |
diff --git a/arch/arm/boot/dts/exynos4210-smdkv310.dts b/arch/arm/boot/dts/exynos4210-smdkv310.dts index f63490707f3a..f52c86e2d424 100644 --- a/arch/arm/boot/dts/exynos4210-smdkv310.dts +++ b/arch/arm/boot/dts/exynos4210-smdkv310.dts | |||
@@ -43,6 +43,12 @@ | |||
43 | status = "okay"; | 43 | status = "okay"; |
44 | }; | 44 | }; |
45 | 45 | ||
46 | codec@13400000 { | ||
47 | samsung,mfc-r = <0x43000000 0x800000>; | ||
48 | samsung,mfc-l = <0x51000000 0x800000>; | ||
49 | status = "okay"; | ||
50 | }; | ||
51 | |||
46 | serial@13800000 { | 52 | serial@13800000 { |
47 | status = "okay"; | 53 | status = "okay"; |
48 | }; | 54 | }; |
@@ -189,4 +195,16 @@ | |||
189 | }; | 195 | }; |
190 | }; | 196 | }; |
191 | }; | 197 | }; |
198 | |||
199 | fixed-rate-clocks { | ||
200 | xxti { | ||
201 | compatible = "samsung,clock-xxti"; | ||
202 | clock-frequency = <12000000>; | ||
203 | }; | ||
204 | |||
205 | xusbxti { | ||
206 | compatible = "samsung,clock-xusbxti"; | ||
207 | clock-frequency = <24000000>; | ||
208 | }; | ||
209 | }; | ||
192 | }; | 210 | }; |
diff --git a/arch/arm/boot/dts/exynos4210-trats.dts b/arch/arm/boot/dts/exynos4210-trats.dts index c346b64dff55..9a14484c7bb1 100644 --- a/arch/arm/boot/dts/exynos4210-trats.dts +++ b/arch/arm/boot/dts/exynos4210-trats.dts | |||
@@ -289,4 +289,16 @@ | |||
289 | }; | 289 | }; |
290 | }; | 290 | }; |
291 | }; | 291 | }; |
292 | |||
293 | fixed-rate-clocks { | ||
294 | xxti { | ||
295 | compatible = "samsung,clock-xxti"; | ||
296 | clock-frequency = <0>; | ||
297 | }; | ||
298 | |||
299 | xusbxti { | ||
300 | compatible = "samsung,clock-xusbxti"; | ||
301 | clock-frequency = <24000000>; | ||
302 | }; | ||
303 | }; | ||
292 | }; | 304 | }; |
diff --git a/arch/arm/boot/dts/exynos4210.dtsi b/arch/arm/boot/dts/exynos4210.dtsi index 2feffc70814c..15143bdbafb8 100644 --- a/arch/arm/boot/dts/exynos4210.dtsi +++ b/arch/arm/boot/dts/exynos4210.dtsi | |||
@@ -47,6 +47,42 @@ | |||
47 | <0 12 0>, <0 13 0>, <0 14 0>, <0 15 0>; | 47 | <0 12 0>, <0 13 0>, <0 14 0>, <0 15 0>; |
48 | }; | 48 | }; |
49 | 49 | ||
50 | mct@10050000 { | ||
51 | compatible = "samsung,exynos4210-mct"; | ||
52 | reg = <0x10050000 0x800>; | ||
53 | interrupt-controller; | ||
54 | #interrups-cells = <2>; | ||
55 | interrupt-parent = <&mct_map>; | ||
56 | interrupts = <0 0>, <1 0>, <2 0>, <3 0>, | ||
57 | <4 0>, <5 0>; | ||
58 | clocks = <&clock 3>, <&clock 344>; | ||
59 | clock-names = "fin_pll", "mct"; | ||
60 | |||
61 | mct_map: mct-map { | ||
62 | #interrupt-cells = <2>; | ||
63 | #address-cells = <0>; | ||
64 | #size-cells = <0>; | ||
65 | interrupt-map = <0x0 0 &gic 0 57 0>, | ||
66 | <0x1 0 &gic 0 69 0>, | ||
67 | <0x2 0 &combiner 12 6>, | ||
68 | <0x3 0 &combiner 12 7>, | ||
69 | <0x4 0 &gic 0 42 0>, | ||
70 | <0x5 0 &gic 0 48 0>; | ||
71 | }; | ||
72 | }; | ||
73 | |||
74 | clock: clock-controller@0x10030000 { | ||
75 | compatible = "samsung,exynos4210-clock"; | ||
76 | reg = <0x10030000 0x20000>; | ||
77 | #clock-cells = <1>; | ||
78 | }; | ||
79 | |||
80 | pmu { | ||
81 | compatible = "arm,cortex-a9-pmu"; | ||
82 | interrupt-parent = <&combiner>; | ||
83 | interrupts = <2 2>, <3 2>; | ||
84 | }; | ||
85 | |||
50 | pinctrl_0: pinctrl@11400000 { | 86 | pinctrl_0: pinctrl@11400000 { |
51 | compatible = "samsung,exynos4210-pinctrl"; | 87 | compatible = "samsung,exynos4210-pinctrl"; |
52 | reg = <0x11400000 0x1000>; | 88 | reg = <0x11400000 0x1000>; |
diff --git a/arch/arm/boot/dts/exynos4212.dtsi b/arch/arm/boot/dts/exynos4212.dtsi index c6ae2005961f..36d4299789ef 100644 --- a/arch/arm/boot/dts/exynos4212.dtsi +++ b/arch/arm/boot/dts/exynos4212.dtsi | |||
@@ -25,4 +25,26 @@ | |||
25 | gic:interrupt-controller@10490000 { | 25 | gic:interrupt-controller@10490000 { |
26 | cpu-offset = <0x8000>; | 26 | cpu-offset = <0x8000>; |
27 | }; | 27 | }; |
28 | |||
29 | mct@10050000 { | ||
30 | compatible = "samsung,exynos4412-mct"; | ||
31 | reg = <0x10050000 0x800>; | ||
32 | interrupt-controller; | ||
33 | #interrups-cells = <2>; | ||
34 | interrupt-parent = <&mct_map>; | ||
35 | interrupts = <0 0>, <1 0>, <2 0>, <3 0>, | ||
36 | <4 0>, <5 0>; | ||
37 | |||
38 | mct_map: mct-map { | ||
39 | #interrupt-cells = <2>; | ||
40 | #address-cells = <0>; | ||
41 | #size-cells = <0>; | ||
42 | interrupt-map = <0x0 0 &gic 0 57 0>, | ||
43 | <0x1 0 &combiner 12 5>, | ||
44 | <0x2 0 &combiner 12 6>, | ||
45 | <0x3 0 &combiner 12 7>, | ||
46 | <0x4 0 &gic 1 12 0>, | ||
47 | <0x5 0 &gic 1 12 0>; | ||
48 | }; | ||
49 | }; | ||
28 | }; | 50 | }; |
diff --git a/arch/arm/boot/dts/exynos4412-odroidx.dts b/arch/arm/boot/dts/exynos4412-odroidx.dts new file mode 100644 index 000000000000..53bc8bf77984 --- /dev/null +++ b/arch/arm/boot/dts/exynos4412-odroidx.dts | |||
@@ -0,0 +1,111 @@ | |||
1 | /* | ||
2 | * Hardkernel's Exynos4412 based ODROID-X board device tree source | ||
3 | * | ||
4 | * Copyright (c) 2012 Dongjin Kim <tobetter@gmail.com> | ||
5 | * | ||
6 | * Device tree source file for Hardkernel's ODROID-X board which is based on | ||
7 | * Samsung's Exynos4412 SoC. | ||
8 | * | ||
9 | * This program is free software; you can redistribute it and/or modify | ||
10 | * it under the terms of the GNU General Public License version 2 as | ||
11 | * published by the Free Software Foundation. | ||
12 | */ | ||
13 | |||
14 | /dts-v1/; | ||
15 | /include/ "exynos4412.dtsi" | ||
16 | |||
17 | / { | ||
18 | model = "Hardkernel ODROID-X board based on Exynos4412"; | ||
19 | compatible = "hardkernel,odroid-x", "samsung,exynos4412"; | ||
20 | |||
21 | memory { | ||
22 | reg = <0x40000000 0x40000000>; | ||
23 | }; | ||
24 | |||
25 | leds { | ||
26 | compatible = "gpio-leds"; | ||
27 | led1 { | ||
28 | label = "led1:heart"; | ||
29 | gpios = <&gpc1 0 1>; | ||
30 | default-state = "on"; | ||
31 | linux,default-trigger = "heartbeat"; | ||
32 | }; | ||
33 | led2 { | ||
34 | label = "led2:mmc0"; | ||
35 | gpios = <&gpc1 2 1>; | ||
36 | default-state = "on"; | ||
37 | linux,default-trigger = "mmc0"; | ||
38 | }; | ||
39 | }; | ||
40 | |||
41 | mshc@12550000 { | ||
42 | #address-cells = <1>; | ||
43 | #size-cells = <0>; | ||
44 | pinctrl-0 = <&sd4_clk &sd4_cmd &sd4_bus4 &sd4_bus8>; | ||
45 | pinctrl-names = "default"; | ||
46 | status = "okay"; | ||
47 | |||
48 | num-slots = <1>; | ||
49 | supports-highspeed; | ||
50 | broken-cd; | ||
51 | fifo-depth = <0x80>; | ||
52 | card-detect-delay = <200>; | ||
53 | samsung,dw-mshc-ciu-div = <3>; | ||
54 | samsung,dw-mshc-sdr-timing = <2 3>; | ||
55 | samsung,dw-mshc-ddr-timing = <1 2>; | ||
56 | |||
57 | slot@0 { | ||
58 | reg = <0>; | ||
59 | bus-width = <8>; | ||
60 | }; | ||
61 | }; | ||
62 | |||
63 | regulator_p3v3 { | ||
64 | compatible = "regulator-fixed"; | ||
65 | regulator-name = "p3v3_en"; | ||
66 | regulator-min-microvolt = <3300000>; | ||
67 | regulator-max-microvolt = <3300000>; | ||
68 | gpio = <&gpa1 1 1>; | ||
69 | enable-active-high; | ||
70 | regulator-boot-on; | ||
71 | }; | ||
72 | |||
73 | rtc@10070000 { | ||
74 | status = "okay"; | ||
75 | }; | ||
76 | |||
77 | sdhci@12530000 { | ||
78 | bus-width = <4>; | ||
79 | pinctrl-0 = <&sd2_clk &sd2_cmd &sd2_cd &sd2_bus4>; | ||
80 | pinctrl-names = "default"; | ||
81 | status = "okay"; | ||
82 | }; | ||
83 | |||
84 | serial@13800000 { | ||
85 | status = "okay"; | ||
86 | }; | ||
87 | |||
88 | serial@13810000 { | ||
89 | status = "okay"; | ||
90 | }; | ||
91 | |||
92 | serial@13820000 { | ||
93 | status = "okay"; | ||
94 | }; | ||
95 | |||
96 | serial@13830000 { | ||
97 | status = "okay"; | ||
98 | }; | ||
99 | |||
100 | fixed-rate-clocks { | ||
101 | xxti { | ||
102 | compatible = "samsung,clock-xxti"; | ||
103 | clock-frequency = <0>; | ||
104 | }; | ||
105 | |||
106 | xusbxti { | ||
107 | compatible = "samsung,clock-xusbxti"; | ||
108 | clock-frequency = <24000000>; | ||
109 | }; | ||
110 | }; | ||
111 | }; | ||
diff --git a/arch/arm/boot/dts/exynos4412-origen.dts b/arch/arm/boot/dts/exynos4412-origen.dts new file mode 100644 index 000000000000..1fecf7666dc0 --- /dev/null +++ b/arch/arm/boot/dts/exynos4412-origen.dts | |||
@@ -0,0 +1,432 @@ | |||
1 | /* | ||
2 | * Insignal's Exynos4412 based Origen board device tree source | ||
3 | * | ||
4 | * Copyright (c) 2012-2013 Samsung Electronics Co., Ltd. | ||
5 | * http://www.samsung.com | ||
6 | * | ||
7 | * Device tree source file for Insignal's Origen board which is based on | ||
8 | * Samsung's Exynos4412 SoC. | ||
9 | * | ||
10 | * This program is free software; you can redistribute it and/or modify | ||
11 | * it under the terms of the GNU General Public License version 2 as | ||
12 | * published by the Free Software Foundation. | ||
13 | */ | ||
14 | |||
15 | /dts-v1/; | ||
16 | /include/ "exynos4412.dtsi" | ||
17 | |||
18 | / { | ||
19 | model = "Insignal Origen evaluation board based on Exynos4412"; | ||
20 | compatible = "insignal,origen4412", "samsung,exynos4412"; | ||
21 | |||
22 | memory { | ||
23 | reg = <0x40000000 0x40000000>; | ||
24 | }; | ||
25 | |||
26 | chosen { | ||
27 | bootargs ="console=ttySAC2,115200"; | ||
28 | }; | ||
29 | |||
30 | mmc_reg: voltage-regulator { | ||
31 | compatible = "regulator-fixed"; | ||
32 | regulator-name = "VMEM_VDD_2.8V"; | ||
33 | regulator-min-microvolt = <2800000>; | ||
34 | regulator-max-microvolt = <2800000>; | ||
35 | gpio = <&gpx1 1 0>; | ||
36 | enable-active-high; | ||
37 | }; | ||
38 | |||
39 | sdhci@12530000 { | ||
40 | bus-width = <4>; | ||
41 | pinctrl-0 = <&sd2_clk &sd2_cmd &sd2_bus4 &sd2_cd>; | ||
42 | pinctrl-names = "default"; | ||
43 | vmmc-supply = <&mmc_reg>; | ||
44 | status = "okay"; | ||
45 | }; | ||
46 | |||
47 | mshc@12550000 { | ||
48 | #address-cells = <1>; | ||
49 | #size-cells = <0>; | ||
50 | pinctrl-0 = <&sd4_clk &sd4_cmd &sd4_bus4 &sd4_bus8>; | ||
51 | pinctrl-names = "default"; | ||
52 | status = "okay"; | ||
53 | |||
54 | num-slots = <1>; | ||
55 | supports-highspeed; | ||
56 | broken-cd; | ||
57 | fifo-depth = <0x80>; | ||
58 | card-detect-delay = <200>; | ||
59 | samsung,dw-mshc-ciu-div = <3>; | ||
60 | samsung,dw-mshc-sdr-timing = <2 3>; | ||
61 | samsung,dw-mshc-ddr-timing = <1 2>; | ||
62 | |||
63 | slot@0 { | ||
64 | reg = <0>; | ||
65 | bus-width = <8>; | ||
66 | }; | ||
67 | }; | ||
68 | |||
69 | codec@13400000 { | ||
70 | samsung,mfc-r = <0x43000000 0x800000>; | ||
71 | samsung,mfc-l = <0x51000000 0x800000>; | ||
72 | status = "okay"; | ||
73 | }; | ||
74 | |||
75 | serial@13800000 { | ||
76 | status = "okay"; | ||
77 | }; | ||
78 | |||
79 | serial@13810000 { | ||
80 | status = "okay"; | ||
81 | }; | ||
82 | |||
83 | serial@13820000 { | ||
84 | status = "okay"; | ||
85 | }; | ||
86 | |||
87 | serial@13830000 { | ||
88 | status = "okay"; | ||
89 | }; | ||
90 | |||
91 | i2c@13860000 { | ||
92 | #address-cells = <1>; | ||
93 | #size-cells = <0>; | ||
94 | samsung,i2c-sda-delay = <100>; | ||
95 | samsung,i2c-max-bus-freq = <20000>; | ||
96 | pinctrl-0 = <&i2c0_bus>; | ||
97 | pinctrl-names = "default"; | ||
98 | status = "okay"; | ||
99 | |||
100 | s5m8767_pmic@66 { | ||
101 | compatible = "samsung,s5m8767-pmic"; | ||
102 | reg = <0x66>; | ||
103 | |||
104 | s5m8767,pmic-buck-default-dvs-idx = <3>; | ||
105 | |||
106 | s5m8767,pmic-buck-dvs-gpios = <&gpx2 3 0>, | ||
107 | <&gpx2 4 0>, | ||
108 | <&gpx2 5 0>; | ||
109 | |||
110 | s5m8767,pmic-buck-ds-gpios = <&gpm3 5 0>, | ||
111 | <&gpm3 6 0>, | ||
112 | <&gpm3 7 0>; | ||
113 | |||
114 | s5m8767,pmic-buck2-dvs-voltage = <1250000>, <1200000>, | ||
115 | <1200000>, <1200000>, | ||
116 | <1200000>, <1200000>, | ||
117 | <1200000>, <1200000>; | ||
118 | |||
119 | s5m8767,pmic-buck3-dvs-voltage = <1100000>, <1100000>, | ||
120 | <1100000>, <1100000>, | ||
121 | <1100000>, <1100000>, | ||
122 | <1100000>, <1100000>; | ||
123 | |||
124 | s5m8767,pmic-buck4-dvs-voltage = <1200000>, <1200000>, | ||
125 | <1200000>, <1200000>, | ||
126 | <1200000>, <1200000>, | ||
127 | <1200000>, <1200000>; | ||
128 | |||
129 | regulators { | ||
130 | ldo1_reg: LDO1 { | ||
131 | regulator-name = "VDD_ALIVE"; | ||
132 | regulator-min-microvolt = <1100000>; | ||
133 | regulator-max-microvolt = <1100000>; | ||
134 | regulator-always-on; | ||
135 | regulator-boot-on; | ||
136 | op_mode = <1>; /* Normal Mode */ | ||
137 | }; | ||
138 | |||
139 | ldo2_reg: LDO2 { | ||
140 | regulator-name = "VDDQ_M12"; | ||
141 | regulator-min-microvolt = <1200000>; | ||
142 | regulator-max-microvolt = <1200000>; | ||
143 | regulator-always-on; | ||
144 | op_mode = <1>; /* Normal Mode */ | ||
145 | }; | ||
146 | |||
147 | ldo3_reg: LDO3 { | ||
148 | regulator-name = "VDDIOAP_18"; | ||
149 | regulator-min-microvolt = <1800000>; | ||
150 | regulator-max-microvolt = <1800000>; | ||
151 | regulator-always-on; | ||
152 | op_mode = <1>; /* Normal Mode */ | ||
153 | }; | ||
154 | |||
155 | ldo4_reg: LDO4 { | ||
156 | regulator-name = "VDDQ_PRE"; | ||
157 | regulator-min-microvolt = <1800000>; | ||
158 | regulator-max-microvolt = <1800000>; | ||
159 | regulator-always-on; | ||
160 | op_mode = <1>; /* Normal Mode */ | ||
161 | }; | ||
162 | |||
163 | ldo5_reg: LDO5 { | ||
164 | regulator-name = "VDD18_2M"; | ||
165 | regulator-min-microvolt = <1800000>; | ||
166 | regulator-max-microvolt = <1800000>; | ||
167 | regulator-always-on; | ||
168 | op_mode = <1>; /* Normal Mode */ | ||
169 | }; | ||
170 | |||
171 | ldo6_reg: LDO6 { | ||
172 | regulator-name = "VDD10_MPLL"; | ||
173 | regulator-min-microvolt = <1000000>; | ||
174 | regulator-max-microvolt = <1000000>; | ||
175 | regulator-always-on; | ||
176 | op_mode = <1>; /* Normal Mode */ | ||
177 | }; | ||
178 | |||
179 | ldo7_reg: LDO7 { | ||
180 | regulator-name = "VDD10_XPLL"; | ||
181 | regulator-min-microvolt = <1000000>; | ||
182 | regulator-max-microvolt = <1000000>; | ||
183 | regulator-always-on; | ||
184 | op_mode = <1>; /* Normal Mode */ | ||
185 | }; | ||
186 | |||
187 | ldo8_reg: LDO8 { | ||
188 | regulator-name = "VDD10_MIPI"; | ||
189 | regulator-min-microvolt = <1000000>; | ||
190 | regulator-max-microvolt = <1000000>; | ||
191 | regulator-always-on; | ||
192 | op_mode = <1>; /* Normal Mode */ | ||
193 | }; | ||
194 | |||
195 | ldo9_reg: LDO9 { | ||
196 | regulator-name = "VDD33_LCD"; | ||
197 | regulator-min-microvolt = <3300000>; | ||
198 | regulator-max-microvolt = <3300000>; | ||
199 | regulator-always-on; | ||
200 | op_mode = <1>; /* Normal Mode */ | ||
201 | }; | ||
202 | |||
203 | ldo10_reg: LDO10 { | ||
204 | regulator-name = "VDD18_MIPI"; | ||
205 | regulator-min-microvolt = <1800000>; | ||
206 | regulator-max-microvolt = <1800000>; | ||
207 | regulator-always-on; | ||
208 | op_mode = <1>; /* Normal Mode */ | ||
209 | }; | ||
210 | |||
211 | ldo11_reg: LDO11 { | ||
212 | regulator-name = "VDD18_ABB1"; | ||
213 | regulator-min-microvolt = <1800000>; | ||
214 | regulator-max-microvolt = <1800000>; | ||
215 | regulator-always-on; | ||
216 | op_mode = <1>; /* Normal Mode */ | ||
217 | }; | ||
218 | |||
219 | ldo12_reg: LDO12 { | ||
220 | regulator-name = "VDD33_UOTG"; | ||
221 | regulator-min-microvolt = <3300000>; | ||
222 | regulator-max-microvolt = <3300000>; | ||
223 | regulator-always-on; | ||
224 | op_mode = <1>; /* Normal Mode */ | ||
225 | }; | ||
226 | |||
227 | ldo13_reg: LDO13 { | ||
228 | regulator-name = "VDDIOPERI_18"; | ||
229 | regulator-min-microvolt = <1800000>; | ||
230 | regulator-max-microvolt = <1800000>; | ||
231 | regulator-always-on; | ||
232 | op_mode = <1>; /* Normal Mode */ | ||
233 | }; | ||
234 | |||
235 | ldo14_reg: LDO14 { | ||
236 | regulator-name = "VDD18_ABB02"; | ||
237 | regulator-min-microvolt = <1800000>; | ||
238 | regulator-max-microvolt = <1800000>; | ||
239 | regulator-always-on; | ||
240 | op_mode = <1>; /* Normal Mode */ | ||
241 | }; | ||
242 | |||
243 | ldo15_reg: LDO15 { | ||
244 | regulator-name = "VDD10_USH"; | ||
245 | regulator-min-microvolt = <1000000>; | ||
246 | regulator-max-microvolt = <1000000>; | ||
247 | regulator-always-on; | ||
248 | op_mode = <1>; /* Normal Mode */ | ||
249 | }; | ||
250 | |||
251 | ldo16_reg: LDO16 { | ||
252 | regulator-name = "VDD18_HSIC"; | ||
253 | regulator-min-microvolt = <1800000>; | ||
254 | regulator-max-microvolt = <1800000>; | ||
255 | regulator-always-on; | ||
256 | op_mode = <1>; /* Normal Mode */ | ||
257 | }; | ||
258 | |||
259 | ldo17_reg: LDO17 { | ||
260 | regulator-name = "VDDIOAP_MMC012_28"; | ||
261 | regulator-min-microvolt = <2800000>; | ||
262 | regulator-max-microvolt = <2800000>; | ||
263 | regulator-always-on; | ||
264 | op_mode = <1>; /* Normal Mode */ | ||
265 | }; | ||
266 | |||
267 | ldo18_reg: LDO18 { | ||
268 | regulator-name = "VDDIOPERI_28"; | ||
269 | regulator-min-microvolt = <2800000>; | ||
270 | regulator-max-microvolt = <2800000>; | ||
271 | regulator-always-on; | ||
272 | op_mode = <1>; /* Normal Mode */ | ||
273 | }; | ||
274 | |||
275 | ldo19_reg: LDO19 { | ||
276 | regulator-name = "DVDD25"; | ||
277 | regulator-min-microvolt = <2500000>; | ||
278 | regulator-max-microvolt = <2500000>; | ||
279 | regulator-always-on; | ||
280 | op_mode = <1>; /* Normal Mode */ | ||
281 | }; | ||
282 | |||
283 | ldo20_reg: LDO20 { | ||
284 | regulator-name = "VDD28_CAM"; | ||
285 | regulator-min-microvolt = <2800000>; | ||
286 | regulator-max-microvolt = <2800000>; | ||
287 | regulator-always-on; | ||
288 | op_mode = <1>; /* Normal Mode */ | ||
289 | }; | ||
290 | |||
291 | ldo21_reg: LDO21 { | ||
292 | regulator-name = "VDD28_AF"; | ||
293 | regulator-min-microvolt = <2800000>; | ||
294 | regulator-max-microvolt = <2800000>; | ||
295 | regulator-always-on; | ||
296 | op_mode = <1>; /* Normal Mode */ | ||
297 | }; | ||
298 | |||
299 | ldo22_reg: LDO22 { | ||
300 | regulator-name = "VDDA28_2M"; | ||
301 | regulator-min-microvolt = <2800000>; | ||
302 | regulator-max-microvolt = <2800000>; | ||
303 | regulator-always-on; | ||
304 | op_mode = <1>; /* Normal Mode */ | ||
305 | }; | ||
306 | |||
307 | ldo23_reg: LDO23 { | ||
308 | regulator-name = "VDD28_TF"; | ||
309 | regulator-min-microvolt = <2800000>; | ||
310 | regulator-max-microvolt = <2800000>; | ||
311 | regulator-always-on; | ||
312 | op_mode = <1>; /* Normal Mode */ | ||
313 | }; | ||
314 | |||
315 | ldo24_reg: LDO24 { | ||
316 | regulator-name = "VDD33_A31"; | ||
317 | regulator-min-microvolt = <3300000>; | ||
318 | regulator-max-microvolt = <3300000>; | ||
319 | regulator-always-on; | ||
320 | op_mode = <1>; /* Normal Mode */ | ||
321 | }; | ||
322 | |||
323 | ldo25_reg: LDO25 { | ||
324 | regulator-name = "VDD18_CAM"; | ||
325 | regulator-min-microvolt = <1800000>; | ||
326 | regulator-max-microvolt = <1800000>; | ||
327 | regulator-always-on; | ||
328 | op_mode = <1>; /* Normal Mode */ | ||
329 | }; | ||
330 | |||
331 | ldo26_reg: LDO26 { | ||
332 | regulator-name = "VDD18_A31"; | ||
333 | regulator-min-microvolt = <1800000>; | ||
334 | regulator-max-microvolt = <1800000>; | ||
335 | regulator-always-on; | ||
336 | op_mode = <1>; /* Normal Mode */ | ||
337 | }; | ||
338 | |||
339 | ldo27_reg: LDO27 { | ||
340 | regulator-name = "GPS_1V8"; | ||
341 | regulator-min-microvolt = <1800000>; | ||
342 | regulator-max-microvolt = <1800000>; | ||
343 | regulator-always-on; | ||
344 | op_mode = <1>; /* Normal Mode */ | ||
345 | }; | ||
346 | |||
347 | ldo28_reg: LDO28 { | ||
348 | regulator-name = "DVDD12"; | ||
349 | regulator-min-microvolt = <1200000>; | ||
350 | regulator-max-microvolt = <1200000>; | ||
351 | regulator-always-on; | ||
352 | op_mode = <1>; /* Normal Mode */ | ||
353 | }; | ||
354 | |||
355 | buck1_reg: BUCK1 { | ||
356 | regulator-name = "vdd_mif"; | ||
357 | regulator-min-microvolt = <950000>; | ||
358 | regulator-max-microvolt = <1100000>; | ||
359 | regulator-always-on; | ||
360 | regulator-boot-on; | ||
361 | op_mode = <1>; /* Normal Mode */ | ||
362 | }; | ||
363 | |||
364 | buck2_reg: BUCK2 { | ||
365 | regulator-name = "vdd_arm"; | ||
366 | regulator-min-microvolt = <925000>; | ||
367 | regulator-max-microvolt = <1300000>; | ||
368 | regulator-always-on; | ||
369 | regulator-boot-on; | ||
370 | op_mode = <1>; /* Normal Mode */ | ||
371 | }; | ||
372 | |||
373 | buck3_reg: BUCK3 { | ||
374 | regulator-name = "vdd_int"; | ||
375 | regulator-min-microvolt = <900000>; | ||
376 | regulator-max-microvolt = <1200000>; | ||
377 | regulator-always-on; | ||
378 | regulator-boot-on; | ||
379 | op_mode = <1>; /* Normal Mode */ | ||
380 | }; | ||
381 | |||
382 | buck4_reg: BUCK4 { | ||
383 | regulator-name = "vdd_g3d"; | ||
384 | regulator-min-microvolt = <750000>; | ||
385 | regulator-max-microvolt = <1500000>; | ||
386 | regulator-always-on; | ||
387 | regulator-boot-on; | ||
388 | op_mode = <1>; /* Normal Mode */ | ||
389 | }; | ||
390 | |||
391 | buck5_reg: BUCK5 { | ||
392 | regulator-name = "vdd_m12"; | ||
393 | regulator-min-microvolt = <750000>; | ||
394 | regulator-max-microvolt = <1500000>; | ||
395 | regulator-always-on; | ||
396 | regulator-boot-on; | ||
397 | op_mode = <1>; /* Normal Mode */ | ||
398 | }; | ||
399 | |||
400 | buck6_reg: BUCK6 { | ||
401 | regulator-name = "vdd12_5m"; | ||
402 | regulator-min-microvolt = <750000>; | ||
403 | regulator-max-microvolt = <1500000>; | ||
404 | regulator-always-on; | ||
405 | regulator-boot-on; | ||
406 | op_mode = <1>; /* Normal Mode */ | ||
407 | }; | ||
408 | |||
409 | buck9_reg: BUCK9 { | ||
410 | regulator-name = "vddf28_emmc"; | ||
411 | regulator-min-microvolt = <750000>; | ||
412 | regulator-max-microvolt = <3000000>; | ||
413 | regulator-always-on; | ||
414 | regulator-boot-on; | ||
415 | op_mode = <1>; /* Normal Mode */ | ||
416 | }; | ||
417 | }; | ||
418 | }; | ||
419 | }; | ||
420 | |||
421 | fixed-rate-clocks { | ||
422 | xxti { | ||
423 | compatible = "samsung,clock-xxti"; | ||
424 | clock-frequency = <0>; | ||
425 | }; | ||
426 | |||
427 | xusbxti { | ||
428 | compatible = "samsung,clock-xusbxti"; | ||
429 | clock-frequency = <24000000>; | ||
430 | }; | ||
431 | }; | ||
432 | }; | ||
diff --git a/arch/arm/boot/dts/exynos4412-smdk4412.dts b/arch/arm/boot/dts/exynos4412-smdk4412.dts index f05bf575cc45..874beeaef99d 100644 --- a/arch/arm/boot/dts/exynos4412-smdk4412.dts +++ b/arch/arm/boot/dts/exynos4412-smdk4412.dts | |||
@@ -27,6 +27,19 @@ | |||
27 | bootargs ="root=/dev/ram0 rw ramdisk=8192 initrd=0x41000000,8M console=ttySAC1,115200 init=/linuxrc"; | 27 | bootargs ="root=/dev/ram0 rw ramdisk=8192 initrd=0x41000000,8M console=ttySAC1,115200 init=/linuxrc"; |
28 | }; | 28 | }; |
29 | 29 | ||
30 | sdhci@12530000 { | ||
31 | bus-width = <4>; | ||
32 | pinctrl-0 = <&sd2_clk &sd2_cmd &sd2_bus4 &sd2_cd>; | ||
33 | pinctrl-names = "default"; | ||
34 | status = "okay"; | ||
35 | }; | ||
36 | |||
37 | codec@13400000 { | ||
38 | samsung,mfc-r = <0x43000000 0x800000>; | ||
39 | samsung,mfc-l = <0x51000000 0x800000>; | ||
40 | status = "okay"; | ||
41 | }; | ||
42 | |||
30 | serial@13800000 { | 43 | serial@13800000 { |
31 | status = "okay"; | 44 | status = "okay"; |
32 | }; | 45 | }; |
@@ -42,4 +55,16 @@ | |||
42 | serial@13830000 { | 55 | serial@13830000 { |
43 | status = "okay"; | 56 | status = "okay"; |
44 | }; | 57 | }; |
58 | |||
59 | fixed-rate-clocks { | ||
60 | xxti { | ||
61 | compatible = "samsung,clock-xxti"; | ||
62 | clock-frequency = <0>; | ||
63 | }; | ||
64 | |||
65 | xusbxti { | ||
66 | compatible = "samsung,clock-xusbxti"; | ||
67 | clock-frequency = <24000000>; | ||
68 | }; | ||
69 | }; | ||
45 | }; | 70 | }; |
diff --git a/arch/arm/boot/dts/exynos4412.dtsi b/arch/arm/boot/dts/exynos4412.dtsi index d7dfe312772a..d75c047e80a9 100644 --- a/arch/arm/boot/dts/exynos4412.dtsi +++ b/arch/arm/boot/dts/exynos4412.dtsi | |||
@@ -25,4 +25,30 @@ | |||
25 | gic:interrupt-controller@10490000 { | 25 | gic:interrupt-controller@10490000 { |
26 | cpu-offset = <0x4000>; | 26 | cpu-offset = <0x4000>; |
27 | }; | 27 | }; |
28 | |||
29 | mct@10050000 { | ||
30 | compatible = "samsung,exynos4412-mct"; | ||
31 | reg = <0x10050000 0x800>; | ||
32 | interrupt-controller; | ||
33 | #interrups-cells = <2>; | ||
34 | interrupt-parent = <&mct_map>; | ||
35 | interrupts = <0 0>, <1 0>, <2 0>, <3 0>, | ||
36 | <4 0>, <5 0>, <6 0>, <7 0>; | ||
37 | clocks = <&clock 3>, <&clock 344>; | ||
38 | clock-names = "fin_pll", "mct"; | ||
39 | |||
40 | mct_map: mct-map { | ||
41 | #interrupt-cells = <2>; | ||
42 | #address-cells = <0>; | ||
43 | #size-cells = <0>; | ||
44 | interrupt-map = <0x0 0 &gic 0 57 0>, | ||
45 | <0x1 0 &combiner 12 5>, | ||
46 | <0x2 0 &combiner 12 6>, | ||
47 | <0x3 0 &combiner 12 7>, | ||
48 | <0x4 0 &gic 1 12 0>, | ||
49 | <0x5 0 &gic 1 12 0>, | ||
50 | <0x6 0 &gic 1 12 0>, | ||
51 | <0x7 0 &gic 1 12 0>; | ||
52 | }; | ||
53 | }; | ||
28 | }; | 54 | }; |
diff --git a/arch/arm/boot/dts/exynos4x12.dtsi b/arch/arm/boot/dts/exynos4x12.dtsi index 9a8780694909..7496b8d633ea 100644 --- a/arch/arm/boot/dts/exynos4x12.dtsi +++ b/arch/arm/boot/dts/exynos4x12.dtsi | |||
@@ -36,6 +36,12 @@ | |||
36 | <0 16 0>, <0 17 0>, <0 18 0>, <0 19 0>; | 36 | <0 16 0>, <0 17 0>, <0 18 0>, <0 19 0>; |
37 | }; | 37 | }; |
38 | 38 | ||
39 | clock: clock-controller@0x10030000 { | ||
40 | compatible = "samsung,exynos4412-clock"; | ||
41 | reg = <0x10030000 0x20000>; | ||
42 | #clock-cells = <1>; | ||
43 | }; | ||
44 | |||
39 | pinctrl_0: pinctrl@11400000 { | 45 | pinctrl_0: pinctrl@11400000 { |
40 | compatible = "samsung,exynos4x12-pinctrl"; | 46 | compatible = "samsung,exynos4x12-pinctrl"; |
41 | reg = <0x11400000 0x1000>; | 47 | reg = <0x11400000 0x1000>; |
diff --git a/arch/arm/boot/dts/exynos5250-arndale.dts b/arch/arm/boot/dts/exynos5250-arndale.dts new file mode 100644 index 000000000000..5de019cb0e58 --- /dev/null +++ b/arch/arm/boot/dts/exynos5250-arndale.dts | |||
@@ -0,0 +1,129 @@ | |||
1 | /* | ||
2 | * Samsung's Exynos5250 based Arndale board device tree source | ||
3 | * | ||
4 | * Copyright (c) 2013 Samsung Electronics Co., Ltd. | ||
5 | * http://www.samsung.com | ||
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 | |||
12 | /dts-v1/; | ||
13 | /include/ "exynos5250.dtsi" | ||
14 | |||
15 | / { | ||
16 | model = "Insignal Arndale evaluation board based on EXYNOS5250"; | ||
17 | compatible = "insignal,arndale", "samsung,exynos5250"; | ||
18 | |||
19 | memory { | ||
20 | reg = <0x40000000 0x80000000>; | ||
21 | }; | ||
22 | |||
23 | chosen { | ||
24 | bootargs = "console=ttySAC2,115200"; | ||
25 | }; | ||
26 | |||
27 | i2c@12C60000 { | ||
28 | status = "disabled"; | ||
29 | }; | ||
30 | |||
31 | i2c@12C70000 { | ||
32 | status = "disabled"; | ||
33 | }; | ||
34 | |||
35 | i2c@12C80000 { | ||
36 | status = "disabled"; | ||
37 | }; | ||
38 | |||
39 | i2c@12C90000 { | ||
40 | status = "disabled"; | ||
41 | }; | ||
42 | |||
43 | i2c@12CA0000 { | ||
44 | status = "disabled"; | ||
45 | }; | ||
46 | |||
47 | i2c@12CB0000 { | ||
48 | status = "disabled"; | ||
49 | }; | ||
50 | |||
51 | i2c@12CC0000 { | ||
52 | status = "disabled"; | ||
53 | }; | ||
54 | |||
55 | i2c@12CD0000 { | ||
56 | status = "disabled"; | ||
57 | }; | ||
58 | |||
59 | i2c@121D0000 { | ||
60 | status = "disabled"; | ||
61 | }; | ||
62 | |||
63 | dwmmc_0: dwmmc0@12200000 { | ||
64 | num-slots = <1>; | ||
65 | supports-highspeed; | ||
66 | broken-cd; | ||
67 | fifo-depth = <0x80>; | ||
68 | card-detect-delay = <200>; | ||
69 | samsung,dw-mshc-ciu-div = <3>; | ||
70 | samsung,dw-mshc-sdr-timing = <2 3>; | ||
71 | samsung,dw-mshc-ddr-timing = <1 2>; | ||
72 | |||
73 | slot@0 { | ||
74 | reg = <0>; | ||
75 | bus-width = <8>; | ||
76 | gpios = <&gpc0 0 2 0 3>, <&gpc0 1 2 0 3>, | ||
77 | <&gpc0 3 2 3 3>, <&gpc0 4 2 3 3>, | ||
78 | <&gpc0 5 2 3 3>, <&gpc0 6 2 3 3>, | ||
79 | <&gpc1 0 2 3 3>, <&gpc1 1 2 3 3>, | ||
80 | <&gpc1 2 2 3 3>, <&gpc1 3 2 3 3>; | ||
81 | }; | ||
82 | }; | ||
83 | |||
84 | dwmmc_1: dwmmc1@12210000 { | ||
85 | status = "disabled"; | ||
86 | }; | ||
87 | |||
88 | dwmmc_2: dwmmc2@12220000 { | ||
89 | num-slots = <1>; | ||
90 | supports-highspeed; | ||
91 | fifo-depth = <0x80>; | ||
92 | card-detect-delay = <200>; | ||
93 | samsung,dw-mshc-ciu-div = <3>; | ||
94 | samsung,dw-mshc-sdr-timing = <2 3>; | ||
95 | samsung,dw-mshc-ddr-timing = <1 2>; | ||
96 | |||
97 | slot@0 { | ||
98 | reg = <0>; | ||
99 | bus-width = <4>; | ||
100 | samsung,cd-pinmux-gpio = <&gpc3 2 2 3 3>; | ||
101 | gpios = <&gpc3 0 2 0 3>, <&gpc3 1 2 0 3>, | ||
102 | <&gpc3 3 2 3 3>, <&gpc3 4 2 3 3>, | ||
103 | <&gpc3 5 2 3 3>, <&gpc3 6 2 3 3>; | ||
104 | }; | ||
105 | }; | ||
106 | |||
107 | dwmmc_3: dwmmc3@12230000 { | ||
108 | status = "disabled"; | ||
109 | }; | ||
110 | |||
111 | spi_0: spi@12d20000 { | ||
112 | status = "disabled"; | ||
113 | }; | ||
114 | |||
115 | spi_1: spi@12d30000 { | ||
116 | status = "disabled"; | ||
117 | }; | ||
118 | |||
119 | spi_2: spi@12d40000 { | ||
120 | status = "disabled"; | ||
121 | }; | ||
122 | |||
123 | fixed-rate-clocks { | ||
124 | xxti { | ||
125 | compatible = "samsung,clock-xxti"; | ||
126 | clock-frequency = <24000000>; | ||
127 | }; | ||
128 | }; | ||
129 | }; | ||
diff --git a/arch/arm/boot/dts/exynos5250-smdk5250.dts b/arch/arm/boot/dts/exynos5250-smdk5250.dts index 1b8d4106d338..872ae1f93c75 100644 --- a/arch/arm/boot/dts/exynos5250-smdk5250.dts +++ b/arch/arm/boot/dts/exynos5250-smdk5250.dts | |||
@@ -231,4 +231,24 @@ | |||
231 | samsung,i2s-controller = <&i2s0>; | 231 | samsung,i2s-controller = <&i2s0>; |
232 | samsung,audio-codec = <&wm8994>; | 232 | samsung,audio-codec = <&wm8994>; |
233 | }; | 233 | }; |
234 | |||
235 | usb@12110000 { | ||
236 | samsung,vbus-gpio = <&gpx2 6 1 3 3>; | ||
237 | }; | ||
238 | |||
239 | dp-controller { | ||
240 | samsung,color-space = <0>; | ||
241 | samsung,dynamic-range = <0>; | ||
242 | samsung,ycbcr-coeff = <0>; | ||
243 | samsung,color-depth = <1>; | ||
244 | samsung,link-rate = <0x0a>; | ||
245 | samsung,lane-count = <4>; | ||
246 | }; | ||
247 | |||
248 | fixed-rate-clocks { | ||
249 | xxti { | ||
250 | compatible = "samsung,clock-xxti"; | ||
251 | clock-frequency = <24000000>; | ||
252 | }; | ||
253 | }; | ||
234 | }; | 254 | }; |
diff --git a/arch/arm/boot/dts/exynos5250-snow.dts b/arch/arm/boot/dts/exynos5250-snow.dts index 17dd951c1cd2..babd9f9b1bf9 100644 --- a/arch/arm/boot/dts/exynos5250-snow.dts +++ b/arch/arm/boot/dts/exynos5250-snow.dts | |||
@@ -40,4 +40,15 @@ | |||
40 | <&gpc4 5 2 3 0>, <&gpc4 6 2 3 0>; | 40 | <&gpc4 5 2 3 0>, <&gpc4 6 2 3 0>; |
41 | }; | 41 | }; |
42 | }; | 42 | }; |
43 | |||
44 | usb@12110000 { | ||
45 | samsung,vbus-gpio = <&gpx1 1 1 3 3>; | ||
46 | }; | ||
47 | |||
48 | fixed-rate-clocks { | ||
49 | xxti { | ||
50 | compatible = "samsung,clock-xxti"; | ||
51 | clock-frequency = <24000000>; | ||
52 | }; | ||
53 | }; | ||
43 | }; | 54 | }; |
diff --git a/arch/arm/boot/dts/exynos5250.dtsi b/arch/arm/boot/dts/exynos5250.dtsi index b1ac73e21c80..28758e5dd15c 100644 --- a/arch/arm/boot/dts/exynos5250.dtsi +++ b/arch/arm/boot/dts/exynos5250.dtsi | |||
@@ -46,6 +46,22 @@ | |||
46 | i2c8 = &i2c_8; | 46 | i2c8 = &i2c_8; |
47 | }; | 47 | }; |
48 | 48 | ||
49 | pd_gsc: gsc-power-domain@0x10044000 { | ||
50 | compatible = "samsung,exynos4210-pd"; | ||
51 | reg = <0x10044000 0x20>; | ||
52 | }; | ||
53 | |||
54 | pd_mfc: mfc-power-domain@0x10044040 { | ||
55 | compatible = "samsung,exynos4210-pd"; | ||
56 | reg = <0x10044040 0x20>; | ||
57 | }; | ||
58 | |||
59 | clock: clock-controller@0x10010000 { | ||
60 | compatible = "samsung,exynos5250-clock"; | ||
61 | reg = <0x10010000 0x30000>; | ||
62 | #clock-cells = <1>; | ||
63 | }; | ||
64 | |||
49 | gic:interrupt-controller@10481000 { | 65 | gic:interrupt-controller@10481000 { |
50 | compatible = "arm,cortex-a9-gic"; | 66 | compatible = "arm,cortex-a9-gic"; |
51 | #interrupt-cells = <3>; | 67 | #interrupt-cells = <3>; |
@@ -69,58 +85,106 @@ | |||
69 | <0 28 0>, <0 29 0>, <0 30 0>, <0 31 0>; | 85 | <0 28 0>, <0 29 0>, <0 30 0>, <0 31 0>; |
70 | }; | 86 | }; |
71 | 87 | ||
88 | mct@101C0000 { | ||
89 | compatible = "samsung,exynos4210-mct"; | ||
90 | reg = <0x101C0000 0x800>; | ||
91 | interrupt-controller; | ||
92 | #interrups-cells = <2>; | ||
93 | interrupt-parent = <&mct_map>; | ||
94 | interrupts = <0 0>, <1 0>, <2 0>, <3 0>, | ||
95 | <4 0>, <5 0>; | ||
96 | clocks = <&clock 1>, <&clock 335>; | ||
97 | clock-names = "fin_pll", "mct"; | ||
98 | |||
99 | mct_map: mct-map { | ||
100 | #interrupt-cells = <2>; | ||
101 | #address-cells = <0>; | ||
102 | #size-cells = <0>; | ||
103 | interrupt-map = <0x0 0 &combiner 23 3>, | ||
104 | <0x1 0 &combiner 23 4>, | ||
105 | <0x2 0 &combiner 25 2>, | ||
106 | <0x3 0 &combiner 25 3>, | ||
107 | <0x4 0 &gic 0 120 0>, | ||
108 | <0x5 0 &gic 0 121 0>; | ||
109 | }; | ||
110 | }; | ||
111 | |||
112 | pmu { | ||
113 | compatible = "arm,cortex-a15-pmu"; | ||
114 | interrupt-parent = <&combiner>; | ||
115 | interrupts = <1 2>, <22 4>; | ||
116 | }; | ||
117 | |||
72 | watchdog { | 118 | watchdog { |
73 | compatible = "samsung,s3c2410-wdt"; | 119 | compatible = "samsung,s3c2410-wdt"; |
74 | reg = <0x101D0000 0x100>; | 120 | reg = <0x101D0000 0x100>; |
75 | interrupts = <0 42 0>; | 121 | interrupts = <0 42 0>; |
122 | clocks = <&clock 336>; | ||
123 | clock-names = "watchdog"; | ||
76 | }; | 124 | }; |
77 | 125 | ||
78 | codec@11000000 { | 126 | codec@11000000 { |
79 | compatible = "samsung,mfc-v6"; | 127 | compatible = "samsung,mfc-v6"; |
80 | reg = <0x11000000 0x10000>; | 128 | reg = <0x11000000 0x10000>; |
81 | interrupts = <0 96 0>; | 129 | interrupts = <0 96 0>; |
130 | samsung,power-domain = <&pd_mfc>; | ||
82 | }; | 131 | }; |
83 | 132 | ||
84 | rtc { | 133 | rtc { |
85 | compatible = "samsung,s3c6410-rtc"; | 134 | compatible = "samsung,s3c6410-rtc"; |
86 | reg = <0x101E0000 0x100>; | 135 | reg = <0x101E0000 0x100>; |
87 | interrupts = <0 43 0>, <0 44 0>; | 136 | interrupts = <0 43 0>, <0 44 0>; |
137 | clocks = <&clock 337>; | ||
138 | clock-names = "rtc"; | ||
139 | status = "disabled"; | ||
88 | }; | 140 | }; |
89 | 141 | ||
90 | tmu@10060000 { | 142 | tmu@10060000 { |
91 | compatible = "samsung,exynos5250-tmu"; | 143 | compatible = "samsung,exynos5250-tmu"; |
92 | reg = <0x10060000 0x100>; | 144 | reg = <0x10060000 0x100>; |
93 | interrupts = <0 65 0>; | 145 | interrupts = <0 65 0>; |
146 | clocks = <&clock 338>; | ||
147 | clock-names = "tmu_apbif"; | ||
94 | }; | 148 | }; |
95 | 149 | ||
96 | serial@12C00000 { | 150 | serial@12C00000 { |
97 | compatible = "samsung,exynos4210-uart"; | 151 | compatible = "samsung,exynos4210-uart"; |
98 | reg = <0x12C00000 0x100>; | 152 | reg = <0x12C00000 0x100>; |
99 | interrupts = <0 51 0>; | 153 | interrupts = <0 51 0>; |
154 | clocks = <&clock 289>, <&clock 146>; | ||
155 | clock-names = "uart", "clk_uart_baud0"; | ||
100 | }; | 156 | }; |
101 | 157 | ||
102 | serial@12C10000 { | 158 | serial@12C10000 { |
103 | compatible = "samsung,exynos4210-uart"; | 159 | compatible = "samsung,exynos4210-uart"; |
104 | reg = <0x12C10000 0x100>; | 160 | reg = <0x12C10000 0x100>; |
105 | interrupts = <0 52 0>; | 161 | interrupts = <0 52 0>; |
162 | clocks = <&clock 290>, <&clock 147>; | ||
163 | clock-names = "uart", "clk_uart_baud0"; | ||
106 | }; | 164 | }; |
107 | 165 | ||
108 | serial@12C20000 { | 166 | serial@12C20000 { |
109 | compatible = "samsung,exynos4210-uart"; | 167 | compatible = "samsung,exynos4210-uart"; |
110 | reg = <0x12C20000 0x100>; | 168 | reg = <0x12C20000 0x100>; |
111 | interrupts = <0 53 0>; | 169 | interrupts = <0 53 0>; |
170 | clocks = <&clock 291>, <&clock 148>; | ||
171 | clock-names = "uart", "clk_uart_baud0"; | ||
112 | }; | 172 | }; |
113 | 173 | ||
114 | serial@12C30000 { | 174 | serial@12C30000 { |
115 | compatible = "samsung,exynos4210-uart"; | 175 | compatible = "samsung,exynos4210-uart"; |
116 | reg = <0x12C30000 0x100>; | 176 | reg = <0x12C30000 0x100>; |
117 | interrupts = <0 54 0>; | 177 | interrupts = <0 54 0>; |
178 | clocks = <&clock 292>, <&clock 149>; | ||
179 | clock-names = "uart", "clk_uart_baud0"; | ||
118 | }; | 180 | }; |
119 | 181 | ||
120 | sata@122F0000 { | 182 | sata@122F0000 { |
121 | compatible = "samsung,exynos5-sata-ahci"; | 183 | compatible = "samsung,exynos5-sata-ahci"; |
122 | reg = <0x122F0000 0x1ff>; | 184 | reg = <0x122F0000 0x1ff>; |
123 | interrupts = <0 115 0>; | 185 | interrupts = <0 115 0>; |
186 | clocks = <&clock 277>, <&clock 143>; | ||
187 | clock-names = "sata", "sclk_sata"; | ||
124 | }; | 188 | }; |
125 | 189 | ||
126 | sata-phy@12170000 { | 190 | sata-phy@12170000 { |
@@ -134,6 +198,8 @@ | |||
134 | interrupts = <0 56 0>; | 198 | interrupts = <0 56 0>; |
135 | #address-cells = <1>; | 199 | #address-cells = <1>; |
136 | #size-cells = <0>; | 200 | #size-cells = <0>; |
201 | clocks = <&clock 294>; | ||
202 | clock-names = "i2c"; | ||
137 | }; | 203 | }; |
138 | 204 | ||
139 | i2c_1: i2c@12C70000 { | 205 | i2c_1: i2c@12C70000 { |
@@ -142,6 +208,8 @@ | |||
142 | interrupts = <0 57 0>; | 208 | interrupts = <0 57 0>; |
143 | #address-cells = <1>; | 209 | #address-cells = <1>; |
144 | #size-cells = <0>; | 210 | #size-cells = <0>; |
211 | clocks = <&clock 295>; | ||
212 | clock-names = "i2c"; | ||
145 | }; | 213 | }; |
146 | 214 | ||
147 | i2c_2: i2c@12C80000 { | 215 | i2c_2: i2c@12C80000 { |
@@ -150,6 +218,8 @@ | |||
150 | interrupts = <0 58 0>; | 218 | interrupts = <0 58 0>; |
151 | #address-cells = <1>; | 219 | #address-cells = <1>; |
152 | #size-cells = <0>; | 220 | #size-cells = <0>; |
221 | clocks = <&clock 296>; | ||
222 | clock-names = "i2c"; | ||
153 | }; | 223 | }; |
154 | 224 | ||
155 | i2c_3: i2c@12C90000 { | 225 | i2c_3: i2c@12C90000 { |
@@ -158,6 +228,8 @@ | |||
158 | interrupts = <0 59 0>; | 228 | interrupts = <0 59 0>; |
159 | #address-cells = <1>; | 229 | #address-cells = <1>; |
160 | #size-cells = <0>; | 230 | #size-cells = <0>; |
231 | clocks = <&clock 297>; | ||
232 | clock-names = "i2c"; | ||
161 | }; | 233 | }; |
162 | 234 | ||
163 | i2c_4: i2c@12CA0000 { | 235 | i2c_4: i2c@12CA0000 { |
@@ -166,6 +238,8 @@ | |||
166 | interrupts = <0 60 0>; | 238 | interrupts = <0 60 0>; |
167 | #address-cells = <1>; | 239 | #address-cells = <1>; |
168 | #size-cells = <0>; | 240 | #size-cells = <0>; |
241 | clocks = <&clock 298>; | ||
242 | clock-names = "i2c"; | ||
169 | }; | 243 | }; |
170 | 244 | ||
171 | i2c_5: i2c@12CB0000 { | 245 | i2c_5: i2c@12CB0000 { |
@@ -174,6 +248,8 @@ | |||
174 | interrupts = <0 61 0>; | 248 | interrupts = <0 61 0>; |
175 | #address-cells = <1>; | 249 | #address-cells = <1>; |
176 | #size-cells = <0>; | 250 | #size-cells = <0>; |
251 | clocks = <&clock 299>; | ||
252 | clock-names = "i2c"; | ||
177 | }; | 253 | }; |
178 | 254 | ||
179 | i2c_6: i2c@12CC0000 { | 255 | i2c_6: i2c@12CC0000 { |
@@ -182,6 +258,8 @@ | |||
182 | interrupts = <0 62 0>; | 258 | interrupts = <0 62 0>; |
183 | #address-cells = <1>; | 259 | #address-cells = <1>; |
184 | #size-cells = <0>; | 260 | #size-cells = <0>; |
261 | clocks = <&clock 300>; | ||
262 | clock-names = "i2c"; | ||
185 | }; | 263 | }; |
186 | 264 | ||
187 | i2c_7: i2c@12CD0000 { | 265 | i2c_7: i2c@12CD0000 { |
@@ -190,6 +268,8 @@ | |||
190 | interrupts = <0 63 0>; | 268 | interrupts = <0 63 0>; |
191 | #address-cells = <1>; | 269 | #address-cells = <1>; |
192 | #size-cells = <0>; | 270 | #size-cells = <0>; |
271 | clocks = <&clock 301>; | ||
272 | clock-names = "i2c"; | ||
193 | }; | 273 | }; |
194 | 274 | ||
195 | i2c_8: i2c@12CE0000 { | 275 | i2c_8: i2c@12CE0000 { |
@@ -198,6 +278,8 @@ | |||
198 | interrupts = <0 64 0>; | 278 | interrupts = <0 64 0>; |
199 | #address-cells = <1>; | 279 | #address-cells = <1>; |
200 | #size-cells = <0>; | 280 | #size-cells = <0>; |
281 | clocks = <&clock 302>; | ||
282 | clock-names = "i2c"; | ||
201 | }; | 283 | }; |
202 | 284 | ||
203 | i2c@121D0000 { | 285 | i2c@121D0000 { |
@@ -205,6 +287,8 @@ | |||
205 | reg = <0x121D0000 0x100>; | 287 | reg = <0x121D0000 0x100>; |
206 | #address-cells = <1>; | 288 | #address-cells = <1>; |
207 | #size-cells = <0>; | 289 | #size-cells = <0>; |
290 | clocks = <&clock 288>; | ||
291 | clock-names = "i2c"; | ||
208 | }; | 292 | }; |
209 | 293 | ||
210 | spi_0: spi@12d20000 { | 294 | spi_0: spi@12d20000 { |
@@ -216,6 +300,8 @@ | |||
216 | dma-names = "tx", "rx"; | 300 | dma-names = "tx", "rx"; |
217 | #address-cells = <1>; | 301 | #address-cells = <1>; |
218 | #size-cells = <0>; | 302 | #size-cells = <0>; |
303 | clocks = <&clock 304>, <&clock 154>; | ||
304 | clock-names = "spi", "spi_busclk0"; | ||
219 | }; | 305 | }; |
220 | 306 | ||
221 | spi_1: spi@12d30000 { | 307 | spi_1: spi@12d30000 { |
@@ -227,6 +313,8 @@ | |||
227 | dma-names = "tx", "rx"; | 313 | dma-names = "tx", "rx"; |
228 | #address-cells = <1>; | 314 | #address-cells = <1>; |
229 | #size-cells = <0>; | 315 | #size-cells = <0>; |
316 | clocks = <&clock 305>, <&clock 155>; | ||
317 | clock-names = "spi", "spi_busclk0"; | ||
230 | }; | 318 | }; |
231 | 319 | ||
232 | spi_2: spi@12d40000 { | 320 | spi_2: spi@12d40000 { |
@@ -238,6 +326,8 @@ | |||
238 | dma-names = "tx", "rx"; | 326 | dma-names = "tx", "rx"; |
239 | #address-cells = <1>; | 327 | #address-cells = <1>; |
240 | #size-cells = <0>; | 328 | #size-cells = <0>; |
329 | clocks = <&clock 306>, <&clock 156>; | ||
330 | clock-names = "spi", "spi_busclk0"; | ||
241 | }; | 331 | }; |
242 | 332 | ||
243 | dwmmc_0: dwmmc0@12200000 { | 333 | dwmmc_0: dwmmc0@12200000 { |
@@ -246,6 +336,8 @@ | |||
246 | interrupts = <0 75 0>; | 336 | interrupts = <0 75 0>; |
247 | #address-cells = <1>; | 337 | #address-cells = <1>; |
248 | #size-cells = <0>; | 338 | #size-cells = <0>; |
339 | clocks = <&clock 280>, <&clock 139>; | ||
340 | clock-names = "biu", "ciu"; | ||
249 | }; | 341 | }; |
250 | 342 | ||
251 | dwmmc_1: dwmmc1@12210000 { | 343 | dwmmc_1: dwmmc1@12210000 { |
@@ -254,6 +346,8 @@ | |||
254 | interrupts = <0 76 0>; | 346 | interrupts = <0 76 0>; |
255 | #address-cells = <1>; | 347 | #address-cells = <1>; |
256 | #size-cells = <0>; | 348 | #size-cells = <0>; |
349 | clocks = <&clock 281>, <&clock 140>; | ||
350 | clock-names = "biu", "ciu"; | ||
257 | }; | 351 | }; |
258 | 352 | ||
259 | dwmmc_2: dwmmc2@12220000 { | 353 | dwmmc_2: dwmmc2@12220000 { |
@@ -262,6 +356,8 @@ | |||
262 | interrupts = <0 77 0>; | 356 | interrupts = <0 77 0>; |
263 | #address-cells = <1>; | 357 | #address-cells = <1>; |
264 | #size-cells = <0>; | 358 | #size-cells = <0>; |
359 | clocks = <&clock 282>, <&clock 141>; | ||
360 | clock-names = "biu", "ciu"; | ||
265 | }; | 361 | }; |
266 | 362 | ||
267 | dwmmc_3: dwmmc3@12230000 { | 363 | dwmmc_3: dwmmc3@12230000 { |
@@ -270,6 +366,8 @@ | |||
270 | interrupts = <0 78 0>; | 366 | interrupts = <0 78 0>; |
271 | #address-cells = <1>; | 367 | #address-cells = <1>; |
272 | #size-cells = <0>; | 368 | #size-cells = <0>; |
369 | clocks = <&clock 283>, <&clock 142>; | ||
370 | clock-names = "biu", "ciu"; | ||
273 | }; | 371 | }; |
274 | 372 | ||
275 | i2s0: i2s@03830000 { | 373 | i2s0: i2s@03830000 { |
@@ -301,6 +399,18 @@ | |||
301 | dma-names = "tx", "rx"; | 399 | dma-names = "tx", "rx"; |
302 | }; | 400 | }; |
303 | 401 | ||
402 | usb@12110000 { | ||
403 | compatible = "samsung,exynos4210-ehci"; | ||
404 | reg = <0x12110000 0x100>; | ||
405 | interrupts = <0 71 0>; | ||
406 | }; | ||
407 | |||
408 | usb@12120000 { | ||
409 | compatible = "samsung,exynos4210-ohci"; | ||
410 | reg = <0x12120000 0x100>; | ||
411 | interrupts = <0 71 0>; | ||
412 | }; | ||
413 | |||
304 | amba { | 414 | amba { |
305 | #address-cells = <1>; | 415 | #address-cells = <1>; |
306 | #size-cells = <1>; | 416 | #size-cells = <1>; |
@@ -312,6 +422,8 @@ | |||
312 | compatible = "arm,pl330", "arm,primecell"; | 422 | compatible = "arm,pl330", "arm,primecell"; |
313 | reg = <0x121A0000 0x1000>; | 423 | reg = <0x121A0000 0x1000>; |
314 | interrupts = <0 34 0>; | 424 | interrupts = <0 34 0>; |
425 | clocks = <&clock 275>; | ||
426 | clock-names = "apb_pclk"; | ||
315 | #dma-cells = <1>; | 427 | #dma-cells = <1>; |
316 | #dma-channels = <8>; | 428 | #dma-channels = <8>; |
317 | #dma-requests = <32>; | 429 | #dma-requests = <32>; |
@@ -321,6 +433,8 @@ | |||
321 | compatible = "arm,pl330", "arm,primecell"; | 433 | compatible = "arm,pl330", "arm,primecell"; |
322 | reg = <0x121B0000 0x1000>; | 434 | reg = <0x121B0000 0x1000>; |
323 | interrupts = <0 35 0>; | 435 | interrupts = <0 35 0>; |
436 | clocks = <&clock 276>; | ||
437 | clock-names = "apb_pclk"; | ||
324 | #dma-cells = <1>; | 438 | #dma-cells = <1>; |
325 | #dma-channels = <8>; | 439 | #dma-channels = <8>; |
326 | #dma-requests = <32>; | 440 | #dma-requests = <32>; |
@@ -330,6 +444,8 @@ | |||
330 | compatible = "arm,pl330", "arm,primecell"; | 444 | compatible = "arm,pl330", "arm,primecell"; |
331 | reg = <0x10800000 0x1000>; | 445 | reg = <0x10800000 0x1000>; |
332 | interrupts = <0 33 0>; | 446 | interrupts = <0 33 0>; |
447 | clocks = <&clock 271>; | ||
448 | clock-names = "apb_pclk"; | ||
333 | #dma-cells = <1>; | 449 | #dma-cells = <1>; |
334 | #dma-channels = <8>; | 450 | #dma-channels = <8>; |
335 | #dma-requests = <1>; | 451 | #dma-requests = <1>; |
@@ -339,6 +455,8 @@ | |||
339 | compatible = "arm,pl330", "arm,primecell"; | 455 | compatible = "arm,pl330", "arm,primecell"; |
340 | reg = <0x11C10000 0x1000>; | 456 | reg = <0x11C10000 0x1000>; |
341 | interrupts = <0 124 0>; | 457 | interrupts = <0 124 0>; |
458 | clocks = <&clock 271>; | ||
459 | clock-names = "apb_pclk"; | ||
342 | #dma-cells = <1>; | 460 | #dma-cells = <1>; |
343 | #dma-channels = <8>; | 461 | #dma-channels = <8>; |
344 | #dma-requests = <1>; | 462 | #dma-requests = <1>; |
@@ -592,34 +710,51 @@ | |||
592 | }; | 710 | }; |
593 | }; | 711 | }; |
594 | 712 | ||
713 | |||
595 | gsc_0: gsc@0x13e00000 { | 714 | gsc_0: gsc@0x13e00000 { |
596 | compatible = "samsung,exynos5-gsc"; | 715 | compatible = "samsung,exynos5-gsc"; |
597 | reg = <0x13e00000 0x1000>; | 716 | reg = <0x13e00000 0x1000>; |
598 | interrupts = <0 85 0>; | 717 | interrupts = <0 85 0>; |
718 | samsung,power-domain = <&pd_gsc>; | ||
719 | clocks = <&clock 256>; | ||
720 | clock-names = "gscl"; | ||
599 | }; | 721 | }; |
600 | 722 | ||
601 | gsc_1: gsc@0x13e10000 { | 723 | gsc_1: gsc@0x13e10000 { |
602 | compatible = "samsung,exynos5-gsc"; | 724 | compatible = "samsung,exynos5-gsc"; |
603 | reg = <0x13e10000 0x1000>; | 725 | reg = <0x13e10000 0x1000>; |
604 | interrupts = <0 86 0>; | 726 | interrupts = <0 86 0>; |
727 | samsung,power-domain = <&pd_gsc>; | ||
728 | clocks = <&clock 257>; | ||
729 | clock-names = "gscl"; | ||
605 | }; | 730 | }; |
606 | 731 | ||
607 | gsc_2: gsc@0x13e20000 { | 732 | gsc_2: gsc@0x13e20000 { |
608 | compatible = "samsung,exynos5-gsc"; | 733 | compatible = "samsung,exynos5-gsc"; |
609 | reg = <0x13e20000 0x1000>; | 734 | reg = <0x13e20000 0x1000>; |
610 | interrupts = <0 87 0>; | 735 | interrupts = <0 87 0>; |
736 | samsung,power-domain = <&pd_gsc>; | ||
737 | clocks = <&clock 258>; | ||
738 | clock-names = "gscl"; | ||
611 | }; | 739 | }; |
612 | 740 | ||
613 | gsc_3: gsc@0x13e30000 { | 741 | gsc_3: gsc@0x13e30000 { |
614 | compatible = "samsung,exynos5-gsc"; | 742 | compatible = "samsung,exynos5-gsc"; |
615 | reg = <0x13e30000 0x1000>; | 743 | reg = <0x13e30000 0x1000>; |
616 | interrupts = <0 88 0>; | 744 | interrupts = <0 88 0>; |
745 | samsung,power-domain = <&pd_gsc>; | ||
746 | clocks = <&clock 259>; | ||
747 | clock-names = "gscl"; | ||
617 | }; | 748 | }; |
618 | 749 | ||
619 | hdmi { | 750 | hdmi { |
620 | compatible = "samsung,exynos5-hdmi"; | 751 | compatible = "samsung,exynos5-hdmi"; |
621 | reg = <0x14530000 0x70000>; | 752 | reg = <0x14530000 0x70000>; |
622 | interrupts = <0 95 0>; | 753 | interrupts = <0 95 0>; |
754 | clocks = <&clock 333>, <&clock 136>, <&clock 137>, | ||
755 | <&clock 333>, <&clock 333>; | ||
756 | clock-names = "hdmi", "sclk_hdmi", "sclk_pixel", | ||
757 | "sclk_hdmiphy", "hdmiphy"; | ||
623 | }; | 758 | }; |
624 | 759 | ||
625 | mixer { | 760 | mixer { |
@@ -627,4 +762,18 @@ | |||
627 | reg = <0x14450000 0x10000>; | 762 | reg = <0x14450000 0x10000>; |
628 | interrupts = <0 94 0>; | 763 | interrupts = <0 94 0>; |
629 | }; | 764 | }; |
765 | |||
766 | dp-controller { | ||
767 | compatible = "samsung,exynos5-dp"; | ||
768 | reg = <0x145b0000 0x1000>; | ||
769 | interrupts = <10 3>; | ||
770 | interrupt-parent = <&combiner>; | ||
771 | #address-cells = <1>; | ||
772 | #size-cells = <0>; | ||
773 | |||
774 | dptx-phy { | ||
775 | reg = <0x10040720>; | ||
776 | samsung,enable-mask = <1>; | ||
777 | }; | ||
778 | }; | ||
630 | }; | 779 | }; |
diff --git a/arch/arm/boot/dts/exynos5440-ssdk5440.dts b/arch/arm/boot/dts/exynos5440-ssdk5440.dts index 81e2c964a900..a21eb4cbe893 100644 --- a/arch/arm/boot/dts/exynos5440-ssdk5440.dts +++ b/arch/arm/boot/dts/exynos5440-ssdk5440.dts | |||
@@ -28,19 +28,10 @@ | |||
28 | status = "disabled"; | 28 | status = "disabled"; |
29 | }; | 29 | }; |
30 | 30 | ||
31 | i2c@F0000 { | 31 | fixed-rate-clocks { |
32 | status = "disabled"; | 32 | xtal { |
33 | }; | 33 | compatible = "samsung,clock-xtal"; |
34 | 34 | clock-frequency = <50000000>; | |
35 | i2c@100000 { | 35 | }; |
36 | status = "disabled"; | ||
37 | }; | ||
38 | |||
39 | watchdog { | ||
40 | status = "disabled"; | ||
41 | }; | ||
42 | |||
43 | rtc { | ||
44 | status = "disabled"; | ||
45 | }; | 36 | }; |
46 | }; | 37 | }; |
diff --git a/arch/arm/boot/dts/exynos5440.dtsi b/arch/arm/boot/dts/exynos5440.dtsi index 9a99755920c0..48cc96aa0b5f 100644 --- a/arch/arm/boot/dts/exynos5440.dtsi +++ b/arch/arm/boot/dts/exynos5440.dtsi | |||
@@ -16,6 +16,12 @@ | |||
16 | 16 | ||
17 | interrupt-parent = <&gic>; | 17 | interrupt-parent = <&gic>; |
18 | 18 | ||
19 | clock: clock-controller@0x160000 { | ||
20 | compatible = "samsung,exynos5440-clock"; | ||
21 | reg = <0x160000 0x1000>; | ||
22 | #clock-cells = <1>; | ||
23 | }; | ||
24 | |||
19 | gic:interrupt-controller@2E0000 { | 25 | gic:interrupt-controller@2E0000 { |
20 | compatible = "arm,cortex-a15-gic"; | 26 | compatible = "arm,cortex-a15-gic"; |
21 | #interrupt-cells = <3>; | 27 | #interrupt-cells = <3>; |
@@ -24,55 +30,51 @@ | |||
24 | }; | 30 | }; |
25 | 31 | ||
26 | cpus { | 32 | cpus { |
33 | #address-cells = <1>; | ||
34 | #size-cells = <0>; | ||
35 | |||
27 | cpu@0 { | 36 | cpu@0 { |
28 | compatible = "arm,cortex-a15"; | 37 | compatible = "arm,cortex-a15"; |
29 | timer { | 38 | reg = <0>; |
30 | compatible = "arm,armv7-timer"; | ||
31 | interrupts = <1 13 0xf08>; | ||
32 | clock-frequency = <1000000>; | ||
33 | }; | ||
34 | }; | 39 | }; |
35 | cpu@1 { | 40 | cpu@1 { |
36 | compatible = "arm,cortex-a15"; | 41 | compatible = "arm,cortex-a15"; |
37 | timer { | 42 | reg = <1>; |
38 | compatible = "arm,armv7-timer"; | ||
39 | interrupts = <1 14 0xf08>; | ||
40 | clock-frequency = <1000000>; | ||
41 | }; | ||
42 | }; | 43 | }; |
43 | cpu@2 { | 44 | cpu@2 { |
44 | compatible = "arm,cortex-a15"; | 45 | compatible = "arm,cortex-a15"; |
45 | timer { | 46 | reg = <2>; |
46 | compatible = "arm,armv7-timer"; | ||
47 | interrupts = <1 14 0xf08>; | ||
48 | clock-frequency = <1000000>; | ||
49 | }; | ||
50 | }; | 47 | }; |
51 | cpu@3 { | 48 | cpu@3 { |
52 | compatible = "arm,cortex-a15"; | 49 | compatible = "arm,cortex-a15"; |
53 | timer { | 50 | reg = <3>; |
54 | compatible = "arm,armv7-timer"; | ||
55 | interrupts = <1 14 0xf08>; | ||
56 | clock-frequency = <1000000>; | ||
57 | }; | ||
58 | }; | 51 | }; |
59 | }; | 52 | }; |
60 | 53 | ||
61 | common { | 54 | timer { |
62 | compatible = "samsung,exynos5440"; | 55 | compatible = "arm,cortex-a15-timer", |
63 | 56 | "arm,armv7-timer"; | |
57 | interrupts = <1 13 0xf08>, | ||
58 | <1 14 0xf08>, | ||
59 | <1 11 0xf08>, | ||
60 | <1 10 0xf08>; | ||
61 | clock-frequency = <50000000>; | ||
64 | }; | 62 | }; |
65 | 63 | ||
66 | serial@B0000 { | 64 | serial@B0000 { |
67 | compatible = "samsung,exynos4210-uart"; | 65 | compatible = "samsung,exynos4210-uart"; |
68 | reg = <0xB0000 0x1000>; | 66 | reg = <0xB0000 0x1000>; |
69 | interrupts = <0 2 0>; | 67 | interrupts = <0 2 0>; |
68 | clocks = <&clock 21>, <&clock 21>; | ||
69 | clock-names = "uart", "clk_uart_baud0"; | ||
70 | }; | 70 | }; |
71 | 71 | ||
72 | serial@C0000 { | 72 | serial@C0000 { |
73 | compatible = "samsung,exynos4210-uart"; | 73 | compatible = "samsung,exynos4210-uart"; |
74 | reg = <0xC0000 0x1000>; | 74 | reg = <0xC0000 0x1000>; |
75 | interrupts = <0 3 0>; | 75 | interrupts = <0 3 0>; |
76 | clocks = <&clock 21>, <&clock 21>; | ||
77 | clock-names = "uart", "clk_uart_baud0"; | ||
76 | }; | 78 | }; |
77 | 79 | ||
78 | spi { | 80 | spi { |
@@ -83,6 +85,8 @@ | |||
83 | rx-dma-channel = <&pdma0 4>; /* preliminary */ | 85 | rx-dma-channel = <&pdma0 4>; /* preliminary */ |
84 | #address-cells = <1>; | 86 | #address-cells = <1>; |
85 | #size-cells = <0>; | 87 | #size-cells = <0>; |
88 | clocks = <&clock 21>, <&clock 16>; | ||
89 | clock-names = "spi", "spi_busclk0"; | ||
86 | }; | 90 | }; |
87 | 91 | ||
88 | pinctrl { | 92 | pinctrl { |
@@ -110,25 +114,31 @@ | |||
110 | }; | 114 | }; |
111 | 115 | ||
112 | i2c@F0000 { | 116 | i2c@F0000 { |
113 | compatible = "samsung,s3c2440-i2c"; | 117 | compatible = "samsung,exynos5440-i2c"; |
114 | reg = <0xF0000 0x1000>; | 118 | reg = <0xF0000 0x1000>; |
115 | interrupts = <0 5 0>; | 119 | interrupts = <0 5 0>; |
116 | #address-cells = <1>; | 120 | #address-cells = <1>; |
117 | #size-cells = <0>; | 121 | #size-cells = <0>; |
122 | clocks = <&clock 21>; | ||
123 | clock-names = "i2c"; | ||
118 | }; | 124 | }; |
119 | 125 | ||
120 | i2c@100000 { | 126 | i2c@100000 { |
121 | compatible = "samsung,s3c2440-i2c"; | 127 | compatible = "samsung,exynos5440-i2c"; |
122 | reg = <0x100000 0x1000>; | 128 | reg = <0x100000 0x1000>; |
123 | interrupts = <0 6 0>; | 129 | interrupts = <0 6 0>; |
124 | #address-cells = <1>; | 130 | #address-cells = <1>; |
125 | #size-cells = <0>; | 131 | #size-cells = <0>; |
132 | clocks = <&clock 21>; | ||
133 | clock-names = "i2c"; | ||
126 | }; | 134 | }; |
127 | 135 | ||
128 | watchdog { | 136 | watchdog { |
129 | compatible = "samsung,s3c2410-wdt"; | 137 | compatible = "samsung,s3c2410-wdt"; |
130 | reg = <0x110000 0x1000>; | 138 | reg = <0x110000 0x1000>; |
131 | interrupts = <0 1 0>; | 139 | interrupts = <0 1 0>; |
140 | clocks = <&clock 21>; | ||
141 | clock-names = "watchdog"; | ||
132 | }; | 142 | }; |
133 | 143 | ||
134 | amba { | 144 | amba { |
@@ -142,6 +152,8 @@ | |||
142 | compatible = "arm,pl330", "arm,primecell"; | 152 | compatible = "arm,pl330", "arm,primecell"; |
143 | reg = <0x120000 0x1000>; | 153 | reg = <0x120000 0x1000>; |
144 | interrupts = <0 34 0>; | 154 | interrupts = <0 34 0>; |
155 | clocks = <&clock 21>; | ||
156 | clock-names = "apb_pclk"; | ||
145 | #dma-cells = <1>; | 157 | #dma-cells = <1>; |
146 | #dma-channels = <8>; | 158 | #dma-channels = <8>; |
147 | #dma-requests = <32>; | 159 | #dma-requests = <32>; |
@@ -151,6 +163,8 @@ | |||
151 | compatible = "arm,pl330", "arm,primecell"; | 163 | compatible = "arm,pl330", "arm,primecell"; |
152 | reg = <0x121000 0x1000>; | 164 | reg = <0x121000 0x1000>; |
153 | interrupts = <0 35 0>; | 165 | interrupts = <0 35 0>; |
166 | clocks = <&clock 21>; | ||
167 | clock-names = "apb_pclk"; | ||
154 | #dma-cells = <1>; | 168 | #dma-cells = <1>; |
155 | #dma-channels = <8>; | 169 | #dma-channels = <8>; |
156 | #dma-requests = <32>; | 170 | #dma-requests = <32>; |
@@ -161,5 +175,8 @@ | |||
161 | compatible = "samsung,s3c6410-rtc"; | 175 | compatible = "samsung,s3c6410-rtc"; |
162 | reg = <0x130000 0x1000>; | 176 | reg = <0x130000 0x1000>; |
163 | interrupts = <0 17 0>, <0 16 0>; | 177 | interrupts = <0 17 0>, <0 16 0>; |
178 | clocks = <&clock 21>; | ||
179 | clock-names = "rtc"; | ||
180 | status = "disabled"; | ||
164 | }; | 181 | }; |
165 | }; | 182 | }; |
diff --git a/arch/arm/boot/dts/omap3-beagle.dts b/arch/arm/boot/dts/omap3-beagle.dts index f624dc85d441..02d23f15fd86 100644 --- a/arch/arm/boot/dts/omap3-beagle.dts +++ b/arch/arm/boot/dts/omap3-beagle.dts | |||
@@ -38,6 +38,57 @@ | |||
38 | }; | 38 | }; |
39 | }; | 39 | }; |
40 | 40 | ||
41 | /* HS USB Port 2 RESET */ | ||
42 | hsusb2_reset: hsusb2_reset_reg { | ||
43 | compatible = "regulator-fixed"; | ||
44 | regulator-name = "hsusb2_reset"; | ||
45 | regulator-min-microvolt = <3300000>; | ||
46 | regulator-max-microvolt = <3300000>; | ||
47 | gpio = <&gpio5 19 0>; /* gpio_147 */ | ||
48 | startup-delay-us = <70000>; | ||
49 | enable-active-high; | ||
50 | }; | ||
51 | |||
52 | /* HS USB Port 2 Power */ | ||
53 | hsusb2_power: hsusb2_power_reg { | ||
54 | compatible = "regulator-fixed"; | ||
55 | regulator-name = "hsusb2_vbus"; | ||
56 | regulator-min-microvolt = <3300000>; | ||
57 | regulator-max-microvolt = <3300000>; | ||
58 | gpio = <&twl_gpio 18 0>; /* GPIO LEDA */ | ||
59 | startup-delay-us = <70000>; | ||
60 | }; | ||
61 | |||
62 | /* HS USB Host PHY on PORT 2 */ | ||
63 | hsusb2_phy: hsusb2_phy { | ||
64 | compatible = "usb-nop-xceiv"; | ||
65 | reset-supply = <&hsusb2_reset>; | ||
66 | vcc-supply = <&hsusb2_power>; | ||
67 | }; | ||
68 | }; | ||
69 | |||
70 | &omap3_pmx_core { | ||
71 | pinctrl-names = "default"; | ||
72 | pinctrl-0 = < | ||
73 | &hsusbb2_pins | ||
74 | >; | ||
75 | |||
76 | hsusbb2_pins: pinmux_hsusbb2_pins { | ||
77 | pinctrl-single,pins = < | ||
78 | 0x5c0 0x3 /* USBB2_ULPITLL_CLK_MUXMODE.usbb1_ulpiphy_clk OUTPUT */ | ||
79 | 0x5c2 0x3 /* USBB2_ULPITLL_CLK_MUXMODE.usbb1_ulpiphy_stp OUTPUT */ | ||
80 | 0x5c4 0x10b /* USBB2_ULPITLL_CLK_MUXMODE.usbb1_ulpiphy_dir INPUT | PULLDOWN */ | ||
81 | 0x5c6 0x10b /* USBB2_ULPITLL_CLK_MUXMODE.usbb1_ulpiphy_nxt INPUT | PULLDOWN */ | ||
82 | 0x5c8 0x10b /* USBB2_ULPITLL_CLK_MUXMODE.usbb1_ulpiphy_dat0 INPUT | PULLDOWN */ | ||
83 | 0x5cA 0x10b /* USBB2_ULPITLL_CLK_MUXMODE.usbb1_ulpiphy_dat1 INPUT | PULLDOWN */ | ||
84 | 0x1a4 0x10b /* USBB2_ULPITLL_CLK_MUXMODE.usbb1_ulpiphy_dat2 INPUT | PULLDOWN */ | ||
85 | 0x1a6 0x10b /* USBB2_ULPITLL_CLK_MUXMODE.usbb1_ulpiphy_dat3 INPUT | PULLDOWN */ | ||
86 | 0x1a8 0x10b /* USBB2_ULPITLL_CLK_MUXMODE.usbb1_ulpiphy_dat4 INPUT | PULLDOWN */ | ||
87 | 0x1aa 0x10b /* USBB2_ULPITLL_CLK_MUXMODE.usbb1_ulpiphy_dat5 INPUT | PULLDOWN */ | ||
88 | 0x1ac 0x10b /* USBB2_ULPITLL_CLK_MUXMODE.usbb1_ulpiphy_dat6 INPUT | PULLDOWN */ | ||
89 | 0x1ae 0x10b /* USBB2_ULPITLL_CLK_MUXMODE.usbb1_ulpiphy_dat7 INPUT | PULLDOWN */ | ||
90 | >; | ||
91 | }; | ||
41 | }; | 92 | }; |
42 | 93 | ||
43 | &i2c1 { | 94 | &i2c1 { |
@@ -65,3 +116,23 @@ | |||
65 | &mmc3 { | 116 | &mmc3 { |
66 | status = "disabled"; | 117 | status = "disabled"; |
67 | }; | 118 | }; |
119 | |||
120 | &usbhshost { | ||
121 | port2-mode = "ehci-phy"; | ||
122 | }; | ||
123 | |||
124 | &usbhsehci { | ||
125 | phys = <0 &hsusb2_phy>; | ||
126 | }; | ||
127 | |||
128 | &twl_gpio { | ||
129 | ti,use-leds; | ||
130 | /* pullups: BIT(1) */ | ||
131 | ti,pullups = <0x000002>; | ||
132 | /* | ||
133 | * pulldowns: | ||
134 | * BIT(2), BIT(6), BIT(7), BIT(8), BIT(13) | ||
135 | * BIT(15), BIT(16), BIT(17) | ||
136 | */ | ||
137 | ti,pulldowns = <0x03a1c4>; | ||
138 | }; | ||
diff --git a/arch/arm/boot/dts/omap3.dtsi b/arch/arm/boot/dts/omap3.dtsi index 1acc26148ffc..a14f74bbce7c 100644 --- a/arch/arm/boot/dts/omap3.dtsi +++ b/arch/arm/boot/dts/omap3.dtsi | |||
@@ -397,5 +397,36 @@ | |||
397 | ti,timer-alwon; | 397 | ti,timer-alwon; |
398 | ti,timer-secure; | 398 | ti,timer-secure; |
399 | }; | 399 | }; |
400 | |||
401 | usbhstll: usbhstll@48062000 { | ||
402 | compatible = "ti,usbhs-tll"; | ||
403 | reg = <0x48062000 0x1000>; | ||
404 | interrupts = <78>; | ||
405 | ti,hwmods = "usb_tll_hs"; | ||
406 | }; | ||
407 | |||
408 | usbhshost: usbhshost@48064000 { | ||
409 | compatible = "ti,usbhs-host"; | ||
410 | reg = <0x48064000 0x400>; | ||
411 | ti,hwmods = "usb_host_hs"; | ||
412 | #address-cells = <1>; | ||
413 | #size-cells = <1>; | ||
414 | ranges; | ||
415 | |||
416 | usbhsohci: ohci@48064400 { | ||
417 | compatible = "ti,ohci-omap3", "usb-ohci"; | ||
418 | reg = <0x48064400 0x400>; | ||
419 | interrupt-parent = <&intc>; | ||
420 | interrupts = <76>; | ||
421 | }; | ||
422 | |||
423 | usbhsehci: ehci@48064800 { | ||
424 | compatible = "ti,ehci-omap", "usb-ehci"; | ||
425 | reg = <0x48064800 0x400>; | ||
426 | interrupt-parent = <&intc>; | ||
427 | interrupts = <77>; | ||
428 | }; | ||
429 | }; | ||
430 | |||
400 | }; | 431 | }; |
401 | }; | 432 | }; |
diff --git a/arch/arm/boot/dts/omap4.dtsi b/arch/arm/boot/dts/omap4.dtsi index 739bb79e410e..b7db1a2b6ca7 100644 --- a/arch/arm/boot/dts/omap4.dtsi +++ b/arch/arm/boot/dts/omap4.dtsi | |||
@@ -529,5 +529,35 @@ | |||
529 | ti,hwmods = "timer11"; | 529 | ti,hwmods = "timer11"; |
530 | ti,timer-pwm; | 530 | ti,timer-pwm; |
531 | }; | 531 | }; |
532 | |||
533 | usbhstll: usbhstll@4a062000 { | ||
534 | compatible = "ti,usbhs-tll"; | ||
535 | reg = <0x4a062000 0x1000>; | ||
536 | interrupts = <0 78 0x4>; | ||
537 | ti,hwmods = "usb_tll_hs"; | ||
538 | }; | ||
539 | |||
540 | usbhshost: usbhshost@4a064000 { | ||
541 | compatible = "ti,usbhs-host"; | ||
542 | reg = <0x4a064000 0x800>; | ||
543 | ti,hwmods = "usb_host_hs"; | ||
544 | #address-cells = <1>; | ||
545 | #size-cells = <1>; | ||
546 | ranges; | ||
547 | |||
548 | usbhsohci: ohci@4a064800 { | ||
549 | compatible = "ti,ohci-omap3", "usb-ohci"; | ||
550 | reg = <0x4a064800 0x400>; | ||
551 | interrupt-parent = <&gic>; | ||
552 | interrupts = <0 76 0x4>; | ||
553 | }; | ||
554 | |||
555 | usbhsehci: ehci@4a064c00 { | ||
556 | compatible = "ti,ehci-omap", "usb-ehci"; | ||
557 | reg = <0x4a064c00 0x400>; | ||
558 | interrupt-parent = <&gic>; | ||
559 | interrupts = <0 77 0x4>; | ||
560 | }; | ||
561 | }; | ||
532 | }; | 562 | }; |
533 | }; | 563 | }; |
diff --git a/arch/arm/boot/dts/tegra114-dalmore.dts b/arch/arm/boot/dts/tegra114-dalmore.dts index 6ebc1b704190..616990dc92db 100644 --- a/arch/arm/boot/dts/tegra114-dalmore.dts +++ b/arch/arm/boot/dts/tegra114-dalmore.dts | |||
@@ -12,7 +12,6 @@ | |||
12 | 12 | ||
13 | serial@70006300 { | 13 | serial@70006300 { |
14 | status = "okay"; | 14 | status = "okay"; |
15 | clock-frequency = <408000000>; | ||
16 | }; | 15 | }; |
17 | 16 | ||
18 | pmc { | 17 | pmc { |
diff --git a/arch/arm/boot/dts/tegra114-pluto.dts b/arch/arm/boot/dts/tegra114-pluto.dts index 5deb8692b350..6bbc8efae9c0 100644 --- a/arch/arm/boot/dts/tegra114-pluto.dts +++ b/arch/arm/boot/dts/tegra114-pluto.dts | |||
@@ -12,7 +12,6 @@ | |||
12 | 12 | ||
13 | serial@70006300 { | 13 | serial@70006300 { |
14 | status = "okay"; | 14 | status = "okay"; |
15 | clock-frequency = <408000000>; | ||
16 | }; | 15 | }; |
17 | 16 | ||
18 | pmc { | 17 | pmc { |
diff --git a/arch/arm/boot/dts/tegra114.dtsi b/arch/arm/boot/dts/tegra114.dtsi index c0b527d15fda..c1110a9b2a91 100644 --- a/arch/arm/boot/dts/tegra114.dtsi +++ b/arch/arm/boot/dts/tegra114.dtsi | |||
@@ -24,10 +24,11 @@ | |||
24 | 0 42 0x04 | 24 | 0 42 0x04 |
25 | 0 121 0x04 | 25 | 0 121 0x04 |
26 | 0 122 0x04>; | 26 | 0 122 0x04>; |
27 | clocks = <&tegra_car 5>; | ||
27 | }; | 28 | }; |
28 | 29 | ||
29 | tegra_car: clock { | 30 | tegra_car: clock { |
30 | compatible = "nvidia,tegra114-car, nvidia,tegra30-car"; | 31 | compatible = "nvidia,tegra114-car"; |
31 | reg = <0x60006000 0x1000>; | 32 | reg = <0x60006000 0x1000>; |
32 | #clock-cells = <1>; | 33 | #clock-cells = <1>; |
33 | }; | 34 | }; |
@@ -66,6 +67,7 @@ | |||
66 | reg-shift = <2>; | 67 | reg-shift = <2>; |
67 | interrupts = <0 36 0x04>; | 68 | interrupts = <0 36 0x04>; |
68 | status = "disabled"; | 69 | status = "disabled"; |
70 | clocks = <&tegra_car 6>; | ||
69 | }; | 71 | }; |
70 | 72 | ||
71 | serial@70006040 { | 73 | serial@70006040 { |
@@ -74,6 +76,7 @@ | |||
74 | reg-shift = <2>; | 76 | reg-shift = <2>; |
75 | interrupts = <0 37 0x04>; | 77 | interrupts = <0 37 0x04>; |
76 | status = "disabled"; | 78 | status = "disabled"; |
79 | clocks = <&tegra_car 192>; | ||
77 | }; | 80 | }; |
78 | 81 | ||
79 | serial@70006200 { | 82 | serial@70006200 { |
@@ -82,6 +85,7 @@ | |||
82 | reg-shift = <2>; | 85 | reg-shift = <2>; |
83 | interrupts = <0 46 0x04>; | 86 | interrupts = <0 46 0x04>; |
84 | status = "disabled"; | 87 | status = "disabled"; |
88 | clocks = <&tegra_car 55>; | ||
85 | }; | 89 | }; |
86 | 90 | ||
87 | serial@70006300 { | 91 | serial@70006300 { |
@@ -90,12 +94,14 @@ | |||
90 | reg-shift = <2>; | 94 | reg-shift = <2>; |
91 | interrupts = <0 90 0x04>; | 95 | interrupts = <0 90 0x04>; |
92 | status = "disabled"; | 96 | status = "disabled"; |
97 | clocks = <&tegra_car 65>; | ||
93 | }; | 98 | }; |
94 | 99 | ||
95 | rtc { | 100 | rtc { |
96 | compatible = "nvidia,tegra114-rtc", "nvidia,tegra20-rtc"; | 101 | compatible = "nvidia,tegra114-rtc", "nvidia,tegra20-rtc"; |
97 | reg = <0x7000e000 0x100>; | 102 | reg = <0x7000e000 0x100>; |
98 | interrupts = <0 2 0x04>; | 103 | interrupts = <0 2 0x04>; |
104 | clocks = <&tegra_car 4>; | ||
99 | }; | 105 | }; |
100 | 106 | ||
101 | pmc { | 107 | pmc { |
diff --git a/arch/arm/boot/dts/vt8500.dtsi b/arch/arm/boot/dts/vt8500.dtsi index 68c8dc644383..4a4b96f6827e 100644 --- a/arch/arm/boot/dts/vt8500.dtsi +++ b/arch/arm/boot/dts/vt8500.dtsi | |||
@@ -25,11 +25,13 @@ | |||
25 | #interrupt-cells = <1>; | 25 | #interrupt-cells = <1>; |
26 | }; | 26 | }; |
27 | 27 | ||
28 | gpio: gpio-controller@d8110000 { | 28 | pinctrl: pinctrl@d8110000 { |
29 | compatible = "via,vt8500-gpio"; | 29 | compatible = "via,vt8500-pinctrl"; |
30 | gpio-controller; | ||
31 | reg = <0xd8110000 0x10000>; | 30 | reg = <0xd8110000 0x10000>; |
32 | #gpio-cells = <3>; | 31 | interrupt-controller; |
32 | #interrupt-cells = <2>; | ||
33 | gpio-controller; | ||
34 | #gpio-cells = <2>; | ||
33 | }; | 35 | }; |
34 | 36 | ||
35 | pmc@d8130000 { | 37 | pmc@d8130000 { |
diff --git a/arch/arm/boot/dts/wm8505.dtsi b/arch/arm/boot/dts/wm8505.dtsi index 398b8bca791e..b2bf359e852f 100644 --- a/arch/arm/boot/dts/wm8505.dtsi +++ b/arch/arm/boot/dts/wm8505.dtsi | |||
@@ -40,11 +40,13 @@ | |||
40 | interrupts = <56 57 58 59 60 61 62 63>; | 40 | interrupts = <56 57 58 59 60 61 62 63>; |
41 | }; | 41 | }; |
42 | 42 | ||
43 | gpio: gpio-controller@d8110000 { | 43 | pinctrl: pinctrl@d8110000 { |
44 | compatible = "wm,wm8505-gpio"; | 44 | compatible = "wm,wm8505-pinctrl"; |
45 | gpio-controller; | ||
46 | reg = <0xd8110000 0x10000>; | 45 | reg = <0xd8110000 0x10000>; |
47 | #gpio-cells = <3>; | 46 | interrupt-controller; |
47 | #interrupt-cells = <2>; | ||
48 | gpio-controller; | ||
49 | #gpio-cells = <2>; | ||
48 | }; | 50 | }; |
49 | 51 | ||
50 | pmc@d8130000 { | 52 | pmc@d8130000 { |
diff --git a/arch/arm/boot/dts/wm8650.dtsi b/arch/arm/boot/dts/wm8650.dtsi index 9313407bbc30..dd8464eeb40d 100644 --- a/arch/arm/boot/dts/wm8650.dtsi +++ b/arch/arm/boot/dts/wm8650.dtsi | |||
@@ -34,11 +34,13 @@ | |||
34 | interrupts = <56 57 58 59 60 61 62 63>; | 34 | interrupts = <56 57 58 59 60 61 62 63>; |
35 | }; | 35 | }; |
36 | 36 | ||
37 | gpio: gpio-controller@d8110000 { | 37 | pinctrl: pinctrl@d8110000 { |
38 | compatible = "wm,wm8650-gpio"; | 38 | compatible = "wm,wm8650-pinctrl"; |
39 | gpio-controller; | ||
40 | reg = <0xd8110000 0x10000>; | 39 | reg = <0xd8110000 0x10000>; |
41 | #gpio-cells = <3>; | 40 | interrupt-controller; |
41 | #interrupt-cells = <2>; | ||
42 | gpio-controller; | ||
43 | #gpio-cells = <2>; | ||
42 | }; | 44 | }; |
43 | 45 | ||
44 | pmc@d8130000 { | 46 | pmc@d8130000 { |
diff --git a/arch/arm/boot/dts/wm8850.dtsi b/arch/arm/boot/dts/wm8850.dtsi index 7149cd13e3b9..fc790d0aee66 100644 --- a/arch/arm/boot/dts/wm8850.dtsi +++ b/arch/arm/boot/dts/wm8850.dtsi | |||
@@ -41,11 +41,13 @@ | |||
41 | interrupts = <56 57 58 59 60 61 62 63>; | 41 | interrupts = <56 57 58 59 60 61 62 63>; |
42 | }; | 42 | }; |
43 | 43 | ||
44 | gpio: gpio-controller@d8110000 { | 44 | pinctrl: pinctrl@d8110000 { |
45 | compatible = "wm,wm8650-gpio"; | 45 | compatible = "wm,wm8850-pinctrl"; |
46 | gpio-controller; | ||
47 | reg = <0xd8110000 0x10000>; | 46 | reg = <0xd8110000 0x10000>; |
48 | #gpio-cells = <3>; | 47 | interrupt-controller; |
48 | #interrupt-cells = <2>; | ||
49 | gpio-controller; | ||
50 | #gpio-cells = <2>; | ||
49 | }; | 51 | }; |
50 | 52 | ||
51 | pmc@d8130000 { | 53 | pmc@d8130000 { |
diff --git a/arch/arm/boot/dts/zynq-7000.dtsi b/arch/arm/boot/dts/zynq-7000.dtsi index 9e1c339c4491..748fc347ed18 100644 --- a/arch/arm/boot/dts/zynq-7000.dtsi +++ b/arch/arm/boot/dts/zynq-7000.dtsi | |||
@@ -118,56 +118,23 @@ | |||
118 | }; | 118 | }; |
119 | 119 | ||
120 | ttc0: ttc0@f8001000 { | 120 | ttc0: ttc0@f8001000 { |
121 | #address-cells = <1>; | 121 | interrupt-parent = <&intc>; |
122 | #size-cells = <0>; | 122 | interrupts = < 0 10 4 0 11 4 0 12 4 >; |
123 | compatible = "xlnx,ttc"; | 123 | compatible = "cdns,ttc"; |
124 | reg = <0xF8001000 0x1000>; | 124 | reg = <0xF8001000 0x1000>; |
125 | clocks = <&cpu_clk 3>; | 125 | clocks = <&cpu_clk 3>; |
126 | clock-names = "cpu_1x"; | 126 | clock-names = "cpu_1x"; |
127 | clock-ranges; | 127 | clock-ranges; |
128 | |||
129 | ttc0_0: ttc0.0 { | ||
130 | status = "disabled"; | ||
131 | reg = <0>; | ||
132 | interrupts = <0 10 4>; | ||
133 | }; | ||
134 | ttc0_1: ttc0.1 { | ||
135 | status = "disabled"; | ||
136 | reg = <1>; | ||
137 | interrupts = <0 11 4>; | ||
138 | }; | ||
139 | ttc0_2: ttc0.2 { | ||
140 | status = "disabled"; | ||
141 | reg = <2>; | ||
142 | interrupts = <0 12 4>; | ||
143 | }; | ||
144 | }; | 128 | }; |
145 | 129 | ||
146 | ttc1: ttc1@f8002000 { | 130 | ttc1: ttc1@f8002000 { |
147 | #interrupt-parent = <&intc>; | 131 | interrupt-parent = <&intc>; |
148 | #address-cells = <1>; | 132 | interrupts = < 0 37 4 0 38 4 0 39 4 >; |
149 | #size-cells = <0>; | 133 | compatible = "cdns,ttc"; |
150 | compatible = "xlnx,ttc"; | ||
151 | reg = <0xF8002000 0x1000>; | 134 | reg = <0xF8002000 0x1000>; |
152 | clocks = <&cpu_clk 3>; | 135 | clocks = <&cpu_clk 3>; |
153 | clock-names = "cpu_1x"; | 136 | clock-names = "cpu_1x"; |
154 | clock-ranges; | 137 | clock-ranges; |
155 | |||
156 | ttc1_0: ttc1.0 { | ||
157 | status = "disabled"; | ||
158 | reg = <0>; | ||
159 | interrupts = <0 37 4>; | ||
160 | }; | ||
161 | ttc1_1: ttc1.1 { | ||
162 | status = "disabled"; | ||
163 | reg = <1>; | ||
164 | interrupts = <0 38 4>; | ||
165 | }; | ||
166 | ttc1_2: ttc1.2 { | ||
167 | status = "disabled"; | ||
168 | reg = <2>; | ||
169 | interrupts = <0 39 4>; | ||
170 | }; | ||
171 | }; | 138 | }; |
172 | }; | 139 | }; |
173 | }; | 140 | }; |
diff --git a/arch/arm/boot/dts/zynq-zc702.dts b/arch/arm/boot/dts/zynq-zc702.dts index c772942a399a..86f44d5b0265 100644 --- a/arch/arm/boot/dts/zynq-zc702.dts +++ b/arch/arm/boot/dts/zynq-zc702.dts | |||
@@ -32,13 +32,3 @@ | |||
32 | &ps_clk { | 32 | &ps_clk { |
33 | clock-frequency = <33333330>; | 33 | clock-frequency = <33333330>; |
34 | }; | 34 | }; |
35 | |||
36 | &ttc0_0 { | ||
37 | status = "ok"; | ||
38 | compatible = "xlnx,ttc-counter-clocksource"; | ||
39 | }; | ||
40 | |||
41 | &ttc0_1 { | ||
42 | status = "ok"; | ||
43 | compatible = "xlnx,ttc-counter-clockevent"; | ||
44 | }; | ||
diff --git a/arch/arm/mach-at91/at91sam9261.c b/arch/arm/mach-at91/at91sam9261.c index ac7a341bd0ff..25efb5ac30f1 100644 --- a/arch/arm/mach-at91/at91sam9261.c +++ b/arch/arm/mach-at91/at91sam9261.c | |||
@@ -169,6 +169,8 @@ static struct clk *periph_clocks[] __initdata = { | |||
169 | }; | 169 | }; |
170 | 170 | ||
171 | static struct clk_lookup periph_clocks_lookups[] = { | 171 | static struct clk_lookup periph_clocks_lookups[] = { |
172 | CLKDEV_CON_DEV_ID("hclk", "at91sam9261-lcdfb.0", &hck1), | ||
173 | CLKDEV_CON_DEV_ID("hclk", "at91sam9g10-lcdfb.0", &hck1), | ||
172 | CLKDEV_CON_DEV_ID("spi_clk", "atmel_spi.0", &spi0_clk), | 174 | CLKDEV_CON_DEV_ID("spi_clk", "atmel_spi.0", &spi0_clk), |
173 | CLKDEV_CON_DEV_ID("spi_clk", "atmel_spi.1", &spi1_clk), | 175 | CLKDEV_CON_DEV_ID("spi_clk", "atmel_spi.1", &spi1_clk), |
174 | CLKDEV_CON_DEV_ID("t0_clk", "atmel_tcb.0", &tc0_clk), | 176 | CLKDEV_CON_DEV_ID("t0_clk", "atmel_tcb.0", &tc0_clk), |
diff --git a/arch/arm/mach-at91/at91sam9261_devices.c b/arch/arm/mach-at91/at91sam9261_devices.c index 92e0f861084a..629ea5fc95cf 100644 --- a/arch/arm/mach-at91/at91sam9261_devices.c +++ b/arch/arm/mach-at91/at91sam9261_devices.c | |||
@@ -488,7 +488,6 @@ static struct resource lcdc_resources[] = { | |||
488 | }; | 488 | }; |
489 | 489 | ||
490 | static struct platform_device at91_lcdc_device = { | 490 | static struct platform_device at91_lcdc_device = { |
491 | .name = "atmel_lcdfb", | ||
492 | .id = 0, | 491 | .id = 0, |
493 | .dev = { | 492 | .dev = { |
494 | .dma_mask = &lcdc_dmamask, | 493 | .dma_mask = &lcdc_dmamask, |
@@ -505,6 +504,11 @@ void __init at91_add_device_lcdc(struct atmel_lcdfb_info *data) | |||
505 | return; | 504 | return; |
506 | } | 505 | } |
507 | 506 | ||
507 | if (cpu_is_at91sam9g10()) | ||
508 | at91_lcdc_device.name = "at91sam9g10-lcdfb"; | ||
509 | else | ||
510 | at91_lcdc_device.name = "at91sam9261-lcdfb"; | ||
511 | |||
508 | #if defined(CONFIG_FB_ATMEL_STN) | 512 | #if defined(CONFIG_FB_ATMEL_STN) |
509 | at91_set_A_periph(AT91_PIN_PB0, 0); /* LCDVSYNC */ | 513 | at91_set_A_periph(AT91_PIN_PB0, 0); /* LCDVSYNC */ |
510 | at91_set_A_periph(AT91_PIN_PB1, 0); /* LCDHSYNC */ | 514 | at91_set_A_periph(AT91_PIN_PB1, 0); /* LCDHSYNC */ |
diff --git a/arch/arm/mach-at91/at91sam9263.c b/arch/arm/mach-at91/at91sam9263.c index 8e2d9f4a9a45..f44ffd2105a7 100644 --- a/arch/arm/mach-at91/at91sam9263.c +++ b/arch/arm/mach-at91/at91sam9263.c | |||
@@ -190,6 +190,7 @@ static struct clk_lookup periph_clocks_lookups[] = { | |||
190 | CLKDEV_CON_DEV_ID("pclk", "at91rm9200_ssc.1", &ssc1_clk), | 190 | CLKDEV_CON_DEV_ID("pclk", "at91rm9200_ssc.1", &ssc1_clk), |
191 | CLKDEV_CON_DEV_ID("pclk", "fff98000.ssc", &ssc0_clk), | 191 | CLKDEV_CON_DEV_ID("pclk", "fff98000.ssc", &ssc0_clk), |
192 | CLKDEV_CON_DEV_ID("pclk", "fff9c000.ssc", &ssc1_clk), | 192 | CLKDEV_CON_DEV_ID("pclk", "fff9c000.ssc", &ssc1_clk), |
193 | CLKDEV_CON_DEV_ID("hclk", "at91sam9263-lcdfb.0", &lcdc_clk), | ||
193 | CLKDEV_CON_DEV_ID("mci_clk", "atmel_mci.0", &mmc0_clk), | 194 | CLKDEV_CON_DEV_ID("mci_clk", "atmel_mci.0", &mmc0_clk), |
194 | CLKDEV_CON_DEV_ID("mci_clk", "atmel_mci.1", &mmc1_clk), | 195 | CLKDEV_CON_DEV_ID("mci_clk", "atmel_mci.1", &mmc1_clk), |
195 | CLKDEV_CON_DEV_ID("spi_clk", "atmel_spi.0", &spi0_clk), | 196 | CLKDEV_CON_DEV_ID("spi_clk", "atmel_spi.0", &spi0_clk), |
diff --git a/arch/arm/mach-at91/at91sam9263_devices.c b/arch/arm/mach-at91/at91sam9263_devices.c index ed666f5cb01d..858c8aac2daf 100644 --- a/arch/arm/mach-at91/at91sam9263_devices.c +++ b/arch/arm/mach-at91/at91sam9263_devices.c | |||
@@ -848,7 +848,7 @@ static struct resource lcdc_resources[] = { | |||
848 | }; | 848 | }; |
849 | 849 | ||
850 | static struct platform_device at91_lcdc_device = { | 850 | static struct platform_device at91_lcdc_device = { |
851 | .name = "atmel_lcdfb", | 851 | .name = "at91sam9263-lcdfb", |
852 | .id = 0, | 852 | .id = 0, |
853 | .dev = { | 853 | .dev = { |
854 | .dma_mask = &lcdc_dmamask, | 854 | .dma_mask = &lcdc_dmamask, |
diff --git a/arch/arm/mach-at91/at91sam9g45.c b/arch/arm/mach-at91/at91sam9g45.c index a6c224fc9542..8b7fce067652 100644 --- a/arch/arm/mach-at91/at91sam9g45.c +++ b/arch/arm/mach-at91/at91sam9g45.c | |||
@@ -228,6 +228,8 @@ static struct clk_lookup periph_clocks_lookups[] = { | |||
228 | CLKDEV_CON_ID("hclk", &macb_clk), | 228 | CLKDEV_CON_ID("hclk", &macb_clk), |
229 | /* One additional fake clock for ohci */ | 229 | /* One additional fake clock for ohci */ |
230 | CLKDEV_CON_ID("ohci_clk", &uhphs_clk), | 230 | CLKDEV_CON_ID("ohci_clk", &uhphs_clk), |
231 | CLKDEV_CON_DEV_ID("hclk", "at91sam9g45-lcdfb.0", &lcdc_clk), | ||
232 | CLKDEV_CON_DEV_ID("hclk", "at91sam9g45es-lcdfb.0", &lcdc_clk), | ||
231 | CLKDEV_CON_DEV_ID("ehci_clk", "atmel-ehci", &uhphs_clk), | 233 | CLKDEV_CON_DEV_ID("ehci_clk", "atmel-ehci", &uhphs_clk), |
232 | CLKDEV_CON_DEV_ID("hclk", "atmel_usba_udc", &utmi_clk), | 234 | CLKDEV_CON_DEV_ID("hclk", "atmel_usba_udc", &utmi_clk), |
233 | CLKDEV_CON_DEV_ID("pclk", "atmel_usba_udc", &udphs_clk), | 235 | CLKDEV_CON_DEV_ID("pclk", "atmel_usba_udc", &udphs_clk), |
diff --git a/arch/arm/mach-at91/at91sam9g45_devices.c b/arch/arm/mach-at91/at91sam9g45_devices.c index f0bf68268ca2..acb703e13331 100644 --- a/arch/arm/mach-at91/at91sam9g45_devices.c +++ b/arch/arm/mach-at91/at91sam9g45_devices.c | |||
@@ -981,7 +981,6 @@ static struct resource lcdc_resources[] = { | |||
981 | }; | 981 | }; |
982 | 982 | ||
983 | static struct platform_device at91_lcdc_device = { | 983 | static struct platform_device at91_lcdc_device = { |
984 | .name = "atmel_lcdfb", | ||
985 | .id = 0, | 984 | .id = 0, |
986 | .dev = { | 985 | .dev = { |
987 | .dma_mask = &lcdc_dmamask, | 986 | .dma_mask = &lcdc_dmamask, |
@@ -997,6 +996,11 @@ void __init at91_add_device_lcdc(struct atmel_lcdfb_info *data) | |||
997 | if (!data) | 996 | if (!data) |
998 | return; | 997 | return; |
999 | 998 | ||
999 | if (cpu_is_at91sam9g45es()) | ||
1000 | at91_lcdc_device.name = "at91sam9g45es-lcdfb"; | ||
1001 | else | ||
1002 | at91_lcdc_device.name = "at91sam9g45-lcdfb"; | ||
1003 | |||
1000 | at91_set_A_periph(AT91_PIN_PE0, 0); /* LCDDPWR */ | 1004 | at91_set_A_periph(AT91_PIN_PE0, 0); /* LCDDPWR */ |
1001 | 1005 | ||
1002 | at91_set_A_periph(AT91_PIN_PE2, 0); /* LCDCC */ | 1006 | at91_set_A_periph(AT91_PIN_PE2, 0); /* LCDCC */ |
diff --git a/arch/arm/mach-at91/at91sam9rl.c b/arch/arm/mach-at91/at91sam9rl.c index c39600764236..f77fae5591bc 100644 --- a/arch/arm/mach-at91/at91sam9rl.c +++ b/arch/arm/mach-at91/at91sam9rl.c | |||
@@ -179,6 +179,7 @@ static struct clk *periph_clocks[] __initdata = { | |||
179 | }; | 179 | }; |
180 | 180 | ||
181 | static struct clk_lookup periph_clocks_lookups[] = { | 181 | static struct clk_lookup periph_clocks_lookups[] = { |
182 | CLKDEV_CON_DEV_ID("hclk", "at91sam9rl-lcdfb.0", &lcdc_clk), | ||
182 | CLKDEV_CON_DEV_ID("hclk", "atmel_usba_udc", &utmi_clk), | 183 | CLKDEV_CON_DEV_ID("hclk", "atmel_usba_udc", &utmi_clk), |
183 | CLKDEV_CON_DEV_ID("pclk", "atmel_usba_udc", &udphs_clk), | 184 | CLKDEV_CON_DEV_ID("pclk", "atmel_usba_udc", &udphs_clk), |
184 | CLKDEV_CON_DEV_ID("t0_clk", "atmel_tcb.0", &tc0_clk), | 185 | CLKDEV_CON_DEV_ID("t0_clk", "atmel_tcb.0", &tc0_clk), |
diff --git a/arch/arm/mach-at91/at91sam9rl_devices.c b/arch/arm/mach-at91/at91sam9rl_devices.c index ddf223ff35c4..352468f265a9 100644 --- a/arch/arm/mach-at91/at91sam9rl_devices.c +++ b/arch/arm/mach-at91/at91sam9rl_devices.c | |||
@@ -514,7 +514,7 @@ static struct resource lcdc_resources[] = { | |||
514 | }; | 514 | }; |
515 | 515 | ||
516 | static struct platform_device at91_lcdc_device = { | 516 | static struct platform_device at91_lcdc_device = { |
517 | .name = "atmel_lcdfb", | 517 | .name = "at91sam9rl-lcdfb", |
518 | .id = 0, | 518 | .id = 0, |
519 | .dev = { | 519 | .dev = { |
520 | .dma_mask = &lcdc_dmamask, | 520 | .dma_mask = &lcdc_dmamask, |
diff --git a/arch/arm/mach-exynos/Kconfig b/arch/arm/mach-exynos/Kconfig index f22f69e2d081..d19edff0ea6e 100644 --- a/arch/arm/mach-exynos/Kconfig +++ b/arch/arm/mach-exynos/Kconfig | |||
@@ -63,6 +63,7 @@ config SOC_EXYNOS5250 | |||
63 | bool "SAMSUNG EXYNOS5250" | 63 | bool "SAMSUNG EXYNOS5250" |
64 | default y | 64 | default y |
65 | depends on ARCH_EXYNOS5 | 65 | depends on ARCH_EXYNOS5 |
66 | select PM_GENERIC_DOMAINS if PM | ||
66 | select S5P_PM if PM | 67 | select S5P_PM if PM |
67 | select S5P_SLEEP if PM | 68 | select S5P_SLEEP if PM |
68 | select S5P_DEV_MFC | 69 | select S5P_DEV_MFC |
@@ -83,12 +84,6 @@ config SOC_EXYNOS5440 | |||
83 | help | 84 | help |
84 | Enable EXYNOS5440 SoC support | 85 | Enable EXYNOS5440 SoC support |
85 | 86 | ||
86 | config EXYNOS4_MCT | ||
87 | bool | ||
88 | default y | ||
89 | help | ||
90 | Use MCT (Multi Core Timer) as kernel timers | ||
91 | |||
92 | config EXYNOS_ATAGS | 87 | config EXYNOS_ATAGS |
93 | bool "ATAGS based boot for EXYNOS (deprecated)" | 88 | bool "ATAGS based boot for EXYNOS (deprecated)" |
94 | depends on !ARCH_MULTIPLATFORM | 89 | depends on !ARCH_MULTIPLATFORM |
@@ -285,8 +280,8 @@ config MACH_UNIVERSAL_C210 | |||
285 | select S5P_DEV_ONENAND | 280 | select S5P_DEV_ONENAND |
286 | select S5P_DEV_TV | 281 | select S5P_DEV_TV |
287 | select S5P_GPIO_INT | 282 | select S5P_GPIO_INT |
288 | select S5P_HRT | ||
289 | select S5P_SETUP_MIPIPHY | 283 | select S5P_SETUP_MIPIPHY |
284 | select SAMSUNG_HRT | ||
290 | help | 285 | help |
291 | Machine support for Samsung Mobile Universal S5PC210 Reference | 286 | Machine support for Samsung Mobile Universal S5PC210 Reference |
292 | Board. | 287 | Board. |
@@ -414,10 +409,12 @@ config MACH_EXYNOS4_DT | |||
414 | bool "Samsung Exynos4 Machine using device tree" | 409 | bool "Samsung Exynos4 Machine using device tree" |
415 | depends on ARCH_EXYNOS4 | 410 | depends on ARCH_EXYNOS4 |
416 | select ARM_AMBA | 411 | select ARM_AMBA |
412 | select CLKSRC_OF | ||
417 | select CPU_EXYNOS4210 | 413 | select CPU_EXYNOS4210 |
418 | select KEYBOARD_SAMSUNG if INPUT_KEYBOARD | 414 | select KEYBOARD_SAMSUNG if INPUT_KEYBOARD |
419 | select PINCTRL | 415 | select PINCTRL |
420 | select PINCTRL_EXYNOS | 416 | select PINCTRL_EXYNOS |
417 | select S5P_DEV_MFC | ||
421 | select USE_OF | 418 | select USE_OF |
422 | help | 419 | help |
423 | Machine support for Samsung Exynos4 machine with device tree enabled. | 420 | Machine support for Samsung Exynos4 machine with device tree enabled. |
@@ -430,6 +427,7 @@ config MACH_EXYNOS5_DT | |||
430 | default y | 427 | default y |
431 | depends on ARCH_EXYNOS5 | 428 | depends on ARCH_EXYNOS5 |
432 | select ARM_AMBA | 429 | select ARM_AMBA |
430 | select CLKSRC_OF | ||
433 | select USE_OF | 431 | select USE_OF |
434 | help | 432 | help |
435 | Machine support for Samsung EXYNOS5 machine with device tree enabled. | 433 | Machine support for Samsung EXYNOS5 machine with device tree enabled. |
diff --git a/arch/arm/mach-exynos/Makefile b/arch/arm/mach-exynos/Makefile index 435757e57bb4..d2f6b362b6dd 100644 --- a/arch/arm/mach-exynos/Makefile +++ b/arch/arm/mach-exynos/Makefile | |||
@@ -13,10 +13,6 @@ obj- := | |||
13 | # Core | 13 | # Core |
14 | 14 | ||
15 | obj-$(CONFIG_ARCH_EXYNOS) += common.o | 15 | obj-$(CONFIG_ARCH_EXYNOS) += common.o |
16 | obj-$(CONFIG_ARCH_EXYNOS4) += clock-exynos4.o | ||
17 | obj-$(CONFIG_CPU_EXYNOS4210) += clock-exynos4210.o | ||
18 | obj-$(CONFIG_SOC_EXYNOS4212) += clock-exynos4212.o | ||
19 | obj-$(CONFIG_SOC_EXYNOS5250) += clock-exynos5.o | ||
20 | 16 | ||
21 | obj-$(CONFIG_PM) += pm.o | 17 | obj-$(CONFIG_PM) += pm.o |
22 | obj-$(CONFIG_PM_GENERIC_DOMAINS) += pm_domains.o | 18 | obj-$(CONFIG_PM_GENERIC_DOMAINS) += pm_domains.o |
@@ -26,8 +22,6 @@ obj-$(CONFIG_ARCH_EXYNOS) += pmu.o | |||
26 | 22 | ||
27 | obj-$(CONFIG_SMP) += platsmp.o headsmp.o | 23 | obj-$(CONFIG_SMP) += platsmp.o headsmp.o |
28 | 24 | ||
29 | obj-$(CONFIG_EXYNOS4_MCT) += mct.o | ||
30 | |||
31 | obj-$(CONFIG_HOTPLUG_CPU) += hotplug.o | 25 | obj-$(CONFIG_HOTPLUG_CPU) += hotplug.o |
32 | 26 | ||
33 | # machine support | 27 | # machine support |
diff --git a/arch/arm/mach-exynos/clock-exynos4.c b/arch/arm/mach-exynos/clock-exynos4.c deleted file mode 100644 index 8a8468d83c8c..000000000000 --- a/arch/arm/mach-exynos/clock-exynos4.c +++ /dev/null | |||
@@ -1,1601 +0,0 @@ | |||
1 | /* | ||
2 | * Copyright (c) 2010-2012 Samsung Electronics Co., Ltd. | ||
3 | * http://www.samsung.com | ||
4 | * | ||
5 | * EXYNOS4 - Clock support | ||
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 | |||
12 | #include <linux/kernel.h> | ||
13 | #include <linux/err.h> | ||
14 | #include <linux/io.h> | ||
15 | #include <linux/syscore_ops.h> | ||
16 | |||
17 | #include <plat/cpu-freq.h> | ||
18 | #include <plat/clock.h> | ||
19 | #include <plat/cpu.h> | ||
20 | #include <plat/pll.h> | ||
21 | #include <plat/s5p-clock.h> | ||
22 | #include <plat/clock-clksrc.h> | ||
23 | #include <plat/pm.h> | ||
24 | |||
25 | #include <mach/map.h> | ||
26 | #include <mach/regs-clock.h> | ||
27 | |||
28 | #include "common.h" | ||
29 | #include "clock-exynos4.h" | ||
30 | |||
31 | #ifdef CONFIG_PM_SLEEP | ||
32 | static struct sleep_save exynos4_clock_save[] = { | ||
33 | SAVE_ITEM(EXYNOS4_CLKDIV_LEFTBUS), | ||
34 | SAVE_ITEM(EXYNOS4_CLKGATE_IP_LEFTBUS), | ||
35 | SAVE_ITEM(EXYNOS4_CLKDIV_RIGHTBUS), | ||
36 | SAVE_ITEM(EXYNOS4_CLKGATE_IP_RIGHTBUS), | ||
37 | SAVE_ITEM(EXYNOS4_CLKSRC_TOP0), | ||
38 | SAVE_ITEM(EXYNOS4_CLKSRC_TOP1), | ||
39 | SAVE_ITEM(EXYNOS4_CLKSRC_CAM), | ||
40 | SAVE_ITEM(EXYNOS4_CLKSRC_TV), | ||
41 | SAVE_ITEM(EXYNOS4_CLKSRC_MFC), | ||
42 | SAVE_ITEM(EXYNOS4_CLKSRC_G3D), | ||
43 | SAVE_ITEM(EXYNOS4_CLKSRC_LCD0), | ||
44 | SAVE_ITEM(EXYNOS4_CLKSRC_MAUDIO), | ||
45 | SAVE_ITEM(EXYNOS4_CLKSRC_FSYS), | ||
46 | SAVE_ITEM(EXYNOS4_CLKSRC_PERIL0), | ||
47 | SAVE_ITEM(EXYNOS4_CLKSRC_PERIL1), | ||
48 | SAVE_ITEM(EXYNOS4_CLKDIV_CAM), | ||
49 | SAVE_ITEM(EXYNOS4_CLKDIV_TV), | ||
50 | SAVE_ITEM(EXYNOS4_CLKDIV_MFC), | ||
51 | SAVE_ITEM(EXYNOS4_CLKDIV_G3D), | ||
52 | SAVE_ITEM(EXYNOS4_CLKDIV_LCD0), | ||
53 | SAVE_ITEM(EXYNOS4_CLKDIV_MAUDIO), | ||
54 | SAVE_ITEM(EXYNOS4_CLKDIV_FSYS0), | ||
55 | SAVE_ITEM(EXYNOS4_CLKDIV_FSYS1), | ||
56 | SAVE_ITEM(EXYNOS4_CLKDIV_FSYS2), | ||
57 | SAVE_ITEM(EXYNOS4_CLKDIV_FSYS3), | ||
58 | SAVE_ITEM(EXYNOS4_CLKDIV_PERIL0), | ||
59 | SAVE_ITEM(EXYNOS4_CLKDIV_PERIL1), | ||
60 | SAVE_ITEM(EXYNOS4_CLKDIV_PERIL2), | ||
61 | SAVE_ITEM(EXYNOS4_CLKDIV_PERIL3), | ||
62 | SAVE_ITEM(EXYNOS4_CLKDIV_PERIL4), | ||
63 | SAVE_ITEM(EXYNOS4_CLKDIV_PERIL5), | ||
64 | SAVE_ITEM(EXYNOS4_CLKDIV_TOP), | ||
65 | SAVE_ITEM(EXYNOS4_CLKSRC_MASK_TOP), | ||
66 | SAVE_ITEM(EXYNOS4_CLKSRC_MASK_CAM), | ||
67 | SAVE_ITEM(EXYNOS4_CLKSRC_MASK_TV), | ||
68 | SAVE_ITEM(EXYNOS4_CLKSRC_MASK_LCD0), | ||
69 | SAVE_ITEM(EXYNOS4_CLKSRC_MASK_MAUDIO), | ||
70 | SAVE_ITEM(EXYNOS4_CLKSRC_MASK_FSYS), | ||
71 | SAVE_ITEM(EXYNOS4_CLKSRC_MASK_PERIL0), | ||
72 | SAVE_ITEM(EXYNOS4_CLKSRC_MASK_PERIL1), | ||
73 | SAVE_ITEM(EXYNOS4_CLKDIV2_RATIO), | ||
74 | SAVE_ITEM(EXYNOS4_CLKGATE_SCLKCAM), | ||
75 | SAVE_ITEM(EXYNOS4_CLKGATE_IP_CAM), | ||
76 | SAVE_ITEM(EXYNOS4_CLKGATE_IP_TV), | ||
77 | SAVE_ITEM(EXYNOS4_CLKGATE_IP_MFC), | ||
78 | SAVE_ITEM(EXYNOS4_CLKGATE_IP_G3D), | ||
79 | SAVE_ITEM(EXYNOS4_CLKGATE_IP_LCD0), | ||
80 | SAVE_ITEM(EXYNOS4_CLKGATE_IP_FSYS), | ||
81 | SAVE_ITEM(EXYNOS4_CLKGATE_IP_GPS), | ||
82 | SAVE_ITEM(EXYNOS4_CLKGATE_IP_PERIL), | ||
83 | SAVE_ITEM(EXYNOS4_CLKGATE_BLOCK), | ||
84 | SAVE_ITEM(EXYNOS4_CLKSRC_MASK_DMC), | ||
85 | SAVE_ITEM(EXYNOS4_CLKSRC_DMC), | ||
86 | SAVE_ITEM(EXYNOS4_CLKDIV_DMC0), | ||
87 | SAVE_ITEM(EXYNOS4_CLKDIV_DMC1), | ||
88 | SAVE_ITEM(EXYNOS4_CLKGATE_IP_DMC), | ||
89 | SAVE_ITEM(EXYNOS4_CLKSRC_CPU), | ||
90 | SAVE_ITEM(EXYNOS4_CLKDIV_CPU), | ||
91 | SAVE_ITEM(EXYNOS4_CLKDIV_CPU + 0x4), | ||
92 | SAVE_ITEM(EXYNOS4_CLKGATE_SCLKCPU), | ||
93 | SAVE_ITEM(EXYNOS4_CLKGATE_IP_CPU), | ||
94 | }; | ||
95 | #endif | ||
96 | |||
97 | static struct clk exynos4_clk_sclk_hdmi27m = { | ||
98 | .name = "sclk_hdmi27m", | ||
99 | .rate = 27000000, | ||
100 | }; | ||
101 | |||
102 | static struct clk exynos4_clk_sclk_hdmiphy = { | ||
103 | .name = "sclk_hdmiphy", | ||
104 | }; | ||
105 | |||
106 | static struct clk exynos4_clk_sclk_usbphy0 = { | ||
107 | .name = "sclk_usbphy0", | ||
108 | .rate = 27000000, | ||
109 | }; | ||
110 | |||
111 | static struct clk exynos4_clk_sclk_usbphy1 = { | ||
112 | .name = "sclk_usbphy1", | ||
113 | }; | ||
114 | |||
115 | static struct clk dummy_apb_pclk = { | ||
116 | .name = "apb_pclk", | ||
117 | .id = -1, | ||
118 | }; | ||
119 | |||
120 | static int exynos4_clksrc_mask_top_ctrl(struct clk *clk, int enable) | ||
121 | { | ||
122 | return s5p_gatectrl(EXYNOS4_CLKSRC_MASK_TOP, clk, enable); | ||
123 | } | ||
124 | |||
125 | static int exynos4_clksrc_mask_cam_ctrl(struct clk *clk, int enable) | ||
126 | { | ||
127 | return s5p_gatectrl(EXYNOS4_CLKSRC_MASK_CAM, clk, enable); | ||
128 | } | ||
129 | |||
130 | static int exynos4_clksrc_mask_lcd0_ctrl(struct clk *clk, int enable) | ||
131 | { | ||
132 | return s5p_gatectrl(EXYNOS4_CLKSRC_MASK_LCD0, clk, enable); | ||
133 | } | ||
134 | |||
135 | int exynos4_clksrc_mask_fsys_ctrl(struct clk *clk, int enable) | ||
136 | { | ||
137 | return s5p_gatectrl(EXYNOS4_CLKSRC_MASK_FSYS, clk, enable); | ||
138 | } | ||
139 | |||
140 | static int exynos4_clksrc_mask_peril0_ctrl(struct clk *clk, int enable) | ||
141 | { | ||
142 | return s5p_gatectrl(EXYNOS4_CLKSRC_MASK_PERIL0, clk, enable); | ||
143 | } | ||
144 | |||
145 | static int exynos4_clksrc_mask_peril1_ctrl(struct clk *clk, int enable) | ||
146 | { | ||
147 | return s5p_gatectrl(EXYNOS4_CLKSRC_MASK_PERIL1, clk, enable); | ||
148 | } | ||
149 | |||
150 | static int exynos4_clk_ip_mfc_ctrl(struct clk *clk, int enable) | ||
151 | { | ||
152 | return s5p_gatectrl(EXYNOS4_CLKGATE_IP_MFC, clk, enable); | ||
153 | } | ||
154 | |||
155 | static int exynos4_clksrc_mask_tv_ctrl(struct clk *clk, int enable) | ||
156 | { | ||
157 | return s5p_gatectrl(EXYNOS4_CLKSRC_MASK_TV, clk, enable); | ||
158 | } | ||
159 | |||
160 | static int exynos4_clk_ip_cam_ctrl(struct clk *clk, int enable) | ||
161 | { | ||
162 | return s5p_gatectrl(EXYNOS4_CLKGATE_IP_CAM, clk, enable); | ||
163 | } | ||
164 | |||
165 | static int exynos4_clk_ip_tv_ctrl(struct clk *clk, int enable) | ||
166 | { | ||
167 | return s5p_gatectrl(EXYNOS4_CLKGATE_IP_TV, clk, enable); | ||
168 | } | ||
169 | |||
170 | int exynos4_clk_ip_image_ctrl(struct clk *clk, int enable) | ||
171 | { | ||
172 | return s5p_gatectrl(EXYNOS4_CLKGATE_IP_IMAGE, clk, enable); | ||
173 | } | ||
174 | |||
175 | static int exynos4_clk_ip_lcd0_ctrl(struct clk *clk, int enable) | ||
176 | { | ||
177 | return s5p_gatectrl(EXYNOS4_CLKGATE_IP_LCD0, clk, enable); | ||
178 | } | ||
179 | |||
180 | int exynos4_clk_ip_lcd1_ctrl(struct clk *clk, int enable) | ||
181 | { | ||
182 | return s5p_gatectrl(EXYNOS4210_CLKGATE_IP_LCD1, clk, enable); | ||
183 | } | ||
184 | |||
185 | int exynos4_clk_ip_fsys_ctrl(struct clk *clk, int enable) | ||
186 | { | ||
187 | return s5p_gatectrl(EXYNOS4_CLKGATE_IP_FSYS, clk, enable); | ||
188 | } | ||
189 | |||
190 | static int exynos4_clk_ip_peril_ctrl(struct clk *clk, int enable) | ||
191 | { | ||
192 | return s5p_gatectrl(EXYNOS4_CLKGATE_IP_PERIL, clk, enable); | ||
193 | } | ||
194 | |||
195 | static int exynos4_clk_ip_perir_ctrl(struct clk *clk, int enable) | ||
196 | { | ||
197 | return s5p_gatectrl(EXYNOS4_CLKGATE_IP_PERIR, clk, enable); | ||
198 | } | ||
199 | |||
200 | int exynos4_clk_ip_dmc_ctrl(struct clk *clk, int enable) | ||
201 | { | ||
202 | return s5p_gatectrl(EXYNOS4_CLKGATE_IP_DMC, clk, enable); | ||
203 | } | ||
204 | |||
205 | static int exynos4_clk_hdmiphy_ctrl(struct clk *clk, int enable) | ||
206 | { | ||
207 | return s5p_gatectrl(S5P_HDMI_PHY_CONTROL, clk, enable); | ||
208 | } | ||
209 | |||
210 | static int exynos4_clk_dac_ctrl(struct clk *clk, int enable) | ||
211 | { | ||
212 | return s5p_gatectrl(S5P_DAC_PHY_CONTROL, clk, enable); | ||
213 | } | ||
214 | |||
215 | /* Core list of CMU_CPU side */ | ||
216 | |||
217 | static struct clksrc_clk exynos4_clk_mout_apll = { | ||
218 | .clk = { | ||
219 | .name = "mout_apll", | ||
220 | }, | ||
221 | .sources = &clk_src_apll, | ||
222 | .reg_src = { .reg = EXYNOS4_CLKSRC_CPU, .shift = 0, .size = 1 }, | ||
223 | }; | ||
224 | |||
225 | static struct clksrc_clk exynos4_clk_sclk_apll = { | ||
226 | .clk = { | ||
227 | .name = "sclk_apll", | ||
228 | .parent = &exynos4_clk_mout_apll.clk, | ||
229 | }, | ||
230 | .reg_div = { .reg = EXYNOS4_CLKDIV_CPU, .shift = 24, .size = 3 }, | ||
231 | }; | ||
232 | |||
233 | static struct clksrc_clk exynos4_clk_mout_epll = { | ||
234 | .clk = { | ||
235 | .name = "mout_epll", | ||
236 | }, | ||
237 | .sources = &clk_src_epll, | ||
238 | .reg_src = { .reg = EXYNOS4_CLKSRC_TOP0, .shift = 4, .size = 1 }, | ||
239 | }; | ||
240 | |||
241 | struct clksrc_clk exynos4_clk_mout_mpll = { | ||
242 | .clk = { | ||
243 | .name = "mout_mpll", | ||
244 | }, | ||
245 | .sources = &clk_src_mpll, | ||
246 | |||
247 | /* reg_src will be added in each SoCs' clock */ | ||
248 | }; | ||
249 | |||
250 | static struct clk *exynos4_clkset_moutcore_list[] = { | ||
251 | [0] = &exynos4_clk_mout_apll.clk, | ||
252 | [1] = &exynos4_clk_mout_mpll.clk, | ||
253 | }; | ||
254 | |||
255 | static struct clksrc_sources exynos4_clkset_moutcore = { | ||
256 | .sources = exynos4_clkset_moutcore_list, | ||
257 | .nr_sources = ARRAY_SIZE(exynos4_clkset_moutcore_list), | ||
258 | }; | ||
259 | |||
260 | static struct clksrc_clk exynos4_clk_moutcore = { | ||
261 | .clk = { | ||
262 | .name = "moutcore", | ||
263 | }, | ||
264 | .sources = &exynos4_clkset_moutcore, | ||
265 | .reg_src = { .reg = EXYNOS4_CLKSRC_CPU, .shift = 16, .size = 1 }, | ||
266 | }; | ||
267 | |||
268 | static struct clksrc_clk exynos4_clk_coreclk = { | ||
269 | .clk = { | ||
270 | .name = "core_clk", | ||
271 | .parent = &exynos4_clk_moutcore.clk, | ||
272 | }, | ||
273 | .reg_div = { .reg = EXYNOS4_CLKDIV_CPU, .shift = 0, .size = 3 }, | ||
274 | }; | ||
275 | |||
276 | static struct clksrc_clk exynos4_clk_armclk = { | ||
277 | .clk = { | ||
278 | .name = "armclk", | ||
279 | .parent = &exynos4_clk_coreclk.clk, | ||
280 | }, | ||
281 | }; | ||
282 | |||
283 | static struct clksrc_clk exynos4_clk_aclk_corem0 = { | ||
284 | .clk = { | ||
285 | .name = "aclk_corem0", | ||
286 | .parent = &exynos4_clk_coreclk.clk, | ||
287 | }, | ||
288 | .reg_div = { .reg = EXYNOS4_CLKDIV_CPU, .shift = 4, .size = 3 }, | ||
289 | }; | ||
290 | |||
291 | static struct clksrc_clk exynos4_clk_aclk_cores = { | ||
292 | .clk = { | ||
293 | .name = "aclk_cores", | ||
294 | .parent = &exynos4_clk_coreclk.clk, | ||
295 | }, | ||
296 | .reg_div = { .reg = EXYNOS4_CLKDIV_CPU, .shift = 4, .size = 3 }, | ||
297 | }; | ||
298 | |||
299 | static struct clksrc_clk exynos4_clk_aclk_corem1 = { | ||
300 | .clk = { | ||
301 | .name = "aclk_corem1", | ||
302 | .parent = &exynos4_clk_coreclk.clk, | ||
303 | }, | ||
304 | .reg_div = { .reg = EXYNOS4_CLKDIV_CPU, .shift = 8, .size = 3 }, | ||
305 | }; | ||
306 | |||
307 | static struct clksrc_clk exynos4_clk_periphclk = { | ||
308 | .clk = { | ||
309 | .name = "periphclk", | ||
310 | .parent = &exynos4_clk_coreclk.clk, | ||
311 | }, | ||
312 | .reg_div = { .reg = EXYNOS4_CLKDIV_CPU, .shift = 12, .size = 3 }, | ||
313 | }; | ||
314 | |||
315 | /* Core list of CMU_CORE side */ | ||
316 | |||
317 | static struct clk *exynos4_clkset_corebus_list[] = { | ||
318 | [0] = &exynos4_clk_mout_mpll.clk, | ||
319 | [1] = &exynos4_clk_sclk_apll.clk, | ||
320 | }; | ||
321 | |||
322 | struct clksrc_sources exynos4_clkset_mout_corebus = { | ||
323 | .sources = exynos4_clkset_corebus_list, | ||
324 | .nr_sources = ARRAY_SIZE(exynos4_clkset_corebus_list), | ||
325 | }; | ||
326 | |||
327 | static struct clksrc_clk exynos4_clk_mout_corebus = { | ||
328 | .clk = { | ||
329 | .name = "mout_corebus", | ||
330 | }, | ||
331 | .sources = &exynos4_clkset_mout_corebus, | ||
332 | .reg_src = { .reg = EXYNOS4_CLKSRC_DMC, .shift = 4, .size = 1 }, | ||
333 | }; | ||
334 | |||
335 | static struct clksrc_clk exynos4_clk_sclk_dmc = { | ||
336 | .clk = { | ||
337 | .name = "sclk_dmc", | ||
338 | .parent = &exynos4_clk_mout_corebus.clk, | ||
339 | }, | ||
340 | .reg_div = { .reg = EXYNOS4_CLKDIV_DMC0, .shift = 12, .size = 3 }, | ||
341 | }; | ||
342 | |||
343 | static struct clksrc_clk exynos4_clk_aclk_cored = { | ||
344 | .clk = { | ||
345 | .name = "aclk_cored", | ||
346 | .parent = &exynos4_clk_sclk_dmc.clk, | ||
347 | }, | ||
348 | .reg_div = { .reg = EXYNOS4_CLKDIV_DMC0, .shift = 16, .size = 3 }, | ||
349 | }; | ||
350 | |||
351 | static struct clksrc_clk exynos4_clk_aclk_corep = { | ||
352 | .clk = { | ||
353 | .name = "aclk_corep", | ||
354 | .parent = &exynos4_clk_aclk_cored.clk, | ||
355 | }, | ||
356 | .reg_div = { .reg = EXYNOS4_CLKDIV_DMC0, .shift = 20, .size = 3 }, | ||
357 | }; | ||
358 | |||
359 | static struct clksrc_clk exynos4_clk_aclk_acp = { | ||
360 | .clk = { | ||
361 | .name = "aclk_acp", | ||
362 | .parent = &exynos4_clk_mout_corebus.clk, | ||
363 | }, | ||
364 | .reg_div = { .reg = EXYNOS4_CLKDIV_DMC0, .shift = 0, .size = 3 }, | ||
365 | }; | ||
366 | |||
367 | static struct clksrc_clk exynos4_clk_pclk_acp = { | ||
368 | .clk = { | ||
369 | .name = "pclk_acp", | ||
370 | .parent = &exynos4_clk_aclk_acp.clk, | ||
371 | }, | ||
372 | .reg_div = { .reg = EXYNOS4_CLKDIV_DMC0, .shift = 4, .size = 3 }, | ||
373 | }; | ||
374 | |||
375 | /* Core list of CMU_TOP side */ | ||
376 | |||
377 | struct clk *exynos4_clkset_aclk_top_list[] = { | ||
378 | [0] = &exynos4_clk_mout_mpll.clk, | ||
379 | [1] = &exynos4_clk_sclk_apll.clk, | ||
380 | }; | ||
381 | |||
382 | static struct clksrc_sources exynos4_clkset_aclk = { | ||
383 | .sources = exynos4_clkset_aclk_top_list, | ||
384 | .nr_sources = ARRAY_SIZE(exynos4_clkset_aclk_top_list), | ||
385 | }; | ||
386 | |||
387 | static struct clksrc_clk exynos4_clk_aclk_200 = { | ||
388 | .clk = { | ||
389 | .name = "aclk_200", | ||
390 | }, | ||
391 | .sources = &exynos4_clkset_aclk, | ||
392 | .reg_src = { .reg = EXYNOS4_CLKSRC_TOP0, .shift = 12, .size = 1 }, | ||
393 | .reg_div = { .reg = EXYNOS4_CLKDIV_TOP, .shift = 0, .size = 3 }, | ||
394 | }; | ||
395 | |||
396 | static struct clksrc_clk exynos4_clk_aclk_100 = { | ||
397 | .clk = { | ||
398 | .name = "aclk_100", | ||
399 | }, | ||
400 | .sources = &exynos4_clkset_aclk, | ||
401 | .reg_src = { .reg = EXYNOS4_CLKSRC_TOP0, .shift = 16, .size = 1 }, | ||
402 | .reg_div = { .reg = EXYNOS4_CLKDIV_TOP, .shift = 4, .size = 4 }, | ||
403 | }; | ||
404 | |||
405 | static struct clksrc_clk exynos4_clk_aclk_160 = { | ||
406 | .clk = { | ||
407 | .name = "aclk_160", | ||
408 | }, | ||
409 | .sources = &exynos4_clkset_aclk, | ||
410 | .reg_src = { .reg = EXYNOS4_CLKSRC_TOP0, .shift = 20, .size = 1 }, | ||
411 | .reg_div = { .reg = EXYNOS4_CLKDIV_TOP, .shift = 8, .size = 3 }, | ||
412 | }; | ||
413 | |||
414 | struct clksrc_clk exynos4_clk_aclk_133 = { | ||
415 | .clk = { | ||
416 | .name = "aclk_133", | ||
417 | }, | ||
418 | .sources = &exynos4_clkset_aclk, | ||
419 | .reg_src = { .reg = EXYNOS4_CLKSRC_TOP0, .shift = 24, .size = 1 }, | ||
420 | .reg_div = { .reg = EXYNOS4_CLKDIV_TOP, .shift = 12, .size = 3 }, | ||
421 | }; | ||
422 | |||
423 | static struct clk *exynos4_clkset_vpllsrc_list[] = { | ||
424 | [0] = &clk_fin_vpll, | ||
425 | [1] = &exynos4_clk_sclk_hdmi27m, | ||
426 | }; | ||
427 | |||
428 | static struct clksrc_sources exynos4_clkset_vpllsrc = { | ||
429 | .sources = exynos4_clkset_vpllsrc_list, | ||
430 | .nr_sources = ARRAY_SIZE(exynos4_clkset_vpllsrc_list), | ||
431 | }; | ||
432 | |||
433 | static struct clksrc_clk exynos4_clk_vpllsrc = { | ||
434 | .clk = { | ||
435 | .name = "vpll_src", | ||
436 | .enable = exynos4_clksrc_mask_top_ctrl, | ||
437 | .ctrlbit = (1 << 0), | ||
438 | }, | ||
439 | .sources = &exynos4_clkset_vpllsrc, | ||
440 | .reg_src = { .reg = EXYNOS4_CLKSRC_TOP1, .shift = 0, .size = 1 }, | ||
441 | }; | ||
442 | |||
443 | static struct clk *exynos4_clkset_sclk_vpll_list[] = { | ||
444 | [0] = &exynos4_clk_vpllsrc.clk, | ||
445 | [1] = &clk_fout_vpll, | ||
446 | }; | ||
447 | |||
448 | static struct clksrc_sources exynos4_clkset_sclk_vpll = { | ||
449 | .sources = exynos4_clkset_sclk_vpll_list, | ||
450 | .nr_sources = ARRAY_SIZE(exynos4_clkset_sclk_vpll_list), | ||
451 | }; | ||
452 | |||
453 | static struct clksrc_clk exynos4_clk_sclk_vpll = { | ||
454 | .clk = { | ||
455 | .name = "sclk_vpll", | ||
456 | }, | ||
457 | .sources = &exynos4_clkset_sclk_vpll, | ||
458 | .reg_src = { .reg = EXYNOS4_CLKSRC_TOP0, .shift = 8, .size = 1 }, | ||
459 | }; | ||
460 | |||
461 | static struct clk exynos4_init_clocks_off[] = { | ||
462 | { | ||
463 | .name = "timers", | ||
464 | .parent = &exynos4_clk_aclk_100.clk, | ||
465 | .enable = exynos4_clk_ip_peril_ctrl, | ||
466 | .ctrlbit = (1<<24), | ||
467 | }, { | ||
468 | .name = "csis", | ||
469 | .devname = "s5p-mipi-csis.0", | ||
470 | .enable = exynos4_clk_ip_cam_ctrl, | ||
471 | .ctrlbit = (1 << 4), | ||
472 | }, { | ||
473 | .name = "csis", | ||
474 | .devname = "s5p-mipi-csis.1", | ||
475 | .enable = exynos4_clk_ip_cam_ctrl, | ||
476 | .ctrlbit = (1 << 5), | ||
477 | }, { | ||
478 | .name = "jpeg", | ||
479 | .id = 0, | ||
480 | .enable = exynos4_clk_ip_cam_ctrl, | ||
481 | .ctrlbit = (1 << 6), | ||
482 | }, { | ||
483 | .name = "fimc", | ||
484 | .devname = "exynos4-fimc.0", | ||
485 | .enable = exynos4_clk_ip_cam_ctrl, | ||
486 | .ctrlbit = (1 << 0), | ||
487 | }, { | ||
488 | .name = "fimc", | ||
489 | .devname = "exynos4-fimc.1", | ||
490 | .enable = exynos4_clk_ip_cam_ctrl, | ||
491 | .ctrlbit = (1 << 1), | ||
492 | }, { | ||
493 | .name = "fimc", | ||
494 | .devname = "exynos4-fimc.2", | ||
495 | .enable = exynos4_clk_ip_cam_ctrl, | ||
496 | .ctrlbit = (1 << 2), | ||
497 | }, { | ||
498 | .name = "fimc", | ||
499 | .devname = "exynos4-fimc.3", | ||
500 | .enable = exynos4_clk_ip_cam_ctrl, | ||
501 | .ctrlbit = (1 << 3), | ||
502 | }, { | ||
503 | .name = "tsi", | ||
504 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
505 | .ctrlbit = (1 << 4), | ||
506 | }, { | ||
507 | .name = "hsmmc", | ||
508 | .devname = "exynos4-sdhci.0", | ||
509 | .parent = &exynos4_clk_aclk_133.clk, | ||
510 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
511 | .ctrlbit = (1 << 5), | ||
512 | }, { | ||
513 | .name = "hsmmc", | ||
514 | .devname = "exynos4-sdhci.1", | ||
515 | .parent = &exynos4_clk_aclk_133.clk, | ||
516 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
517 | .ctrlbit = (1 << 6), | ||
518 | }, { | ||
519 | .name = "hsmmc", | ||
520 | .devname = "exynos4-sdhci.2", | ||
521 | .parent = &exynos4_clk_aclk_133.clk, | ||
522 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
523 | .ctrlbit = (1 << 7), | ||
524 | }, { | ||
525 | .name = "hsmmc", | ||
526 | .devname = "exynos4-sdhci.3", | ||
527 | .parent = &exynos4_clk_aclk_133.clk, | ||
528 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
529 | .ctrlbit = (1 << 8), | ||
530 | }, { | ||
531 | .name = "biu", | ||
532 | .parent = &exynos4_clk_aclk_133.clk, | ||
533 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
534 | .ctrlbit = (1 << 9), | ||
535 | }, { | ||
536 | .name = "onenand", | ||
537 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
538 | .ctrlbit = (1 << 15), | ||
539 | }, { | ||
540 | .name = "nfcon", | ||
541 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
542 | .ctrlbit = (1 << 16), | ||
543 | }, { | ||
544 | .name = "dac", | ||
545 | .devname = "s5p-sdo", | ||
546 | .enable = exynos4_clk_ip_tv_ctrl, | ||
547 | .ctrlbit = (1 << 2), | ||
548 | }, { | ||
549 | .name = "mixer", | ||
550 | .devname = "s5p-mixer", | ||
551 | .enable = exynos4_clk_ip_tv_ctrl, | ||
552 | .ctrlbit = (1 << 1), | ||
553 | }, { | ||
554 | .name = "vp", | ||
555 | .devname = "s5p-mixer", | ||
556 | .enable = exynos4_clk_ip_tv_ctrl, | ||
557 | .ctrlbit = (1 << 0), | ||
558 | }, { | ||
559 | .name = "hdmi", | ||
560 | .devname = "exynos4-hdmi", | ||
561 | .enable = exynos4_clk_ip_tv_ctrl, | ||
562 | .ctrlbit = (1 << 3), | ||
563 | }, { | ||
564 | .name = "hdmiphy", | ||
565 | .devname = "exynos4-hdmi", | ||
566 | .enable = exynos4_clk_hdmiphy_ctrl, | ||
567 | .ctrlbit = (1 << 0), | ||
568 | }, { | ||
569 | .name = "dacphy", | ||
570 | .devname = "s5p-sdo", | ||
571 | .enable = exynos4_clk_dac_ctrl, | ||
572 | .ctrlbit = (1 << 0), | ||
573 | }, { | ||
574 | .name = "adc", | ||
575 | .enable = exynos4_clk_ip_peril_ctrl, | ||
576 | .ctrlbit = (1 << 15), | ||
577 | }, { | ||
578 | .name = "tmu_apbif", | ||
579 | .enable = exynos4_clk_ip_perir_ctrl, | ||
580 | .ctrlbit = (1 << 17), | ||
581 | }, { | ||
582 | .name = "keypad", | ||
583 | .enable = exynos4_clk_ip_perir_ctrl, | ||
584 | .ctrlbit = (1 << 16), | ||
585 | }, { | ||
586 | .name = "rtc", | ||
587 | .enable = exynos4_clk_ip_perir_ctrl, | ||
588 | .ctrlbit = (1 << 15), | ||
589 | }, { | ||
590 | .name = "watchdog", | ||
591 | .parent = &exynos4_clk_aclk_100.clk, | ||
592 | .enable = exynos4_clk_ip_perir_ctrl, | ||
593 | .ctrlbit = (1 << 14), | ||
594 | }, { | ||
595 | .name = "usbhost", | ||
596 | .enable = exynos4_clk_ip_fsys_ctrl , | ||
597 | .ctrlbit = (1 << 12), | ||
598 | }, { | ||
599 | .name = "otg", | ||
600 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
601 | .ctrlbit = (1 << 13), | ||
602 | }, { | ||
603 | .name = "spi", | ||
604 | .devname = "exynos4210-spi.0", | ||
605 | .enable = exynos4_clk_ip_peril_ctrl, | ||
606 | .ctrlbit = (1 << 16), | ||
607 | }, { | ||
608 | .name = "spi", | ||
609 | .devname = "exynos4210-spi.1", | ||
610 | .enable = exynos4_clk_ip_peril_ctrl, | ||
611 | .ctrlbit = (1 << 17), | ||
612 | }, { | ||
613 | .name = "spi", | ||
614 | .devname = "exynos4210-spi.2", | ||
615 | .enable = exynos4_clk_ip_peril_ctrl, | ||
616 | .ctrlbit = (1 << 18), | ||
617 | }, { | ||
618 | .name = "iis", | ||
619 | .devname = "samsung-i2s.1", | ||
620 | .enable = exynos4_clk_ip_peril_ctrl, | ||
621 | .ctrlbit = (1 << 20), | ||
622 | }, { | ||
623 | .name = "iis", | ||
624 | .devname = "samsung-i2s.2", | ||
625 | .enable = exynos4_clk_ip_peril_ctrl, | ||
626 | .ctrlbit = (1 << 21), | ||
627 | }, { | ||
628 | .name = "pcm", | ||
629 | .devname = "samsung-pcm.1", | ||
630 | .enable = exynos4_clk_ip_peril_ctrl, | ||
631 | .ctrlbit = (1 << 22), | ||
632 | }, { | ||
633 | .name = "pcm", | ||
634 | .devname = "samsung-pcm.2", | ||
635 | .enable = exynos4_clk_ip_peril_ctrl, | ||
636 | .ctrlbit = (1 << 23), | ||
637 | }, { | ||
638 | .name = "slimbus", | ||
639 | .enable = exynos4_clk_ip_peril_ctrl, | ||
640 | .ctrlbit = (1 << 25), | ||
641 | }, { | ||
642 | .name = "spdif", | ||
643 | .devname = "samsung-spdif", | ||
644 | .enable = exynos4_clk_ip_peril_ctrl, | ||
645 | .ctrlbit = (1 << 26), | ||
646 | }, { | ||
647 | .name = "ac97", | ||
648 | .devname = "samsung-ac97", | ||
649 | .enable = exynos4_clk_ip_peril_ctrl, | ||
650 | .ctrlbit = (1 << 27), | ||
651 | }, { | ||
652 | .name = "mfc", | ||
653 | .devname = "s5p-mfc", | ||
654 | .enable = exynos4_clk_ip_mfc_ctrl, | ||
655 | .ctrlbit = (1 << 0), | ||
656 | }, { | ||
657 | .name = "i2c", | ||
658 | .devname = "s3c2440-i2c.0", | ||
659 | .parent = &exynos4_clk_aclk_100.clk, | ||
660 | .enable = exynos4_clk_ip_peril_ctrl, | ||
661 | .ctrlbit = (1 << 6), | ||
662 | }, { | ||
663 | .name = "i2c", | ||
664 | .devname = "s3c2440-i2c.1", | ||
665 | .parent = &exynos4_clk_aclk_100.clk, | ||
666 | .enable = exynos4_clk_ip_peril_ctrl, | ||
667 | .ctrlbit = (1 << 7), | ||
668 | }, { | ||
669 | .name = "i2c", | ||
670 | .devname = "s3c2440-i2c.2", | ||
671 | .parent = &exynos4_clk_aclk_100.clk, | ||
672 | .enable = exynos4_clk_ip_peril_ctrl, | ||
673 | .ctrlbit = (1 << 8), | ||
674 | }, { | ||
675 | .name = "i2c", | ||
676 | .devname = "s3c2440-i2c.3", | ||
677 | .parent = &exynos4_clk_aclk_100.clk, | ||
678 | .enable = exynos4_clk_ip_peril_ctrl, | ||
679 | .ctrlbit = (1 << 9), | ||
680 | }, { | ||
681 | .name = "i2c", | ||
682 | .devname = "s3c2440-i2c.4", | ||
683 | .parent = &exynos4_clk_aclk_100.clk, | ||
684 | .enable = exynos4_clk_ip_peril_ctrl, | ||
685 | .ctrlbit = (1 << 10), | ||
686 | }, { | ||
687 | .name = "i2c", | ||
688 | .devname = "s3c2440-i2c.5", | ||
689 | .parent = &exynos4_clk_aclk_100.clk, | ||
690 | .enable = exynos4_clk_ip_peril_ctrl, | ||
691 | .ctrlbit = (1 << 11), | ||
692 | }, { | ||
693 | .name = "i2c", | ||
694 | .devname = "s3c2440-i2c.6", | ||
695 | .parent = &exynos4_clk_aclk_100.clk, | ||
696 | .enable = exynos4_clk_ip_peril_ctrl, | ||
697 | .ctrlbit = (1 << 12), | ||
698 | }, { | ||
699 | .name = "i2c", | ||
700 | .devname = "s3c2440-i2c.7", | ||
701 | .parent = &exynos4_clk_aclk_100.clk, | ||
702 | .enable = exynos4_clk_ip_peril_ctrl, | ||
703 | .ctrlbit = (1 << 13), | ||
704 | }, { | ||
705 | .name = "i2c", | ||
706 | .devname = "s3c2440-hdmiphy-i2c", | ||
707 | .parent = &exynos4_clk_aclk_100.clk, | ||
708 | .enable = exynos4_clk_ip_peril_ctrl, | ||
709 | .ctrlbit = (1 << 14), | ||
710 | }, { | ||
711 | .name = "sysmmu", | ||
712 | .devname = "exynos-sysmmu.0", | ||
713 | .enable = exynos4_clk_ip_mfc_ctrl, | ||
714 | .ctrlbit = (1 << 1), | ||
715 | }, { | ||
716 | .name = "sysmmu", | ||
717 | .devname = "exynos-sysmmu.1", | ||
718 | .enable = exynos4_clk_ip_mfc_ctrl, | ||
719 | .ctrlbit = (1 << 2), | ||
720 | }, { | ||
721 | .name = "sysmmu", | ||
722 | .devname = "exynos-sysmmu.2", | ||
723 | .enable = exynos4_clk_ip_tv_ctrl, | ||
724 | .ctrlbit = (1 << 4), | ||
725 | }, { | ||
726 | .name = "sysmmu", | ||
727 | .devname = "exynos-sysmmu.3", | ||
728 | .enable = exynos4_clk_ip_cam_ctrl, | ||
729 | .ctrlbit = (1 << 11), | ||
730 | }, { | ||
731 | .name = "sysmmu", | ||
732 | .devname = "exynos-sysmmu.4", | ||
733 | .enable = exynos4_clk_ip_image_ctrl, | ||
734 | .ctrlbit = (1 << 4), | ||
735 | }, { | ||
736 | .name = "sysmmu", | ||
737 | .devname = "exynos-sysmmu.5", | ||
738 | .enable = exynos4_clk_ip_cam_ctrl, | ||
739 | .ctrlbit = (1 << 7), | ||
740 | }, { | ||
741 | .name = "sysmmu", | ||
742 | .devname = "exynos-sysmmu.6", | ||
743 | .enable = exynos4_clk_ip_cam_ctrl, | ||
744 | .ctrlbit = (1 << 8), | ||
745 | }, { | ||
746 | .name = "sysmmu", | ||
747 | .devname = "exynos-sysmmu.7", | ||
748 | .enable = exynos4_clk_ip_cam_ctrl, | ||
749 | .ctrlbit = (1 << 9), | ||
750 | }, { | ||
751 | .name = "sysmmu", | ||
752 | .devname = "exynos-sysmmu.8", | ||
753 | .enable = exynos4_clk_ip_cam_ctrl, | ||
754 | .ctrlbit = (1 << 10), | ||
755 | }, { | ||
756 | .name = "sysmmu", | ||
757 | .devname = "exynos-sysmmu.10", | ||
758 | .enable = exynos4_clk_ip_lcd0_ctrl, | ||
759 | .ctrlbit = (1 << 4), | ||
760 | } | ||
761 | }; | ||
762 | |||
763 | static struct clk exynos4_init_clocks_on[] = { | ||
764 | { | ||
765 | .name = "uart", | ||
766 | .devname = "s5pv210-uart.0", | ||
767 | .enable = exynos4_clk_ip_peril_ctrl, | ||
768 | .ctrlbit = (1 << 0), | ||
769 | }, { | ||
770 | .name = "uart", | ||
771 | .devname = "s5pv210-uart.1", | ||
772 | .enable = exynos4_clk_ip_peril_ctrl, | ||
773 | .ctrlbit = (1 << 1), | ||
774 | }, { | ||
775 | .name = "uart", | ||
776 | .devname = "s5pv210-uart.2", | ||
777 | .enable = exynos4_clk_ip_peril_ctrl, | ||
778 | .ctrlbit = (1 << 2), | ||
779 | }, { | ||
780 | .name = "uart", | ||
781 | .devname = "s5pv210-uart.3", | ||
782 | .enable = exynos4_clk_ip_peril_ctrl, | ||
783 | .ctrlbit = (1 << 3), | ||
784 | }, { | ||
785 | .name = "uart", | ||
786 | .devname = "s5pv210-uart.4", | ||
787 | .enable = exynos4_clk_ip_peril_ctrl, | ||
788 | .ctrlbit = (1 << 4), | ||
789 | }, { | ||
790 | .name = "uart", | ||
791 | .devname = "s5pv210-uart.5", | ||
792 | .enable = exynos4_clk_ip_peril_ctrl, | ||
793 | .ctrlbit = (1 << 5), | ||
794 | } | ||
795 | }; | ||
796 | |||
797 | static struct clk exynos4_clk_pdma0 = { | ||
798 | .name = "dma", | ||
799 | .devname = "dma-pl330.0", | ||
800 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
801 | .ctrlbit = (1 << 0), | ||
802 | }; | ||
803 | |||
804 | static struct clk exynos4_clk_pdma1 = { | ||
805 | .name = "dma", | ||
806 | .devname = "dma-pl330.1", | ||
807 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
808 | .ctrlbit = (1 << 1), | ||
809 | }; | ||
810 | |||
811 | static struct clk exynos4_clk_mdma1 = { | ||
812 | .name = "dma", | ||
813 | .devname = "dma-pl330.2", | ||
814 | .enable = exynos4_clk_ip_image_ctrl, | ||
815 | .ctrlbit = ((1 << 8) | (1 << 5) | (1 << 2)), | ||
816 | }; | ||
817 | |||
818 | static struct clk exynos4_clk_fimd0 = { | ||
819 | .name = "fimd", | ||
820 | .devname = "exynos4-fb.0", | ||
821 | .enable = exynos4_clk_ip_lcd0_ctrl, | ||
822 | .ctrlbit = (1 << 0), | ||
823 | }; | ||
824 | |||
825 | struct clk *exynos4_clkset_group_list[] = { | ||
826 | [0] = &clk_ext_xtal_mux, | ||
827 | [1] = &clk_xusbxti, | ||
828 | [2] = &exynos4_clk_sclk_hdmi27m, | ||
829 | [3] = &exynos4_clk_sclk_usbphy0, | ||
830 | [4] = &exynos4_clk_sclk_usbphy1, | ||
831 | [5] = &exynos4_clk_sclk_hdmiphy, | ||
832 | [6] = &exynos4_clk_mout_mpll.clk, | ||
833 | [7] = &exynos4_clk_mout_epll.clk, | ||
834 | [8] = &exynos4_clk_sclk_vpll.clk, | ||
835 | }; | ||
836 | |||
837 | struct clksrc_sources exynos4_clkset_group = { | ||
838 | .sources = exynos4_clkset_group_list, | ||
839 | .nr_sources = ARRAY_SIZE(exynos4_clkset_group_list), | ||
840 | }; | ||
841 | |||
842 | static struct clk *exynos4_clkset_mout_g2d0_list[] = { | ||
843 | [0] = &exynos4_clk_mout_mpll.clk, | ||
844 | [1] = &exynos4_clk_sclk_apll.clk, | ||
845 | }; | ||
846 | |||
847 | struct clksrc_sources exynos4_clkset_mout_g2d0 = { | ||
848 | .sources = exynos4_clkset_mout_g2d0_list, | ||
849 | .nr_sources = ARRAY_SIZE(exynos4_clkset_mout_g2d0_list), | ||
850 | }; | ||
851 | |||
852 | static struct clk *exynos4_clkset_mout_g2d1_list[] = { | ||
853 | [0] = &exynos4_clk_mout_epll.clk, | ||
854 | [1] = &exynos4_clk_sclk_vpll.clk, | ||
855 | }; | ||
856 | |||
857 | struct clksrc_sources exynos4_clkset_mout_g2d1 = { | ||
858 | .sources = exynos4_clkset_mout_g2d1_list, | ||
859 | .nr_sources = ARRAY_SIZE(exynos4_clkset_mout_g2d1_list), | ||
860 | }; | ||
861 | |||
862 | static struct clk *exynos4_clkset_mout_mfc0_list[] = { | ||
863 | [0] = &exynos4_clk_mout_mpll.clk, | ||
864 | [1] = &exynos4_clk_sclk_apll.clk, | ||
865 | }; | ||
866 | |||
867 | static struct clksrc_sources exynos4_clkset_mout_mfc0 = { | ||
868 | .sources = exynos4_clkset_mout_mfc0_list, | ||
869 | .nr_sources = ARRAY_SIZE(exynos4_clkset_mout_mfc0_list), | ||
870 | }; | ||
871 | |||
872 | static struct clksrc_clk exynos4_clk_mout_mfc0 = { | ||
873 | .clk = { | ||
874 | .name = "mout_mfc0", | ||
875 | }, | ||
876 | .sources = &exynos4_clkset_mout_mfc0, | ||
877 | .reg_src = { .reg = EXYNOS4_CLKSRC_MFC, .shift = 0, .size = 1 }, | ||
878 | }; | ||
879 | |||
880 | static struct clk *exynos4_clkset_mout_mfc1_list[] = { | ||
881 | [0] = &exynos4_clk_mout_epll.clk, | ||
882 | [1] = &exynos4_clk_sclk_vpll.clk, | ||
883 | }; | ||
884 | |||
885 | static struct clksrc_sources exynos4_clkset_mout_mfc1 = { | ||
886 | .sources = exynos4_clkset_mout_mfc1_list, | ||
887 | .nr_sources = ARRAY_SIZE(exynos4_clkset_mout_mfc1_list), | ||
888 | }; | ||
889 | |||
890 | static struct clksrc_clk exynos4_clk_mout_mfc1 = { | ||
891 | .clk = { | ||
892 | .name = "mout_mfc1", | ||
893 | }, | ||
894 | .sources = &exynos4_clkset_mout_mfc1, | ||
895 | .reg_src = { .reg = EXYNOS4_CLKSRC_MFC, .shift = 4, .size = 1 }, | ||
896 | }; | ||
897 | |||
898 | static struct clk *exynos4_clkset_mout_mfc_list[] = { | ||
899 | [0] = &exynos4_clk_mout_mfc0.clk, | ||
900 | [1] = &exynos4_clk_mout_mfc1.clk, | ||
901 | }; | ||
902 | |||
903 | static struct clksrc_sources exynos4_clkset_mout_mfc = { | ||
904 | .sources = exynos4_clkset_mout_mfc_list, | ||
905 | .nr_sources = ARRAY_SIZE(exynos4_clkset_mout_mfc_list), | ||
906 | }; | ||
907 | |||
908 | static struct clk *exynos4_clkset_sclk_dac_list[] = { | ||
909 | [0] = &exynos4_clk_sclk_vpll.clk, | ||
910 | [1] = &exynos4_clk_sclk_hdmiphy, | ||
911 | }; | ||
912 | |||
913 | static struct clksrc_sources exynos4_clkset_sclk_dac = { | ||
914 | .sources = exynos4_clkset_sclk_dac_list, | ||
915 | .nr_sources = ARRAY_SIZE(exynos4_clkset_sclk_dac_list), | ||
916 | }; | ||
917 | |||
918 | static struct clksrc_clk exynos4_clk_sclk_dac = { | ||
919 | .clk = { | ||
920 | .name = "sclk_dac", | ||
921 | .enable = exynos4_clksrc_mask_tv_ctrl, | ||
922 | .ctrlbit = (1 << 8), | ||
923 | }, | ||
924 | .sources = &exynos4_clkset_sclk_dac, | ||
925 | .reg_src = { .reg = EXYNOS4_CLKSRC_TV, .shift = 8, .size = 1 }, | ||
926 | }; | ||
927 | |||
928 | static struct clksrc_clk exynos4_clk_sclk_pixel = { | ||
929 | .clk = { | ||
930 | .name = "sclk_pixel", | ||
931 | .parent = &exynos4_clk_sclk_vpll.clk, | ||
932 | }, | ||
933 | .reg_div = { .reg = EXYNOS4_CLKDIV_TV, .shift = 0, .size = 4 }, | ||
934 | }; | ||
935 | |||
936 | static struct clk *exynos4_clkset_sclk_hdmi_list[] = { | ||
937 | [0] = &exynos4_clk_sclk_pixel.clk, | ||
938 | [1] = &exynos4_clk_sclk_hdmiphy, | ||
939 | }; | ||
940 | |||
941 | static struct clksrc_sources exynos4_clkset_sclk_hdmi = { | ||
942 | .sources = exynos4_clkset_sclk_hdmi_list, | ||
943 | .nr_sources = ARRAY_SIZE(exynos4_clkset_sclk_hdmi_list), | ||
944 | }; | ||
945 | |||
946 | static struct clksrc_clk exynos4_clk_sclk_hdmi = { | ||
947 | .clk = { | ||
948 | .name = "sclk_hdmi", | ||
949 | .enable = exynos4_clksrc_mask_tv_ctrl, | ||
950 | .ctrlbit = (1 << 0), | ||
951 | }, | ||
952 | .sources = &exynos4_clkset_sclk_hdmi, | ||
953 | .reg_src = { .reg = EXYNOS4_CLKSRC_TV, .shift = 0, .size = 1 }, | ||
954 | }; | ||
955 | |||
956 | static struct clk *exynos4_clkset_sclk_mixer_list[] = { | ||
957 | [0] = &exynos4_clk_sclk_dac.clk, | ||
958 | [1] = &exynos4_clk_sclk_hdmi.clk, | ||
959 | }; | ||
960 | |||
961 | static struct clksrc_sources exynos4_clkset_sclk_mixer = { | ||
962 | .sources = exynos4_clkset_sclk_mixer_list, | ||
963 | .nr_sources = ARRAY_SIZE(exynos4_clkset_sclk_mixer_list), | ||
964 | }; | ||
965 | |||
966 | static struct clksrc_clk exynos4_clk_sclk_mixer = { | ||
967 | .clk = { | ||
968 | .name = "sclk_mixer", | ||
969 | .enable = exynos4_clksrc_mask_tv_ctrl, | ||
970 | .ctrlbit = (1 << 4), | ||
971 | }, | ||
972 | .sources = &exynos4_clkset_sclk_mixer, | ||
973 | .reg_src = { .reg = EXYNOS4_CLKSRC_TV, .shift = 4, .size = 1 }, | ||
974 | }; | ||
975 | |||
976 | static struct clksrc_clk *exynos4_sclk_tv[] = { | ||
977 | &exynos4_clk_sclk_dac, | ||
978 | &exynos4_clk_sclk_pixel, | ||
979 | &exynos4_clk_sclk_hdmi, | ||
980 | &exynos4_clk_sclk_mixer, | ||
981 | }; | ||
982 | |||
983 | static struct clksrc_clk exynos4_clk_dout_mmc0 = { | ||
984 | .clk = { | ||
985 | .name = "dout_mmc0", | ||
986 | }, | ||
987 | .sources = &exynos4_clkset_group, | ||
988 | .reg_src = { .reg = EXYNOS4_CLKSRC_FSYS, .shift = 0, .size = 4 }, | ||
989 | .reg_div = { .reg = EXYNOS4_CLKDIV_FSYS1, .shift = 0, .size = 4 }, | ||
990 | }; | ||
991 | |||
992 | static struct clksrc_clk exynos4_clk_dout_mmc1 = { | ||
993 | .clk = { | ||
994 | .name = "dout_mmc1", | ||
995 | }, | ||
996 | .sources = &exynos4_clkset_group, | ||
997 | .reg_src = { .reg = EXYNOS4_CLKSRC_FSYS, .shift = 4, .size = 4 }, | ||
998 | .reg_div = { .reg = EXYNOS4_CLKDIV_FSYS1, .shift = 16, .size = 4 }, | ||
999 | }; | ||
1000 | |||
1001 | static struct clksrc_clk exynos4_clk_dout_mmc2 = { | ||
1002 | .clk = { | ||
1003 | .name = "dout_mmc2", | ||
1004 | }, | ||
1005 | .sources = &exynos4_clkset_group, | ||
1006 | .reg_src = { .reg = EXYNOS4_CLKSRC_FSYS, .shift = 8, .size = 4 }, | ||
1007 | .reg_div = { .reg = EXYNOS4_CLKDIV_FSYS2, .shift = 0, .size = 4 }, | ||
1008 | }; | ||
1009 | |||
1010 | static struct clksrc_clk exynos4_clk_dout_mmc3 = { | ||
1011 | .clk = { | ||
1012 | .name = "dout_mmc3", | ||
1013 | }, | ||
1014 | .sources = &exynos4_clkset_group, | ||
1015 | .reg_src = { .reg = EXYNOS4_CLKSRC_FSYS, .shift = 12, .size = 4 }, | ||
1016 | .reg_div = { .reg = EXYNOS4_CLKDIV_FSYS2, .shift = 16, .size = 4 }, | ||
1017 | }; | ||
1018 | |||
1019 | static struct clksrc_clk exynos4_clk_dout_mmc4 = { | ||
1020 | .clk = { | ||
1021 | .name = "dout_mmc4", | ||
1022 | }, | ||
1023 | .sources = &exynos4_clkset_group, | ||
1024 | .reg_src = { .reg = EXYNOS4_CLKSRC_FSYS, .shift = 16, .size = 4 }, | ||
1025 | .reg_div = { .reg = EXYNOS4_CLKDIV_FSYS3, .shift = 0, .size = 4 }, | ||
1026 | }; | ||
1027 | |||
1028 | static struct clksrc_clk exynos4_clksrcs[] = { | ||
1029 | { | ||
1030 | .clk = { | ||
1031 | .name = "sclk_pwm", | ||
1032 | .enable = exynos4_clksrc_mask_peril0_ctrl, | ||
1033 | .ctrlbit = (1 << 24), | ||
1034 | }, | ||
1035 | .sources = &exynos4_clkset_group, | ||
1036 | .reg_src = { .reg = EXYNOS4_CLKSRC_PERIL0, .shift = 24, .size = 4 }, | ||
1037 | .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL3, .shift = 0, .size = 4 }, | ||
1038 | }, { | ||
1039 | .clk = { | ||
1040 | .name = "sclk_csis", | ||
1041 | .devname = "s5p-mipi-csis.0", | ||
1042 | .enable = exynos4_clksrc_mask_cam_ctrl, | ||
1043 | .ctrlbit = (1 << 24), | ||
1044 | }, | ||
1045 | .sources = &exynos4_clkset_group, | ||
1046 | .reg_src = { .reg = EXYNOS4_CLKSRC_CAM, .shift = 24, .size = 4 }, | ||
1047 | .reg_div = { .reg = EXYNOS4_CLKDIV_CAM, .shift = 24, .size = 4 }, | ||
1048 | }, { | ||
1049 | .clk = { | ||
1050 | .name = "sclk_csis", | ||
1051 | .devname = "s5p-mipi-csis.1", | ||
1052 | .enable = exynos4_clksrc_mask_cam_ctrl, | ||
1053 | .ctrlbit = (1 << 28), | ||
1054 | }, | ||
1055 | .sources = &exynos4_clkset_group, | ||
1056 | .reg_src = { .reg = EXYNOS4_CLKSRC_CAM, .shift = 28, .size = 4 }, | ||
1057 | .reg_div = { .reg = EXYNOS4_CLKDIV_CAM, .shift = 28, .size = 4 }, | ||
1058 | }, { | ||
1059 | .clk = { | ||
1060 | .name = "sclk_cam0", | ||
1061 | .enable = exynos4_clksrc_mask_cam_ctrl, | ||
1062 | .ctrlbit = (1 << 16), | ||
1063 | }, | ||
1064 | .sources = &exynos4_clkset_group, | ||
1065 | .reg_src = { .reg = EXYNOS4_CLKSRC_CAM, .shift = 16, .size = 4 }, | ||
1066 | .reg_div = { .reg = EXYNOS4_CLKDIV_CAM, .shift = 16, .size = 4 }, | ||
1067 | }, { | ||
1068 | .clk = { | ||
1069 | .name = "sclk_cam1", | ||
1070 | .enable = exynos4_clksrc_mask_cam_ctrl, | ||
1071 | .ctrlbit = (1 << 20), | ||
1072 | }, | ||
1073 | .sources = &exynos4_clkset_group, | ||
1074 | .reg_src = { .reg = EXYNOS4_CLKSRC_CAM, .shift = 20, .size = 4 }, | ||
1075 | .reg_div = { .reg = EXYNOS4_CLKDIV_CAM, .shift = 20, .size = 4 }, | ||
1076 | }, { | ||
1077 | .clk = { | ||
1078 | .name = "sclk_fimc", | ||
1079 | .devname = "exynos4-fimc.0", | ||
1080 | .enable = exynos4_clksrc_mask_cam_ctrl, | ||
1081 | .ctrlbit = (1 << 0), | ||
1082 | }, | ||
1083 | .sources = &exynos4_clkset_group, | ||
1084 | .reg_src = { .reg = EXYNOS4_CLKSRC_CAM, .shift = 0, .size = 4 }, | ||
1085 | .reg_div = { .reg = EXYNOS4_CLKDIV_CAM, .shift = 0, .size = 4 }, | ||
1086 | }, { | ||
1087 | .clk = { | ||
1088 | .name = "sclk_fimc", | ||
1089 | .devname = "exynos4-fimc.1", | ||
1090 | .enable = exynos4_clksrc_mask_cam_ctrl, | ||
1091 | .ctrlbit = (1 << 4), | ||
1092 | }, | ||
1093 | .sources = &exynos4_clkset_group, | ||
1094 | .reg_src = { .reg = EXYNOS4_CLKSRC_CAM, .shift = 4, .size = 4 }, | ||
1095 | .reg_div = { .reg = EXYNOS4_CLKDIV_CAM, .shift = 4, .size = 4 }, | ||
1096 | }, { | ||
1097 | .clk = { | ||
1098 | .name = "sclk_fimc", | ||
1099 | .devname = "exynos4-fimc.2", | ||
1100 | .enable = exynos4_clksrc_mask_cam_ctrl, | ||
1101 | .ctrlbit = (1 << 8), | ||
1102 | }, | ||
1103 | .sources = &exynos4_clkset_group, | ||
1104 | .reg_src = { .reg = EXYNOS4_CLKSRC_CAM, .shift = 8, .size = 4 }, | ||
1105 | .reg_div = { .reg = EXYNOS4_CLKDIV_CAM, .shift = 8, .size = 4 }, | ||
1106 | }, { | ||
1107 | .clk = { | ||
1108 | .name = "sclk_fimc", | ||
1109 | .devname = "exynos4-fimc.3", | ||
1110 | .enable = exynos4_clksrc_mask_cam_ctrl, | ||
1111 | .ctrlbit = (1 << 12), | ||
1112 | }, | ||
1113 | .sources = &exynos4_clkset_group, | ||
1114 | .reg_src = { .reg = EXYNOS4_CLKSRC_CAM, .shift = 12, .size = 4 }, | ||
1115 | .reg_div = { .reg = EXYNOS4_CLKDIV_CAM, .shift = 12, .size = 4 }, | ||
1116 | }, { | ||
1117 | .clk = { | ||
1118 | .name = "sclk_fimd", | ||
1119 | .devname = "exynos4-fb.0", | ||
1120 | .enable = exynos4_clksrc_mask_lcd0_ctrl, | ||
1121 | .ctrlbit = (1 << 0), | ||
1122 | }, | ||
1123 | .sources = &exynos4_clkset_group, | ||
1124 | .reg_src = { .reg = EXYNOS4_CLKSRC_LCD0, .shift = 0, .size = 4 }, | ||
1125 | .reg_div = { .reg = EXYNOS4_CLKDIV_LCD0, .shift = 0, .size = 4 }, | ||
1126 | }, { | ||
1127 | .clk = { | ||
1128 | .name = "sclk_mfc", | ||
1129 | .devname = "s5p-mfc", | ||
1130 | }, | ||
1131 | .sources = &exynos4_clkset_mout_mfc, | ||
1132 | .reg_src = { .reg = EXYNOS4_CLKSRC_MFC, .shift = 8, .size = 1 }, | ||
1133 | .reg_div = { .reg = EXYNOS4_CLKDIV_MFC, .shift = 0, .size = 4 }, | ||
1134 | }, { | ||
1135 | .clk = { | ||
1136 | .name = "ciu", | ||
1137 | .parent = &exynos4_clk_dout_mmc4.clk, | ||
1138 | .enable = exynos4_clksrc_mask_fsys_ctrl, | ||
1139 | .ctrlbit = (1 << 16), | ||
1140 | }, | ||
1141 | .reg_div = { .reg = EXYNOS4_CLKDIV_FSYS3, .shift = 8, .size = 8 }, | ||
1142 | } | ||
1143 | }; | ||
1144 | |||
1145 | static struct clksrc_clk exynos4_clk_sclk_uart0 = { | ||
1146 | .clk = { | ||
1147 | .name = "uclk1", | ||
1148 | .devname = "exynos4210-uart.0", | ||
1149 | .enable = exynos4_clksrc_mask_peril0_ctrl, | ||
1150 | .ctrlbit = (1 << 0), | ||
1151 | }, | ||
1152 | .sources = &exynos4_clkset_group, | ||
1153 | .reg_src = { .reg = EXYNOS4_CLKSRC_PERIL0, .shift = 0, .size = 4 }, | ||
1154 | .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL0, .shift = 0, .size = 4 }, | ||
1155 | }; | ||
1156 | |||
1157 | static struct clksrc_clk exynos4_clk_sclk_uart1 = { | ||
1158 | .clk = { | ||
1159 | .name = "uclk1", | ||
1160 | .devname = "exynos4210-uart.1", | ||
1161 | .enable = exynos4_clksrc_mask_peril0_ctrl, | ||
1162 | .ctrlbit = (1 << 4), | ||
1163 | }, | ||
1164 | .sources = &exynos4_clkset_group, | ||
1165 | .reg_src = { .reg = EXYNOS4_CLKSRC_PERIL0, .shift = 4, .size = 4 }, | ||
1166 | .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL0, .shift = 4, .size = 4 }, | ||
1167 | }; | ||
1168 | |||
1169 | static struct clksrc_clk exynos4_clk_sclk_uart2 = { | ||
1170 | .clk = { | ||
1171 | .name = "uclk1", | ||
1172 | .devname = "exynos4210-uart.2", | ||
1173 | .enable = exynos4_clksrc_mask_peril0_ctrl, | ||
1174 | .ctrlbit = (1 << 8), | ||
1175 | }, | ||
1176 | .sources = &exynos4_clkset_group, | ||
1177 | .reg_src = { .reg = EXYNOS4_CLKSRC_PERIL0, .shift = 8, .size = 4 }, | ||
1178 | .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL0, .shift = 8, .size = 4 }, | ||
1179 | }; | ||
1180 | |||
1181 | static struct clksrc_clk exynos4_clk_sclk_uart3 = { | ||
1182 | .clk = { | ||
1183 | .name = "uclk1", | ||
1184 | .devname = "exynos4210-uart.3", | ||
1185 | .enable = exynos4_clksrc_mask_peril0_ctrl, | ||
1186 | .ctrlbit = (1 << 12), | ||
1187 | }, | ||
1188 | .sources = &exynos4_clkset_group, | ||
1189 | .reg_src = { .reg = EXYNOS4_CLKSRC_PERIL0, .shift = 12, .size = 4 }, | ||
1190 | .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL0, .shift = 12, .size = 4 }, | ||
1191 | }; | ||
1192 | |||
1193 | static struct clksrc_clk exynos4_clk_sclk_mmc0 = { | ||
1194 | .clk = { | ||
1195 | .name = "sclk_mmc", | ||
1196 | .devname = "exynos4-sdhci.0", | ||
1197 | .parent = &exynos4_clk_dout_mmc0.clk, | ||
1198 | .enable = exynos4_clksrc_mask_fsys_ctrl, | ||
1199 | .ctrlbit = (1 << 0), | ||
1200 | }, | ||
1201 | .reg_div = { .reg = EXYNOS4_CLKDIV_FSYS1, .shift = 8, .size = 8 }, | ||
1202 | }; | ||
1203 | |||
1204 | static struct clksrc_clk exynos4_clk_sclk_mmc1 = { | ||
1205 | .clk = { | ||
1206 | .name = "sclk_mmc", | ||
1207 | .devname = "exynos4-sdhci.1", | ||
1208 | .parent = &exynos4_clk_dout_mmc1.clk, | ||
1209 | .enable = exynos4_clksrc_mask_fsys_ctrl, | ||
1210 | .ctrlbit = (1 << 4), | ||
1211 | }, | ||
1212 | .reg_div = { .reg = EXYNOS4_CLKDIV_FSYS1, .shift = 24, .size = 8 }, | ||
1213 | }; | ||
1214 | |||
1215 | static struct clksrc_clk exynos4_clk_sclk_mmc2 = { | ||
1216 | .clk = { | ||
1217 | .name = "sclk_mmc", | ||
1218 | .devname = "exynos4-sdhci.2", | ||
1219 | .parent = &exynos4_clk_dout_mmc2.clk, | ||
1220 | .enable = exynos4_clksrc_mask_fsys_ctrl, | ||
1221 | .ctrlbit = (1 << 8), | ||
1222 | }, | ||
1223 | .reg_div = { .reg = EXYNOS4_CLKDIV_FSYS2, .shift = 8, .size = 8 }, | ||
1224 | }; | ||
1225 | |||
1226 | static struct clksrc_clk exynos4_clk_sclk_mmc3 = { | ||
1227 | .clk = { | ||
1228 | .name = "sclk_mmc", | ||
1229 | .devname = "exynos4-sdhci.3", | ||
1230 | .parent = &exynos4_clk_dout_mmc3.clk, | ||
1231 | .enable = exynos4_clksrc_mask_fsys_ctrl, | ||
1232 | .ctrlbit = (1 << 12), | ||
1233 | }, | ||
1234 | .reg_div = { .reg = EXYNOS4_CLKDIV_FSYS2, .shift = 24, .size = 8 }, | ||
1235 | }; | ||
1236 | |||
1237 | static struct clksrc_clk exynos4_clk_mdout_spi0 = { | ||
1238 | .clk = { | ||
1239 | .name = "mdout_spi", | ||
1240 | .devname = "exynos4210-spi.0", | ||
1241 | }, | ||
1242 | .sources = &exynos4_clkset_group, | ||
1243 | .reg_src = { .reg = EXYNOS4_CLKSRC_PERIL1, .shift = 16, .size = 4 }, | ||
1244 | .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL1, .shift = 0, .size = 4 }, | ||
1245 | }; | ||
1246 | |||
1247 | static struct clksrc_clk exynos4_clk_mdout_spi1 = { | ||
1248 | .clk = { | ||
1249 | .name = "mdout_spi", | ||
1250 | .devname = "exynos4210-spi.1", | ||
1251 | }, | ||
1252 | .sources = &exynos4_clkset_group, | ||
1253 | .reg_src = { .reg = EXYNOS4_CLKSRC_PERIL1, .shift = 20, .size = 4 }, | ||
1254 | .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL1, .shift = 16, .size = 4 }, | ||
1255 | }; | ||
1256 | |||
1257 | static struct clksrc_clk exynos4_clk_mdout_spi2 = { | ||
1258 | .clk = { | ||
1259 | .name = "mdout_spi", | ||
1260 | .devname = "exynos4210-spi.2", | ||
1261 | }, | ||
1262 | .sources = &exynos4_clkset_group, | ||
1263 | .reg_src = { .reg = EXYNOS4_CLKSRC_PERIL1, .shift = 24, .size = 4 }, | ||
1264 | .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL2, .shift = 0, .size = 4 }, | ||
1265 | }; | ||
1266 | |||
1267 | static struct clksrc_clk exynos4_clk_sclk_spi0 = { | ||
1268 | .clk = { | ||
1269 | .name = "sclk_spi", | ||
1270 | .devname = "exynos4210-spi.0", | ||
1271 | .parent = &exynos4_clk_mdout_spi0.clk, | ||
1272 | .enable = exynos4_clksrc_mask_peril1_ctrl, | ||
1273 | .ctrlbit = (1 << 16), | ||
1274 | }, | ||
1275 | .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL1, .shift = 8, .size = 8 }, | ||
1276 | }; | ||
1277 | |||
1278 | static struct clksrc_clk exynos4_clk_sclk_spi1 = { | ||
1279 | .clk = { | ||
1280 | .name = "sclk_spi", | ||
1281 | .devname = "exynos4210-spi.1", | ||
1282 | .parent = &exynos4_clk_mdout_spi1.clk, | ||
1283 | .enable = exynos4_clksrc_mask_peril1_ctrl, | ||
1284 | .ctrlbit = (1 << 20), | ||
1285 | }, | ||
1286 | .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL1, .shift = 24, .size = 8 }, | ||
1287 | }; | ||
1288 | |||
1289 | static struct clksrc_clk exynos4_clk_sclk_spi2 = { | ||
1290 | .clk = { | ||
1291 | .name = "sclk_spi", | ||
1292 | .devname = "exynos4210-spi.2", | ||
1293 | .parent = &exynos4_clk_mdout_spi2.clk, | ||
1294 | .enable = exynos4_clksrc_mask_peril1_ctrl, | ||
1295 | .ctrlbit = (1 << 24), | ||
1296 | }, | ||
1297 | .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL2, .shift = 8, .size = 8 }, | ||
1298 | }; | ||
1299 | |||
1300 | /* Clock initialization code */ | ||
1301 | static struct clksrc_clk *exynos4_sysclks[] = { | ||
1302 | &exynos4_clk_mout_apll, | ||
1303 | &exynos4_clk_sclk_apll, | ||
1304 | &exynos4_clk_mout_epll, | ||
1305 | &exynos4_clk_mout_mpll, | ||
1306 | &exynos4_clk_moutcore, | ||
1307 | &exynos4_clk_coreclk, | ||
1308 | &exynos4_clk_armclk, | ||
1309 | &exynos4_clk_aclk_corem0, | ||
1310 | &exynos4_clk_aclk_cores, | ||
1311 | &exynos4_clk_aclk_corem1, | ||
1312 | &exynos4_clk_periphclk, | ||
1313 | &exynos4_clk_mout_corebus, | ||
1314 | &exynos4_clk_sclk_dmc, | ||
1315 | &exynos4_clk_aclk_cored, | ||
1316 | &exynos4_clk_aclk_corep, | ||
1317 | &exynos4_clk_aclk_acp, | ||
1318 | &exynos4_clk_pclk_acp, | ||
1319 | &exynos4_clk_vpllsrc, | ||
1320 | &exynos4_clk_sclk_vpll, | ||
1321 | &exynos4_clk_aclk_200, | ||
1322 | &exynos4_clk_aclk_100, | ||
1323 | &exynos4_clk_aclk_160, | ||
1324 | &exynos4_clk_aclk_133, | ||
1325 | &exynos4_clk_dout_mmc0, | ||
1326 | &exynos4_clk_dout_mmc1, | ||
1327 | &exynos4_clk_dout_mmc2, | ||
1328 | &exynos4_clk_dout_mmc3, | ||
1329 | &exynos4_clk_dout_mmc4, | ||
1330 | &exynos4_clk_mout_mfc0, | ||
1331 | &exynos4_clk_mout_mfc1, | ||
1332 | }; | ||
1333 | |||
1334 | static struct clk *exynos4_clk_cdev[] = { | ||
1335 | &exynos4_clk_pdma0, | ||
1336 | &exynos4_clk_pdma1, | ||
1337 | &exynos4_clk_mdma1, | ||
1338 | &exynos4_clk_fimd0, | ||
1339 | }; | ||
1340 | |||
1341 | static struct clksrc_clk *exynos4_clksrc_cdev[] = { | ||
1342 | &exynos4_clk_sclk_uart0, | ||
1343 | &exynos4_clk_sclk_uart1, | ||
1344 | &exynos4_clk_sclk_uart2, | ||
1345 | &exynos4_clk_sclk_uart3, | ||
1346 | &exynos4_clk_sclk_mmc0, | ||
1347 | &exynos4_clk_sclk_mmc1, | ||
1348 | &exynos4_clk_sclk_mmc2, | ||
1349 | &exynos4_clk_sclk_mmc3, | ||
1350 | &exynos4_clk_sclk_spi0, | ||
1351 | &exynos4_clk_sclk_spi1, | ||
1352 | &exynos4_clk_sclk_spi2, | ||
1353 | &exynos4_clk_mdout_spi0, | ||
1354 | &exynos4_clk_mdout_spi1, | ||
1355 | &exynos4_clk_mdout_spi2, | ||
1356 | }; | ||
1357 | |||
1358 | static struct clk_lookup exynos4_clk_lookup[] = { | ||
1359 | CLKDEV_INIT("exynos4210-uart.0", "clk_uart_baud0", &exynos4_clk_sclk_uart0.clk), | ||
1360 | CLKDEV_INIT("exynos4210-uart.1", "clk_uart_baud0", &exynos4_clk_sclk_uart1.clk), | ||
1361 | CLKDEV_INIT("exynos4210-uart.2", "clk_uart_baud0", &exynos4_clk_sclk_uart2.clk), | ||
1362 | CLKDEV_INIT("exynos4210-uart.3", "clk_uart_baud0", &exynos4_clk_sclk_uart3.clk), | ||
1363 | CLKDEV_INIT("exynos4-sdhci.0", "mmc_busclk.2", &exynos4_clk_sclk_mmc0.clk), | ||
1364 | CLKDEV_INIT("exynos4-sdhci.1", "mmc_busclk.2", &exynos4_clk_sclk_mmc1.clk), | ||
1365 | CLKDEV_INIT("exynos4-sdhci.2", "mmc_busclk.2", &exynos4_clk_sclk_mmc2.clk), | ||
1366 | CLKDEV_INIT("exynos4-sdhci.3", "mmc_busclk.2", &exynos4_clk_sclk_mmc3.clk), | ||
1367 | CLKDEV_INIT("exynos4-fb.0", "lcd", &exynos4_clk_fimd0), | ||
1368 | CLKDEV_INIT("dma-pl330.0", "apb_pclk", &exynos4_clk_pdma0), | ||
1369 | CLKDEV_INIT("dma-pl330.1", "apb_pclk", &exynos4_clk_pdma1), | ||
1370 | CLKDEV_INIT("dma-pl330.2", "apb_pclk", &exynos4_clk_mdma1), | ||
1371 | CLKDEV_INIT("exynos4210-spi.0", "spi_busclk0", &exynos4_clk_sclk_spi0.clk), | ||
1372 | CLKDEV_INIT("exynos4210-spi.1", "spi_busclk0", &exynos4_clk_sclk_spi1.clk), | ||
1373 | CLKDEV_INIT("exynos4210-spi.2", "spi_busclk0", &exynos4_clk_sclk_spi2.clk), | ||
1374 | }; | ||
1375 | |||
1376 | static int xtal_rate; | ||
1377 | |||
1378 | static unsigned long exynos4_fout_apll_get_rate(struct clk *clk) | ||
1379 | { | ||
1380 | if (soc_is_exynos4210()) | ||
1381 | return s5p_get_pll45xx(xtal_rate, __raw_readl(EXYNOS4_APLL_CON0), | ||
1382 | pll_4508); | ||
1383 | else if (soc_is_exynos4212() || soc_is_exynos4412()) | ||
1384 | return s5p_get_pll35xx(xtal_rate, __raw_readl(EXYNOS4_APLL_CON0)); | ||
1385 | else | ||
1386 | return 0; | ||
1387 | } | ||
1388 | |||
1389 | static struct clk_ops exynos4_fout_apll_ops = { | ||
1390 | .get_rate = exynos4_fout_apll_get_rate, | ||
1391 | }; | ||
1392 | |||
1393 | static u32 exynos4_vpll_div[][8] = { | ||
1394 | { 54000000, 3, 53, 3, 1024, 0, 17, 0 }, | ||
1395 | { 108000000, 3, 53, 2, 1024, 0, 17, 0 }, | ||
1396 | }; | ||
1397 | |||
1398 | static unsigned long exynos4_vpll_get_rate(struct clk *clk) | ||
1399 | { | ||
1400 | return clk->rate; | ||
1401 | } | ||
1402 | |||
1403 | static int exynos4_vpll_set_rate(struct clk *clk, unsigned long rate) | ||
1404 | { | ||
1405 | unsigned int vpll_con0, vpll_con1 = 0; | ||
1406 | unsigned int i; | ||
1407 | |||
1408 | /* Return if nothing changed */ | ||
1409 | if (clk->rate == rate) | ||
1410 | return 0; | ||
1411 | |||
1412 | vpll_con0 = __raw_readl(EXYNOS4_VPLL_CON0); | ||
1413 | vpll_con0 &= ~(0x1 << 27 | \ | ||
1414 | PLL90XX_MDIV_MASK << PLL46XX_MDIV_SHIFT | \ | ||
1415 | PLL90XX_PDIV_MASK << PLL46XX_PDIV_SHIFT | \ | ||
1416 | PLL90XX_SDIV_MASK << PLL46XX_SDIV_SHIFT); | ||
1417 | |||
1418 | vpll_con1 = __raw_readl(EXYNOS4_VPLL_CON1); | ||
1419 | vpll_con1 &= ~(PLL46XX_MRR_MASK << PLL46XX_MRR_SHIFT | \ | ||
1420 | PLL46XX_MFR_MASK << PLL46XX_MFR_SHIFT | \ | ||
1421 | PLL4650C_KDIV_MASK << PLL46XX_KDIV_SHIFT); | ||
1422 | |||
1423 | for (i = 0; i < ARRAY_SIZE(exynos4_vpll_div); i++) { | ||
1424 | if (exynos4_vpll_div[i][0] == rate) { | ||
1425 | vpll_con0 |= exynos4_vpll_div[i][1] << PLL46XX_PDIV_SHIFT; | ||
1426 | vpll_con0 |= exynos4_vpll_div[i][2] << PLL46XX_MDIV_SHIFT; | ||
1427 | vpll_con0 |= exynos4_vpll_div[i][3] << PLL46XX_SDIV_SHIFT; | ||
1428 | vpll_con1 |= exynos4_vpll_div[i][4] << PLL46XX_KDIV_SHIFT; | ||
1429 | vpll_con1 |= exynos4_vpll_div[i][5] << PLL46XX_MFR_SHIFT; | ||
1430 | vpll_con1 |= exynos4_vpll_div[i][6] << PLL46XX_MRR_SHIFT; | ||
1431 | vpll_con0 |= exynos4_vpll_div[i][7] << 27; | ||
1432 | break; | ||
1433 | } | ||
1434 | } | ||
1435 | |||
1436 | if (i == ARRAY_SIZE(exynos4_vpll_div)) { | ||
1437 | printk(KERN_ERR "%s: Invalid Clock VPLL Frequency\n", | ||
1438 | __func__); | ||
1439 | return -EINVAL; | ||
1440 | } | ||
1441 | |||
1442 | __raw_writel(vpll_con0, EXYNOS4_VPLL_CON0); | ||
1443 | __raw_writel(vpll_con1, EXYNOS4_VPLL_CON1); | ||
1444 | |||
1445 | /* Wait for VPLL lock */ | ||
1446 | while (!(__raw_readl(EXYNOS4_VPLL_CON0) & (1 << PLL46XX_LOCKED_SHIFT))) | ||
1447 | continue; | ||
1448 | |||
1449 | clk->rate = rate; | ||
1450 | return 0; | ||
1451 | } | ||
1452 | |||
1453 | static struct clk_ops exynos4_vpll_ops = { | ||
1454 | .get_rate = exynos4_vpll_get_rate, | ||
1455 | .set_rate = exynos4_vpll_set_rate, | ||
1456 | }; | ||
1457 | |||
1458 | void __init_or_cpufreq exynos4_setup_clocks(void) | ||
1459 | { | ||
1460 | struct clk *xtal_clk; | ||
1461 | unsigned long apll = 0; | ||
1462 | unsigned long mpll = 0; | ||
1463 | unsigned long epll = 0; | ||
1464 | unsigned long vpll = 0; | ||
1465 | unsigned long vpllsrc; | ||
1466 | unsigned long xtal; | ||
1467 | unsigned long armclk; | ||
1468 | unsigned long sclk_dmc; | ||
1469 | unsigned long aclk_200; | ||
1470 | unsigned long aclk_100; | ||
1471 | unsigned long aclk_160; | ||
1472 | unsigned long aclk_133; | ||
1473 | unsigned int ptr; | ||
1474 | |||
1475 | printk(KERN_DEBUG "%s: registering clocks\n", __func__); | ||
1476 | |||
1477 | xtal_clk = clk_get(NULL, "xtal"); | ||
1478 | BUG_ON(IS_ERR(xtal_clk)); | ||
1479 | |||
1480 | xtal = clk_get_rate(xtal_clk); | ||
1481 | |||
1482 | xtal_rate = xtal; | ||
1483 | |||
1484 | clk_put(xtal_clk); | ||
1485 | |||
1486 | printk(KERN_DEBUG "%s: xtal is %ld\n", __func__, xtal); | ||
1487 | |||
1488 | if (soc_is_exynos4210()) { | ||
1489 | apll = s5p_get_pll45xx(xtal, __raw_readl(EXYNOS4_APLL_CON0), | ||
1490 | pll_4508); | ||
1491 | mpll = s5p_get_pll45xx(xtal, __raw_readl(EXYNOS4_MPLL_CON0), | ||
1492 | pll_4508); | ||
1493 | epll = s5p_get_pll46xx(xtal, __raw_readl(EXYNOS4_EPLL_CON0), | ||
1494 | __raw_readl(EXYNOS4_EPLL_CON1), pll_4600); | ||
1495 | |||
1496 | vpllsrc = clk_get_rate(&exynos4_clk_vpllsrc.clk); | ||
1497 | vpll = s5p_get_pll46xx(vpllsrc, __raw_readl(EXYNOS4_VPLL_CON0), | ||
1498 | __raw_readl(EXYNOS4_VPLL_CON1), pll_4650c); | ||
1499 | } else if (soc_is_exynos4212() || soc_is_exynos4412()) { | ||
1500 | apll = s5p_get_pll35xx(xtal, __raw_readl(EXYNOS4_APLL_CON0)); | ||
1501 | mpll = s5p_get_pll35xx(xtal, __raw_readl(EXYNOS4_MPLL_CON0)); | ||
1502 | epll = s5p_get_pll36xx(xtal, __raw_readl(EXYNOS4_EPLL_CON0), | ||
1503 | __raw_readl(EXYNOS4_EPLL_CON1)); | ||
1504 | |||
1505 | vpllsrc = clk_get_rate(&exynos4_clk_vpllsrc.clk); | ||
1506 | vpll = s5p_get_pll36xx(vpllsrc, __raw_readl(EXYNOS4_VPLL_CON0), | ||
1507 | __raw_readl(EXYNOS4_VPLL_CON1)); | ||
1508 | } else { | ||
1509 | /* nothing */ | ||
1510 | } | ||
1511 | |||
1512 | clk_fout_apll.ops = &exynos4_fout_apll_ops; | ||
1513 | clk_fout_mpll.rate = mpll; | ||
1514 | clk_fout_epll.rate = epll; | ||
1515 | clk_fout_vpll.ops = &exynos4_vpll_ops; | ||
1516 | clk_fout_vpll.rate = vpll; | ||
1517 | |||
1518 | printk(KERN_INFO "EXYNOS4: PLL settings, A=%ld, M=%ld, E=%ld V=%ld", | ||
1519 | apll, mpll, epll, vpll); | ||
1520 | |||
1521 | armclk = clk_get_rate(&exynos4_clk_armclk.clk); | ||
1522 | sclk_dmc = clk_get_rate(&exynos4_clk_sclk_dmc.clk); | ||
1523 | |||
1524 | aclk_200 = clk_get_rate(&exynos4_clk_aclk_200.clk); | ||
1525 | aclk_100 = clk_get_rate(&exynos4_clk_aclk_100.clk); | ||
1526 | aclk_160 = clk_get_rate(&exynos4_clk_aclk_160.clk); | ||
1527 | aclk_133 = clk_get_rate(&exynos4_clk_aclk_133.clk); | ||
1528 | |||
1529 | printk(KERN_INFO "EXYNOS4: ARMCLK=%ld, DMC=%ld, ACLK200=%ld\n" | ||
1530 | "ACLK100=%ld, ACLK160=%ld, ACLK133=%ld\n", | ||
1531 | armclk, sclk_dmc, aclk_200, | ||
1532 | aclk_100, aclk_160, aclk_133); | ||
1533 | |||
1534 | clk_f.rate = armclk; | ||
1535 | clk_h.rate = sclk_dmc; | ||
1536 | clk_p.rate = aclk_100; | ||
1537 | |||
1538 | for (ptr = 0; ptr < ARRAY_SIZE(exynos4_clksrcs); ptr++) | ||
1539 | s3c_set_clksrc(&exynos4_clksrcs[ptr], true); | ||
1540 | } | ||
1541 | |||
1542 | static struct clk *exynos4_clks[] __initdata = { | ||
1543 | &exynos4_clk_sclk_hdmi27m, | ||
1544 | &exynos4_clk_sclk_hdmiphy, | ||
1545 | &exynos4_clk_sclk_usbphy0, | ||
1546 | &exynos4_clk_sclk_usbphy1, | ||
1547 | }; | ||
1548 | |||
1549 | #ifdef CONFIG_PM_SLEEP | ||
1550 | static int exynos4_clock_suspend(void) | ||
1551 | { | ||
1552 | s3c_pm_do_save(exynos4_clock_save, ARRAY_SIZE(exynos4_clock_save)); | ||
1553 | return 0; | ||
1554 | } | ||
1555 | |||
1556 | static void exynos4_clock_resume(void) | ||
1557 | { | ||
1558 | s3c_pm_do_restore_core(exynos4_clock_save, ARRAY_SIZE(exynos4_clock_save)); | ||
1559 | } | ||
1560 | |||
1561 | #else | ||
1562 | #define exynos4_clock_suspend NULL | ||
1563 | #define exynos4_clock_resume NULL | ||
1564 | #endif | ||
1565 | |||
1566 | static struct syscore_ops exynos4_clock_syscore_ops = { | ||
1567 | .suspend = exynos4_clock_suspend, | ||
1568 | .resume = exynos4_clock_resume, | ||
1569 | }; | ||
1570 | |||
1571 | void __init exynos4_register_clocks(void) | ||
1572 | { | ||
1573 | int ptr; | ||
1574 | |||
1575 | s3c24xx_register_clocks(exynos4_clks, ARRAY_SIZE(exynos4_clks)); | ||
1576 | |||
1577 | for (ptr = 0; ptr < ARRAY_SIZE(exynos4_sysclks); ptr++) | ||
1578 | s3c_register_clksrc(exynos4_sysclks[ptr], 1); | ||
1579 | |||
1580 | for (ptr = 0; ptr < ARRAY_SIZE(exynos4_sclk_tv); ptr++) | ||
1581 | s3c_register_clksrc(exynos4_sclk_tv[ptr], 1); | ||
1582 | |||
1583 | for (ptr = 0; ptr < ARRAY_SIZE(exynos4_clksrc_cdev); ptr++) | ||
1584 | s3c_register_clksrc(exynos4_clksrc_cdev[ptr], 1); | ||
1585 | |||
1586 | s3c_register_clksrc(exynos4_clksrcs, ARRAY_SIZE(exynos4_clksrcs)); | ||
1587 | s3c_register_clocks(exynos4_init_clocks_on, ARRAY_SIZE(exynos4_init_clocks_on)); | ||
1588 | |||
1589 | s3c24xx_register_clocks(exynos4_clk_cdev, ARRAY_SIZE(exynos4_clk_cdev)); | ||
1590 | for (ptr = 0; ptr < ARRAY_SIZE(exynos4_clk_cdev); ptr++) | ||
1591 | s3c_disable_clocks(exynos4_clk_cdev[ptr], 1); | ||
1592 | |||
1593 | s3c_register_clocks(exynos4_init_clocks_off, ARRAY_SIZE(exynos4_init_clocks_off)); | ||
1594 | s3c_disable_clocks(exynos4_init_clocks_off, ARRAY_SIZE(exynos4_init_clocks_off)); | ||
1595 | clkdev_add_table(exynos4_clk_lookup, ARRAY_SIZE(exynos4_clk_lookup)); | ||
1596 | |||
1597 | register_syscore_ops(&exynos4_clock_syscore_ops); | ||
1598 | s3c24xx_register_clock(&dummy_apb_pclk); | ||
1599 | |||
1600 | s3c_pwmclk_init(); | ||
1601 | } | ||
diff --git a/arch/arm/mach-exynos/clock-exynos4.h b/arch/arm/mach-exynos/clock-exynos4.h deleted file mode 100644 index bd12d5f8b63d..000000000000 --- a/arch/arm/mach-exynos/clock-exynos4.h +++ /dev/null | |||
@@ -1,35 +0,0 @@ | |||
1 | /* | ||
2 | * Copyright (c) 2011-2012 Samsung Electronics Co., Ltd. | ||
3 | * http://www.samsung.com | ||
4 | * | ||
5 | * Header file for exynos4 clock support | ||
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 | |||
12 | #ifndef __ASM_ARCH_CLOCK_H | ||
13 | #define __ASM_ARCH_CLOCK_H __FILE__ | ||
14 | |||
15 | #include <linux/clk.h> | ||
16 | |||
17 | extern struct clksrc_clk exynos4_clk_aclk_133; | ||
18 | extern struct clksrc_clk exynos4_clk_mout_mpll; | ||
19 | |||
20 | extern struct clksrc_sources exynos4_clkset_mout_corebus; | ||
21 | extern struct clksrc_sources exynos4_clkset_group; | ||
22 | |||
23 | extern struct clk *exynos4_clkset_aclk_top_list[]; | ||
24 | extern struct clk *exynos4_clkset_group_list[]; | ||
25 | |||
26 | extern struct clksrc_sources exynos4_clkset_mout_g2d0; | ||
27 | extern struct clksrc_sources exynos4_clkset_mout_g2d1; | ||
28 | |||
29 | extern int exynos4_clksrc_mask_fsys_ctrl(struct clk *clk, int enable); | ||
30 | extern int exynos4_clk_ip_fsys_ctrl(struct clk *clk, int enable); | ||
31 | extern int exynos4_clk_ip_lcd1_ctrl(struct clk *clk, int enable); | ||
32 | extern int exynos4_clk_ip_image_ctrl(struct clk *clk, int enable); | ||
33 | extern int exynos4_clk_ip_dmc_ctrl(struct clk *clk, int enable); | ||
34 | |||
35 | #endif /* __ASM_ARCH_CLOCK_H */ | ||
diff --git a/arch/arm/mach-exynos/clock-exynos4210.c b/arch/arm/mach-exynos/clock-exynos4210.c deleted file mode 100644 index 19af9f783c56..000000000000 --- a/arch/arm/mach-exynos/clock-exynos4210.c +++ /dev/null | |||
@@ -1,187 +0,0 @@ | |||
1 | /* | ||
2 | * Copyright (c) 2011-2012 Samsung Electronics Co., Ltd. | ||
3 | * http://www.samsung.com | ||
4 | * | ||
5 | * EXYNOS4210 - Clock support | ||
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 | |||
12 | #include <linux/kernel.h> | ||
13 | #include <linux/err.h> | ||
14 | #include <linux/clk.h> | ||
15 | #include <linux/io.h> | ||
16 | #include <linux/syscore_ops.h> | ||
17 | |||
18 | #include <plat/cpu-freq.h> | ||
19 | #include <plat/clock.h> | ||
20 | #include <plat/cpu.h> | ||
21 | #include <plat/pll.h> | ||
22 | #include <plat/s5p-clock.h> | ||
23 | #include <plat/clock-clksrc.h> | ||
24 | #include <plat/pm.h> | ||
25 | |||
26 | #include <mach/hardware.h> | ||
27 | #include <mach/map.h> | ||
28 | #include <mach/regs-clock.h> | ||
29 | |||
30 | #include "common.h" | ||
31 | #include "clock-exynos4.h" | ||
32 | |||
33 | #ifdef CONFIG_PM_SLEEP | ||
34 | static struct sleep_save exynos4210_clock_save[] = { | ||
35 | SAVE_ITEM(EXYNOS4_CLKSRC_IMAGE), | ||
36 | SAVE_ITEM(EXYNOS4_CLKDIV_IMAGE), | ||
37 | SAVE_ITEM(EXYNOS4210_CLKSRC_LCD1), | ||
38 | SAVE_ITEM(EXYNOS4210_CLKDIV_LCD1), | ||
39 | SAVE_ITEM(EXYNOS4210_CLKSRC_MASK_LCD1), | ||
40 | SAVE_ITEM(EXYNOS4210_CLKGATE_IP_IMAGE), | ||
41 | SAVE_ITEM(EXYNOS4210_CLKGATE_IP_LCD1), | ||
42 | SAVE_ITEM(EXYNOS4210_CLKGATE_IP_PERIR), | ||
43 | }; | ||
44 | #endif | ||
45 | |||
46 | static struct clksrc_clk *sysclks[] = { | ||
47 | /* nothing here yet */ | ||
48 | }; | ||
49 | |||
50 | static struct clksrc_clk exynos4210_clk_mout_g2d0 = { | ||
51 | .clk = { | ||
52 | .name = "mout_g2d0", | ||
53 | }, | ||
54 | .sources = &exynos4_clkset_mout_g2d0, | ||
55 | .reg_src = { .reg = EXYNOS4_CLKSRC_IMAGE, .shift = 0, .size = 1 }, | ||
56 | }; | ||
57 | |||
58 | static struct clksrc_clk exynos4210_clk_mout_g2d1 = { | ||
59 | .clk = { | ||
60 | .name = "mout_g2d1", | ||
61 | }, | ||
62 | .sources = &exynos4_clkset_mout_g2d1, | ||
63 | .reg_src = { .reg = EXYNOS4_CLKSRC_IMAGE, .shift = 4, .size = 1 }, | ||
64 | }; | ||
65 | |||
66 | static struct clk *exynos4210_clkset_mout_g2d_list[] = { | ||
67 | [0] = &exynos4210_clk_mout_g2d0.clk, | ||
68 | [1] = &exynos4210_clk_mout_g2d1.clk, | ||
69 | }; | ||
70 | |||
71 | static struct clksrc_sources exynos4210_clkset_mout_g2d = { | ||
72 | .sources = exynos4210_clkset_mout_g2d_list, | ||
73 | .nr_sources = ARRAY_SIZE(exynos4210_clkset_mout_g2d_list), | ||
74 | }; | ||
75 | |||
76 | static int exynos4_clksrc_mask_lcd1_ctrl(struct clk *clk, int enable) | ||
77 | { | ||
78 | return s5p_gatectrl(EXYNOS4210_CLKSRC_MASK_LCD1, clk, enable); | ||
79 | } | ||
80 | |||
81 | static struct clksrc_clk clksrcs[] = { | ||
82 | { | ||
83 | .clk = { | ||
84 | .name = "sclk_sata", | ||
85 | .id = -1, | ||
86 | .enable = exynos4_clksrc_mask_fsys_ctrl, | ||
87 | .ctrlbit = (1 << 24), | ||
88 | }, | ||
89 | .sources = &exynos4_clkset_mout_corebus, | ||
90 | .reg_src = { .reg = EXYNOS4_CLKSRC_FSYS, .shift = 24, .size = 1 }, | ||
91 | .reg_div = { .reg = EXYNOS4_CLKDIV_FSYS0, .shift = 20, .size = 4 }, | ||
92 | }, { | ||
93 | .clk = { | ||
94 | .name = "sclk_fimd", | ||
95 | .devname = "exynos4-fb.1", | ||
96 | .enable = exynos4_clksrc_mask_lcd1_ctrl, | ||
97 | .ctrlbit = (1 << 0), | ||
98 | }, | ||
99 | .sources = &exynos4_clkset_group, | ||
100 | .reg_src = { .reg = EXYNOS4210_CLKSRC_LCD1, .shift = 0, .size = 4 }, | ||
101 | .reg_div = { .reg = EXYNOS4210_CLKDIV_LCD1, .shift = 0, .size = 4 }, | ||
102 | }, { | ||
103 | .clk = { | ||
104 | .name = "sclk_fimg2d", | ||
105 | }, | ||
106 | .sources = &exynos4210_clkset_mout_g2d, | ||
107 | .reg_src = { .reg = EXYNOS4_CLKSRC_IMAGE, .shift = 8, .size = 1 }, | ||
108 | .reg_div = { .reg = EXYNOS4_CLKDIV_IMAGE, .shift = 0, .size = 4 }, | ||
109 | }, | ||
110 | }; | ||
111 | |||
112 | static struct clk init_clocks_off[] = { | ||
113 | { | ||
114 | .name = "sataphy", | ||
115 | .id = -1, | ||
116 | .parent = &exynos4_clk_aclk_133.clk, | ||
117 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
118 | .ctrlbit = (1 << 3), | ||
119 | }, { | ||
120 | .name = "sata", | ||
121 | .id = -1, | ||
122 | .parent = &exynos4_clk_aclk_133.clk, | ||
123 | .enable = exynos4_clk_ip_fsys_ctrl, | ||
124 | .ctrlbit = (1 << 10), | ||
125 | }, { | ||
126 | .name = "fimd", | ||
127 | .devname = "exynos4-fb.1", | ||
128 | .enable = exynos4_clk_ip_lcd1_ctrl, | ||
129 | .ctrlbit = (1 << 0), | ||
130 | }, { | ||
131 | .name = "sysmmu", | ||
132 | .devname = "exynos-sysmmu.9", | ||
133 | .enable = exynos4_clk_ip_image_ctrl, | ||
134 | .ctrlbit = (1 << 3), | ||
135 | }, { | ||
136 | .name = "sysmmu", | ||
137 | .devname = "exynos-sysmmu.11", | ||
138 | .enable = exynos4_clk_ip_lcd1_ctrl, | ||
139 | .ctrlbit = (1 << 4), | ||
140 | }, { | ||
141 | .name = "fimg2d", | ||
142 | .enable = exynos4_clk_ip_image_ctrl, | ||
143 | .ctrlbit = (1 << 0), | ||
144 | }, | ||
145 | }; | ||
146 | |||
147 | #ifdef CONFIG_PM_SLEEP | ||
148 | static int exynos4210_clock_suspend(void) | ||
149 | { | ||
150 | s3c_pm_do_save(exynos4210_clock_save, ARRAY_SIZE(exynos4210_clock_save)); | ||
151 | |||
152 | return 0; | ||
153 | } | ||
154 | |||
155 | static void exynos4210_clock_resume(void) | ||
156 | { | ||
157 | s3c_pm_do_restore_core(exynos4210_clock_save, ARRAY_SIZE(exynos4210_clock_save)); | ||
158 | } | ||
159 | |||
160 | #else | ||
161 | #define exynos4210_clock_suspend NULL | ||
162 | #define exynos4210_clock_resume NULL | ||
163 | #endif | ||
164 | |||
165 | static struct syscore_ops exynos4210_clock_syscore_ops = { | ||
166 | .suspend = exynos4210_clock_suspend, | ||
167 | .resume = exynos4210_clock_resume, | ||
168 | }; | ||
169 | |||
170 | void __init exynos4210_register_clocks(void) | ||
171 | { | ||
172 | int ptr; | ||
173 | |||
174 | exynos4_clk_mout_mpll.reg_src.reg = EXYNOS4_CLKSRC_CPU; | ||
175 | exynos4_clk_mout_mpll.reg_src.shift = 8; | ||
176 | exynos4_clk_mout_mpll.reg_src.size = 1; | ||
177 | |||
178 | for (ptr = 0; ptr < ARRAY_SIZE(sysclks); ptr++) | ||
179 | s3c_register_clksrc(sysclks[ptr], 1); | ||
180 | |||
181 | s3c_register_clksrc(clksrcs, ARRAY_SIZE(clksrcs)); | ||
182 | |||
183 | s3c_register_clocks(init_clocks_off, ARRAY_SIZE(init_clocks_off)); | ||
184 | s3c_disable_clocks(init_clocks_off, ARRAY_SIZE(init_clocks_off)); | ||
185 | |||
186 | register_syscore_ops(&exynos4210_clock_syscore_ops); | ||
187 | } | ||
diff --git a/arch/arm/mach-exynos/clock-exynos4212.c b/arch/arm/mach-exynos/clock-exynos4212.c deleted file mode 100644 index 529476f8ec71..000000000000 --- a/arch/arm/mach-exynos/clock-exynos4212.c +++ /dev/null | |||
@@ -1,201 +0,0 @@ | |||
1 | /* | ||
2 | * Copyright (c) 2011-2012 Samsung Electronics Co., Ltd. | ||
3 | * http://www.samsung.com | ||
4 | * | ||
5 | * EXYNOS4212 - Clock support | ||
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 | |||
12 | #include <linux/kernel.h> | ||
13 | #include <linux/err.h> | ||
14 | #include <linux/clk.h> | ||
15 | #include <linux/io.h> | ||
16 | #include <linux/syscore_ops.h> | ||
17 | |||
18 | #include <plat/cpu-freq.h> | ||
19 | #include <plat/clock.h> | ||
20 | #include <plat/cpu.h> | ||
21 | #include <plat/pll.h> | ||
22 | #include <plat/s5p-clock.h> | ||
23 | #include <plat/clock-clksrc.h> | ||
24 | #include <plat/pm.h> | ||
25 | |||
26 | #include <mach/hardware.h> | ||
27 | #include <mach/map.h> | ||
28 | #include <mach/regs-clock.h> | ||
29 | |||
30 | #include "common.h" | ||
31 | #include "clock-exynos4.h" | ||
32 | |||
33 | #ifdef CONFIG_PM_SLEEP | ||
34 | static struct sleep_save exynos4212_clock_save[] = { | ||
35 | SAVE_ITEM(EXYNOS4_CLKSRC_IMAGE), | ||
36 | SAVE_ITEM(EXYNOS4_CLKDIV_IMAGE), | ||
37 | SAVE_ITEM(EXYNOS4212_CLKGATE_IP_IMAGE), | ||
38 | SAVE_ITEM(EXYNOS4212_CLKGATE_IP_PERIR), | ||
39 | }; | ||
40 | #endif | ||
41 | |||
42 | static int exynos4212_clk_ip_isp0_ctrl(struct clk *clk, int enable) | ||
43 | { | ||
44 | return s5p_gatectrl(EXYNOS4_CLKGATE_IP_ISP0, clk, enable); | ||
45 | } | ||
46 | |||
47 | static int exynos4212_clk_ip_isp1_ctrl(struct clk *clk, int enable) | ||
48 | { | ||
49 | return s5p_gatectrl(EXYNOS4_CLKGATE_IP_ISP1, clk, enable); | ||
50 | } | ||
51 | |||
52 | static struct clk *clk_src_mpll_user_list[] = { | ||
53 | [0] = &clk_fin_mpll, | ||
54 | [1] = &exynos4_clk_mout_mpll.clk, | ||
55 | }; | ||
56 | |||
57 | static struct clksrc_sources clk_src_mpll_user = { | ||
58 | .sources = clk_src_mpll_user_list, | ||
59 | .nr_sources = ARRAY_SIZE(clk_src_mpll_user_list), | ||
60 | }; | ||
61 | |||
62 | static struct clksrc_clk clk_mout_mpll_user = { | ||
63 | .clk = { | ||
64 | .name = "mout_mpll_user", | ||
65 | }, | ||
66 | .sources = &clk_src_mpll_user, | ||
67 | .reg_src = { .reg = EXYNOS4_CLKSRC_CPU, .shift = 24, .size = 1 }, | ||
68 | }; | ||
69 | |||
70 | static struct clksrc_clk exynos4x12_clk_mout_g2d0 = { | ||
71 | .clk = { | ||
72 | .name = "mout_g2d0", | ||
73 | }, | ||
74 | .sources = &exynos4_clkset_mout_g2d0, | ||
75 | .reg_src = { .reg = EXYNOS4_CLKSRC_DMC, .shift = 20, .size = 1 }, | ||
76 | }; | ||
77 | |||
78 | static struct clksrc_clk exynos4x12_clk_mout_g2d1 = { | ||
79 | .clk = { | ||
80 | .name = "mout_g2d1", | ||
81 | }, | ||
82 | .sources = &exynos4_clkset_mout_g2d1, | ||
83 | .reg_src = { .reg = EXYNOS4_CLKSRC_DMC, .shift = 24, .size = 1 }, | ||
84 | }; | ||
85 | |||
86 | static struct clk *exynos4x12_clkset_mout_g2d_list[] = { | ||
87 | [0] = &exynos4x12_clk_mout_g2d0.clk, | ||
88 | [1] = &exynos4x12_clk_mout_g2d1.clk, | ||
89 | }; | ||
90 | |||
91 | static struct clksrc_sources exynos4x12_clkset_mout_g2d = { | ||
92 | .sources = exynos4x12_clkset_mout_g2d_list, | ||
93 | .nr_sources = ARRAY_SIZE(exynos4x12_clkset_mout_g2d_list), | ||
94 | }; | ||
95 | |||
96 | static struct clksrc_clk *sysclks[] = { | ||
97 | &clk_mout_mpll_user, | ||
98 | }; | ||
99 | |||
100 | static struct clksrc_clk clksrcs[] = { | ||
101 | { | ||
102 | .clk = { | ||
103 | .name = "sclk_fimg2d", | ||
104 | }, | ||
105 | .sources = &exynos4x12_clkset_mout_g2d, | ||
106 | .reg_src = { .reg = EXYNOS4_CLKSRC_DMC, .shift = 28, .size = 1 }, | ||
107 | .reg_div = { .reg = EXYNOS4_CLKDIV_DMC1, .shift = 0, .size = 4 }, | ||
108 | }, | ||
109 | }; | ||
110 | |||
111 | static struct clk init_clocks_off[] = { | ||
112 | { | ||
113 | .name = "sysmmu", | ||
114 | .devname = "exynos-sysmmu.9", | ||
115 | .enable = exynos4_clk_ip_dmc_ctrl, | ||
116 | .ctrlbit = (1 << 24), | ||
117 | }, { | ||
118 | .name = "sysmmu", | ||
119 | .devname = "exynos-sysmmu.12", | ||
120 | .enable = exynos4212_clk_ip_isp0_ctrl, | ||
121 | .ctrlbit = (7 << 8), | ||
122 | }, { | ||
123 | .name = "sysmmu", | ||
124 | .devname = "exynos-sysmmu.13", | ||
125 | .enable = exynos4212_clk_ip_isp1_ctrl, | ||
126 | .ctrlbit = (1 << 4), | ||
127 | }, { | ||
128 | .name = "sysmmu", | ||
129 | .devname = "exynos-sysmmu.14", | ||
130 | .enable = exynos4212_clk_ip_isp0_ctrl, | ||
131 | .ctrlbit = (1 << 11), | ||
132 | }, { | ||
133 | .name = "sysmmu", | ||
134 | .devname = "exynos-sysmmu.15", | ||
135 | .enable = exynos4212_clk_ip_isp0_ctrl, | ||
136 | .ctrlbit = (1 << 12), | ||
137 | }, { | ||
138 | .name = "flite", | ||
139 | .devname = "exynos-fimc-lite.0", | ||
140 | .enable = exynos4212_clk_ip_isp0_ctrl, | ||
141 | .ctrlbit = (1 << 4), | ||
142 | }, { | ||
143 | .name = "flite", | ||
144 | .devname = "exynos-fimc-lite.1", | ||
145 | .enable = exynos4212_clk_ip_isp0_ctrl, | ||
146 | .ctrlbit = (1 << 3), | ||
147 | }, { | ||
148 | .name = "fimg2d", | ||
149 | .enable = exynos4_clk_ip_dmc_ctrl, | ||
150 | .ctrlbit = (1 << 23), | ||
151 | }, | ||
152 | }; | ||
153 | |||
154 | #ifdef CONFIG_PM_SLEEP | ||
155 | static int exynos4212_clock_suspend(void) | ||
156 | { | ||
157 | s3c_pm_do_save(exynos4212_clock_save, ARRAY_SIZE(exynos4212_clock_save)); | ||
158 | |||
159 | return 0; | ||
160 | } | ||
161 | |||
162 | static void exynos4212_clock_resume(void) | ||
163 | { | ||
164 | s3c_pm_do_restore_core(exynos4212_clock_save, ARRAY_SIZE(exynos4212_clock_save)); | ||
165 | } | ||
166 | |||
167 | #else | ||
168 | #define exynos4212_clock_suspend NULL | ||
169 | #define exynos4212_clock_resume NULL | ||
170 | #endif | ||
171 | |||
172 | static struct syscore_ops exynos4212_clock_syscore_ops = { | ||
173 | .suspend = exynos4212_clock_suspend, | ||
174 | .resume = exynos4212_clock_resume, | ||
175 | }; | ||
176 | |||
177 | void __init exynos4212_register_clocks(void) | ||
178 | { | ||
179 | int ptr; | ||
180 | |||
181 | /* usbphy1 is removed */ | ||
182 | exynos4_clkset_group_list[4] = NULL; | ||
183 | |||
184 | /* mout_mpll_user is used */ | ||
185 | exynos4_clkset_group_list[6] = &clk_mout_mpll_user.clk; | ||
186 | exynos4_clkset_aclk_top_list[0] = &clk_mout_mpll_user.clk; | ||
187 | |||
188 | exynos4_clk_mout_mpll.reg_src.reg = EXYNOS4_CLKSRC_DMC; | ||
189 | exynos4_clk_mout_mpll.reg_src.shift = 12; | ||
190 | exynos4_clk_mout_mpll.reg_src.size = 1; | ||
191 | |||
192 | for (ptr = 0; ptr < ARRAY_SIZE(sysclks); ptr++) | ||
193 | s3c_register_clksrc(sysclks[ptr], 1); | ||
194 | |||
195 | s3c_register_clksrc(clksrcs, ARRAY_SIZE(clksrcs)); | ||
196 | |||
197 | s3c_register_clocks(init_clocks_off, ARRAY_SIZE(init_clocks_off)); | ||
198 | s3c_disable_clocks(init_clocks_off, ARRAY_SIZE(init_clocks_off)); | ||
199 | |||
200 | register_syscore_ops(&exynos4212_clock_syscore_ops); | ||
201 | } | ||
diff --git a/arch/arm/mach-exynos/clock-exynos5.c b/arch/arm/mach-exynos/clock-exynos5.c deleted file mode 100644 index b0ea31fc9fb8..000000000000 --- a/arch/arm/mach-exynos/clock-exynos5.c +++ /dev/null | |||
@@ -1,1645 +0,0 @@ | |||
1 | /* | ||
2 | * Copyright (c) 2012 Samsung Electronics Co., Ltd. | ||
3 | * http://www.samsung.com | ||
4 | * | ||
5 | * Clock support for EXYNOS5 SoCs | ||
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 | |||
12 | #include <linux/kernel.h> | ||
13 | #include <linux/err.h> | ||
14 | #include <linux/io.h> | ||
15 | #include <linux/syscore_ops.h> | ||
16 | |||
17 | #include <plat/cpu-freq.h> | ||
18 | #include <plat/clock.h> | ||
19 | #include <plat/cpu.h> | ||
20 | #include <plat/pll.h> | ||
21 | #include <plat/s5p-clock.h> | ||
22 | #include <plat/clock-clksrc.h> | ||
23 | #include <plat/pm.h> | ||
24 | |||
25 | #include <mach/map.h> | ||
26 | #include <mach/regs-clock.h> | ||
27 | |||
28 | #include "common.h" | ||
29 | |||
30 | #ifdef CONFIG_PM_SLEEP | ||
31 | static struct sleep_save exynos5_clock_save[] = { | ||
32 | SAVE_ITEM(EXYNOS5_CLKSRC_MASK_TOP), | ||
33 | SAVE_ITEM(EXYNOS5_CLKSRC_MASK_GSCL), | ||
34 | SAVE_ITEM(EXYNOS5_CLKSRC_MASK_DISP1_0), | ||
35 | SAVE_ITEM(EXYNOS5_CLKSRC_MASK_FSYS), | ||
36 | SAVE_ITEM(EXYNOS5_CLKSRC_MASK_MAUDIO), | ||
37 | SAVE_ITEM(EXYNOS5_CLKSRC_MASK_PERIC0), | ||
38 | SAVE_ITEM(EXYNOS5_CLKSRC_MASK_PERIC1), | ||
39 | SAVE_ITEM(EXYNOS5_CLKGATE_IP_GSCL), | ||
40 | SAVE_ITEM(EXYNOS5_CLKGATE_IP_DISP1), | ||
41 | SAVE_ITEM(EXYNOS5_CLKGATE_IP_MFC), | ||
42 | SAVE_ITEM(EXYNOS5_CLKGATE_IP_G3D), | ||
43 | SAVE_ITEM(EXYNOS5_CLKGATE_IP_GEN), | ||
44 | SAVE_ITEM(EXYNOS5_CLKGATE_IP_FSYS), | ||
45 | SAVE_ITEM(EXYNOS5_CLKGATE_IP_PERIC), | ||
46 | SAVE_ITEM(EXYNOS5_CLKGATE_IP_PERIS), | ||
47 | SAVE_ITEM(EXYNOS5_CLKGATE_BLOCK), | ||
48 | SAVE_ITEM(EXYNOS5_CLKDIV_TOP0), | ||
49 | SAVE_ITEM(EXYNOS5_CLKDIV_TOP1), | ||
50 | SAVE_ITEM(EXYNOS5_CLKDIV_GSCL), | ||
51 | SAVE_ITEM(EXYNOS5_CLKDIV_DISP1_0), | ||
52 | SAVE_ITEM(EXYNOS5_CLKDIV_GEN), | ||
53 | SAVE_ITEM(EXYNOS5_CLKDIV_MAUDIO), | ||
54 | SAVE_ITEM(EXYNOS5_CLKDIV_FSYS0), | ||
55 | SAVE_ITEM(EXYNOS5_CLKDIV_FSYS1), | ||
56 | SAVE_ITEM(EXYNOS5_CLKDIV_FSYS2), | ||
57 | SAVE_ITEM(EXYNOS5_CLKDIV_FSYS3), | ||
58 | SAVE_ITEM(EXYNOS5_CLKDIV_PERIC0), | ||
59 | SAVE_ITEM(EXYNOS5_CLKDIV_PERIC1), | ||
60 | SAVE_ITEM(EXYNOS5_CLKDIV_PERIC2), | ||
61 | SAVE_ITEM(EXYNOS5_CLKDIV_PERIC3), | ||
62 | SAVE_ITEM(EXYNOS5_CLKDIV_PERIC4), | ||
63 | SAVE_ITEM(EXYNOS5_CLKDIV_PERIC5), | ||
64 | SAVE_ITEM(EXYNOS5_SCLK_DIV_ISP), | ||
65 | SAVE_ITEM(EXYNOS5_CLKSRC_TOP0), | ||
66 | SAVE_ITEM(EXYNOS5_CLKSRC_TOP1), | ||
67 | SAVE_ITEM(EXYNOS5_CLKSRC_TOP2), | ||
68 | SAVE_ITEM(EXYNOS5_CLKSRC_TOP3), | ||
69 | SAVE_ITEM(EXYNOS5_CLKSRC_GSCL), | ||
70 | SAVE_ITEM(EXYNOS5_CLKSRC_DISP1_0), | ||
71 | SAVE_ITEM(EXYNOS5_CLKSRC_MAUDIO), | ||
72 | SAVE_ITEM(EXYNOS5_CLKSRC_FSYS), | ||
73 | SAVE_ITEM(EXYNOS5_CLKSRC_PERIC0), | ||
74 | SAVE_ITEM(EXYNOS5_CLKSRC_PERIC1), | ||
75 | SAVE_ITEM(EXYNOS5_SCLK_SRC_ISP), | ||
76 | SAVE_ITEM(EXYNOS5_EPLL_CON0), | ||
77 | SAVE_ITEM(EXYNOS5_EPLL_CON1), | ||
78 | SAVE_ITEM(EXYNOS5_EPLL_CON2), | ||
79 | SAVE_ITEM(EXYNOS5_VPLL_CON0), | ||
80 | SAVE_ITEM(EXYNOS5_VPLL_CON1), | ||
81 | SAVE_ITEM(EXYNOS5_VPLL_CON2), | ||
82 | SAVE_ITEM(EXYNOS5_PWR_CTRL1), | ||
83 | SAVE_ITEM(EXYNOS5_PWR_CTRL2), | ||
84 | }; | ||
85 | #endif | ||
86 | |||
87 | static struct clk exynos5_clk_sclk_dptxphy = { | ||
88 | .name = "sclk_dptx", | ||
89 | }; | ||
90 | |||
91 | static struct clk exynos5_clk_sclk_hdmi24m = { | ||
92 | .name = "sclk_hdmi24m", | ||
93 | .rate = 24000000, | ||
94 | }; | ||
95 | |||
96 | static struct clk exynos5_clk_sclk_hdmi27m = { | ||
97 | .name = "sclk_hdmi27m", | ||
98 | .rate = 27000000, | ||
99 | }; | ||
100 | |||
101 | static struct clk exynos5_clk_sclk_hdmiphy = { | ||
102 | .name = "sclk_hdmiphy", | ||
103 | }; | ||
104 | |||
105 | static struct clk exynos5_clk_sclk_usbphy = { | ||
106 | .name = "sclk_usbphy", | ||
107 | .rate = 48000000, | ||
108 | }; | ||
109 | |||
110 | static int exynos5_clksrc_mask_top_ctrl(struct clk *clk, int enable) | ||
111 | { | ||
112 | return s5p_gatectrl(EXYNOS5_CLKSRC_MASK_TOP, clk, enable); | ||
113 | } | ||
114 | |||
115 | static int exynos5_clksrc_mask_disp1_0_ctrl(struct clk *clk, int enable) | ||
116 | { | ||
117 | return s5p_gatectrl(EXYNOS5_CLKSRC_MASK_DISP1_0, clk, enable); | ||
118 | } | ||
119 | |||
120 | static int exynos5_clksrc_mask_fsys_ctrl(struct clk *clk, int enable) | ||
121 | { | ||
122 | return s5p_gatectrl(EXYNOS5_CLKSRC_MASK_FSYS, clk, enable); | ||
123 | } | ||
124 | |||
125 | static int exynos5_clksrc_mask_gscl_ctrl(struct clk *clk, int enable) | ||
126 | { | ||
127 | return s5p_gatectrl(EXYNOS5_CLKSRC_MASK_GSCL, clk, enable); | ||
128 | } | ||
129 | |||
130 | static int exynos5_clksrc_mask_peric0_ctrl(struct clk *clk, int enable) | ||
131 | { | ||
132 | return s5p_gatectrl(EXYNOS5_CLKSRC_MASK_PERIC0, clk, enable); | ||
133 | } | ||
134 | |||
135 | static int exynos5_clksrc_mask_peric1_ctrl(struct clk *clk, int enable) | ||
136 | { | ||
137 | return s5p_gatectrl(EXYNOS5_CLKSRC_MASK_PERIC1, clk, enable); | ||
138 | } | ||
139 | |||
140 | static int exynos5_clk_ip_acp_ctrl(struct clk *clk, int enable) | ||
141 | { | ||
142 | return s5p_gatectrl(EXYNOS5_CLKGATE_IP_ACP, clk, enable); | ||
143 | } | ||
144 | |||
145 | static int exynos5_clk_ip_core_ctrl(struct clk *clk, int enable) | ||
146 | { | ||
147 | return s5p_gatectrl(EXYNOS5_CLKGATE_IP_CORE, clk, enable); | ||
148 | } | ||
149 | |||
150 | static int exynos5_clk_ip_disp1_ctrl(struct clk *clk, int enable) | ||
151 | { | ||
152 | return s5p_gatectrl(EXYNOS5_CLKGATE_IP_DISP1, clk, enable); | ||
153 | } | ||
154 | |||
155 | static int exynos5_clk_ip_fsys_ctrl(struct clk *clk, int enable) | ||
156 | { | ||
157 | return s5p_gatectrl(EXYNOS5_CLKGATE_IP_FSYS, clk, enable); | ||
158 | } | ||
159 | |||
160 | static int exynos5_clk_block_ctrl(struct clk *clk, int enable) | ||
161 | { | ||
162 | return s5p_gatectrl(EXYNOS5_CLKGATE_BLOCK, clk, enable); | ||
163 | } | ||
164 | |||
165 | static int exynos5_clk_ip_gen_ctrl(struct clk *clk, int enable) | ||
166 | { | ||
167 | return s5p_gatectrl(EXYNOS5_CLKGATE_IP_GEN, clk, enable); | ||
168 | } | ||
169 | |||
170 | static int exynos5_clk_ip_mfc_ctrl(struct clk *clk, int enable) | ||
171 | { | ||
172 | return s5p_gatectrl(EXYNOS5_CLKGATE_IP_MFC, clk, enable); | ||
173 | } | ||
174 | |||
175 | static int exynos5_clk_ip_peric_ctrl(struct clk *clk, int enable) | ||
176 | { | ||
177 | return s5p_gatectrl(EXYNOS5_CLKGATE_IP_PERIC, clk, enable); | ||
178 | } | ||
179 | |||
180 | static int exynos5_clk_ip_peris_ctrl(struct clk *clk, int enable) | ||
181 | { | ||
182 | return s5p_gatectrl(EXYNOS5_CLKGATE_IP_PERIS, clk, enable); | ||
183 | } | ||
184 | |||
185 | static int exynos5_clk_ip_gscl_ctrl(struct clk *clk, int enable) | ||
186 | { | ||
187 | return s5p_gatectrl(EXYNOS5_CLKGATE_IP_GSCL, clk, enable); | ||
188 | } | ||
189 | |||
190 | static int exynos5_clk_ip_isp0_ctrl(struct clk *clk, int enable) | ||
191 | { | ||
192 | return s5p_gatectrl(EXYNOS5_CLKGATE_IP_ISP0, clk, enable); | ||
193 | } | ||
194 | |||
195 | static int exynos5_clk_ip_isp1_ctrl(struct clk *clk, int enable) | ||
196 | { | ||
197 | return s5p_gatectrl(EXYNOS5_CLKGATE_IP_ISP1, clk, enable); | ||
198 | } | ||
199 | |||
200 | static int exynos5_clk_hdmiphy_ctrl(struct clk *clk, int enable) | ||
201 | { | ||
202 | return s5p_gatectrl(S5P_HDMI_PHY_CONTROL, clk, enable); | ||
203 | } | ||
204 | |||
205 | /* Core list of CMU_CPU side */ | ||
206 | |||
207 | static struct clksrc_clk exynos5_clk_mout_apll = { | ||
208 | .clk = { | ||
209 | .name = "mout_apll", | ||
210 | }, | ||
211 | .sources = &clk_src_apll, | ||
212 | .reg_src = { .reg = EXYNOS5_CLKSRC_CPU, .shift = 0, .size = 1 }, | ||
213 | }; | ||
214 | |||
215 | static struct clksrc_clk exynos5_clk_sclk_apll = { | ||
216 | .clk = { | ||
217 | .name = "sclk_apll", | ||
218 | .parent = &exynos5_clk_mout_apll.clk, | ||
219 | }, | ||
220 | .reg_div = { .reg = EXYNOS5_CLKDIV_CPU0, .shift = 24, .size = 3 }, | ||
221 | }; | ||
222 | |||
223 | static struct clksrc_clk exynos5_clk_mout_bpll_fout = { | ||
224 | .clk = { | ||
225 | .name = "mout_bpll_fout", | ||
226 | }, | ||
227 | .sources = &clk_src_bpll_fout, | ||
228 | .reg_src = { .reg = EXYNOS5_PLL_DIV2_SEL, .shift = 0, .size = 1 }, | ||
229 | }; | ||
230 | |||
231 | static struct clk *exynos5_clk_src_bpll_list[] = { | ||
232 | [0] = &clk_fin_bpll, | ||
233 | [1] = &exynos5_clk_mout_bpll_fout.clk, | ||
234 | }; | ||
235 | |||
236 | static struct clksrc_sources exynos5_clk_src_bpll = { | ||
237 | .sources = exynos5_clk_src_bpll_list, | ||
238 | .nr_sources = ARRAY_SIZE(exynos5_clk_src_bpll_list), | ||
239 | }; | ||
240 | |||
241 | static struct clksrc_clk exynos5_clk_mout_bpll = { | ||
242 | .clk = { | ||
243 | .name = "mout_bpll", | ||
244 | }, | ||
245 | .sources = &exynos5_clk_src_bpll, | ||
246 | .reg_src = { .reg = EXYNOS5_CLKSRC_CDREX, .shift = 0, .size = 1 }, | ||
247 | }; | ||
248 | |||
249 | static struct clk *exynos5_clk_src_bpll_user_list[] = { | ||
250 | [0] = &clk_fin_mpll, | ||
251 | [1] = &exynos5_clk_mout_bpll.clk, | ||
252 | }; | ||
253 | |||
254 | static struct clksrc_sources exynos5_clk_src_bpll_user = { | ||
255 | .sources = exynos5_clk_src_bpll_user_list, | ||
256 | .nr_sources = ARRAY_SIZE(exynos5_clk_src_bpll_user_list), | ||
257 | }; | ||
258 | |||
259 | static struct clksrc_clk exynos5_clk_mout_bpll_user = { | ||
260 | .clk = { | ||
261 | .name = "mout_bpll_user", | ||
262 | }, | ||
263 | .sources = &exynos5_clk_src_bpll_user, | ||
264 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP2, .shift = 24, .size = 1 }, | ||
265 | }; | ||
266 | |||
267 | static struct clksrc_clk exynos5_clk_mout_cpll = { | ||
268 | .clk = { | ||
269 | .name = "mout_cpll", | ||
270 | }, | ||
271 | .sources = &clk_src_cpll, | ||
272 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP2, .shift = 8, .size = 1 }, | ||
273 | }; | ||
274 | |||
275 | static struct clksrc_clk exynos5_clk_mout_epll = { | ||
276 | .clk = { | ||
277 | .name = "mout_epll", | ||
278 | }, | ||
279 | .sources = &clk_src_epll, | ||
280 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP2, .shift = 12, .size = 1 }, | ||
281 | }; | ||
282 | |||
283 | static struct clksrc_clk exynos5_clk_mout_mpll_fout = { | ||
284 | .clk = { | ||
285 | .name = "mout_mpll_fout", | ||
286 | }, | ||
287 | .sources = &clk_src_mpll_fout, | ||
288 | .reg_src = { .reg = EXYNOS5_PLL_DIV2_SEL, .shift = 4, .size = 1 }, | ||
289 | }; | ||
290 | |||
291 | static struct clk *exynos5_clk_src_mpll_list[] = { | ||
292 | [0] = &clk_fin_mpll, | ||
293 | [1] = &exynos5_clk_mout_mpll_fout.clk, | ||
294 | }; | ||
295 | |||
296 | static struct clksrc_sources exynos5_clk_src_mpll = { | ||
297 | .sources = exynos5_clk_src_mpll_list, | ||
298 | .nr_sources = ARRAY_SIZE(exynos5_clk_src_mpll_list), | ||
299 | }; | ||
300 | |||
301 | static struct clksrc_clk exynos5_clk_mout_mpll = { | ||
302 | .clk = { | ||
303 | .name = "mout_mpll", | ||
304 | }, | ||
305 | .sources = &exynos5_clk_src_mpll, | ||
306 | .reg_src = { .reg = EXYNOS5_CLKSRC_CORE1, .shift = 8, .size = 1 }, | ||
307 | }; | ||
308 | |||
309 | static struct clk *exynos_clkset_vpllsrc_list[] = { | ||
310 | [0] = &clk_fin_vpll, | ||
311 | [1] = &exynos5_clk_sclk_hdmi27m, | ||
312 | }; | ||
313 | |||
314 | static struct clksrc_sources exynos5_clkset_vpllsrc = { | ||
315 | .sources = exynos_clkset_vpllsrc_list, | ||
316 | .nr_sources = ARRAY_SIZE(exynos_clkset_vpllsrc_list), | ||
317 | }; | ||
318 | |||
319 | static struct clksrc_clk exynos5_clk_vpllsrc = { | ||
320 | .clk = { | ||
321 | .name = "vpll_src", | ||
322 | .enable = exynos5_clksrc_mask_top_ctrl, | ||
323 | .ctrlbit = (1 << 0), | ||
324 | }, | ||
325 | .sources = &exynos5_clkset_vpllsrc, | ||
326 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP2, .shift = 0, .size = 1 }, | ||
327 | }; | ||
328 | |||
329 | static struct clk *exynos5_clkset_sclk_vpll_list[] = { | ||
330 | [0] = &exynos5_clk_vpllsrc.clk, | ||
331 | [1] = &clk_fout_vpll, | ||
332 | }; | ||
333 | |||
334 | static struct clksrc_sources exynos5_clkset_sclk_vpll = { | ||
335 | .sources = exynos5_clkset_sclk_vpll_list, | ||
336 | .nr_sources = ARRAY_SIZE(exynos5_clkset_sclk_vpll_list), | ||
337 | }; | ||
338 | |||
339 | static struct clksrc_clk exynos5_clk_sclk_vpll = { | ||
340 | .clk = { | ||
341 | .name = "sclk_vpll", | ||
342 | }, | ||
343 | .sources = &exynos5_clkset_sclk_vpll, | ||
344 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP2, .shift = 16, .size = 1 }, | ||
345 | }; | ||
346 | |||
347 | static struct clksrc_clk exynos5_clk_sclk_pixel = { | ||
348 | .clk = { | ||
349 | .name = "sclk_pixel", | ||
350 | .parent = &exynos5_clk_sclk_vpll.clk, | ||
351 | }, | ||
352 | .reg_div = { .reg = EXYNOS5_CLKDIV_DISP1_0, .shift = 28, .size = 4 }, | ||
353 | }; | ||
354 | |||
355 | static struct clk *exynos5_clkset_sclk_hdmi_list[] = { | ||
356 | [0] = &exynos5_clk_sclk_pixel.clk, | ||
357 | [1] = &exynos5_clk_sclk_hdmiphy, | ||
358 | }; | ||
359 | |||
360 | static struct clksrc_sources exynos5_clkset_sclk_hdmi = { | ||
361 | .sources = exynos5_clkset_sclk_hdmi_list, | ||
362 | .nr_sources = ARRAY_SIZE(exynos5_clkset_sclk_hdmi_list), | ||
363 | }; | ||
364 | |||
365 | static struct clksrc_clk exynos5_clk_sclk_hdmi = { | ||
366 | .clk = { | ||
367 | .name = "sclk_hdmi", | ||
368 | .enable = exynos5_clksrc_mask_disp1_0_ctrl, | ||
369 | .ctrlbit = (1 << 20), | ||
370 | }, | ||
371 | .sources = &exynos5_clkset_sclk_hdmi, | ||
372 | .reg_src = { .reg = EXYNOS5_CLKSRC_DISP1_0, .shift = 20, .size = 1 }, | ||
373 | }; | ||
374 | |||
375 | static struct clksrc_clk *exynos5_sclk_tv[] = { | ||
376 | &exynos5_clk_sclk_pixel, | ||
377 | &exynos5_clk_sclk_hdmi, | ||
378 | }; | ||
379 | |||
380 | static struct clk *exynos5_clk_src_mpll_user_list[] = { | ||
381 | [0] = &clk_fin_mpll, | ||
382 | [1] = &exynos5_clk_mout_mpll.clk, | ||
383 | }; | ||
384 | |||
385 | static struct clksrc_sources exynos5_clk_src_mpll_user = { | ||
386 | .sources = exynos5_clk_src_mpll_user_list, | ||
387 | .nr_sources = ARRAY_SIZE(exynos5_clk_src_mpll_user_list), | ||
388 | }; | ||
389 | |||
390 | static struct clksrc_clk exynos5_clk_mout_mpll_user = { | ||
391 | .clk = { | ||
392 | .name = "mout_mpll_user", | ||
393 | }, | ||
394 | .sources = &exynos5_clk_src_mpll_user, | ||
395 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP2, .shift = 20, .size = 1 }, | ||
396 | }; | ||
397 | |||
398 | static struct clk *exynos5_clkset_mout_cpu_list[] = { | ||
399 | [0] = &exynos5_clk_mout_apll.clk, | ||
400 | [1] = &exynos5_clk_mout_mpll.clk, | ||
401 | }; | ||
402 | |||
403 | static struct clksrc_sources exynos5_clkset_mout_cpu = { | ||
404 | .sources = exynos5_clkset_mout_cpu_list, | ||
405 | .nr_sources = ARRAY_SIZE(exynos5_clkset_mout_cpu_list), | ||
406 | }; | ||
407 | |||
408 | static struct clksrc_clk exynos5_clk_mout_cpu = { | ||
409 | .clk = { | ||
410 | .name = "mout_cpu", | ||
411 | }, | ||
412 | .sources = &exynos5_clkset_mout_cpu, | ||
413 | .reg_src = { .reg = EXYNOS5_CLKSRC_CPU, .shift = 16, .size = 1 }, | ||
414 | }; | ||
415 | |||
416 | static struct clksrc_clk exynos5_clk_dout_armclk = { | ||
417 | .clk = { | ||
418 | .name = "dout_armclk", | ||
419 | .parent = &exynos5_clk_mout_cpu.clk, | ||
420 | }, | ||
421 | .reg_div = { .reg = EXYNOS5_CLKDIV_CPU0, .shift = 0, .size = 3 }, | ||
422 | }; | ||
423 | |||
424 | static struct clksrc_clk exynos5_clk_dout_arm2clk = { | ||
425 | .clk = { | ||
426 | .name = "dout_arm2clk", | ||
427 | .parent = &exynos5_clk_dout_armclk.clk, | ||
428 | }, | ||
429 | .reg_div = { .reg = EXYNOS5_CLKDIV_CPU0, .shift = 28, .size = 3 }, | ||
430 | }; | ||
431 | |||
432 | static struct clk exynos5_clk_armclk = { | ||
433 | .name = "armclk", | ||
434 | .parent = &exynos5_clk_dout_arm2clk.clk, | ||
435 | }; | ||
436 | |||
437 | /* Core list of CMU_CDREX side */ | ||
438 | |||
439 | static struct clk *exynos5_clkset_cdrex_list[] = { | ||
440 | [0] = &exynos5_clk_mout_mpll.clk, | ||
441 | [1] = &exynos5_clk_mout_bpll.clk, | ||
442 | }; | ||
443 | |||
444 | static struct clksrc_sources exynos5_clkset_cdrex = { | ||
445 | .sources = exynos5_clkset_cdrex_list, | ||
446 | .nr_sources = ARRAY_SIZE(exynos5_clkset_cdrex_list), | ||
447 | }; | ||
448 | |||
449 | static struct clksrc_clk exynos5_clk_cdrex = { | ||
450 | .clk = { | ||
451 | .name = "clk_cdrex", | ||
452 | }, | ||
453 | .sources = &exynos5_clkset_cdrex, | ||
454 | .reg_src = { .reg = EXYNOS5_CLKSRC_CDREX, .shift = 4, .size = 1 }, | ||
455 | .reg_div = { .reg = EXYNOS5_CLKDIV_CDREX, .shift = 16, .size = 3 }, | ||
456 | }; | ||
457 | |||
458 | static struct clksrc_clk exynos5_clk_aclk_acp = { | ||
459 | .clk = { | ||
460 | .name = "aclk_acp", | ||
461 | .parent = &exynos5_clk_mout_mpll.clk, | ||
462 | }, | ||
463 | .reg_div = { .reg = EXYNOS5_CLKDIV_ACP, .shift = 0, .size = 3 }, | ||
464 | }; | ||
465 | |||
466 | static struct clksrc_clk exynos5_clk_pclk_acp = { | ||
467 | .clk = { | ||
468 | .name = "pclk_acp", | ||
469 | .parent = &exynos5_clk_aclk_acp.clk, | ||
470 | }, | ||
471 | .reg_div = { .reg = EXYNOS5_CLKDIV_ACP, .shift = 4, .size = 3 }, | ||
472 | }; | ||
473 | |||
474 | /* Core list of CMU_TOP side */ | ||
475 | |||
476 | static struct clk *exynos5_clkset_aclk_top_list[] = { | ||
477 | [0] = &exynos5_clk_mout_mpll_user.clk, | ||
478 | [1] = &exynos5_clk_mout_bpll_user.clk, | ||
479 | }; | ||
480 | |||
481 | static struct clksrc_sources exynos5_clkset_aclk = { | ||
482 | .sources = exynos5_clkset_aclk_top_list, | ||
483 | .nr_sources = ARRAY_SIZE(exynos5_clkset_aclk_top_list), | ||
484 | }; | ||
485 | |||
486 | static struct clksrc_clk exynos5_clk_aclk_400 = { | ||
487 | .clk = { | ||
488 | .name = "aclk_400", | ||
489 | }, | ||
490 | .sources = &exynos5_clkset_aclk, | ||
491 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP0, .shift = 20, .size = 1 }, | ||
492 | .reg_div = { .reg = EXYNOS5_CLKDIV_TOP0, .shift = 24, .size = 3 }, | ||
493 | }; | ||
494 | |||
495 | static struct clk *exynos5_clkset_aclk_333_166_list[] = { | ||
496 | [0] = &exynos5_clk_mout_cpll.clk, | ||
497 | [1] = &exynos5_clk_mout_mpll_user.clk, | ||
498 | }; | ||
499 | |||
500 | static struct clksrc_sources exynos5_clkset_aclk_333_166 = { | ||
501 | .sources = exynos5_clkset_aclk_333_166_list, | ||
502 | .nr_sources = ARRAY_SIZE(exynos5_clkset_aclk_333_166_list), | ||
503 | }; | ||
504 | |||
505 | static struct clksrc_clk exynos5_clk_aclk_333 = { | ||
506 | .clk = { | ||
507 | .name = "aclk_333", | ||
508 | }, | ||
509 | .sources = &exynos5_clkset_aclk_333_166, | ||
510 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP0, .shift = 16, .size = 1 }, | ||
511 | .reg_div = { .reg = EXYNOS5_CLKDIV_TOP0, .shift = 20, .size = 3 }, | ||
512 | }; | ||
513 | |||
514 | static struct clksrc_clk exynos5_clk_aclk_166 = { | ||
515 | .clk = { | ||
516 | .name = "aclk_166", | ||
517 | }, | ||
518 | .sources = &exynos5_clkset_aclk_333_166, | ||
519 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP0, .shift = 8, .size = 1 }, | ||
520 | .reg_div = { .reg = EXYNOS5_CLKDIV_TOP0, .shift = 8, .size = 3 }, | ||
521 | }; | ||
522 | |||
523 | static struct clksrc_clk exynos5_clk_aclk_266 = { | ||
524 | .clk = { | ||
525 | .name = "aclk_266", | ||
526 | .parent = &exynos5_clk_mout_mpll_user.clk, | ||
527 | }, | ||
528 | .reg_div = { .reg = EXYNOS5_CLKDIV_TOP0, .shift = 16, .size = 3 }, | ||
529 | }; | ||
530 | |||
531 | static struct clksrc_clk exynos5_clk_aclk_200 = { | ||
532 | .clk = { | ||
533 | .name = "aclk_200", | ||
534 | }, | ||
535 | .sources = &exynos5_clkset_aclk, | ||
536 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP0, .shift = 12, .size = 1 }, | ||
537 | .reg_div = { .reg = EXYNOS5_CLKDIV_TOP0, .shift = 12, .size = 3 }, | ||
538 | }; | ||
539 | |||
540 | static struct clksrc_clk exynos5_clk_aclk_66_pre = { | ||
541 | .clk = { | ||
542 | .name = "aclk_66_pre", | ||
543 | .parent = &exynos5_clk_mout_mpll_user.clk, | ||
544 | }, | ||
545 | .reg_div = { .reg = EXYNOS5_CLKDIV_TOP1, .shift = 24, .size = 3 }, | ||
546 | }; | ||
547 | |||
548 | static struct clksrc_clk exynos5_clk_aclk_66 = { | ||
549 | .clk = { | ||
550 | .name = "aclk_66", | ||
551 | .parent = &exynos5_clk_aclk_66_pre.clk, | ||
552 | }, | ||
553 | .reg_div = { .reg = EXYNOS5_CLKDIV_TOP0, .shift = 0, .size = 3 }, | ||
554 | }; | ||
555 | |||
556 | static struct clksrc_clk exynos5_clk_mout_aclk_300_gscl_mid = { | ||
557 | .clk = { | ||
558 | .name = "mout_aclk_300_gscl_mid", | ||
559 | }, | ||
560 | .sources = &exynos5_clkset_aclk, | ||
561 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP0, .shift = 24, .size = 1 }, | ||
562 | }; | ||
563 | |||
564 | static struct clk *exynos5_clkset_aclk_300_mid1_list[] = { | ||
565 | [0] = &exynos5_clk_sclk_vpll.clk, | ||
566 | [1] = &exynos5_clk_mout_cpll.clk, | ||
567 | }; | ||
568 | |||
569 | static struct clksrc_sources exynos5_clkset_aclk_300_gscl_mid1 = { | ||
570 | .sources = exynos5_clkset_aclk_300_mid1_list, | ||
571 | .nr_sources = ARRAY_SIZE(exynos5_clkset_aclk_300_mid1_list), | ||
572 | }; | ||
573 | |||
574 | static struct clksrc_clk exynos5_clk_mout_aclk_300_gscl_mid1 = { | ||
575 | .clk = { | ||
576 | .name = "mout_aclk_300_gscl_mid1", | ||
577 | }, | ||
578 | .sources = &exynos5_clkset_aclk_300_gscl_mid1, | ||
579 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP1, .shift = 12, .size = 1 }, | ||
580 | }; | ||
581 | |||
582 | static struct clk *exynos5_clkset_aclk_300_gscl_list[] = { | ||
583 | [0] = &exynos5_clk_mout_aclk_300_gscl_mid.clk, | ||
584 | [1] = &exynos5_clk_mout_aclk_300_gscl_mid1.clk, | ||
585 | }; | ||
586 | |||
587 | static struct clksrc_sources exynos5_clkset_aclk_300_gscl = { | ||
588 | .sources = exynos5_clkset_aclk_300_gscl_list, | ||
589 | .nr_sources = ARRAY_SIZE(exynos5_clkset_aclk_300_gscl_list), | ||
590 | }; | ||
591 | |||
592 | static struct clksrc_clk exynos5_clk_mout_aclk_300_gscl = { | ||
593 | .clk = { | ||
594 | .name = "mout_aclk_300_gscl", | ||
595 | }, | ||
596 | .sources = &exynos5_clkset_aclk_300_gscl, | ||
597 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP0, .shift = 25, .size = 1 }, | ||
598 | }; | ||
599 | |||
600 | static struct clk *exynos5_clk_src_gscl_300_list[] = { | ||
601 | [0] = &clk_ext_xtal_mux, | ||
602 | [1] = &exynos5_clk_mout_aclk_300_gscl.clk, | ||
603 | }; | ||
604 | |||
605 | static struct clksrc_sources exynos5_clk_src_gscl_300 = { | ||
606 | .sources = exynos5_clk_src_gscl_300_list, | ||
607 | .nr_sources = ARRAY_SIZE(exynos5_clk_src_gscl_300_list), | ||
608 | }; | ||
609 | |||
610 | static struct clksrc_clk exynos5_clk_aclk_300_gscl = { | ||
611 | .clk = { | ||
612 | .name = "aclk_300_gscl", | ||
613 | }, | ||
614 | .sources = &exynos5_clk_src_gscl_300, | ||
615 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP3, .shift = 10, .size = 1 }, | ||
616 | }; | ||
617 | |||
618 | static struct clk exynos5_init_clocks_off[] = { | ||
619 | { | ||
620 | .name = "timers", | ||
621 | .parent = &exynos5_clk_aclk_66.clk, | ||
622 | .enable = exynos5_clk_ip_peric_ctrl, | ||
623 | .ctrlbit = (1 << 24), | ||
624 | }, { | ||
625 | .name = "tmu_apbif", | ||
626 | .parent = &exynos5_clk_aclk_66.clk, | ||
627 | .enable = exynos5_clk_ip_peris_ctrl, | ||
628 | .ctrlbit = (1 << 21), | ||
629 | }, { | ||
630 | .name = "rtc", | ||
631 | .parent = &exynos5_clk_aclk_66.clk, | ||
632 | .enable = exynos5_clk_ip_peris_ctrl, | ||
633 | .ctrlbit = (1 << 20), | ||
634 | }, { | ||
635 | .name = "watchdog", | ||
636 | .parent = &exynos5_clk_aclk_66.clk, | ||
637 | .enable = exynos5_clk_ip_peris_ctrl, | ||
638 | .ctrlbit = (1 << 19), | ||
639 | }, { | ||
640 | .name = "biu", /* bus interface unit clock */ | ||
641 | .devname = "dw_mmc.0", | ||
642 | .parent = &exynos5_clk_aclk_200.clk, | ||
643 | .enable = exynos5_clk_ip_fsys_ctrl, | ||
644 | .ctrlbit = (1 << 12), | ||
645 | }, { | ||
646 | .name = "biu", | ||
647 | .devname = "dw_mmc.1", | ||
648 | .parent = &exynos5_clk_aclk_200.clk, | ||
649 | .enable = exynos5_clk_ip_fsys_ctrl, | ||
650 | .ctrlbit = (1 << 13), | ||
651 | }, { | ||
652 | .name = "biu", | ||
653 | .devname = "dw_mmc.2", | ||
654 | .parent = &exynos5_clk_aclk_200.clk, | ||
655 | .enable = exynos5_clk_ip_fsys_ctrl, | ||
656 | .ctrlbit = (1 << 14), | ||
657 | }, { | ||
658 | .name = "biu", | ||
659 | .devname = "dw_mmc.3", | ||
660 | .parent = &exynos5_clk_aclk_200.clk, | ||
661 | .enable = exynos5_clk_ip_fsys_ctrl, | ||
662 | .ctrlbit = (1 << 15), | ||
663 | }, { | ||
664 | .name = "sata", | ||
665 | .devname = "exynos5-sata", | ||
666 | .parent = &exynos5_clk_aclk_200.clk, | ||
667 | .enable = exynos5_clk_ip_fsys_ctrl, | ||
668 | .ctrlbit = (1 << 6), | ||
669 | }, { | ||
670 | .name = "sata-phy", | ||
671 | .devname = "exynos5-sata-phy", | ||
672 | .parent = &exynos5_clk_aclk_200.clk, | ||
673 | .enable = exynos5_clk_ip_fsys_ctrl, | ||
674 | .ctrlbit = (1 << 24), | ||
675 | }, { | ||
676 | .name = "i2c", | ||
677 | .devname = "exynos5-sata-phy-i2c", | ||
678 | .parent = &exynos5_clk_aclk_200.clk, | ||
679 | .enable = exynos5_clk_ip_fsys_ctrl, | ||
680 | .ctrlbit = (1 << 25), | ||
681 | }, { | ||
682 | .name = "mfc", | ||
683 | .devname = "s5p-mfc-v6", | ||
684 | .enable = exynos5_clk_ip_mfc_ctrl, | ||
685 | .ctrlbit = (1 << 0), | ||
686 | }, { | ||
687 | .name = "hdmi", | ||
688 | .devname = "exynos5-hdmi", | ||
689 | .enable = exynos5_clk_ip_disp1_ctrl, | ||
690 | .ctrlbit = (1 << 6), | ||
691 | }, { | ||
692 | .name = "hdmiphy", | ||
693 | .devname = "exynos5-hdmi", | ||
694 | .enable = exynos5_clk_hdmiphy_ctrl, | ||
695 | .ctrlbit = (1 << 0), | ||
696 | }, { | ||
697 | .name = "mixer", | ||
698 | .devname = "exynos5-mixer", | ||
699 | .enable = exynos5_clk_ip_disp1_ctrl, | ||
700 | .ctrlbit = (1 << 5), | ||
701 | }, { | ||
702 | .name = "dp", | ||
703 | .devname = "exynos-dp", | ||
704 | .enable = exynos5_clk_ip_disp1_ctrl, | ||
705 | .ctrlbit = (1 << 4), | ||
706 | }, { | ||
707 | .name = "jpeg", | ||
708 | .enable = exynos5_clk_ip_gen_ctrl, | ||
709 | .ctrlbit = (1 << 2), | ||
710 | }, { | ||
711 | .name = "dsim0", | ||
712 | .enable = exynos5_clk_ip_disp1_ctrl, | ||
713 | .ctrlbit = (1 << 3), | ||
714 | }, { | ||
715 | .name = "iis", | ||
716 | .devname = "samsung-i2s.1", | ||
717 | .enable = exynos5_clk_ip_peric_ctrl, | ||
718 | .ctrlbit = (1 << 20), | ||
719 | }, { | ||
720 | .name = "iis", | ||
721 | .devname = "samsung-i2s.2", | ||
722 | .enable = exynos5_clk_ip_peric_ctrl, | ||
723 | .ctrlbit = (1 << 21), | ||
724 | }, { | ||
725 | .name = "pcm", | ||
726 | .devname = "samsung-pcm.1", | ||
727 | .enable = exynos5_clk_ip_peric_ctrl, | ||
728 | .ctrlbit = (1 << 22), | ||
729 | }, { | ||
730 | .name = "pcm", | ||
731 | .devname = "samsung-pcm.2", | ||
732 | .enable = exynos5_clk_ip_peric_ctrl, | ||
733 | .ctrlbit = (1 << 23), | ||
734 | }, { | ||
735 | .name = "spdif", | ||
736 | .devname = "samsung-spdif", | ||
737 | .enable = exynos5_clk_ip_peric_ctrl, | ||
738 | .ctrlbit = (1 << 26), | ||
739 | }, { | ||
740 | .name = "ac97", | ||
741 | .devname = "samsung-ac97", | ||
742 | .enable = exynos5_clk_ip_peric_ctrl, | ||
743 | .ctrlbit = (1 << 27), | ||
744 | }, { | ||
745 | .name = "usbhost", | ||
746 | .enable = exynos5_clk_ip_fsys_ctrl , | ||
747 | .ctrlbit = (1 << 18), | ||
748 | }, { | ||
749 | .name = "usbotg", | ||
750 | .enable = exynos5_clk_ip_fsys_ctrl, | ||
751 | .ctrlbit = (1 << 7), | ||
752 | }, { | ||
753 | .name = "nfcon", | ||
754 | .enable = exynos5_clk_ip_fsys_ctrl, | ||
755 | .ctrlbit = (1 << 22), | ||
756 | }, { | ||
757 | .name = "iop", | ||
758 | .enable = exynos5_clk_ip_fsys_ctrl, | ||
759 | .ctrlbit = ((1 << 30) | (1 << 26) | (1 << 23)), | ||
760 | }, { | ||
761 | .name = "core_iop", | ||
762 | .enable = exynos5_clk_ip_core_ctrl, | ||
763 | .ctrlbit = ((1 << 21) | (1 << 3)), | ||
764 | }, { | ||
765 | .name = "mcu_iop", | ||
766 | .enable = exynos5_clk_ip_fsys_ctrl, | ||
767 | .ctrlbit = (1 << 0), | ||
768 | }, { | ||
769 | .name = "i2c", | ||
770 | .devname = "s3c2440-i2c.0", | ||
771 | .parent = &exynos5_clk_aclk_66.clk, | ||
772 | .enable = exynos5_clk_ip_peric_ctrl, | ||
773 | .ctrlbit = (1 << 6), | ||
774 | }, { | ||
775 | .name = "i2c", | ||
776 | .devname = "s3c2440-i2c.1", | ||
777 | .parent = &exynos5_clk_aclk_66.clk, | ||
778 | .enable = exynos5_clk_ip_peric_ctrl, | ||
779 | .ctrlbit = (1 << 7), | ||
780 | }, { | ||
781 | .name = "i2c", | ||
782 | .devname = "s3c2440-i2c.2", | ||
783 | .parent = &exynos5_clk_aclk_66.clk, | ||
784 | .enable = exynos5_clk_ip_peric_ctrl, | ||
785 | .ctrlbit = (1 << 8), | ||
786 | }, { | ||
787 | .name = "i2c", | ||
788 | .devname = "s3c2440-i2c.3", | ||
789 | .parent = &exynos5_clk_aclk_66.clk, | ||
790 | .enable = exynos5_clk_ip_peric_ctrl, | ||
791 | .ctrlbit = (1 << 9), | ||
792 | }, { | ||
793 | .name = "i2c", | ||
794 | .devname = "s3c2440-i2c.4", | ||
795 | .parent = &exynos5_clk_aclk_66.clk, | ||
796 | .enable = exynos5_clk_ip_peric_ctrl, | ||
797 | .ctrlbit = (1 << 10), | ||
798 | }, { | ||
799 | .name = "i2c", | ||
800 | .devname = "s3c2440-i2c.5", | ||
801 | .parent = &exynos5_clk_aclk_66.clk, | ||
802 | .enable = exynos5_clk_ip_peric_ctrl, | ||
803 | .ctrlbit = (1 << 11), | ||
804 | }, { | ||
805 | .name = "i2c", | ||
806 | .devname = "s3c2440-i2c.6", | ||
807 | .parent = &exynos5_clk_aclk_66.clk, | ||
808 | .enable = exynos5_clk_ip_peric_ctrl, | ||
809 | .ctrlbit = (1 << 12), | ||
810 | }, { | ||
811 | .name = "i2c", | ||
812 | .devname = "s3c2440-i2c.7", | ||
813 | .parent = &exynos5_clk_aclk_66.clk, | ||
814 | .enable = exynos5_clk_ip_peric_ctrl, | ||
815 | .ctrlbit = (1 << 13), | ||
816 | }, { | ||
817 | .name = "i2c", | ||
818 | .devname = "s3c2440-hdmiphy-i2c", | ||
819 | .parent = &exynos5_clk_aclk_66.clk, | ||
820 | .enable = exynos5_clk_ip_peric_ctrl, | ||
821 | .ctrlbit = (1 << 14), | ||
822 | }, { | ||
823 | .name = "spi", | ||
824 | .devname = "exynos4210-spi.0", | ||
825 | .parent = &exynos5_clk_aclk_66.clk, | ||
826 | .enable = exynos5_clk_ip_peric_ctrl, | ||
827 | .ctrlbit = (1 << 16), | ||
828 | }, { | ||
829 | .name = "spi", | ||
830 | .devname = "exynos4210-spi.1", | ||
831 | .parent = &exynos5_clk_aclk_66.clk, | ||
832 | .enable = exynos5_clk_ip_peric_ctrl, | ||
833 | .ctrlbit = (1 << 17), | ||
834 | }, { | ||
835 | .name = "spi", | ||
836 | .devname = "exynos4210-spi.2", | ||
837 | .parent = &exynos5_clk_aclk_66.clk, | ||
838 | .enable = exynos5_clk_ip_peric_ctrl, | ||
839 | .ctrlbit = (1 << 18), | ||
840 | }, { | ||
841 | .name = "gscl", | ||
842 | .devname = "exynos-gsc.0", | ||
843 | .enable = exynos5_clk_ip_gscl_ctrl, | ||
844 | .ctrlbit = (1 << 0), | ||
845 | }, { | ||
846 | .name = "gscl", | ||
847 | .devname = "exynos-gsc.1", | ||
848 | .enable = exynos5_clk_ip_gscl_ctrl, | ||
849 | .ctrlbit = (1 << 1), | ||
850 | }, { | ||
851 | .name = "gscl", | ||
852 | .devname = "exynos-gsc.2", | ||
853 | .enable = exynos5_clk_ip_gscl_ctrl, | ||
854 | .ctrlbit = (1 << 2), | ||
855 | }, { | ||
856 | .name = "gscl", | ||
857 | .devname = "exynos-gsc.3", | ||
858 | .enable = exynos5_clk_ip_gscl_ctrl, | ||
859 | .ctrlbit = (1 << 3), | ||
860 | }, { | ||
861 | .name = "sysmmu", | ||
862 | .devname = "exynos-sysmmu.1", | ||
863 | .enable = &exynos5_clk_ip_mfc_ctrl, | ||
864 | .ctrlbit = (1 << 1), | ||
865 | }, { | ||
866 | .name = "sysmmu", | ||
867 | .devname = "exynos-sysmmu.0", | ||
868 | .enable = &exynos5_clk_ip_mfc_ctrl, | ||
869 | .ctrlbit = (1 << 2), | ||
870 | }, { | ||
871 | .name = "sysmmu", | ||
872 | .devname = "exynos-sysmmu.2", | ||
873 | .enable = &exynos5_clk_ip_disp1_ctrl, | ||
874 | .ctrlbit = (1 << 9) | ||
875 | }, { | ||
876 | .name = "sysmmu", | ||
877 | .devname = "exynos-sysmmu.3", | ||
878 | .enable = &exynos5_clk_ip_gen_ctrl, | ||
879 | .ctrlbit = (1 << 7), | ||
880 | }, { | ||
881 | .name = "sysmmu", | ||
882 | .devname = "exynos-sysmmu.4", | ||
883 | .enable = &exynos5_clk_ip_gen_ctrl, | ||
884 | .ctrlbit = (1 << 6) | ||
885 | }, { | ||
886 | .name = "sysmmu", | ||
887 | .devname = "exynos-sysmmu.5", | ||
888 | .enable = &exynos5_clk_ip_gscl_ctrl, | ||
889 | .ctrlbit = (1 << 7), | ||
890 | }, { | ||
891 | .name = "sysmmu", | ||
892 | .devname = "exynos-sysmmu.6", | ||
893 | .enable = &exynos5_clk_ip_gscl_ctrl, | ||
894 | .ctrlbit = (1 << 8), | ||
895 | }, { | ||
896 | .name = "sysmmu", | ||
897 | .devname = "exynos-sysmmu.7", | ||
898 | .enable = &exynos5_clk_ip_gscl_ctrl, | ||
899 | .ctrlbit = (1 << 9), | ||
900 | }, { | ||
901 | .name = "sysmmu", | ||
902 | .devname = "exynos-sysmmu.8", | ||
903 | .enable = &exynos5_clk_ip_gscl_ctrl, | ||
904 | .ctrlbit = (1 << 10), | ||
905 | }, { | ||
906 | .name = "sysmmu", | ||
907 | .devname = "exynos-sysmmu.9", | ||
908 | .enable = &exynos5_clk_ip_isp0_ctrl, | ||
909 | .ctrlbit = (0x3F << 8), | ||
910 | }, { | ||
911 | .name = "sysmmu", | ||
912 | .devname = "exynos-sysmmu.10", | ||
913 | .enable = &exynos5_clk_ip_isp1_ctrl, | ||
914 | .ctrlbit = (0xF << 4), | ||
915 | }, { | ||
916 | .name = "sysmmu", | ||
917 | .devname = "exynos-sysmmu.11", | ||
918 | .enable = &exynos5_clk_ip_disp1_ctrl, | ||
919 | .ctrlbit = (1 << 8) | ||
920 | }, { | ||
921 | .name = "sysmmu", | ||
922 | .devname = "exynos-sysmmu.12", | ||
923 | .enable = &exynos5_clk_ip_gscl_ctrl, | ||
924 | .ctrlbit = (1 << 11), | ||
925 | }, { | ||
926 | .name = "sysmmu", | ||
927 | .devname = "exynos-sysmmu.13", | ||
928 | .enable = &exynos5_clk_ip_gscl_ctrl, | ||
929 | .ctrlbit = (1 << 12), | ||
930 | }, { | ||
931 | .name = "sysmmu", | ||
932 | .devname = "exynos-sysmmu.14", | ||
933 | .enable = &exynos5_clk_ip_acp_ctrl, | ||
934 | .ctrlbit = (1 << 7) | ||
935 | } | ||
936 | }; | ||
937 | |||
938 | static struct clk exynos5_init_clocks_on[] = { | ||
939 | { | ||
940 | .name = "uart", | ||
941 | .devname = "s5pv210-uart.0", | ||
942 | .enable = exynos5_clk_ip_peric_ctrl, | ||
943 | .ctrlbit = (1 << 0), | ||
944 | }, { | ||
945 | .name = "uart", | ||
946 | .devname = "s5pv210-uart.1", | ||
947 | .enable = exynos5_clk_ip_peric_ctrl, | ||
948 | .ctrlbit = (1 << 1), | ||
949 | }, { | ||
950 | .name = "uart", | ||
951 | .devname = "s5pv210-uart.2", | ||
952 | .enable = exynos5_clk_ip_peric_ctrl, | ||
953 | .ctrlbit = (1 << 2), | ||
954 | }, { | ||
955 | .name = "uart", | ||
956 | .devname = "s5pv210-uart.3", | ||
957 | .enable = exynos5_clk_ip_peric_ctrl, | ||
958 | .ctrlbit = (1 << 3), | ||
959 | }, { | ||
960 | .name = "uart", | ||
961 | .devname = "s5pv210-uart.4", | ||
962 | .enable = exynos5_clk_ip_peric_ctrl, | ||
963 | .ctrlbit = (1 << 4), | ||
964 | }, { | ||
965 | .name = "uart", | ||
966 | .devname = "s5pv210-uart.5", | ||
967 | .enable = exynos5_clk_ip_peric_ctrl, | ||
968 | .ctrlbit = (1 << 5), | ||
969 | } | ||
970 | }; | ||
971 | |||
972 | static struct clk exynos5_clk_pdma0 = { | ||
973 | .name = "dma", | ||
974 | .devname = "dma-pl330.0", | ||
975 | .enable = exynos5_clk_ip_fsys_ctrl, | ||
976 | .ctrlbit = (1 << 1), | ||
977 | }; | ||
978 | |||
979 | static struct clk exynos5_clk_pdma1 = { | ||
980 | .name = "dma", | ||
981 | .devname = "dma-pl330.1", | ||
982 | .enable = exynos5_clk_ip_fsys_ctrl, | ||
983 | .ctrlbit = (1 << 2), | ||
984 | }; | ||
985 | |||
986 | static struct clk exynos5_clk_mdma1 = { | ||
987 | .name = "dma", | ||
988 | .devname = "dma-pl330.2", | ||
989 | .enable = exynos5_clk_ip_gen_ctrl, | ||
990 | .ctrlbit = (1 << 4), | ||
991 | }; | ||
992 | |||
993 | static struct clk exynos5_clk_fimd1 = { | ||
994 | .name = "fimd", | ||
995 | .devname = "exynos5-fb.1", | ||
996 | .enable = exynos5_clk_ip_disp1_ctrl, | ||
997 | .ctrlbit = (1 << 0), | ||
998 | }; | ||
999 | |||
1000 | static struct clk *exynos5_clkset_group_list[] = { | ||
1001 | [0] = &clk_ext_xtal_mux, | ||
1002 | [1] = NULL, | ||
1003 | [2] = &exynos5_clk_sclk_hdmi24m, | ||
1004 | [3] = &exynos5_clk_sclk_dptxphy, | ||
1005 | [4] = &exynos5_clk_sclk_usbphy, | ||
1006 | [5] = &exynos5_clk_sclk_hdmiphy, | ||
1007 | [6] = &exynos5_clk_mout_mpll_user.clk, | ||
1008 | [7] = &exynos5_clk_mout_epll.clk, | ||
1009 | [8] = &exynos5_clk_sclk_vpll.clk, | ||
1010 | [9] = &exynos5_clk_mout_cpll.clk, | ||
1011 | }; | ||
1012 | |||
1013 | static struct clksrc_sources exynos5_clkset_group = { | ||
1014 | .sources = exynos5_clkset_group_list, | ||
1015 | .nr_sources = ARRAY_SIZE(exynos5_clkset_group_list), | ||
1016 | }; | ||
1017 | |||
1018 | /* Possible clock sources for aclk_266_gscl_sub Mux */ | ||
1019 | static struct clk *clk_src_gscl_266_list[] = { | ||
1020 | [0] = &clk_ext_xtal_mux, | ||
1021 | [1] = &exynos5_clk_aclk_266.clk, | ||
1022 | }; | ||
1023 | |||
1024 | static struct clksrc_sources clk_src_gscl_266 = { | ||
1025 | .sources = clk_src_gscl_266_list, | ||
1026 | .nr_sources = ARRAY_SIZE(clk_src_gscl_266_list), | ||
1027 | }; | ||
1028 | |||
1029 | static struct clksrc_clk exynos5_clk_dout_mmc0 = { | ||
1030 | .clk = { | ||
1031 | .name = "dout_mmc0", | ||
1032 | }, | ||
1033 | .sources = &exynos5_clkset_group, | ||
1034 | .reg_src = { .reg = EXYNOS5_CLKSRC_FSYS, .shift = 0, .size = 4 }, | ||
1035 | .reg_div = { .reg = EXYNOS5_CLKDIV_FSYS1, .shift = 0, .size = 4 }, | ||
1036 | }; | ||
1037 | |||
1038 | static struct clksrc_clk exynos5_clk_dout_mmc1 = { | ||
1039 | .clk = { | ||
1040 | .name = "dout_mmc1", | ||
1041 | }, | ||
1042 | .sources = &exynos5_clkset_group, | ||
1043 | .reg_src = { .reg = EXYNOS5_CLKSRC_FSYS, .shift = 4, .size = 4 }, | ||
1044 | .reg_div = { .reg = EXYNOS5_CLKDIV_FSYS1, .shift = 16, .size = 4 }, | ||
1045 | }; | ||
1046 | |||
1047 | static struct clksrc_clk exynos5_clk_dout_mmc2 = { | ||
1048 | .clk = { | ||
1049 | .name = "dout_mmc2", | ||
1050 | }, | ||
1051 | .sources = &exynos5_clkset_group, | ||
1052 | .reg_src = { .reg = EXYNOS5_CLKSRC_FSYS, .shift = 8, .size = 4 }, | ||
1053 | .reg_div = { .reg = EXYNOS5_CLKDIV_FSYS2, .shift = 0, .size = 4 }, | ||
1054 | }; | ||
1055 | |||
1056 | static struct clksrc_clk exynos5_clk_dout_mmc3 = { | ||
1057 | .clk = { | ||
1058 | .name = "dout_mmc3", | ||
1059 | }, | ||
1060 | .sources = &exynos5_clkset_group, | ||
1061 | .reg_src = { .reg = EXYNOS5_CLKSRC_FSYS, .shift = 12, .size = 4 }, | ||
1062 | .reg_div = { .reg = EXYNOS5_CLKDIV_FSYS2, .shift = 16, .size = 4 }, | ||
1063 | }; | ||
1064 | |||
1065 | static struct clksrc_clk exynos5_clk_dout_mmc4 = { | ||
1066 | .clk = { | ||
1067 | .name = "dout_mmc4", | ||
1068 | }, | ||
1069 | .sources = &exynos5_clkset_group, | ||
1070 | .reg_src = { .reg = EXYNOS5_CLKSRC_FSYS, .shift = 16, .size = 4 }, | ||
1071 | .reg_div = { .reg = EXYNOS5_CLKDIV_FSYS3, .shift = 0, .size = 4 }, | ||
1072 | }; | ||
1073 | |||
1074 | static struct clksrc_clk exynos5_clk_sclk_uart0 = { | ||
1075 | .clk = { | ||
1076 | .name = "uclk1", | ||
1077 | .devname = "exynos4210-uart.0", | ||
1078 | .enable = exynos5_clksrc_mask_peric0_ctrl, | ||
1079 | .ctrlbit = (1 << 0), | ||
1080 | }, | ||
1081 | .sources = &exynos5_clkset_group, | ||
1082 | .reg_src = { .reg = EXYNOS5_CLKSRC_PERIC0, .shift = 0, .size = 4 }, | ||
1083 | .reg_div = { .reg = EXYNOS5_CLKDIV_PERIC0, .shift = 0, .size = 4 }, | ||
1084 | }; | ||
1085 | |||
1086 | static struct clksrc_clk exynos5_clk_sclk_uart1 = { | ||
1087 | .clk = { | ||
1088 | .name = "uclk1", | ||
1089 | .devname = "exynos4210-uart.1", | ||
1090 | .enable = exynos5_clksrc_mask_peric0_ctrl, | ||
1091 | .ctrlbit = (1 << 4), | ||
1092 | }, | ||
1093 | .sources = &exynos5_clkset_group, | ||
1094 | .reg_src = { .reg = EXYNOS5_CLKSRC_PERIC0, .shift = 4, .size = 4 }, | ||
1095 | .reg_div = { .reg = EXYNOS5_CLKDIV_PERIC0, .shift = 4, .size = 4 }, | ||
1096 | }; | ||
1097 | |||
1098 | static struct clksrc_clk exynos5_clk_sclk_uart2 = { | ||
1099 | .clk = { | ||
1100 | .name = "uclk1", | ||
1101 | .devname = "exynos4210-uart.2", | ||
1102 | .enable = exynos5_clksrc_mask_peric0_ctrl, | ||
1103 | .ctrlbit = (1 << 8), | ||
1104 | }, | ||
1105 | .sources = &exynos5_clkset_group, | ||
1106 | .reg_src = { .reg = EXYNOS5_CLKSRC_PERIC0, .shift = 8, .size = 4 }, | ||
1107 | .reg_div = { .reg = EXYNOS5_CLKDIV_PERIC0, .shift = 8, .size = 4 }, | ||
1108 | }; | ||
1109 | |||
1110 | static struct clksrc_clk exynos5_clk_sclk_uart3 = { | ||
1111 | .clk = { | ||
1112 | .name = "uclk1", | ||
1113 | .devname = "exynos4210-uart.3", | ||
1114 | .enable = exynos5_clksrc_mask_peric0_ctrl, | ||
1115 | .ctrlbit = (1 << 12), | ||
1116 | }, | ||
1117 | .sources = &exynos5_clkset_group, | ||
1118 | .reg_src = { .reg = EXYNOS5_CLKSRC_PERIC0, .shift = 12, .size = 4 }, | ||
1119 | .reg_div = { .reg = EXYNOS5_CLKDIV_PERIC0, .shift = 12, .size = 4 }, | ||
1120 | }; | ||
1121 | |||
1122 | static struct clksrc_clk exynos5_clk_sclk_mmc0 = { | ||
1123 | .clk = { | ||
1124 | .name = "ciu", /* card interface unit clock */ | ||
1125 | .devname = "dw_mmc.0", | ||
1126 | .parent = &exynos5_clk_dout_mmc0.clk, | ||
1127 | .enable = exynos5_clksrc_mask_fsys_ctrl, | ||
1128 | .ctrlbit = (1 << 0), | ||
1129 | }, | ||
1130 | .reg_div = { .reg = EXYNOS5_CLKDIV_FSYS1, .shift = 8, .size = 8 }, | ||
1131 | }; | ||
1132 | |||
1133 | static struct clksrc_clk exynos5_clk_sclk_mmc1 = { | ||
1134 | .clk = { | ||
1135 | .name = "ciu", | ||
1136 | .devname = "dw_mmc.1", | ||
1137 | .parent = &exynos5_clk_dout_mmc1.clk, | ||
1138 | .enable = exynos5_clksrc_mask_fsys_ctrl, | ||
1139 | .ctrlbit = (1 << 4), | ||
1140 | }, | ||
1141 | .reg_div = { .reg = EXYNOS5_CLKDIV_FSYS1, .shift = 24, .size = 8 }, | ||
1142 | }; | ||
1143 | |||
1144 | static struct clksrc_clk exynos5_clk_sclk_mmc2 = { | ||
1145 | .clk = { | ||
1146 | .name = "ciu", | ||
1147 | .devname = "dw_mmc.2", | ||
1148 | .parent = &exynos5_clk_dout_mmc2.clk, | ||
1149 | .enable = exynos5_clksrc_mask_fsys_ctrl, | ||
1150 | .ctrlbit = (1 << 8), | ||
1151 | }, | ||
1152 | .reg_div = { .reg = EXYNOS5_CLKDIV_FSYS2, .shift = 8, .size = 8 }, | ||
1153 | }; | ||
1154 | |||
1155 | static struct clksrc_clk exynos5_clk_sclk_mmc3 = { | ||
1156 | .clk = { | ||
1157 | .name = "ciu", | ||
1158 | .devname = "dw_mmc.3", | ||
1159 | .parent = &exynos5_clk_dout_mmc3.clk, | ||
1160 | .enable = exynos5_clksrc_mask_fsys_ctrl, | ||
1161 | .ctrlbit = (1 << 12), | ||
1162 | }, | ||
1163 | .reg_div = { .reg = EXYNOS5_CLKDIV_FSYS2, .shift = 24, .size = 8 }, | ||
1164 | }; | ||
1165 | |||
1166 | static struct clksrc_clk exynos5_clk_mdout_spi0 = { | ||
1167 | .clk = { | ||
1168 | .name = "mdout_spi", | ||
1169 | .devname = "exynos4210-spi.0", | ||
1170 | }, | ||
1171 | .sources = &exynos5_clkset_group, | ||
1172 | .reg_src = { .reg = EXYNOS5_CLKSRC_PERIC1, .shift = 16, .size = 4 }, | ||
1173 | .reg_div = { .reg = EXYNOS5_CLKDIV_PERIC1, .shift = 0, .size = 4 }, | ||
1174 | }; | ||
1175 | |||
1176 | static struct clksrc_clk exynos5_clk_mdout_spi1 = { | ||
1177 | .clk = { | ||
1178 | .name = "mdout_spi", | ||
1179 | .devname = "exynos4210-spi.1", | ||
1180 | }, | ||
1181 | .sources = &exynos5_clkset_group, | ||
1182 | .reg_src = { .reg = EXYNOS5_CLKSRC_PERIC1, .shift = 20, .size = 4 }, | ||
1183 | .reg_div = { .reg = EXYNOS5_CLKDIV_PERIC1, .shift = 16, .size = 4 }, | ||
1184 | }; | ||
1185 | |||
1186 | static struct clksrc_clk exynos5_clk_mdout_spi2 = { | ||
1187 | .clk = { | ||
1188 | .name = "mdout_spi", | ||
1189 | .devname = "exynos4210-spi.2", | ||
1190 | }, | ||
1191 | .sources = &exynos5_clkset_group, | ||
1192 | .reg_src = { .reg = EXYNOS5_CLKSRC_PERIC1, .shift = 24, .size = 4 }, | ||
1193 | .reg_div = { .reg = EXYNOS5_CLKDIV_PERIC2, .shift = 0, .size = 4 }, | ||
1194 | }; | ||
1195 | |||
1196 | static struct clksrc_clk exynos5_clk_sclk_spi0 = { | ||
1197 | .clk = { | ||
1198 | .name = "sclk_spi", | ||
1199 | .devname = "exynos4210-spi.0", | ||
1200 | .parent = &exynos5_clk_mdout_spi0.clk, | ||
1201 | .enable = exynos5_clksrc_mask_peric1_ctrl, | ||
1202 | .ctrlbit = (1 << 16), | ||
1203 | }, | ||
1204 | .reg_div = { .reg = EXYNOS5_CLKDIV_PERIC1, .shift = 8, .size = 8 }, | ||
1205 | }; | ||
1206 | |||
1207 | static struct clksrc_clk exynos5_clk_sclk_spi1 = { | ||
1208 | .clk = { | ||
1209 | .name = "sclk_spi", | ||
1210 | .devname = "exynos4210-spi.1", | ||
1211 | .parent = &exynos5_clk_mdout_spi1.clk, | ||
1212 | .enable = exynos5_clksrc_mask_peric1_ctrl, | ||
1213 | .ctrlbit = (1 << 20), | ||
1214 | }, | ||
1215 | .reg_div = { .reg = EXYNOS5_CLKDIV_PERIC1, .shift = 24, .size = 8 }, | ||
1216 | }; | ||
1217 | |||
1218 | static struct clksrc_clk exynos5_clk_sclk_spi2 = { | ||
1219 | .clk = { | ||
1220 | .name = "sclk_spi", | ||
1221 | .devname = "exynos4210-spi.2", | ||
1222 | .parent = &exynos5_clk_mdout_spi2.clk, | ||
1223 | .enable = exynos5_clksrc_mask_peric1_ctrl, | ||
1224 | .ctrlbit = (1 << 24), | ||
1225 | }, | ||
1226 | .reg_div = { .reg = EXYNOS5_CLKDIV_PERIC2, .shift = 8, .size = 8 }, | ||
1227 | }; | ||
1228 | |||
1229 | static struct clksrc_clk exynos5_clk_sclk_fimd1 = { | ||
1230 | .clk = { | ||
1231 | .name = "sclk_fimd", | ||
1232 | .devname = "exynos5-fb.1", | ||
1233 | .enable = exynos5_clksrc_mask_disp1_0_ctrl, | ||
1234 | .ctrlbit = (1 << 0), | ||
1235 | }, | ||
1236 | .sources = &exynos5_clkset_group, | ||
1237 | .reg_src = { .reg = EXYNOS5_CLKSRC_DISP1_0, .shift = 0, .size = 4 }, | ||
1238 | .reg_div = { .reg = EXYNOS5_CLKDIV_DISP1_0, .shift = 0, .size = 4 }, | ||
1239 | }; | ||
1240 | |||
1241 | static struct clksrc_clk exynos5_clksrcs[] = { | ||
1242 | { | ||
1243 | .clk = { | ||
1244 | .name = "aclk_266_gscl", | ||
1245 | }, | ||
1246 | .sources = &clk_src_gscl_266, | ||
1247 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP3, .shift = 8, .size = 1 }, | ||
1248 | }, { | ||
1249 | .clk = { | ||
1250 | .name = "sclk_g3d", | ||
1251 | .devname = "mali-t604.0", | ||
1252 | .enable = exynos5_clk_block_ctrl, | ||
1253 | .ctrlbit = (1 << 1), | ||
1254 | }, | ||
1255 | .sources = &exynos5_clkset_aclk, | ||
1256 | .reg_src = { .reg = EXYNOS5_CLKSRC_TOP0, .shift = 20, .size = 1 }, | ||
1257 | .reg_div = { .reg = EXYNOS5_CLKDIV_TOP0, .shift = 24, .size = 3 }, | ||
1258 | }, { | ||
1259 | .clk = { | ||
1260 | .name = "sclk_sata", | ||
1261 | .devname = "exynos5-sata", | ||
1262 | .enable = exynos5_clksrc_mask_fsys_ctrl, | ||
1263 | .ctrlbit = (1 << 24), | ||
1264 | }, | ||
1265 | .sources = &exynos5_clkset_aclk, | ||
1266 | .reg_src = { .reg = EXYNOS5_CLKSRC_FSYS, .shift = 24, .size = 1 }, | ||
1267 | .reg_div = { .reg = EXYNOS5_CLKDIV_FSYS0, .shift = 20, .size = 4 }, | ||
1268 | }, { | ||
1269 | .clk = { | ||
1270 | .name = "sclk_gscl_wrap", | ||
1271 | .devname = "s5p-mipi-csis.0", | ||
1272 | .enable = exynos5_clksrc_mask_gscl_ctrl, | ||
1273 | .ctrlbit = (1 << 24), | ||
1274 | }, | ||
1275 | .sources = &exynos5_clkset_group, | ||
1276 | .reg_src = { .reg = EXYNOS5_CLKSRC_GSCL, .shift = 24, .size = 4 }, | ||
1277 | .reg_div = { .reg = EXYNOS5_CLKDIV_GSCL, .shift = 24, .size = 4 }, | ||
1278 | }, { | ||
1279 | .clk = { | ||
1280 | .name = "sclk_gscl_wrap", | ||
1281 | .devname = "s5p-mipi-csis.1", | ||
1282 | .enable = exynos5_clksrc_mask_gscl_ctrl, | ||
1283 | .ctrlbit = (1 << 28), | ||
1284 | }, | ||
1285 | .sources = &exynos5_clkset_group, | ||
1286 | .reg_src = { .reg = EXYNOS5_CLKSRC_GSCL, .shift = 28, .size = 4 }, | ||
1287 | .reg_div = { .reg = EXYNOS5_CLKDIV_GSCL, .shift = 28, .size = 4 }, | ||
1288 | }, { | ||
1289 | .clk = { | ||
1290 | .name = "sclk_cam0", | ||
1291 | .enable = exynos5_clksrc_mask_gscl_ctrl, | ||
1292 | .ctrlbit = (1 << 16), | ||
1293 | }, | ||
1294 | .sources = &exynos5_clkset_group, | ||
1295 | .reg_src = { .reg = EXYNOS5_CLKSRC_GSCL, .shift = 16, .size = 4 }, | ||
1296 | .reg_div = { .reg = EXYNOS5_CLKDIV_GSCL, .shift = 16, .size = 4 }, | ||
1297 | }, { | ||
1298 | .clk = { | ||
1299 | .name = "sclk_cam1", | ||
1300 | .enable = exynos5_clksrc_mask_gscl_ctrl, | ||
1301 | .ctrlbit = (1 << 20), | ||
1302 | }, | ||
1303 | .sources = &exynos5_clkset_group, | ||
1304 | .reg_src = { .reg = EXYNOS5_CLKSRC_GSCL, .shift = 20, .size = 4 }, | ||
1305 | .reg_div = { .reg = EXYNOS5_CLKDIV_GSCL, .shift = 20, .size = 4 }, | ||
1306 | }, { | ||
1307 | .clk = { | ||
1308 | .name = "sclk_jpeg", | ||
1309 | .parent = &exynos5_clk_mout_cpll.clk, | ||
1310 | }, | ||
1311 | .reg_div = { .reg = EXYNOS5_CLKDIV_GEN, .shift = 4, .size = 3 }, | ||
1312 | }, | ||
1313 | }; | ||
1314 | |||
1315 | /* Clock initialization code */ | ||
1316 | static struct clksrc_clk *exynos5_sysclks[] = { | ||
1317 | &exynos5_clk_mout_apll, | ||
1318 | &exynos5_clk_sclk_apll, | ||
1319 | &exynos5_clk_mout_bpll, | ||
1320 | &exynos5_clk_mout_bpll_fout, | ||
1321 | &exynos5_clk_mout_bpll_user, | ||
1322 | &exynos5_clk_mout_cpll, | ||
1323 | &exynos5_clk_mout_epll, | ||
1324 | &exynos5_clk_mout_mpll, | ||
1325 | &exynos5_clk_mout_mpll_fout, | ||
1326 | &exynos5_clk_mout_mpll_user, | ||
1327 | &exynos5_clk_vpllsrc, | ||
1328 | &exynos5_clk_sclk_vpll, | ||
1329 | &exynos5_clk_mout_cpu, | ||
1330 | &exynos5_clk_dout_armclk, | ||
1331 | &exynos5_clk_dout_arm2clk, | ||
1332 | &exynos5_clk_cdrex, | ||
1333 | &exynos5_clk_aclk_400, | ||
1334 | &exynos5_clk_aclk_333, | ||
1335 | &exynos5_clk_aclk_266, | ||
1336 | &exynos5_clk_aclk_200, | ||
1337 | &exynos5_clk_aclk_166, | ||
1338 | &exynos5_clk_aclk_300_gscl, | ||
1339 | &exynos5_clk_mout_aclk_300_gscl, | ||
1340 | &exynos5_clk_mout_aclk_300_gscl_mid, | ||
1341 | &exynos5_clk_mout_aclk_300_gscl_mid1, | ||
1342 | &exynos5_clk_aclk_66_pre, | ||
1343 | &exynos5_clk_aclk_66, | ||
1344 | &exynos5_clk_dout_mmc0, | ||
1345 | &exynos5_clk_dout_mmc1, | ||
1346 | &exynos5_clk_dout_mmc2, | ||
1347 | &exynos5_clk_dout_mmc3, | ||
1348 | &exynos5_clk_dout_mmc4, | ||
1349 | &exynos5_clk_aclk_acp, | ||
1350 | &exynos5_clk_pclk_acp, | ||
1351 | &exynos5_clk_sclk_spi0, | ||
1352 | &exynos5_clk_sclk_spi1, | ||
1353 | &exynos5_clk_sclk_spi2, | ||
1354 | &exynos5_clk_mdout_spi0, | ||
1355 | &exynos5_clk_mdout_spi1, | ||
1356 | &exynos5_clk_mdout_spi2, | ||
1357 | &exynos5_clk_sclk_fimd1, | ||
1358 | }; | ||
1359 | |||
1360 | static struct clk *exynos5_clk_cdev[] = { | ||
1361 | &exynos5_clk_pdma0, | ||
1362 | &exynos5_clk_pdma1, | ||
1363 | &exynos5_clk_mdma1, | ||
1364 | &exynos5_clk_fimd1, | ||
1365 | }; | ||
1366 | |||
1367 | static struct clksrc_clk *exynos5_clksrc_cdev[] = { | ||
1368 | &exynos5_clk_sclk_uart0, | ||
1369 | &exynos5_clk_sclk_uart1, | ||
1370 | &exynos5_clk_sclk_uart2, | ||
1371 | &exynos5_clk_sclk_uart3, | ||
1372 | &exynos5_clk_sclk_mmc0, | ||
1373 | &exynos5_clk_sclk_mmc1, | ||
1374 | &exynos5_clk_sclk_mmc2, | ||
1375 | &exynos5_clk_sclk_mmc3, | ||
1376 | }; | ||
1377 | |||
1378 | static struct clk_lookup exynos5_clk_lookup[] = { | ||
1379 | CLKDEV_INIT("exynos4210-uart.0", "clk_uart_baud0", &exynos5_clk_sclk_uart0.clk), | ||
1380 | CLKDEV_INIT("exynos4210-uart.1", "clk_uart_baud0", &exynos5_clk_sclk_uart1.clk), | ||
1381 | CLKDEV_INIT("exynos4210-uart.2", "clk_uart_baud0", &exynos5_clk_sclk_uart2.clk), | ||
1382 | CLKDEV_INIT("exynos4210-uart.3", "clk_uart_baud0", &exynos5_clk_sclk_uart3.clk), | ||
1383 | CLKDEV_INIT("exynos4-sdhci.0", "mmc_busclk.2", &exynos5_clk_sclk_mmc0.clk), | ||
1384 | CLKDEV_INIT("exynos4-sdhci.1", "mmc_busclk.2", &exynos5_clk_sclk_mmc1.clk), | ||
1385 | CLKDEV_INIT("exynos4-sdhci.2", "mmc_busclk.2", &exynos5_clk_sclk_mmc2.clk), | ||
1386 | CLKDEV_INIT("exynos4-sdhci.3", "mmc_busclk.2", &exynos5_clk_sclk_mmc3.clk), | ||
1387 | CLKDEV_INIT("exynos4210-spi.0", "spi_busclk0", &exynos5_clk_sclk_spi0.clk), | ||
1388 | CLKDEV_INIT("exynos4210-spi.1", "spi_busclk0", &exynos5_clk_sclk_spi1.clk), | ||
1389 | CLKDEV_INIT("exynos4210-spi.2", "spi_busclk0", &exynos5_clk_sclk_spi2.clk), | ||
1390 | CLKDEV_INIT("dma-pl330.0", "apb_pclk", &exynos5_clk_pdma0), | ||
1391 | CLKDEV_INIT("dma-pl330.1", "apb_pclk", &exynos5_clk_pdma1), | ||
1392 | CLKDEV_INIT("dma-pl330.2", "apb_pclk", &exynos5_clk_mdma1), | ||
1393 | CLKDEV_INIT("exynos5-fb.1", "lcd", &exynos5_clk_fimd1), | ||
1394 | }; | ||
1395 | |||
1396 | static unsigned long exynos5_epll_get_rate(struct clk *clk) | ||
1397 | { | ||
1398 | return clk->rate; | ||
1399 | } | ||
1400 | |||
1401 | static struct clk *exynos5_clks[] __initdata = { | ||
1402 | &exynos5_clk_sclk_hdmi27m, | ||
1403 | &exynos5_clk_sclk_hdmiphy, | ||
1404 | &clk_fout_bpll, | ||
1405 | &clk_fout_bpll_div2, | ||
1406 | &clk_fout_cpll, | ||
1407 | &clk_fout_mpll_div2, | ||
1408 | &exynos5_clk_armclk, | ||
1409 | }; | ||
1410 | |||
1411 | static u32 epll_div[][6] = { | ||
1412 | { 192000000, 0, 48, 3, 1, 0 }, | ||
1413 | { 180000000, 0, 45, 3, 1, 0 }, | ||
1414 | { 73728000, 1, 73, 3, 3, 47710 }, | ||
1415 | { 67737600, 1, 90, 4, 3, 20762 }, | ||
1416 | { 49152000, 0, 49, 3, 3, 9961 }, | ||
1417 | { 45158400, 0, 45, 3, 3, 10381 }, | ||
1418 | { 180633600, 0, 45, 3, 1, 10381 }, | ||
1419 | }; | ||
1420 | |||
1421 | static int exynos5_epll_set_rate(struct clk *clk, unsigned long rate) | ||
1422 | { | ||
1423 | unsigned int epll_con, epll_con_k; | ||
1424 | unsigned int i; | ||
1425 | unsigned int tmp; | ||
1426 | unsigned int epll_rate; | ||
1427 | unsigned int locktime; | ||
1428 | unsigned int lockcnt; | ||
1429 | |||
1430 | /* Return if nothing changed */ | ||
1431 | if (clk->rate == rate) | ||
1432 | return 0; | ||
1433 | |||
1434 | if (clk->parent) | ||
1435 | epll_rate = clk_get_rate(clk->parent); | ||
1436 | else | ||
1437 | epll_rate = clk_ext_xtal_mux.rate; | ||
1438 | |||
1439 | if (epll_rate != 24000000) { | ||
1440 | pr_err("Invalid Clock : recommended clock is 24MHz.\n"); | ||
1441 | return -EINVAL; | ||
1442 | } | ||
1443 | |||
1444 | epll_con = __raw_readl(EXYNOS5_EPLL_CON0); | ||
1445 | epll_con &= ~(0x1 << 27 | \ | ||
1446 | PLL46XX_MDIV_MASK << PLL46XX_MDIV_SHIFT | \ | ||
1447 | PLL46XX_PDIV_MASK << PLL46XX_PDIV_SHIFT | \ | ||
1448 | PLL46XX_SDIV_MASK << PLL46XX_SDIV_SHIFT); | ||
1449 | |||
1450 | for (i = 0; i < ARRAY_SIZE(epll_div); i++) { | ||
1451 | if (epll_div[i][0] == rate) { | ||
1452 | epll_con_k = epll_div[i][5] << 0; | ||
1453 | epll_con |= epll_div[i][1] << 27; | ||
1454 | epll_con |= epll_div[i][2] << PLL46XX_MDIV_SHIFT; | ||
1455 | epll_con |= epll_div[i][3] << PLL46XX_PDIV_SHIFT; | ||
1456 | epll_con |= epll_div[i][4] << PLL46XX_SDIV_SHIFT; | ||
1457 | break; | ||
1458 | } | ||
1459 | } | ||
1460 | |||
1461 | if (i == ARRAY_SIZE(epll_div)) { | ||
1462 | printk(KERN_ERR "%s: Invalid Clock EPLL Frequency\n", | ||
1463 | __func__); | ||
1464 | return -EINVAL; | ||
1465 | } | ||
1466 | |||
1467 | epll_rate /= 1000000; | ||
1468 | |||
1469 | /* 3000 max_cycls : specification data */ | ||
1470 | locktime = 3000 / epll_rate * epll_div[i][3]; | ||
1471 | lockcnt = locktime * 10000 / (10000 / epll_rate); | ||
1472 | |||
1473 | __raw_writel(lockcnt, EXYNOS5_EPLL_LOCK); | ||
1474 | |||
1475 | __raw_writel(epll_con, EXYNOS5_EPLL_CON0); | ||
1476 | __raw_writel(epll_con_k, EXYNOS5_EPLL_CON1); | ||
1477 | |||
1478 | do { | ||
1479 | tmp = __raw_readl(EXYNOS5_EPLL_CON0); | ||
1480 | } while (!(tmp & 0x1 << EXYNOS5_EPLLCON0_LOCKED_SHIFT)); | ||
1481 | |||
1482 | clk->rate = rate; | ||
1483 | |||
1484 | return 0; | ||
1485 | } | ||
1486 | |||
1487 | static struct clk_ops exynos5_epll_ops = { | ||
1488 | .get_rate = exynos5_epll_get_rate, | ||
1489 | .set_rate = exynos5_epll_set_rate, | ||
1490 | }; | ||
1491 | |||
1492 | static int xtal_rate; | ||
1493 | |||
1494 | static unsigned long exynos5_fout_apll_get_rate(struct clk *clk) | ||
1495 | { | ||
1496 | return s5p_get_pll35xx(xtal_rate, __raw_readl(EXYNOS5_APLL_CON0)); | ||
1497 | } | ||
1498 | |||
1499 | static struct clk_ops exynos5_fout_apll_ops = { | ||
1500 | .get_rate = exynos5_fout_apll_get_rate, | ||
1501 | }; | ||
1502 | |||
1503 | #ifdef CONFIG_PM | ||
1504 | static int exynos5_clock_suspend(void) | ||
1505 | { | ||
1506 | s3c_pm_do_save(exynos5_clock_save, ARRAY_SIZE(exynos5_clock_save)); | ||
1507 | |||
1508 | return 0; | ||
1509 | } | ||
1510 | |||
1511 | static void exynos5_clock_resume(void) | ||
1512 | { | ||
1513 | s3c_pm_do_restore_core(exynos5_clock_save, ARRAY_SIZE(exynos5_clock_save)); | ||
1514 | } | ||
1515 | #else | ||
1516 | #define exynos5_clock_suspend NULL | ||
1517 | #define exynos5_clock_resume NULL | ||
1518 | #endif | ||
1519 | |||
1520 | static struct syscore_ops exynos5_clock_syscore_ops = { | ||
1521 | .suspend = exynos5_clock_suspend, | ||
1522 | .resume = exynos5_clock_resume, | ||
1523 | }; | ||
1524 | |||
1525 | void __init_or_cpufreq exynos5_setup_clocks(void) | ||
1526 | { | ||
1527 | struct clk *xtal_clk; | ||
1528 | unsigned long apll; | ||
1529 | unsigned long bpll; | ||
1530 | unsigned long cpll; | ||
1531 | unsigned long mpll; | ||
1532 | unsigned long epll; | ||
1533 | unsigned long vpll; | ||
1534 | unsigned long vpllsrc; | ||
1535 | unsigned long xtal; | ||
1536 | unsigned long armclk; | ||
1537 | unsigned long mout_cdrex; | ||
1538 | unsigned long aclk_400; | ||
1539 | unsigned long aclk_333; | ||
1540 | unsigned long aclk_266; | ||
1541 | unsigned long aclk_200; | ||
1542 | unsigned long aclk_166; | ||
1543 | unsigned long aclk_66; | ||
1544 | unsigned int ptr; | ||
1545 | |||
1546 | printk(KERN_DEBUG "%s: registering clocks\n", __func__); | ||
1547 | |||
1548 | xtal_clk = clk_get(NULL, "xtal"); | ||
1549 | BUG_ON(IS_ERR(xtal_clk)); | ||
1550 | |||
1551 | xtal = clk_get_rate(xtal_clk); | ||
1552 | |||
1553 | xtal_rate = xtal; | ||
1554 | |||
1555 | clk_put(xtal_clk); | ||
1556 | |||
1557 | printk(KERN_DEBUG "%s: xtal is %ld\n", __func__, xtal); | ||
1558 | |||
1559 | apll = s5p_get_pll35xx(xtal, __raw_readl(EXYNOS5_APLL_CON0)); | ||
1560 | bpll = s5p_get_pll35xx(xtal, __raw_readl(EXYNOS5_BPLL_CON0)); | ||
1561 | cpll = s5p_get_pll35xx(xtal, __raw_readl(EXYNOS5_CPLL_CON0)); | ||
1562 | mpll = s5p_get_pll35xx(xtal, __raw_readl(EXYNOS5_MPLL_CON0)); | ||
1563 | epll = s5p_get_pll36xx(xtal, __raw_readl(EXYNOS5_EPLL_CON0), | ||
1564 | __raw_readl(EXYNOS5_EPLL_CON1)); | ||
1565 | |||
1566 | vpllsrc = clk_get_rate(&exynos5_clk_vpllsrc.clk); | ||
1567 | vpll = s5p_get_pll36xx(vpllsrc, __raw_readl(EXYNOS5_VPLL_CON0), | ||
1568 | __raw_readl(EXYNOS5_VPLL_CON1)); | ||
1569 | |||
1570 | clk_fout_apll.ops = &exynos5_fout_apll_ops; | ||
1571 | clk_fout_bpll.rate = bpll; | ||
1572 | clk_fout_bpll_div2.rate = bpll >> 1; | ||
1573 | clk_fout_cpll.rate = cpll; | ||
1574 | clk_fout_mpll.rate = mpll; | ||
1575 | clk_fout_mpll_div2.rate = mpll >> 1; | ||
1576 | clk_fout_epll.rate = epll; | ||
1577 | clk_fout_vpll.rate = vpll; | ||
1578 | |||
1579 | printk(KERN_INFO "EXYNOS5: PLL settings, A=%ld, B=%ld, C=%ld\n" | ||
1580 | "M=%ld, E=%ld V=%ld", | ||
1581 | apll, bpll, cpll, mpll, epll, vpll); | ||
1582 | |||
1583 | armclk = clk_get_rate(&exynos5_clk_armclk); | ||
1584 | mout_cdrex = clk_get_rate(&exynos5_clk_cdrex.clk); | ||
1585 | |||
1586 | aclk_400 = clk_get_rate(&exynos5_clk_aclk_400.clk); | ||
1587 | aclk_333 = clk_get_rate(&exynos5_clk_aclk_333.clk); | ||
1588 | aclk_266 = clk_get_rate(&exynos5_clk_aclk_266.clk); | ||
1589 | aclk_200 = clk_get_rate(&exynos5_clk_aclk_200.clk); | ||
1590 | aclk_166 = clk_get_rate(&exynos5_clk_aclk_166.clk); | ||
1591 | aclk_66 = clk_get_rate(&exynos5_clk_aclk_66.clk); | ||
1592 | |||
1593 | printk(KERN_INFO "EXYNOS5: ARMCLK=%ld, CDREX=%ld, ACLK400=%ld\n" | ||
1594 | "ACLK333=%ld, ACLK266=%ld, ACLK200=%ld\n" | ||
1595 | "ACLK166=%ld, ACLK66=%ld\n", | ||
1596 | armclk, mout_cdrex, aclk_400, | ||
1597 | aclk_333, aclk_266, aclk_200, | ||
1598 | aclk_166, aclk_66); | ||
1599 | |||
1600 | |||
1601 | clk_fout_epll.ops = &exynos5_epll_ops; | ||
1602 | |||
1603 | if (clk_set_parent(&exynos5_clk_mout_epll.clk, &clk_fout_epll)) | ||
1604 | printk(KERN_ERR "Unable to set parent %s of clock %s.\n", | ||
1605 | clk_fout_epll.name, exynos5_clk_mout_epll.clk.name); | ||
1606 | |||
1607 | clk_set_rate(&exynos5_clk_sclk_apll.clk, 100000000); | ||
1608 | clk_set_rate(&exynos5_clk_aclk_266.clk, 300000000); | ||
1609 | |||
1610 | clk_set_rate(&exynos5_clk_aclk_acp.clk, 267000000); | ||
1611 | clk_set_rate(&exynos5_clk_pclk_acp.clk, 134000000); | ||
1612 | |||
1613 | for (ptr = 0; ptr < ARRAY_SIZE(exynos5_clksrcs); ptr++) | ||
1614 | s3c_set_clksrc(&exynos5_clksrcs[ptr], true); | ||
1615 | } | ||
1616 | |||
1617 | void __init exynos5_register_clocks(void) | ||
1618 | { | ||
1619 | int ptr; | ||
1620 | |||
1621 | s3c24xx_register_clocks(exynos5_clks, ARRAY_SIZE(exynos5_clks)); | ||
1622 | |||
1623 | for (ptr = 0; ptr < ARRAY_SIZE(exynos5_sysclks); ptr++) | ||
1624 | s3c_register_clksrc(exynos5_sysclks[ptr], 1); | ||
1625 | |||
1626 | for (ptr = 0; ptr < ARRAY_SIZE(exynos5_sclk_tv); ptr++) | ||
1627 | s3c_register_clksrc(exynos5_sclk_tv[ptr], 1); | ||
1628 | |||
1629 | for (ptr = 0; ptr < ARRAY_SIZE(exynos5_clksrc_cdev); ptr++) | ||
1630 | s3c_register_clksrc(exynos5_clksrc_cdev[ptr], 1); | ||
1631 | |||
1632 | s3c_register_clksrc(exynos5_clksrcs, ARRAY_SIZE(exynos5_clksrcs)); | ||
1633 | s3c_register_clocks(exynos5_init_clocks_on, ARRAY_SIZE(exynos5_init_clocks_on)); | ||
1634 | |||
1635 | s3c24xx_register_clocks(exynos5_clk_cdev, ARRAY_SIZE(exynos5_clk_cdev)); | ||
1636 | for (ptr = 0; ptr < ARRAY_SIZE(exynos5_clk_cdev); ptr++) | ||
1637 | s3c_disable_clocks(exynos5_clk_cdev[ptr], 1); | ||
1638 | |||
1639 | s3c_register_clocks(exynos5_init_clocks_off, ARRAY_SIZE(exynos5_init_clocks_off)); | ||
1640 | s3c_disable_clocks(exynos5_init_clocks_off, ARRAY_SIZE(exynos5_init_clocks_off)); | ||
1641 | clkdev_add_table(exynos5_clk_lookup, ARRAY_SIZE(exynos5_clk_lookup)); | ||
1642 | |||
1643 | register_syscore_ops(&exynos5_clock_syscore_ops); | ||
1644 | s3c_pwmclk_init(); | ||
1645 | } | ||
diff --git a/arch/arm/mach-exynos/common.c b/arch/arm/mach-exynos/common.c index 15718da30c45..b35c60059bb8 100644 --- a/arch/arm/mach-exynos/common.c +++ b/arch/arm/mach-exynos/common.c | |||
@@ -24,6 +24,8 @@ | |||
24 | #include <linux/export.h> | 24 | #include <linux/export.h> |
25 | #include <linux/irqdomain.h> | 25 | #include <linux/irqdomain.h> |
26 | #include <linux/of_address.h> | 26 | #include <linux/of_address.h> |
27 | #include <linux/clocksource.h> | ||
28 | #include <linux/clk-provider.h> | ||
27 | #include <linux/irqchip/arm-gic.h> | 29 | #include <linux/irqchip/arm-gic.h> |
28 | #include <linux/irqchip/chained_irq.h> | 30 | #include <linux/irqchip/chained_irq.h> |
29 | 31 | ||
@@ -37,9 +39,9 @@ | |||
37 | #include <mach/regs-irq.h> | 39 | #include <mach/regs-irq.h> |
38 | #include <mach/regs-pmu.h> | 40 | #include <mach/regs-pmu.h> |
39 | #include <mach/regs-gpio.h> | 41 | #include <mach/regs-gpio.h> |
42 | #include <mach/irqs.h> | ||
40 | 43 | ||
41 | #include <plat/cpu.h> | 44 | #include <plat/cpu.h> |
42 | #include <plat/clock.h> | ||
43 | #include <plat/devs.h> | 45 | #include <plat/devs.h> |
44 | #include <plat/pm.h> | 46 | #include <plat/pm.h> |
45 | #include <plat/sdhci.h> | 47 | #include <plat/sdhci.h> |
@@ -65,17 +67,16 @@ static const char name_exynos5440[] = "EXYNOS5440"; | |||
65 | static void exynos4_map_io(void); | 67 | static void exynos4_map_io(void); |
66 | static void exynos5_map_io(void); | 68 | static void exynos5_map_io(void); |
67 | static void exynos5440_map_io(void); | 69 | static void exynos5440_map_io(void); |
68 | static void exynos4_init_clocks(int xtal); | ||
69 | static void exynos5_init_clocks(int xtal); | ||
70 | static void exynos4_init_uarts(struct s3c2410_uartcfg *cfg, int no); | 70 | static void exynos4_init_uarts(struct s3c2410_uartcfg *cfg, int no); |
71 | static int exynos_init(void); | 71 | static int exynos_init(void); |
72 | 72 | ||
73 | unsigned long xxti_f = 0, xusbxti_f = 0; | ||
74 | |||
73 | static struct cpu_table cpu_ids[] __initdata = { | 75 | static struct cpu_table cpu_ids[] __initdata = { |
74 | { | 76 | { |
75 | .idcode = EXYNOS4210_CPU_ID, | 77 | .idcode = EXYNOS4210_CPU_ID, |
76 | .idmask = EXYNOS4_CPU_MASK, | 78 | .idmask = EXYNOS4_CPU_MASK, |
77 | .map_io = exynos4_map_io, | 79 | .map_io = exynos4_map_io, |
78 | .init_clocks = exynos4_init_clocks, | ||
79 | .init_uarts = exynos4_init_uarts, | 80 | .init_uarts = exynos4_init_uarts, |
80 | .init = exynos_init, | 81 | .init = exynos_init, |
81 | .name = name_exynos4210, | 82 | .name = name_exynos4210, |
@@ -83,7 +84,6 @@ static struct cpu_table cpu_ids[] __initdata = { | |||
83 | .idcode = EXYNOS4212_CPU_ID, | 84 | .idcode = EXYNOS4212_CPU_ID, |
84 | .idmask = EXYNOS4_CPU_MASK, | 85 | .idmask = EXYNOS4_CPU_MASK, |
85 | .map_io = exynos4_map_io, | 86 | .map_io = exynos4_map_io, |
86 | .init_clocks = exynos4_init_clocks, | ||
87 | .init_uarts = exynos4_init_uarts, | 87 | .init_uarts = exynos4_init_uarts, |
88 | .init = exynos_init, | 88 | .init = exynos_init, |
89 | .name = name_exynos4212, | 89 | .name = name_exynos4212, |
@@ -91,7 +91,6 @@ static struct cpu_table cpu_ids[] __initdata = { | |||
91 | .idcode = EXYNOS4412_CPU_ID, | 91 | .idcode = EXYNOS4412_CPU_ID, |
92 | .idmask = EXYNOS4_CPU_MASK, | 92 | .idmask = EXYNOS4_CPU_MASK, |
93 | .map_io = exynos4_map_io, | 93 | .map_io = exynos4_map_io, |
94 | .init_clocks = exynos4_init_clocks, | ||
95 | .init_uarts = exynos4_init_uarts, | 94 | .init_uarts = exynos4_init_uarts, |
96 | .init = exynos_init, | 95 | .init = exynos_init, |
97 | .name = name_exynos4412, | 96 | .name = name_exynos4412, |
@@ -99,7 +98,6 @@ static struct cpu_table cpu_ids[] __initdata = { | |||
99 | .idcode = EXYNOS5250_SOC_ID, | 98 | .idcode = EXYNOS5250_SOC_ID, |
100 | .idmask = EXYNOS5_SOC_MASK, | 99 | .idmask = EXYNOS5_SOC_MASK, |
101 | .map_io = exynos5_map_io, | 100 | .map_io = exynos5_map_io, |
102 | .init_clocks = exynos5_init_clocks, | ||
103 | .init = exynos_init, | 101 | .init = exynos_init, |
104 | .name = name_exynos5250, | 102 | .name = name_exynos5250, |
105 | }, { | 103 | }, { |
@@ -257,11 +255,6 @@ static struct map_desc exynos5_iodesc[] __initdata = { | |||
257 | .length = SZ_4K, | 255 | .length = SZ_4K, |
258 | .type = MT_DEVICE, | 256 | .type = MT_DEVICE, |
259 | }, { | 257 | }, { |
260 | .virtual = (unsigned long)S5P_VA_SYSTIMER, | ||
261 | .pfn = __phys_to_pfn(EXYNOS5_PA_SYSTIMER), | ||
262 | .length = SZ_4K, | ||
263 | .type = MT_DEVICE, | ||
264 | }, { | ||
265 | .virtual = (unsigned long)S5P_VA_SYSRAM, | 258 | .virtual = (unsigned long)S5P_VA_SYSRAM, |
266 | .pfn = __phys_to_pfn(EXYNOS5_PA_SYSRAM), | 259 | .pfn = __phys_to_pfn(EXYNOS5_PA_SYSRAM), |
267 | .length = SZ_4K, | 260 | .length = SZ_4K, |
@@ -402,43 +395,26 @@ static void __init exynos5_map_io(void) | |||
402 | iotable_init(exynos5_iodesc, ARRAY_SIZE(exynos5_iodesc)); | 395 | iotable_init(exynos5_iodesc, ARRAY_SIZE(exynos5_iodesc)); |
403 | } | 396 | } |
404 | 397 | ||
405 | static void __init exynos4_init_clocks(int xtal) | ||
406 | { | ||
407 | printk(KERN_DEBUG "%s: initializing clocks\n", __func__); | ||
408 | |||
409 | s3c24xx_register_baseclocks(xtal); | ||
410 | s5p_register_clocks(xtal); | ||
411 | |||
412 | if (soc_is_exynos4210()) | ||
413 | exynos4210_register_clocks(); | ||
414 | else if (soc_is_exynos4212() || soc_is_exynos4412()) | ||
415 | exynos4212_register_clocks(); | ||
416 | |||
417 | exynos4_register_clocks(); | ||
418 | exynos4_setup_clocks(); | ||
419 | } | ||
420 | |||
421 | static void __init exynos5440_map_io(void) | 398 | static void __init exynos5440_map_io(void) |
422 | { | 399 | { |
423 | iotable_init(exynos5440_iodesc0, ARRAY_SIZE(exynos5440_iodesc0)); | 400 | iotable_init(exynos5440_iodesc0, ARRAY_SIZE(exynos5440_iodesc0)); |
424 | } | 401 | } |
425 | 402 | ||
426 | static void __init exynos5_init_clocks(int xtal) | 403 | void __init exynos_init_time(void) |
427 | { | 404 | { |
428 | printk(KERN_DEBUG "%s: initializing clocks\n", __func__); | 405 | if (of_have_populated_dt()) { |
429 | 406 | #ifdef CONFIG_OF | |
430 | /* EXYNOS5440 can support only common clock framework */ | 407 | of_clk_init(NULL); |
431 | 408 | clocksource_of_init(); | |
432 | if (soc_is_exynos5440()) | 409 | #endif |
433 | return; | 410 | } else { |
434 | 411 | /* todo: remove after migrating legacy E4 platforms to dt */ | |
435 | #ifdef CONFIG_SOC_EXYNOS5250 | 412 | #ifdef CONFIG_ARCH_EXYNOS4 |
436 | s3c24xx_register_baseclocks(xtal); | 413 | exynos4_clk_init(NULL); |
437 | s5p_register_clocks(xtal); | 414 | exynos4_clk_register_fixed_ext(xxti_f, xusbxti_f); |
438 | |||
439 | exynos5_register_clocks(); | ||
440 | exynos5_setup_clocks(); | ||
441 | #endif | 415 | #endif |
416 | mct_init(); | ||
417 | } | ||
442 | } | 418 | } |
443 | 419 | ||
444 | void __init exynos4_init_irq(void) | 420 | void __init exynos4_init_irq(void) |
@@ -824,6 +800,7 @@ static int __init exynos_init_irq_eint(void) | |||
824 | static const struct of_device_id exynos_pinctrl_ids[] = { | 800 | static const struct of_device_id exynos_pinctrl_ids[] = { |
825 | { .compatible = "samsung,exynos4210-pinctrl", }, | 801 | { .compatible = "samsung,exynos4210-pinctrl", }, |
826 | { .compatible = "samsung,exynos4x12-pinctrl", }, | 802 | { .compatible = "samsung,exynos4x12-pinctrl", }, |
803 | { .compatible = "samsung,exynos5250-pinctrl", }, | ||
827 | }; | 804 | }; |
828 | struct device_node *pctrl_np, *wkup_np; | 805 | struct device_node *pctrl_np, *wkup_np; |
829 | const char *wkup_compat = "samsung,exynos4210-wakeup-eint"; | 806 | const char *wkup_compat = "samsung,exynos4210-wakeup-eint"; |
@@ -877,3 +854,30 @@ static int __init exynos_init_irq_eint(void) | |||
877 | return 0; | 854 | return 0; |
878 | } | 855 | } |
879 | arch_initcall(exynos_init_irq_eint); | 856 | arch_initcall(exynos_init_irq_eint); |
857 | |||
858 | static struct resource exynos4_pmu_resource[] = { | ||
859 | DEFINE_RES_IRQ(EXYNOS4_IRQ_PMU), | ||
860 | DEFINE_RES_IRQ(EXYNOS4_IRQ_PMU_CPU1), | ||
861 | #if defined(CONFIG_SOC_EXYNOS4412) | ||
862 | DEFINE_RES_IRQ(EXYNOS4_IRQ_PMU_CPU2), | ||
863 | DEFINE_RES_IRQ(EXYNOS4_IRQ_PMU_CPU3), | ||
864 | #endif | ||
865 | }; | ||
866 | |||
867 | static struct platform_device exynos4_device_pmu = { | ||
868 | .name = "arm-pmu", | ||
869 | .num_resources = ARRAY_SIZE(exynos4_pmu_resource), | ||
870 | .resource = exynos4_pmu_resource, | ||
871 | }; | ||
872 | |||
873 | static int __init exynos_armpmu_init(void) | ||
874 | { | ||
875 | if (!of_have_populated_dt()) { | ||
876 | if (soc_is_exynos4210() || soc_is_exynos4212()) | ||
877 | exynos4_device_pmu.num_resources = 2; | ||
878 | platform_device_register(&exynos4_device_pmu); | ||
879 | } | ||
880 | |||
881 | return 0; | ||
882 | } | ||
883 | arch_initcall(exynos_armpmu_init); | ||
diff --git a/arch/arm/mach-exynos/common.h b/arch/arm/mach-exynos/common.h index 9339bb8954be..cb89ab886950 100644 --- a/arch/arm/mach-exynos/common.h +++ b/arch/arm/mach-exynos/common.h | |||
@@ -12,7 +12,11 @@ | |||
12 | #ifndef __ARCH_ARM_MACH_EXYNOS_COMMON_H | 12 | #ifndef __ARCH_ARM_MACH_EXYNOS_COMMON_H |
13 | #define __ARCH_ARM_MACH_EXYNOS_COMMON_H | 13 | #define __ARCH_ARM_MACH_EXYNOS_COMMON_H |
14 | 14 | ||
15 | extern void exynos4_timer_init(void); | 15 | #include <linux/of.h> |
16 | |||
17 | extern void mct_init(void); | ||
18 | void exynos_init_time(void); | ||
19 | extern unsigned long xxti_f, xusbxti_f; | ||
16 | 20 | ||
17 | struct map_desc; | 21 | struct map_desc; |
18 | void exynos_init_io(struct map_desc *mach_desc, int size); | 22 | void exynos_init_io(struct map_desc *mach_desc, int size); |
@@ -22,6 +26,10 @@ void exynos4_restart(char mode, const char *cmd); | |||
22 | void exynos5_restart(char mode, const char *cmd); | 26 | void exynos5_restart(char mode, const char *cmd); |
23 | void exynos_init_late(void); | 27 | void exynos_init_late(void); |
24 | 28 | ||
29 | /* ToDo: remove these after migrating legacy exynos4 platforms to dt */ | ||
30 | void exynos4_clk_init(struct device_node *np); | ||
31 | void exynos4_clk_register_fixed_ext(unsigned long, unsigned long); | ||
32 | |||
25 | #ifdef CONFIG_PM_GENERIC_DOMAINS | 33 | #ifdef CONFIG_PM_GENERIC_DOMAINS |
26 | int exynos_pm_late_initcall(void); | 34 | int exynos_pm_late_initcall(void); |
27 | #else | 35 | #else |
diff --git a/arch/arm/mach-exynos/include/mach/irqs.h b/arch/arm/mach-exynos/include/mach/irqs.h index 8bd5dde5fc78..c72f59d91fce 100644 --- a/arch/arm/mach-exynos/include/mach/irqs.h +++ b/arch/arm/mach-exynos/include/mach/irqs.h | |||
@@ -30,8 +30,6 @@ | |||
30 | 30 | ||
31 | /* For EXYNOS4 and EXYNOS5 */ | 31 | /* For EXYNOS4 and EXYNOS5 */ |
32 | 32 | ||
33 | #define EXYNOS_IRQ_MCT_LOCALTIMER IRQ_PPI(12) | ||
34 | |||
35 | #define EXYNOS_IRQ_EINT16_31 IRQ_SPI(32) | 33 | #define EXYNOS_IRQ_EINT16_31 IRQ_SPI(32) |
36 | 34 | ||
37 | /* For EXYNOS4 SoCs */ | 35 | /* For EXYNOS4 SoCs */ |
@@ -128,7 +126,7 @@ | |||
128 | #define EXYNOS4_IRQ_ADC1 IRQ_SPI(107) | 126 | #define EXYNOS4_IRQ_ADC1 IRQ_SPI(107) |
129 | #define EXYNOS4_IRQ_PEN1 IRQ_SPI(108) | 127 | #define EXYNOS4_IRQ_PEN1 IRQ_SPI(108) |
130 | #define EXYNOS4_IRQ_KEYPAD IRQ_SPI(109) | 128 | #define EXYNOS4_IRQ_KEYPAD IRQ_SPI(109) |
131 | #define EXYNOS4_IRQ_PMU IRQ_SPI(110) | 129 | #define EXYNOS4_IRQ_POWER_PMU IRQ_SPI(110) |
132 | #define EXYNOS4_IRQ_GPS IRQ_SPI(111) | 130 | #define EXYNOS4_IRQ_GPS IRQ_SPI(111) |
133 | #define EXYNOS4_IRQ_INTFEEDCTRL_SSS IRQ_SPI(112) | 131 | #define EXYNOS4_IRQ_INTFEEDCTRL_SSS IRQ_SPI(112) |
134 | #define EXYNOS4_IRQ_SLIMBUS IRQ_SPI(113) | 132 | #define EXYNOS4_IRQ_SLIMBUS IRQ_SPI(113) |
@@ -136,6 +134,11 @@ | |||
136 | #define EXYNOS4_IRQ_TSI IRQ_SPI(115) | 134 | #define EXYNOS4_IRQ_TSI IRQ_SPI(115) |
137 | #define EXYNOS4_IRQ_SATA IRQ_SPI(116) | 135 | #define EXYNOS4_IRQ_SATA IRQ_SPI(116) |
138 | 136 | ||
137 | #define EXYNOS4_IRQ_PMU COMBINER_IRQ(2, 2) | ||
138 | #define EXYNOS4_IRQ_PMU_CPU1 COMBINER_IRQ(3, 2) | ||
139 | #define EXYNOS4_IRQ_PMU_CPU2 COMBINER_IRQ(18, 2) | ||
140 | #define EXYNOS4_IRQ_PMU_CPU3 COMBINER_IRQ(19, 2) | ||
141 | |||
139 | #define EXYNOS4_IRQ_TMU_TRIG0 COMBINER_IRQ(2, 4) | 142 | #define EXYNOS4_IRQ_TMU_TRIG0 COMBINER_IRQ(2, 4) |
140 | #define EXYNOS4_IRQ_TMU_TRIG1 COMBINER_IRQ(3, 4) | 143 | #define EXYNOS4_IRQ_TMU_TRIG1 COMBINER_IRQ(3, 4) |
141 | 144 | ||
@@ -168,7 +171,10 @@ | |||
168 | #define EXYNOS4_IRQ_FIMD0_VSYNC COMBINER_IRQ(11, 1) | 171 | #define EXYNOS4_IRQ_FIMD0_VSYNC COMBINER_IRQ(11, 1) |
169 | #define EXYNOS4_IRQ_FIMD0_SYSTEM COMBINER_IRQ(11, 2) | 172 | #define EXYNOS4_IRQ_FIMD0_SYSTEM COMBINER_IRQ(11, 2) |
170 | 173 | ||
171 | #define EXYNOS4_MAX_COMBINER_NR 16 | 174 | #define EXYNOS4210_MAX_COMBINER_NR 16 |
175 | #define EXYNOS4212_MAX_COMBINER_NR 18 | ||
176 | #define EXYNOS4412_MAX_COMBINER_NR 20 | ||
177 | #define EXYNOS4_MAX_COMBINER_NR EXYNOS4412_MAX_COMBINER_NR | ||
172 | 178 | ||
173 | #define EXYNOS4_IRQ_GPIO1_NR_GROUPS 16 | 179 | #define EXYNOS4_IRQ_GPIO1_NR_GROUPS 16 |
174 | #define EXYNOS4_IRQ_GPIO2_NR_GROUPS 9 | 180 | #define EXYNOS4_IRQ_GPIO2_NR_GROUPS 9 |
@@ -233,7 +239,6 @@ | |||
233 | #define IRQ_TC EXYNOS4_IRQ_PEN0 | 239 | #define IRQ_TC EXYNOS4_IRQ_PEN0 |
234 | 240 | ||
235 | #define IRQ_KEYPAD EXYNOS4_IRQ_KEYPAD | 241 | #define IRQ_KEYPAD EXYNOS4_IRQ_KEYPAD |
236 | #define IRQ_PMU EXYNOS4_IRQ_PMU | ||
237 | 242 | ||
238 | #define IRQ_FIMD0_FIFO EXYNOS4_IRQ_FIMD0_FIFO | 243 | #define IRQ_FIMD0_FIFO EXYNOS4_IRQ_FIMD0_FIFO |
239 | #define IRQ_FIMD0_VSYNC EXYNOS4_IRQ_FIMD0_VSYNC | 244 | #define IRQ_FIMD0_VSYNC EXYNOS4_IRQ_FIMD0_VSYNC |
@@ -323,8 +328,6 @@ | |||
323 | #define EXYNOS5_IRQ_CEC IRQ_SPI(114) | 328 | #define EXYNOS5_IRQ_CEC IRQ_SPI(114) |
324 | #define EXYNOS5_IRQ_SATA IRQ_SPI(115) | 329 | #define EXYNOS5_IRQ_SATA IRQ_SPI(115) |
325 | 330 | ||
326 | #define EXYNOS5_IRQ_MCT_L0 IRQ_SPI(120) | ||
327 | #define EXYNOS5_IRQ_MCT_L1 IRQ_SPI(121) | ||
328 | #define EXYNOS5_IRQ_MMC44 IRQ_SPI(123) | 331 | #define EXYNOS5_IRQ_MMC44 IRQ_SPI(123) |
329 | #define EXYNOS5_IRQ_MDMA1 IRQ_SPI(124) | 332 | #define EXYNOS5_IRQ_MDMA1 IRQ_SPI(124) |
330 | #define EXYNOS5_IRQ_FIMC_LITE0 IRQ_SPI(125) | 333 | #define EXYNOS5_IRQ_FIMC_LITE0 IRQ_SPI(125) |
@@ -419,8 +422,6 @@ | |||
419 | #define EXYNOS5_IRQ_PMU_CPU1 COMBINER_IRQ(22, 4) | 422 | #define EXYNOS5_IRQ_PMU_CPU1 COMBINER_IRQ(22, 4) |
420 | 423 | ||
421 | #define EXYNOS5_IRQ_EINT0 COMBINER_IRQ(23, 0) | 424 | #define EXYNOS5_IRQ_EINT0 COMBINER_IRQ(23, 0) |
422 | #define EXYNOS5_IRQ_MCT_G0 COMBINER_IRQ(23, 3) | ||
423 | #define EXYNOS5_IRQ_MCT_G1 COMBINER_IRQ(23, 4) | ||
424 | 425 | ||
425 | #define EXYNOS5_IRQ_EINT1 COMBINER_IRQ(24, 0) | 426 | #define EXYNOS5_IRQ_EINT1 COMBINER_IRQ(24, 0) |
426 | #define EXYNOS5_IRQ_SYSMMU_LITE1_0 COMBINER_IRQ(24, 1) | 427 | #define EXYNOS5_IRQ_SYSMMU_LITE1_0 COMBINER_IRQ(24, 1) |
diff --git a/arch/arm/mach-exynos/include/mach/map.h b/arch/arm/mach-exynos/include/mach/map.h index 1df6abbf53b8..7f99b7b187d6 100644 --- a/arch/arm/mach-exynos/include/mach/map.h +++ b/arch/arm/mach-exynos/include/mach/map.h | |||
@@ -65,7 +65,6 @@ | |||
65 | #define EXYNOS5_PA_CMU 0x10010000 | 65 | #define EXYNOS5_PA_CMU 0x10010000 |
66 | 66 | ||
67 | #define EXYNOS4_PA_SYSTIMER 0x10050000 | 67 | #define EXYNOS4_PA_SYSTIMER 0x10050000 |
68 | #define EXYNOS5_PA_SYSTIMER 0x101C0000 | ||
69 | 68 | ||
70 | #define EXYNOS4_PA_WATCHDOG 0x10060000 | 69 | #define EXYNOS4_PA_WATCHDOG 0x10060000 |
71 | #define EXYNOS5_PA_WATCHDOG 0x101D0000 | 70 | #define EXYNOS5_PA_WATCHDOG 0x101D0000 |
diff --git a/arch/arm/mach-exynos/include/mach/regs-mct.h b/arch/arm/mach-exynos/include/mach/regs-mct.h deleted file mode 100644 index 80dd02ad6d61..000000000000 --- a/arch/arm/mach-exynos/include/mach/regs-mct.h +++ /dev/null | |||
@@ -1,53 +0,0 @@ | |||
1 | /* arch/arm/mach-exynos4/include/mach/regs-mct.h | ||
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * EXYNOS4 MCT configutation | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_ARCH_REGS_MCT_H | ||
14 | #define __ASM_ARCH_REGS_MCT_H __FILE__ | ||
15 | |||
16 | #include <mach/map.h> | ||
17 | |||
18 | #define EXYNOS4_MCTREG(x) (S5P_VA_SYSTIMER + (x)) | ||
19 | |||
20 | #define EXYNOS4_MCT_G_CNT_L EXYNOS4_MCTREG(0x100) | ||
21 | #define EXYNOS4_MCT_G_CNT_U EXYNOS4_MCTREG(0x104) | ||
22 | #define EXYNOS4_MCT_G_CNT_WSTAT EXYNOS4_MCTREG(0x110) | ||
23 | |||
24 | #define EXYNOS4_MCT_G_COMP0_L EXYNOS4_MCTREG(0x200) | ||
25 | #define EXYNOS4_MCT_G_COMP0_U EXYNOS4_MCTREG(0x204) | ||
26 | #define EXYNOS4_MCT_G_COMP0_ADD_INCR EXYNOS4_MCTREG(0x208) | ||
27 | |||
28 | #define EXYNOS4_MCT_G_TCON EXYNOS4_MCTREG(0x240) | ||
29 | |||
30 | #define EXYNOS4_MCT_G_INT_CSTAT EXYNOS4_MCTREG(0x244) | ||
31 | #define EXYNOS4_MCT_G_INT_ENB EXYNOS4_MCTREG(0x248) | ||
32 | #define EXYNOS4_MCT_G_WSTAT EXYNOS4_MCTREG(0x24C) | ||
33 | |||
34 | #define _EXYNOS4_MCT_L_BASE EXYNOS4_MCTREG(0x300) | ||
35 | #define EXYNOS4_MCT_L_BASE(x) (_EXYNOS4_MCT_L_BASE + (0x100 * x)) | ||
36 | #define EXYNOS4_MCT_L_MASK (0xffffff00) | ||
37 | |||
38 | #define MCT_L_TCNTB_OFFSET (0x00) | ||
39 | #define MCT_L_ICNTB_OFFSET (0x08) | ||
40 | #define MCT_L_TCON_OFFSET (0x20) | ||
41 | #define MCT_L_INT_CSTAT_OFFSET (0x30) | ||
42 | #define MCT_L_INT_ENB_OFFSET (0x34) | ||
43 | #define MCT_L_WSTAT_OFFSET (0x40) | ||
44 | |||
45 | #define MCT_G_TCON_START (1 << 8) | ||
46 | #define MCT_G_TCON_COMP0_AUTO_INC (1 << 1) | ||
47 | #define MCT_G_TCON_COMP0_ENABLE (1 << 0) | ||
48 | |||
49 | #define MCT_L_TCON_INTERVAL_MODE (1 << 2) | ||
50 | #define MCT_L_TCON_INT_START (1 << 1) | ||
51 | #define MCT_L_TCON_TIMER_START (1 << 0) | ||
52 | |||
53 | #endif /* __ASM_ARCH_REGS_MCT_H */ | ||
diff --git a/arch/arm/mach-exynos/mach-armlex4210.c b/arch/arm/mach-exynos/mach-armlex4210.c index 2126f3503a3f..5f0f55701374 100644 --- a/arch/arm/mach-exynos/mach-armlex4210.c +++ b/arch/arm/mach-exynos/mach-armlex4210.c | |||
@@ -178,7 +178,6 @@ static void __init armlex4210_smsc911x_init(void) | |||
178 | static void __init armlex4210_map_io(void) | 178 | static void __init armlex4210_map_io(void) |
179 | { | 179 | { |
180 | exynos_init_io(NULL, 0); | 180 | exynos_init_io(NULL, 0); |
181 | s3c24xx_init_clocks(24000000); | ||
182 | s3c24xx_init_uarts(armlex4210_uartcfgs, | 181 | s3c24xx_init_uarts(armlex4210_uartcfgs, |
183 | ARRAY_SIZE(armlex4210_uartcfgs)); | 182 | ARRAY_SIZE(armlex4210_uartcfgs)); |
184 | } | 183 | } |
@@ -203,6 +202,6 @@ MACHINE_START(ARMLEX4210, "ARMLEX4210") | |||
203 | .map_io = armlex4210_map_io, | 202 | .map_io = armlex4210_map_io, |
204 | .init_machine = armlex4210_machine_init, | 203 | .init_machine = armlex4210_machine_init, |
205 | .init_late = exynos_init_late, | 204 | .init_late = exynos_init_late, |
206 | .init_time = exynos4_timer_init, | 205 | .init_time = exynos_init_time, |
207 | .restart = exynos4_restart, | 206 | .restart = exynos4_restart, |
208 | MACHINE_END | 207 | MACHINE_END |
diff --git a/arch/arm/mach-exynos/mach-exynos4-dt.c b/arch/arm/mach-exynos/mach-exynos4-dt.c index 3358088c822a..ac27f3cd121f 100644 --- a/arch/arm/mach-exynos/mach-exynos4-dt.c +++ b/arch/arm/mach-exynos/mach-exynos4-dt.c | |||
@@ -11,121 +11,26 @@ | |||
11 | * published by the Free Software Foundation. | 11 | * published by the Free Software Foundation. |
12 | */ | 12 | */ |
13 | 13 | ||
14 | #include <linux/kernel.h> | ||
14 | #include <linux/of_platform.h> | 15 | #include <linux/of_platform.h> |
16 | #include <linux/of_fdt.h> | ||
15 | #include <linux/serial_core.h> | 17 | #include <linux/serial_core.h> |
18 | #include <linux/memblock.h> | ||
19 | #include <linux/clocksource.h> | ||
16 | 20 | ||
17 | #include <asm/mach/arch.h> | 21 | #include <asm/mach/arch.h> |
18 | #include <mach/map.h> | 22 | #include <plat/mfc.h> |
19 | |||
20 | #include <plat/cpu.h> | ||
21 | #include <plat/regs-serial.h> | ||
22 | 23 | ||
23 | #include "common.h" | 24 | #include "common.h" |
24 | 25 | ||
25 | /* | ||
26 | * The following lookup table is used to override device names when devices | ||
27 | * are registered from device tree. This is temporarily added to enable | ||
28 | * device tree support addition for the Exynos4 architecture. | ||
29 | * | ||
30 | * For drivers that require platform data to be provided from the machine | ||
31 | * file, a platform data pointer can also be supplied along with the | ||
32 | * devices names. Usually, the platform data elements that cannot be parsed | ||
33 | * from the device tree by the drivers (example: function pointers) are | ||
34 | * supplied. But it should be noted that this is a temporary mechanism and | ||
35 | * at some point, the drivers should be capable of parsing all the platform | ||
36 | * data from the device tree. | ||
37 | */ | ||
38 | static const struct of_dev_auxdata exynos4_auxdata_lookup[] __initconst = { | ||
39 | OF_DEV_AUXDATA("samsung,exynos4210-uart", EXYNOS4_PA_UART0, | ||
40 | "exynos4210-uart.0", NULL), | ||
41 | OF_DEV_AUXDATA("samsung,exynos4210-uart", EXYNOS4_PA_UART1, | ||
42 | "exynos4210-uart.1", NULL), | ||
43 | OF_DEV_AUXDATA("samsung,exynos4210-uart", EXYNOS4_PA_UART2, | ||
44 | "exynos4210-uart.2", NULL), | ||
45 | OF_DEV_AUXDATA("samsung,exynos4210-uart", EXYNOS4_PA_UART3, | ||
46 | "exynos4210-uart.3", NULL), | ||
47 | OF_DEV_AUXDATA("samsung,exynos4210-sdhci", EXYNOS4_PA_HSMMC(0), | ||
48 | "exynos4-sdhci.0", NULL), | ||
49 | OF_DEV_AUXDATA("samsung,exynos4210-sdhci", EXYNOS4_PA_HSMMC(1), | ||
50 | "exynos4-sdhci.1", NULL), | ||
51 | OF_DEV_AUXDATA("samsung,exynos4210-sdhci", EXYNOS4_PA_HSMMC(2), | ||
52 | "exynos4-sdhci.2", NULL), | ||
53 | OF_DEV_AUXDATA("samsung,exynos4210-sdhci", EXYNOS4_PA_HSMMC(3), | ||
54 | "exynos4-sdhci.3", NULL), | ||
55 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS4_PA_IIC(0), | ||
56 | "s3c2440-i2c.0", NULL), | ||
57 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS4_PA_IIC(1), | ||
58 | "s3c2440-i2c.1", NULL), | ||
59 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS4_PA_IIC(2), | ||
60 | "s3c2440-i2c.2", NULL), | ||
61 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS4_PA_IIC(3), | ||
62 | "s3c2440-i2c.3", NULL), | ||
63 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS4_PA_IIC(4), | ||
64 | "s3c2440-i2c.4", NULL), | ||
65 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS4_PA_IIC(5), | ||
66 | "s3c2440-i2c.5", NULL), | ||
67 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS4_PA_IIC(6), | ||
68 | "s3c2440-i2c.6", NULL), | ||
69 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS4_PA_IIC(7), | ||
70 | "s3c2440-i2c.7", NULL), | ||
71 | OF_DEV_AUXDATA("samsung,exynos4210-spi", EXYNOS4_PA_SPI0, | ||
72 | "exynos4210-spi.0", NULL), | ||
73 | OF_DEV_AUXDATA("samsung,exynos4210-spi", EXYNOS4_PA_SPI1, | ||
74 | "exynos4210-spi.1", NULL), | ||
75 | OF_DEV_AUXDATA("samsung,exynos4210-spi", EXYNOS4_PA_SPI2, | ||
76 | "exynos4210-spi.2", NULL), | ||
77 | OF_DEV_AUXDATA("arm,pl330", EXYNOS4_PA_PDMA0, "dma-pl330.0", NULL), | ||
78 | OF_DEV_AUXDATA("arm,pl330", EXYNOS4_PA_PDMA1, "dma-pl330.1", NULL), | ||
79 | OF_DEV_AUXDATA("arm,pl330", EXYNOS4_PA_MDMA1, "dma-pl330.2", NULL), | ||
80 | OF_DEV_AUXDATA("samsung,exynos4210-tmu", EXYNOS4_PA_TMU, | ||
81 | "exynos-tmu", NULL), | ||
82 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x13620000, | ||
83 | "exynos-sysmmu.0", NULL), /* MFC_L */ | ||
84 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x13630000, | ||
85 | "exynos-sysmmu.1", NULL), /* MFC_R */ | ||
86 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x13E20000, | ||
87 | "exynos-sysmmu.2", NULL), /* TV */ | ||
88 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x11A60000, | ||
89 | "exynos-sysmmu.3", NULL), /* JPEG */ | ||
90 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x12A30000, | ||
91 | "exynos-sysmmu.4", NULL), /* ROTATOR */ | ||
92 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x11A20000, | ||
93 | "exynos-sysmmu.5", NULL), /* FIMC0 */ | ||
94 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x11A30000, | ||
95 | "exynos-sysmmu.6", NULL), /* FIMC1 */ | ||
96 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x11A40000, | ||
97 | "exynos-sysmmu.7", NULL), /* FIMC2 */ | ||
98 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x11A50000, | ||
99 | "exynos-sysmmu.8", NULL), /* FIMC3 */ | ||
100 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x12A20000, | ||
101 | "exynos-sysmmu.9", NULL), /* G2D(4210) */ | ||
102 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x10A40000, | ||
103 | "exynos-sysmmu.9", NULL), /* G2D(4x12) */ | ||
104 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x11E20000, | ||
105 | "exynos-sysmmu.10", NULL), /* FIMD0 */ | ||
106 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x12220000, | ||
107 | "exynos-sysmmu.11", NULL), /* FIMD1(4210) */ | ||
108 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x12260000, | ||
109 | "exynos-sysmmu.12", NULL), /* IS0(4x12) */ | ||
110 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x122B0000, | ||
111 | "exynos-sysmmu.13", NULL), /* IS1(4x12) */ | ||
112 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x123B0000, | ||
113 | "exynos-sysmmu.14", NULL), /* FIMC-LITE0(4x12) */ | ||
114 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x123C0000, | ||
115 | "exynos-sysmmu.15", NULL), /* FIMC-LITE1(4x12) */ | ||
116 | {}, | ||
117 | }; | ||
118 | |||
119 | static void __init exynos4_dt_map_io(void) | 26 | static void __init exynos4_dt_map_io(void) |
120 | { | 27 | { |
121 | exynos_init_io(NULL, 0); | 28 | exynos_init_io(NULL, 0); |
122 | s3c24xx_init_clocks(24000000); | ||
123 | } | 29 | } |
124 | 30 | ||
125 | static void __init exynos4_dt_machine_init(void) | 31 | static void __init exynos4_dt_machine_init(void) |
126 | { | 32 | { |
127 | of_platform_populate(NULL, of_default_bus_match_table, | 33 | of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL); |
128 | exynos4_auxdata_lookup, NULL); | ||
129 | } | 34 | } |
130 | 35 | ||
131 | static char const *exynos4_dt_compat[] __initdata = { | 36 | static char const *exynos4_dt_compat[] __initdata = { |
@@ -135,6 +40,18 @@ static char const *exynos4_dt_compat[] __initdata = { | |||
135 | NULL | 40 | NULL |
136 | }; | 41 | }; |
137 | 42 | ||
43 | static void __init exynos4_reserve(void) | ||
44 | { | ||
45 | #ifdef CONFIG_S5P_DEV_MFC | ||
46 | struct s5p_mfc_dt_meminfo mfc_mem; | ||
47 | |||
48 | /* Reserve memory for MFC only if it's available */ | ||
49 | mfc_mem.compatible = "samsung,mfc-v5"; | ||
50 | if (of_scan_flat_dt(s5p_fdt_find_mfc_mem, &mfc_mem)) | ||
51 | s5p_mfc_reserve_mem(mfc_mem.roff, mfc_mem.rsize, mfc_mem.loff, | ||
52 | mfc_mem.lsize); | ||
53 | #endif | ||
54 | } | ||
138 | DT_MACHINE_START(EXYNOS4210_DT, "Samsung Exynos4 (Flattened Device Tree)") | 55 | DT_MACHINE_START(EXYNOS4210_DT, "Samsung Exynos4 (Flattened Device Tree)") |
139 | /* Maintainer: Thomas Abraham <thomas.abraham@linaro.org> */ | 56 | /* Maintainer: Thomas Abraham <thomas.abraham@linaro.org> */ |
140 | .smp = smp_ops(exynos_smp_ops), | 57 | .smp = smp_ops(exynos_smp_ops), |
@@ -142,7 +59,8 @@ DT_MACHINE_START(EXYNOS4210_DT, "Samsung Exynos4 (Flattened Device Tree)") | |||
142 | .map_io = exynos4_dt_map_io, | 59 | .map_io = exynos4_dt_map_io, |
143 | .init_machine = exynos4_dt_machine_init, | 60 | .init_machine = exynos4_dt_machine_init, |
144 | .init_late = exynos_init_late, | 61 | .init_late = exynos_init_late, |
145 | .init_time = exynos4_timer_init, | 62 | .init_time = exynos_init_time, |
146 | .dt_compat = exynos4_dt_compat, | 63 | .dt_compat = exynos4_dt_compat, |
147 | .restart = exynos4_restart, | 64 | .restart = exynos4_restart, |
65 | .reserve = exynos4_reserve, | ||
148 | MACHINE_END | 66 | MACHINE_END |
diff --git a/arch/arm/mach-exynos/mach-exynos5-dt.c b/arch/arm/mach-exynos/mach-exynos5-dt.c index acaeb14db54b..753b94f3fca7 100644 --- a/arch/arm/mach-exynos/mach-exynos5-dt.c +++ b/arch/arm/mach-exynos/mach-exynos5-dt.c | |||
@@ -11,151 +11,21 @@ | |||
11 | 11 | ||
12 | #include <linux/of_platform.h> | 12 | #include <linux/of_platform.h> |
13 | #include <linux/of_fdt.h> | 13 | #include <linux/of_fdt.h> |
14 | #include <linux/serial_core.h> | ||
15 | #include <linux/memblock.h> | 14 | #include <linux/memblock.h> |
16 | #include <linux/io.h> | 15 | #include <linux/io.h> |
16 | #include <linux/clocksource.h> | ||
17 | 17 | ||
18 | #include <asm/mach/arch.h> | 18 | #include <asm/mach/arch.h> |
19 | #include <mach/map.h> | ||
20 | #include <mach/regs-pmu.h> | 19 | #include <mach/regs-pmu.h> |
21 | 20 | ||
22 | #include <plat/cpu.h> | 21 | #include <plat/cpu.h> |
23 | #include <plat/regs-serial.h> | ||
24 | #include <plat/mfc.h> | 22 | #include <plat/mfc.h> |
25 | 23 | ||
26 | #include "common.h" | 24 | #include "common.h" |
27 | 25 | ||
28 | /* | ||
29 | * The following lookup table is used to override device names when devices | ||
30 | * are registered from device tree. This is temporarily added to enable | ||
31 | * device tree support addition for the EXYNOS5 architecture. | ||
32 | * | ||
33 | * For drivers that require platform data to be provided from the machine | ||
34 | * file, a platform data pointer can also be supplied along with the | ||
35 | * devices names. Usually, the platform data elements that cannot be parsed | ||
36 | * from the device tree by the drivers (example: function pointers) are | ||
37 | * supplied. But it should be noted that this is a temporary mechanism and | ||
38 | * at some point, the drivers should be capable of parsing all the platform | ||
39 | * data from the device tree. | ||
40 | */ | ||
41 | static const struct of_dev_auxdata exynos5250_auxdata_lookup[] __initconst = { | ||
42 | OF_DEV_AUXDATA("samsung,exynos4210-uart", EXYNOS5_PA_UART0, | ||
43 | "exynos4210-uart.0", NULL), | ||
44 | OF_DEV_AUXDATA("samsung,exynos4210-uart", EXYNOS5_PA_UART1, | ||
45 | "exynos4210-uart.1", NULL), | ||
46 | OF_DEV_AUXDATA("samsung,exynos4210-uart", EXYNOS5_PA_UART2, | ||
47 | "exynos4210-uart.2", NULL), | ||
48 | OF_DEV_AUXDATA("samsung,exynos4210-uart", EXYNOS5_PA_UART3, | ||
49 | "exynos4210-uart.3", NULL), | ||
50 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS5_PA_IIC(0), | ||
51 | "s3c2440-i2c.0", NULL), | ||
52 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS5_PA_IIC(1), | ||
53 | "s3c2440-i2c.1", NULL), | ||
54 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS5_PA_IIC(2), | ||
55 | "s3c2440-i2c.2", NULL), | ||
56 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS5_PA_IIC(3), | ||
57 | "s3c2440-i2c.3", NULL), | ||
58 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS5_PA_IIC(4), | ||
59 | "s3c2440-i2c.4", NULL), | ||
60 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS5_PA_IIC(5), | ||
61 | "s3c2440-i2c.5", NULL), | ||
62 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS5_PA_IIC(6), | ||
63 | "s3c2440-i2c.6", NULL), | ||
64 | OF_DEV_AUXDATA("samsung,s3c2440-i2c", EXYNOS5_PA_IIC(7), | ||
65 | "s3c2440-i2c.7", NULL), | ||
66 | OF_DEV_AUXDATA("samsung,s3c2440-hdmiphy-i2c", EXYNOS5_PA_IIC(8), | ||
67 | "s3c2440-hdmiphy-i2c", NULL), | ||
68 | OF_DEV_AUXDATA("samsung,exynos5250-dw-mshc", EXYNOS5_PA_DWMCI0, | ||
69 | "dw_mmc.0", NULL), | ||
70 | OF_DEV_AUXDATA("samsung,exynos5250-dw-mshc", EXYNOS5_PA_DWMCI1, | ||
71 | "dw_mmc.1", NULL), | ||
72 | OF_DEV_AUXDATA("samsung,exynos5250-dw-mshc", EXYNOS5_PA_DWMCI2, | ||
73 | "dw_mmc.2", NULL), | ||
74 | OF_DEV_AUXDATA("samsung,exynos5250-dw-mshc", EXYNOS5_PA_DWMCI3, | ||
75 | "dw_mmc.3", NULL), | ||
76 | OF_DEV_AUXDATA("samsung,exynos4210-spi", EXYNOS5_PA_SPI0, | ||
77 | "exynos4210-spi.0", NULL), | ||
78 | OF_DEV_AUXDATA("samsung,exynos4210-spi", EXYNOS5_PA_SPI1, | ||
79 | "exynos4210-spi.1", NULL), | ||
80 | OF_DEV_AUXDATA("samsung,exynos4210-spi", EXYNOS5_PA_SPI2, | ||
81 | "exynos4210-spi.2", NULL), | ||
82 | OF_DEV_AUXDATA("samsung,exynos5-sata-ahci", 0x122F0000, | ||
83 | "exynos5-sata", NULL), | ||
84 | OF_DEV_AUXDATA("samsung,exynos5-sata-phy", 0x12170000, | ||
85 | "exynos5-sata-phy", NULL), | ||
86 | OF_DEV_AUXDATA("samsung,exynos5-sata-phy-i2c", 0x121D0000, | ||
87 | "exynos5-sata-phy-i2c", NULL), | ||
88 | OF_DEV_AUXDATA("arm,pl330", EXYNOS5_PA_PDMA0, "dma-pl330.0", NULL), | ||
89 | OF_DEV_AUXDATA("arm,pl330", EXYNOS5_PA_PDMA1, "dma-pl330.1", NULL), | ||
90 | OF_DEV_AUXDATA("arm,pl330", EXYNOS5_PA_MDMA1, "dma-pl330.2", NULL), | ||
91 | OF_DEV_AUXDATA("samsung,exynos5-gsc", EXYNOS5_PA_GSC0, | ||
92 | "exynos-gsc.0", NULL), | ||
93 | OF_DEV_AUXDATA("samsung,exynos5-gsc", EXYNOS5_PA_GSC1, | ||
94 | "exynos-gsc.1", NULL), | ||
95 | OF_DEV_AUXDATA("samsung,exynos5-gsc", EXYNOS5_PA_GSC2, | ||
96 | "exynos-gsc.2", NULL), | ||
97 | OF_DEV_AUXDATA("samsung,exynos5-gsc", EXYNOS5_PA_GSC3, | ||
98 | "exynos-gsc.3", NULL), | ||
99 | OF_DEV_AUXDATA("samsung,exynos5-hdmi", 0x14530000, | ||
100 | "exynos5-hdmi", NULL), | ||
101 | OF_DEV_AUXDATA("samsung,exynos5-mixer", 0x14450000, | ||
102 | "exynos5-mixer", NULL), | ||
103 | OF_DEV_AUXDATA("samsung,mfc-v6", 0x11000000, "s5p-mfc-v6", NULL), | ||
104 | OF_DEV_AUXDATA("samsung,exynos5250-tmu", 0x10060000, | ||
105 | "exynos-tmu", NULL), | ||
106 | OF_DEV_AUXDATA("samsung,i2s-v5", 0x03830000, | ||
107 | "samsung-i2s.0", NULL), | ||
108 | OF_DEV_AUXDATA("samsung,i2s-v5", 0x12D60000, | ||
109 | "samsung-i2s.1", NULL), | ||
110 | OF_DEV_AUXDATA("samsung,i2s-v5", 0x12D70000, | ||
111 | "samsung-i2s.2", NULL), | ||
112 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x11210000, | ||
113 | "exynos-sysmmu.0", "mfc"), /* MFC_L */ | ||
114 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x11200000, | ||
115 | "exynos-sysmmu.1", "mfc"), /* MFC_R */ | ||
116 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x14650000, | ||
117 | "exynos-sysmmu.2", NULL), /* TV */ | ||
118 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x11F20000, | ||
119 | "exynos-sysmmu.3", "jpeg"), /* JPEG */ | ||
120 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x11D40000, | ||
121 | "exynos-sysmmu.4", NULL), /* ROTATOR */ | ||
122 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x13E80000, | ||
123 | "exynos-sysmmu.5", "gscl"), /* GSCL0 */ | ||
124 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x13E90000, | ||
125 | "exynos-sysmmu.6", "gscl"), /* GSCL1 */ | ||
126 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x13EA0000, | ||
127 | "exynos-sysmmu.7", "gscl"), /* GSCL2 */ | ||
128 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x13EB0000, | ||
129 | "exynos-sysmmu.8", "gscl"), /* GSCL3 */ | ||
130 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x13260000, | ||
131 | "exynos-sysmmu.9", NULL), /* FIMC-IS0 */ | ||
132 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x132C0000, | ||
133 | "exynos-sysmmu.10", NULL), /* FIMC-IS1 */ | ||
134 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x14640000, | ||
135 | "exynos-sysmmu.11", NULL), /* FIMD1 */ | ||
136 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x13C40000, | ||
137 | "exynos-sysmmu.12", NULL), /* FIMC-LITE0 */ | ||
138 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x13C50000, | ||
139 | "exynos-sysmmu.13", NULL), /* FIMC-LITE1 */ | ||
140 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x10A60000, | ||
141 | "exynos-sysmmu.14", NULL), /* G2D */ | ||
142 | {}, | ||
143 | }; | ||
144 | |||
145 | static const struct of_dev_auxdata exynos5440_auxdata_lookup[] __initconst = { | ||
146 | OF_DEV_AUXDATA("samsung,exynos4210-uart", EXYNOS5440_PA_UART0, | ||
147 | "exynos4210-uart.0", NULL), | ||
148 | {}, | ||
149 | }; | ||
150 | |||
151 | static void __init exynos5_dt_map_io(void) | 26 | static void __init exynos5_dt_map_io(void) |
152 | { | 27 | { |
153 | unsigned long root = of_get_flat_dt_root(); | ||
154 | |||
155 | exynos_init_io(NULL, 0); | 28 | exynos_init_io(NULL, 0); |
156 | |||
157 | if (of_flat_dt_is_compatible(root, "samsung,exynos5250")) | ||
158 | s3c24xx_init_clocks(24000000); | ||
159 | } | 29 | } |
160 | 30 | ||
161 | static void __init exynos5_dt_machine_init(void) | 31 | static void __init exynos5_dt_machine_init(void) |
@@ -182,12 +52,7 @@ static void __init exynos5_dt_machine_init(void) | |||
182 | } | 52 | } |
183 | } | 53 | } |
184 | 54 | ||
185 | if (of_machine_is_compatible("samsung,exynos5250")) | 55 | of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL); |
186 | of_platform_populate(NULL, of_default_bus_match_table, | ||
187 | exynos5250_auxdata_lookup, NULL); | ||
188 | else if (of_machine_is_compatible("samsung,exynos5440")) | ||
189 | of_platform_populate(NULL, of_default_bus_match_table, | ||
190 | exynos5440_auxdata_lookup, NULL); | ||
191 | } | 56 | } |
192 | 57 | ||
193 | static char const *exynos5_dt_compat[] __initdata = { | 58 | static char const *exynos5_dt_compat[] __initdata = { |
@@ -216,7 +81,7 @@ DT_MACHINE_START(EXYNOS5_DT, "SAMSUNG EXYNOS5 (Flattened Device Tree)") | |||
216 | .map_io = exynos5_dt_map_io, | 81 | .map_io = exynos5_dt_map_io, |
217 | .init_machine = exynos5_dt_machine_init, | 82 | .init_machine = exynos5_dt_machine_init, |
218 | .init_late = exynos_init_late, | 83 | .init_late = exynos_init_late, |
219 | .init_time = exynos4_timer_init, | 84 | .init_time = exynos_init_time, |
220 | .dt_compat = exynos5_dt_compat, | 85 | .dt_compat = exynos5_dt_compat, |
221 | .restart = exynos5_restart, | 86 | .restart = exynos5_restart, |
222 | .reserve = exynos5_reserve, | 87 | .reserve = exynos5_reserve, |
diff --git a/arch/arm/mach-exynos/mach-nuri.c b/arch/arm/mach-exynos/mach-nuri.c index 2517406e7f56..5c8b2878dbbd 100644 --- a/arch/arm/mach-exynos/mach-nuri.c +++ b/arch/arm/mach-exynos/mach-nuri.c | |||
@@ -1331,8 +1331,9 @@ static struct platform_device *nuri_devices[] __initdata = { | |||
1331 | static void __init nuri_map_io(void) | 1331 | static void __init nuri_map_io(void) |
1332 | { | 1332 | { |
1333 | exynos_init_io(NULL, 0); | 1333 | exynos_init_io(NULL, 0); |
1334 | s3c24xx_init_clocks(clk_xusbxti.rate); | ||
1335 | s3c24xx_init_uarts(nuri_uartcfgs, ARRAY_SIZE(nuri_uartcfgs)); | 1334 | s3c24xx_init_uarts(nuri_uartcfgs, ARRAY_SIZE(nuri_uartcfgs)); |
1335 | xxti_f = 0; | ||
1336 | xusbxti_f = 24000000; | ||
1336 | } | 1337 | } |
1337 | 1338 | ||
1338 | static void __init nuri_reserve(void) | 1339 | static void __init nuri_reserve(void) |
@@ -1381,7 +1382,7 @@ MACHINE_START(NURI, "NURI") | |||
1381 | .map_io = nuri_map_io, | 1382 | .map_io = nuri_map_io, |
1382 | .init_machine = nuri_machine_init, | 1383 | .init_machine = nuri_machine_init, |
1383 | .init_late = exynos_init_late, | 1384 | .init_late = exynos_init_late, |
1384 | .init_time = exynos4_timer_init, | 1385 | .init_time = exynos_init_time, |
1385 | .reserve = &nuri_reserve, | 1386 | .reserve = &nuri_reserve, |
1386 | .restart = exynos4_restart, | 1387 | .restart = exynos4_restart, |
1387 | MACHINE_END | 1388 | MACHINE_END |
diff --git a/arch/arm/mach-exynos/mach-origen.c b/arch/arm/mach-exynos/mach-origen.c index ec42024dd13f..27f03ed5d067 100644 --- a/arch/arm/mach-exynos/mach-origen.c +++ b/arch/arm/mach-exynos/mach-origen.c | |||
@@ -755,8 +755,9 @@ static void s5p_tv_setup(void) | |||
755 | static void __init origen_map_io(void) | 755 | static void __init origen_map_io(void) |
756 | { | 756 | { |
757 | exynos_init_io(NULL, 0); | 757 | exynos_init_io(NULL, 0); |
758 | s3c24xx_init_clocks(clk_xusbxti.rate); | ||
759 | s3c24xx_init_uarts(origen_uartcfgs, ARRAY_SIZE(origen_uartcfgs)); | 758 | s3c24xx_init_uarts(origen_uartcfgs, ARRAY_SIZE(origen_uartcfgs)); |
759 | xxti_f = 0; | ||
760 | xusbxti_f = 24000000; | ||
760 | } | 761 | } |
761 | 762 | ||
762 | static void __init origen_power_init(void) | 763 | static void __init origen_power_init(void) |
@@ -816,7 +817,7 @@ MACHINE_START(ORIGEN, "ORIGEN") | |||
816 | .map_io = origen_map_io, | 817 | .map_io = origen_map_io, |
817 | .init_machine = origen_machine_init, | 818 | .init_machine = origen_machine_init, |
818 | .init_late = exynos_init_late, | 819 | .init_late = exynos_init_late, |
819 | .init_time = exynos4_timer_init, | 820 | .init_time = exynos_init_time, |
820 | .reserve = &origen_reserve, | 821 | .reserve = &origen_reserve, |
821 | .restart = exynos4_restart, | 822 | .restart = exynos4_restart, |
822 | MACHINE_END | 823 | MACHINE_END |
diff --git a/arch/arm/mach-exynos/mach-smdk4x12.c b/arch/arm/mach-exynos/mach-smdk4x12.c index 5df91236dbb4..2c8af9617920 100644 --- a/arch/arm/mach-exynos/mach-smdk4x12.c +++ b/arch/arm/mach-exynos/mach-smdk4x12.c | |||
@@ -323,7 +323,6 @@ static struct platform_device *smdk4x12_devices[] __initdata = { | |||
323 | static void __init smdk4x12_map_io(void) | 323 | static void __init smdk4x12_map_io(void) |
324 | { | 324 | { |
325 | exynos_init_io(NULL, 0); | 325 | exynos_init_io(NULL, 0); |
326 | s3c24xx_init_clocks(clk_xusbxti.rate); | ||
327 | s3c24xx_init_uarts(smdk4x12_uartcfgs, ARRAY_SIZE(smdk4x12_uartcfgs)); | 326 | s3c24xx_init_uarts(smdk4x12_uartcfgs, ARRAY_SIZE(smdk4x12_uartcfgs)); |
328 | } | 327 | } |
329 | 328 | ||
@@ -377,7 +376,7 @@ MACHINE_START(SMDK4212, "SMDK4212") | |||
377 | .init_irq = exynos4_init_irq, | 376 | .init_irq = exynos4_init_irq, |
378 | .map_io = smdk4x12_map_io, | 377 | .map_io = smdk4x12_map_io, |
379 | .init_machine = smdk4x12_machine_init, | 378 | .init_machine = smdk4x12_machine_init, |
380 | .init_time = exynos4_timer_init, | 379 | .init_time = exynos_init_time, |
381 | .restart = exynos4_restart, | 380 | .restart = exynos4_restart, |
382 | .reserve = &smdk4x12_reserve, | 381 | .reserve = &smdk4x12_reserve, |
383 | MACHINE_END | 382 | MACHINE_END |
@@ -391,7 +390,7 @@ MACHINE_START(SMDK4412, "SMDK4412") | |||
391 | .map_io = smdk4x12_map_io, | 390 | .map_io = smdk4x12_map_io, |
392 | .init_machine = smdk4x12_machine_init, | 391 | .init_machine = smdk4x12_machine_init, |
393 | .init_late = exynos_init_late, | 392 | .init_late = exynos_init_late, |
394 | .init_time = exynos4_timer_init, | 393 | .init_time = exynos_init_time, |
395 | .restart = exynos4_restart, | 394 | .restart = exynos4_restart, |
396 | .reserve = &smdk4x12_reserve, | 395 | .reserve = &smdk4x12_reserve, |
397 | MACHINE_END | 396 | MACHINE_END |
diff --git a/arch/arm/mach-exynos/mach-smdkv310.c b/arch/arm/mach-exynos/mach-smdkv310.c index 9680e1291065..d95b8cf85253 100644 --- a/arch/arm/mach-exynos/mach-smdkv310.c +++ b/arch/arm/mach-exynos/mach-smdkv310.c | |||
@@ -372,8 +372,9 @@ static void s5p_tv_setup(void) | |||
372 | static void __init smdkv310_map_io(void) | 372 | static void __init smdkv310_map_io(void) |
373 | { | 373 | { |
374 | exynos_init_io(NULL, 0); | 374 | exynos_init_io(NULL, 0); |
375 | s3c24xx_init_clocks(clk_xusbxti.rate); | ||
376 | s3c24xx_init_uarts(smdkv310_uartcfgs, ARRAY_SIZE(smdkv310_uartcfgs)); | 375 | s3c24xx_init_uarts(smdkv310_uartcfgs, ARRAY_SIZE(smdkv310_uartcfgs)); |
376 | xxti_f = 12000000; | ||
377 | xusbxti_f = 24000000; | ||
377 | } | 378 | } |
378 | 379 | ||
379 | static void __init smdkv310_reserve(void) | 380 | static void __init smdkv310_reserve(void) |
@@ -424,7 +425,7 @@ MACHINE_START(SMDKV310, "SMDKV310") | |||
424 | .init_irq = exynos4_init_irq, | 425 | .init_irq = exynos4_init_irq, |
425 | .map_io = smdkv310_map_io, | 426 | .map_io = smdkv310_map_io, |
426 | .init_machine = smdkv310_machine_init, | 427 | .init_machine = smdkv310_machine_init, |
427 | .init_time = exynos4_timer_init, | 428 | .init_time = exynos_init_time, |
428 | .reserve = &smdkv310_reserve, | 429 | .reserve = &smdkv310_reserve, |
429 | .restart = exynos4_restart, | 430 | .restart = exynos4_restart, |
430 | MACHINE_END | 431 | MACHINE_END |
@@ -437,7 +438,7 @@ MACHINE_START(SMDKC210, "SMDKC210") | |||
437 | .map_io = smdkv310_map_io, | 438 | .map_io = smdkv310_map_io, |
438 | .init_machine = smdkv310_machine_init, | 439 | .init_machine = smdkv310_machine_init, |
439 | .init_late = exynos_init_late, | 440 | .init_late = exynos_init_late, |
440 | .init_time = exynos4_timer_init, | 441 | .init_time = exynos_init_time, |
441 | .reserve = &smdkv310_reserve, | 442 | .reserve = &smdkv310_reserve, |
442 | .restart = exynos4_restart, | 443 | .restart = exynos4_restart, |
443 | MACHINE_END | 444 | MACHINE_END |
diff --git a/arch/arm/mach-exynos/mach-universal_c210.c b/arch/arm/mach-exynos/mach-universal_c210.c index d28c7fbaba2d..327d50d4681d 100644 --- a/arch/arm/mach-exynos/mach-universal_c210.c +++ b/arch/arm/mach-exynos/mach-universal_c210.c | |||
@@ -41,7 +41,7 @@ | |||
41 | #include <plat/mfc.h> | 41 | #include <plat/mfc.h> |
42 | #include <plat/sdhci.h> | 42 | #include <plat/sdhci.h> |
43 | #include <plat/fimc-core.h> | 43 | #include <plat/fimc-core.h> |
44 | #include <plat/s5p-time.h> | 44 | #include <plat/samsung-time.h> |
45 | #include <plat/camport.h> | 45 | #include <plat/camport.h> |
46 | 46 | ||
47 | #include <mach/map.h> | 47 | #include <mach/map.h> |
@@ -1093,9 +1093,10 @@ static struct platform_device *universal_devices[] __initdata = { | |||
1093 | static void __init universal_map_io(void) | 1093 | static void __init universal_map_io(void) |
1094 | { | 1094 | { |
1095 | exynos_init_io(NULL, 0); | 1095 | exynos_init_io(NULL, 0); |
1096 | s3c24xx_init_clocks(clk_xusbxti.rate); | ||
1097 | s3c24xx_init_uarts(universal_uartcfgs, ARRAY_SIZE(universal_uartcfgs)); | 1096 | s3c24xx_init_uarts(universal_uartcfgs, ARRAY_SIZE(universal_uartcfgs)); |
1098 | s5p_set_timer_source(S5P_PWM2, S5P_PWM4); | 1097 | samsung_set_timer_source(SAMSUNG_PWM2, SAMSUNG_PWM4); |
1098 | xxti_f = 0; | ||
1099 | xusbxti_f = 24000000; | ||
1099 | } | 1100 | } |
1100 | 1101 | ||
1101 | static void s5p_tv_setup(void) | 1102 | static void s5p_tv_setup(void) |
@@ -1153,7 +1154,7 @@ MACHINE_START(UNIVERSAL_C210, "UNIVERSAL_C210") | |||
1153 | .map_io = universal_map_io, | 1154 | .map_io = universal_map_io, |
1154 | .init_machine = universal_machine_init, | 1155 | .init_machine = universal_machine_init, |
1155 | .init_late = exynos_init_late, | 1156 | .init_late = exynos_init_late, |
1156 | .init_time = s5p_timer_init, | 1157 | .init_time = samsung_timer_init, |
1157 | .reserve = &universal_reserve, | 1158 | .reserve = &universal_reserve, |
1158 | .restart = exynos4_restart, | 1159 | .restart = exynos4_restart, |
1159 | MACHINE_END | 1160 | MACHINE_END |
diff --git a/arch/arm/mach-exynos/mct.c b/arch/arm/mach-exynos/mct.c deleted file mode 100644 index c9d6650f9b5d..000000000000 --- a/arch/arm/mach-exynos/mct.c +++ /dev/null | |||
@@ -1,485 +0,0 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/mct.c | ||
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * EXYNOS4 MCT(Multi-Core Timer) support | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #include <linux/sched.h> | ||
14 | #include <linux/interrupt.h> | ||
15 | #include <linux/irq.h> | ||
16 | #include <linux/err.h> | ||
17 | #include <linux/clk.h> | ||
18 | #include <linux/clockchips.h> | ||
19 | #include <linux/platform_device.h> | ||
20 | #include <linux/delay.h> | ||
21 | #include <linux/percpu.h> | ||
22 | #include <linux/of.h> | ||
23 | |||
24 | #include <asm/arch_timer.h> | ||
25 | #include <asm/localtimer.h> | ||
26 | |||
27 | #include <plat/cpu.h> | ||
28 | |||
29 | #include <mach/map.h> | ||
30 | #include <mach/irqs.h> | ||
31 | #include <mach/regs-mct.h> | ||
32 | #include <asm/mach/time.h> | ||
33 | |||
34 | #define TICK_BASE_CNT 1 | ||
35 | |||
36 | enum { | ||
37 | MCT_INT_SPI, | ||
38 | MCT_INT_PPI | ||
39 | }; | ||
40 | |||
41 | static unsigned long clk_rate; | ||
42 | static unsigned int mct_int_type; | ||
43 | |||
44 | struct mct_clock_event_device { | ||
45 | struct clock_event_device *evt; | ||
46 | void __iomem *base; | ||
47 | char name[10]; | ||
48 | }; | ||
49 | |||
50 | static void exynos4_mct_write(unsigned int value, void *addr) | ||
51 | { | ||
52 | void __iomem *stat_addr; | ||
53 | u32 mask; | ||
54 | u32 i; | ||
55 | |||
56 | __raw_writel(value, addr); | ||
57 | |||
58 | if (likely(addr >= EXYNOS4_MCT_L_BASE(0))) { | ||
59 | u32 base = (u32) addr & EXYNOS4_MCT_L_MASK; | ||
60 | switch ((u32) addr & ~EXYNOS4_MCT_L_MASK) { | ||
61 | case (u32) MCT_L_TCON_OFFSET: | ||
62 | stat_addr = (void __iomem *) base + MCT_L_WSTAT_OFFSET; | ||
63 | mask = 1 << 3; /* L_TCON write status */ | ||
64 | break; | ||
65 | case (u32) MCT_L_ICNTB_OFFSET: | ||
66 | stat_addr = (void __iomem *) base + MCT_L_WSTAT_OFFSET; | ||
67 | mask = 1 << 1; /* L_ICNTB write status */ | ||
68 | break; | ||
69 | case (u32) MCT_L_TCNTB_OFFSET: | ||
70 | stat_addr = (void __iomem *) base + MCT_L_WSTAT_OFFSET; | ||
71 | mask = 1 << 0; /* L_TCNTB write status */ | ||
72 | break; | ||
73 | default: | ||
74 | return; | ||
75 | } | ||
76 | } else { | ||
77 | switch ((u32) addr) { | ||
78 | case (u32) EXYNOS4_MCT_G_TCON: | ||
79 | stat_addr = EXYNOS4_MCT_G_WSTAT; | ||
80 | mask = 1 << 16; /* G_TCON write status */ | ||
81 | break; | ||
82 | case (u32) EXYNOS4_MCT_G_COMP0_L: | ||
83 | stat_addr = EXYNOS4_MCT_G_WSTAT; | ||
84 | mask = 1 << 0; /* G_COMP0_L write status */ | ||
85 | break; | ||
86 | case (u32) EXYNOS4_MCT_G_COMP0_U: | ||
87 | stat_addr = EXYNOS4_MCT_G_WSTAT; | ||
88 | mask = 1 << 1; /* G_COMP0_U write status */ | ||
89 | break; | ||
90 | case (u32) EXYNOS4_MCT_G_COMP0_ADD_INCR: | ||
91 | stat_addr = EXYNOS4_MCT_G_WSTAT; | ||
92 | mask = 1 << 2; /* G_COMP0_ADD_INCR w status */ | ||
93 | break; | ||
94 | case (u32) EXYNOS4_MCT_G_CNT_L: | ||
95 | stat_addr = EXYNOS4_MCT_G_CNT_WSTAT; | ||
96 | mask = 1 << 0; /* G_CNT_L write status */ | ||
97 | break; | ||
98 | case (u32) EXYNOS4_MCT_G_CNT_U: | ||
99 | stat_addr = EXYNOS4_MCT_G_CNT_WSTAT; | ||
100 | mask = 1 << 1; /* G_CNT_U write status */ | ||
101 | break; | ||
102 | default: | ||
103 | return; | ||
104 | } | ||
105 | } | ||
106 | |||
107 | /* Wait maximum 1 ms until written values are applied */ | ||
108 | for (i = 0; i < loops_per_jiffy / 1000 * HZ; i++) | ||
109 | if (__raw_readl(stat_addr) & mask) { | ||
110 | __raw_writel(mask, stat_addr); | ||
111 | return; | ||
112 | } | ||
113 | |||
114 | panic("MCT hangs after writing %d (addr:0x%08x)\n", value, (u32)addr); | ||
115 | } | ||
116 | |||
117 | /* Clocksource handling */ | ||
118 | static void exynos4_mct_frc_start(u32 hi, u32 lo) | ||
119 | { | ||
120 | u32 reg; | ||
121 | |||
122 | exynos4_mct_write(lo, EXYNOS4_MCT_G_CNT_L); | ||
123 | exynos4_mct_write(hi, EXYNOS4_MCT_G_CNT_U); | ||
124 | |||
125 | reg = __raw_readl(EXYNOS4_MCT_G_TCON); | ||
126 | reg |= MCT_G_TCON_START; | ||
127 | exynos4_mct_write(reg, EXYNOS4_MCT_G_TCON); | ||
128 | } | ||
129 | |||
130 | static cycle_t exynos4_frc_read(struct clocksource *cs) | ||
131 | { | ||
132 | unsigned int lo, hi; | ||
133 | u32 hi2 = __raw_readl(EXYNOS4_MCT_G_CNT_U); | ||
134 | |||
135 | do { | ||
136 | hi = hi2; | ||
137 | lo = __raw_readl(EXYNOS4_MCT_G_CNT_L); | ||
138 | hi2 = __raw_readl(EXYNOS4_MCT_G_CNT_U); | ||
139 | } while (hi != hi2); | ||
140 | |||
141 | return ((cycle_t)hi << 32) | lo; | ||
142 | } | ||
143 | |||
144 | static void exynos4_frc_resume(struct clocksource *cs) | ||
145 | { | ||
146 | exynos4_mct_frc_start(0, 0); | ||
147 | } | ||
148 | |||
149 | struct clocksource mct_frc = { | ||
150 | .name = "mct-frc", | ||
151 | .rating = 400, | ||
152 | .read = exynos4_frc_read, | ||
153 | .mask = CLOCKSOURCE_MASK(64), | ||
154 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | ||
155 | .resume = exynos4_frc_resume, | ||
156 | }; | ||
157 | |||
158 | static void __init exynos4_clocksource_init(void) | ||
159 | { | ||
160 | exynos4_mct_frc_start(0, 0); | ||
161 | |||
162 | if (clocksource_register_hz(&mct_frc, clk_rate)) | ||
163 | panic("%s: can't register clocksource\n", mct_frc.name); | ||
164 | } | ||
165 | |||
166 | static void exynos4_mct_comp0_stop(void) | ||
167 | { | ||
168 | unsigned int tcon; | ||
169 | |||
170 | tcon = __raw_readl(EXYNOS4_MCT_G_TCON); | ||
171 | tcon &= ~(MCT_G_TCON_COMP0_ENABLE | MCT_G_TCON_COMP0_AUTO_INC); | ||
172 | |||
173 | exynos4_mct_write(tcon, EXYNOS4_MCT_G_TCON); | ||
174 | exynos4_mct_write(0, EXYNOS4_MCT_G_INT_ENB); | ||
175 | } | ||
176 | |||
177 | static void exynos4_mct_comp0_start(enum clock_event_mode mode, | ||
178 | unsigned long cycles) | ||
179 | { | ||
180 | unsigned int tcon; | ||
181 | cycle_t comp_cycle; | ||
182 | |||
183 | tcon = __raw_readl(EXYNOS4_MCT_G_TCON); | ||
184 | |||
185 | if (mode == CLOCK_EVT_MODE_PERIODIC) { | ||
186 | tcon |= MCT_G_TCON_COMP0_AUTO_INC; | ||
187 | exynos4_mct_write(cycles, EXYNOS4_MCT_G_COMP0_ADD_INCR); | ||
188 | } | ||
189 | |||
190 | comp_cycle = exynos4_frc_read(&mct_frc) + cycles; | ||
191 | exynos4_mct_write((u32)comp_cycle, EXYNOS4_MCT_G_COMP0_L); | ||
192 | exynos4_mct_write((u32)(comp_cycle >> 32), EXYNOS4_MCT_G_COMP0_U); | ||
193 | |||
194 | exynos4_mct_write(0x1, EXYNOS4_MCT_G_INT_ENB); | ||
195 | |||
196 | tcon |= MCT_G_TCON_COMP0_ENABLE; | ||
197 | exynos4_mct_write(tcon , EXYNOS4_MCT_G_TCON); | ||
198 | } | ||
199 | |||
200 | static int exynos4_comp_set_next_event(unsigned long cycles, | ||
201 | struct clock_event_device *evt) | ||
202 | { | ||
203 | exynos4_mct_comp0_start(evt->mode, cycles); | ||
204 | |||
205 | return 0; | ||
206 | } | ||
207 | |||
208 | static void exynos4_comp_set_mode(enum clock_event_mode mode, | ||
209 | struct clock_event_device *evt) | ||
210 | { | ||
211 | unsigned long cycles_per_jiffy; | ||
212 | exynos4_mct_comp0_stop(); | ||
213 | |||
214 | switch (mode) { | ||
215 | case CLOCK_EVT_MODE_PERIODIC: | ||
216 | cycles_per_jiffy = | ||
217 | (((unsigned long long) NSEC_PER_SEC / HZ * evt->mult) >> evt->shift); | ||
218 | exynos4_mct_comp0_start(mode, cycles_per_jiffy); | ||
219 | break; | ||
220 | |||
221 | case CLOCK_EVT_MODE_ONESHOT: | ||
222 | case CLOCK_EVT_MODE_UNUSED: | ||
223 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
224 | case CLOCK_EVT_MODE_RESUME: | ||
225 | break; | ||
226 | } | ||
227 | } | ||
228 | |||
229 | static struct clock_event_device mct_comp_device = { | ||
230 | .name = "mct-comp", | ||
231 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, | ||
232 | .rating = 250, | ||
233 | .set_next_event = exynos4_comp_set_next_event, | ||
234 | .set_mode = exynos4_comp_set_mode, | ||
235 | }; | ||
236 | |||
237 | static irqreturn_t exynos4_mct_comp_isr(int irq, void *dev_id) | ||
238 | { | ||
239 | struct clock_event_device *evt = dev_id; | ||
240 | |||
241 | exynos4_mct_write(0x1, EXYNOS4_MCT_G_INT_CSTAT); | ||
242 | |||
243 | evt->event_handler(evt); | ||
244 | |||
245 | return IRQ_HANDLED; | ||
246 | } | ||
247 | |||
248 | static struct irqaction mct_comp_event_irq = { | ||
249 | .name = "mct_comp_irq", | ||
250 | .flags = IRQF_TIMER | IRQF_IRQPOLL, | ||
251 | .handler = exynos4_mct_comp_isr, | ||
252 | .dev_id = &mct_comp_device, | ||
253 | }; | ||
254 | |||
255 | static void exynos4_clockevent_init(void) | ||
256 | { | ||
257 | mct_comp_device.cpumask = cpumask_of(0); | ||
258 | clockevents_config_and_register(&mct_comp_device, clk_rate, | ||
259 | 0xf, 0xffffffff); | ||
260 | |||
261 | if (soc_is_exynos5250()) | ||
262 | setup_irq(EXYNOS5_IRQ_MCT_G0, &mct_comp_event_irq); | ||
263 | else | ||
264 | setup_irq(EXYNOS4_IRQ_MCT_G0, &mct_comp_event_irq); | ||
265 | } | ||
266 | |||
267 | #ifdef CONFIG_LOCAL_TIMERS | ||
268 | |||
269 | static DEFINE_PER_CPU(struct mct_clock_event_device, percpu_mct_tick); | ||
270 | |||
271 | /* Clock event handling */ | ||
272 | static void exynos4_mct_tick_stop(struct mct_clock_event_device *mevt) | ||
273 | { | ||
274 | unsigned long tmp; | ||
275 | unsigned long mask = MCT_L_TCON_INT_START | MCT_L_TCON_TIMER_START; | ||
276 | void __iomem *addr = mevt->base + MCT_L_TCON_OFFSET; | ||
277 | |||
278 | tmp = __raw_readl(addr); | ||
279 | if (tmp & mask) { | ||
280 | tmp &= ~mask; | ||
281 | exynos4_mct_write(tmp, addr); | ||
282 | } | ||
283 | } | ||
284 | |||
285 | static void exynos4_mct_tick_start(unsigned long cycles, | ||
286 | struct mct_clock_event_device *mevt) | ||
287 | { | ||
288 | unsigned long tmp; | ||
289 | |||
290 | exynos4_mct_tick_stop(mevt); | ||
291 | |||
292 | tmp = (1 << 31) | cycles; /* MCT_L_UPDATE_ICNTB */ | ||
293 | |||
294 | /* update interrupt count buffer */ | ||
295 | exynos4_mct_write(tmp, mevt->base + MCT_L_ICNTB_OFFSET); | ||
296 | |||
297 | /* enable MCT tick interrupt */ | ||
298 | exynos4_mct_write(0x1, mevt->base + MCT_L_INT_ENB_OFFSET); | ||
299 | |||
300 | tmp = __raw_readl(mevt->base + MCT_L_TCON_OFFSET); | ||
301 | tmp |= MCT_L_TCON_INT_START | MCT_L_TCON_TIMER_START | | ||
302 | MCT_L_TCON_INTERVAL_MODE; | ||
303 | exynos4_mct_write(tmp, mevt->base + MCT_L_TCON_OFFSET); | ||
304 | } | ||
305 | |||
306 | static int exynos4_tick_set_next_event(unsigned long cycles, | ||
307 | struct clock_event_device *evt) | ||
308 | { | ||
309 | struct mct_clock_event_device *mevt = this_cpu_ptr(&percpu_mct_tick); | ||
310 | |||
311 | exynos4_mct_tick_start(cycles, mevt); | ||
312 | |||
313 | return 0; | ||
314 | } | ||
315 | |||
316 | static inline void exynos4_tick_set_mode(enum clock_event_mode mode, | ||
317 | struct clock_event_device *evt) | ||
318 | { | ||
319 | struct mct_clock_event_device *mevt = this_cpu_ptr(&percpu_mct_tick); | ||
320 | unsigned long cycles_per_jiffy; | ||
321 | |||
322 | exynos4_mct_tick_stop(mevt); | ||
323 | |||
324 | switch (mode) { | ||
325 | case CLOCK_EVT_MODE_PERIODIC: | ||
326 | cycles_per_jiffy = | ||
327 | (((unsigned long long) NSEC_PER_SEC / HZ * evt->mult) >> evt->shift); | ||
328 | exynos4_mct_tick_start(cycles_per_jiffy, mevt); | ||
329 | break; | ||
330 | |||
331 | case CLOCK_EVT_MODE_ONESHOT: | ||
332 | case CLOCK_EVT_MODE_UNUSED: | ||
333 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
334 | case CLOCK_EVT_MODE_RESUME: | ||
335 | break; | ||
336 | } | ||
337 | } | ||
338 | |||
339 | static int exynos4_mct_tick_clear(struct mct_clock_event_device *mevt) | ||
340 | { | ||
341 | struct clock_event_device *evt = mevt->evt; | ||
342 | |||
343 | /* | ||
344 | * This is for supporting oneshot mode. | ||
345 | * Mct would generate interrupt periodically | ||
346 | * without explicit stopping. | ||
347 | */ | ||
348 | if (evt->mode != CLOCK_EVT_MODE_PERIODIC) | ||
349 | exynos4_mct_tick_stop(mevt); | ||
350 | |||
351 | /* Clear the MCT tick interrupt */ | ||
352 | if (__raw_readl(mevt->base + MCT_L_INT_CSTAT_OFFSET) & 1) { | ||
353 | exynos4_mct_write(0x1, mevt->base + MCT_L_INT_CSTAT_OFFSET); | ||
354 | return 1; | ||
355 | } else { | ||
356 | return 0; | ||
357 | } | ||
358 | } | ||
359 | |||
360 | static irqreturn_t exynos4_mct_tick_isr(int irq, void *dev_id) | ||
361 | { | ||
362 | struct mct_clock_event_device *mevt = dev_id; | ||
363 | struct clock_event_device *evt = mevt->evt; | ||
364 | |||
365 | exynos4_mct_tick_clear(mevt); | ||
366 | |||
367 | evt->event_handler(evt); | ||
368 | |||
369 | return IRQ_HANDLED; | ||
370 | } | ||
371 | |||
372 | static struct irqaction mct_tick0_event_irq = { | ||
373 | .name = "mct_tick0_irq", | ||
374 | .flags = IRQF_TIMER | IRQF_NOBALANCING, | ||
375 | .handler = exynos4_mct_tick_isr, | ||
376 | }; | ||
377 | |||
378 | static struct irqaction mct_tick1_event_irq = { | ||
379 | .name = "mct_tick1_irq", | ||
380 | .flags = IRQF_TIMER | IRQF_NOBALANCING, | ||
381 | .handler = exynos4_mct_tick_isr, | ||
382 | }; | ||
383 | |||
384 | static int __cpuinit exynos4_local_timer_setup(struct clock_event_device *evt) | ||
385 | { | ||
386 | struct mct_clock_event_device *mevt; | ||
387 | unsigned int cpu = smp_processor_id(); | ||
388 | int mct_lx_irq; | ||
389 | |||
390 | mevt = this_cpu_ptr(&percpu_mct_tick); | ||
391 | mevt->evt = evt; | ||
392 | |||
393 | mevt->base = EXYNOS4_MCT_L_BASE(cpu); | ||
394 | sprintf(mevt->name, "mct_tick%d", cpu); | ||
395 | |||
396 | evt->name = mevt->name; | ||
397 | evt->cpumask = cpumask_of(cpu); | ||
398 | evt->set_next_event = exynos4_tick_set_next_event; | ||
399 | evt->set_mode = exynos4_tick_set_mode; | ||
400 | evt->features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT; | ||
401 | evt->rating = 450; | ||
402 | clockevents_config_and_register(evt, clk_rate / (TICK_BASE_CNT + 1), | ||
403 | 0xf, 0x7fffffff); | ||
404 | |||
405 | exynos4_mct_write(TICK_BASE_CNT, mevt->base + MCT_L_TCNTB_OFFSET); | ||
406 | |||
407 | if (mct_int_type == MCT_INT_SPI) { | ||
408 | if (cpu == 0) { | ||
409 | mct_lx_irq = soc_is_exynos4210() ? EXYNOS4_IRQ_MCT_L0 : | ||
410 | EXYNOS5_IRQ_MCT_L0; | ||
411 | mct_tick0_event_irq.dev_id = mevt; | ||
412 | evt->irq = mct_lx_irq; | ||
413 | setup_irq(mct_lx_irq, &mct_tick0_event_irq); | ||
414 | } else { | ||
415 | mct_lx_irq = soc_is_exynos4210() ? EXYNOS4_IRQ_MCT_L1 : | ||
416 | EXYNOS5_IRQ_MCT_L1; | ||
417 | mct_tick1_event_irq.dev_id = mevt; | ||
418 | evt->irq = mct_lx_irq; | ||
419 | setup_irq(mct_lx_irq, &mct_tick1_event_irq); | ||
420 | irq_set_affinity(mct_lx_irq, cpumask_of(1)); | ||
421 | } | ||
422 | } else { | ||
423 | enable_percpu_irq(EXYNOS_IRQ_MCT_LOCALTIMER, 0); | ||
424 | } | ||
425 | |||
426 | return 0; | ||
427 | } | ||
428 | |||
429 | static void exynos4_local_timer_stop(struct clock_event_device *evt) | ||
430 | { | ||
431 | unsigned int cpu = smp_processor_id(); | ||
432 | evt->set_mode(CLOCK_EVT_MODE_UNUSED, evt); | ||
433 | if (mct_int_type == MCT_INT_SPI) | ||
434 | if (cpu == 0) | ||
435 | remove_irq(evt->irq, &mct_tick0_event_irq); | ||
436 | else | ||
437 | remove_irq(evt->irq, &mct_tick1_event_irq); | ||
438 | else | ||
439 | disable_percpu_irq(EXYNOS_IRQ_MCT_LOCALTIMER); | ||
440 | } | ||
441 | |||
442 | static struct local_timer_ops exynos4_mct_tick_ops __cpuinitdata = { | ||
443 | .setup = exynos4_local_timer_setup, | ||
444 | .stop = exynos4_local_timer_stop, | ||
445 | }; | ||
446 | #endif /* CONFIG_LOCAL_TIMERS */ | ||
447 | |||
448 | static void __init exynos4_timer_resources(void) | ||
449 | { | ||
450 | struct clk *mct_clk; | ||
451 | mct_clk = clk_get(NULL, "xtal"); | ||
452 | |||
453 | clk_rate = clk_get_rate(mct_clk); | ||
454 | |||
455 | #ifdef CONFIG_LOCAL_TIMERS | ||
456 | if (mct_int_type == MCT_INT_PPI) { | ||
457 | int err; | ||
458 | |||
459 | err = request_percpu_irq(EXYNOS_IRQ_MCT_LOCALTIMER, | ||
460 | exynos4_mct_tick_isr, "MCT", | ||
461 | &percpu_mct_tick); | ||
462 | WARN(err, "MCT: can't request IRQ %d (%d)\n", | ||
463 | EXYNOS_IRQ_MCT_LOCALTIMER, err); | ||
464 | } | ||
465 | |||
466 | local_timer_register(&exynos4_mct_tick_ops); | ||
467 | #endif /* CONFIG_LOCAL_TIMERS */ | ||
468 | } | ||
469 | |||
470 | void __init exynos4_timer_init(void) | ||
471 | { | ||
472 | if (soc_is_exynos5440()) { | ||
473 | arch_timer_of_register(); | ||
474 | return; | ||
475 | } | ||
476 | |||
477 | if ((soc_is_exynos4210()) || (soc_is_exynos5250())) | ||
478 | mct_int_type = MCT_INT_SPI; | ||
479 | else | ||
480 | mct_int_type = MCT_INT_PPI; | ||
481 | |||
482 | exynos4_timer_resources(); | ||
483 | exynos4_clocksource_init(); | ||
484 | exynos4_clockevent_init(); | ||
485 | } | ||
diff --git a/arch/arm/mach-omap2/board-3430sdp.c b/arch/arm/mach-omap2/board-3430sdp.c index 2612eeaa5889..a4d4664894e1 100644 --- a/arch/arm/mach-omap2/board-3430sdp.c +++ b/arch/arm/mach-omap2/board-3430sdp.c | |||
@@ -445,16 +445,23 @@ static void enable_board_wakeup_source(void) | |||
445 | OMAP_WAKEUP_EN | OMAP_PIN_INPUT_PULLUP); | 445 | OMAP_WAKEUP_EN | OMAP_PIN_INPUT_PULLUP); |
446 | } | 446 | } |
447 | 447 | ||
448 | static struct usbhs_phy_data phy_data[] __initdata = { | ||
449 | { | ||
450 | .port = 1, | ||
451 | .reset_gpio = 57, | ||
452 | .vcc_gpio = -EINVAL, | ||
453 | }, | ||
454 | { | ||
455 | .port = 2, | ||
456 | .reset_gpio = 61, | ||
457 | .vcc_gpio = -EINVAL, | ||
458 | }, | ||
459 | }; | ||
460 | |||
448 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { | 461 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { |
449 | 462 | ||
450 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, | 463 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, |
451 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, | 464 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, |
452 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
453 | |||
454 | .phy_reset = true, | ||
455 | .reset_gpio_port[0] = 57, | ||
456 | .reset_gpio_port[1] = 61, | ||
457 | .reset_gpio_port[2] = -EINVAL | ||
458 | }; | 465 | }; |
459 | 466 | ||
460 | #ifdef CONFIG_OMAP_MUX | 467 | #ifdef CONFIG_OMAP_MUX |
@@ -606,6 +613,8 @@ static void __init omap_3430sdp_init(void) | |||
606 | board_flash_init(sdp_flash_partitions, chip_sel_3430, 0); | 613 | board_flash_init(sdp_flash_partitions, chip_sel_3430, 0); |
607 | sdp3430_display_init(); | 614 | sdp3430_display_init(); |
608 | enable_board_wakeup_source(); | 615 | enable_board_wakeup_source(); |
616 | |||
617 | usbhs_init_phys(phy_data, ARRAY_SIZE(phy_data)); | ||
609 | usbhs_init(&usbhs_bdata); | 618 | usbhs_init(&usbhs_bdata); |
610 | } | 619 | } |
611 | 620 | ||
diff --git a/arch/arm/mach-omap2/board-3630sdp.c b/arch/arm/mach-omap2/board-3630sdp.c index 67447bd4564f..20d6d8189240 100644 --- a/arch/arm/mach-omap2/board-3630sdp.c +++ b/arch/arm/mach-omap2/board-3630sdp.c | |||
@@ -53,16 +53,23 @@ static void enable_board_wakeup_source(void) | |||
53 | OMAP_WAKEUP_EN | OMAP_PIN_INPUT_PULLUP); | 53 | OMAP_WAKEUP_EN | OMAP_PIN_INPUT_PULLUP); |
54 | } | 54 | } |
55 | 55 | ||
56 | static struct usbhs_phy_data phy_data[] __initdata = { | ||
57 | { | ||
58 | .port = 1, | ||
59 | .reset_gpio = 126, | ||
60 | .vcc_gpio = -EINVAL, | ||
61 | }, | ||
62 | { | ||
63 | .port = 2, | ||
64 | .reset_gpio = 61, | ||
65 | .vcc_gpio = -EINVAL, | ||
66 | }, | ||
67 | }; | ||
68 | |||
56 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { | 69 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { |
57 | 70 | ||
58 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, | 71 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, |
59 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, | 72 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, |
60 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
61 | |||
62 | .phy_reset = true, | ||
63 | .reset_gpio_port[0] = 126, | ||
64 | .reset_gpio_port[1] = 61, | ||
65 | .reset_gpio_port[2] = -EINVAL | ||
66 | }; | 73 | }; |
67 | 74 | ||
68 | #ifdef CONFIG_OMAP_MUX | 75 | #ifdef CONFIG_OMAP_MUX |
@@ -199,6 +206,8 @@ static void __init omap_sdp_init(void) | |||
199 | board_smc91x_init(); | 206 | board_smc91x_init(); |
200 | board_flash_init(sdp_flash_partitions, chip_sel_sdp, NAND_BUSWIDTH_16); | 207 | board_flash_init(sdp_flash_partitions, chip_sel_sdp, NAND_BUSWIDTH_16); |
201 | enable_board_wakeup_source(); | 208 | enable_board_wakeup_source(); |
209 | |||
210 | usbhs_init_phys(phy_data, ARRAY_SIZE(phy_data)); | ||
202 | usbhs_init(&usbhs_bdata); | 211 | usbhs_init(&usbhs_bdata); |
203 | } | 212 | } |
204 | 213 | ||
diff --git a/arch/arm/mach-omap2/board-am3517crane.c b/arch/arm/mach-omap2/board-am3517crane.c index 7d3358b2e593..fc53911d0d13 100644 --- a/arch/arm/mach-omap2/board-am3517crane.c +++ b/arch/arm/mach-omap2/board-am3517crane.c | |||
@@ -47,15 +47,17 @@ static struct omap_board_mux board_mux[] __initdata = { | |||
47 | }; | 47 | }; |
48 | #endif | 48 | #endif |
49 | 49 | ||
50 | static struct usbhs_phy_data phy_data[] __initdata = { | ||
51 | { | ||
52 | .port = 1, | ||
53 | .reset_gpio = GPIO_USB_NRESET, | ||
54 | .vcc_gpio = GPIO_USB_POWER, | ||
55 | .vcc_polarity = 1, | ||
56 | }, | ||
57 | }; | ||
58 | |||
50 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { | 59 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { |
51 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, | 60 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, |
52 | .port_mode[1] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
53 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
54 | |||
55 | .phy_reset = true, | ||
56 | .reset_gpio_port[0] = GPIO_USB_NRESET, | ||
57 | .reset_gpio_port[1] = -EINVAL, | ||
58 | .reset_gpio_port[2] = -EINVAL | ||
59 | }; | 61 | }; |
60 | 62 | ||
61 | static struct mtd_partition crane_nand_partitions[] = { | 63 | static struct mtd_partition crane_nand_partitions[] = { |
@@ -131,13 +133,7 @@ static void __init am3517_crane_init(void) | |||
131 | return; | 133 | return; |
132 | } | 134 | } |
133 | 135 | ||
134 | ret = gpio_request_one(GPIO_USB_POWER, GPIOF_OUT_INIT_HIGH, | 136 | usbhs_init_phys(phy_data, ARRAY_SIZE(phy_data)); |
135 | "usb_ehci_enable"); | ||
136 | if (ret < 0) { | ||
137 | pr_err("Can not request GPIO %d\n", GPIO_USB_POWER); | ||
138 | return; | ||
139 | } | ||
140 | |||
141 | usbhs_init(&usbhs_bdata); | 137 | usbhs_init(&usbhs_bdata); |
142 | am35xx_emac_init(AM35XX_DEFAULT_MDIO_FREQUENCY, 1); | 138 | am35xx_emac_init(AM35XX_DEFAULT_MDIO_FREQUENCY, 1); |
143 | } | 139 | } |
diff --git a/arch/arm/mach-omap2/board-am3517evm.c b/arch/arm/mach-omap2/board-am3517evm.c index 1d6c28872505..c29d2e743688 100644 --- a/arch/arm/mach-omap2/board-am3517evm.c +++ b/arch/arm/mach-omap2/board-am3517evm.c | |||
@@ -273,6 +273,14 @@ static __init void am3517_evm_mcbsp1_init(void) | |||
273 | omap_ctrl_writel(devconf0, OMAP2_CONTROL_DEVCONF0); | 273 | omap_ctrl_writel(devconf0, OMAP2_CONTROL_DEVCONF0); |
274 | } | 274 | } |
275 | 275 | ||
276 | static struct usbhs_phy_data phy_data[] __initdata = { | ||
277 | { | ||
278 | .port = 1, | ||
279 | .reset_gpio = 57, | ||
280 | .vcc_gpio = -EINVAL, | ||
281 | }, | ||
282 | }; | ||
283 | |||
276 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { | 284 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { |
277 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, | 285 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, |
278 | #if defined(CONFIG_PANEL_SHARP_LQ043T1DG01) || \ | 286 | #if defined(CONFIG_PANEL_SHARP_LQ043T1DG01) || \ |
@@ -281,12 +289,6 @@ static struct usbhs_omap_platform_data usbhs_bdata __initdata = { | |||
281 | #else | 289 | #else |
282 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, | 290 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, |
283 | #endif | 291 | #endif |
284 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
285 | |||
286 | .phy_reset = true, | ||
287 | .reset_gpio_port[0] = 57, | ||
288 | .reset_gpio_port[1] = -EINVAL, | ||
289 | .reset_gpio_port[2] = -EINVAL | ||
290 | }; | 292 | }; |
291 | 293 | ||
292 | #ifdef CONFIG_OMAP_MUX | 294 | #ifdef CONFIG_OMAP_MUX |
@@ -348,7 +350,6 @@ static struct omap2_hsmmc_info mmc[] = { | |||
348 | {} /* Terminator */ | 350 | {} /* Terminator */ |
349 | }; | 351 | }; |
350 | 352 | ||
351 | |||
352 | static void __init am3517_evm_init(void) | 353 | static void __init am3517_evm_init(void) |
353 | { | 354 | { |
354 | omap3_mux_init(board_mux, OMAP_PACKAGE_CBB); | 355 | omap3_mux_init(board_mux, OMAP_PACKAGE_CBB); |
@@ -360,6 +361,8 @@ static void __init am3517_evm_init(void) | |||
360 | 361 | ||
361 | /* Configure GPIO for EHCI port */ | 362 | /* Configure GPIO for EHCI port */ |
362 | omap_mux_init_gpio(57, OMAP_PIN_OUTPUT); | 363 | omap_mux_init_gpio(57, OMAP_PIN_OUTPUT); |
364 | |||
365 | usbhs_init_phys(phy_data, ARRAY_SIZE(phy_data)); | ||
363 | usbhs_init(&usbhs_bdata); | 366 | usbhs_init(&usbhs_bdata); |
364 | am3517_evm_hecc_init(&am3517_evm_hecc_pdata); | 367 | am3517_evm_hecc_init(&am3517_evm_hecc_pdata); |
365 | /* DSS */ | 368 | /* DSS */ |
diff --git a/arch/arm/mach-omap2/board-cm-t35.c b/arch/arm/mach-omap2/board-cm-t35.c index bccd3e51fecb..e0ed8c07fc54 100644 --- a/arch/arm/mach-omap2/board-cm-t35.c +++ b/arch/arm/mach-omap2/board-cm-t35.c | |||
@@ -418,15 +418,22 @@ static struct omap2_hsmmc_info mmc[] = { | |||
418 | {} /* Terminator */ | 418 | {} /* Terminator */ |
419 | }; | 419 | }; |
420 | 420 | ||
421 | static struct usbhs_phy_data phy_data[] __initdata = { | ||
422 | { | ||
423 | .port = 1, | ||
424 | .reset_gpio = OMAP_MAX_GPIO_LINES + 6, | ||
425 | .vcc_gpio = -EINVAL, | ||
426 | }, | ||
427 | { | ||
428 | .port = 2, | ||
429 | .reset_gpio = OMAP_MAX_GPIO_LINES + 7, | ||
430 | .vcc_gpio = -EINVAL, | ||
431 | }, | ||
432 | }; | ||
433 | |||
421 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { | 434 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { |
422 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, | 435 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, |
423 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, | 436 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, |
424 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
425 | |||
426 | .phy_reset = true, | ||
427 | .reset_gpio_port[0] = OMAP_MAX_GPIO_LINES + 6, | ||
428 | .reset_gpio_port[1] = OMAP_MAX_GPIO_LINES + 7, | ||
429 | .reset_gpio_port[2] = -EINVAL | ||
430 | }; | 437 | }; |
431 | 438 | ||
432 | static void __init cm_t35_init_usbh(void) | 439 | static void __init cm_t35_init_usbh(void) |
@@ -443,6 +450,7 @@ static void __init cm_t35_init_usbh(void) | |||
443 | msleep(1); | 450 | msleep(1); |
444 | } | 451 | } |
445 | 452 | ||
453 | usbhs_init_phys(phy_data, ARRAY_SIZE(phy_data)); | ||
446 | usbhs_init(&usbhs_bdata); | 454 | usbhs_init(&usbhs_bdata); |
447 | } | 455 | } |
448 | 456 | ||
diff --git a/arch/arm/mach-omap2/board-cm-t3517.c b/arch/arm/mach-omap2/board-cm-t3517.c index a66da808cc4a..4eb5e6f2f7f5 100644 --- a/arch/arm/mach-omap2/board-cm-t3517.c +++ b/arch/arm/mach-omap2/board-cm-t3517.c | |||
@@ -188,15 +188,22 @@ static inline void cm_t3517_init_rtc(void) {} | |||
188 | #define HSUSB2_RESET_GPIO (147) | 188 | #define HSUSB2_RESET_GPIO (147) |
189 | #define USB_HUB_RESET_GPIO (152) | 189 | #define USB_HUB_RESET_GPIO (152) |
190 | 190 | ||
191 | static struct usbhs_phy_data phy_data[] __initdata = { | ||
192 | { | ||
193 | .port = 1, | ||
194 | .reset_gpio = HSUSB1_RESET_GPIO, | ||
195 | .vcc_gpio = -EINVAL, | ||
196 | }, | ||
197 | { | ||
198 | .port = 2, | ||
199 | .reset_gpio = HSUSB2_RESET_GPIO, | ||
200 | .vcc_gpio = -EINVAL, | ||
201 | }, | ||
202 | }; | ||
203 | |||
191 | static struct usbhs_omap_platform_data cm_t3517_ehci_pdata __initdata = { | 204 | static struct usbhs_omap_platform_data cm_t3517_ehci_pdata __initdata = { |
192 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, | 205 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, |
193 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, | 206 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, |
194 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
195 | |||
196 | .phy_reset = true, | ||
197 | .reset_gpio_port[0] = HSUSB1_RESET_GPIO, | ||
198 | .reset_gpio_port[1] = HSUSB2_RESET_GPIO, | ||
199 | .reset_gpio_port[2] = -EINVAL, | ||
200 | }; | 207 | }; |
201 | 208 | ||
202 | static int __init cm_t3517_init_usbh(void) | 209 | static int __init cm_t3517_init_usbh(void) |
@@ -213,6 +220,7 @@ static int __init cm_t3517_init_usbh(void) | |||
213 | msleep(1); | 220 | msleep(1); |
214 | } | 221 | } |
215 | 222 | ||
223 | usbhs_init_phys(phy_data, ARRAY_SIZE(phy_data)); | ||
216 | usbhs_init(&cm_t3517_ehci_pdata); | 224 | usbhs_init(&cm_t3517_ehci_pdata); |
217 | 225 | ||
218 | return 0; | 226 | return 0; |
@@ -324,6 +332,6 @@ MACHINE_START(CM_T3517, "Compulab CM-T3517") | |||
324 | .handle_irq = omap3_intc_handle_irq, | 332 | .handle_irq = omap3_intc_handle_irq, |
325 | .init_machine = cm_t3517_init, | 333 | .init_machine = cm_t3517_init, |
326 | .init_late = am35xx_init_late, | 334 | .init_late = am35xx_init_late, |
327 | .init_time = omap3_gp_gptimer_timer_init, | 335 | .init_time = omap3_gptimer_timer_init, |
328 | .restart = omap3xxx_restart, | 336 | .restart = omap3xxx_restart, |
329 | MACHINE_END | 337 | MACHINE_END |
diff --git a/arch/arm/mach-omap2/board-devkit8000.c b/arch/arm/mach-omap2/board-devkit8000.c index 12d2126a2382..e44b804f75ae 100644 --- a/arch/arm/mach-omap2/board-devkit8000.c +++ b/arch/arm/mach-omap2/board-devkit8000.c | |||
@@ -436,15 +436,7 @@ static struct platform_device *devkit8000_devices[] __initdata = { | |||
436 | }; | 436 | }; |
437 | 437 | ||
438 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { | 438 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { |
439 | |||
440 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, | 439 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, |
441 | .port_mode[1] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
442 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
443 | |||
444 | .phy_reset = true, | ||
445 | .reset_gpio_port[0] = -EINVAL, | ||
446 | .reset_gpio_port[1] = -EINVAL, | ||
447 | .reset_gpio_port[2] = -EINVAL | ||
448 | }; | 440 | }; |
449 | 441 | ||
450 | #ifdef CONFIG_OMAP_MUX | 442 | #ifdef CONFIG_OMAP_MUX |
diff --git a/arch/arm/mach-omap2/board-generic.c b/arch/arm/mach-omap2/board-generic.c index e54a48060198..78813b397209 100644 --- a/arch/arm/mach-omap2/board-generic.c +++ b/arch/arm/mach-omap2/board-generic.c | |||
@@ -140,7 +140,7 @@ DT_MACHINE_START(AM33XX_DT, "Generic AM33XX (Flattened Device Tree)") | |||
140 | .init_irq = omap_intc_of_init, | 140 | .init_irq = omap_intc_of_init, |
141 | .handle_irq = omap3_intc_handle_irq, | 141 | .handle_irq = omap3_intc_handle_irq, |
142 | .init_machine = omap_generic_init, | 142 | .init_machine = omap_generic_init, |
143 | .init_time = omap3_am33xx_gptimer_timer_init, | 143 | .init_time = omap3_gptimer_timer_init, |
144 | .dt_compat = am33xx_boards_compat, | 144 | .dt_compat = am33xx_boards_compat, |
145 | .restart = am33xx_restart, | 145 | .restart = am33xx_restart, |
146 | MACHINE_END | 146 | MACHINE_END |
diff --git a/arch/arm/mach-omap2/board-igep0020.c b/arch/arm/mach-omap2/board-igep0020.c index e979d48270c9..b54562d1235e 100644 --- a/arch/arm/mach-omap2/board-igep0020.c +++ b/arch/arm/mach-omap2/board-igep0020.c | |||
@@ -527,26 +527,28 @@ static void __init igep_i2c_init(void) | |||
527 | omap3_pmic_init("twl4030", &igep_twldata); | 527 | omap3_pmic_init("twl4030", &igep_twldata); |
528 | } | 528 | } |
529 | 529 | ||
530 | static struct usbhs_phy_data igep2_phy_data[] __initdata = { | ||
531 | { | ||
532 | .port = 1, | ||
533 | .reset_gpio = IGEP2_GPIO_USBH_NRESET, | ||
534 | .vcc_gpio = -EINVAL, | ||
535 | }, | ||
536 | }; | ||
537 | |||
538 | static struct usbhs_phy_data igep3_phy_data[] __initdata = { | ||
539 | { | ||
540 | .port = 2, | ||
541 | .reset_gpio = IGEP3_GPIO_USBH_NRESET, | ||
542 | .vcc_gpio = -EINVAL, | ||
543 | }, | ||
544 | }; | ||
545 | |||
530 | static struct usbhs_omap_platform_data igep2_usbhs_bdata __initdata = { | 546 | static struct usbhs_omap_platform_data igep2_usbhs_bdata __initdata = { |
531 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, | 547 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, |
532 | .port_mode[1] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
533 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
534 | |||
535 | .phy_reset = true, | ||
536 | .reset_gpio_port[0] = IGEP2_GPIO_USBH_NRESET, | ||
537 | .reset_gpio_port[1] = -EINVAL, | ||
538 | .reset_gpio_port[2] = -EINVAL, | ||
539 | }; | 548 | }; |
540 | 549 | ||
541 | static struct usbhs_omap_platform_data igep3_usbhs_bdata __initdata = { | 550 | static struct usbhs_omap_platform_data igep3_usbhs_bdata __initdata = { |
542 | .port_mode[0] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
543 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, | 551 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, |
544 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
545 | |||
546 | .phy_reset = true, | ||
547 | .reset_gpio_port[0] = -EINVAL, | ||
548 | .reset_gpio_port[1] = IGEP3_GPIO_USBH_NRESET, | ||
549 | .reset_gpio_port[2] = -EINVAL, | ||
550 | }; | 552 | }; |
551 | 553 | ||
552 | #ifdef CONFIG_OMAP_MUX | 554 | #ifdef CONFIG_OMAP_MUX |
@@ -642,8 +644,10 @@ static void __init igep_init(void) | |||
642 | if (machine_is_igep0020()) { | 644 | if (machine_is_igep0020()) { |
643 | omap_display_init(&igep2_dss_data); | 645 | omap_display_init(&igep2_dss_data); |
644 | igep2_init_smsc911x(); | 646 | igep2_init_smsc911x(); |
647 | usbhs_init_phys(igep2_phy_data, ARRAY_SIZE(igep2_phy_data)); | ||
645 | usbhs_init(&igep2_usbhs_bdata); | 648 | usbhs_init(&igep2_usbhs_bdata); |
646 | } else { | 649 | } else { |
650 | usbhs_init_phys(igep3_phy_data, ARRAY_SIZE(igep3_phy_data)); | ||
647 | usbhs_init(&igep3_usbhs_bdata); | 651 | usbhs_init(&igep3_usbhs_bdata); |
648 | } | 652 | } |
649 | } | 653 | } |
diff --git a/arch/arm/mach-omap2/board-omap3beagle.c b/arch/arm/mach-omap2/board-omap3beagle.c index fff141330a63..6de78605c0af 100644 --- a/arch/arm/mach-omap2/board-omap3beagle.c +++ b/arch/arm/mach-omap2/board-omap3beagle.c | |||
@@ -33,6 +33,7 @@ | |||
33 | #include <linux/mtd/nand.h> | 33 | #include <linux/mtd/nand.h> |
34 | #include <linux/mmc/host.h> | 34 | #include <linux/mmc/host.h> |
35 | #include <linux/usb/phy.h> | 35 | #include <linux/usb/phy.h> |
36 | #include <linux/usb/nop-usb-xceiv.h> | ||
36 | 37 | ||
37 | #include <linux/regulator/machine.h> | 38 | #include <linux/regulator/machine.h> |
38 | #include <linux/i2c/twl.h> | 39 | #include <linux/i2c/twl.h> |
@@ -277,6 +278,21 @@ static struct regulator_consumer_supply beagle_vsim_supply[] = { | |||
277 | 278 | ||
278 | static struct gpio_led gpio_leds[]; | 279 | static struct gpio_led gpio_leds[]; |
279 | 280 | ||
281 | /* PHY's VCC regulator might be added later, so flag that we need it */ | ||
282 | static struct nop_usb_xceiv_platform_data hsusb2_phy_data = { | ||
283 | .needs_vcc = true, | ||
284 | }; | ||
285 | |||
286 | static struct usbhs_phy_data phy_data[] = { | ||
287 | { | ||
288 | .port = 2, | ||
289 | .reset_gpio = 147, | ||
290 | .vcc_gpio = -1, /* updated in beagle_twl_gpio_setup */ | ||
291 | .vcc_polarity = 1, /* updated in beagle_twl_gpio_setup */ | ||
292 | .platform_data = &hsusb2_phy_data, | ||
293 | }, | ||
294 | }; | ||
295 | |||
280 | static int beagle_twl_gpio_setup(struct device *dev, | 296 | static int beagle_twl_gpio_setup(struct device *dev, |
281 | unsigned gpio, unsigned ngpio) | 297 | unsigned gpio, unsigned ngpio) |
282 | { | 298 | { |
@@ -318,9 +334,11 @@ static int beagle_twl_gpio_setup(struct device *dev, | |||
318 | } | 334 | } |
319 | dvi_panel.power_down_gpio = beagle_config.dvi_pd_gpio; | 335 | dvi_panel.power_down_gpio = beagle_config.dvi_pd_gpio; |
320 | 336 | ||
321 | gpio_request_one(gpio + TWL4030_GPIO_MAX, beagle_config.usb_pwr_level, | 337 | /* TWL4030_GPIO_MAX i.e. LED_GPO controls HS USB Port 2 power */ |
322 | "nEN_USB_PWR"); | 338 | phy_data[0].vcc_gpio = gpio + TWL4030_GPIO_MAX; |
339 | phy_data[0].vcc_polarity = beagle_config.usb_pwr_level; | ||
323 | 340 | ||
341 | usbhs_init_phys(phy_data, ARRAY_SIZE(phy_data)); | ||
324 | return 0; | 342 | return 0; |
325 | } | 343 | } |
326 | 344 | ||
@@ -453,15 +471,7 @@ static struct platform_device *omap3_beagle_devices[] __initdata = { | |||
453 | }; | 471 | }; |
454 | 472 | ||
455 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { | 473 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { |
456 | |||
457 | .port_mode[0] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
458 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, | 474 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, |
459 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
460 | |||
461 | .phy_reset = true, | ||
462 | .reset_gpio_port[0] = -EINVAL, | ||
463 | .reset_gpio_port[1] = 147, | ||
464 | .reset_gpio_port[2] = -EINVAL | ||
465 | }; | 475 | }; |
466 | 476 | ||
467 | #ifdef CONFIG_OMAP_MUX | 477 | #ifdef CONFIG_OMAP_MUX |
@@ -543,7 +553,9 @@ static void __init omap3_beagle_init(void) | |||
543 | 553 | ||
544 | usb_bind_phy("musb-hdrc.0.auto", 0, "twl4030_usb"); | 554 | usb_bind_phy("musb-hdrc.0.auto", 0, "twl4030_usb"); |
545 | usb_musb_init(NULL); | 555 | usb_musb_init(NULL); |
556 | |||
546 | usbhs_init(&usbhs_bdata); | 557 | usbhs_init(&usbhs_bdata); |
558 | |||
547 | board_nand_init(omap3beagle_nand_partitions, | 559 | board_nand_init(omap3beagle_nand_partitions, |
548 | ARRAY_SIZE(omap3beagle_nand_partitions), NAND_CS, | 560 | ARRAY_SIZE(omap3beagle_nand_partitions), NAND_CS, |
549 | NAND_BUSWIDTH_16, NULL); | 561 | NAND_BUSWIDTH_16, NULL); |
diff --git a/arch/arm/mach-omap2/board-omap3evm.c b/arch/arm/mach-omap2/board-omap3evm.c index 233a0d528fcf..4f1bbc3cc29b 100644 --- a/arch/arm/mach-omap2/board-omap3evm.c +++ b/arch/arm/mach-omap2/board-omap3evm.c | |||
@@ -496,7 +496,7 @@ struct wl12xx_platform_data omap3evm_wlan_data __initdata = { | |||
496 | static struct regulator_consumer_supply omap3evm_vaux2_supplies[] = { | 496 | static struct regulator_consumer_supply omap3evm_vaux2_supplies[] = { |
497 | REGULATOR_SUPPLY("VDD_CSIPHY1", "omap3isp"), /* OMAP ISP */ | 497 | REGULATOR_SUPPLY("VDD_CSIPHY1", "omap3isp"), /* OMAP ISP */ |
498 | REGULATOR_SUPPLY("VDD_CSIPHY2", "omap3isp"), /* OMAP ISP */ | 498 | REGULATOR_SUPPLY("VDD_CSIPHY2", "omap3isp"), /* OMAP ISP */ |
499 | REGULATOR_SUPPLY("hsusb1", "ehci-omap.0"), | 499 | REGULATOR_SUPPLY("vcc", "nop_usb_xceiv.2"), /* hsusb port 2 */ |
500 | REGULATOR_SUPPLY("vaux2", NULL), | 500 | REGULATOR_SUPPLY("vaux2", NULL), |
501 | }; | 501 | }; |
502 | 502 | ||
@@ -539,17 +539,16 @@ static int __init omap3_evm_i2c_init(void) | |||
539 | return 0; | 539 | return 0; |
540 | } | 540 | } |
541 | 541 | ||
542 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { | 542 | static struct usbhs_phy_data phy_data[] __initdata = { |
543 | { | ||
544 | .port = 2, | ||
545 | .reset_gpio = -1, /* set at runtime */ | ||
546 | .vcc_gpio = -EINVAL, | ||
547 | }, | ||
548 | }; | ||
543 | 549 | ||
544 | .port_mode[0] = OMAP_USBHS_PORT_MODE_UNUSED, | 550 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { |
545 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, | 551 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, |
546 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
547 | |||
548 | .phy_reset = true, | ||
549 | /* PHY reset GPIO will be runtime programmed based on EVM version */ | ||
550 | .reset_gpio_port[0] = -EINVAL, | ||
551 | .reset_gpio_port[1] = -EINVAL, | ||
552 | .reset_gpio_port[2] = -EINVAL | ||
553 | }; | 552 | }; |
554 | 553 | ||
555 | #ifdef CONFIG_OMAP_MUX | 554 | #ifdef CONFIG_OMAP_MUX |
@@ -725,7 +724,7 @@ static void __init omap3_evm_init(void) | |||
725 | 724 | ||
726 | /* setup EHCI phy reset config */ | 725 | /* setup EHCI phy reset config */ |
727 | omap_mux_init_gpio(21, OMAP_PIN_INPUT_PULLUP); | 726 | omap_mux_init_gpio(21, OMAP_PIN_INPUT_PULLUP); |
728 | usbhs_bdata.reset_gpio_port[1] = 21; | 727 | phy_data[0].reset_gpio = 21; |
729 | 728 | ||
730 | /* EVM REV >= E can supply 500mA with EXTVBUS programming */ | 729 | /* EVM REV >= E can supply 500mA with EXTVBUS programming */ |
731 | musb_board_data.power = 500; | 730 | musb_board_data.power = 500; |
@@ -733,10 +732,12 @@ static void __init omap3_evm_init(void) | |||
733 | } else { | 732 | } else { |
734 | /* setup EHCI phy reset on MDC */ | 733 | /* setup EHCI phy reset on MDC */ |
735 | omap_mux_init_gpio(135, OMAP_PIN_OUTPUT); | 734 | omap_mux_init_gpio(135, OMAP_PIN_OUTPUT); |
736 | usbhs_bdata.reset_gpio_port[1] = 135; | 735 | phy_data[0].reset_gpio = 135; |
737 | } | 736 | } |
738 | usb_bind_phy("musb-hdrc.0.auto", 0, "twl4030_usb"); | 737 | usb_bind_phy("musb-hdrc.0.auto", 0, "twl4030_usb"); |
739 | usb_musb_init(&musb_board_data); | 738 | usb_musb_init(&musb_board_data); |
739 | |||
740 | usbhs_init_phys(phy_data, ARRAY_SIZE(phy_data)); | ||
740 | usbhs_init(&usbhs_bdata); | 741 | usbhs_init(&usbhs_bdata); |
741 | board_nand_init(omap3evm_nand_partitions, | 742 | board_nand_init(omap3evm_nand_partitions, |
742 | ARRAY_SIZE(omap3evm_nand_partitions), NAND_CS, | 743 | ARRAY_SIZE(omap3evm_nand_partitions), NAND_CS, |
diff --git a/arch/arm/mach-omap2/board-omap3pandora.c b/arch/arm/mach-omap2/board-omap3pandora.c index 2bba362148a0..1004d2aaa68f 100644 --- a/arch/arm/mach-omap2/board-omap3pandora.c +++ b/arch/arm/mach-omap2/board-omap3pandora.c | |||
@@ -346,7 +346,7 @@ static struct regulator_consumer_supply pandora_vcc_lcd_supply[] = { | |||
346 | }; | 346 | }; |
347 | 347 | ||
348 | static struct regulator_consumer_supply pandora_usb_phy_supply[] = { | 348 | static struct regulator_consumer_supply pandora_usb_phy_supply[] = { |
349 | REGULATOR_SUPPLY("hsusb1", "ehci-omap.0"), | 349 | REGULATOR_SUPPLY("vcc", "nop_usb_xceiv.2"), /* hsusb port 2 */ |
350 | }; | 350 | }; |
351 | 351 | ||
352 | /* ads7846 on SPI and 2 nub controllers on I2C */ | 352 | /* ads7846 on SPI and 2 nub controllers on I2C */ |
@@ -561,6 +561,14 @@ fail: | |||
561 | printk(KERN_ERR "wl1251 board initialisation failed\n"); | 561 | printk(KERN_ERR "wl1251 board initialisation failed\n"); |
562 | } | 562 | } |
563 | 563 | ||
564 | static struct usbhs_phy_data phy_data[] __initdata = { | ||
565 | { | ||
566 | .port = 2, | ||
567 | .reset_gpio = 16, | ||
568 | .vcc_gpio = -EINVAL, | ||
569 | }, | ||
570 | }; | ||
571 | |||
564 | static struct platform_device *omap3pandora_devices[] __initdata = { | 572 | static struct platform_device *omap3pandora_devices[] __initdata = { |
565 | &pandora_leds_gpio, | 573 | &pandora_leds_gpio, |
566 | &pandora_keys_gpio, | 574 | &pandora_keys_gpio, |
@@ -569,15 +577,7 @@ static struct platform_device *omap3pandora_devices[] __initdata = { | |||
569 | }; | 577 | }; |
570 | 578 | ||
571 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { | 579 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { |
572 | |||
573 | .port_mode[0] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
574 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, | 580 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, |
575 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
576 | |||
577 | .phy_reset = true, | ||
578 | .reset_gpio_port[0] = -EINVAL, | ||
579 | .reset_gpio_port[1] = 16, | ||
580 | .reset_gpio_port[2] = -EINVAL | ||
581 | }; | 581 | }; |
582 | 582 | ||
583 | #ifdef CONFIG_OMAP_MUX | 583 | #ifdef CONFIG_OMAP_MUX |
@@ -601,7 +601,10 @@ static void __init omap3pandora_init(void) | |||
601 | spi_register_board_info(omap3pandora_spi_board_info, | 601 | spi_register_board_info(omap3pandora_spi_board_info, |
602 | ARRAY_SIZE(omap3pandora_spi_board_info)); | 602 | ARRAY_SIZE(omap3pandora_spi_board_info)); |
603 | omap_ads7846_init(1, OMAP3_PANDORA_TS_GPIO, 0, NULL); | 603 | omap_ads7846_init(1, OMAP3_PANDORA_TS_GPIO, 0, NULL); |
604 | |||
605 | usbhs_init_phys(phy_data, ARRAY_SIZE(phy_data)); | ||
604 | usbhs_init(&usbhs_bdata); | 606 | usbhs_init(&usbhs_bdata); |
607 | |||
605 | usb_bind_phy("musb-hdrc.0.auto", 0, "twl4030_usb"); | 608 | usb_bind_phy("musb-hdrc.0.auto", 0, "twl4030_usb"); |
606 | usb_musb_init(NULL); | 609 | usb_musb_init(NULL); |
607 | gpmc_nand_init(&pandora_nand_data, NULL); | 610 | gpmc_nand_init(&pandora_nand_data, NULL); |
diff --git a/arch/arm/mach-omap2/board-omap3stalker.c b/arch/arm/mach-omap2/board-omap3stalker.c index 495b989f9040..8afbba0923d6 100644 --- a/arch/arm/mach-omap2/board-omap3stalker.c +++ b/arch/arm/mach-omap2/board-omap3stalker.c | |||
@@ -357,19 +357,20 @@ static int __init omap3_stalker_i2c_init(void) | |||
357 | 357 | ||
358 | #define OMAP3_STALKER_TS_GPIO 175 | 358 | #define OMAP3_STALKER_TS_GPIO 175 |
359 | 359 | ||
360 | static struct usbhs_phy_data phy_data[] __initdata = { | ||
361 | { | ||
362 | .port = 2, | ||
363 | .reset_gpio = 21, | ||
364 | .vcc_gpio = -EINVAL, | ||
365 | }, | ||
366 | }; | ||
367 | |||
360 | static struct platform_device *omap3_stalker_devices[] __initdata = { | 368 | static struct platform_device *omap3_stalker_devices[] __initdata = { |
361 | &keys_gpio, | 369 | &keys_gpio, |
362 | }; | 370 | }; |
363 | 371 | ||
364 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { | 372 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { |
365 | .port_mode[0] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
366 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, | 373 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, |
367 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
368 | |||
369 | .phy_reset = true, | ||
370 | .reset_gpio_port[0] = -EINVAL, | ||
371 | .reset_gpio_port[1] = 21, | ||
372 | .reset_gpio_port[2] = -EINVAL, | ||
373 | }; | 374 | }; |
374 | 375 | ||
375 | #ifdef CONFIG_OMAP_MUX | 376 | #ifdef CONFIG_OMAP_MUX |
@@ -406,6 +407,8 @@ static void __init omap3_stalker_init(void) | |||
406 | omap_sdrc_init(mt46h32m32lf6_sdrc_params, NULL); | 407 | omap_sdrc_init(mt46h32m32lf6_sdrc_params, NULL); |
407 | usb_bind_phy("musb-hdrc.0.auto", 0, "twl4030_usb"); | 408 | usb_bind_phy("musb-hdrc.0.auto", 0, "twl4030_usb"); |
408 | usb_musb_init(NULL); | 409 | usb_musb_init(NULL); |
410 | |||
411 | usbhs_init_phys(phy_data, ARRAY_SIZE(phy_data)); | ||
409 | usbhs_init(&usbhs_bdata); | 412 | usbhs_init(&usbhs_bdata); |
410 | omap_ads7846_init(1, OMAP3_STALKER_TS_GPIO, 310, NULL); | 413 | omap_ads7846_init(1, OMAP3_STALKER_TS_GPIO, 310, NULL); |
411 | 414 | ||
diff --git a/arch/arm/mach-omap2/board-omap3touchbook.c b/arch/arm/mach-omap2/board-omap3touchbook.c index bcd44fbcd877..7da48bc42bbf 100644 --- a/arch/arm/mach-omap2/board-omap3touchbook.c +++ b/arch/arm/mach-omap2/board-omap3touchbook.c | |||
@@ -305,21 +305,22 @@ static struct omap_board_mux board_mux[] __initdata = { | |||
305 | }; | 305 | }; |
306 | #endif | 306 | #endif |
307 | 307 | ||
308 | static struct usbhs_phy_data phy_data[] __initdata = { | ||
309 | { | ||
310 | .port = 2, | ||
311 | .reset_gpio = 147, | ||
312 | .vcc_gpio = -EINVAL, | ||
313 | }, | ||
314 | }; | ||
315 | |||
308 | static struct platform_device *omap3_touchbook_devices[] __initdata = { | 316 | static struct platform_device *omap3_touchbook_devices[] __initdata = { |
309 | &leds_gpio, | 317 | &leds_gpio, |
310 | &keys_gpio, | 318 | &keys_gpio, |
311 | }; | 319 | }; |
312 | 320 | ||
313 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { | 321 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { |
314 | |||
315 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, | 322 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, |
316 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, | 323 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, |
317 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
318 | |||
319 | .phy_reset = true, | ||
320 | .reset_gpio_port[0] = -EINVAL, | ||
321 | .reset_gpio_port[1] = 147, | ||
322 | .reset_gpio_port[2] = -EINVAL | ||
323 | }; | 324 | }; |
324 | 325 | ||
325 | static void omap3_touchbook_poweroff(void) | 326 | static void omap3_touchbook_poweroff(void) |
@@ -368,6 +369,8 @@ static void __init omap3_touchbook_init(void) | |||
368 | omap_ads7846_init(4, OMAP3_TS_GPIO, 310, &ads7846_pdata); | 369 | omap_ads7846_init(4, OMAP3_TS_GPIO, 310, &ads7846_pdata); |
369 | usb_bind_phy("musb-hdrc.0.auto", 0, "twl4030_usb"); | 370 | usb_bind_phy("musb-hdrc.0.auto", 0, "twl4030_usb"); |
370 | usb_musb_init(NULL); | 371 | usb_musb_init(NULL); |
372 | |||
373 | usbhs_init_phys(phy_data, ARRAY_SIZE(phy_data)); | ||
371 | usbhs_init(&usbhs_bdata); | 374 | usbhs_init(&usbhs_bdata); |
372 | board_nand_init(omap3touchbook_nand_partitions, | 375 | board_nand_init(omap3touchbook_nand_partitions, |
373 | ARRAY_SIZE(omap3touchbook_nand_partitions), NAND_CS, | 376 | ARRAY_SIZE(omap3touchbook_nand_partitions), NAND_CS, |
diff --git a/arch/arm/mach-omap2/board-omap4panda.c b/arch/arm/mach-omap2/board-omap4panda.c index b02c2f00609b..a71ad345f20d 100644 --- a/arch/arm/mach-omap2/board-omap4panda.c +++ b/arch/arm/mach-omap2/board-omap4panda.c | |||
@@ -31,6 +31,7 @@ | |||
31 | #include <linux/ti_wilink_st.h> | 31 | #include <linux/ti_wilink_st.h> |
32 | #include <linux/usb/musb.h> | 32 | #include <linux/usb/musb.h> |
33 | #include <linux/usb/phy.h> | 33 | #include <linux/usb/phy.h> |
34 | #include <linux/usb/nop-usb-xceiv.h> | ||
34 | #include <linux/wl12xx.h> | 35 | #include <linux/wl12xx.h> |
35 | #include <linux/irqchip/arm-gic.h> | 36 | #include <linux/irqchip/arm-gic.h> |
36 | #include <linux/platform_data/omap-abe-twl6040.h> | 37 | #include <linux/platform_data/omap-abe-twl6040.h> |
@@ -132,6 +133,22 @@ static struct platform_device btwilink_device = { | |||
132 | .id = -1, | 133 | .id = -1, |
133 | }; | 134 | }; |
134 | 135 | ||
136 | /* PHY device on HS USB Port 1 i.e. nop_usb_xceiv.1 */ | ||
137 | static struct nop_usb_xceiv_platform_data hsusb1_phy_data = { | ||
138 | /* FREF_CLK3 provides the 19.2 MHz reference clock to the PHY */ | ||
139 | .clk_rate = 19200000, | ||
140 | }; | ||
141 | |||
142 | static struct usbhs_phy_data phy_data[] __initdata = { | ||
143 | { | ||
144 | .port = 1, | ||
145 | .reset_gpio = GPIO_HUB_NRESET, | ||
146 | .vcc_gpio = GPIO_HUB_POWER, | ||
147 | .vcc_polarity = 1, | ||
148 | .platform_data = &hsusb1_phy_data, | ||
149 | }, | ||
150 | }; | ||
151 | |||
135 | static struct platform_device *panda_devices[] __initdata = { | 152 | static struct platform_device *panda_devices[] __initdata = { |
136 | &leds_gpio, | 153 | &leds_gpio, |
137 | &wl1271_device, | 154 | &wl1271_device, |
@@ -142,49 +159,19 @@ static struct platform_device *panda_devices[] __initdata = { | |||
142 | 159 | ||
143 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { | 160 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { |
144 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, | 161 | .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, |
145 | .port_mode[1] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
146 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
147 | .phy_reset = false, | ||
148 | .reset_gpio_port[0] = -EINVAL, | ||
149 | .reset_gpio_port[1] = -EINVAL, | ||
150 | .reset_gpio_port[2] = -EINVAL | ||
151 | }; | ||
152 | |||
153 | static struct gpio panda_ehci_gpios[] __initdata = { | ||
154 | { GPIO_HUB_POWER, GPIOF_OUT_INIT_LOW, "hub_power" }, | ||
155 | { GPIO_HUB_NRESET, GPIOF_OUT_INIT_LOW, "hub_nreset" }, | ||
156 | }; | 162 | }; |
157 | 163 | ||
158 | static void __init omap4_ehci_init(void) | 164 | static void __init omap4_ehci_init(void) |
159 | { | 165 | { |
160 | int ret; | 166 | int ret; |
161 | struct clk *phy_ref_clk; | ||
162 | 167 | ||
163 | /* FREF_CLK3 provides the 19.2 MHz reference clock to the PHY */ | 168 | /* FREF_CLK3 provides the 19.2 MHz reference clock to the PHY */ |
164 | phy_ref_clk = clk_get(NULL, "auxclk3_ck"); | 169 | ret = clk_add_alias("main_clk", "nop_usb_xceiv.1", "auxclk3_ck", NULL); |
165 | if (IS_ERR(phy_ref_clk)) { | 170 | if (ret) |
166 | pr_err("Cannot request auxclk3\n"); | 171 | pr_err("Failed to add main_clk alias to auxclk3_ck\n"); |
167 | return; | ||
168 | } | ||
169 | clk_set_rate(phy_ref_clk, 19200000); | ||
170 | clk_prepare_enable(phy_ref_clk); | ||
171 | |||
172 | /* disable the power to the usb hub prior to init and reset phy+hub */ | ||
173 | ret = gpio_request_array(panda_ehci_gpios, | ||
174 | ARRAY_SIZE(panda_ehci_gpios)); | ||
175 | if (ret) { | ||
176 | pr_err("Unable to initialize EHCI power/reset\n"); | ||
177 | return; | ||
178 | } | ||
179 | |||
180 | gpio_export(GPIO_HUB_POWER, 0); | ||
181 | gpio_export(GPIO_HUB_NRESET, 0); | ||
182 | gpio_set_value(GPIO_HUB_NRESET, 1); | ||
183 | 172 | ||
173 | usbhs_init_phys(phy_data, ARRAY_SIZE(phy_data)); | ||
184 | usbhs_init(&usbhs_bdata); | 174 | usbhs_init(&usbhs_bdata); |
185 | |||
186 | /* enable power to hub */ | ||
187 | gpio_set_value(GPIO_HUB_POWER, 1); | ||
188 | } | 175 | } |
189 | 176 | ||
190 | static struct omap_musb_board_data musb_board_data = { | 177 | static struct omap_musb_board_data musb_board_data = { |
diff --git a/arch/arm/mach-omap2/board-overo.c b/arch/arm/mach-omap2/board-overo.c index 630833235cbc..f9101407cd56 100644 --- a/arch/arm/mach-omap2/board-overo.c +++ b/arch/arm/mach-omap2/board-overo.c | |||
@@ -457,14 +457,16 @@ static int __init overo_spi_init(void) | |||
457 | return 0; | 457 | return 0; |
458 | } | 458 | } |
459 | 459 | ||
460 | static struct usbhs_phy_data phy_data[] __initdata = { | ||
461 | { | ||
462 | .port = 2, | ||
463 | .reset_gpio = OVERO_GPIO_USBH_NRESET, | ||
464 | .vcc_gpio = -EINVAL, | ||
465 | }, | ||
466 | }; | ||
467 | |||
460 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { | 468 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { |
461 | .port_mode[0] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
462 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, | 469 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, |
463 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
464 | .phy_reset = true, | ||
465 | .reset_gpio_port[0] = -EINVAL, | ||
466 | .reset_gpio_port[1] = OVERO_GPIO_USBH_NRESET, | ||
467 | .reset_gpio_port[2] = -EINVAL | ||
468 | }; | 470 | }; |
469 | 471 | ||
470 | #ifdef CONFIG_OMAP_MUX | 472 | #ifdef CONFIG_OMAP_MUX |
@@ -501,6 +503,8 @@ static void __init overo_init(void) | |||
501 | ARRAY_SIZE(overo_nand_partitions), NAND_CS, 0, NULL); | 503 | ARRAY_SIZE(overo_nand_partitions), NAND_CS, 0, NULL); |
502 | usb_bind_phy("musb-hdrc.0.auto", 0, "twl4030_usb"); | 504 | usb_bind_phy("musb-hdrc.0.auto", 0, "twl4030_usb"); |
503 | usb_musb_init(NULL); | 505 | usb_musb_init(NULL); |
506 | |||
507 | usbhs_init_phys(phy_data, ARRAY_SIZE(phy_data)); | ||
504 | usbhs_init(&usbhs_bdata); | 508 | usbhs_init(&usbhs_bdata); |
505 | overo_spi_init(); | 509 | overo_spi_init(); |
506 | overo_init_smsc911x(); | 510 | overo_init_smsc911x(); |
diff --git a/arch/arm/mach-omap2/board-zoom.c b/arch/arm/mach-omap2/board-zoom.c index 5e4d4c9fe61a..1a3dd865d8eb 100644 --- a/arch/arm/mach-omap2/board-zoom.c +++ b/arch/arm/mach-omap2/board-zoom.c | |||
@@ -92,14 +92,16 @@ static struct mtd_partition zoom_nand_partitions[] = { | |||
92 | }, | 92 | }, |
93 | }; | 93 | }; |
94 | 94 | ||
95 | static struct usbhs_phy_data phy_data[] __initdata = { | ||
96 | { | ||
97 | .port = 2, | ||
98 | .reset_gpio = ZOOM3_EHCI_RESET_GPIO, | ||
99 | .vcc_gpio = -EINVAL, | ||
100 | }, | ||
101 | }; | ||
102 | |||
95 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { | 103 | static struct usbhs_omap_platform_data usbhs_bdata __initdata = { |
96 | .port_mode[0] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
97 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, | 104 | .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, |
98 | .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | ||
99 | .phy_reset = true, | ||
100 | .reset_gpio_port[0] = -EINVAL, | ||
101 | .reset_gpio_port[1] = ZOOM3_EHCI_RESET_GPIO, | ||
102 | .reset_gpio_port[2] = -EINVAL, | ||
103 | }; | 105 | }; |
104 | 106 | ||
105 | static void __init omap_zoom_init(void) | 107 | static void __init omap_zoom_init(void) |
@@ -109,6 +111,8 @@ static void __init omap_zoom_init(void) | |||
109 | } else if (machine_is_omap_zoom3()) { | 111 | } else if (machine_is_omap_zoom3()) { |
110 | omap3_mux_init(board_mux, OMAP_PACKAGE_CBP); | 112 | omap3_mux_init(board_mux, OMAP_PACKAGE_CBP); |
111 | omap_mux_init_gpio(ZOOM3_EHCI_RESET_GPIO, OMAP_PIN_OUTPUT); | 113 | omap_mux_init_gpio(ZOOM3_EHCI_RESET_GPIO, OMAP_PIN_OUTPUT); |
114 | |||
115 | usbhs_init_phys(phy_data, ARRAY_SIZE(phy_data)); | ||
112 | usbhs_init(&usbhs_bdata); | 116 | usbhs_init(&usbhs_bdata); |
113 | } | 117 | } |
114 | 118 | ||
diff --git a/arch/arm/mach-omap2/common.h b/arch/arm/mach-omap2/common.h index df00e7580aa7..d555cf2459e1 100644 --- a/arch/arm/mach-omap2/common.h +++ b/arch/arm/mach-omap2/common.h | |||
@@ -82,8 +82,7 @@ extern void omap2_init_common_infrastructure(void); | |||
82 | extern void omap2_sync32k_timer_init(void); | 82 | extern void omap2_sync32k_timer_init(void); |
83 | extern void omap3_sync32k_timer_init(void); | 83 | extern void omap3_sync32k_timer_init(void); |
84 | extern void omap3_secure_sync32k_timer_init(void); | 84 | extern void omap3_secure_sync32k_timer_init(void); |
85 | extern void omap3_gp_gptimer_timer_init(void); | 85 | extern void omap3_gptimer_timer_init(void); |
86 | extern void omap3_am33xx_gptimer_timer_init(void); | ||
87 | extern void omap4_local_timer_init(void); | 86 | extern void omap4_local_timer_init(void); |
88 | extern void omap5_realtime_timer_init(void); | 87 | extern void omap5_realtime_timer_init(void); |
89 | 88 | ||
diff --git a/arch/arm/mach-omap2/gpmc-nand.c b/arch/arm/mach-omap2/gpmc-nand.c index afc1e8c32d6c..d9c27195caf0 100644 --- a/arch/arm/mach-omap2/gpmc-nand.c +++ b/arch/arm/mach-omap2/gpmc-nand.c | |||
@@ -74,14 +74,6 @@ static int omap2_nand_gpmc_retime( | |||
74 | t.cs_wr_off = gpmc_t->cs_wr_off; | 74 | t.cs_wr_off = gpmc_t->cs_wr_off; |
75 | t.wr_cycle = gpmc_t->wr_cycle; | 75 | t.wr_cycle = gpmc_t->wr_cycle; |
76 | 76 | ||
77 | /* Configure GPMC */ | ||
78 | if (gpmc_nand_data->devsize == NAND_BUSWIDTH_16) | ||
79 | gpmc_cs_configure(gpmc_nand_data->cs, GPMC_CONFIG_DEV_SIZE, 1); | ||
80 | else | ||
81 | gpmc_cs_configure(gpmc_nand_data->cs, GPMC_CONFIG_DEV_SIZE, 0); | ||
82 | gpmc_cs_configure(gpmc_nand_data->cs, | ||
83 | GPMC_CONFIG_DEV_TYPE, GPMC_DEVICETYPE_NAND); | ||
84 | gpmc_cs_configure(gpmc_nand_data->cs, GPMC_CONFIG_WP, 0); | ||
85 | err = gpmc_cs_set_timings(gpmc_nand_data->cs, &t); | 77 | err = gpmc_cs_set_timings(gpmc_nand_data->cs, &t); |
86 | if (err) | 78 | if (err) |
87 | return err; | 79 | return err; |
@@ -115,14 +107,18 @@ int gpmc_nand_init(struct omap_nand_platform_data *gpmc_nand_data, | |||
115 | struct gpmc_timings *gpmc_t) | 107 | struct gpmc_timings *gpmc_t) |
116 | { | 108 | { |
117 | int err = 0; | 109 | int err = 0; |
110 | struct gpmc_settings s; | ||
118 | struct device *dev = &gpmc_nand_device.dev; | 111 | struct device *dev = &gpmc_nand_device.dev; |
119 | 112 | ||
113 | memset(&s, 0, sizeof(struct gpmc_settings)); | ||
114 | |||
120 | gpmc_nand_device.dev.platform_data = gpmc_nand_data; | 115 | gpmc_nand_device.dev.platform_data = gpmc_nand_data; |
121 | 116 | ||
122 | err = gpmc_cs_request(gpmc_nand_data->cs, NAND_IO_SIZE, | 117 | err = gpmc_cs_request(gpmc_nand_data->cs, NAND_IO_SIZE, |
123 | (unsigned long *)&gpmc_nand_resource[0].start); | 118 | (unsigned long *)&gpmc_nand_resource[0].start); |
124 | if (err < 0) { | 119 | if (err < 0) { |
125 | dev_err(dev, "Cannot request GPMC CS\n"); | 120 | dev_err(dev, "Cannot request GPMC CS %d, error %d\n", |
121 | gpmc_nand_data->cs, err); | ||
126 | return err; | 122 | return err; |
127 | } | 123 | } |
128 | 124 | ||
@@ -140,11 +136,31 @@ int gpmc_nand_init(struct omap_nand_platform_data *gpmc_nand_data, | |||
140 | dev_err(dev, "Unable to set gpmc timings: %d\n", err); | 136 | dev_err(dev, "Unable to set gpmc timings: %d\n", err); |
141 | return err; | 137 | return err; |
142 | } | 138 | } |
143 | } | ||
144 | 139 | ||
145 | /* Enable RD PIN Monitoring Reg */ | 140 | if (gpmc_nand_data->of_node) { |
146 | if (gpmc_nand_data->dev_ready) { | 141 | gpmc_read_settings_dt(gpmc_nand_data->of_node, &s); |
147 | gpmc_cs_configure(gpmc_nand_data->cs, GPMC_CONFIG_RDY_BSY, 1); | 142 | } else { |
143 | s.device_nand = true; | ||
144 | |||
145 | /* Enable RD PIN Monitoring Reg */ | ||
146 | if (gpmc_nand_data->dev_ready) { | ||
147 | s.wait_on_read = true; | ||
148 | s.wait_on_write = true; | ||
149 | } | ||
150 | } | ||
151 | |||
152 | if (gpmc_nand_data->devsize == NAND_BUSWIDTH_16) | ||
153 | s.device_width = GPMC_DEVWIDTH_16BIT; | ||
154 | else | ||
155 | s.device_width = GPMC_DEVWIDTH_8BIT; | ||
156 | |||
157 | err = gpmc_cs_program_settings(gpmc_nand_data->cs, &s); | ||
158 | if (err < 0) | ||
159 | goto out_free_cs; | ||
160 | |||
161 | err = gpmc_configure(GPMC_CONFIG_WP, 0); | ||
162 | if (err < 0) | ||
163 | goto out_free_cs; | ||
148 | } | 164 | } |
149 | 165 | ||
150 | gpmc_update_nand_reg(&gpmc_nand_data->reg, gpmc_nand_data->cs); | 166 | gpmc_update_nand_reg(&gpmc_nand_data->reg, gpmc_nand_data->cs); |
diff --git a/arch/arm/mach-omap2/gpmc-onenand.c b/arch/arm/mach-omap2/gpmc-onenand.c index 0d75889c0a6f..64b5a8346982 100644 --- a/arch/arm/mach-omap2/gpmc-onenand.c +++ b/arch/arm/mach-omap2/gpmc-onenand.c | |||
@@ -47,11 +47,23 @@ static struct platform_device gpmc_onenand_device = { | |||
47 | .resource = &gpmc_onenand_resource, | 47 | .resource = &gpmc_onenand_resource, |
48 | }; | 48 | }; |
49 | 49 | ||
50 | static struct gpmc_timings omap2_onenand_calc_async_timings(void) | 50 | static struct gpmc_settings onenand_async = { |
51 | .device_width = GPMC_DEVWIDTH_16BIT, | ||
52 | .mux_add_data = GPMC_MUX_AD, | ||
53 | }; | ||
54 | |||
55 | static struct gpmc_settings onenand_sync = { | ||
56 | .burst_read = true, | ||
57 | .burst_wrap = true, | ||
58 | .burst_len = GPMC_BURST_16, | ||
59 | .device_width = GPMC_DEVWIDTH_16BIT, | ||
60 | .mux_add_data = GPMC_MUX_AD, | ||
61 | .wait_pin = 0, | ||
62 | }; | ||
63 | |||
64 | static void omap2_onenand_calc_async_timings(struct gpmc_timings *t) | ||
51 | { | 65 | { |
52 | struct gpmc_device_timings dev_t; | 66 | struct gpmc_device_timings dev_t; |
53 | struct gpmc_timings t; | ||
54 | |||
55 | const int t_cer = 15; | 67 | const int t_cer = 15; |
56 | const int t_avdp = 12; | 68 | const int t_avdp = 12; |
57 | const int t_aavdh = 7; | 69 | const int t_aavdh = 7; |
@@ -64,7 +76,6 @@ static struct gpmc_timings omap2_onenand_calc_async_timings(void) | |||
64 | 76 | ||
65 | memset(&dev_t, 0, sizeof(dev_t)); | 77 | memset(&dev_t, 0, sizeof(dev_t)); |
66 | 78 | ||
67 | dev_t.mux = true; | ||
68 | dev_t.t_avdp_r = max_t(int, t_avdp, t_cer) * 1000; | 79 | dev_t.t_avdp_r = max_t(int, t_avdp, t_cer) * 1000; |
69 | dev_t.t_avdp_w = dev_t.t_avdp_r; | 80 | dev_t.t_avdp_w = dev_t.t_avdp_r; |
70 | dev_t.t_aavdh = t_aavdh * 1000; | 81 | dev_t.t_aavdh = t_aavdh * 1000; |
@@ -76,19 +87,7 @@ static struct gpmc_timings omap2_onenand_calc_async_timings(void) | |||
76 | dev_t.t_wpl = t_wpl * 1000; | 87 | dev_t.t_wpl = t_wpl * 1000; |
77 | dev_t.t_wph = t_wph * 1000; | 88 | dev_t.t_wph = t_wph * 1000; |
78 | 89 | ||
79 | gpmc_calc_timings(&t, &dev_t); | 90 | gpmc_calc_timings(t, &onenand_async, &dev_t); |
80 | |||
81 | return t; | ||
82 | } | ||
83 | |||
84 | static int gpmc_set_async_mode(int cs, struct gpmc_timings *t) | ||
85 | { | ||
86 | /* Configure GPMC for asynchronous read */ | ||
87 | gpmc_cs_write_reg(cs, GPMC_CS_CONFIG1, | ||
88 | GPMC_CONFIG1_DEVICESIZE_16 | | ||
89 | GPMC_CONFIG1_MUXADDDATA); | ||
90 | |||
91 | return gpmc_cs_set_timings(cs, t); | ||
92 | } | 91 | } |
93 | 92 | ||
94 | static void omap2_onenand_set_async_mode(void __iomem *onenand_base) | 93 | static void omap2_onenand_set_async_mode(void __iomem *onenand_base) |
@@ -158,12 +157,11 @@ static int omap2_onenand_get_freq(struct omap_onenand_platform_data *cfg, | |||
158 | return freq; | 157 | return freq; |
159 | } | 158 | } |
160 | 159 | ||
161 | static struct gpmc_timings | 160 | static void omap2_onenand_calc_sync_timings(struct gpmc_timings *t, |
162 | omap2_onenand_calc_sync_timings(struct omap_onenand_platform_data *cfg, | 161 | unsigned int flags, |
163 | int freq) | 162 | int freq) |
164 | { | 163 | { |
165 | struct gpmc_device_timings dev_t; | 164 | struct gpmc_device_timings dev_t; |
166 | struct gpmc_timings t; | ||
167 | const int t_cer = 15; | 165 | const int t_cer = 15; |
168 | const int t_avdp = 12; | 166 | const int t_avdp = 12; |
169 | const int t_cez = 20; /* max of t_cez, t_oez */ | 167 | const int t_cez = 20; /* max of t_cez, t_oez */ |
@@ -172,9 +170,9 @@ omap2_onenand_calc_sync_timings(struct omap_onenand_platform_data *cfg, | |||
172 | int min_gpmc_clk_period, t_ces, t_avds, t_avdh, t_ach, t_aavdh, t_rdyo; | 170 | int min_gpmc_clk_period, t_ces, t_avds, t_avdh, t_ach, t_aavdh, t_rdyo; |
173 | int div, gpmc_clk_ns; | 171 | int div, gpmc_clk_ns; |
174 | 172 | ||
175 | if (cfg->flags & ONENAND_SYNC_READ) | 173 | if (flags & ONENAND_SYNC_READ) |
176 | onenand_flags = ONENAND_FLAG_SYNCREAD; | 174 | onenand_flags = ONENAND_FLAG_SYNCREAD; |
177 | else if (cfg->flags & ONENAND_SYNC_READWRITE) | 175 | else if (flags & ONENAND_SYNC_READWRITE) |
178 | onenand_flags = ONENAND_FLAG_SYNCREAD | ONENAND_FLAG_SYNCWRITE; | 176 | onenand_flags = ONENAND_FLAG_SYNCREAD | ONENAND_FLAG_SYNCWRITE; |
179 | 177 | ||
180 | switch (freq) { | 178 | switch (freq) { |
@@ -239,10 +237,11 @@ omap2_onenand_calc_sync_timings(struct omap_onenand_platform_data *cfg, | |||
239 | /* Set synchronous read timings */ | 237 | /* Set synchronous read timings */ |
240 | memset(&dev_t, 0, sizeof(dev_t)); | 238 | memset(&dev_t, 0, sizeof(dev_t)); |
241 | 239 | ||
242 | dev_t.mux = true; | 240 | if (onenand_flags & ONENAND_FLAG_SYNCREAD) |
243 | dev_t.sync_read = true; | 241 | onenand_sync.sync_read = true; |
244 | if (onenand_flags & ONENAND_FLAG_SYNCWRITE) { | 242 | if (onenand_flags & ONENAND_FLAG_SYNCWRITE) { |
245 | dev_t.sync_write = true; | 243 | onenand_sync.sync_write = true; |
244 | onenand_sync.burst_write = true; | ||
246 | } else { | 245 | } else { |
247 | dev_t.t_avdp_w = max(t_avdp, t_cer) * 1000; | 246 | dev_t.t_avdp_w = max(t_avdp, t_cer) * 1000; |
248 | dev_t.t_wpl = t_wpl * 1000; | 247 | dev_t.t_wpl = t_wpl * 1000; |
@@ -265,32 +264,7 @@ omap2_onenand_calc_sync_timings(struct omap_onenand_platform_data *cfg, | |||
265 | dev_t.cyc_aavdh_oe = 1; | 264 | dev_t.cyc_aavdh_oe = 1; |
266 | dev_t.t_rdyo = t_rdyo * 1000 + min_gpmc_clk_period; | 265 | dev_t.t_rdyo = t_rdyo * 1000 + min_gpmc_clk_period; |
267 | 266 | ||
268 | gpmc_calc_timings(&t, &dev_t); | 267 | gpmc_calc_timings(t, &onenand_sync, &dev_t); |
269 | |||
270 | return t; | ||
271 | } | ||
272 | |||
273 | static int gpmc_set_sync_mode(int cs, struct gpmc_timings *t) | ||
274 | { | ||
275 | unsigned sync_read = onenand_flags & ONENAND_FLAG_SYNCREAD; | ||
276 | unsigned sync_write = onenand_flags & ONENAND_FLAG_SYNCWRITE; | ||
277 | |||
278 | /* Configure GPMC for synchronous read */ | ||
279 | gpmc_cs_write_reg(cs, GPMC_CS_CONFIG1, | ||
280 | GPMC_CONFIG1_WRAPBURST_SUPP | | ||
281 | GPMC_CONFIG1_READMULTIPLE_SUPP | | ||
282 | (sync_read ? GPMC_CONFIG1_READTYPE_SYNC : 0) | | ||
283 | (sync_write ? GPMC_CONFIG1_WRITEMULTIPLE_SUPP : 0) | | ||
284 | (sync_write ? GPMC_CONFIG1_WRITETYPE_SYNC : 0) | | ||
285 | GPMC_CONFIG1_PAGE_LEN(2) | | ||
286 | (cpu_is_omap34xx() ? 0 : | ||
287 | (GPMC_CONFIG1_WAIT_READ_MON | | ||
288 | GPMC_CONFIG1_WAIT_PIN_SEL(0))) | | ||
289 | GPMC_CONFIG1_DEVICESIZE_16 | | ||
290 | GPMC_CONFIG1_DEVICETYPE_NOR | | ||
291 | GPMC_CONFIG1_MUXADDDATA); | ||
292 | |||
293 | return gpmc_cs_set_timings(cs, t); | ||
294 | } | 268 | } |
295 | 269 | ||
296 | static int omap2_onenand_setup_async(void __iomem *onenand_base) | 270 | static int omap2_onenand_setup_async(void __iomem *onenand_base) |
@@ -298,11 +272,19 @@ static int omap2_onenand_setup_async(void __iomem *onenand_base) | |||
298 | struct gpmc_timings t; | 272 | struct gpmc_timings t; |
299 | int ret; | 273 | int ret; |
300 | 274 | ||
275 | if (gpmc_onenand_data->of_node) | ||
276 | gpmc_read_settings_dt(gpmc_onenand_data->of_node, | ||
277 | &onenand_async); | ||
278 | |||
301 | omap2_onenand_set_async_mode(onenand_base); | 279 | omap2_onenand_set_async_mode(onenand_base); |
302 | 280 | ||
303 | t = omap2_onenand_calc_async_timings(); | 281 | omap2_onenand_calc_async_timings(&t); |
282 | |||
283 | ret = gpmc_cs_program_settings(gpmc_onenand_data->cs, &onenand_async); | ||
284 | if (ret < 0) | ||
285 | return ret; | ||
304 | 286 | ||
305 | ret = gpmc_set_async_mode(gpmc_onenand_data->cs, &t); | 287 | ret = gpmc_cs_set_timings(gpmc_onenand_data->cs, &t); |
306 | if (ret < 0) | 288 | if (ret < 0) |
307 | return ret; | 289 | return ret; |
308 | 290 | ||
@@ -322,9 +304,25 @@ static int omap2_onenand_setup_sync(void __iomem *onenand_base, int *freq_ptr) | |||
322 | set_onenand_cfg(onenand_base); | 304 | set_onenand_cfg(onenand_base); |
323 | } | 305 | } |
324 | 306 | ||
325 | t = omap2_onenand_calc_sync_timings(gpmc_onenand_data, freq); | 307 | if (gpmc_onenand_data->of_node) { |
308 | gpmc_read_settings_dt(gpmc_onenand_data->of_node, | ||
309 | &onenand_sync); | ||
310 | } else { | ||
311 | /* | ||
312 | * FIXME: Appears to be legacy code from initial ONENAND commit. | ||
313 | * Unclear what boards this is for and if this can be removed. | ||
314 | */ | ||
315 | if (!cpu_is_omap34xx()) | ||
316 | onenand_sync.wait_on_read = true; | ||
317 | } | ||
326 | 318 | ||
327 | ret = gpmc_set_sync_mode(gpmc_onenand_data->cs, &t); | 319 | omap2_onenand_calc_sync_timings(&t, gpmc_onenand_data->flags, freq); |
320 | |||
321 | ret = gpmc_cs_program_settings(gpmc_onenand_data->cs, &onenand_sync); | ||
322 | if (ret < 0) | ||
323 | return ret; | ||
324 | |||
325 | ret = gpmc_cs_set_timings(gpmc_onenand_data->cs, &t); | ||
328 | if (ret < 0) | 326 | if (ret < 0) |
329 | return ret; | 327 | return ret; |
330 | 328 | ||
@@ -359,6 +357,7 @@ static int gpmc_onenand_setup(void __iomem *onenand_base, int *freq_ptr) | |||
359 | void gpmc_onenand_init(struct omap_onenand_platform_data *_onenand_data) | 357 | void gpmc_onenand_init(struct omap_onenand_platform_data *_onenand_data) |
360 | { | 358 | { |
361 | int err; | 359 | int err; |
360 | struct device *dev = &gpmc_onenand_device.dev; | ||
362 | 361 | ||
363 | gpmc_onenand_data = _onenand_data; | 362 | gpmc_onenand_data = _onenand_data; |
364 | gpmc_onenand_data->onenand_setup = gpmc_onenand_setup; | 363 | gpmc_onenand_data->onenand_setup = gpmc_onenand_setup; |
@@ -366,7 +365,7 @@ void gpmc_onenand_init(struct omap_onenand_platform_data *_onenand_data) | |||
366 | 365 | ||
367 | if (cpu_is_omap24xx() && | 366 | if (cpu_is_omap24xx() && |
368 | (gpmc_onenand_data->flags & ONENAND_SYNC_READWRITE)) { | 367 | (gpmc_onenand_data->flags & ONENAND_SYNC_READWRITE)) { |
369 | printk(KERN_ERR "Onenand using only SYNC_READ on 24xx\n"); | 368 | dev_warn(dev, "OneNAND using only SYNC_READ on 24xx\n"); |
370 | gpmc_onenand_data->flags &= ~ONENAND_SYNC_READWRITE; | 369 | gpmc_onenand_data->flags &= ~ONENAND_SYNC_READWRITE; |
371 | gpmc_onenand_data->flags |= ONENAND_SYNC_READ; | 370 | gpmc_onenand_data->flags |= ONENAND_SYNC_READ; |
372 | } | 371 | } |
@@ -379,7 +378,8 @@ void gpmc_onenand_init(struct omap_onenand_platform_data *_onenand_data) | |||
379 | err = gpmc_cs_request(gpmc_onenand_data->cs, ONENAND_IO_SIZE, | 378 | err = gpmc_cs_request(gpmc_onenand_data->cs, ONENAND_IO_SIZE, |
380 | (unsigned long *)&gpmc_onenand_resource.start); | 379 | (unsigned long *)&gpmc_onenand_resource.start); |
381 | if (err < 0) { | 380 | if (err < 0) { |
382 | pr_err("%s: Cannot request GPMC CS\n", __func__); | 381 | dev_err(dev, "Cannot request GPMC CS %d, error %d\n", |
382 | gpmc_onenand_data->cs, err); | ||
383 | return; | 383 | return; |
384 | } | 384 | } |
385 | 385 | ||
@@ -387,7 +387,7 @@ void gpmc_onenand_init(struct omap_onenand_platform_data *_onenand_data) | |||
387 | ONENAND_IO_SIZE - 1; | 387 | ONENAND_IO_SIZE - 1; |
388 | 388 | ||
389 | if (platform_device_register(&gpmc_onenand_device) < 0) { | 389 | if (platform_device_register(&gpmc_onenand_device) < 0) { |
390 | pr_err("%s: Unable to register OneNAND device\n", __func__); | 390 | dev_err(dev, "Unable to register OneNAND device\n"); |
391 | gpmc_cs_free(gpmc_onenand_data->cs); | 391 | gpmc_cs_free(gpmc_onenand_data->cs); |
392 | return; | 392 | return; |
393 | } | 393 | } |
diff --git a/arch/arm/mach-omap2/gpmc-smc91x.c b/arch/arm/mach-omap2/gpmc-smc91x.c index 11d0b756f098..61a063595e66 100644 --- a/arch/arm/mach-omap2/gpmc-smc91x.c +++ b/arch/arm/mach-omap2/gpmc-smc91x.c | |||
@@ -49,6 +49,10 @@ static struct platform_device gpmc_smc91x_device = { | |||
49 | .resource = gpmc_smc91x_resources, | 49 | .resource = gpmc_smc91x_resources, |
50 | }; | 50 | }; |
51 | 51 | ||
52 | static struct gpmc_settings smc91x_settings = { | ||
53 | .device_width = GPMC_DEVWIDTH_16BIT, | ||
54 | }; | ||
55 | |||
52 | /* | 56 | /* |
53 | * Set the gpmc timings for smc91c96. The timings are taken | 57 | * Set the gpmc timings for smc91c96. The timings are taken |
54 | * from the data sheet available at: | 58 | * from the data sheet available at: |
@@ -67,18 +71,6 @@ static int smc91c96_gpmc_retime(void) | |||
67 | const int t7 = 5; /* Figure 12.4 write */ | 71 | const int t7 = 5; /* Figure 12.4 write */ |
68 | const int t8 = 5; /* Figure 12.4 write */ | 72 | const int t8 = 5; /* Figure 12.4 write */ |
69 | const int t20 = 185; /* Figure 12.2 read and 12.4 write */ | 73 | const int t20 = 185; /* Figure 12.2 read and 12.4 write */ |
70 | u32 l; | ||
71 | |||
72 | l = GPMC_CONFIG1_DEVICESIZE_16; | ||
73 | if (gpmc_cfg->flags & GPMC_MUX_ADD_DATA) | ||
74 | l |= GPMC_CONFIG1_MUXADDDATA; | ||
75 | if (gpmc_cfg->flags & GPMC_READ_MON) | ||
76 | l |= GPMC_CONFIG1_WAIT_READ_MON; | ||
77 | if (gpmc_cfg->flags & GPMC_WRITE_MON) | ||
78 | l |= GPMC_CONFIG1_WAIT_WRITE_MON; | ||
79 | if (gpmc_cfg->wait_pin) | ||
80 | l |= GPMC_CONFIG1_WAIT_PIN_SEL(gpmc_cfg->wait_pin); | ||
81 | gpmc_cs_write_reg(gpmc_cfg->cs, GPMC_CS_CONFIG1, l); | ||
82 | 74 | ||
83 | /* | 75 | /* |
84 | * FIXME: Calculate the address and data bus muxed timings. | 76 | * FIXME: Calculate the address and data bus muxed timings. |
@@ -104,7 +96,7 @@ static int smc91c96_gpmc_retime(void) | |||
104 | dev_t.t_cez_w = t4_w * 1000; | 96 | dev_t.t_cez_w = t4_w * 1000; |
105 | dev_t.t_wr_cycle = (t20 - t3) * 1000; | 97 | dev_t.t_wr_cycle = (t20 - t3) * 1000; |
106 | 98 | ||
107 | gpmc_calc_timings(&t, &dev_t); | 99 | gpmc_calc_timings(&t, &smc91x_settings, &dev_t); |
108 | 100 | ||
109 | return gpmc_cs_set_timings(gpmc_cfg->cs, &t); | 101 | return gpmc_cs_set_timings(gpmc_cfg->cs, &t); |
110 | } | 102 | } |
@@ -133,6 +125,18 @@ void __init gpmc_smc91x_init(struct omap_smc91x_platform_data *board_data) | |||
133 | gpmc_smc91x_resources[0].end = cs_mem_base + 0x30f; | 125 | gpmc_smc91x_resources[0].end = cs_mem_base + 0x30f; |
134 | gpmc_smc91x_resources[1].flags |= (gpmc_cfg->flags & IRQF_TRIGGER_MASK); | 126 | gpmc_smc91x_resources[1].flags |= (gpmc_cfg->flags & IRQF_TRIGGER_MASK); |
135 | 127 | ||
128 | if (gpmc_cfg->flags & GPMC_MUX_ADD_DATA) | ||
129 | smc91x_settings.mux_add_data = GPMC_MUX_AD; | ||
130 | if (gpmc_cfg->flags & GPMC_READ_MON) | ||
131 | smc91x_settings.wait_on_read = true; | ||
132 | if (gpmc_cfg->flags & GPMC_WRITE_MON) | ||
133 | smc91x_settings.wait_on_write = true; | ||
134 | if (gpmc_cfg->wait_pin) | ||
135 | smc91x_settings.wait_pin = gpmc_cfg->wait_pin; | ||
136 | ret = gpmc_cs_program_settings(gpmc_cfg->cs, &smc91x_settings); | ||
137 | if (ret < 0) | ||
138 | goto free1; | ||
139 | |||
136 | if (gpmc_cfg->retime) { | 140 | if (gpmc_cfg->retime) { |
137 | ret = gpmc_cfg->retime(); | 141 | ret = gpmc_cfg->retime(); |
138 | if (ret != 0) | 142 | if (ret != 0) |
diff --git a/arch/arm/mach-omap2/gpmc.c b/arch/arm/mach-omap2/gpmc.c index 6de31739b45c..ed946df5ad8a 100644 --- a/arch/arm/mach-omap2/gpmc.c +++ b/arch/arm/mach-omap2/gpmc.c | |||
@@ -26,6 +26,7 @@ | |||
26 | #include <linux/interrupt.h> | 26 | #include <linux/interrupt.h> |
27 | #include <linux/platform_device.h> | 27 | #include <linux/platform_device.h> |
28 | #include <linux/of.h> | 28 | #include <linux/of.h> |
29 | #include <linux/of_address.h> | ||
29 | #include <linux/of_mtd.h> | 30 | #include <linux/of_mtd.h> |
30 | #include <linux/of_device.h> | 31 | #include <linux/of_device.h> |
31 | #include <linux/mtd/nand.h> | 32 | #include <linux/mtd/nand.h> |
@@ -91,9 +92,7 @@ | |||
91 | #define GPMC_CS_SIZE 0x30 | 92 | #define GPMC_CS_SIZE 0x30 |
92 | #define GPMC_BCH_SIZE 0x10 | 93 | #define GPMC_BCH_SIZE 0x10 |
93 | 94 | ||
94 | #define GPMC_MEM_START 0x00000000 | ||
95 | #define GPMC_MEM_END 0x3FFFFFFF | 95 | #define GPMC_MEM_END 0x3FFFFFFF |
96 | #define BOOT_ROM_SPACE 0x100000 /* 1MB */ | ||
97 | 96 | ||
98 | #define GPMC_CHUNK_SHIFT 24 /* 16 MB */ | 97 | #define GPMC_CHUNK_SHIFT 24 /* 16 MB */ |
99 | #define GPMC_SECTION_SHIFT 28 /* 128 MB */ | 98 | #define GPMC_SECTION_SHIFT 28 /* 128 MB */ |
@@ -107,6 +106,9 @@ | |||
107 | 106 | ||
108 | #define GPMC_HAS_WR_ACCESS 0x1 | 107 | #define GPMC_HAS_WR_ACCESS 0x1 |
109 | #define GPMC_HAS_WR_DATA_MUX_BUS 0x2 | 108 | #define GPMC_HAS_WR_DATA_MUX_BUS 0x2 |
109 | #define GPMC_HAS_MUX_AAD 0x4 | ||
110 | |||
111 | #define GPMC_NR_WAITPINS 4 | ||
110 | 112 | ||
111 | /* XXX: Only NAND irq has been considered,currently these are the only ones used | 113 | /* XXX: Only NAND irq has been considered,currently these are the only ones used |
112 | */ | 114 | */ |
@@ -153,6 +155,7 @@ static struct resource gpmc_cs_mem[GPMC_CS_NUM]; | |||
153 | static DEFINE_SPINLOCK(gpmc_mem_lock); | 155 | static DEFINE_SPINLOCK(gpmc_mem_lock); |
154 | /* Define chip-selects as reserved by default until probe completes */ | 156 | /* Define chip-selects as reserved by default until probe completes */ |
155 | static unsigned int gpmc_cs_map = ((1 << GPMC_CS_NUM) - 1); | 157 | static unsigned int gpmc_cs_map = ((1 << GPMC_CS_NUM) - 1); |
158 | static unsigned int gpmc_nr_waitpins; | ||
156 | static struct device *gpmc_dev; | 159 | static struct device *gpmc_dev; |
157 | static int gpmc_irq; | 160 | static int gpmc_irq; |
158 | static resource_size_t phys_base, mem_size; | 161 | static resource_size_t phys_base, mem_size; |
@@ -181,7 +184,7 @@ void gpmc_cs_write_reg(int cs, int idx, u32 val) | |||
181 | __raw_writel(val, reg_addr); | 184 | __raw_writel(val, reg_addr); |
182 | } | 185 | } |
183 | 186 | ||
184 | u32 gpmc_cs_read_reg(int cs, int idx) | 187 | static u32 gpmc_cs_read_reg(int cs, int idx) |
185 | { | 188 | { |
186 | void __iomem *reg_addr; | 189 | void __iomem *reg_addr; |
187 | 190 | ||
@@ -190,7 +193,7 @@ u32 gpmc_cs_read_reg(int cs, int idx) | |||
190 | } | 193 | } |
191 | 194 | ||
192 | /* TODO: Add support for gpmc_fck to clock framework and use it */ | 195 | /* TODO: Add support for gpmc_fck to clock framework and use it */ |
193 | unsigned long gpmc_get_fclk_period(void) | 196 | static unsigned long gpmc_get_fclk_period(void) |
194 | { | 197 | { |
195 | unsigned long rate = clk_get_rate(gpmc_l3_clk); | 198 | unsigned long rate = clk_get_rate(gpmc_l3_clk); |
196 | 199 | ||
@@ -205,7 +208,7 @@ unsigned long gpmc_get_fclk_period(void) | |||
205 | return rate; | 208 | return rate; |
206 | } | 209 | } |
207 | 210 | ||
208 | unsigned int gpmc_ns_to_ticks(unsigned int time_ns) | 211 | static unsigned int gpmc_ns_to_ticks(unsigned int time_ns) |
209 | { | 212 | { |
210 | unsigned long tick_ps; | 213 | unsigned long tick_ps; |
211 | 214 | ||
@@ -215,7 +218,7 @@ unsigned int gpmc_ns_to_ticks(unsigned int time_ns) | |||
215 | return (time_ns * 1000 + tick_ps - 1) / tick_ps; | 218 | return (time_ns * 1000 + tick_ps - 1) / tick_ps; |
216 | } | 219 | } |
217 | 220 | ||
218 | unsigned int gpmc_ps_to_ticks(unsigned int time_ps) | 221 | static unsigned int gpmc_ps_to_ticks(unsigned int time_ps) |
219 | { | 222 | { |
220 | unsigned long tick_ps; | 223 | unsigned long tick_ps; |
221 | 224 | ||
@@ -230,13 +233,6 @@ unsigned int gpmc_ticks_to_ns(unsigned int ticks) | |||
230 | return ticks * gpmc_get_fclk_period() / 1000; | 233 | return ticks * gpmc_get_fclk_period() / 1000; |
231 | } | 234 | } |
232 | 235 | ||
233 | unsigned int gpmc_round_ns_to_ticks(unsigned int time_ns) | ||
234 | { | ||
235 | unsigned long ticks = gpmc_ns_to_ticks(time_ns); | ||
236 | |||
237 | return ticks * gpmc_get_fclk_period() / 1000; | ||
238 | } | ||
239 | |||
240 | static unsigned int gpmc_ticks_to_ps(unsigned int ticks) | 236 | static unsigned int gpmc_ticks_to_ps(unsigned int ticks) |
241 | { | 237 | { |
242 | return ticks * gpmc_get_fclk_period(); | 238 | return ticks * gpmc_get_fclk_period(); |
@@ -405,11 +401,18 @@ int gpmc_cs_set_timings(int cs, const struct gpmc_timings *t) | |||
405 | return 0; | 401 | return 0; |
406 | } | 402 | } |
407 | 403 | ||
408 | static void gpmc_cs_enable_mem(int cs, u32 base, u32 size) | 404 | static int gpmc_cs_enable_mem(int cs, u32 base, u32 size) |
409 | { | 405 | { |
410 | u32 l; | 406 | u32 l; |
411 | u32 mask; | 407 | u32 mask; |
412 | 408 | ||
409 | /* | ||
410 | * Ensure that base address is aligned on a | ||
411 | * boundary equal to or greater than size. | ||
412 | */ | ||
413 | if (base & (size - 1)) | ||
414 | return -EINVAL; | ||
415 | |||
413 | mask = (1 << GPMC_SECTION_SHIFT) - size; | 416 | mask = (1 << GPMC_SECTION_SHIFT) - size; |
414 | l = gpmc_cs_read_reg(cs, GPMC_CS_CONFIG7); | 417 | l = gpmc_cs_read_reg(cs, GPMC_CS_CONFIG7); |
415 | l &= ~0x3f; | 418 | l &= ~0x3f; |
@@ -418,6 +421,8 @@ static void gpmc_cs_enable_mem(int cs, u32 base, u32 size) | |||
418 | l |= ((mask >> GPMC_CHUNK_SHIFT) & 0x0f) << 8; | 421 | l |= ((mask >> GPMC_CHUNK_SHIFT) & 0x0f) << 8; |
419 | l |= GPMC_CONFIG7_CSVALID; | 422 | l |= GPMC_CONFIG7_CSVALID; |
420 | gpmc_cs_write_reg(cs, GPMC_CS_CONFIG7, l); | 423 | gpmc_cs_write_reg(cs, GPMC_CS_CONFIG7, l); |
424 | |||
425 | return 0; | ||
421 | } | 426 | } |
422 | 427 | ||
423 | static void gpmc_cs_disable_mem(int cs) | 428 | static void gpmc_cs_disable_mem(int cs) |
@@ -448,22 +453,14 @@ static int gpmc_cs_mem_enabled(int cs) | |||
448 | return l & GPMC_CONFIG7_CSVALID; | 453 | return l & GPMC_CONFIG7_CSVALID; |
449 | } | 454 | } |
450 | 455 | ||
451 | int gpmc_cs_set_reserved(int cs, int reserved) | 456 | static void gpmc_cs_set_reserved(int cs, int reserved) |
452 | { | 457 | { |
453 | if (cs > GPMC_CS_NUM) | ||
454 | return -ENODEV; | ||
455 | |||
456 | gpmc_cs_map &= ~(1 << cs); | 458 | gpmc_cs_map &= ~(1 << cs); |
457 | gpmc_cs_map |= (reserved ? 1 : 0) << cs; | 459 | gpmc_cs_map |= (reserved ? 1 : 0) << cs; |
458 | |||
459 | return 0; | ||
460 | } | 460 | } |
461 | 461 | ||
462 | int gpmc_cs_reserved(int cs) | 462 | static bool gpmc_cs_reserved(int cs) |
463 | { | 463 | { |
464 | if (cs > GPMC_CS_NUM) | ||
465 | return -ENODEV; | ||
466 | |||
467 | return gpmc_cs_map & (1 << cs); | 464 | return gpmc_cs_map & (1 << cs); |
468 | } | 465 | } |
469 | 466 | ||
@@ -510,6 +507,39 @@ static int gpmc_cs_delete_mem(int cs) | |||
510 | return r; | 507 | return r; |
511 | } | 508 | } |
512 | 509 | ||
510 | /** | ||
511 | * gpmc_cs_remap - remaps a chip-select physical base address | ||
512 | * @cs: chip-select to remap | ||
513 | * @base: physical base address to re-map chip-select to | ||
514 | * | ||
515 | * Re-maps a chip-select to a new physical base address specified by | ||
516 | * "base". Returns 0 on success and appropriate negative error code | ||
517 | * on failure. | ||
518 | */ | ||
519 | static int gpmc_cs_remap(int cs, u32 base) | ||
520 | { | ||
521 | int ret; | ||
522 | u32 old_base, size; | ||
523 | |||
524 | if (cs > GPMC_CS_NUM) | ||
525 | return -ENODEV; | ||
526 | gpmc_cs_get_memconf(cs, &old_base, &size); | ||
527 | if (base == old_base) | ||
528 | return 0; | ||
529 | gpmc_cs_disable_mem(cs); | ||
530 | ret = gpmc_cs_delete_mem(cs); | ||
531 | if (ret < 0) | ||
532 | return ret; | ||
533 | ret = gpmc_cs_insert_mem(cs, base, size); | ||
534 | if (ret < 0) | ||
535 | return ret; | ||
536 | ret = gpmc_cs_enable_mem(cs, base, size); | ||
537 | if (ret < 0) | ||
538 | return ret; | ||
539 | |||
540 | return 0; | ||
541 | } | ||
542 | |||
513 | int gpmc_cs_request(int cs, unsigned long size, unsigned long *base) | 543 | int gpmc_cs_request(int cs, unsigned long size, unsigned long *base) |
514 | { | 544 | { |
515 | struct resource *res = &gpmc_cs_mem[cs]; | 545 | struct resource *res = &gpmc_cs_mem[cs]; |
@@ -535,7 +565,12 @@ int gpmc_cs_request(int cs, unsigned long size, unsigned long *base) | |||
535 | if (r < 0) | 565 | if (r < 0) |
536 | goto out; | 566 | goto out; |
537 | 567 | ||
538 | gpmc_cs_enable_mem(cs, res->start, resource_size(res)); | 568 | r = gpmc_cs_enable_mem(cs, res->start, resource_size(res)); |
569 | if (r < 0) { | ||
570 | release_resource(res); | ||
571 | goto out; | ||
572 | } | ||
573 | |||
539 | *base = res->start; | 574 | *base = res->start; |
540 | gpmc_cs_set_reserved(cs, 1); | 575 | gpmc_cs_set_reserved(cs, 1); |
541 | out: | 576 | out: |
@@ -561,16 +596,14 @@ void gpmc_cs_free(int cs) | |||
561 | EXPORT_SYMBOL(gpmc_cs_free); | 596 | EXPORT_SYMBOL(gpmc_cs_free); |
562 | 597 | ||
563 | /** | 598 | /** |
564 | * gpmc_cs_configure - write request to configure gpmc | 599 | * gpmc_configure - write request to configure gpmc |
565 | * @cs: chip select number | ||
566 | * @cmd: command type | 600 | * @cmd: command type |
567 | * @wval: value to write | 601 | * @wval: value to write |
568 | * @return status of the operation | 602 | * @return status of the operation |
569 | */ | 603 | */ |
570 | int gpmc_cs_configure(int cs, int cmd, int wval) | 604 | int gpmc_configure(int cmd, int wval) |
571 | { | 605 | { |
572 | int err = 0; | 606 | u32 regval; |
573 | u32 regval = 0; | ||
574 | 607 | ||
575 | switch (cmd) { | 608 | switch (cmd) { |
576 | case GPMC_ENABLE_IRQ: | 609 | case GPMC_ENABLE_IRQ: |
@@ -590,43 +623,14 @@ int gpmc_cs_configure(int cs, int cmd, int wval) | |||
590 | gpmc_write_reg(GPMC_CONFIG, regval); | 623 | gpmc_write_reg(GPMC_CONFIG, regval); |
591 | break; | 624 | break; |
592 | 625 | ||
593 | case GPMC_CONFIG_RDY_BSY: | ||
594 | regval = gpmc_cs_read_reg(cs, GPMC_CS_CONFIG1); | ||
595 | if (wval) | ||
596 | regval |= WR_RD_PIN_MONITORING; | ||
597 | else | ||
598 | regval &= ~WR_RD_PIN_MONITORING; | ||
599 | gpmc_cs_write_reg(cs, GPMC_CS_CONFIG1, regval); | ||
600 | break; | ||
601 | |||
602 | case GPMC_CONFIG_DEV_SIZE: | ||
603 | regval = gpmc_cs_read_reg(cs, GPMC_CS_CONFIG1); | ||
604 | |||
605 | /* clear 2 target bits */ | ||
606 | regval &= ~GPMC_CONFIG1_DEVICESIZE(3); | ||
607 | |||
608 | /* set the proper value */ | ||
609 | regval |= GPMC_CONFIG1_DEVICESIZE(wval); | ||
610 | |||
611 | gpmc_cs_write_reg(cs, GPMC_CS_CONFIG1, regval); | ||
612 | break; | ||
613 | |||
614 | case GPMC_CONFIG_DEV_TYPE: | ||
615 | regval = gpmc_cs_read_reg(cs, GPMC_CS_CONFIG1); | ||
616 | regval |= GPMC_CONFIG1_DEVICETYPE(wval); | ||
617 | if (wval == GPMC_DEVICETYPE_NOR) | ||
618 | regval |= GPMC_CONFIG1_MUXADDDATA; | ||
619 | gpmc_cs_write_reg(cs, GPMC_CS_CONFIG1, regval); | ||
620 | break; | ||
621 | |||
622 | default: | 626 | default: |
623 | printk(KERN_ERR "gpmc_configure_cs: Not supported\n"); | 627 | pr_err("%s: command not supported\n", __func__); |
624 | err = -EINVAL; | 628 | return -EINVAL; |
625 | } | 629 | } |
626 | 630 | ||
627 | return err; | 631 | return 0; |
628 | } | 632 | } |
629 | EXPORT_SYMBOL(gpmc_cs_configure); | 633 | EXPORT_SYMBOL(gpmc_configure); |
630 | 634 | ||
631 | void gpmc_update_nand_reg(struct gpmc_nand_regs *reg, int cs) | 635 | void gpmc_update_nand_reg(struct gpmc_nand_regs *reg, int cs) |
632 | { | 636 | { |
@@ -781,16 +785,16 @@ static void gpmc_mem_exit(void) | |||
781 | 785 | ||
782 | } | 786 | } |
783 | 787 | ||
784 | static int gpmc_mem_init(void) | 788 | static void gpmc_mem_init(void) |
785 | { | 789 | { |
786 | int cs, rc; | 790 | int cs; |
787 | unsigned long boot_rom_space = 0; | ||
788 | 791 | ||
789 | /* never allocate the first page, to facilitate bug detection; | 792 | /* |
790 | * even if we didn't boot from ROM. | 793 | * The first 1MB of GPMC address space is typically mapped to |
794 | * the internal ROM. Never allocate the first page, to | ||
795 | * facilitate bug detection; even if we didn't boot from ROM. | ||
791 | */ | 796 | */ |
792 | boot_rom_space = BOOT_ROM_SPACE; | 797 | gpmc_mem_root.start = SZ_1M; |
793 | gpmc_mem_root.start = GPMC_MEM_START + boot_rom_space; | ||
794 | gpmc_mem_root.end = GPMC_MEM_END; | 798 | gpmc_mem_root.end = GPMC_MEM_END; |
795 | 799 | ||
796 | /* Reserve all regions that has been set up by bootloader */ | 800 | /* Reserve all regions that has been set up by bootloader */ |
@@ -800,16 +804,12 @@ static int gpmc_mem_init(void) | |||
800 | if (!gpmc_cs_mem_enabled(cs)) | 804 | if (!gpmc_cs_mem_enabled(cs)) |
801 | continue; | 805 | continue; |
802 | gpmc_cs_get_memconf(cs, &base, &size); | 806 | gpmc_cs_get_memconf(cs, &base, &size); |
803 | rc = gpmc_cs_insert_mem(cs, base, size); | 807 | if (gpmc_cs_insert_mem(cs, base, size)) { |
804 | if (rc < 0) { | 808 | pr_warn("%s: disabling cs %d mapped at 0x%x-0x%x\n", |
805 | while (--cs >= 0) | 809 | __func__, cs, base, base + size); |
806 | if (gpmc_cs_mem_enabled(cs)) | 810 | gpmc_cs_disable_mem(cs); |
807 | gpmc_cs_delete_mem(cs); | ||
808 | return rc; | ||
809 | } | 811 | } |
810 | } | 812 | } |
811 | |||
812 | return 0; | ||
813 | } | 813 | } |
814 | 814 | ||
815 | static u32 gpmc_round_ps_to_sync_clk(u32 time_ps, u32 sync_clk) | 815 | static u32 gpmc_round_ps_to_sync_clk(u32 time_ps, u32 sync_clk) |
@@ -825,9 +825,9 @@ static u32 gpmc_round_ps_to_sync_clk(u32 time_ps, u32 sync_clk) | |||
825 | 825 | ||
826 | /* XXX: can the cycles be avoided ? */ | 826 | /* XXX: can the cycles be avoided ? */ |
827 | static int gpmc_calc_sync_read_timings(struct gpmc_timings *gpmc_t, | 827 | static int gpmc_calc_sync_read_timings(struct gpmc_timings *gpmc_t, |
828 | struct gpmc_device_timings *dev_t) | 828 | struct gpmc_device_timings *dev_t, |
829 | bool mux) | ||
829 | { | 830 | { |
830 | bool mux = dev_t->mux; | ||
831 | u32 temp; | 831 | u32 temp; |
832 | 832 | ||
833 | /* adv_rd_off */ | 833 | /* adv_rd_off */ |
@@ -880,9 +880,9 @@ static int gpmc_calc_sync_read_timings(struct gpmc_timings *gpmc_t, | |||
880 | } | 880 | } |
881 | 881 | ||
882 | static int gpmc_calc_sync_write_timings(struct gpmc_timings *gpmc_t, | 882 | static int gpmc_calc_sync_write_timings(struct gpmc_timings *gpmc_t, |
883 | struct gpmc_device_timings *dev_t) | 883 | struct gpmc_device_timings *dev_t, |
884 | bool mux) | ||
884 | { | 885 | { |
885 | bool mux = dev_t->mux; | ||
886 | u32 temp; | 886 | u32 temp; |
887 | 887 | ||
888 | /* adv_wr_off */ | 888 | /* adv_wr_off */ |
@@ -942,9 +942,9 @@ static int gpmc_calc_sync_write_timings(struct gpmc_timings *gpmc_t, | |||
942 | } | 942 | } |
943 | 943 | ||
944 | static int gpmc_calc_async_read_timings(struct gpmc_timings *gpmc_t, | 944 | static int gpmc_calc_async_read_timings(struct gpmc_timings *gpmc_t, |
945 | struct gpmc_device_timings *dev_t) | 945 | struct gpmc_device_timings *dev_t, |
946 | bool mux) | ||
946 | { | 947 | { |
947 | bool mux = dev_t->mux; | ||
948 | u32 temp; | 948 | u32 temp; |
949 | 949 | ||
950 | /* adv_rd_off */ | 950 | /* adv_rd_off */ |
@@ -982,9 +982,9 @@ static int gpmc_calc_async_read_timings(struct gpmc_timings *gpmc_t, | |||
982 | } | 982 | } |
983 | 983 | ||
984 | static int gpmc_calc_async_write_timings(struct gpmc_timings *gpmc_t, | 984 | static int gpmc_calc_async_write_timings(struct gpmc_timings *gpmc_t, |
985 | struct gpmc_device_timings *dev_t) | 985 | struct gpmc_device_timings *dev_t, |
986 | bool mux) | ||
986 | { | 987 | { |
987 | bool mux = dev_t->mux; | ||
988 | u32 temp; | 988 | u32 temp; |
989 | 989 | ||
990 | /* adv_wr_off */ | 990 | /* adv_wr_off */ |
@@ -1054,7 +1054,8 @@ static int gpmc_calc_sync_common_timings(struct gpmc_timings *gpmc_t, | |||
1054 | } | 1054 | } |
1055 | 1055 | ||
1056 | static int gpmc_calc_common_timings(struct gpmc_timings *gpmc_t, | 1056 | static int gpmc_calc_common_timings(struct gpmc_timings *gpmc_t, |
1057 | struct gpmc_device_timings *dev_t) | 1057 | struct gpmc_device_timings *dev_t, |
1058 | bool sync) | ||
1058 | { | 1059 | { |
1059 | u32 temp; | 1060 | u32 temp; |
1060 | 1061 | ||
@@ -1068,7 +1069,7 @@ static int gpmc_calc_common_timings(struct gpmc_timings *gpmc_t, | |||
1068 | gpmc_t->cs_on + dev_t->t_ce_avd); | 1069 | gpmc_t->cs_on + dev_t->t_ce_avd); |
1069 | gpmc_t->adv_on = gpmc_round_ps_to_ticks(temp); | 1070 | gpmc_t->adv_on = gpmc_round_ps_to_ticks(temp); |
1070 | 1071 | ||
1071 | if (dev_t->sync_write || dev_t->sync_read) | 1072 | if (sync) |
1072 | gpmc_calc_sync_common_timings(gpmc_t, dev_t); | 1073 | gpmc_calc_sync_common_timings(gpmc_t, dev_t); |
1073 | 1074 | ||
1074 | return 0; | 1075 | return 0; |
@@ -1103,21 +1104,29 @@ static void gpmc_convert_ps_to_ns(struct gpmc_timings *t) | |||
1103 | } | 1104 | } |
1104 | 1105 | ||
1105 | int gpmc_calc_timings(struct gpmc_timings *gpmc_t, | 1106 | int gpmc_calc_timings(struct gpmc_timings *gpmc_t, |
1106 | struct gpmc_device_timings *dev_t) | 1107 | struct gpmc_settings *gpmc_s, |
1108 | struct gpmc_device_timings *dev_t) | ||
1107 | { | 1109 | { |
1110 | bool mux = false, sync = false; | ||
1111 | |||
1112 | if (gpmc_s) { | ||
1113 | mux = gpmc_s->mux_add_data ? true : false; | ||
1114 | sync = (gpmc_s->sync_read || gpmc_s->sync_write); | ||
1115 | } | ||
1116 | |||
1108 | memset(gpmc_t, 0, sizeof(*gpmc_t)); | 1117 | memset(gpmc_t, 0, sizeof(*gpmc_t)); |
1109 | 1118 | ||
1110 | gpmc_calc_common_timings(gpmc_t, dev_t); | 1119 | gpmc_calc_common_timings(gpmc_t, dev_t, sync); |
1111 | 1120 | ||
1112 | if (dev_t->sync_read) | 1121 | if (gpmc_s && gpmc_s->sync_read) |
1113 | gpmc_calc_sync_read_timings(gpmc_t, dev_t); | 1122 | gpmc_calc_sync_read_timings(gpmc_t, dev_t, mux); |
1114 | else | 1123 | else |
1115 | gpmc_calc_async_read_timings(gpmc_t, dev_t); | 1124 | gpmc_calc_async_read_timings(gpmc_t, dev_t, mux); |
1116 | 1125 | ||
1117 | if (dev_t->sync_write) | 1126 | if (gpmc_s && gpmc_s->sync_write) |
1118 | gpmc_calc_sync_write_timings(gpmc_t, dev_t); | 1127 | gpmc_calc_sync_write_timings(gpmc_t, dev_t, mux); |
1119 | else | 1128 | else |
1120 | gpmc_calc_async_write_timings(gpmc_t, dev_t); | 1129 | gpmc_calc_async_write_timings(gpmc_t, dev_t, mux); |
1121 | 1130 | ||
1122 | /* TODO: remove, see function definition */ | 1131 | /* TODO: remove, see function definition */ |
1123 | gpmc_convert_ps_to_ns(gpmc_t); | 1132 | gpmc_convert_ps_to_ns(gpmc_t); |
@@ -1125,6 +1134,90 @@ int gpmc_calc_timings(struct gpmc_timings *gpmc_t, | |||
1125 | return 0; | 1134 | return 0; |
1126 | } | 1135 | } |
1127 | 1136 | ||
1137 | /** | ||
1138 | * gpmc_cs_program_settings - programs non-timing related settings | ||
1139 | * @cs: GPMC chip-select to program | ||
1140 | * @p: pointer to GPMC settings structure | ||
1141 | * | ||
1142 | * Programs non-timing related settings for a GPMC chip-select, such as | ||
1143 | * bus-width, burst configuration, etc. Function should be called once | ||
1144 | * for each chip-select that is being used and must be called before | ||
1145 | * calling gpmc_cs_set_timings() as timing parameters in the CONFIG1 | ||
1146 | * register will be initialised to zero by this function. Returns 0 on | ||
1147 | * success and appropriate negative error code on failure. | ||
1148 | */ | ||
1149 | int gpmc_cs_program_settings(int cs, struct gpmc_settings *p) | ||
1150 | { | ||
1151 | u32 config1; | ||
1152 | |||
1153 | if ((!p->device_width) || (p->device_width > GPMC_DEVWIDTH_16BIT)) { | ||
1154 | pr_err("%s: invalid width %d!", __func__, p->device_width); | ||
1155 | return -EINVAL; | ||
1156 | } | ||
1157 | |||
1158 | /* Address-data multiplexing not supported for NAND devices */ | ||
1159 | if (p->device_nand && p->mux_add_data) { | ||
1160 | pr_err("%s: invalid configuration!\n", __func__); | ||
1161 | return -EINVAL; | ||
1162 | } | ||
1163 | |||
1164 | if ((p->mux_add_data > GPMC_MUX_AD) || | ||
1165 | ((p->mux_add_data == GPMC_MUX_AAD) && | ||
1166 | !(gpmc_capability & GPMC_HAS_MUX_AAD))) { | ||
1167 | pr_err("%s: invalid multiplex configuration!\n", __func__); | ||
1168 | return -EINVAL; | ||
1169 | } | ||
1170 | |||
1171 | /* Page/burst mode supports lengths of 4, 8 and 16 bytes */ | ||
1172 | if (p->burst_read || p->burst_write) { | ||
1173 | switch (p->burst_len) { | ||
1174 | case GPMC_BURST_4: | ||
1175 | case GPMC_BURST_8: | ||
1176 | case GPMC_BURST_16: | ||
1177 | break; | ||
1178 | default: | ||
1179 | pr_err("%s: invalid page/burst-length (%d)\n", | ||
1180 | __func__, p->burst_len); | ||
1181 | return -EINVAL; | ||
1182 | } | ||
1183 | } | ||
1184 | |||
1185 | if ((p->wait_on_read || p->wait_on_write) && | ||
1186 | (p->wait_pin > gpmc_nr_waitpins)) { | ||
1187 | pr_err("%s: invalid wait-pin (%d)\n", __func__, p->wait_pin); | ||
1188 | return -EINVAL; | ||
1189 | } | ||
1190 | |||
1191 | config1 = GPMC_CONFIG1_DEVICESIZE((p->device_width - 1)); | ||
1192 | |||
1193 | if (p->sync_read) | ||
1194 | config1 |= GPMC_CONFIG1_READTYPE_SYNC; | ||
1195 | if (p->sync_write) | ||
1196 | config1 |= GPMC_CONFIG1_WRITETYPE_SYNC; | ||
1197 | if (p->wait_on_read) | ||
1198 | config1 |= GPMC_CONFIG1_WAIT_READ_MON; | ||
1199 | if (p->wait_on_write) | ||
1200 | config1 |= GPMC_CONFIG1_WAIT_WRITE_MON; | ||
1201 | if (p->wait_on_read || p->wait_on_write) | ||
1202 | config1 |= GPMC_CONFIG1_WAIT_PIN_SEL(p->wait_pin); | ||
1203 | if (p->device_nand) | ||
1204 | config1 |= GPMC_CONFIG1_DEVICETYPE(GPMC_DEVICETYPE_NAND); | ||
1205 | if (p->mux_add_data) | ||
1206 | config1 |= GPMC_CONFIG1_MUXTYPE(p->mux_add_data); | ||
1207 | if (p->burst_read) | ||
1208 | config1 |= GPMC_CONFIG1_READMULTIPLE_SUPP; | ||
1209 | if (p->burst_write) | ||
1210 | config1 |= GPMC_CONFIG1_WRITEMULTIPLE_SUPP; | ||
1211 | if (p->burst_read || p->burst_write) { | ||
1212 | config1 |= GPMC_CONFIG1_PAGE_LEN(p->burst_len >> 3); | ||
1213 | config1 |= p->burst_wrap ? GPMC_CONFIG1_WRAPBURST_SUPP : 0; | ||
1214 | } | ||
1215 | |||
1216 | gpmc_cs_write_reg(cs, GPMC_CS_CONFIG1, config1); | ||
1217 | |||
1218 | return 0; | ||
1219 | } | ||
1220 | |||
1128 | #ifdef CONFIG_OF | 1221 | #ifdef CONFIG_OF |
1129 | static struct of_device_id gpmc_dt_ids[] = { | 1222 | static struct of_device_id gpmc_dt_ids[] = { |
1130 | { .compatible = "ti,omap2420-gpmc" }, | 1223 | { .compatible = "ti,omap2420-gpmc" }, |
@@ -1136,70 +1229,110 @@ static struct of_device_id gpmc_dt_ids[] = { | |||
1136 | }; | 1229 | }; |
1137 | MODULE_DEVICE_TABLE(of, gpmc_dt_ids); | 1230 | MODULE_DEVICE_TABLE(of, gpmc_dt_ids); |
1138 | 1231 | ||
1232 | /** | ||
1233 | * gpmc_read_settings_dt - read gpmc settings from device-tree | ||
1234 | * @np: pointer to device-tree node for a gpmc child device | ||
1235 | * @p: pointer to gpmc settings structure | ||
1236 | * | ||
1237 | * Reads the GPMC settings for a GPMC child device from device-tree and | ||
1238 | * stores them in the GPMC settings structure passed. The GPMC settings | ||
1239 | * structure is initialised to zero by this function and so any | ||
1240 | * previously stored settings will be cleared. | ||
1241 | */ | ||
1242 | void gpmc_read_settings_dt(struct device_node *np, struct gpmc_settings *p) | ||
1243 | { | ||
1244 | memset(p, 0, sizeof(struct gpmc_settings)); | ||
1245 | |||
1246 | p->sync_read = of_property_read_bool(np, "gpmc,sync-read"); | ||
1247 | p->sync_write = of_property_read_bool(np, "gpmc,sync-write"); | ||
1248 | p->device_nand = of_property_read_bool(np, "gpmc,device-nand"); | ||
1249 | of_property_read_u32(np, "gpmc,device-width", &p->device_width); | ||
1250 | of_property_read_u32(np, "gpmc,mux-add-data", &p->mux_add_data); | ||
1251 | |||
1252 | if (!of_property_read_u32(np, "gpmc,burst-length", &p->burst_len)) { | ||
1253 | p->burst_wrap = of_property_read_bool(np, "gpmc,burst-wrap"); | ||
1254 | p->burst_read = of_property_read_bool(np, "gpmc,burst-read"); | ||
1255 | p->burst_write = of_property_read_bool(np, "gpmc,burst-write"); | ||
1256 | if (!p->burst_read && !p->burst_write) | ||
1257 | pr_warn("%s: page/burst-length set but not used!\n", | ||
1258 | __func__); | ||
1259 | } | ||
1260 | |||
1261 | if (!of_property_read_u32(np, "gpmc,wait-pin", &p->wait_pin)) { | ||
1262 | p->wait_on_read = of_property_read_bool(np, | ||
1263 | "gpmc,wait-on-read"); | ||
1264 | p->wait_on_write = of_property_read_bool(np, | ||
1265 | "gpmc,wait-on-write"); | ||
1266 | if (!p->wait_on_read && !p->wait_on_write) | ||
1267 | pr_warn("%s: read/write wait monitoring not enabled!\n", | ||
1268 | __func__); | ||
1269 | } | ||
1270 | } | ||
1271 | |||
1139 | static void __maybe_unused gpmc_read_timings_dt(struct device_node *np, | 1272 | static void __maybe_unused gpmc_read_timings_dt(struct device_node *np, |
1140 | struct gpmc_timings *gpmc_t) | 1273 | struct gpmc_timings *gpmc_t) |
1141 | { | 1274 | { |
1142 | u32 val; | 1275 | struct gpmc_bool_timings *p; |
1276 | |||
1277 | if (!np || !gpmc_t) | ||
1278 | return; | ||
1143 | 1279 | ||
1144 | memset(gpmc_t, 0, sizeof(*gpmc_t)); | 1280 | memset(gpmc_t, 0, sizeof(*gpmc_t)); |
1145 | 1281 | ||
1146 | /* minimum clock period for syncronous mode */ | 1282 | /* minimum clock period for syncronous mode */ |
1147 | if (!of_property_read_u32(np, "gpmc,sync-clk", &val)) | 1283 | of_property_read_u32(np, "gpmc,sync-clk-ps", &gpmc_t->sync_clk); |
1148 | gpmc_t->sync_clk = val; | ||
1149 | 1284 | ||
1150 | /* chip select timtings */ | 1285 | /* chip select timtings */ |
1151 | if (!of_property_read_u32(np, "gpmc,cs-on", &val)) | 1286 | of_property_read_u32(np, "gpmc,cs-on-ns", &gpmc_t->cs_on); |
1152 | gpmc_t->cs_on = val; | 1287 | of_property_read_u32(np, "gpmc,cs-rd-off-ns", &gpmc_t->cs_rd_off); |
1153 | 1288 | of_property_read_u32(np, "gpmc,cs-wr-off-ns", &gpmc_t->cs_wr_off); | |
1154 | if (!of_property_read_u32(np, "gpmc,cs-rd-off", &val)) | ||
1155 | gpmc_t->cs_rd_off = val; | ||
1156 | |||
1157 | if (!of_property_read_u32(np, "gpmc,cs-wr-off", &val)) | ||
1158 | gpmc_t->cs_wr_off = val; | ||
1159 | 1289 | ||
1160 | /* ADV signal timings */ | 1290 | /* ADV signal timings */ |
1161 | if (!of_property_read_u32(np, "gpmc,adv-on", &val)) | 1291 | of_property_read_u32(np, "gpmc,adv-on-ns", &gpmc_t->adv_on); |
1162 | gpmc_t->adv_on = val; | 1292 | of_property_read_u32(np, "gpmc,adv-rd-off-ns", &gpmc_t->adv_rd_off); |
1163 | 1293 | of_property_read_u32(np, "gpmc,adv-wr-off-ns", &gpmc_t->adv_wr_off); | |
1164 | if (!of_property_read_u32(np, "gpmc,adv-rd-off", &val)) | ||
1165 | gpmc_t->adv_rd_off = val; | ||
1166 | |||
1167 | if (!of_property_read_u32(np, "gpmc,adv-wr-off", &val)) | ||
1168 | gpmc_t->adv_wr_off = val; | ||
1169 | 1294 | ||
1170 | /* WE signal timings */ | 1295 | /* WE signal timings */ |
1171 | if (!of_property_read_u32(np, "gpmc,we-on", &val)) | 1296 | of_property_read_u32(np, "gpmc,we-on-ns", &gpmc_t->we_on); |
1172 | gpmc_t->we_on = val; | 1297 | of_property_read_u32(np, "gpmc,we-off-ns", &gpmc_t->we_off); |
1173 | |||
1174 | if (!of_property_read_u32(np, "gpmc,we-off", &val)) | ||
1175 | gpmc_t->we_off = val; | ||
1176 | 1298 | ||
1177 | /* OE signal timings */ | 1299 | /* OE signal timings */ |
1178 | if (!of_property_read_u32(np, "gpmc,oe-on", &val)) | 1300 | of_property_read_u32(np, "gpmc,oe-on-ns", &gpmc_t->oe_on); |
1179 | gpmc_t->oe_on = val; | 1301 | of_property_read_u32(np, "gpmc,oe-off-ns", &gpmc_t->oe_off); |
1180 | |||
1181 | if (!of_property_read_u32(np, "gpmc,oe-off", &val)) | ||
1182 | gpmc_t->oe_off = val; | ||
1183 | 1302 | ||
1184 | /* access and cycle timings */ | 1303 | /* access and cycle timings */ |
1185 | if (!of_property_read_u32(np, "gpmc,page-burst-access", &val)) | 1304 | of_property_read_u32(np, "gpmc,page-burst-access-ns", |
1186 | gpmc_t->page_burst_access = val; | 1305 | &gpmc_t->page_burst_access); |
1187 | 1306 | of_property_read_u32(np, "gpmc,access-ns", &gpmc_t->access); | |
1188 | if (!of_property_read_u32(np, "gpmc,access", &val)) | 1307 | of_property_read_u32(np, "gpmc,rd-cycle-ns", &gpmc_t->rd_cycle); |
1189 | gpmc_t->access = val; | 1308 | of_property_read_u32(np, "gpmc,wr-cycle-ns", &gpmc_t->wr_cycle); |
1190 | 1309 | of_property_read_u32(np, "gpmc,bus-turnaround-ns", | |
1191 | if (!of_property_read_u32(np, "gpmc,rd-cycle", &val)) | 1310 | &gpmc_t->bus_turnaround); |
1192 | gpmc_t->rd_cycle = val; | 1311 | of_property_read_u32(np, "gpmc,cycle2cycle-delay-ns", |
1193 | 1312 | &gpmc_t->cycle2cycle_delay); | |
1194 | if (!of_property_read_u32(np, "gpmc,wr-cycle", &val)) | 1313 | of_property_read_u32(np, "gpmc,wait-monitoring-ns", |
1195 | gpmc_t->wr_cycle = val; | 1314 | &gpmc_t->wait_monitoring); |
1196 | 1315 | of_property_read_u32(np, "gpmc,clk-activation-ns", | |
1197 | /* only for OMAP3430 */ | 1316 | &gpmc_t->clk_activation); |
1198 | if (!of_property_read_u32(np, "gpmc,wr-access", &val)) | 1317 | |
1199 | gpmc_t->wr_access = val; | 1318 | /* only applicable to OMAP3+ */ |
1200 | 1319 | of_property_read_u32(np, "gpmc,wr-access-ns", &gpmc_t->wr_access); | |
1201 | if (!of_property_read_u32(np, "gpmc,wr-data-mux-bus", &val)) | 1320 | of_property_read_u32(np, "gpmc,wr-data-mux-bus-ns", |
1202 | gpmc_t->wr_data_mux_bus = val; | 1321 | &gpmc_t->wr_data_mux_bus); |
1322 | |||
1323 | /* bool timing parameters */ | ||
1324 | p = &gpmc_t->bool_timings; | ||
1325 | |||
1326 | p->cycle2cyclediffcsen = | ||
1327 | of_property_read_bool(np, "gpmc,cycle2cycle-diffcsen"); | ||
1328 | p->cycle2cyclesamecsen = | ||
1329 | of_property_read_bool(np, "gpmc,cycle2cycle-samecsen"); | ||
1330 | p->we_extra_delay = of_property_read_bool(np, "gpmc,we-extra-delay"); | ||
1331 | p->oe_extra_delay = of_property_read_bool(np, "gpmc,oe-extra-delay"); | ||
1332 | p->adv_extra_delay = of_property_read_bool(np, "gpmc,adv-extra-delay"); | ||
1333 | p->cs_extra_delay = of_property_read_bool(np, "gpmc,cs-extra-delay"); | ||
1334 | p->time_para_granularity = | ||
1335 | of_property_read_bool(np, "gpmc,time-para-granularity"); | ||
1203 | } | 1336 | } |
1204 | 1337 | ||
1205 | #ifdef CONFIG_MTD_NAND | 1338 | #ifdef CONFIG_MTD_NAND |
@@ -1295,6 +1428,81 @@ static int gpmc_probe_onenand_child(struct platform_device *pdev, | |||
1295 | } | 1428 | } |
1296 | #endif | 1429 | #endif |
1297 | 1430 | ||
1431 | /** | ||
1432 | * gpmc_probe_generic_child - configures the gpmc for a child device | ||
1433 | * @pdev: pointer to gpmc platform device | ||
1434 | * @child: pointer to device-tree node for child device | ||
1435 | * | ||
1436 | * Allocates and configures a GPMC chip-select for a child device. | ||
1437 | * Returns 0 on success and appropriate negative error code on failure. | ||
1438 | */ | ||
1439 | static int gpmc_probe_generic_child(struct platform_device *pdev, | ||
1440 | struct device_node *child) | ||
1441 | { | ||
1442 | struct gpmc_settings gpmc_s; | ||
1443 | struct gpmc_timings gpmc_t; | ||
1444 | struct resource res; | ||
1445 | unsigned long base; | ||
1446 | int ret, cs; | ||
1447 | |||
1448 | if (of_property_read_u32(child, "reg", &cs) < 0) { | ||
1449 | dev_err(&pdev->dev, "%s has no 'reg' property\n", | ||
1450 | child->full_name); | ||
1451 | return -ENODEV; | ||
1452 | } | ||
1453 | |||
1454 | if (of_address_to_resource(child, 0, &res) < 0) { | ||
1455 | dev_err(&pdev->dev, "%s has malformed 'reg' property\n", | ||
1456 | child->full_name); | ||
1457 | return -ENODEV; | ||
1458 | } | ||
1459 | |||
1460 | ret = gpmc_cs_request(cs, resource_size(&res), &base); | ||
1461 | if (ret < 0) { | ||
1462 | dev_err(&pdev->dev, "cannot request GPMC CS %d\n", cs); | ||
1463 | return ret; | ||
1464 | } | ||
1465 | |||
1466 | /* | ||
1467 | * FIXME: gpmc_cs_request() will map the CS to an arbitary | ||
1468 | * location in the gpmc address space. When booting with | ||
1469 | * device-tree we want the NOR flash to be mapped to the | ||
1470 | * location specified in the device-tree blob. So remap the | ||
1471 | * CS to this location. Once DT migration is complete should | ||
1472 | * just make gpmc_cs_request() map a specific address. | ||
1473 | */ | ||
1474 | ret = gpmc_cs_remap(cs, res.start); | ||
1475 | if (ret < 0) { | ||
1476 | dev_err(&pdev->dev, "cannot remap GPMC CS %d to 0x%x\n", | ||
1477 | cs, res.start); | ||
1478 | goto err; | ||
1479 | } | ||
1480 | |||
1481 | gpmc_read_settings_dt(child, &gpmc_s); | ||
1482 | |||
1483 | ret = of_property_read_u32(child, "bank-width", &gpmc_s.device_width); | ||
1484 | if (ret < 0) | ||
1485 | goto err; | ||
1486 | |||
1487 | ret = gpmc_cs_program_settings(cs, &gpmc_s); | ||
1488 | if (ret < 0) | ||
1489 | goto err; | ||
1490 | |||
1491 | gpmc_read_timings_dt(child, &gpmc_t); | ||
1492 | gpmc_cs_set_timings(cs, &gpmc_t); | ||
1493 | |||
1494 | if (of_platform_device_create(child, NULL, &pdev->dev)) | ||
1495 | return 0; | ||
1496 | |||
1497 | dev_err(&pdev->dev, "failed to create gpmc child %s\n", child->name); | ||
1498 | ret = -ENODEV; | ||
1499 | |||
1500 | err: | ||
1501 | gpmc_cs_free(cs); | ||
1502 | |||
1503 | return ret; | ||
1504 | } | ||
1505 | |||
1298 | static int gpmc_probe_dt(struct platform_device *pdev) | 1506 | static int gpmc_probe_dt(struct platform_device *pdev) |
1299 | { | 1507 | { |
1300 | int ret; | 1508 | int ret; |
@@ -1305,6 +1513,13 @@ static int gpmc_probe_dt(struct platform_device *pdev) | |||
1305 | if (!of_id) | 1513 | if (!of_id) |
1306 | return 0; | 1514 | return 0; |
1307 | 1515 | ||
1516 | ret = of_property_read_u32(pdev->dev.of_node, "gpmc,num-waitpins", | ||
1517 | &gpmc_nr_waitpins); | ||
1518 | if (ret < 0) { | ||
1519 | pr_err("%s: number of wait pins not found!\n", __func__); | ||
1520 | return ret; | ||
1521 | } | ||
1522 | |||
1308 | for_each_node_by_name(child, "nand") { | 1523 | for_each_node_by_name(child, "nand") { |
1309 | ret = gpmc_probe_nand_child(pdev, child); | 1524 | ret = gpmc_probe_nand_child(pdev, child); |
1310 | if (ret < 0) { | 1525 | if (ret < 0) { |
@@ -1320,6 +1535,23 @@ static int gpmc_probe_dt(struct platform_device *pdev) | |||
1320 | return ret; | 1535 | return ret; |
1321 | } | 1536 | } |
1322 | } | 1537 | } |
1538 | |||
1539 | for_each_node_by_name(child, "nor") { | ||
1540 | ret = gpmc_probe_generic_child(pdev, child); | ||
1541 | if (ret < 0) { | ||
1542 | of_node_put(child); | ||
1543 | return ret; | ||
1544 | } | ||
1545 | } | ||
1546 | |||
1547 | for_each_node_by_name(child, "ethernet") { | ||
1548 | ret = gpmc_probe_generic_child(pdev, child); | ||
1549 | if (ret < 0) { | ||
1550 | of_node_put(child); | ||
1551 | return ret; | ||
1552 | } | ||
1553 | } | ||
1554 | |||
1323 | return 0; | 1555 | return 0; |
1324 | } | 1556 | } |
1325 | #else | 1557 | #else |
@@ -1364,18 +1596,27 @@ static int gpmc_probe(struct platform_device *pdev) | |||
1364 | gpmc_dev = &pdev->dev; | 1596 | gpmc_dev = &pdev->dev; |
1365 | 1597 | ||
1366 | l = gpmc_read_reg(GPMC_REVISION); | 1598 | l = gpmc_read_reg(GPMC_REVISION); |
1599 | |||
1600 | /* | ||
1601 | * FIXME: Once device-tree migration is complete the below flags | ||
1602 | * should be populated based upon the device-tree compatible | ||
1603 | * string. For now just use the IP revision. OMAP3+ devices have | ||
1604 | * the wr_access and wr_data_mux_bus register fields. OMAP4+ | ||
1605 | * devices support the addr-addr-data multiplex protocol. | ||
1606 | * | ||
1607 | * GPMC IP revisions: | ||
1608 | * - OMAP24xx = 2.0 | ||
1609 | * - OMAP3xxx = 5.0 | ||
1610 | * - OMAP44xx/54xx/AM335x = 6.0 | ||
1611 | */ | ||
1367 | if (GPMC_REVISION_MAJOR(l) > 0x4) | 1612 | if (GPMC_REVISION_MAJOR(l) > 0x4) |
1368 | gpmc_capability = GPMC_HAS_WR_ACCESS | GPMC_HAS_WR_DATA_MUX_BUS; | 1613 | gpmc_capability = GPMC_HAS_WR_ACCESS | GPMC_HAS_WR_DATA_MUX_BUS; |
1614 | if (GPMC_REVISION_MAJOR(l) > 0x5) | ||
1615 | gpmc_capability |= GPMC_HAS_MUX_AAD; | ||
1369 | dev_info(gpmc_dev, "GPMC revision %d.%d\n", GPMC_REVISION_MAJOR(l), | 1616 | dev_info(gpmc_dev, "GPMC revision %d.%d\n", GPMC_REVISION_MAJOR(l), |
1370 | GPMC_REVISION_MINOR(l)); | 1617 | GPMC_REVISION_MINOR(l)); |
1371 | 1618 | ||
1372 | rc = gpmc_mem_init(); | 1619 | gpmc_mem_init(); |
1373 | if (rc < 0) { | ||
1374 | clk_disable_unprepare(gpmc_l3_clk); | ||
1375 | clk_put(gpmc_l3_clk); | ||
1376 | dev_err(gpmc_dev, "failed to reserve memory\n"); | ||
1377 | return rc; | ||
1378 | } | ||
1379 | 1620 | ||
1380 | if (gpmc_setup_irq() < 0) | 1621 | if (gpmc_setup_irq() < 0) |
1381 | dev_warn(gpmc_dev, "gpmc_setup_irq failed\n"); | 1622 | dev_warn(gpmc_dev, "gpmc_setup_irq failed\n"); |
@@ -1383,6 +1624,9 @@ static int gpmc_probe(struct platform_device *pdev) | |||
1383 | /* Now the GPMC is initialised, unreserve the chip-selects */ | 1624 | /* Now the GPMC is initialised, unreserve the chip-selects */ |
1384 | gpmc_cs_map = 0; | 1625 | gpmc_cs_map = 0; |
1385 | 1626 | ||
1627 | if (!pdev->dev.of_node) | ||
1628 | gpmc_nr_waitpins = GPMC_NR_WAITPINS; | ||
1629 | |||
1386 | rc = gpmc_probe_dt(pdev); | 1630 | rc = gpmc_probe_dt(pdev); |
1387 | if (rc < 0) { | 1631 | if (rc < 0) { |
1388 | clk_disable_unprepare(gpmc_l3_clk); | 1632 | clk_disable_unprepare(gpmc_l3_clk); |
diff --git a/arch/arm/mach-omap2/gpmc.h b/arch/arm/mach-omap2/gpmc.h index fe0a844d5007..707f6d58edd5 100644 --- a/arch/arm/mach-omap2/gpmc.h +++ b/arch/arm/mach-omap2/gpmc.h | |||
@@ -58,7 +58,7 @@ | |||
58 | #define GPMC_CONFIG1_DEVICESIZE_16 GPMC_CONFIG1_DEVICESIZE(1) | 58 | #define GPMC_CONFIG1_DEVICESIZE_16 GPMC_CONFIG1_DEVICESIZE(1) |
59 | #define GPMC_CONFIG1_DEVICETYPE(val) ((val & 3) << 10) | 59 | #define GPMC_CONFIG1_DEVICETYPE(val) ((val & 3) << 10) |
60 | #define GPMC_CONFIG1_DEVICETYPE_NOR GPMC_CONFIG1_DEVICETYPE(0) | 60 | #define GPMC_CONFIG1_DEVICETYPE_NOR GPMC_CONFIG1_DEVICETYPE(0) |
61 | #define GPMC_CONFIG1_MUXADDDATA (1 << 9) | 61 | #define GPMC_CONFIG1_MUXTYPE(val) ((val & 3) << 8) |
62 | #define GPMC_CONFIG1_TIME_PARA_GRAN (1 << 4) | 62 | #define GPMC_CONFIG1_TIME_PARA_GRAN (1 << 4) |
63 | #define GPMC_CONFIG1_FCLK_DIV(val) (val & 3) | 63 | #define GPMC_CONFIG1_FCLK_DIV(val) (val & 3) |
64 | #define GPMC_CONFIG1_FCLK_DIV2 (GPMC_CONFIG1_FCLK_DIV(1)) | 64 | #define GPMC_CONFIG1_FCLK_DIV2 (GPMC_CONFIG1_FCLK_DIV(1)) |
@@ -73,6 +73,13 @@ | |||
73 | #define GPMC_IRQ_FIFOEVENTENABLE 0x01 | 73 | #define GPMC_IRQ_FIFOEVENTENABLE 0x01 |
74 | #define GPMC_IRQ_COUNT_EVENT 0x02 | 74 | #define GPMC_IRQ_COUNT_EVENT 0x02 |
75 | 75 | ||
76 | #define GPMC_BURST_4 4 /* 4 word burst */ | ||
77 | #define GPMC_BURST_8 8 /* 8 word burst */ | ||
78 | #define GPMC_BURST_16 16 /* 16 word burst */ | ||
79 | #define GPMC_DEVWIDTH_8BIT 1 /* 8-bit device width */ | ||
80 | #define GPMC_DEVWIDTH_16BIT 2 /* 16-bit device width */ | ||
81 | #define GPMC_MUX_AAD 1 /* Addr-Addr-Data multiplex */ | ||
82 | #define GPMC_MUX_AD 2 /* Addr-Data multiplex */ | ||
76 | 83 | ||
77 | /* bool type time settings */ | 84 | /* bool type time settings */ |
78 | struct gpmc_bool_timings { | 85 | struct gpmc_bool_timings { |
@@ -178,10 +185,6 @@ struct gpmc_device_timings { | |||
178 | u8 cyc_wpl; /* write deassertion time in cycles */ | 185 | u8 cyc_wpl; /* write deassertion time in cycles */ |
179 | u32 cyc_iaa; /* initial access time in cycles */ | 186 | u32 cyc_iaa; /* initial access time in cycles */ |
180 | 187 | ||
181 | bool mux; /* address & data muxed */ | ||
182 | bool sync_write;/* synchronous write */ | ||
183 | bool sync_read; /* synchronous read */ | ||
184 | |||
185 | /* extra delays */ | 188 | /* extra delays */ |
186 | bool ce_xdelay; | 189 | bool ce_xdelay; |
187 | bool avd_xdelay; | 190 | bool avd_xdelay; |
@@ -189,28 +192,40 @@ struct gpmc_device_timings { | |||
189 | bool we_xdelay; | 192 | bool we_xdelay; |
190 | }; | 193 | }; |
191 | 194 | ||
195 | struct gpmc_settings { | ||
196 | bool burst_wrap; /* enables wrap bursting */ | ||
197 | bool burst_read; /* enables read page/burst mode */ | ||
198 | bool burst_write; /* enables write page/burst mode */ | ||
199 | bool device_nand; /* device is NAND */ | ||
200 | bool sync_read; /* enables synchronous reads */ | ||
201 | bool sync_write; /* enables synchronous writes */ | ||
202 | bool wait_on_read; /* monitor wait on reads */ | ||
203 | bool wait_on_write; /* monitor wait on writes */ | ||
204 | u32 burst_len; /* page/burst length */ | ||
205 | u32 device_width; /* device bus width (8 or 16 bit) */ | ||
206 | u32 mux_add_data; /* multiplex address & data */ | ||
207 | u32 wait_pin; /* wait-pin to be used */ | ||
208 | }; | ||
209 | |||
192 | extern int gpmc_calc_timings(struct gpmc_timings *gpmc_t, | 210 | extern int gpmc_calc_timings(struct gpmc_timings *gpmc_t, |
193 | struct gpmc_device_timings *dev_t); | 211 | struct gpmc_settings *gpmc_s, |
212 | struct gpmc_device_timings *dev_t); | ||
194 | 213 | ||
195 | extern void gpmc_update_nand_reg(struct gpmc_nand_regs *reg, int cs); | 214 | extern void gpmc_update_nand_reg(struct gpmc_nand_regs *reg, int cs); |
196 | extern int gpmc_get_client_irq(unsigned irq_config); | 215 | extern int gpmc_get_client_irq(unsigned irq_config); |
197 | 216 | ||
198 | extern unsigned int gpmc_ns_to_ticks(unsigned int time_ns); | ||
199 | extern unsigned int gpmc_ps_to_ticks(unsigned int time_ps); | ||
200 | extern unsigned int gpmc_ticks_to_ns(unsigned int ticks); | 217 | extern unsigned int gpmc_ticks_to_ns(unsigned int ticks); |
201 | extern unsigned int gpmc_round_ns_to_ticks(unsigned int time_ns); | ||
202 | extern unsigned long gpmc_get_fclk_period(void); | ||
203 | 218 | ||
204 | extern void gpmc_cs_write_reg(int cs, int idx, u32 val); | 219 | extern void gpmc_cs_write_reg(int cs, int idx, u32 val); |
205 | extern u32 gpmc_cs_read_reg(int cs, int idx); | ||
206 | extern int gpmc_calc_divider(unsigned int sync_clk); | 220 | extern int gpmc_calc_divider(unsigned int sync_clk); |
207 | extern int gpmc_cs_set_timings(int cs, const struct gpmc_timings *t); | 221 | extern int gpmc_cs_set_timings(int cs, const struct gpmc_timings *t); |
222 | extern int gpmc_cs_program_settings(int cs, struct gpmc_settings *p); | ||
208 | extern int gpmc_cs_request(int cs, unsigned long size, unsigned long *base); | 223 | extern int gpmc_cs_request(int cs, unsigned long size, unsigned long *base); |
209 | extern void gpmc_cs_free(int cs); | 224 | extern void gpmc_cs_free(int cs); |
210 | extern int gpmc_cs_set_reserved(int cs, int reserved); | ||
211 | extern int gpmc_cs_reserved(int cs); | ||
212 | extern void omap3_gpmc_save_context(void); | 225 | extern void omap3_gpmc_save_context(void); |
213 | extern void omap3_gpmc_restore_context(void); | 226 | extern void omap3_gpmc_restore_context(void); |
214 | extern int gpmc_cs_configure(int cs, int cmd, int wval); | 227 | extern int gpmc_configure(int cmd, int wval); |
228 | extern void gpmc_read_settings_dt(struct device_node *np, | ||
229 | struct gpmc_settings *p); | ||
215 | 230 | ||
216 | #endif | 231 | #endif |
diff --git a/arch/arm/mach-omap2/timer.c b/arch/arm/mach-omap2/timer.c index 63e6384fa72e..f12aa6c15da4 100644 --- a/arch/arm/mach-omap2/timer.c +++ b/arch/arm/mach-omap2/timer.c | |||
@@ -57,16 +57,6 @@ | |||
57 | #include "common.h" | 57 | #include "common.h" |
58 | #include "powerdomain.h" | 58 | #include "powerdomain.h" |
59 | 59 | ||
60 | /* Parent clocks, eventually these will come from the clock framework */ | ||
61 | |||
62 | #define OMAP2_MPU_SOURCE "sys_ck" | ||
63 | #define OMAP3_MPU_SOURCE OMAP2_MPU_SOURCE | ||
64 | #define OMAP4_MPU_SOURCE "sys_clkin_ck" | ||
65 | #define OMAP5_MPU_SOURCE "sys_clkin" | ||
66 | #define OMAP2_32K_SOURCE "func_32k_ck" | ||
67 | #define OMAP3_32K_SOURCE "omap_32k_fck" | ||
68 | #define OMAP4_32K_SOURCE "sys_32k_ck" | ||
69 | |||
70 | #define REALTIME_COUNTER_BASE 0x48243200 | 60 | #define REALTIME_COUNTER_BASE 0x48243200 |
71 | #define INCREMENTER_NUMERATOR_OFFSET 0x10 | 61 | #define INCREMENTER_NUMERATOR_OFFSET 0x10 |
72 | #define INCREMENTER_DENUMERATOR_RELOAD_OFFSET 0x14 | 62 | #define INCREMENTER_DENUMERATOR_RELOAD_OFFSET 0x14 |
@@ -130,7 +120,6 @@ static void omap2_gp_timer_set_mode(enum clock_event_mode mode, | |||
130 | } | 120 | } |
131 | 121 | ||
132 | static struct clock_event_device clockevent_gpt = { | 122 | static struct clock_event_device clockevent_gpt = { |
133 | .name = "gp_timer", | ||
134 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, | 123 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, |
135 | .rating = 300, | 124 | .rating = 300, |
136 | .set_next_event = omap2_gp_timer_set_next_event, | 125 | .set_next_event = omap2_gp_timer_set_next_event, |
@@ -171,6 +160,12 @@ static struct device_node * __init omap_get_timer_dt(struct of_device_id *match, | |||
171 | if (property && !of_get_property(np, property, NULL)) | 160 | if (property && !of_get_property(np, property, NULL)) |
172 | continue; | 161 | continue; |
173 | 162 | ||
163 | if (!property && (of_get_property(np, "ti,timer-alwon", NULL) || | ||
164 | of_get_property(np, "ti,timer-dsp", NULL) || | ||
165 | of_get_property(np, "ti,timer-pwm", NULL) || | ||
166 | of_get_property(np, "ti,timer-secure", NULL))) | ||
167 | continue; | ||
168 | |||
174 | of_add_property(np, &device_disabled); | 169 | of_add_property(np, &device_disabled); |
175 | return np; | 170 | return np; |
176 | } | 171 | } |
@@ -215,16 +210,17 @@ static u32 __init omap_dm_timer_get_errata(void) | |||
215 | } | 210 | } |
216 | 211 | ||
217 | static int __init omap_dm_timer_init_one(struct omap_dm_timer *timer, | 212 | static int __init omap_dm_timer_init_one(struct omap_dm_timer *timer, |
218 | int gptimer_id, | 213 | const char *fck_source, |
219 | const char *fck_source, | 214 | const char *property, |
220 | const char *property, | 215 | const char **timer_name, |
221 | int posted) | 216 | int posted) |
222 | { | 217 | { |
223 | char name[10]; /* 10 = sizeof("gptXX_Xck0") */ | 218 | char name[10]; /* 10 = sizeof("gptXX_Xck0") */ |
224 | const char *oh_name; | 219 | const char *oh_name; |
225 | struct device_node *np; | 220 | struct device_node *np; |
226 | struct omap_hwmod *oh; | 221 | struct omap_hwmod *oh; |
227 | struct resource irq, mem; | 222 | struct resource irq, mem; |
223 | struct clk *src; | ||
228 | int r = 0; | 224 | int r = 0; |
229 | 225 | ||
230 | if (of_have_populated_dt()) { | 226 | if (of_have_populated_dt()) { |
@@ -244,10 +240,10 @@ static int __init omap_dm_timer_init_one(struct omap_dm_timer *timer, | |||
244 | 240 | ||
245 | of_node_put(np); | 241 | of_node_put(np); |
246 | } else { | 242 | } else { |
247 | if (omap_dm_timer_reserve_systimer(gptimer_id)) | 243 | if (omap_dm_timer_reserve_systimer(timer->id)) |
248 | return -ENODEV; | 244 | return -ENODEV; |
249 | 245 | ||
250 | sprintf(name, "timer%d", gptimer_id); | 246 | sprintf(name, "timer%d", timer->id); |
251 | oh_name = name; | 247 | oh_name = name; |
252 | } | 248 | } |
253 | 249 | ||
@@ -255,6 +251,8 @@ static int __init omap_dm_timer_init_one(struct omap_dm_timer *timer, | |||
255 | if (!oh) | 251 | if (!oh) |
256 | return -ENODEV; | 252 | return -ENODEV; |
257 | 253 | ||
254 | *timer_name = oh->name; | ||
255 | |||
258 | if (!of_have_populated_dt()) { | 256 | if (!of_have_populated_dt()) { |
259 | r = omap_hwmod_get_resource_byname(oh, IORESOURCE_IRQ, NULL, | 257 | r = omap_hwmod_get_resource_byname(oh, IORESOURCE_IRQ, NULL, |
260 | &irq); | 258 | &irq); |
@@ -277,24 +275,24 @@ static int __init omap_dm_timer_init_one(struct omap_dm_timer *timer, | |||
277 | /* After the dmtimer is using hwmod these clocks won't be needed */ | 275 | /* After the dmtimer is using hwmod these clocks won't be needed */ |
278 | timer->fclk = clk_get(NULL, omap_hwmod_get_main_clk(oh)); | 276 | timer->fclk = clk_get(NULL, omap_hwmod_get_main_clk(oh)); |
279 | if (IS_ERR(timer->fclk)) | 277 | if (IS_ERR(timer->fclk)) |
280 | return -ENODEV; | 278 | return PTR_ERR(timer->fclk); |
281 | 279 | ||
282 | /* FIXME: Need to remove hard-coded test on timer ID */ | 280 | src = clk_get(NULL, fck_source); |
283 | if (gptimer_id != 12) { | 281 | if (IS_ERR(src)) |
284 | struct clk *src; | 282 | return PTR_ERR(src); |
285 | 283 | ||
286 | src = clk_get(NULL, fck_source); | 284 | if (clk_get_parent(timer->fclk) != src) { |
287 | if (IS_ERR(src)) { | 285 | r = clk_set_parent(timer->fclk, src); |
288 | r = -EINVAL; | 286 | if (r < 0) { |
289 | } else { | 287 | pr_warn("%s: %s cannot set source\n", __func__, |
290 | r = clk_set_parent(timer->fclk, src); | 288 | oh->name); |
291 | if (r < 0) | ||
292 | pr_warn("%s: %s cannot set source\n", | ||
293 | __func__, oh->name); | ||
294 | clk_put(src); | 289 | clk_put(src); |
290 | return r; | ||
295 | } | 291 | } |
296 | } | 292 | } |
297 | 293 | ||
294 | clk_put(src); | ||
295 | |||
298 | omap_hwmod_setup_one(oh_name); | 296 | omap_hwmod_setup_one(oh_name); |
299 | omap_hwmod_enable(oh); | 297 | omap_hwmod_enable(oh); |
300 | __omap_dm_timer_init_regs(timer); | 298 | __omap_dm_timer_init_regs(timer); |
@@ -318,6 +316,7 @@ static void __init omap2_gp_clockevent_init(int gptimer_id, | |||
318 | { | 316 | { |
319 | int res; | 317 | int res; |
320 | 318 | ||
319 | clkev.id = gptimer_id; | ||
321 | clkev.errata = omap_dm_timer_get_errata(); | 320 | clkev.errata = omap_dm_timer_get_errata(); |
322 | 321 | ||
323 | /* | 322 | /* |
@@ -327,8 +326,8 @@ static void __init omap2_gp_clockevent_init(int gptimer_id, | |||
327 | */ | 326 | */ |
328 | __omap_dm_timer_override_errata(&clkev, OMAP_TIMER_ERRATA_I103_I767); | 327 | __omap_dm_timer_override_errata(&clkev, OMAP_TIMER_ERRATA_I103_I767); |
329 | 328 | ||
330 | res = omap_dm_timer_init_one(&clkev, gptimer_id, fck_source, property, | 329 | res = omap_dm_timer_init_one(&clkev, fck_source, property, |
331 | OMAP_TIMER_POSTED); | 330 | &clockevent_gpt.name, OMAP_TIMER_POSTED); |
332 | BUG_ON(res); | 331 | BUG_ON(res); |
333 | 332 | ||
334 | omap2_gp_timer_irq.dev_id = &clkev; | 333 | omap2_gp_timer_irq.dev_id = &clkev; |
@@ -342,8 +341,8 @@ static void __init omap2_gp_clockevent_init(int gptimer_id, | |||
342 | 3, /* Timer internal resynch latency */ | 341 | 3, /* Timer internal resynch latency */ |
343 | 0xffffffff); | 342 | 0xffffffff); |
344 | 343 | ||
345 | pr_info("OMAP clockevent source: GPTIMER%d at %lu Hz\n", | 344 | pr_info("OMAP clockevent source: %s at %lu Hz\n", clockevent_gpt.name, |
346 | gptimer_id, clkev.rate); | 345 | clkev.rate); |
347 | } | 346 | } |
348 | 347 | ||
349 | /* Clocksource code */ | 348 | /* Clocksource code */ |
@@ -360,7 +359,6 @@ static cycle_t clocksource_read_cycles(struct clocksource *cs) | |||
360 | } | 359 | } |
361 | 360 | ||
362 | static struct clocksource clocksource_gpt = { | 361 | static struct clocksource clocksource_gpt = { |
363 | .name = "gp_timer", | ||
364 | .rating = 300, | 362 | .rating = 300, |
365 | .read = clocksource_read_cycles, | 363 | .read = clocksource_read_cycles, |
366 | .mask = CLOCKSOURCE_MASK(32), | 364 | .mask = CLOCKSOURCE_MASK(32), |
@@ -443,13 +441,16 @@ static int __init __maybe_unused omap2_sync32k_clocksource_init(void) | |||
443 | } | 441 | } |
444 | 442 | ||
445 | static void __init omap2_gptimer_clocksource_init(int gptimer_id, | 443 | static void __init omap2_gptimer_clocksource_init(int gptimer_id, |
446 | const char *fck_source) | 444 | const char *fck_source, |
445 | const char *property) | ||
447 | { | 446 | { |
448 | int res; | 447 | int res; |
449 | 448 | ||
449 | clksrc.id = gptimer_id; | ||
450 | clksrc.errata = omap_dm_timer_get_errata(); | 450 | clksrc.errata = omap_dm_timer_get_errata(); |
451 | 451 | ||
452 | res = omap_dm_timer_init_one(&clksrc, gptimer_id, fck_source, NULL, | 452 | res = omap_dm_timer_init_one(&clksrc, fck_source, property, |
453 | &clocksource_gpt.name, | ||
453 | OMAP_TIMER_NONPOSTED); | 454 | OMAP_TIMER_NONPOSTED); |
454 | BUG_ON(res); | 455 | BUG_ON(res); |
455 | 456 | ||
@@ -462,8 +463,8 @@ static void __init omap2_gptimer_clocksource_init(int gptimer_id, | |||
462 | pr_err("Could not register clocksource %s\n", | 463 | pr_err("Could not register clocksource %s\n", |
463 | clocksource_gpt.name); | 464 | clocksource_gpt.name); |
464 | else | 465 | else |
465 | pr_info("OMAP clocksource: GPTIMER%d at %lu Hz\n", | 466 | pr_info("OMAP clocksource: %s at %lu Hz\n", |
466 | gptimer_id, clksrc.rate); | 467 | clocksource_gpt.name, clksrc.rate); |
467 | } | 468 | } |
468 | 469 | ||
469 | #ifdef CONFIG_SOC_HAS_REALTIME_COUNTER | 470 | #ifdef CONFIG_SOC_HAS_REALTIME_COUNTER |
@@ -488,7 +489,7 @@ static void __init realtime_counter_init(void) | |||
488 | pr_err("%s: ioremap failed\n", __func__); | 489 | pr_err("%s: ioremap failed\n", __func__); |
489 | return; | 490 | return; |
490 | } | 491 | } |
491 | sys_clk = clk_get(NULL, OMAP5_MPU_SOURCE); | 492 | sys_clk = clk_get(NULL, "sys_clkin"); |
492 | if (IS_ERR(sys_clk)) { | 493 | if (IS_ERR(sys_clk)) { |
493 | pr_err("%s: failed to get system clock handle\n", __func__); | 494 | pr_err("%s: failed to get system clock handle\n", __func__); |
494 | iounmap(base); | 495 | iounmap(base); |
@@ -545,53 +546,52 @@ static inline void __init realtime_counter_init(void) | |||
545 | #endif | 546 | #endif |
546 | 547 | ||
547 | #define OMAP_SYS_GP_TIMER_INIT(name, clkev_nr, clkev_src, clkev_prop, \ | 548 | #define OMAP_SYS_GP_TIMER_INIT(name, clkev_nr, clkev_src, clkev_prop, \ |
548 | clksrc_nr, clksrc_src) \ | 549 | clksrc_nr, clksrc_src, clksrc_prop) \ |
549 | void __init omap##name##_gptimer_timer_init(void) \ | 550 | void __init omap##name##_gptimer_timer_init(void) \ |
550 | { \ | 551 | { \ |
551 | if (omap_clk_init) \ | ||
552 | omap_clk_init(); \ | ||
553 | omap_dmtimer_init(); \ | 552 | omap_dmtimer_init(); \ |
554 | omap2_gp_clockevent_init((clkev_nr), clkev_src, clkev_prop); \ | 553 | omap2_gp_clockevent_init((clkev_nr), clkev_src, clkev_prop); \ |
555 | omap2_gptimer_clocksource_init((clksrc_nr), clksrc_src); \ | 554 | omap2_gptimer_clocksource_init((clksrc_nr), clksrc_src, \ |
555 | clksrc_prop); \ | ||
556 | } | 556 | } |
557 | 557 | ||
558 | #define OMAP_SYS_32K_TIMER_INIT(name, clkev_nr, clkev_src, clkev_prop, \ | 558 | #define OMAP_SYS_32K_TIMER_INIT(name, clkev_nr, clkev_src, clkev_prop, \ |
559 | clksrc_nr, clksrc_src) \ | 559 | clksrc_nr, clksrc_src, clksrc_prop) \ |
560 | void __init omap##name##_sync32k_timer_init(void) \ | 560 | void __init omap##name##_sync32k_timer_init(void) \ |
561 | { \ | 561 | { \ |
562 | if (omap_clk_init) \ | ||
563 | omap_clk_init(); \ | ||
564 | omap_dmtimer_init(); \ | 562 | omap_dmtimer_init(); \ |
565 | omap2_gp_clockevent_init((clkev_nr), clkev_src, clkev_prop); \ | 563 | omap2_gp_clockevent_init((clkev_nr), clkev_src, clkev_prop); \ |
566 | /* Enable the use of clocksource="gp_timer" kernel parameter */ \ | 564 | /* Enable the use of clocksource="gp_timer" kernel parameter */ \ |
567 | if (use_gptimer_clksrc) \ | 565 | if (use_gptimer_clksrc) \ |
568 | omap2_gptimer_clocksource_init((clksrc_nr), clksrc_src);\ | 566 | omap2_gptimer_clocksource_init((clksrc_nr), clksrc_src, \ |
567 | clksrc_prop); \ | ||
569 | else \ | 568 | else \ |
570 | omap2_sync32k_clocksource_init(); \ | 569 | omap2_sync32k_clocksource_init(); \ |
571 | } | 570 | } |
572 | 571 | ||
573 | #ifdef CONFIG_ARCH_OMAP2 | 572 | #ifdef CONFIG_ARCH_OMAP2 |
574 | OMAP_SYS_32K_TIMER_INIT(2, 1, OMAP2_32K_SOURCE, "ti,timer-alwon", | 573 | OMAP_SYS_32K_TIMER_INIT(2, 1, "timer_32k_ck", "ti,timer-alwon", |
575 | 2, OMAP2_MPU_SOURCE); | 574 | 2, "timer_sys_ck", NULL); |
576 | #endif /* CONFIG_ARCH_OMAP2 */ | 575 | #endif /* CONFIG_ARCH_OMAP2 */ |
577 | 576 | ||
578 | #ifdef CONFIG_ARCH_OMAP3 | 577 | #ifdef CONFIG_ARCH_OMAP3 |
579 | OMAP_SYS_32K_TIMER_INIT(3, 1, OMAP3_32K_SOURCE, "ti,timer-alwon", | 578 | OMAP_SYS_32K_TIMER_INIT(3, 1, "timer_32k_ck", "ti,timer-alwon", |
580 | 2, OMAP3_MPU_SOURCE); | 579 | 2, "timer_sys_ck", NULL); |
581 | OMAP_SYS_32K_TIMER_INIT(3_secure, 12, OMAP3_32K_SOURCE, "ti,timer-secure", | 580 | OMAP_SYS_32K_TIMER_INIT(3_secure, 12, "secure_32k_fck", "ti,timer-secure", |
582 | 2, OMAP3_MPU_SOURCE); | 581 | 2, "timer_sys_ck", NULL); |
583 | OMAP_SYS_GP_TIMER_INIT(3_gp, 1, OMAP3_MPU_SOURCE, "ti,timer-alwon", | ||
584 | 2, OMAP3_MPU_SOURCE); | ||
585 | #endif /* CONFIG_ARCH_OMAP3 */ | 582 | #endif /* CONFIG_ARCH_OMAP3 */ |
586 | 583 | ||
587 | #ifdef CONFIG_SOC_AM33XX | 584 | #if defined(CONFIG_ARCH_OMAP3) || defined(CONFIG_SOC_AM33XX) |
588 | OMAP_SYS_GP_TIMER_INIT(3_am33xx, 1, OMAP4_MPU_SOURCE, "ti,timer-alwon", | 585 | OMAP_SYS_GP_TIMER_INIT(3, 2, "timer_sys_ck", NULL, |
589 | 2, OMAP4_MPU_SOURCE); | 586 | 1, "timer_sys_ck", "ti,timer-alwon"); |
590 | #endif /* CONFIG_SOC_AM33XX */ | 587 | #endif |
588 | |||
589 | #if defined(CONFIG_ARCH_OMAP4) || defined(CONFIG_SOC_OMAP5) | ||
590 | static OMAP_SYS_32K_TIMER_INIT(4, 1, "timer_32k_ck", "ti,timer-alwon", | ||
591 | 2, "sys_clkin_ck", NULL); | ||
592 | #endif | ||
591 | 593 | ||
592 | #ifdef CONFIG_ARCH_OMAP4 | 594 | #ifdef CONFIG_ARCH_OMAP4 |
593 | OMAP_SYS_32K_TIMER_INIT(4, 1, OMAP4_32K_SOURCE, "ti,timer-alwon", | ||
594 | 2, OMAP4_MPU_SOURCE); | ||
595 | #ifdef CONFIG_LOCAL_TIMERS | 595 | #ifdef CONFIG_LOCAL_TIMERS |
596 | static DEFINE_TWD_LOCAL_TIMER(twd_local_timer, OMAP44XX_LOCAL_TWD_BASE, 29); | 596 | static DEFINE_TWD_LOCAL_TIMER(twd_local_timer, OMAP44XX_LOCAL_TWD_BASE, 29); |
597 | void __init omap4_local_timer_init(void) | 597 | void __init omap4_local_timer_init(void) |
@@ -620,13 +620,11 @@ void __init omap4_local_timer_init(void) | |||
620 | #endif /* CONFIG_ARCH_OMAP4 */ | 620 | #endif /* CONFIG_ARCH_OMAP4 */ |
621 | 621 | ||
622 | #ifdef CONFIG_SOC_OMAP5 | 622 | #ifdef CONFIG_SOC_OMAP5 |
623 | OMAP_SYS_32K_TIMER_INIT(5, 1, OMAP4_32K_SOURCE, "ti,timer-alwon", | ||
624 | 2, OMAP5_MPU_SOURCE); | ||
625 | void __init omap5_realtime_timer_init(void) | 623 | void __init omap5_realtime_timer_init(void) |
626 | { | 624 | { |
627 | int err; | 625 | int err; |
628 | 626 | ||
629 | omap5_sync32k_timer_init(); | 627 | omap4_sync32k_timer_init(); |
630 | realtime_counter_init(); | 628 | realtime_counter_init(); |
631 | 629 | ||
632 | err = arch_timer_of_register(); | 630 | err = arch_timer_of_register(); |
diff --git a/arch/arm/mach-omap2/usb-host.c b/arch/arm/mach-omap2/usb-host.c index 5706bdccf45e..aa27d7f5cbb7 100644 --- a/arch/arm/mach-omap2/usb-host.c +++ b/arch/arm/mach-omap2/usb-host.c | |||
@@ -22,8 +22,12 @@ | |||
22 | #include <linux/platform_device.h> | 22 | #include <linux/platform_device.h> |
23 | #include <linux/slab.h> | 23 | #include <linux/slab.h> |
24 | #include <linux/dma-mapping.h> | 24 | #include <linux/dma-mapping.h> |
25 | 25 | #include <linux/regulator/machine.h> | |
26 | #include <asm/io.h> | 26 | #include <linux/regulator/fixed.h> |
27 | #include <linux/string.h> | ||
28 | #include <linux/io.h> | ||
29 | #include <linux/gpio.h> | ||
30 | #include <linux/usb/phy.h> | ||
27 | 31 | ||
28 | #include "soc.h" | 32 | #include "soc.h" |
29 | #include "omap_device.h" | 33 | #include "omap_device.h" |
@@ -526,3 +530,155 @@ void __init usbhs_init(struct usbhs_omap_platform_data *pdata) | |||
526 | } | 530 | } |
527 | 531 | ||
528 | #endif | 532 | #endif |
533 | |||
534 | /* Template for PHY regulators */ | ||
535 | static struct fixed_voltage_config hsusb_reg_config = { | ||
536 | /* .supply_name filled later */ | ||
537 | .microvolts = 3300000, | ||
538 | .gpio = -1, /* updated later */ | ||
539 | .startup_delay = 70000, /* 70msec */ | ||
540 | .enable_high = 1, /* updated later */ | ||
541 | .enabled_at_boot = 0, /* keep in RESET */ | ||
542 | /* .init_data filled later */ | ||
543 | }; | ||
544 | |||
545 | static const char *nop_name = "nop_usb_xceiv"; /* NOP PHY driver */ | ||
546 | static const char *reg_name = "reg-fixed-voltage"; /* Regulator driver */ | ||
547 | |||
548 | /** | ||
549 | * usbhs_add_regulator - Add a gpio based fixed voltage regulator device | ||
550 | * @name: name for the regulator | ||
551 | * @dev_id: device id of the device this regulator supplies power to | ||
552 | * @dev_supply: supply name that the device expects | ||
553 | * @gpio: GPIO number | ||
554 | * @polarity: 1 - Active high, 0 - Active low | ||
555 | */ | ||
556 | static int usbhs_add_regulator(char *name, char *dev_id, char *dev_supply, | ||
557 | int gpio, int polarity) | ||
558 | { | ||
559 | struct regulator_consumer_supply *supplies; | ||
560 | struct regulator_init_data *reg_data; | ||
561 | struct fixed_voltage_config *config; | ||
562 | struct platform_device *pdev; | ||
563 | int ret; | ||
564 | |||
565 | supplies = kzalloc(sizeof(*supplies), GFP_KERNEL); | ||
566 | if (!supplies) | ||
567 | return -ENOMEM; | ||
568 | |||
569 | supplies->supply = dev_supply; | ||
570 | supplies->dev_name = dev_id; | ||
571 | |||
572 | reg_data = kzalloc(sizeof(*reg_data), GFP_KERNEL); | ||
573 | if (!reg_data) | ||
574 | return -ENOMEM; | ||
575 | |||
576 | reg_data->constraints.valid_ops_mask = REGULATOR_CHANGE_STATUS; | ||
577 | reg_data->consumer_supplies = supplies; | ||
578 | reg_data->num_consumer_supplies = 1; | ||
579 | |||
580 | config = kmemdup(&hsusb_reg_config, sizeof(hsusb_reg_config), | ||
581 | GFP_KERNEL); | ||
582 | if (!config) | ||
583 | return -ENOMEM; | ||
584 | |||
585 | config->supply_name = name; | ||
586 | config->gpio = gpio; | ||
587 | config->enable_high = polarity; | ||
588 | config->init_data = reg_data; | ||
589 | |||
590 | /* create a regulator device */ | ||
591 | pdev = kzalloc(sizeof(*pdev), GFP_KERNEL); | ||
592 | if (!pdev) | ||
593 | return -ENOMEM; | ||
594 | |||
595 | pdev->id = PLATFORM_DEVID_AUTO; | ||
596 | pdev->name = reg_name; | ||
597 | pdev->dev.platform_data = config; | ||
598 | |||
599 | ret = platform_device_register(pdev); | ||
600 | if (ret) | ||
601 | pr_err("%s: Failed registering regulator %s for %s\n", | ||
602 | __func__, name, dev_id); | ||
603 | |||
604 | return ret; | ||
605 | } | ||
606 | |||
607 | int usbhs_init_phys(struct usbhs_phy_data *phy, int num_phys) | ||
608 | { | ||
609 | char *rail_name; | ||
610 | int i, len; | ||
611 | struct platform_device *pdev; | ||
612 | char *phy_id; | ||
613 | |||
614 | /* the phy_id will be something like "nop_usb_xceiv.1" */ | ||
615 | len = strlen(nop_name) + 3; /* 3 -> ".1" and NULL terminator */ | ||
616 | |||
617 | for (i = 0; i < num_phys; i++) { | ||
618 | |||
619 | if (!phy->port) { | ||
620 | pr_err("%s: Invalid port 0. Must start from 1\n", | ||
621 | __func__); | ||
622 | continue; | ||
623 | } | ||
624 | |||
625 | /* do we need a NOP PHY device ? */ | ||
626 | if (!gpio_is_valid(phy->reset_gpio) && | ||
627 | !gpio_is_valid(phy->vcc_gpio)) | ||
628 | continue; | ||
629 | |||
630 | /* create a NOP PHY device */ | ||
631 | pdev = kzalloc(sizeof(*pdev), GFP_KERNEL); | ||
632 | if (!pdev) | ||
633 | return -ENOMEM; | ||
634 | |||
635 | pdev->id = phy->port; | ||
636 | pdev->name = nop_name; | ||
637 | pdev->dev.platform_data = phy->platform_data; | ||
638 | |||
639 | phy_id = kmalloc(len, GFP_KERNEL); | ||
640 | if (!phy_id) | ||
641 | return -ENOMEM; | ||
642 | |||
643 | scnprintf(phy_id, len, "nop_usb_xceiv.%d\n", | ||
644 | pdev->id); | ||
645 | |||
646 | if (platform_device_register(pdev)) { | ||
647 | pr_err("%s: Failed to register device %s\n", | ||
648 | __func__, phy_id); | ||
649 | continue; | ||
650 | } | ||
651 | |||
652 | usb_bind_phy("ehci-omap.0", phy->port - 1, phy_id); | ||
653 | |||
654 | /* Do we need RESET regulator ? */ | ||
655 | if (gpio_is_valid(phy->reset_gpio)) { | ||
656 | |||
657 | rail_name = kmalloc(13, GFP_KERNEL); | ||
658 | if (!rail_name) | ||
659 | return -ENOMEM; | ||
660 | |||
661 | scnprintf(rail_name, 13, "hsusb%d_reset", phy->port); | ||
662 | |||
663 | usbhs_add_regulator(rail_name, phy_id, "reset", | ||
664 | phy->reset_gpio, 1); | ||
665 | } | ||
666 | |||
667 | /* Do we need VCC regulator ? */ | ||
668 | if (gpio_is_valid(phy->vcc_gpio)) { | ||
669 | |||
670 | rail_name = kmalloc(13, GFP_KERNEL); | ||
671 | if (!rail_name) | ||
672 | return -ENOMEM; | ||
673 | |||
674 | scnprintf(rail_name, 13, "hsusb%d_vcc", phy->port); | ||
675 | |||
676 | usbhs_add_regulator(rail_name, phy_id, "vcc", | ||
677 | phy->vcc_gpio, phy->vcc_polarity); | ||
678 | } | ||
679 | |||
680 | phy++; | ||
681 | } | ||
682 | |||
683 | return 0; | ||
684 | } | ||
diff --git a/arch/arm/mach-omap2/usb-tusb6010.c b/arch/arm/mach-omap2/usb-tusb6010.c index c5a3c6f9504e..e832bc7b8e2d 100644 --- a/arch/arm/mach-omap2/usb-tusb6010.c +++ b/arch/arm/mach-omap2/usb-tusb6010.c | |||
@@ -8,6 +8,7 @@ | |||
8 | * published by the Free Software Foundation. | 8 | * published by the Free Software Foundation. |
9 | */ | 9 | */ |
10 | 10 | ||
11 | #include <linux/err.h> | ||
11 | #include <linux/string.h> | 12 | #include <linux/string.h> |
12 | #include <linux/types.h> | 13 | #include <linux/types.h> |
13 | #include <linux/errno.h> | 14 | #include <linux/errno.h> |
@@ -26,6 +27,24 @@ | |||
26 | static u8 async_cs, sync_cs; | 27 | static u8 async_cs, sync_cs; |
27 | static unsigned refclk_psec; | 28 | static unsigned refclk_psec; |
28 | 29 | ||
30 | static struct gpmc_settings tusb_async = { | ||
31 | .wait_on_read = true, | ||
32 | .wait_on_write = true, | ||
33 | .device_width = GPMC_DEVWIDTH_16BIT, | ||
34 | .mux_add_data = GPMC_MUX_AD, | ||
35 | }; | ||
36 | |||
37 | static struct gpmc_settings tusb_sync = { | ||
38 | .burst_read = true, | ||
39 | .burst_write = true, | ||
40 | .sync_read = true, | ||
41 | .sync_write = true, | ||
42 | .wait_on_read = true, | ||
43 | .wait_on_write = true, | ||
44 | .burst_len = GPMC_BURST_16, | ||
45 | .device_width = GPMC_DEVWIDTH_16BIT, | ||
46 | .mux_add_data = GPMC_MUX_AD, | ||
47 | }; | ||
29 | 48 | ||
30 | /* NOTE: timings are from tusb 6010 datasheet Rev 1.8, 12-Sept 2006 */ | 49 | /* NOTE: timings are from tusb 6010 datasheet Rev 1.8, 12-Sept 2006 */ |
31 | 50 | ||
@@ -37,8 +56,6 @@ static int tusb_set_async_mode(unsigned sysclk_ps) | |||
37 | 56 | ||
38 | memset(&dev_t, 0, sizeof(dev_t)); | 57 | memset(&dev_t, 0, sizeof(dev_t)); |
39 | 58 | ||
40 | dev_t.mux = true; | ||
41 | |||
42 | dev_t.t_ceasu = 8 * 1000; | 59 | dev_t.t_ceasu = 8 * 1000; |
43 | dev_t.t_avdasu = t_acsnh_advnh - 7000; | 60 | dev_t.t_avdasu = t_acsnh_advnh - 7000; |
44 | dev_t.t_ce_avd = 1000; | 61 | dev_t.t_ce_avd = 1000; |
@@ -52,7 +69,7 @@ static int tusb_set_async_mode(unsigned sysclk_ps) | |||
52 | dev_t.t_wpl = 300; | 69 | dev_t.t_wpl = 300; |
53 | dev_t.cyc_aavdh_we = 1; | 70 | dev_t.cyc_aavdh_we = 1; |
54 | 71 | ||
55 | gpmc_calc_timings(&t, &dev_t); | 72 | gpmc_calc_timings(&t, &tusb_async, &dev_t); |
56 | 73 | ||
57 | return gpmc_cs_set_timings(async_cs, &t); | 74 | return gpmc_cs_set_timings(async_cs, &t); |
58 | } | 75 | } |
@@ -65,10 +82,6 @@ static int tusb_set_sync_mode(unsigned sysclk_ps) | |||
65 | 82 | ||
66 | memset(&dev_t, 0, sizeof(dev_t)); | 83 | memset(&dev_t, 0, sizeof(dev_t)); |
67 | 84 | ||
68 | dev_t.mux = true; | ||
69 | dev_t.sync_read = true; | ||
70 | dev_t.sync_write = true; | ||
71 | |||
72 | dev_t.clk = 11100; | 85 | dev_t.clk = 11100; |
73 | dev_t.t_bacc = 1000; | 86 | dev_t.t_bacc = 1000; |
74 | dev_t.t_ces = 1000; | 87 | dev_t.t_ces = 1000; |
@@ -84,7 +97,7 @@ static int tusb_set_sync_mode(unsigned sysclk_ps) | |||
84 | dev_t.cyc_wpl = 6; | 97 | dev_t.cyc_wpl = 6; |
85 | dev_t.t_ce_rdyz = 7000; | 98 | dev_t.t_ce_rdyz = 7000; |
86 | 99 | ||
87 | gpmc_calc_timings(&t, &dev_t); | 100 | gpmc_calc_timings(&t, &tusb_sync, &dev_t); |
88 | 101 | ||
89 | return gpmc_cs_set_timings(sync_cs, &t); | 102 | return gpmc_cs_set_timings(sync_cs, &t); |
90 | } | 103 | } |
@@ -165,18 +178,12 @@ tusb6010_setup_interface(struct musb_hdrc_platform_data *data, | |||
165 | return status; | 178 | return status; |
166 | } | 179 | } |
167 | tusb_resources[0].end = tusb_resources[0].start + 0x9ff; | 180 | tusb_resources[0].end = tusb_resources[0].start + 0x9ff; |
181 | tusb_async.wait_pin = waitpin; | ||
168 | async_cs = async; | 182 | async_cs = async; |
169 | gpmc_cs_write_reg(async, GPMC_CS_CONFIG1, | ||
170 | GPMC_CONFIG1_PAGE_LEN(2) | ||
171 | | GPMC_CONFIG1_WAIT_READ_MON | ||
172 | | GPMC_CONFIG1_WAIT_WRITE_MON | ||
173 | | GPMC_CONFIG1_WAIT_PIN_SEL(waitpin) | ||
174 | | GPMC_CONFIG1_READTYPE_ASYNC | ||
175 | | GPMC_CONFIG1_WRITETYPE_ASYNC | ||
176 | | GPMC_CONFIG1_DEVICESIZE_16 | ||
177 | | GPMC_CONFIG1_DEVICETYPE_NOR | ||
178 | | GPMC_CONFIG1_MUXADDDATA); | ||
179 | 183 | ||
184 | status = gpmc_cs_program_settings(async_cs, &tusb_async); | ||
185 | if (status < 0) | ||
186 | return status; | ||
180 | 187 | ||
181 | /* SYNC region, primarily for DMA */ | 188 | /* SYNC region, primarily for DMA */ |
182 | status = gpmc_cs_request(sync, SZ_16M, (unsigned long *) | 189 | status = gpmc_cs_request(sync, SZ_16M, (unsigned long *) |
@@ -186,21 +193,12 @@ tusb6010_setup_interface(struct musb_hdrc_platform_data *data, | |||
186 | return status; | 193 | return status; |
187 | } | 194 | } |
188 | tusb_resources[1].end = tusb_resources[1].start + 0x9ff; | 195 | tusb_resources[1].end = tusb_resources[1].start + 0x9ff; |
196 | tusb_sync.wait_pin = waitpin; | ||
189 | sync_cs = sync; | 197 | sync_cs = sync; |
190 | gpmc_cs_write_reg(sync, GPMC_CS_CONFIG1, | 198 | |
191 | GPMC_CONFIG1_READMULTIPLE_SUPP | 199 | status = gpmc_cs_program_settings(sync_cs, &tusb_sync); |
192 | | GPMC_CONFIG1_READTYPE_SYNC | 200 | if (status < 0) |
193 | | GPMC_CONFIG1_WRITEMULTIPLE_SUPP | 201 | return status; |
194 | | GPMC_CONFIG1_WRITETYPE_SYNC | ||
195 | | GPMC_CONFIG1_PAGE_LEN(2) | ||
196 | | GPMC_CONFIG1_WAIT_READ_MON | ||
197 | | GPMC_CONFIG1_WAIT_WRITE_MON | ||
198 | | GPMC_CONFIG1_WAIT_PIN_SEL(waitpin) | ||
199 | | GPMC_CONFIG1_DEVICESIZE_16 | ||
200 | | GPMC_CONFIG1_DEVICETYPE_NOR | ||
201 | | GPMC_CONFIG1_MUXADDDATA | ||
202 | /* fclk divider gets set later */ | ||
203 | ); | ||
204 | 202 | ||
205 | /* IRQ */ | 203 | /* IRQ */ |
206 | status = gpio_request_one(irq, GPIOF_IN, "TUSB6010 irq"); | 204 | status = gpio_request_one(irq, GPIOF_IN, "TUSB6010 irq"); |
diff --git a/arch/arm/mach-omap2/usb.h b/arch/arm/mach-omap2/usb.h index 3319f5cf47a3..e7261ebcf7b0 100644 --- a/arch/arm/mach-omap2/usb.h +++ b/arch/arm/mach-omap2/usb.h | |||
@@ -53,8 +53,17 @@ | |||
53 | #define USBPHY_OTGSESSEND_EN (1 << 20) | 53 | #define USBPHY_OTGSESSEND_EN (1 << 20) |
54 | #define USBPHY_DATA_POLARITY (1 << 23) | 54 | #define USBPHY_DATA_POLARITY (1 << 23) |
55 | 55 | ||
56 | struct usbhs_phy_data { | ||
57 | int port; /* 1 indexed port number */ | ||
58 | int reset_gpio; | ||
59 | int vcc_gpio; | ||
60 | bool vcc_polarity; /* 1 active high, 0 active low */ | ||
61 | void *platform_data; | ||
62 | }; | ||
63 | |||
56 | extern void usb_musb_init(struct omap_musb_board_data *board_data); | 64 | extern void usb_musb_init(struct omap_musb_board_data *board_data); |
57 | extern void usbhs_init(struct usbhs_omap_platform_data *pdata); | 65 | extern void usbhs_init(struct usbhs_omap_platform_data *pdata); |
66 | extern int usbhs_init_phys(struct usbhs_phy_data *phy, int num_phys); | ||
58 | 67 | ||
59 | extern void am35x_musb_reset(void); | 68 | extern void am35x_musb_reset(void); |
60 | extern void am35x_musb_phy_power(u8 on); | 69 | extern void am35x_musb_phy_power(u8 on); |
diff --git a/arch/arm/mach-s3c24xx/Kconfig b/arch/arm/mach-s3c24xx/Kconfig index 8d5fa6ece014..f2f7088bfd22 100644 --- a/arch/arm/mach-s3c24xx/Kconfig +++ b/arch/arm/mach-s3c24xx/Kconfig | |||
@@ -30,6 +30,7 @@ config CPU_S3C2410 | |||
30 | select S3C2410_CLOCK | 30 | select S3C2410_CLOCK |
31 | select S3C2410_CPUFREQ if CPU_FREQ_S3C24XX | 31 | select S3C2410_CPUFREQ if CPU_FREQ_S3C24XX |
32 | select S3C2410_PM if PM | 32 | select S3C2410_PM if PM |
33 | select SAMSUNG_HRT | ||
33 | help | 34 | help |
34 | Support for S3C2410 and S3C2410A family from the S3C24XX line | 35 | Support for S3C2410 and S3C2410A family from the S3C24XX line |
35 | of Samsung Mobile CPUs. | 36 | of Samsung Mobile CPUs. |
@@ -40,6 +41,7 @@ config CPU_S3C2412 | |||
40 | select CPU_LLSERIAL_S3C2440 | 41 | select CPU_LLSERIAL_S3C2440 |
41 | select S3C2412_DMA if S3C24XX_DMA | 42 | select S3C2412_DMA if S3C24XX_DMA |
42 | select S3C2412_PM if PM | 43 | select S3C2412_PM if PM |
44 | select SAMSUNG_HRT | ||
43 | help | 45 | help |
44 | Support for the S3C2412 and S3C2413 SoCs from the S3C24XX line | 46 | Support for the S3C2412 and S3C2413 SoCs from the S3C24XX line |
45 | 47 | ||
@@ -51,6 +53,7 @@ config CPU_S3C2416 | |||
51 | select S3C2443_COMMON | 53 | select S3C2443_COMMON |
52 | select S3C2443_DMA if S3C24XX_DMA | 54 | select S3C2443_DMA if S3C24XX_DMA |
53 | select SAMSUNG_CLKSRC | 55 | select SAMSUNG_CLKSRC |
56 | select SAMSUNG_HRT | ||
54 | help | 57 | help |
55 | Support for the S3C2416 SoC from the S3C24XX line | 58 | Support for the S3C2416 SoC from the S3C24XX line |
56 | 59 | ||
@@ -61,6 +64,7 @@ config CPU_S3C2440 | |||
61 | select S3C2410_CLOCK | 64 | select S3C2410_CLOCK |
62 | select S3C2410_PM if PM | 65 | select S3C2410_PM if PM |
63 | select S3C2440_DMA if S3C24XX_DMA | 66 | select S3C2440_DMA if S3C24XX_DMA |
67 | select SAMSUNG_HRT | ||
64 | help | 68 | help |
65 | Support for S3C2440 Samsung Mobile CPU based systems. | 69 | Support for S3C2440 Samsung Mobile CPU based systems. |
66 | 70 | ||
@@ -70,6 +74,7 @@ config CPU_S3C2442 | |||
70 | select CPU_LLSERIAL_S3C2440 | 74 | select CPU_LLSERIAL_S3C2440 |
71 | select S3C2410_CLOCK | 75 | select S3C2410_CLOCK |
72 | select S3C2410_PM if PM | 76 | select S3C2410_PM if PM |
77 | select SAMSUNG_HRT | ||
73 | help | 78 | help |
74 | Support for S3C2442 Samsung Mobile CPU based systems. | 79 | Support for S3C2442 Samsung Mobile CPU based systems. |
75 | 80 | ||
@@ -84,6 +89,7 @@ config CPU_S3C2443 | |||
84 | select S3C2443_COMMON | 89 | select S3C2443_COMMON |
85 | select S3C2443_DMA if S3C24XX_DMA | 90 | select S3C2443_DMA if S3C24XX_DMA |
86 | select SAMSUNG_CLKSRC | 91 | select SAMSUNG_CLKSRC |
92 | select SAMSUNG_HRT | ||
87 | help | 93 | help |
88 | Support for the S3C2443 SoC from the S3C24XX line | 94 | Support for the S3C2443 SoC from the S3C24XX line |
89 | 95 | ||
@@ -395,6 +401,7 @@ config S3C2412_DMA | |||
395 | config S3C2412_PM | 401 | config S3C2412_PM |
396 | bool | 402 | bool |
397 | select S3C2412_PM_SLEEP | 403 | select S3C2412_PM_SLEEP |
404 | select SAMSUNG_WAKEMASK | ||
398 | help | 405 | help |
399 | Internal config node to apply S3C2412 power management | 406 | Internal config node to apply S3C2412 power management |
400 | 407 | ||
diff --git a/arch/arm/mach-s3c24xx/Makefile b/arch/arm/mach-s3c24xx/Makefile index af53d27d5c36..6f46ecfc8396 100644 --- a/arch/arm/mach-s3c24xx/Makefile +++ b/arch/arm/mach-s3c24xx/Makefile | |||
@@ -14,7 +14,7 @@ obj- := | |||
14 | 14 | ||
15 | # core | 15 | # core |
16 | 16 | ||
17 | obj-y += common.o irq.o | 17 | obj-y += common.o |
18 | 18 | ||
19 | obj-$(CONFIG_CPU_S3C2410) += s3c2410.o | 19 | obj-$(CONFIG_CPU_S3C2410) += s3c2410.o |
20 | obj-$(CONFIG_S3C2410_CPUFREQ) += cpufreq-s3c2410.o | 20 | obj-$(CONFIG_S3C2410_CPUFREQ) += cpufreq-s3c2410.o |
@@ -22,7 +22,7 @@ obj-$(CONFIG_S3C2410_DMA) += dma-s3c2410.o | |||
22 | obj-$(CONFIG_S3C2410_PLL) += pll-s3c2410.o | 22 | obj-$(CONFIG_S3C2410_PLL) += pll-s3c2410.o |
23 | obj-$(CONFIG_S3C2410_PM) += pm-s3c2410.o sleep-s3c2410.o | 23 | obj-$(CONFIG_S3C2410_PM) += pm-s3c2410.o sleep-s3c2410.o |
24 | 24 | ||
25 | obj-$(CONFIG_CPU_S3C2412) += s3c2412.o irq-s3c2412.o clock-s3c2412.o | 25 | obj-$(CONFIG_CPU_S3C2412) += s3c2412.o clock-s3c2412.o |
26 | obj-$(CONFIG_S3C2412_CPUFREQ) += cpufreq-s3c2412.o | 26 | obj-$(CONFIG_S3C2412_CPUFREQ) += cpufreq-s3c2412.o |
27 | obj-$(CONFIG_S3C2412_DMA) += dma-s3c2412.o | 27 | obj-$(CONFIG_S3C2412_DMA) += dma-s3c2412.o |
28 | obj-$(CONFIG_S3C2412_PM) += pm-s3c2412.o | 28 | obj-$(CONFIG_S3C2412_PM) += pm-s3c2412.o |
@@ -31,9 +31,9 @@ obj-$(CONFIG_S3C2412_PM_SLEEP) += sleep-s3c2412.o | |||
31 | obj-$(CONFIG_CPU_S3C2416) += s3c2416.o clock-s3c2416.o | 31 | obj-$(CONFIG_CPU_S3C2416) += s3c2416.o clock-s3c2416.o |
32 | obj-$(CONFIG_S3C2416_PM) += pm-s3c2416.o | 32 | obj-$(CONFIG_S3C2416_PM) += pm-s3c2416.o |
33 | 33 | ||
34 | obj-$(CONFIG_CPU_S3C2440) += s3c2440.o irq-s3c2440.o clock-s3c2440.o | 34 | obj-$(CONFIG_CPU_S3C2440) += s3c2440.o clock-s3c2440.o |
35 | obj-$(CONFIG_CPU_S3C2442) += s3c2442.o | 35 | obj-$(CONFIG_CPU_S3C2442) += s3c2442.o |
36 | obj-$(CONFIG_CPU_S3C244X) += s3c244x.o irq-s3c244x.o clock-s3c244x.o | 36 | obj-$(CONFIG_CPU_S3C244X) += s3c244x.o clock-s3c244x.o |
37 | obj-$(CONFIG_S3C2440_CPUFREQ) += cpufreq-s3c2440.o | 37 | obj-$(CONFIG_S3C2440_CPUFREQ) += cpufreq-s3c2440.o |
38 | obj-$(CONFIG_S3C2440_DMA) += dma-s3c2440.o | 38 | obj-$(CONFIG_S3C2440_DMA) += dma-s3c2440.o |
39 | obj-$(CONFIG_S3C2440_PLL_12000000) += pll-s3c2440-12000000.o | 39 | obj-$(CONFIG_S3C2440_PLL_12000000) += pll-s3c2440-12000000.o |
diff --git a/arch/arm/mach-s3c24xx/common.h b/arch/arm/mach-s3c24xx/common.h index 8a2b4137ddb6..307c3714be55 100644 --- a/arch/arm/mach-s3c24xx/common.h +++ b/arch/arm/mach-s3c24xx/common.h | |||
@@ -21,6 +21,7 @@ extern void s3c2410_map_io(void); | |||
21 | extern void s3c2410_init_uarts(struct s3c2410_uartcfg *cfg, int no); | 21 | extern void s3c2410_init_uarts(struct s3c2410_uartcfg *cfg, int no); |
22 | extern void s3c2410_init_clocks(int xtal); | 22 | extern void s3c2410_init_clocks(int xtal); |
23 | extern void s3c2410_restart(char mode, const char *cmd); | 23 | extern void s3c2410_restart(char mode, const char *cmd); |
24 | extern void s3c2410_init_irq(void); | ||
24 | #else | 25 | #else |
25 | #define s3c2410_init_clocks NULL | 26 | #define s3c2410_init_clocks NULL |
26 | #define s3c2410_init_uarts NULL | 27 | #define s3c2410_init_uarts NULL |
@@ -36,6 +37,7 @@ extern void s3c2412_init_uarts(struct s3c2410_uartcfg *cfg, int no); | |||
36 | extern void s3c2412_init_clocks(int xtal); | 37 | extern void s3c2412_init_clocks(int xtal); |
37 | extern int s3c2412_baseclk_add(void); | 38 | extern int s3c2412_baseclk_add(void); |
38 | extern void s3c2412_restart(char mode, const char *cmd); | 39 | extern void s3c2412_restart(char mode, const char *cmd); |
40 | extern void s3c2412_init_irq(void); | ||
39 | #else | 41 | #else |
40 | #define s3c2412_init_clocks NULL | 42 | #define s3c2412_init_clocks NULL |
41 | #define s3c2412_init_uarts NULL | 43 | #define s3c2412_init_uarts NULL |
@@ -73,6 +75,7 @@ extern void s3c244x_restart(char mode, const char *cmd); | |||
73 | #ifdef CONFIG_CPU_S3C2440 | 75 | #ifdef CONFIG_CPU_S3C2440 |
74 | extern int s3c2440_init(void); | 76 | extern int s3c2440_init(void); |
75 | extern void s3c2440_map_io(void); | 77 | extern void s3c2440_map_io(void); |
78 | extern void s3c2440_init_irq(void); | ||
76 | #else | 79 | #else |
77 | #define s3c2440_init NULL | 80 | #define s3c2440_init NULL |
78 | #define s3c2440_map_io NULL | 81 | #define s3c2440_map_io NULL |
@@ -81,6 +84,7 @@ extern void s3c2440_map_io(void); | |||
81 | #ifdef CONFIG_CPU_S3C2442 | 84 | #ifdef CONFIG_CPU_S3C2442 |
82 | extern int s3c2442_init(void); | 85 | extern int s3c2442_init(void); |
83 | extern void s3c2442_map_io(void); | 86 | extern void s3c2442_map_io(void); |
87 | extern void s3c2442_init_irq(void); | ||
84 | #else | 88 | #else |
85 | #define s3c2442_init NULL | 89 | #define s3c2442_init NULL |
86 | #define s3c2442_map_io NULL | 90 | #define s3c2442_map_io NULL |
diff --git a/arch/arm/mach-s3c24xx/include/mach/entry-macro.S b/arch/arm/mach-s3c24xx/include/mach/entry-macro.S deleted file mode 100644 index 6a21beeba1da..000000000000 --- a/arch/arm/mach-s3c24xx/include/mach/entry-macro.S +++ /dev/null | |||
@@ -1,70 +0,0 @@ | |||
1 | /* | ||
2 | * arch/arm/mach-s3c2410/include/mach/entry-macro.S | ||
3 | * | ||
4 | * Low-level IRQ helper macros for S3C2410-based platforms | ||
5 | * | ||
6 | * This file is licensed under the terms of the GNU General Public | ||
7 | * License version 2. This program is licensed "as is" without any | ||
8 | * warranty of any kind, whether express or implied. | ||
9 | */ | ||
10 | |||
11 | /* We have a problem that the INTOFFSET register does not always | ||
12 | * show one interrupt. Occasionally we get two interrupts through | ||
13 | * the prioritiser, and this causes the INTOFFSET register to show | ||
14 | * what looks like the logical-or of the two interrupt numbers. | ||
15 | * | ||
16 | * Thanks to Klaus, Shannon, et al for helping to debug this problem | ||
17 | */ | ||
18 | |||
19 | #define INTPND (0x10) | ||
20 | #define INTOFFSET (0x14) | ||
21 | |||
22 | #include <mach/hardware.h> | ||
23 | #include <asm/irq.h> | ||
24 | |||
25 | .macro get_irqnr_preamble, base, tmp | ||
26 | .endm | ||
27 | |||
28 | .macro get_irqnr_and_base, irqnr, irqstat, base, tmp | ||
29 | |||
30 | mov \base, #S3C24XX_VA_IRQ | ||
31 | |||
32 | @@ try the interrupt offset register, since it is there | ||
33 | |||
34 | ldr \irqstat, [\base, #INTPND ] | ||
35 | teq \irqstat, #0 | ||
36 | beq 1002f | ||
37 | ldr \irqnr, [\base, #INTOFFSET ] | ||
38 | mov \tmp, #1 | ||
39 | tst \irqstat, \tmp, lsl \irqnr | ||
40 | bne 1001f | ||
41 | |||
42 | @@ the number specified is not a valid irq, so try | ||
43 | @@ and work it out for ourselves | ||
44 | |||
45 | mov \irqnr, #0 @@ start here | ||
46 | |||
47 | @@ work out which irq (if any) we got | ||
48 | |||
49 | movs \tmp, \irqstat, lsl#16 | ||
50 | addeq \irqnr, \irqnr, #16 | ||
51 | moveq \irqstat, \irqstat, lsr#16 | ||
52 | tst \irqstat, #0xff | ||
53 | addeq \irqnr, \irqnr, #8 | ||
54 | moveq \irqstat, \irqstat, lsr#8 | ||
55 | tst \irqstat, #0xf | ||
56 | addeq \irqnr, \irqnr, #4 | ||
57 | moveq \irqstat, \irqstat, lsr#4 | ||
58 | tst \irqstat, #0x3 | ||
59 | addeq \irqnr, \irqnr, #2 | ||
60 | moveq \irqstat, \irqstat, lsr#2 | ||
61 | tst \irqstat, #0x1 | ||
62 | addeq \irqnr, \irqnr, #1 | ||
63 | |||
64 | @@ we have the value | ||
65 | 1001: | ||
66 | adds \irqnr, \irqnr, #IRQ_EINT0 | ||
67 | 1002: | ||
68 | @@ exit here, Z flag unset if IRQ | ||
69 | |||
70 | .endm | ||
diff --git a/arch/arm/mach-s3c24xx/include/mach/irqs.h b/arch/arm/mach-s3c24xx/include/mach/irqs.h index 1e73f5fa8659..b6dd4cb5a2ec 100644 --- a/arch/arm/mach-s3c24xx/include/mach/irqs.h +++ b/arch/arm/mach-s3c24xx/include/mach/irqs.h | |||
@@ -59,49 +59,53 @@ | |||
59 | #define IRQ_ADCPARENT S3C2410_IRQ(31) | 59 | #define IRQ_ADCPARENT S3C2410_IRQ(31) |
60 | 60 | ||
61 | /* interrupts generated from the external interrupts sources */ | 61 | /* interrupts generated from the external interrupts sources */ |
62 | #define IRQ_EINT4 S3C2410_IRQ(32) /* 48 */ | 62 | #define IRQ_EINT0_2412 S3C2410_IRQ(32) |
63 | #define IRQ_EINT5 S3C2410_IRQ(33) | 63 | #define IRQ_EINT1_2412 S3C2410_IRQ(33) |
64 | #define IRQ_EINT6 S3C2410_IRQ(34) | 64 | #define IRQ_EINT2_2412 S3C2410_IRQ(34) |
65 | #define IRQ_EINT7 S3C2410_IRQ(35) | 65 | #define IRQ_EINT3_2412 S3C2410_IRQ(35) |
66 | #define IRQ_EINT8 S3C2410_IRQ(36) | 66 | #define IRQ_EINT4 S3C2410_IRQ(36) /* 52 */ |
67 | #define IRQ_EINT9 S3C2410_IRQ(37) | 67 | #define IRQ_EINT5 S3C2410_IRQ(37) |
68 | #define IRQ_EINT10 S3C2410_IRQ(38) | 68 | #define IRQ_EINT6 S3C2410_IRQ(38) |
69 | #define IRQ_EINT11 S3C2410_IRQ(39) | 69 | #define IRQ_EINT7 S3C2410_IRQ(39) |
70 | #define IRQ_EINT12 S3C2410_IRQ(40) | 70 | #define IRQ_EINT8 S3C2410_IRQ(40) |
71 | #define IRQ_EINT13 S3C2410_IRQ(41) | 71 | #define IRQ_EINT9 S3C2410_IRQ(41) |
72 | #define IRQ_EINT14 S3C2410_IRQ(42) | 72 | #define IRQ_EINT10 S3C2410_IRQ(42) |
73 | #define IRQ_EINT15 S3C2410_IRQ(43) | 73 | #define IRQ_EINT11 S3C2410_IRQ(43) |
74 | #define IRQ_EINT16 S3C2410_IRQ(44) | 74 | #define IRQ_EINT12 S3C2410_IRQ(44) |
75 | #define IRQ_EINT17 S3C2410_IRQ(45) | 75 | #define IRQ_EINT13 S3C2410_IRQ(45) |
76 | #define IRQ_EINT18 S3C2410_IRQ(46) | 76 | #define IRQ_EINT14 S3C2410_IRQ(46) |
77 | #define IRQ_EINT19 S3C2410_IRQ(47) | 77 | #define IRQ_EINT15 S3C2410_IRQ(47) |
78 | #define IRQ_EINT20 S3C2410_IRQ(48) /* 64 */ | 78 | #define IRQ_EINT16 S3C2410_IRQ(48) |
79 | #define IRQ_EINT21 S3C2410_IRQ(49) | 79 | #define IRQ_EINT17 S3C2410_IRQ(49) |
80 | #define IRQ_EINT22 S3C2410_IRQ(50) | 80 | #define IRQ_EINT18 S3C2410_IRQ(50) |
81 | #define IRQ_EINT23 S3C2410_IRQ(51) | 81 | #define IRQ_EINT19 S3C2410_IRQ(51) |
82 | #define IRQ_EINT20 S3C2410_IRQ(52) /* 68 */ | ||
83 | #define IRQ_EINT21 S3C2410_IRQ(53) | ||
84 | #define IRQ_EINT22 S3C2410_IRQ(54) | ||
85 | #define IRQ_EINT23 S3C2410_IRQ(55) | ||
82 | 86 | ||
83 | #define IRQ_EINT_BIT(x) ((x) - IRQ_EINT4 + 4) | 87 | #define IRQ_EINT_BIT(x) ((x) - IRQ_EINT4 + 4) |
84 | #define IRQ_EINT(x) (((x) >= 4) ? (IRQ_EINT4 + (x) - 4) : (IRQ_EINT0 + (x))) | 88 | #define IRQ_EINT(x) (((x) >= 4) ? (IRQ_EINT4 + (x) - 4) : (IRQ_EINT0 + (x))) |
85 | 89 | ||
86 | #define IRQ_LCD_FIFO S3C2410_IRQ(52) | 90 | #define IRQ_LCD_FIFO S3C2410_IRQ(56) |
87 | #define IRQ_LCD_FRAME S3C2410_IRQ(53) | 91 | #define IRQ_LCD_FRAME S3C2410_IRQ(57) |
88 | 92 | ||
89 | /* IRQs for the interal UARTs, and ADC | 93 | /* IRQs for the interal UARTs, and ADC |
90 | * these need to be ordered in number of appearance in the | 94 | * these need to be ordered in number of appearance in the |
91 | * SUBSRC mask register | 95 | * SUBSRC mask register |
92 | */ | 96 | */ |
93 | 97 | ||
94 | #define S3C2410_IRQSUB(x) S3C2410_IRQ((x)+54) | 98 | #define S3C2410_IRQSUB(x) S3C2410_IRQ((x)+58) |
95 | 99 | ||
96 | #define IRQ_S3CUART_RX0 S3C2410_IRQSUB(0) /* 70 */ | 100 | #define IRQ_S3CUART_RX0 S3C2410_IRQSUB(0) /* 74 */ |
97 | #define IRQ_S3CUART_TX0 S3C2410_IRQSUB(1) | 101 | #define IRQ_S3CUART_TX0 S3C2410_IRQSUB(1) |
98 | #define IRQ_S3CUART_ERR0 S3C2410_IRQSUB(2) | 102 | #define IRQ_S3CUART_ERR0 S3C2410_IRQSUB(2) |
99 | 103 | ||
100 | #define IRQ_S3CUART_RX1 S3C2410_IRQSUB(3) /* 73 */ | 104 | #define IRQ_S3CUART_RX1 S3C2410_IRQSUB(3) /* 77 */ |
101 | #define IRQ_S3CUART_TX1 S3C2410_IRQSUB(4) | 105 | #define IRQ_S3CUART_TX1 S3C2410_IRQSUB(4) |
102 | #define IRQ_S3CUART_ERR1 S3C2410_IRQSUB(5) | 106 | #define IRQ_S3CUART_ERR1 S3C2410_IRQSUB(5) |
103 | 107 | ||
104 | #define IRQ_S3CUART_RX2 S3C2410_IRQSUB(6) /* 76 */ | 108 | #define IRQ_S3CUART_RX2 S3C2410_IRQSUB(6) /* 80 */ |
105 | #define IRQ_S3CUART_TX2 S3C2410_IRQSUB(7) | 109 | #define IRQ_S3CUART_TX2 S3C2410_IRQSUB(7) |
106 | #define IRQ_S3CUART_ERR2 S3C2410_IRQSUB(8) | 110 | #define IRQ_S3CUART_ERR2 S3C2410_IRQSUB(8) |
107 | 111 | ||
@@ -136,7 +140,7 @@ | |||
136 | 140 | ||
137 | /* second interrupt-register of s3c2416/s3c2450 */ | 141 | /* second interrupt-register of s3c2416/s3c2450 */ |
138 | 142 | ||
139 | #define S3C2416_IRQ(x) S3C2410_IRQ((x) + 54 + 29) | 143 | #define S3C2416_IRQ(x) S3C2410_IRQ((x) + 58 + 29) |
140 | #define IRQ_S3C2416_2D S3C2416_IRQ(0) | 144 | #define IRQ_S3C2416_2D S3C2416_IRQ(0) |
141 | #define IRQ_S3C2416_IIC1 S3C2416_IRQ(1) | 145 | #define IRQ_S3C2416_IIC1 S3C2416_IRQ(1) |
142 | #define IRQ_S3C2416_RESERVED2 S3C2416_IRQ(2) | 146 | #define IRQ_S3C2416_RESERVED2 S3C2416_IRQ(2) |
diff --git a/arch/arm/mach-s3c24xx/irq-s3c2412.c b/arch/arm/mach-s3c24xx/irq-s3c2412.c deleted file mode 100644 index 67d763178d3f..000000000000 --- a/arch/arm/mach-s3c24xx/irq-s3c2412.c +++ /dev/null | |||
@@ -1,215 +0,0 @@ | |||
1 | /* linux/arch/arm/mach-s3c2412/irq.c | ||
2 | * | ||
3 | * Copyright (c) 2006 Simtec Electronics | ||
4 | * Ben Dooks <ben@simtec.co.uk> | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License as published by | ||
8 | * the Free Software Foundation; either version 2 of the License, or | ||
9 | * (at your option) any later version. | ||
10 | * | ||
11 | * This program is distributed in the hope that it will be useful, | ||
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
14 | * GNU General Public License for more details. | ||
15 | * | ||
16 | * You should have received a copy of the GNU General Public License | ||
17 | * along with this program; if not, write to the Free Software | ||
18 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
19 | * | ||
20 | */ | ||
21 | |||
22 | #include <linux/init.h> | ||
23 | #include <linux/module.h> | ||
24 | #include <linux/interrupt.h> | ||
25 | #include <linux/ioport.h> | ||
26 | #include <linux/device.h> | ||
27 | #include <linux/io.h> | ||
28 | |||
29 | #include <mach/hardware.h> | ||
30 | #include <asm/irq.h> | ||
31 | |||
32 | #include <asm/mach/irq.h> | ||
33 | |||
34 | #include <mach/regs-irq.h> | ||
35 | #include <mach/regs-gpio.h> | ||
36 | |||
37 | #include <plat/cpu.h> | ||
38 | #include <plat/irq.h> | ||
39 | #include <plat/pm.h> | ||
40 | |||
41 | #include "s3c2412-power.h" | ||
42 | |||
43 | #define INTMSK(start, end) ((1 << ((end) + 1 - (start))) - 1) | ||
44 | #define INTMSK_SUB(start, end) (INTMSK(start, end) << ((start - S3C2410_IRQSUB(0)))) | ||
45 | |||
46 | /* the s3c2412 changes the behaviour of IRQ_EINT0 through IRQ_EINT3 by | ||
47 | * having them turn up in both the INT* and the EINT* registers. Whilst | ||
48 | * both show the status, they both now need to be acked when the IRQs | ||
49 | * go off. | ||
50 | */ | ||
51 | |||
52 | static void | ||
53 | s3c2412_irq_mask(struct irq_data *data) | ||
54 | { | ||
55 | unsigned long bitval = 1UL << (data->irq - IRQ_EINT0); | ||
56 | unsigned long mask; | ||
57 | |||
58 | mask = __raw_readl(S3C2410_INTMSK); | ||
59 | __raw_writel(mask | bitval, S3C2410_INTMSK); | ||
60 | |||
61 | mask = __raw_readl(S3C2412_EINTMASK); | ||
62 | __raw_writel(mask | bitval, S3C2412_EINTMASK); | ||
63 | } | ||
64 | |||
65 | static inline void | ||
66 | s3c2412_irq_ack(struct irq_data *data) | ||
67 | { | ||
68 | unsigned long bitval = 1UL << (data->irq - IRQ_EINT0); | ||
69 | |||
70 | __raw_writel(bitval, S3C2412_EINTPEND); | ||
71 | __raw_writel(bitval, S3C2410_SRCPND); | ||
72 | __raw_writel(bitval, S3C2410_INTPND); | ||
73 | } | ||
74 | |||
75 | static inline void | ||
76 | s3c2412_irq_maskack(struct irq_data *data) | ||
77 | { | ||
78 | unsigned long bitval = 1UL << (data->irq - IRQ_EINT0); | ||
79 | unsigned long mask; | ||
80 | |||
81 | mask = __raw_readl(S3C2410_INTMSK); | ||
82 | __raw_writel(mask|bitval, S3C2410_INTMSK); | ||
83 | |||
84 | mask = __raw_readl(S3C2412_EINTMASK); | ||
85 | __raw_writel(mask | bitval, S3C2412_EINTMASK); | ||
86 | |||
87 | __raw_writel(bitval, S3C2412_EINTPEND); | ||
88 | __raw_writel(bitval, S3C2410_SRCPND); | ||
89 | __raw_writel(bitval, S3C2410_INTPND); | ||
90 | } | ||
91 | |||
92 | static void | ||
93 | s3c2412_irq_unmask(struct irq_data *data) | ||
94 | { | ||
95 | unsigned long bitval = 1UL << (data->irq - IRQ_EINT0); | ||
96 | unsigned long mask; | ||
97 | |||
98 | mask = __raw_readl(S3C2412_EINTMASK); | ||
99 | __raw_writel(mask & ~bitval, S3C2412_EINTMASK); | ||
100 | |||
101 | mask = __raw_readl(S3C2410_INTMSK); | ||
102 | __raw_writel(mask & ~bitval, S3C2410_INTMSK); | ||
103 | } | ||
104 | |||
105 | static struct irq_chip s3c2412_irq_eint0t4 = { | ||
106 | .irq_ack = s3c2412_irq_ack, | ||
107 | .irq_mask = s3c2412_irq_mask, | ||
108 | .irq_unmask = s3c2412_irq_unmask, | ||
109 | .irq_set_wake = s3c_irq_wake, | ||
110 | .irq_set_type = s3c_irqext_type, | ||
111 | }; | ||
112 | |||
113 | #define INTBIT(x) (1 << ((x) - S3C2410_IRQSUB(0))) | ||
114 | |||
115 | /* CF and SDI sub interrupts */ | ||
116 | |||
117 | static void s3c2412_irq_demux_cfsdi(unsigned int irq, struct irq_desc *desc) | ||
118 | { | ||
119 | unsigned int subsrc, submsk; | ||
120 | |||
121 | subsrc = __raw_readl(S3C2410_SUBSRCPND); | ||
122 | submsk = __raw_readl(S3C2410_INTSUBMSK); | ||
123 | |||
124 | subsrc &= ~submsk; | ||
125 | |||
126 | if (subsrc & INTBIT(IRQ_S3C2412_SDI)) | ||
127 | generic_handle_irq(IRQ_S3C2412_SDI); | ||
128 | |||
129 | if (subsrc & INTBIT(IRQ_S3C2412_CF)) | ||
130 | generic_handle_irq(IRQ_S3C2412_CF); | ||
131 | } | ||
132 | |||
133 | #define INTMSK_CFSDI (1UL << (IRQ_S3C2412_CFSDI - IRQ_EINT0)) | ||
134 | #define SUBMSK_CFSDI INTMSK_SUB(IRQ_S3C2412_SDI, IRQ_S3C2412_CF) | ||
135 | |||
136 | static void s3c2412_irq_cfsdi_mask(struct irq_data *data) | ||
137 | { | ||
138 | s3c_irqsub_mask(data->irq, INTMSK_CFSDI, SUBMSK_CFSDI); | ||
139 | } | ||
140 | |||
141 | static void s3c2412_irq_cfsdi_unmask(struct irq_data *data) | ||
142 | { | ||
143 | s3c_irqsub_unmask(data->irq, INTMSK_CFSDI); | ||
144 | } | ||
145 | |||
146 | static void s3c2412_irq_cfsdi_ack(struct irq_data *data) | ||
147 | { | ||
148 | s3c_irqsub_maskack(data->irq, INTMSK_CFSDI, SUBMSK_CFSDI); | ||
149 | } | ||
150 | |||
151 | static struct irq_chip s3c2412_irq_cfsdi = { | ||
152 | .name = "s3c2412-cfsdi", | ||
153 | .irq_ack = s3c2412_irq_cfsdi_ack, | ||
154 | .irq_mask = s3c2412_irq_cfsdi_mask, | ||
155 | .irq_unmask = s3c2412_irq_cfsdi_unmask, | ||
156 | }; | ||
157 | |||
158 | static int s3c2412_irq_rtc_wake(struct irq_data *data, unsigned int state) | ||
159 | { | ||
160 | unsigned long pwrcfg; | ||
161 | |||
162 | pwrcfg = __raw_readl(S3C2412_PWRCFG); | ||
163 | if (state) | ||
164 | pwrcfg &= ~S3C2412_PWRCFG_RTC_MASKIRQ; | ||
165 | else | ||
166 | pwrcfg |= S3C2412_PWRCFG_RTC_MASKIRQ; | ||
167 | __raw_writel(pwrcfg, S3C2412_PWRCFG); | ||
168 | |||
169 | return s3c_irq_chip.irq_set_wake(data, state); | ||
170 | } | ||
171 | |||
172 | static struct irq_chip s3c2412_irq_rtc_chip; | ||
173 | |||
174 | static int s3c2412_irq_add(struct device *dev, struct subsys_interface *sif) | ||
175 | { | ||
176 | unsigned int irqno; | ||
177 | |||
178 | for (irqno = IRQ_EINT0; irqno <= IRQ_EINT3; irqno++) { | ||
179 | irq_set_chip_and_handler(irqno, &s3c2412_irq_eint0t4, | ||
180 | handle_edge_irq); | ||
181 | set_irq_flags(irqno, IRQF_VALID); | ||
182 | } | ||
183 | |||
184 | /* add demux support for CF/SDI */ | ||
185 | |||
186 | irq_set_chained_handler(IRQ_S3C2412_CFSDI, s3c2412_irq_demux_cfsdi); | ||
187 | |||
188 | for (irqno = IRQ_S3C2412_SDI; irqno <= IRQ_S3C2412_CF; irqno++) { | ||
189 | irq_set_chip_and_handler(irqno, &s3c2412_irq_cfsdi, | ||
190 | handle_level_irq); | ||
191 | set_irq_flags(irqno, IRQF_VALID); | ||
192 | } | ||
193 | |||
194 | /* change RTC IRQ's set wake method */ | ||
195 | |||
196 | s3c2412_irq_rtc_chip = s3c_irq_chip; | ||
197 | s3c2412_irq_rtc_chip.irq_set_wake = s3c2412_irq_rtc_wake; | ||
198 | |||
199 | irq_set_chip(IRQ_RTC, &s3c2412_irq_rtc_chip); | ||
200 | |||
201 | return 0; | ||
202 | } | ||
203 | |||
204 | static struct subsys_interface s3c2412_irq_interface = { | ||
205 | .name = "s3c2412_irq", | ||
206 | .subsys = &s3c2412_subsys, | ||
207 | .add_dev = s3c2412_irq_add, | ||
208 | }; | ||
209 | |||
210 | static int s3c2412_irq_init(void) | ||
211 | { | ||
212 | return subsys_interface_register(&s3c2412_irq_interface); | ||
213 | } | ||
214 | |||
215 | arch_initcall(s3c2412_irq_init); | ||
diff --git a/arch/arm/mach-s3c24xx/irq-s3c2440.c b/arch/arm/mach-s3c24xx/irq-s3c2440.c deleted file mode 100644 index 4a18cde439cc..000000000000 --- a/arch/arm/mach-s3c24xx/irq-s3c2440.c +++ /dev/null | |||
@@ -1,128 +0,0 @@ | |||
1 | /* linux/arch/arm/mach-s3c2440/irq.c | ||
2 | * | ||
3 | * Copyright (c) 2003-2004 Simtec Electronics | ||
4 | * Ben Dooks <ben@simtec.co.uk> | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License as published by | ||
8 | * the Free Software Foundation; either version 2 of the License, or | ||
9 | * (at your option) any later version. | ||
10 | * | ||
11 | * This program is distributed in the hope that it will be useful, | ||
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
14 | * GNU General Public License for more details. | ||
15 | * | ||
16 | * You should have received a copy of the GNU General Public License | ||
17 | * along with this program; if not, write to the Free Software | ||
18 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
19 | * | ||
20 | */ | ||
21 | |||
22 | #include <linux/init.h> | ||
23 | #include <linux/module.h> | ||
24 | #include <linux/interrupt.h> | ||
25 | #include <linux/ioport.h> | ||
26 | #include <linux/device.h> | ||
27 | #include <linux/io.h> | ||
28 | |||
29 | #include <mach/hardware.h> | ||
30 | #include <asm/irq.h> | ||
31 | |||
32 | #include <asm/mach/irq.h> | ||
33 | |||
34 | #include <mach/regs-irq.h> | ||
35 | #include <mach/regs-gpio.h> | ||
36 | |||
37 | #include <plat/cpu.h> | ||
38 | #include <plat/pm.h> | ||
39 | #include <plat/irq.h> | ||
40 | |||
41 | /* WDT/AC97 */ | ||
42 | |||
43 | static void s3c_irq_demux_wdtac97(unsigned int irq, | ||
44 | struct irq_desc *desc) | ||
45 | { | ||
46 | unsigned int subsrc, submsk; | ||
47 | |||
48 | /* read the current pending interrupts, and the mask | ||
49 | * for what it is available */ | ||
50 | |||
51 | subsrc = __raw_readl(S3C2410_SUBSRCPND); | ||
52 | submsk = __raw_readl(S3C2410_INTSUBMSK); | ||
53 | |||
54 | subsrc &= ~submsk; | ||
55 | subsrc >>= 13; | ||
56 | subsrc &= 3; | ||
57 | |||
58 | if (subsrc != 0) { | ||
59 | if (subsrc & 1) { | ||
60 | generic_handle_irq(IRQ_S3C2440_WDT); | ||
61 | } | ||
62 | if (subsrc & 2) { | ||
63 | generic_handle_irq(IRQ_S3C2440_AC97); | ||
64 | } | ||
65 | } | ||
66 | } | ||
67 | |||
68 | |||
69 | #define INTMSK_WDT (1UL << (IRQ_WDT - IRQ_EINT0)) | ||
70 | |||
71 | static void | ||
72 | s3c_irq_wdtac97_mask(struct irq_data *data) | ||
73 | { | ||
74 | s3c_irqsub_mask(data->irq, INTMSK_WDT, 3 << 13); | ||
75 | } | ||
76 | |||
77 | static void | ||
78 | s3c_irq_wdtac97_unmask(struct irq_data *data) | ||
79 | { | ||
80 | s3c_irqsub_unmask(data->irq, INTMSK_WDT); | ||
81 | } | ||
82 | |||
83 | static void | ||
84 | s3c_irq_wdtac97_ack(struct irq_data *data) | ||
85 | { | ||
86 | s3c_irqsub_maskack(data->irq, INTMSK_WDT, 3 << 13); | ||
87 | } | ||
88 | |||
89 | static struct irq_chip s3c_irq_wdtac97 = { | ||
90 | .irq_mask = s3c_irq_wdtac97_mask, | ||
91 | .irq_unmask = s3c_irq_wdtac97_unmask, | ||
92 | .irq_ack = s3c_irq_wdtac97_ack, | ||
93 | }; | ||
94 | |||
95 | static int s3c2440_irq_add(struct device *dev, struct subsys_interface *sif) | ||
96 | { | ||
97 | unsigned int irqno; | ||
98 | |||
99 | printk("S3C2440: IRQ Support\n"); | ||
100 | |||
101 | /* add new chained handler for wdt, ac7 */ | ||
102 | |||
103 | irq_set_chip_and_handler(IRQ_WDT, &s3c_irq_level_chip, | ||
104 | handle_level_irq); | ||
105 | irq_set_chained_handler(IRQ_WDT, s3c_irq_demux_wdtac97); | ||
106 | |||
107 | for (irqno = IRQ_S3C2440_WDT; irqno <= IRQ_S3C2440_AC97; irqno++) { | ||
108 | irq_set_chip_and_handler(irqno, &s3c_irq_wdtac97, | ||
109 | handle_level_irq); | ||
110 | set_irq_flags(irqno, IRQF_VALID); | ||
111 | } | ||
112 | |||
113 | return 0; | ||
114 | } | ||
115 | |||
116 | static struct subsys_interface s3c2440_irq_interface = { | ||
117 | .name = "s3c2440_irq", | ||
118 | .subsys = &s3c2440_subsys, | ||
119 | .add_dev = s3c2440_irq_add, | ||
120 | }; | ||
121 | |||
122 | static int s3c2440_irq_init(void) | ||
123 | { | ||
124 | return subsys_interface_register(&s3c2440_irq_interface); | ||
125 | } | ||
126 | |||
127 | arch_initcall(s3c2440_irq_init); | ||
128 | |||
diff --git a/arch/arm/mach-s3c24xx/irq-s3c244x.c b/arch/arm/mach-s3c24xx/irq-s3c244x.c deleted file mode 100644 index 5fe8e58d3afd..000000000000 --- a/arch/arm/mach-s3c24xx/irq-s3c244x.c +++ /dev/null | |||
@@ -1,142 +0,0 @@ | |||
1 | /* linux/arch/arm/plat-s3c24xx/s3c244x-irq.c | ||
2 | * | ||
3 | * Copyright (c) 2003-2004 Simtec Electronics | ||
4 | * Ben Dooks <ben@simtec.co.uk> | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License as published by | ||
8 | * the Free Software Foundation; either version 2 of the License, or | ||
9 | * (at your option) any later version. | ||
10 | * | ||
11 | * This program is distributed in the hope that it will be useful, | ||
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
14 | * GNU General Public License for more details. | ||
15 | * | ||
16 | * You should have received a copy of the GNU General Public License | ||
17 | * along with this program; if not, write to the Free Software | ||
18 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
19 | * | ||
20 | */ | ||
21 | |||
22 | #include <linux/init.h> | ||
23 | #include <linux/module.h> | ||
24 | #include <linux/interrupt.h> | ||
25 | #include <linux/ioport.h> | ||
26 | #include <linux/device.h> | ||
27 | #include <linux/io.h> | ||
28 | |||
29 | #include <mach/hardware.h> | ||
30 | #include <asm/irq.h> | ||
31 | |||
32 | #include <asm/mach/irq.h> | ||
33 | |||
34 | #include <mach/regs-irq.h> | ||
35 | #include <mach/regs-gpio.h> | ||
36 | |||
37 | #include <plat/cpu.h> | ||
38 | #include <plat/pm.h> | ||
39 | #include <plat/irq.h> | ||
40 | |||
41 | /* camera irq */ | ||
42 | |||
43 | static void s3c_irq_demux_cam(unsigned int irq, | ||
44 | struct irq_desc *desc) | ||
45 | { | ||
46 | unsigned int subsrc, submsk; | ||
47 | |||
48 | /* read the current pending interrupts, and the mask | ||
49 | * for what it is available */ | ||
50 | |||
51 | subsrc = __raw_readl(S3C2410_SUBSRCPND); | ||
52 | submsk = __raw_readl(S3C2410_INTSUBMSK); | ||
53 | |||
54 | subsrc &= ~submsk; | ||
55 | subsrc >>= 11; | ||
56 | subsrc &= 3; | ||
57 | |||
58 | if (subsrc != 0) { | ||
59 | if (subsrc & 1) { | ||
60 | generic_handle_irq(IRQ_S3C2440_CAM_C); | ||
61 | } | ||
62 | if (subsrc & 2) { | ||
63 | generic_handle_irq(IRQ_S3C2440_CAM_P); | ||
64 | } | ||
65 | } | ||
66 | } | ||
67 | |||
68 | #define INTMSK_CAM (1UL << (IRQ_CAM - IRQ_EINT0)) | ||
69 | |||
70 | static void | ||
71 | s3c_irq_cam_mask(struct irq_data *data) | ||
72 | { | ||
73 | s3c_irqsub_mask(data->irq, INTMSK_CAM, 3 << 11); | ||
74 | } | ||
75 | |||
76 | static void | ||
77 | s3c_irq_cam_unmask(struct irq_data *data) | ||
78 | { | ||
79 | s3c_irqsub_unmask(data->irq, INTMSK_CAM); | ||
80 | } | ||
81 | |||
82 | static void | ||
83 | s3c_irq_cam_ack(struct irq_data *data) | ||
84 | { | ||
85 | s3c_irqsub_maskack(data->irq, INTMSK_CAM, 3 << 11); | ||
86 | } | ||
87 | |||
88 | static struct irq_chip s3c_irq_cam = { | ||
89 | .irq_mask = s3c_irq_cam_mask, | ||
90 | .irq_unmask = s3c_irq_cam_unmask, | ||
91 | .irq_ack = s3c_irq_cam_ack, | ||
92 | }; | ||
93 | |||
94 | static int s3c244x_irq_add(struct device *dev, struct subsys_interface *sif) | ||
95 | { | ||
96 | unsigned int irqno; | ||
97 | |||
98 | irq_set_chip_and_handler(IRQ_NFCON, &s3c_irq_level_chip, | ||
99 | handle_level_irq); | ||
100 | set_irq_flags(IRQ_NFCON, IRQF_VALID); | ||
101 | |||
102 | /* add chained handler for camera */ | ||
103 | |||
104 | irq_set_chip_and_handler(IRQ_CAM, &s3c_irq_level_chip, | ||
105 | handle_level_irq); | ||
106 | irq_set_chained_handler(IRQ_CAM, s3c_irq_demux_cam); | ||
107 | |||
108 | for (irqno = IRQ_S3C2440_CAM_C; irqno <= IRQ_S3C2440_CAM_P; irqno++) { | ||
109 | irq_set_chip_and_handler(irqno, &s3c_irq_cam, | ||
110 | handle_level_irq); | ||
111 | set_irq_flags(irqno, IRQF_VALID); | ||
112 | } | ||
113 | |||
114 | return 0; | ||
115 | } | ||
116 | |||
117 | static struct subsys_interface s3c2440_irq_interface = { | ||
118 | .name = "s3c2440_irq", | ||
119 | .subsys = &s3c2440_subsys, | ||
120 | .add_dev = s3c244x_irq_add, | ||
121 | }; | ||
122 | |||
123 | static int s3c2440_irq_init(void) | ||
124 | { | ||
125 | return subsys_interface_register(&s3c2440_irq_interface); | ||
126 | } | ||
127 | |||
128 | arch_initcall(s3c2440_irq_init); | ||
129 | |||
130 | static struct subsys_interface s3c2442_irq_interface = { | ||
131 | .name = "s3c2442_irq", | ||
132 | .subsys = &s3c2442_subsys, | ||
133 | .add_dev = s3c244x_irq_add, | ||
134 | }; | ||
135 | |||
136 | |||
137 | static int s3c2442_irq_init(void) | ||
138 | { | ||
139 | return subsys_interface_register(&s3c2442_irq_interface); | ||
140 | } | ||
141 | |||
142 | arch_initcall(s3c2442_irq_init); | ||
diff --git a/arch/arm/mach-s3c24xx/irq.c b/arch/arm/mach-s3c24xx/irq.c deleted file mode 100644 index b41c2cb7af4a..000000000000 --- a/arch/arm/mach-s3c24xx/irq.c +++ /dev/null | |||
@@ -1,821 +0,0 @@ | |||
1 | /* | ||
2 | * S3C24XX IRQ handling | ||
3 | * | ||
4 | * Copyright (c) 2003-2004 Simtec Electronics | ||
5 | * Ben Dooks <ben@simtec.co.uk> | ||
6 | * Copyright (c) 2012 Heiko Stuebner <heiko@sntech.de> | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License as published by | ||
10 | * the Free Software Foundation; either version 2 of the License, or | ||
11 | * (at your option) any later version. | ||
12 | * | ||
13 | * This program is distributed in the hope that it will be useful, | ||
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
16 | * GNU General Public License for more details. | ||
17 | */ | ||
18 | |||
19 | #include <linux/init.h> | ||
20 | #include <linux/slab.h> | ||
21 | #include <linux/module.h> | ||
22 | #include <linux/io.h> | ||
23 | #include <linux/err.h> | ||
24 | #include <linux/interrupt.h> | ||
25 | #include <linux/ioport.h> | ||
26 | #include <linux/device.h> | ||
27 | #include <linux/irqdomain.h> | ||
28 | #include <linux/irqchip/chained_irq.h> | ||
29 | |||
30 | #include <asm/mach/irq.h> | ||
31 | |||
32 | #include <mach/regs-irq.h> | ||
33 | #include <mach/regs-gpio.h> | ||
34 | |||
35 | #include <plat/cpu.h> | ||
36 | #include <plat/regs-irqtype.h> | ||
37 | #include <plat/pm.h> | ||
38 | |||
39 | #define S3C_IRQTYPE_NONE 0 | ||
40 | #define S3C_IRQTYPE_EINT 1 | ||
41 | #define S3C_IRQTYPE_EDGE 2 | ||
42 | #define S3C_IRQTYPE_LEVEL 3 | ||
43 | |||
44 | struct s3c_irq_data { | ||
45 | unsigned int type; | ||
46 | unsigned long parent_irq; | ||
47 | |||
48 | /* data gets filled during init */ | ||
49 | struct s3c_irq_intc *intc; | ||
50 | unsigned long sub_bits; | ||
51 | struct s3c_irq_intc *sub_intc; | ||
52 | }; | ||
53 | |||
54 | /* | ||
55 | * Sructure holding the controller data | ||
56 | * @reg_pending register holding pending irqs | ||
57 | * @reg_intpnd special register intpnd in main intc | ||
58 | * @reg_mask mask register | ||
59 | * @domain irq_domain of the controller | ||
60 | * @parent parent controller for ext and sub irqs | ||
61 | * @irqs irq-data, always s3c_irq_data[32] | ||
62 | */ | ||
63 | struct s3c_irq_intc { | ||
64 | void __iomem *reg_pending; | ||
65 | void __iomem *reg_intpnd; | ||
66 | void __iomem *reg_mask; | ||
67 | struct irq_domain *domain; | ||
68 | struct s3c_irq_intc *parent; | ||
69 | struct s3c_irq_data *irqs; | ||
70 | }; | ||
71 | |||
72 | static void s3c_irq_mask(struct irq_data *data) | ||
73 | { | ||
74 | struct s3c_irq_intc *intc = data->domain->host_data; | ||
75 | struct s3c_irq_intc *parent_intc = intc->parent; | ||
76 | struct s3c_irq_data *irq_data = &intc->irqs[data->hwirq]; | ||
77 | struct s3c_irq_data *parent_data; | ||
78 | unsigned long mask; | ||
79 | unsigned int irqno; | ||
80 | |||
81 | mask = __raw_readl(intc->reg_mask); | ||
82 | mask |= (1UL << data->hwirq); | ||
83 | __raw_writel(mask, intc->reg_mask); | ||
84 | |||
85 | if (parent_intc && irq_data->parent_irq) { | ||
86 | parent_data = &parent_intc->irqs[irq_data->parent_irq]; | ||
87 | |||
88 | /* check to see if we need to mask the parent IRQ */ | ||
89 | if ((mask & parent_data->sub_bits) == parent_data->sub_bits) { | ||
90 | irqno = irq_find_mapping(parent_intc->domain, | ||
91 | irq_data->parent_irq); | ||
92 | s3c_irq_mask(irq_get_irq_data(irqno)); | ||
93 | } | ||
94 | } | ||
95 | } | ||
96 | |||
97 | static void s3c_irq_unmask(struct irq_data *data) | ||
98 | { | ||
99 | struct s3c_irq_intc *intc = data->domain->host_data; | ||
100 | struct s3c_irq_intc *parent_intc = intc->parent; | ||
101 | struct s3c_irq_data *irq_data = &intc->irqs[data->hwirq]; | ||
102 | unsigned long mask; | ||
103 | unsigned int irqno; | ||
104 | |||
105 | mask = __raw_readl(intc->reg_mask); | ||
106 | mask &= ~(1UL << data->hwirq); | ||
107 | __raw_writel(mask, intc->reg_mask); | ||
108 | |||
109 | if (parent_intc && irq_data->parent_irq) { | ||
110 | irqno = irq_find_mapping(parent_intc->domain, | ||
111 | irq_data->parent_irq); | ||
112 | s3c_irq_unmask(irq_get_irq_data(irqno)); | ||
113 | } | ||
114 | } | ||
115 | |||
116 | static inline void s3c_irq_ack(struct irq_data *data) | ||
117 | { | ||
118 | struct s3c_irq_intc *intc = data->domain->host_data; | ||
119 | unsigned long bitval = 1UL << data->hwirq; | ||
120 | |||
121 | __raw_writel(bitval, intc->reg_pending); | ||
122 | if (intc->reg_intpnd) | ||
123 | __raw_writel(bitval, intc->reg_intpnd); | ||
124 | } | ||
125 | |||
126 | static int s3c_irqext_type_set(void __iomem *gpcon_reg, | ||
127 | void __iomem *extint_reg, | ||
128 | unsigned long gpcon_offset, | ||
129 | unsigned long extint_offset, | ||
130 | unsigned int type) | ||
131 | { | ||
132 | unsigned long newvalue = 0, value; | ||
133 | |||
134 | /* Set the GPIO to external interrupt mode */ | ||
135 | value = __raw_readl(gpcon_reg); | ||
136 | value = (value & ~(3 << gpcon_offset)) | (0x02 << gpcon_offset); | ||
137 | __raw_writel(value, gpcon_reg); | ||
138 | |||
139 | /* Set the external interrupt to pointed trigger type */ | ||
140 | switch (type) | ||
141 | { | ||
142 | case IRQ_TYPE_NONE: | ||
143 | pr_warn("No edge setting!\n"); | ||
144 | break; | ||
145 | |||
146 | case IRQ_TYPE_EDGE_RISING: | ||
147 | newvalue = S3C2410_EXTINT_RISEEDGE; | ||
148 | break; | ||
149 | |||
150 | case IRQ_TYPE_EDGE_FALLING: | ||
151 | newvalue = S3C2410_EXTINT_FALLEDGE; | ||
152 | break; | ||
153 | |||
154 | case IRQ_TYPE_EDGE_BOTH: | ||
155 | newvalue = S3C2410_EXTINT_BOTHEDGE; | ||
156 | break; | ||
157 | |||
158 | case IRQ_TYPE_LEVEL_LOW: | ||
159 | newvalue = S3C2410_EXTINT_LOWLEV; | ||
160 | break; | ||
161 | |||
162 | case IRQ_TYPE_LEVEL_HIGH: | ||
163 | newvalue = S3C2410_EXTINT_HILEV; | ||
164 | break; | ||
165 | |||
166 | default: | ||
167 | pr_err("No such irq type %d", type); | ||
168 | return -EINVAL; | ||
169 | } | ||
170 | |||
171 | value = __raw_readl(extint_reg); | ||
172 | value = (value & ~(7 << extint_offset)) | (newvalue << extint_offset); | ||
173 | __raw_writel(value, extint_reg); | ||
174 | |||
175 | return 0; | ||
176 | } | ||
177 | |||
178 | static int s3c_irqext_type(struct irq_data *data, unsigned int type) | ||
179 | { | ||
180 | void __iomem *extint_reg; | ||
181 | void __iomem *gpcon_reg; | ||
182 | unsigned long gpcon_offset, extint_offset; | ||
183 | |||
184 | if ((data->hwirq >= 4) && (data->hwirq <= 7)) { | ||
185 | gpcon_reg = S3C2410_GPFCON; | ||
186 | extint_reg = S3C24XX_EXTINT0; | ||
187 | gpcon_offset = (data->hwirq) * 2; | ||
188 | extint_offset = (data->hwirq) * 4; | ||
189 | } else if ((data->hwirq >= 8) && (data->hwirq <= 15)) { | ||
190 | gpcon_reg = S3C2410_GPGCON; | ||
191 | extint_reg = S3C24XX_EXTINT1; | ||
192 | gpcon_offset = (data->hwirq - 8) * 2; | ||
193 | extint_offset = (data->hwirq - 8) * 4; | ||
194 | } else if ((data->hwirq >= 16) && (data->hwirq <= 23)) { | ||
195 | gpcon_reg = S3C2410_GPGCON; | ||
196 | extint_reg = S3C24XX_EXTINT2; | ||
197 | gpcon_offset = (data->hwirq - 8) * 2; | ||
198 | extint_offset = (data->hwirq - 16) * 4; | ||
199 | } else { | ||
200 | return -EINVAL; | ||
201 | } | ||
202 | |||
203 | return s3c_irqext_type_set(gpcon_reg, extint_reg, gpcon_offset, | ||
204 | extint_offset, type); | ||
205 | } | ||
206 | |||
207 | static int s3c_irqext0_type(struct irq_data *data, unsigned int type) | ||
208 | { | ||
209 | void __iomem *extint_reg; | ||
210 | void __iomem *gpcon_reg; | ||
211 | unsigned long gpcon_offset, extint_offset; | ||
212 | |||
213 | if ((data->hwirq >= 0) && (data->hwirq <= 3)) { | ||
214 | gpcon_reg = S3C2410_GPFCON; | ||
215 | extint_reg = S3C24XX_EXTINT0; | ||
216 | gpcon_offset = (data->hwirq) * 2; | ||
217 | extint_offset = (data->hwirq) * 4; | ||
218 | } else { | ||
219 | return -EINVAL; | ||
220 | } | ||
221 | |||
222 | return s3c_irqext_type_set(gpcon_reg, extint_reg, gpcon_offset, | ||
223 | extint_offset, type); | ||
224 | } | ||
225 | |||
226 | static struct irq_chip s3c_irq_chip = { | ||
227 | .name = "s3c", | ||
228 | .irq_ack = s3c_irq_ack, | ||
229 | .irq_mask = s3c_irq_mask, | ||
230 | .irq_unmask = s3c_irq_unmask, | ||
231 | .irq_set_wake = s3c_irq_wake | ||
232 | }; | ||
233 | |||
234 | static struct irq_chip s3c_irq_level_chip = { | ||
235 | .name = "s3c-level", | ||
236 | .irq_mask = s3c_irq_mask, | ||
237 | .irq_unmask = s3c_irq_unmask, | ||
238 | .irq_ack = s3c_irq_ack, | ||
239 | }; | ||
240 | |||
241 | static struct irq_chip s3c_irqext_chip = { | ||
242 | .name = "s3c-ext", | ||
243 | .irq_mask = s3c_irq_mask, | ||
244 | .irq_unmask = s3c_irq_unmask, | ||
245 | .irq_ack = s3c_irq_ack, | ||
246 | .irq_set_type = s3c_irqext_type, | ||
247 | .irq_set_wake = s3c_irqext_wake | ||
248 | }; | ||
249 | |||
250 | static struct irq_chip s3c_irq_eint0t4 = { | ||
251 | .name = "s3c-ext0", | ||
252 | .irq_ack = s3c_irq_ack, | ||
253 | .irq_mask = s3c_irq_mask, | ||
254 | .irq_unmask = s3c_irq_unmask, | ||
255 | .irq_set_wake = s3c_irq_wake, | ||
256 | .irq_set_type = s3c_irqext0_type, | ||
257 | }; | ||
258 | |||
259 | static void s3c_irq_demux(unsigned int irq, struct irq_desc *desc) | ||
260 | { | ||
261 | struct irq_chip *chip = irq_desc_get_chip(desc); | ||
262 | struct s3c_irq_intc *intc = desc->irq_data.domain->host_data; | ||
263 | struct s3c_irq_data *irq_data = &intc->irqs[desc->irq_data.hwirq]; | ||
264 | struct s3c_irq_intc *sub_intc = irq_data->sub_intc; | ||
265 | unsigned long src; | ||
266 | unsigned long msk; | ||
267 | unsigned int n; | ||
268 | |||
269 | chained_irq_enter(chip, desc); | ||
270 | |||
271 | src = __raw_readl(sub_intc->reg_pending); | ||
272 | msk = __raw_readl(sub_intc->reg_mask); | ||
273 | |||
274 | src &= ~msk; | ||
275 | src &= irq_data->sub_bits; | ||
276 | |||
277 | while (src) { | ||
278 | n = __ffs(src); | ||
279 | src &= ~(1 << n); | ||
280 | generic_handle_irq(irq_find_mapping(sub_intc->domain, n)); | ||
281 | } | ||
282 | |||
283 | chained_irq_exit(chip, desc); | ||
284 | } | ||
285 | |||
286 | #ifdef CONFIG_FIQ | ||
287 | /** | ||
288 | * s3c24xx_set_fiq - set the FIQ routing | ||
289 | * @irq: IRQ number to route to FIQ on processor. | ||
290 | * @on: Whether to route @irq to the FIQ, or to remove the FIQ routing. | ||
291 | * | ||
292 | * Change the state of the IRQ to FIQ routing depending on @irq and @on. If | ||
293 | * @on is true, the @irq is checked to see if it can be routed and the | ||
294 | * interrupt controller updated to route the IRQ. If @on is false, the FIQ | ||
295 | * routing is cleared, regardless of which @irq is specified. | ||
296 | */ | ||
297 | int s3c24xx_set_fiq(unsigned int irq, bool on) | ||
298 | { | ||
299 | u32 intmod; | ||
300 | unsigned offs; | ||
301 | |||
302 | if (on) { | ||
303 | offs = irq - FIQ_START; | ||
304 | if (offs > 31) | ||
305 | return -EINVAL; | ||
306 | |||
307 | intmod = 1 << offs; | ||
308 | } else { | ||
309 | intmod = 0; | ||
310 | } | ||
311 | |||
312 | __raw_writel(intmod, S3C2410_INTMOD); | ||
313 | return 0; | ||
314 | } | ||
315 | |||
316 | EXPORT_SYMBOL_GPL(s3c24xx_set_fiq); | ||
317 | #endif | ||
318 | |||
319 | static int s3c24xx_irq_map(struct irq_domain *h, unsigned int virq, | ||
320 | irq_hw_number_t hw) | ||
321 | { | ||
322 | struct s3c_irq_intc *intc = h->host_data; | ||
323 | struct s3c_irq_data *irq_data = &intc->irqs[hw]; | ||
324 | struct s3c_irq_intc *parent_intc; | ||
325 | struct s3c_irq_data *parent_irq_data; | ||
326 | unsigned int irqno; | ||
327 | |||
328 | if (!intc) { | ||
329 | pr_err("irq-s3c24xx: no controller found for hwirq %lu\n", hw); | ||
330 | return -EINVAL; | ||
331 | } | ||
332 | |||
333 | if (!irq_data) { | ||
334 | pr_err("irq-s3c24xx: no irq data found for hwirq %lu\n", hw); | ||
335 | return -EINVAL; | ||
336 | } | ||
337 | |||
338 | /* attach controller pointer to irq_data */ | ||
339 | irq_data->intc = intc; | ||
340 | |||
341 | /* set handler and flags */ | ||
342 | switch (irq_data->type) { | ||
343 | case S3C_IRQTYPE_NONE: | ||
344 | return 0; | ||
345 | case S3C_IRQTYPE_EINT: | ||
346 | if (irq_data->parent_irq) | ||
347 | irq_set_chip_and_handler(virq, &s3c_irqext_chip, | ||
348 | handle_edge_irq); | ||
349 | else | ||
350 | irq_set_chip_and_handler(virq, &s3c_irq_eint0t4, | ||
351 | handle_edge_irq); | ||
352 | break; | ||
353 | case S3C_IRQTYPE_EDGE: | ||
354 | if (irq_data->parent_irq || | ||
355 | intc->reg_pending == S3C2416_SRCPND2) | ||
356 | irq_set_chip_and_handler(virq, &s3c_irq_level_chip, | ||
357 | handle_edge_irq); | ||
358 | else | ||
359 | irq_set_chip_and_handler(virq, &s3c_irq_chip, | ||
360 | handle_edge_irq); | ||
361 | break; | ||
362 | case S3C_IRQTYPE_LEVEL: | ||
363 | if (irq_data->parent_irq) | ||
364 | irq_set_chip_and_handler(virq, &s3c_irq_level_chip, | ||
365 | handle_level_irq); | ||
366 | else | ||
367 | irq_set_chip_and_handler(virq, &s3c_irq_chip, | ||
368 | handle_level_irq); | ||
369 | break; | ||
370 | default: | ||
371 | pr_err("irq-s3c24xx: unsupported irqtype %d\n", irq_data->type); | ||
372 | return -EINVAL; | ||
373 | } | ||
374 | set_irq_flags(virq, IRQF_VALID); | ||
375 | |||
376 | if (irq_data->parent_irq) { | ||
377 | parent_intc = intc->parent; | ||
378 | if (!parent_intc) { | ||
379 | pr_err("irq-s3c24xx: no parent controller found for hwirq %lu\n", | ||
380 | hw); | ||
381 | goto err; | ||
382 | } | ||
383 | |||
384 | parent_irq_data = &parent_intc->irqs[irq_data->parent_irq]; | ||
385 | if (!irq_data) { | ||
386 | pr_err("irq-s3c24xx: no irq data found for hwirq %lu\n", | ||
387 | hw); | ||
388 | goto err; | ||
389 | } | ||
390 | |||
391 | parent_irq_data->sub_intc = intc; | ||
392 | parent_irq_data->sub_bits |= (1UL << hw); | ||
393 | |||
394 | /* attach the demuxer to the parent irq */ | ||
395 | irqno = irq_find_mapping(parent_intc->domain, | ||
396 | irq_data->parent_irq); | ||
397 | if (!irqno) { | ||
398 | pr_err("irq-s3c24xx: could not find mapping for parent irq %lu\n", | ||
399 | irq_data->parent_irq); | ||
400 | goto err; | ||
401 | } | ||
402 | irq_set_chained_handler(irqno, s3c_irq_demux); | ||
403 | } | ||
404 | |||
405 | return 0; | ||
406 | |||
407 | err: | ||
408 | set_irq_flags(virq, 0); | ||
409 | |||
410 | /* the only error can result from bad mapping data*/ | ||
411 | return -EINVAL; | ||
412 | } | ||
413 | |||
414 | static struct irq_domain_ops s3c24xx_irq_ops = { | ||
415 | .map = s3c24xx_irq_map, | ||
416 | .xlate = irq_domain_xlate_twocell, | ||
417 | }; | ||
418 | |||
419 | static void s3c24xx_clear_intc(struct s3c_irq_intc *intc) | ||
420 | { | ||
421 | void __iomem *reg_source; | ||
422 | unsigned long pend; | ||
423 | unsigned long last; | ||
424 | int i; | ||
425 | |||
426 | /* if intpnd is set, read the next pending irq from there */ | ||
427 | reg_source = intc->reg_intpnd ? intc->reg_intpnd : intc->reg_pending; | ||
428 | |||
429 | last = 0; | ||
430 | for (i = 0; i < 4; i++) { | ||
431 | pend = __raw_readl(reg_source); | ||
432 | |||
433 | if (pend == 0 || pend == last) | ||
434 | break; | ||
435 | |||
436 | __raw_writel(pend, intc->reg_pending); | ||
437 | if (intc->reg_intpnd) | ||
438 | __raw_writel(pend, intc->reg_intpnd); | ||
439 | |||
440 | pr_info("irq: clearing pending status %08x\n", (int)pend); | ||
441 | last = pend; | ||
442 | } | ||
443 | } | ||
444 | |||
445 | struct s3c_irq_intc *s3c24xx_init_intc(struct device_node *np, | ||
446 | struct s3c_irq_data *irq_data, | ||
447 | struct s3c_irq_intc *parent, | ||
448 | unsigned long address) | ||
449 | { | ||
450 | struct s3c_irq_intc *intc; | ||
451 | void __iomem *base = (void *)0xf6000000; /* static mapping */ | ||
452 | int irq_num; | ||
453 | int irq_start; | ||
454 | int irq_offset; | ||
455 | int ret; | ||
456 | |||
457 | intc = kzalloc(sizeof(struct s3c_irq_intc), GFP_KERNEL); | ||
458 | if (!intc) | ||
459 | return ERR_PTR(-ENOMEM); | ||
460 | |||
461 | intc->irqs = irq_data; | ||
462 | |||
463 | if (parent) | ||
464 | intc->parent = parent; | ||
465 | |||
466 | /* select the correct data for the controller. | ||
467 | * Need to hard code the irq num start and offset | ||
468 | * to preserve the static mapping for now | ||
469 | */ | ||
470 | switch (address) { | ||
471 | case 0x4a000000: | ||
472 | pr_debug("irq: found main intc\n"); | ||
473 | intc->reg_pending = base; | ||
474 | intc->reg_mask = base + 0x08; | ||
475 | intc->reg_intpnd = base + 0x10; | ||
476 | irq_num = 32; | ||
477 | irq_start = S3C2410_IRQ(0); | ||
478 | irq_offset = 0; | ||
479 | break; | ||
480 | case 0x4a000018: | ||
481 | pr_debug("irq: found subintc\n"); | ||
482 | intc->reg_pending = base + 0x18; | ||
483 | intc->reg_mask = base + 0x1c; | ||
484 | irq_num = 29; | ||
485 | irq_start = S3C2410_IRQSUB(0); | ||
486 | irq_offset = 0; | ||
487 | break; | ||
488 | case 0x4a000040: | ||
489 | pr_debug("irq: found intc2\n"); | ||
490 | intc->reg_pending = base + 0x40; | ||
491 | intc->reg_mask = base + 0x48; | ||
492 | intc->reg_intpnd = base + 0x50; | ||
493 | irq_num = 8; | ||
494 | irq_start = S3C2416_IRQ(0); | ||
495 | irq_offset = 0; | ||
496 | break; | ||
497 | case 0x560000a4: | ||
498 | pr_debug("irq: found eintc\n"); | ||
499 | base = (void *)0xfd000000; | ||
500 | |||
501 | intc->reg_mask = base + 0xa4; | ||
502 | intc->reg_pending = base + 0xa8; | ||
503 | irq_num = 20; | ||
504 | irq_start = S3C2410_IRQ(32); | ||
505 | irq_offset = 4; | ||
506 | break; | ||
507 | default: | ||
508 | pr_err("irq: unsupported controller address\n"); | ||
509 | ret = -EINVAL; | ||
510 | goto err; | ||
511 | } | ||
512 | |||
513 | /* now that all the data is complete, init the irq-domain */ | ||
514 | s3c24xx_clear_intc(intc); | ||
515 | intc->domain = irq_domain_add_legacy(np, irq_num, irq_start, | ||
516 | irq_offset, &s3c24xx_irq_ops, | ||
517 | intc); | ||
518 | if (!intc->domain) { | ||
519 | pr_err("irq: could not create irq-domain\n"); | ||
520 | ret = -EINVAL; | ||
521 | goto err; | ||
522 | } | ||
523 | |||
524 | return intc; | ||
525 | |||
526 | err: | ||
527 | kfree(intc); | ||
528 | return ERR_PTR(ret); | ||
529 | } | ||
530 | |||
531 | /* s3c24xx_init_irq | ||
532 | * | ||
533 | * Initialise S3C2410 IRQ system | ||
534 | */ | ||
535 | |||
536 | static struct s3c_irq_data init_base[32] = { | ||
537 | { .type = S3C_IRQTYPE_EINT, }, /* EINT0 */ | ||
538 | { .type = S3C_IRQTYPE_EINT, }, /* EINT1 */ | ||
539 | { .type = S3C_IRQTYPE_EINT, }, /* EINT2 */ | ||
540 | { .type = S3C_IRQTYPE_EINT, }, /* EINT3 */ | ||
541 | { .type = S3C_IRQTYPE_LEVEL, }, /* EINT4to7 */ | ||
542 | { .type = S3C_IRQTYPE_LEVEL, }, /* EINT8to23 */ | ||
543 | { .type = S3C_IRQTYPE_NONE, }, /* reserved */ | ||
544 | { .type = S3C_IRQTYPE_EDGE, }, /* nBATT_FLT */ | ||
545 | { .type = S3C_IRQTYPE_EDGE, }, /* TICK */ | ||
546 | { .type = S3C_IRQTYPE_EDGE, }, /* WDT */ | ||
547 | { .type = S3C_IRQTYPE_EDGE, }, /* TIMER0 */ | ||
548 | { .type = S3C_IRQTYPE_EDGE, }, /* TIMER1 */ | ||
549 | { .type = S3C_IRQTYPE_EDGE, }, /* TIMER2 */ | ||
550 | { .type = S3C_IRQTYPE_EDGE, }, /* TIMER3 */ | ||
551 | { .type = S3C_IRQTYPE_EDGE, }, /* TIMER4 */ | ||
552 | { .type = S3C_IRQTYPE_LEVEL, }, /* UART2 */ | ||
553 | { .type = S3C_IRQTYPE_EDGE, }, /* LCD */ | ||
554 | { .type = S3C_IRQTYPE_EDGE, }, /* DMA0 */ | ||
555 | { .type = S3C_IRQTYPE_EDGE, }, /* DMA1 */ | ||
556 | { .type = S3C_IRQTYPE_EDGE, }, /* DMA2 */ | ||
557 | { .type = S3C_IRQTYPE_EDGE, }, /* DMA3 */ | ||
558 | { .type = S3C_IRQTYPE_EDGE, }, /* SDI */ | ||
559 | { .type = S3C_IRQTYPE_EDGE, }, /* SPI0 */ | ||
560 | { .type = S3C_IRQTYPE_LEVEL, }, /* UART1 */ | ||
561 | { .type = S3C_IRQTYPE_NONE, }, /* reserved */ | ||
562 | { .type = S3C_IRQTYPE_EDGE, }, /* USBD */ | ||
563 | { .type = S3C_IRQTYPE_EDGE, }, /* USBH */ | ||
564 | { .type = S3C_IRQTYPE_EDGE, }, /* IIC */ | ||
565 | { .type = S3C_IRQTYPE_LEVEL, }, /* UART0 */ | ||
566 | { .type = S3C_IRQTYPE_EDGE, }, /* SPI1 */ | ||
567 | { .type = S3C_IRQTYPE_EDGE, }, /* RTC */ | ||
568 | { .type = S3C_IRQTYPE_LEVEL, }, /* ADCPARENT */ | ||
569 | }; | ||
570 | |||
571 | static struct s3c_irq_data init_eint[32] = { | ||
572 | { .type = S3C_IRQTYPE_NONE, }, /* reserved */ | ||
573 | { .type = S3C_IRQTYPE_NONE, }, /* reserved */ | ||
574 | { .type = S3C_IRQTYPE_NONE, }, /* reserved */ | ||
575 | { .type = S3C_IRQTYPE_NONE, }, /* reserved */ | ||
576 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 4 }, /* EINT4 */ | ||
577 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 4 }, /* EINT5 */ | ||
578 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 4 }, /* EINT6 */ | ||
579 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 4 }, /* EINT7 */ | ||
580 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT8 */ | ||
581 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT9 */ | ||
582 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT10 */ | ||
583 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT11 */ | ||
584 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT12 */ | ||
585 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT13 */ | ||
586 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT14 */ | ||
587 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT15 */ | ||
588 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT16 */ | ||
589 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT17 */ | ||
590 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT18 */ | ||
591 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT19 */ | ||
592 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT20 */ | ||
593 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT21 */ | ||
594 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT22 */ | ||
595 | { .type = S3C_IRQTYPE_EINT, .parent_irq = 5 }, /* EINT23 */ | ||
596 | }; | ||
597 | |||
598 | static struct s3c_irq_data init_subint[32] = { | ||
599 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 28 }, /* UART0-RX */ | ||
600 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 28 }, /* UART0-TX */ | ||
601 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 28 }, /* UART0-ERR */ | ||
602 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 23 }, /* UART1-RX */ | ||
603 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 23 }, /* UART1-TX */ | ||
604 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 23 }, /* UART1-ERR */ | ||
605 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 15 }, /* UART2-RX */ | ||
606 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 15 }, /* UART2-TX */ | ||
607 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 15 }, /* UART2-ERR */ | ||
608 | { .type = S3C_IRQTYPE_EDGE, .parent_irq = 31 }, /* TC */ | ||
609 | { .type = S3C_IRQTYPE_EDGE, .parent_irq = 31 }, /* ADC */ | ||
610 | }; | ||
611 | |||
612 | void __init s3c24xx_init_irq(void) | ||
613 | { | ||
614 | struct s3c_irq_intc *main_intc; | ||
615 | |||
616 | #ifdef CONFIG_FIQ | ||
617 | init_FIQ(FIQ_START); | ||
618 | #endif | ||
619 | |||
620 | main_intc = s3c24xx_init_intc(NULL, &init_base[0], NULL, 0x4a000000); | ||
621 | if (IS_ERR(main_intc)) { | ||
622 | pr_err("irq: could not create main interrupt controller\n"); | ||
623 | return; | ||
624 | } | ||
625 | |||
626 | s3c24xx_init_intc(NULL, &init_subint[0], main_intc, 0x4a000018); | ||
627 | s3c24xx_init_intc(NULL, &init_eint[0], main_intc, 0x560000a4); | ||
628 | } | ||
629 | |||
630 | #ifdef CONFIG_CPU_S3C2416 | ||
631 | static struct s3c_irq_data init_s3c2416base[32] = { | ||
632 | { .type = S3C_IRQTYPE_EINT, }, /* EINT0 */ | ||
633 | { .type = S3C_IRQTYPE_EINT, }, /* EINT1 */ | ||
634 | { .type = S3C_IRQTYPE_EINT, }, /* EINT2 */ | ||
635 | { .type = S3C_IRQTYPE_EINT, }, /* EINT3 */ | ||
636 | { .type = S3C_IRQTYPE_LEVEL, }, /* EINT4to7 */ | ||
637 | { .type = S3C_IRQTYPE_LEVEL, }, /* EINT8to23 */ | ||
638 | { .type = S3C_IRQTYPE_NONE, }, /* reserved */ | ||
639 | { .type = S3C_IRQTYPE_EDGE, }, /* nBATT_FLT */ | ||
640 | { .type = S3C_IRQTYPE_EDGE, }, /* TICK */ | ||
641 | { .type = S3C_IRQTYPE_LEVEL, }, /* WDT/AC97 */ | ||
642 | { .type = S3C_IRQTYPE_EDGE, }, /* TIMER0 */ | ||
643 | { .type = S3C_IRQTYPE_EDGE, }, /* TIMER1 */ | ||
644 | { .type = S3C_IRQTYPE_EDGE, }, /* TIMER2 */ | ||
645 | { .type = S3C_IRQTYPE_EDGE, }, /* TIMER3 */ | ||
646 | { .type = S3C_IRQTYPE_EDGE, }, /* TIMER4 */ | ||
647 | { .type = S3C_IRQTYPE_LEVEL, }, /* UART2 */ | ||
648 | { .type = S3C_IRQTYPE_LEVEL, }, /* LCD */ | ||
649 | { .type = S3C_IRQTYPE_LEVEL, }, /* DMA */ | ||
650 | { .type = S3C_IRQTYPE_LEVEL, }, /* UART3 */ | ||
651 | { .type = S3C_IRQTYPE_NONE, }, /* reserved */ | ||
652 | { .type = S3C_IRQTYPE_EDGE, }, /* SDI1 */ | ||
653 | { .type = S3C_IRQTYPE_EDGE, }, /* SDI0 */ | ||
654 | { .type = S3C_IRQTYPE_EDGE, }, /* SPI0 */ | ||
655 | { .type = S3C_IRQTYPE_LEVEL, }, /* UART1 */ | ||
656 | { .type = S3C_IRQTYPE_EDGE, }, /* NAND */ | ||
657 | { .type = S3C_IRQTYPE_EDGE, }, /* USBD */ | ||
658 | { .type = S3C_IRQTYPE_EDGE, }, /* USBH */ | ||
659 | { .type = S3C_IRQTYPE_EDGE, }, /* IIC */ | ||
660 | { .type = S3C_IRQTYPE_LEVEL, }, /* UART0 */ | ||
661 | { .type = S3C_IRQTYPE_NONE, }, | ||
662 | { .type = S3C_IRQTYPE_EDGE, }, /* RTC */ | ||
663 | { .type = S3C_IRQTYPE_LEVEL, }, /* ADCPARENT */ | ||
664 | }; | ||
665 | |||
666 | static struct s3c_irq_data init_s3c2416subint[32] = { | ||
667 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 28 }, /* UART0-RX */ | ||
668 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 28 }, /* UART0-TX */ | ||
669 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 28 }, /* UART0-ERR */ | ||
670 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 23 }, /* UART1-RX */ | ||
671 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 23 }, /* UART1-TX */ | ||
672 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 23 }, /* UART1-ERR */ | ||
673 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 15 }, /* UART2-RX */ | ||
674 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 15 }, /* UART2-TX */ | ||
675 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 15 }, /* UART2-ERR */ | ||
676 | { .type = S3C_IRQTYPE_EDGE, .parent_irq = 31 }, /* TC */ | ||
677 | { .type = S3C_IRQTYPE_EDGE, .parent_irq = 31 }, /* ADC */ | ||
678 | { .type = S3C_IRQTYPE_NONE }, /* reserved */ | ||
679 | { .type = S3C_IRQTYPE_NONE }, /* reserved */ | ||
680 | { .type = S3C_IRQTYPE_NONE }, /* reserved */ | ||
681 | { .type = S3C_IRQTYPE_NONE }, /* reserved */ | ||
682 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 16 }, /* LCD2 */ | ||
683 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 16 }, /* LCD3 */ | ||
684 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 16 }, /* LCD4 */ | ||
685 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 17 }, /* DMA0 */ | ||
686 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 17 }, /* DMA1 */ | ||
687 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 17 }, /* DMA2 */ | ||
688 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 17 }, /* DMA3 */ | ||
689 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 17 }, /* DMA4 */ | ||
690 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 17 }, /* DMA5 */ | ||
691 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 18 }, /* UART3-RX */ | ||
692 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 18 }, /* UART3-TX */ | ||
693 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 18 }, /* UART3-ERR */ | ||
694 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 9 }, /* WDT */ | ||
695 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 9 }, /* AC97 */ | ||
696 | }; | ||
697 | |||
698 | static struct s3c_irq_data init_s3c2416_second[32] = { | ||
699 | { .type = S3C_IRQTYPE_EDGE }, /* 2D */ | ||
700 | { .type = S3C_IRQTYPE_EDGE }, /* IIC1 */ | ||
701 | { .type = S3C_IRQTYPE_NONE }, /* reserved */ | ||
702 | { .type = S3C_IRQTYPE_NONE }, /* reserved */ | ||
703 | { .type = S3C_IRQTYPE_EDGE }, /* PCM0 */ | ||
704 | { .type = S3C_IRQTYPE_EDGE }, /* PCM1 */ | ||
705 | { .type = S3C_IRQTYPE_EDGE }, /* I2S0 */ | ||
706 | { .type = S3C_IRQTYPE_EDGE }, /* I2S1 */ | ||
707 | }; | ||
708 | |||
709 | void __init s3c2416_init_irq(void) | ||
710 | { | ||
711 | struct s3c_irq_intc *main_intc; | ||
712 | |||
713 | pr_info("S3C2416: IRQ Support\n"); | ||
714 | |||
715 | #ifdef CONFIG_FIQ | ||
716 | init_FIQ(FIQ_START); | ||
717 | #endif | ||
718 | |||
719 | main_intc = s3c24xx_init_intc(NULL, &init_s3c2416base[0], NULL, 0x4a000000); | ||
720 | if (IS_ERR(main_intc)) { | ||
721 | pr_err("irq: could not create main interrupt controller\n"); | ||
722 | return; | ||
723 | } | ||
724 | |||
725 | s3c24xx_init_intc(NULL, &init_eint[0], main_intc, 0x560000a4); | ||
726 | s3c24xx_init_intc(NULL, &init_s3c2416subint[0], main_intc, 0x4a000018); | ||
727 | |||
728 | s3c24xx_init_intc(NULL, &init_s3c2416_second[0], NULL, 0x4a000040); | ||
729 | } | ||
730 | |||
731 | #endif | ||
732 | |||
733 | #ifdef CONFIG_CPU_S3C2443 | ||
734 | static struct s3c_irq_data init_s3c2443base[32] = { | ||
735 | { .type = S3C_IRQTYPE_EINT, }, /* EINT0 */ | ||
736 | { .type = S3C_IRQTYPE_EINT, }, /* EINT1 */ | ||
737 | { .type = S3C_IRQTYPE_EINT, }, /* EINT2 */ | ||
738 | { .type = S3C_IRQTYPE_EINT, }, /* EINT3 */ | ||
739 | { .type = S3C_IRQTYPE_LEVEL, }, /* EINT4to7 */ | ||
740 | { .type = S3C_IRQTYPE_LEVEL, }, /* EINT8to23 */ | ||
741 | { .type = S3C_IRQTYPE_LEVEL, }, /* CAM */ | ||
742 | { .type = S3C_IRQTYPE_EDGE, }, /* nBATT_FLT */ | ||
743 | { .type = S3C_IRQTYPE_EDGE, }, /* TICK */ | ||
744 | { .type = S3C_IRQTYPE_LEVEL, }, /* WDT/AC97 */ | ||
745 | { .type = S3C_IRQTYPE_EDGE, }, /* TIMER0 */ | ||
746 | { .type = S3C_IRQTYPE_EDGE, }, /* TIMER1 */ | ||
747 | { .type = S3C_IRQTYPE_EDGE, }, /* TIMER2 */ | ||
748 | { .type = S3C_IRQTYPE_EDGE, }, /* TIMER3 */ | ||
749 | { .type = S3C_IRQTYPE_EDGE, }, /* TIMER4 */ | ||
750 | { .type = S3C_IRQTYPE_LEVEL, }, /* UART2 */ | ||
751 | { .type = S3C_IRQTYPE_LEVEL, }, /* LCD */ | ||
752 | { .type = S3C_IRQTYPE_LEVEL, }, /* DMA */ | ||
753 | { .type = S3C_IRQTYPE_LEVEL, }, /* UART3 */ | ||
754 | { .type = S3C_IRQTYPE_EDGE, }, /* CFON */ | ||
755 | { .type = S3C_IRQTYPE_EDGE, }, /* SDI1 */ | ||
756 | { .type = S3C_IRQTYPE_EDGE, }, /* SDI0 */ | ||
757 | { .type = S3C_IRQTYPE_EDGE, }, /* SPI0 */ | ||
758 | { .type = S3C_IRQTYPE_LEVEL, }, /* UART1 */ | ||
759 | { .type = S3C_IRQTYPE_EDGE, }, /* NAND */ | ||
760 | { .type = S3C_IRQTYPE_EDGE, }, /* USBD */ | ||
761 | { .type = S3C_IRQTYPE_EDGE, }, /* USBH */ | ||
762 | { .type = S3C_IRQTYPE_EDGE, }, /* IIC */ | ||
763 | { .type = S3C_IRQTYPE_LEVEL, }, /* UART0 */ | ||
764 | { .type = S3C_IRQTYPE_EDGE, }, /* SPI1 */ | ||
765 | { .type = S3C_IRQTYPE_EDGE, }, /* RTC */ | ||
766 | { .type = S3C_IRQTYPE_LEVEL, }, /* ADCPARENT */ | ||
767 | }; | ||
768 | |||
769 | |||
770 | static struct s3c_irq_data init_s3c2443subint[32] = { | ||
771 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 28 }, /* UART0-RX */ | ||
772 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 28 }, /* UART0-TX */ | ||
773 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 28 }, /* UART0-ERR */ | ||
774 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 23 }, /* UART1-RX */ | ||
775 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 23 }, /* UART1-TX */ | ||
776 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 23 }, /* UART1-ERR */ | ||
777 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 15 }, /* UART2-RX */ | ||
778 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 15 }, /* UART2-TX */ | ||
779 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 15 }, /* UART2-ERR */ | ||
780 | { .type = S3C_IRQTYPE_EDGE, .parent_irq = 31 }, /* TC */ | ||
781 | { .type = S3C_IRQTYPE_EDGE, .parent_irq = 31 }, /* ADC */ | ||
782 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 6 }, /* CAM_C */ | ||
783 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 6 }, /* CAM_P */ | ||
784 | { .type = S3C_IRQTYPE_NONE }, /* reserved */ | ||
785 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 16 }, /* LCD1 */ | ||
786 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 16 }, /* LCD2 */ | ||
787 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 16 }, /* LCD3 */ | ||
788 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 16 }, /* LCD4 */ | ||
789 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 17 }, /* DMA0 */ | ||
790 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 17 }, /* DMA1 */ | ||
791 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 17 }, /* DMA2 */ | ||
792 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 17 }, /* DMA3 */ | ||
793 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 17 }, /* DMA4 */ | ||
794 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 17 }, /* DMA5 */ | ||
795 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 18 }, /* UART3-RX */ | ||
796 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 18 }, /* UART3-TX */ | ||
797 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 18 }, /* UART3-ERR */ | ||
798 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 9 }, /* WDT */ | ||
799 | { .type = S3C_IRQTYPE_LEVEL, .parent_irq = 9 }, /* AC97 */ | ||
800 | }; | ||
801 | |||
802 | void __init s3c2443_init_irq(void) | ||
803 | { | ||
804 | struct s3c_irq_intc *main_intc; | ||
805 | |||
806 | pr_info("S3C2443: IRQ Support\n"); | ||
807 | |||
808 | #ifdef CONFIG_FIQ | ||
809 | init_FIQ(FIQ_START); | ||
810 | #endif | ||
811 | |||
812 | main_intc = s3c24xx_init_intc(NULL, &init_s3c2443base[0], NULL, 0x4a000000); | ||
813 | if (IS_ERR(main_intc)) { | ||
814 | pr_err("irq: could not create main interrupt controller\n"); | ||
815 | return; | ||
816 | } | ||
817 | |||
818 | s3c24xx_init_intc(NULL, &init_eint[0], main_intc, 0x560000a4); | ||
819 | s3c24xx_init_intc(NULL, &init_s3c2443subint[0], main_intc, 0x4a000018); | ||
820 | } | ||
821 | #endif | ||
diff --git a/arch/arm/mach-s3c24xx/mach-amlm5900.c b/arch/arm/mach-s3c24xx/mach-amlm5900.c index 0e0279e79150..e27b5c91b3db 100644 --- a/arch/arm/mach-s3c24xx/mach-amlm5900.c +++ b/arch/arm/mach-s3c24xx/mach-amlm5900.c | |||
@@ -63,6 +63,8 @@ | |||
63 | #include <linux/mtd/map.h> | 63 | #include <linux/mtd/map.h> |
64 | #include <linux/mtd/physmap.h> | 64 | #include <linux/mtd/physmap.h> |
65 | 65 | ||
66 | #include <plat/samsung-time.h> | ||
67 | |||
66 | #include "common.h" | 68 | #include "common.h" |
67 | 69 | ||
68 | static struct resource amlm5900_nor_resource = | 70 | static struct resource amlm5900_nor_resource = |
@@ -160,6 +162,7 @@ static void __init amlm5900_map_io(void) | |||
160 | s3c24xx_init_io(amlm5900_iodesc, ARRAY_SIZE(amlm5900_iodesc)); | 162 | s3c24xx_init_io(amlm5900_iodesc, ARRAY_SIZE(amlm5900_iodesc)); |
161 | s3c24xx_init_clocks(0); | 163 | s3c24xx_init_clocks(0); |
162 | s3c24xx_init_uarts(amlm5900_uartcfgs, ARRAY_SIZE(amlm5900_uartcfgs)); | 164 | s3c24xx_init_uarts(amlm5900_uartcfgs, ARRAY_SIZE(amlm5900_uartcfgs)); |
165 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
163 | } | 166 | } |
164 | 167 | ||
165 | #ifdef CONFIG_FB_S3C2410 | 168 | #ifdef CONFIG_FB_S3C2410 |
@@ -235,8 +238,8 @@ static void __init amlm5900_init(void) | |||
235 | MACHINE_START(AML_M5900, "AML_M5900") | 238 | MACHINE_START(AML_M5900, "AML_M5900") |
236 | .atag_offset = 0x100, | 239 | .atag_offset = 0x100, |
237 | .map_io = amlm5900_map_io, | 240 | .map_io = amlm5900_map_io, |
238 | .init_irq = s3c24xx_init_irq, | 241 | .init_irq = s3c2410_init_irq, |
239 | .init_machine = amlm5900_init, | 242 | .init_machine = amlm5900_init, |
240 | .init_time = s3c24xx_timer_init, | 243 | .init_time = samsung_timer_init, |
241 | .restart = s3c2410_restart, | 244 | .restart = s3c2410_restart, |
242 | MACHINE_END | 245 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-anubis.c b/arch/arm/mach-s3c24xx/mach-anubis.c index bb595f15ce36..c1fb6c37867f 100644 --- a/arch/arm/mach-s3c24xx/mach-anubis.c +++ b/arch/arm/mach-s3c24xx/mach-anubis.c | |||
@@ -49,6 +49,7 @@ | |||
49 | #include <plat/devs.h> | 49 | #include <plat/devs.h> |
50 | #include <plat/cpu.h> | 50 | #include <plat/cpu.h> |
51 | #include <linux/platform_data/asoc-s3c24xx_simtec.h> | 51 | #include <linux/platform_data/asoc-s3c24xx_simtec.h> |
52 | #include <plat/samsung-time.h> | ||
52 | 53 | ||
53 | #include "anubis.h" | 54 | #include "anubis.h" |
54 | #include "common.h" | 55 | #include "common.h" |
@@ -410,6 +411,7 @@ static void __init anubis_map_io(void) | |||
410 | s3c24xx_init_io(anubis_iodesc, ARRAY_SIZE(anubis_iodesc)); | 411 | s3c24xx_init_io(anubis_iodesc, ARRAY_SIZE(anubis_iodesc)); |
411 | s3c24xx_init_clocks(0); | 412 | s3c24xx_init_clocks(0); |
412 | s3c24xx_init_uarts(anubis_uartcfgs, ARRAY_SIZE(anubis_uartcfgs)); | 413 | s3c24xx_init_uarts(anubis_uartcfgs, ARRAY_SIZE(anubis_uartcfgs)); |
414 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
413 | 415 | ||
414 | /* check for the newer revision boards with large page nand */ | 416 | /* check for the newer revision boards with large page nand */ |
415 | 417 | ||
@@ -443,7 +445,7 @@ MACHINE_START(ANUBIS, "Simtec-Anubis") | |||
443 | .atag_offset = 0x100, | 445 | .atag_offset = 0x100, |
444 | .map_io = anubis_map_io, | 446 | .map_io = anubis_map_io, |
445 | .init_machine = anubis_init, | 447 | .init_machine = anubis_init, |
446 | .init_irq = s3c24xx_init_irq, | 448 | .init_irq = s3c2440_init_irq, |
447 | .init_time = s3c24xx_timer_init, | 449 | .init_time = samsung_timer_init, |
448 | .restart = s3c244x_restart, | 450 | .restart = s3c244x_restart, |
449 | MACHINE_END | 451 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-at2440evb.c b/arch/arm/mach-s3c24xx/mach-at2440evb.c index b4bc60c78ebb..6dfeeb7ef469 100644 --- a/arch/arm/mach-s3c24xx/mach-at2440evb.c +++ b/arch/arm/mach-s3c24xx/mach-at2440evb.c | |||
@@ -48,6 +48,7 @@ | |||
48 | #include <plat/devs.h> | 48 | #include <plat/devs.h> |
49 | #include <plat/cpu.h> | 49 | #include <plat/cpu.h> |
50 | #include <linux/platform_data/mmc-s3cmci.h> | 50 | #include <linux/platform_data/mmc-s3cmci.h> |
51 | #include <plat/samsung-time.h> | ||
51 | 52 | ||
52 | #include "common.h" | 53 | #include "common.h" |
53 | 54 | ||
@@ -192,6 +193,7 @@ static void __init at2440evb_map_io(void) | |||
192 | s3c24xx_init_io(at2440evb_iodesc, ARRAY_SIZE(at2440evb_iodesc)); | 193 | s3c24xx_init_io(at2440evb_iodesc, ARRAY_SIZE(at2440evb_iodesc)); |
193 | s3c24xx_init_clocks(16934400); | 194 | s3c24xx_init_clocks(16934400); |
194 | s3c24xx_init_uarts(at2440evb_uartcfgs, ARRAY_SIZE(at2440evb_uartcfgs)); | 195 | s3c24xx_init_uarts(at2440evb_uartcfgs, ARRAY_SIZE(at2440evb_uartcfgs)); |
196 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
195 | } | 197 | } |
196 | 198 | ||
197 | static void __init at2440evb_init(void) | 199 | static void __init at2440evb_init(void) |
@@ -209,7 +211,7 @@ MACHINE_START(AT2440EVB, "AT2440EVB") | |||
209 | .atag_offset = 0x100, | 211 | .atag_offset = 0x100, |
210 | .map_io = at2440evb_map_io, | 212 | .map_io = at2440evb_map_io, |
211 | .init_machine = at2440evb_init, | 213 | .init_machine = at2440evb_init, |
212 | .init_irq = s3c24xx_init_irq, | 214 | .init_irq = s3c2440_init_irq, |
213 | .init_time = s3c24xx_timer_init, | 215 | .init_time = samsung_timer_init, |
214 | .restart = s3c244x_restart, | 216 | .restart = s3c244x_restart, |
215 | MACHINE_END | 217 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-bast.c b/arch/arm/mach-s3c24xx/mach-bast.c index ca6618081041..22d6ae926d91 100644 --- a/arch/arm/mach-s3c24xx/mach-bast.c +++ b/arch/arm/mach-s3c24xx/mach-bast.c | |||
@@ -55,6 +55,7 @@ | |||
55 | #include <plat/devs.h> | 55 | #include <plat/devs.h> |
56 | #include <plat/gpio-cfg.h> | 56 | #include <plat/gpio-cfg.h> |
57 | #include <plat/regs-serial.h> | 57 | #include <plat/regs-serial.h> |
58 | #include <plat/samsung-time.h> | ||
58 | 59 | ||
59 | #include "bast.h" | 60 | #include "bast.h" |
60 | #include "common.h" | 61 | #include "common.h" |
@@ -576,6 +577,7 @@ static void __init bast_map_io(void) | |||
576 | s3c24xx_init_io(bast_iodesc, ARRAY_SIZE(bast_iodesc)); | 577 | s3c24xx_init_io(bast_iodesc, ARRAY_SIZE(bast_iodesc)); |
577 | s3c24xx_init_clocks(0); | 578 | s3c24xx_init_clocks(0); |
578 | s3c24xx_init_uarts(bast_uartcfgs, ARRAY_SIZE(bast_uartcfgs)); | 579 | s3c24xx_init_uarts(bast_uartcfgs, ARRAY_SIZE(bast_uartcfgs)); |
580 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
579 | } | 581 | } |
580 | 582 | ||
581 | static void __init bast_init(void) | 583 | static void __init bast_init(void) |
@@ -603,8 +605,8 @@ MACHINE_START(BAST, "Simtec-BAST") | |||
603 | /* Maintainer: Ben Dooks <ben@simtec.co.uk> */ | 605 | /* Maintainer: Ben Dooks <ben@simtec.co.uk> */ |
604 | .atag_offset = 0x100, | 606 | .atag_offset = 0x100, |
605 | .map_io = bast_map_io, | 607 | .map_io = bast_map_io, |
606 | .init_irq = s3c24xx_init_irq, | 608 | .init_irq = s3c2410_init_irq, |
607 | .init_machine = bast_init, | 609 | .init_machine = bast_init, |
608 | .init_time = s3c24xx_timer_init, | 610 | .init_time = samsung_timer_init, |
609 | .restart = s3c2410_restart, | 611 | .restart = s3c2410_restart, |
610 | MACHINE_END | 612 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-gta02.c b/arch/arm/mach-s3c24xx/mach-gta02.c index a25e8c5a7b4c..13d8d073675a 100644 --- a/arch/arm/mach-s3c24xx/mach-gta02.c +++ b/arch/arm/mach-s3c24xx/mach-gta02.c | |||
@@ -81,6 +81,7 @@ | |||
81 | #include <plat/gpio-cfg.h> | 81 | #include <plat/gpio-cfg.h> |
82 | #include <plat/pm.h> | 82 | #include <plat/pm.h> |
83 | #include <plat/regs-serial.h> | 83 | #include <plat/regs-serial.h> |
84 | #include <plat/samsung-time.h> | ||
84 | 85 | ||
85 | #include "common.h" | 86 | #include "common.h" |
86 | #include "gta02.h" | 87 | #include "gta02.h" |
@@ -501,6 +502,7 @@ static void __init gta02_map_io(void) | |||
501 | s3c24xx_init_io(gta02_iodesc, ARRAY_SIZE(gta02_iodesc)); | 502 | s3c24xx_init_io(gta02_iodesc, ARRAY_SIZE(gta02_iodesc)); |
502 | s3c24xx_init_clocks(12000000); | 503 | s3c24xx_init_clocks(12000000); |
503 | s3c24xx_init_uarts(gta02_uartcfgs, ARRAY_SIZE(gta02_uartcfgs)); | 504 | s3c24xx_init_uarts(gta02_uartcfgs, ARRAY_SIZE(gta02_uartcfgs)); |
505 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
504 | } | 506 | } |
505 | 507 | ||
506 | 508 | ||
@@ -587,8 +589,8 @@ MACHINE_START(NEO1973_GTA02, "GTA02") | |||
587 | /* Maintainer: Nelson Castillo <arhuaco@freaks-unidos.net> */ | 589 | /* Maintainer: Nelson Castillo <arhuaco@freaks-unidos.net> */ |
588 | .atag_offset = 0x100, | 590 | .atag_offset = 0x100, |
589 | .map_io = gta02_map_io, | 591 | .map_io = gta02_map_io, |
590 | .init_irq = s3c24xx_init_irq, | 592 | .init_irq = s3c2442_init_irq, |
591 | .init_machine = gta02_machine_init, | 593 | .init_machine = gta02_machine_init, |
592 | .init_time = s3c24xx_timer_init, | 594 | .init_time = samsung_timer_init, |
593 | .restart = s3c244x_restart, | 595 | .restart = s3c244x_restart, |
594 | MACHINE_END | 596 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-h1940.c b/arch/arm/mach-s3c24xx/mach-h1940.c index 79bc0830d740..af4334d6b4d5 100644 --- a/arch/arm/mach-s3c24xx/mach-h1940.c +++ b/arch/arm/mach-s3c24xx/mach-h1940.c | |||
@@ -62,7 +62,7 @@ | |||
62 | #include <plat/pll.h> | 62 | #include <plat/pll.h> |
63 | #include <plat/pm.h> | 63 | #include <plat/pm.h> |
64 | #include <plat/regs-serial.h> | 64 | #include <plat/regs-serial.h> |
65 | 65 | #include <plat/samsung-time.h> | |
66 | 66 | ||
67 | #include "common.h" | 67 | #include "common.h" |
68 | #include "h1940.h" | 68 | #include "h1940.h" |
@@ -646,6 +646,7 @@ static void __init h1940_map_io(void) | |||
646 | s3c24xx_init_io(h1940_iodesc, ARRAY_SIZE(h1940_iodesc)); | 646 | s3c24xx_init_io(h1940_iodesc, ARRAY_SIZE(h1940_iodesc)); |
647 | s3c24xx_init_clocks(0); | 647 | s3c24xx_init_clocks(0); |
648 | s3c24xx_init_uarts(h1940_uartcfgs, ARRAY_SIZE(h1940_uartcfgs)); | 648 | s3c24xx_init_uarts(h1940_uartcfgs, ARRAY_SIZE(h1940_uartcfgs)); |
649 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
649 | 650 | ||
650 | /* setup PM */ | 651 | /* setup PM */ |
651 | 652 | ||
@@ -666,11 +667,6 @@ static void __init h1940_reserve(void) | |||
666 | memblock_reserve(0x30081000, 0x1000); | 667 | memblock_reserve(0x30081000, 0x1000); |
667 | } | 668 | } |
668 | 669 | ||
669 | static void __init h1940_init_irq(void) | ||
670 | { | ||
671 | s3c24xx_init_irq(); | ||
672 | } | ||
673 | |||
674 | static void __init h1940_init(void) | 670 | static void __init h1940_init(void) |
675 | { | 671 | { |
676 | u32 tmp; | 672 | u32 tmp; |
@@ -739,8 +735,8 @@ MACHINE_START(H1940, "IPAQ-H1940") | |||
739 | .atag_offset = 0x100, | 735 | .atag_offset = 0x100, |
740 | .map_io = h1940_map_io, | 736 | .map_io = h1940_map_io, |
741 | .reserve = h1940_reserve, | 737 | .reserve = h1940_reserve, |
742 | .init_irq = h1940_init_irq, | 738 | .init_irq = s3c2410_init_irq, |
743 | .init_machine = h1940_init, | 739 | .init_machine = h1940_init, |
744 | .init_time = s3c24xx_timer_init, | 740 | .init_time = samsung_timer_init, |
745 | .restart = s3c2410_restart, | 741 | .restart = s3c2410_restart, |
746 | MACHINE_END | 742 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-jive.c b/arch/arm/mach-s3c24xx/mach-jive.c index ca08d7df07f7..a45fcd8ccf79 100644 --- a/arch/arm/mach-s3c24xx/mach-jive.c +++ b/arch/arm/mach-s3c24xx/mach-jive.c | |||
@@ -52,6 +52,7 @@ | |||
52 | #include <plat/cpu.h> | 52 | #include <plat/cpu.h> |
53 | #include <plat/pm.h> | 53 | #include <plat/pm.h> |
54 | #include <linux/platform_data/usb-s3c2410_udc.h> | 54 | #include <linux/platform_data/usb-s3c2410_udc.h> |
55 | #include <plat/samsung-time.h> | ||
55 | 56 | ||
56 | #include "common.h" | 57 | #include "common.h" |
57 | #include "s3c2412-power.h" | 58 | #include "s3c2412-power.h" |
@@ -506,6 +507,7 @@ static void __init jive_map_io(void) | |||
506 | s3c24xx_init_io(jive_iodesc, ARRAY_SIZE(jive_iodesc)); | 507 | s3c24xx_init_io(jive_iodesc, ARRAY_SIZE(jive_iodesc)); |
507 | s3c24xx_init_clocks(12000000); | 508 | s3c24xx_init_clocks(12000000); |
508 | s3c24xx_init_uarts(jive_uartcfgs, ARRAY_SIZE(jive_uartcfgs)); | 509 | s3c24xx_init_uarts(jive_uartcfgs, ARRAY_SIZE(jive_uartcfgs)); |
510 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
509 | } | 511 | } |
510 | 512 | ||
511 | static void jive_power_off(void) | 513 | static void jive_power_off(void) |
@@ -658,9 +660,9 @@ MACHINE_START(JIVE, "JIVE") | |||
658 | /* Maintainer: Ben Dooks <ben-linux@fluff.org> */ | 660 | /* Maintainer: Ben Dooks <ben-linux@fluff.org> */ |
659 | .atag_offset = 0x100, | 661 | .atag_offset = 0x100, |
660 | 662 | ||
661 | .init_irq = s3c24xx_init_irq, | 663 | .init_irq = s3c2412_init_irq, |
662 | .map_io = jive_map_io, | 664 | .map_io = jive_map_io, |
663 | .init_machine = jive_machine_init, | 665 | .init_machine = jive_machine_init, |
664 | .init_time = s3c24xx_timer_init, | 666 | .init_time = samsung_timer_init, |
665 | .restart = s3c2412_restart, | 667 | .restart = s3c2412_restart, |
666 | MACHINE_END | 668 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-mini2440.c b/arch/arm/mach-s3c24xx/mach-mini2440.c index 2865e5919f2c..a83db46320bc 100644 --- a/arch/arm/mach-s3c24xx/mach-mini2440.c +++ b/arch/arm/mach-s3c24xx/mach-mini2440.c | |||
@@ -56,6 +56,7 @@ | |||
56 | #include <plat/clock.h> | 56 | #include <plat/clock.h> |
57 | #include <plat/devs.h> | 57 | #include <plat/devs.h> |
58 | #include <plat/cpu.h> | 58 | #include <plat/cpu.h> |
59 | #include <plat/samsung-time.h> | ||
59 | 60 | ||
60 | #include <sound/s3c24xx_uda134x.h> | 61 | #include <sound/s3c24xx_uda134x.h> |
61 | 62 | ||
@@ -525,6 +526,7 @@ static void __init mini2440_map_io(void) | |||
525 | s3c24xx_init_io(mini2440_iodesc, ARRAY_SIZE(mini2440_iodesc)); | 526 | s3c24xx_init_io(mini2440_iodesc, ARRAY_SIZE(mini2440_iodesc)); |
526 | s3c24xx_init_clocks(12000000); | 527 | s3c24xx_init_clocks(12000000); |
527 | s3c24xx_init_uarts(mini2440_uartcfgs, ARRAY_SIZE(mini2440_uartcfgs)); | 528 | s3c24xx_init_uarts(mini2440_uartcfgs, ARRAY_SIZE(mini2440_uartcfgs)); |
529 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
528 | } | 530 | } |
529 | 531 | ||
530 | /* | 532 | /* |
@@ -686,7 +688,7 @@ MACHINE_START(MINI2440, "MINI2440") | |||
686 | .atag_offset = 0x100, | 688 | .atag_offset = 0x100, |
687 | .map_io = mini2440_map_io, | 689 | .map_io = mini2440_map_io, |
688 | .init_machine = mini2440_init, | 690 | .init_machine = mini2440_init, |
689 | .init_irq = s3c24xx_init_irq, | 691 | .init_irq = s3c2440_init_irq, |
690 | .init_time = s3c24xx_timer_init, | 692 | .init_time = samsung_timer_init, |
691 | .restart = s3c244x_restart, | 693 | .restart = s3c244x_restart, |
692 | MACHINE_END | 694 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-n30.c b/arch/arm/mach-s3c24xx/mach-n30.c index 8017c0fc1729..2cb46c37c920 100644 --- a/arch/arm/mach-s3c24xx/mach-n30.c +++ b/arch/arm/mach-s3c24xx/mach-n30.c | |||
@@ -49,6 +49,7 @@ | |||
49 | #include <plat/devs.h> | 49 | #include <plat/devs.h> |
50 | #include <linux/platform_data/mmc-s3cmci.h> | 50 | #include <linux/platform_data/mmc-s3cmci.h> |
51 | #include <linux/platform_data/usb-s3c2410_udc.h> | 51 | #include <linux/platform_data/usb-s3c2410_udc.h> |
52 | #include <plat/samsung-time.h> | ||
52 | 53 | ||
53 | #include "common.h" | 54 | #include "common.h" |
54 | 55 | ||
@@ -535,6 +536,7 @@ static void __init n30_map_io(void) | |||
535 | n30_hwinit(); | 536 | n30_hwinit(); |
536 | s3c24xx_init_clocks(0); | 537 | s3c24xx_init_clocks(0); |
537 | s3c24xx_init_uarts(n30_uartcfgs, ARRAY_SIZE(n30_uartcfgs)); | 538 | s3c24xx_init_uarts(n30_uartcfgs, ARRAY_SIZE(n30_uartcfgs)); |
539 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
538 | } | 540 | } |
539 | 541 | ||
540 | /* GPB3 is the line that controls the pull-up for the USB D+ line */ | 542 | /* GPB3 is the line that controls the pull-up for the USB D+ line */ |
@@ -588,9 +590,9 @@ MACHINE_START(N30, "Acer-N30") | |||
588 | Ben Dooks <ben-linux@fluff.org> | 590 | Ben Dooks <ben-linux@fluff.org> |
589 | */ | 591 | */ |
590 | .atag_offset = 0x100, | 592 | .atag_offset = 0x100, |
591 | .init_time = s3c24xx_timer_init, | 593 | .init_time = samsung_timer_init, |
592 | .init_machine = n30_init, | 594 | .init_machine = n30_init, |
593 | .init_irq = s3c24xx_init_irq, | 595 | .init_irq = s3c2410_init_irq, |
594 | .map_io = n30_map_io, | 596 | .map_io = n30_map_io, |
595 | .restart = s3c2410_restart, | 597 | .restart = s3c2410_restart, |
596 | MACHINE_END | 598 | MACHINE_END |
@@ -599,9 +601,9 @@ MACHINE_START(N35, "Acer-N35") | |||
599 | /* Maintainer: Christer Weinigel <christer@weinigel.se> | 601 | /* Maintainer: Christer Weinigel <christer@weinigel.se> |
600 | */ | 602 | */ |
601 | .atag_offset = 0x100, | 603 | .atag_offset = 0x100, |
602 | .init_time = s3c24xx_timer_init, | 604 | .init_time = samsung_timer_init, |
603 | .init_machine = n30_init, | 605 | .init_machine = n30_init, |
604 | .init_irq = s3c24xx_init_irq, | 606 | .init_irq = s3c2410_init_irq, |
605 | .map_io = n30_map_io, | 607 | .map_io = n30_map_io, |
606 | .restart = s3c2410_restart, | 608 | .restart = s3c2410_restart, |
607 | MACHINE_END | 609 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-nexcoder.c b/arch/arm/mach-s3c24xx/mach-nexcoder.c index 144b9f80c4a5..01f4354206f9 100644 --- a/arch/arm/mach-s3c24xx/mach-nexcoder.c +++ b/arch/arm/mach-s3c24xx/mach-nexcoder.c | |||
@@ -44,6 +44,7 @@ | |||
44 | #include <plat/clock.h> | 44 | #include <plat/clock.h> |
45 | #include <plat/devs.h> | 45 | #include <plat/devs.h> |
46 | #include <plat/cpu.h> | 46 | #include <plat/cpu.h> |
47 | #include <plat/samsung-time.h> | ||
47 | 48 | ||
48 | #include "common.h" | 49 | #include "common.h" |
49 | 50 | ||
@@ -135,6 +136,7 @@ static void __init nexcoder_map_io(void) | |||
135 | s3c24xx_init_io(nexcoder_iodesc, ARRAY_SIZE(nexcoder_iodesc)); | 136 | s3c24xx_init_io(nexcoder_iodesc, ARRAY_SIZE(nexcoder_iodesc)); |
136 | s3c24xx_init_clocks(0); | 137 | s3c24xx_init_clocks(0); |
137 | s3c24xx_init_uarts(nexcoder_uartcfgs, ARRAY_SIZE(nexcoder_uartcfgs)); | 138 | s3c24xx_init_uarts(nexcoder_uartcfgs, ARRAY_SIZE(nexcoder_uartcfgs)); |
139 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
138 | 140 | ||
139 | nexcoder_sensorboard_init(); | 141 | nexcoder_sensorboard_init(); |
140 | } | 142 | } |
@@ -150,7 +152,7 @@ MACHINE_START(NEXCODER_2440, "NexVision - Nexcoder 2440") | |||
150 | .atag_offset = 0x100, | 152 | .atag_offset = 0x100, |
151 | .map_io = nexcoder_map_io, | 153 | .map_io = nexcoder_map_io, |
152 | .init_machine = nexcoder_init, | 154 | .init_machine = nexcoder_init, |
153 | .init_irq = s3c24xx_init_irq, | 155 | .init_irq = s3c2440_init_irq, |
154 | .init_time = s3c24xx_timer_init, | 156 | .init_time = samsung_timer_init, |
155 | .restart = s3c244x_restart, | 157 | .restart = s3c244x_restart, |
156 | MACHINE_END | 158 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-osiris.c b/arch/arm/mach-s3c24xx/mach-osiris.c index ae2cbdf3e3ca..58d6fbe5bf1f 100644 --- a/arch/arm/mach-s3c24xx/mach-osiris.c +++ b/arch/arm/mach-s3c24xx/mach-osiris.c | |||
@@ -45,6 +45,7 @@ | |||
45 | #include <plat/devs.h> | 45 | #include <plat/devs.h> |
46 | #include <plat/gpio-cfg.h> | 46 | #include <plat/gpio-cfg.h> |
47 | #include <plat/regs-serial.h> | 47 | #include <plat/regs-serial.h> |
48 | #include <plat/samsung-time.h> | ||
48 | 49 | ||
49 | #include <mach/hardware.h> | 50 | #include <mach/hardware.h> |
50 | #include <mach/regs-gpio.h> | 51 | #include <mach/regs-gpio.h> |
@@ -384,6 +385,7 @@ static void __init osiris_map_io(void) | |||
384 | s3c24xx_init_io(osiris_iodesc, ARRAY_SIZE(osiris_iodesc)); | 385 | s3c24xx_init_io(osiris_iodesc, ARRAY_SIZE(osiris_iodesc)); |
385 | s3c24xx_init_clocks(0); | 386 | s3c24xx_init_clocks(0); |
386 | s3c24xx_init_uarts(osiris_uartcfgs, ARRAY_SIZE(osiris_uartcfgs)); | 387 | s3c24xx_init_uarts(osiris_uartcfgs, ARRAY_SIZE(osiris_uartcfgs)); |
388 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
387 | 389 | ||
388 | /* check for the newer revision boards with large page nand */ | 390 | /* check for the newer revision boards with large page nand */ |
389 | 391 | ||
@@ -424,8 +426,8 @@ MACHINE_START(OSIRIS, "Simtec-OSIRIS") | |||
424 | /* Maintainer: Ben Dooks <ben@simtec.co.uk> */ | 426 | /* Maintainer: Ben Dooks <ben@simtec.co.uk> */ |
425 | .atag_offset = 0x100, | 427 | .atag_offset = 0x100, |
426 | .map_io = osiris_map_io, | 428 | .map_io = osiris_map_io, |
427 | .init_irq = s3c24xx_init_irq, | 429 | .init_irq = s3c2440_init_irq, |
428 | .init_machine = osiris_init, | 430 | .init_machine = osiris_init, |
429 | .init_time = s3c24xx_timer_init, | 431 | .init_time = samsung_timer_init, |
430 | .restart = s3c244x_restart, | 432 | .restart = s3c244x_restart, |
431 | MACHINE_END | 433 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-otom.c b/arch/arm/mach-s3c24xx/mach-otom.c index deb0ace585b0..7e16b0740ec1 100644 --- a/arch/arm/mach-s3c24xx/mach-otom.c +++ b/arch/arm/mach-s3c24xx/mach-otom.c | |||
@@ -33,6 +33,7 @@ | |||
33 | #include <plat/cpu.h> | 33 | #include <plat/cpu.h> |
34 | #include <plat/devs.h> | 34 | #include <plat/devs.h> |
35 | #include <plat/regs-serial.h> | 35 | #include <plat/regs-serial.h> |
36 | #include <plat/samsung-time.h> | ||
36 | 37 | ||
37 | #include "common.h" | 38 | #include "common.h" |
38 | #include "otom.h" | 39 | #include "otom.h" |
@@ -101,6 +102,7 @@ static void __init otom11_map_io(void) | |||
101 | s3c24xx_init_io(otom11_iodesc, ARRAY_SIZE(otom11_iodesc)); | 102 | s3c24xx_init_io(otom11_iodesc, ARRAY_SIZE(otom11_iodesc)); |
102 | s3c24xx_init_clocks(0); | 103 | s3c24xx_init_clocks(0); |
103 | s3c24xx_init_uarts(otom11_uartcfgs, ARRAY_SIZE(otom11_uartcfgs)); | 104 | s3c24xx_init_uarts(otom11_uartcfgs, ARRAY_SIZE(otom11_uartcfgs)); |
105 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
104 | } | 106 | } |
105 | 107 | ||
106 | static void __init otom11_init(void) | 108 | static void __init otom11_init(void) |
@@ -114,7 +116,7 @@ MACHINE_START(OTOM, "Nex Vision - Otom 1.1") | |||
114 | .atag_offset = 0x100, | 116 | .atag_offset = 0x100, |
115 | .map_io = otom11_map_io, | 117 | .map_io = otom11_map_io, |
116 | .init_machine = otom11_init, | 118 | .init_machine = otom11_init, |
117 | .init_irq = s3c24xx_init_irq, | 119 | .init_irq = s3c2410_init_irq, |
118 | .init_time = s3c24xx_timer_init, | 120 | .init_time = samsung_timer_init, |
119 | .restart = s3c2410_restart, | 121 | .restart = s3c2410_restart, |
120 | MACHINE_END | 122 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-qt2410.c b/arch/arm/mach-s3c24xx/mach-qt2410.c index 84c541602661..f8feaeadb55a 100644 --- a/arch/arm/mach-s3c24xx/mach-qt2410.c +++ b/arch/arm/mach-s3c24xx/mach-qt2410.c | |||
@@ -59,6 +59,7 @@ | |||
59 | #include <plat/devs.h> | 59 | #include <plat/devs.h> |
60 | #include <plat/cpu.h> | 60 | #include <plat/cpu.h> |
61 | #include <plat/pm.h> | 61 | #include <plat/pm.h> |
62 | #include <plat/samsung-time.h> | ||
62 | 63 | ||
63 | #include "common.h" | 64 | #include "common.h" |
64 | #include "common-smdk.h" | 65 | #include "common-smdk.h" |
@@ -304,6 +305,7 @@ static void __init qt2410_map_io(void) | |||
304 | s3c24xx_init_io(qt2410_iodesc, ARRAY_SIZE(qt2410_iodesc)); | 305 | s3c24xx_init_io(qt2410_iodesc, ARRAY_SIZE(qt2410_iodesc)); |
305 | s3c24xx_init_clocks(12*1000*1000); | 306 | s3c24xx_init_clocks(12*1000*1000); |
306 | s3c24xx_init_uarts(smdk2410_uartcfgs, ARRAY_SIZE(smdk2410_uartcfgs)); | 307 | s3c24xx_init_uarts(smdk2410_uartcfgs, ARRAY_SIZE(smdk2410_uartcfgs)); |
308 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
307 | } | 309 | } |
308 | 310 | ||
309 | static void __init qt2410_machine_init(void) | 311 | static void __init qt2410_machine_init(void) |
@@ -341,8 +343,8 @@ static void __init qt2410_machine_init(void) | |||
341 | MACHINE_START(QT2410, "QT2410") | 343 | MACHINE_START(QT2410, "QT2410") |
342 | .atag_offset = 0x100, | 344 | .atag_offset = 0x100, |
343 | .map_io = qt2410_map_io, | 345 | .map_io = qt2410_map_io, |
344 | .init_irq = s3c24xx_init_irq, | 346 | .init_irq = s3c2410_init_irq, |
345 | .init_machine = qt2410_machine_init, | 347 | .init_machine = qt2410_machine_init, |
346 | .init_time = s3c24xx_timer_init, | 348 | .init_time = samsung_timer_init, |
347 | .restart = s3c2410_restart, | 349 | .restart = s3c2410_restart, |
348 | MACHINE_END | 350 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-rx1950.c b/arch/arm/mach-s3c24xx/mach-rx1950.c index 43f3ac5a1c7a..44ca018e1f96 100644 --- a/arch/arm/mach-s3c24xx/mach-rx1950.c +++ b/arch/arm/mach-s3c24xx/mach-rx1950.c | |||
@@ -57,6 +57,7 @@ | |||
57 | #include <plat/devs.h> | 57 | #include <plat/devs.h> |
58 | #include <plat/pm.h> | 58 | #include <plat/pm.h> |
59 | #include <plat/regs-serial.h> | 59 | #include <plat/regs-serial.h> |
60 | #include <plat/samsung-time.h> | ||
60 | 61 | ||
61 | #include "common.h" | 62 | #include "common.h" |
62 | #include "h1940.h" | 63 | #include "h1940.h" |
@@ -740,6 +741,7 @@ static void __init rx1950_map_io(void) | |||
740 | s3c24xx_init_io(rx1950_iodesc, ARRAY_SIZE(rx1950_iodesc)); | 741 | s3c24xx_init_io(rx1950_iodesc, ARRAY_SIZE(rx1950_iodesc)); |
741 | s3c24xx_init_clocks(16934000); | 742 | s3c24xx_init_clocks(16934000); |
742 | s3c24xx_init_uarts(rx1950_uartcfgs, ARRAY_SIZE(rx1950_uartcfgs)); | 743 | s3c24xx_init_uarts(rx1950_uartcfgs, ARRAY_SIZE(rx1950_uartcfgs)); |
744 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
743 | 745 | ||
744 | /* setup PM */ | 746 | /* setup PM */ |
745 | 747 | ||
@@ -810,8 +812,8 @@ MACHINE_START(RX1950, "HP iPAQ RX1950") | |||
810 | .atag_offset = 0x100, | 812 | .atag_offset = 0x100, |
811 | .map_io = rx1950_map_io, | 813 | .map_io = rx1950_map_io, |
812 | .reserve = rx1950_reserve, | 814 | .reserve = rx1950_reserve, |
813 | .init_irq = s3c24xx_init_irq, | 815 | .init_irq = s3c2442_init_irq, |
814 | .init_machine = rx1950_init_machine, | 816 | .init_machine = rx1950_init_machine, |
815 | .init_time = s3c24xx_timer_init, | 817 | .init_time = samsung_timer_init, |
816 | .restart = s3c244x_restart, | 818 | .restart = s3c244x_restart, |
817 | MACHINE_END | 819 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-rx3715.c b/arch/arm/mach-s3c24xx/mach-rx3715.c index f20418a2fb1b..3bc6231d0a1f 100644 --- a/arch/arm/mach-s3c24xx/mach-rx3715.c +++ b/arch/arm/mach-s3c24xx/mach-rx3715.c | |||
@@ -49,6 +49,7 @@ | |||
49 | #include <plat/devs.h> | 49 | #include <plat/devs.h> |
50 | #include <plat/pm.h> | 50 | #include <plat/pm.h> |
51 | #include <plat/regs-serial.h> | 51 | #include <plat/regs-serial.h> |
52 | #include <plat/samsung-time.h> | ||
52 | 53 | ||
53 | #include "common.h" | 54 | #include "common.h" |
54 | #include "h1940.h" | 55 | #include "h1940.h" |
@@ -179,6 +180,7 @@ static void __init rx3715_map_io(void) | |||
179 | s3c24xx_init_io(rx3715_iodesc, ARRAY_SIZE(rx3715_iodesc)); | 180 | s3c24xx_init_io(rx3715_iodesc, ARRAY_SIZE(rx3715_iodesc)); |
180 | s3c24xx_init_clocks(16934000); | 181 | s3c24xx_init_clocks(16934000); |
181 | s3c24xx_init_uarts(rx3715_uartcfgs, ARRAY_SIZE(rx3715_uartcfgs)); | 182 | s3c24xx_init_uarts(rx3715_uartcfgs, ARRAY_SIZE(rx3715_uartcfgs)); |
183 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
182 | } | 184 | } |
183 | 185 | ||
184 | /* H1940 and RX3715 need to reserve this for suspend */ | 186 | /* H1940 and RX3715 need to reserve this for suspend */ |
@@ -188,11 +190,6 @@ static void __init rx3715_reserve(void) | |||
188 | memblock_reserve(0x30081000, 0x1000); | 190 | memblock_reserve(0x30081000, 0x1000); |
189 | } | 191 | } |
190 | 192 | ||
191 | static void __init rx3715_init_irq(void) | ||
192 | { | ||
193 | s3c24xx_init_irq(); | ||
194 | } | ||
195 | |||
196 | static void __init rx3715_init_machine(void) | 193 | static void __init rx3715_init_machine(void) |
197 | { | 194 | { |
198 | #ifdef CONFIG_PM_H1940 | 195 | #ifdef CONFIG_PM_H1940 |
@@ -210,8 +207,8 @@ MACHINE_START(RX3715, "IPAQ-RX3715") | |||
210 | .atag_offset = 0x100, | 207 | .atag_offset = 0x100, |
211 | .map_io = rx3715_map_io, | 208 | .map_io = rx3715_map_io, |
212 | .reserve = rx3715_reserve, | 209 | .reserve = rx3715_reserve, |
213 | .init_irq = rx3715_init_irq, | 210 | .init_irq = s3c2440_init_irq, |
214 | .init_machine = rx3715_init_machine, | 211 | .init_machine = rx3715_init_machine, |
215 | .init_time = s3c24xx_timer_init, | 212 | .init_time = samsung_timer_init, |
216 | .restart = s3c244x_restart, | 213 | .restart = s3c244x_restart, |
217 | MACHINE_END | 214 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-smdk2410.c b/arch/arm/mach-s3c24xx/mach-smdk2410.c index cd0b1635c47e..a773789e4f38 100644 --- a/arch/arm/mach-s3c24xx/mach-smdk2410.c +++ b/arch/arm/mach-s3c24xx/mach-smdk2410.c | |||
@@ -51,6 +51,7 @@ | |||
51 | 51 | ||
52 | #include <plat/devs.h> | 52 | #include <plat/devs.h> |
53 | #include <plat/cpu.h> | 53 | #include <plat/cpu.h> |
54 | #include <plat/samsung-time.h> | ||
54 | 55 | ||
55 | #include "common.h" | 56 | #include "common.h" |
56 | #include "common-smdk.h" | 57 | #include "common-smdk.h" |
@@ -100,6 +101,7 @@ static void __init smdk2410_map_io(void) | |||
100 | s3c24xx_init_io(smdk2410_iodesc, ARRAY_SIZE(smdk2410_iodesc)); | 101 | s3c24xx_init_io(smdk2410_iodesc, ARRAY_SIZE(smdk2410_iodesc)); |
101 | s3c24xx_init_clocks(0); | 102 | s3c24xx_init_clocks(0); |
102 | s3c24xx_init_uarts(smdk2410_uartcfgs, ARRAY_SIZE(smdk2410_uartcfgs)); | 103 | s3c24xx_init_uarts(smdk2410_uartcfgs, ARRAY_SIZE(smdk2410_uartcfgs)); |
104 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
103 | } | 105 | } |
104 | 106 | ||
105 | static void __init smdk2410_init(void) | 107 | static void __init smdk2410_init(void) |
@@ -114,8 +116,8 @@ MACHINE_START(SMDK2410, "SMDK2410") /* @TODO: request a new identifier and switc | |||
114 | /* Maintainer: Jonas Dietsche */ | 116 | /* Maintainer: Jonas Dietsche */ |
115 | .atag_offset = 0x100, | 117 | .atag_offset = 0x100, |
116 | .map_io = smdk2410_map_io, | 118 | .map_io = smdk2410_map_io, |
117 | .init_irq = s3c24xx_init_irq, | 119 | .init_irq = s3c2410_init_irq, |
118 | .init_machine = smdk2410_init, | 120 | .init_machine = smdk2410_init, |
119 | .init_time = s3c24xx_timer_init, | 121 | .init_time = samsung_timer_init, |
120 | .restart = s3c2410_restart, | 122 | .restart = s3c2410_restart, |
121 | MACHINE_END | 123 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-smdk2413.c b/arch/arm/mach-s3c24xx/mach-smdk2413.c index 79485907950f..8146e920f10d 100644 --- a/arch/arm/mach-s3c24xx/mach-smdk2413.c +++ b/arch/arm/mach-s3c24xx/mach-smdk2413.c | |||
@@ -44,6 +44,7 @@ | |||
44 | #include <plat/clock.h> | 44 | #include <plat/clock.h> |
45 | #include <plat/devs.h> | 45 | #include <plat/devs.h> |
46 | #include <plat/cpu.h> | 46 | #include <plat/cpu.h> |
47 | #include <plat/samsung-time.h> | ||
47 | 48 | ||
48 | #include "common.h" | 49 | #include "common.h" |
49 | #include "common-smdk.h" | 50 | #include "common-smdk.h" |
@@ -105,6 +106,7 @@ static void __init smdk2413_map_io(void) | |||
105 | s3c24xx_init_io(smdk2413_iodesc, ARRAY_SIZE(smdk2413_iodesc)); | 106 | s3c24xx_init_io(smdk2413_iodesc, ARRAY_SIZE(smdk2413_iodesc)); |
106 | s3c24xx_init_clocks(12000000); | 107 | s3c24xx_init_clocks(12000000); |
107 | s3c24xx_init_uarts(smdk2413_uartcfgs, ARRAY_SIZE(smdk2413_uartcfgs)); | 108 | s3c24xx_init_uarts(smdk2413_uartcfgs, ARRAY_SIZE(smdk2413_uartcfgs)); |
109 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
108 | } | 110 | } |
109 | 111 | ||
110 | static void __init smdk2413_machine_init(void) | 112 | static void __init smdk2413_machine_init(void) |
@@ -128,10 +130,10 @@ MACHINE_START(S3C2413, "S3C2413") | |||
128 | .atag_offset = 0x100, | 130 | .atag_offset = 0x100, |
129 | 131 | ||
130 | .fixup = smdk2413_fixup, | 132 | .fixup = smdk2413_fixup, |
131 | .init_irq = s3c24xx_init_irq, | 133 | .init_irq = s3c2412_init_irq, |
132 | .map_io = smdk2413_map_io, | 134 | .map_io = smdk2413_map_io, |
133 | .init_machine = smdk2413_machine_init, | 135 | .init_machine = smdk2413_machine_init, |
134 | .init_time = s3c24xx_timer_init, | 136 | .init_time = samsung_timer_init, |
135 | .restart = s3c2412_restart, | 137 | .restart = s3c2412_restart, |
136 | MACHINE_END | 138 | MACHINE_END |
137 | 139 | ||
@@ -140,10 +142,10 @@ MACHINE_START(SMDK2412, "SMDK2412") | |||
140 | .atag_offset = 0x100, | 142 | .atag_offset = 0x100, |
141 | 143 | ||
142 | .fixup = smdk2413_fixup, | 144 | .fixup = smdk2413_fixup, |
143 | .init_irq = s3c24xx_init_irq, | 145 | .init_irq = s3c2412_init_irq, |
144 | .map_io = smdk2413_map_io, | 146 | .map_io = smdk2413_map_io, |
145 | .init_machine = smdk2413_machine_init, | 147 | .init_machine = smdk2413_machine_init, |
146 | .init_time = s3c24xx_timer_init, | 148 | .init_time = samsung_timer_init, |
147 | .restart = s3c2412_restart, | 149 | .restart = s3c2412_restart, |
148 | MACHINE_END | 150 | MACHINE_END |
149 | 151 | ||
@@ -152,9 +154,9 @@ MACHINE_START(SMDK2413, "SMDK2413") | |||
152 | .atag_offset = 0x100, | 154 | .atag_offset = 0x100, |
153 | 155 | ||
154 | .fixup = smdk2413_fixup, | 156 | .fixup = smdk2413_fixup, |
155 | .init_irq = s3c24xx_init_irq, | 157 | .init_irq = s3c2412_init_irq, |
156 | .map_io = smdk2413_map_io, | 158 | .map_io = smdk2413_map_io, |
157 | .init_machine = smdk2413_machine_init, | 159 | .init_machine = smdk2413_machine_init, |
158 | .init_time = s3c24xx_timer_init, | 160 | .init_time = samsung_timer_init, |
159 | .restart = s3c2412_restart, | 161 | .restart = s3c2412_restart, |
160 | MACHINE_END | 162 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-smdk2416.c b/arch/arm/mach-s3c24xx/mach-smdk2416.c index 037a5da343bd..cb46847c66b4 100644 --- a/arch/arm/mach-s3c24xx/mach-smdk2416.c +++ b/arch/arm/mach-s3c24xx/mach-smdk2416.c | |||
@@ -50,6 +50,7 @@ | |||
50 | #include <plat/sdhci.h> | 50 | #include <plat/sdhci.h> |
51 | #include <linux/platform_data/usb-s3c2410_udc.h> | 51 | #include <linux/platform_data/usb-s3c2410_udc.h> |
52 | #include <linux/platform_data/s3c-hsudc.h> | 52 | #include <linux/platform_data/s3c-hsudc.h> |
53 | #include <plat/samsung-time.h> | ||
53 | 54 | ||
54 | #include <plat/fb.h> | 55 | #include <plat/fb.h> |
55 | 56 | ||
@@ -221,6 +222,7 @@ static void __init smdk2416_map_io(void) | |||
221 | s3c24xx_init_io(smdk2416_iodesc, ARRAY_SIZE(smdk2416_iodesc)); | 222 | s3c24xx_init_io(smdk2416_iodesc, ARRAY_SIZE(smdk2416_iodesc)); |
222 | s3c24xx_init_clocks(12000000); | 223 | s3c24xx_init_clocks(12000000); |
223 | s3c24xx_init_uarts(smdk2416_uartcfgs, ARRAY_SIZE(smdk2416_uartcfgs)); | 224 | s3c24xx_init_uarts(smdk2416_uartcfgs, ARRAY_SIZE(smdk2416_uartcfgs)); |
225 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
224 | } | 226 | } |
225 | 227 | ||
226 | static void __init smdk2416_machine_init(void) | 228 | static void __init smdk2416_machine_init(void) |
@@ -253,6 +255,6 @@ MACHINE_START(SMDK2416, "SMDK2416") | |||
253 | .init_irq = s3c2416_init_irq, | 255 | .init_irq = s3c2416_init_irq, |
254 | .map_io = smdk2416_map_io, | 256 | .map_io = smdk2416_map_io, |
255 | .init_machine = smdk2416_machine_init, | 257 | .init_machine = smdk2416_machine_init, |
256 | .init_time = s3c24xx_timer_init, | 258 | .init_time = samsung_timer_init, |
257 | .restart = s3c2416_restart, | 259 | .restart = s3c2416_restart, |
258 | MACHINE_END | 260 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-smdk2440.c b/arch/arm/mach-s3c24xx/mach-smdk2440.c index 29d31314e23c..de2e5d39a847 100644 --- a/arch/arm/mach-s3c24xx/mach-smdk2440.c +++ b/arch/arm/mach-s3c24xx/mach-smdk2440.c | |||
@@ -41,6 +41,7 @@ | |||
41 | #include <plat/clock.h> | 41 | #include <plat/clock.h> |
42 | #include <plat/devs.h> | 42 | #include <plat/devs.h> |
43 | #include <plat/cpu.h> | 43 | #include <plat/cpu.h> |
44 | #include <plat/samsung-time.h> | ||
44 | 45 | ||
45 | #include "common.h" | 46 | #include "common.h" |
46 | #include "common-smdk.h" | 47 | #include "common-smdk.h" |
@@ -160,6 +161,7 @@ static void __init smdk2440_map_io(void) | |||
160 | s3c24xx_init_io(smdk2440_iodesc, ARRAY_SIZE(smdk2440_iodesc)); | 161 | s3c24xx_init_io(smdk2440_iodesc, ARRAY_SIZE(smdk2440_iodesc)); |
161 | s3c24xx_init_clocks(16934400); | 162 | s3c24xx_init_clocks(16934400); |
162 | s3c24xx_init_uarts(smdk2440_uartcfgs, ARRAY_SIZE(smdk2440_uartcfgs)); | 163 | s3c24xx_init_uarts(smdk2440_uartcfgs, ARRAY_SIZE(smdk2440_uartcfgs)); |
164 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
163 | } | 165 | } |
164 | 166 | ||
165 | static void __init smdk2440_machine_init(void) | 167 | static void __init smdk2440_machine_init(void) |
@@ -175,9 +177,9 @@ MACHINE_START(S3C2440, "SMDK2440") | |||
175 | /* Maintainer: Ben Dooks <ben-linux@fluff.org> */ | 177 | /* Maintainer: Ben Dooks <ben-linux@fluff.org> */ |
176 | .atag_offset = 0x100, | 178 | .atag_offset = 0x100, |
177 | 179 | ||
178 | .init_irq = s3c24xx_init_irq, | 180 | .init_irq = s3c2440_init_irq, |
179 | .map_io = smdk2440_map_io, | 181 | .map_io = smdk2440_map_io, |
180 | .init_machine = smdk2440_machine_init, | 182 | .init_machine = smdk2440_machine_init, |
181 | .init_time = s3c24xx_timer_init, | 183 | .init_time = samsung_timer_init, |
182 | .restart = s3c244x_restart, | 184 | .restart = s3c244x_restart, |
183 | MACHINE_END | 185 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-smdk2443.c b/arch/arm/mach-s3c24xx/mach-smdk2443.c index b3be4c4dc7bc..9435c3bef18a 100644 --- a/arch/arm/mach-s3c24xx/mach-smdk2443.c +++ b/arch/arm/mach-s3c24xx/mach-smdk2443.c | |||
@@ -41,6 +41,7 @@ | |||
41 | #include <plat/clock.h> | 41 | #include <plat/clock.h> |
42 | #include <plat/devs.h> | 42 | #include <plat/devs.h> |
43 | #include <plat/cpu.h> | 43 | #include <plat/cpu.h> |
44 | #include <plat/samsung-time.h> | ||
44 | 45 | ||
45 | #include "common.h" | 46 | #include "common.h" |
46 | #include "common-smdk.h" | 47 | #include "common-smdk.h" |
@@ -121,6 +122,7 @@ static void __init smdk2443_map_io(void) | |||
121 | s3c24xx_init_io(smdk2443_iodesc, ARRAY_SIZE(smdk2443_iodesc)); | 122 | s3c24xx_init_io(smdk2443_iodesc, ARRAY_SIZE(smdk2443_iodesc)); |
122 | s3c24xx_init_clocks(12000000); | 123 | s3c24xx_init_clocks(12000000); |
123 | s3c24xx_init_uarts(smdk2443_uartcfgs, ARRAY_SIZE(smdk2443_uartcfgs)); | 124 | s3c24xx_init_uarts(smdk2443_uartcfgs, ARRAY_SIZE(smdk2443_uartcfgs)); |
125 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
124 | } | 126 | } |
125 | 127 | ||
126 | static void __init smdk2443_machine_init(void) | 128 | static void __init smdk2443_machine_init(void) |
@@ -142,6 +144,6 @@ MACHINE_START(SMDK2443, "SMDK2443") | |||
142 | .init_irq = s3c2443_init_irq, | 144 | .init_irq = s3c2443_init_irq, |
143 | .map_io = smdk2443_map_io, | 145 | .map_io = smdk2443_map_io, |
144 | .init_machine = smdk2443_machine_init, | 146 | .init_machine = smdk2443_machine_init, |
145 | .init_time = s3c24xx_timer_init, | 147 | .init_time = samsung_timer_init, |
146 | .restart = s3c2443_restart, | 148 | .restart = s3c2443_restart, |
147 | MACHINE_END | 149 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-tct_hammer.c b/arch/arm/mach-s3c24xx/mach-tct_hammer.c index 24b3d79e7b2c..7fad8f055cab 100644 --- a/arch/arm/mach-s3c24xx/mach-tct_hammer.c +++ b/arch/arm/mach-s3c24xx/mach-tct_hammer.c | |||
@@ -53,6 +53,7 @@ | |||
53 | #include <linux/mtd/partitions.h> | 53 | #include <linux/mtd/partitions.h> |
54 | #include <linux/mtd/map.h> | 54 | #include <linux/mtd/map.h> |
55 | #include <linux/mtd/physmap.h> | 55 | #include <linux/mtd/physmap.h> |
56 | #include <plat/samsung-time.h> | ||
56 | 57 | ||
57 | #include "common.h" | 58 | #include "common.h" |
58 | 59 | ||
@@ -136,6 +137,7 @@ static void __init tct_hammer_map_io(void) | |||
136 | s3c24xx_init_io(tct_hammer_iodesc, ARRAY_SIZE(tct_hammer_iodesc)); | 137 | s3c24xx_init_io(tct_hammer_iodesc, ARRAY_SIZE(tct_hammer_iodesc)); |
137 | s3c24xx_init_clocks(0); | 138 | s3c24xx_init_clocks(0); |
138 | s3c24xx_init_uarts(tct_hammer_uartcfgs, ARRAY_SIZE(tct_hammer_uartcfgs)); | 139 | s3c24xx_init_uarts(tct_hammer_uartcfgs, ARRAY_SIZE(tct_hammer_uartcfgs)); |
140 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
139 | } | 141 | } |
140 | 142 | ||
141 | static void __init tct_hammer_init(void) | 143 | static void __init tct_hammer_init(void) |
@@ -147,8 +149,8 @@ static void __init tct_hammer_init(void) | |||
147 | MACHINE_START(TCT_HAMMER, "TCT_HAMMER") | 149 | MACHINE_START(TCT_HAMMER, "TCT_HAMMER") |
148 | .atag_offset = 0x100, | 150 | .atag_offset = 0x100, |
149 | .map_io = tct_hammer_map_io, | 151 | .map_io = tct_hammer_map_io, |
150 | .init_irq = s3c24xx_init_irq, | 152 | .init_irq = s3c2410_init_irq, |
151 | .init_machine = tct_hammer_init, | 153 | .init_machine = tct_hammer_init, |
152 | .init_time = s3c24xx_timer_init, | 154 | .init_time = samsung_timer_init, |
153 | .restart = s3c2410_restart, | 155 | .restart = s3c2410_restart, |
154 | MACHINE_END | 156 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-vr1000.c b/arch/arm/mach-s3c24xx/mach-vr1000.c index ec42d1e4e465..42e7187fed60 100644 --- a/arch/arm/mach-s3c24xx/mach-vr1000.c +++ b/arch/arm/mach-s3c24xx/mach-vr1000.c | |||
@@ -45,6 +45,7 @@ | |||
45 | #include <plat/cpu.h> | 45 | #include <plat/cpu.h> |
46 | #include <plat/devs.h> | 46 | #include <plat/devs.h> |
47 | #include <plat/regs-serial.h> | 47 | #include <plat/regs-serial.h> |
48 | #include <plat/samsung-time.h> | ||
48 | 49 | ||
49 | #include "bast.h" | 50 | #include "bast.h" |
50 | #include "common.h" | 51 | #include "common.h" |
@@ -332,6 +333,7 @@ static void __init vr1000_map_io(void) | |||
332 | s3c24xx_init_io(vr1000_iodesc, ARRAY_SIZE(vr1000_iodesc)); | 333 | s3c24xx_init_io(vr1000_iodesc, ARRAY_SIZE(vr1000_iodesc)); |
333 | s3c24xx_init_clocks(0); | 334 | s3c24xx_init_clocks(0); |
334 | s3c24xx_init_uarts(vr1000_uartcfgs, ARRAY_SIZE(vr1000_uartcfgs)); | 335 | s3c24xx_init_uarts(vr1000_uartcfgs, ARRAY_SIZE(vr1000_uartcfgs)); |
336 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
335 | } | 337 | } |
336 | 338 | ||
337 | static void __init vr1000_init(void) | 339 | static void __init vr1000_init(void) |
@@ -353,7 +355,7 @@ MACHINE_START(VR1000, "Thorcom-VR1000") | |||
353 | .atag_offset = 0x100, | 355 | .atag_offset = 0x100, |
354 | .map_io = vr1000_map_io, | 356 | .map_io = vr1000_map_io, |
355 | .init_machine = vr1000_init, | 357 | .init_machine = vr1000_init, |
356 | .init_irq = s3c24xx_init_irq, | 358 | .init_irq = s3c2410_init_irq, |
357 | .init_time = s3c24xx_timer_init, | 359 | .init_time = samsung_timer_init, |
358 | .restart = s3c2410_restart, | 360 | .restart = s3c2410_restart, |
359 | MACHINE_END | 361 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/mach-vstms.c b/arch/arm/mach-s3c24xx/mach-vstms.c index 239129c2d8bc..b66588428ec9 100644 --- a/arch/arm/mach-s3c24xx/mach-vstms.c +++ b/arch/arm/mach-s3c24xx/mach-vstms.c | |||
@@ -44,6 +44,7 @@ | |||
44 | #include <plat/clock.h> | 44 | #include <plat/clock.h> |
45 | #include <plat/devs.h> | 45 | #include <plat/devs.h> |
46 | #include <plat/cpu.h> | 46 | #include <plat/cpu.h> |
47 | #include <plat/samsung-time.h> | ||
47 | 48 | ||
48 | #include "common.h" | 49 | #include "common.h" |
49 | 50 | ||
@@ -142,6 +143,7 @@ static void __init vstms_map_io(void) | |||
142 | s3c24xx_init_io(vstms_iodesc, ARRAY_SIZE(vstms_iodesc)); | 143 | s3c24xx_init_io(vstms_iodesc, ARRAY_SIZE(vstms_iodesc)); |
143 | s3c24xx_init_clocks(12000000); | 144 | s3c24xx_init_clocks(12000000); |
144 | s3c24xx_init_uarts(vstms_uartcfgs, ARRAY_SIZE(vstms_uartcfgs)); | 145 | s3c24xx_init_uarts(vstms_uartcfgs, ARRAY_SIZE(vstms_uartcfgs)); |
146 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
145 | } | 147 | } |
146 | 148 | ||
147 | static void __init vstms_init(void) | 149 | static void __init vstms_init(void) |
@@ -156,9 +158,9 @@ MACHINE_START(VSTMS, "VSTMS") | |||
156 | .atag_offset = 0x100, | 158 | .atag_offset = 0x100, |
157 | 159 | ||
158 | .fixup = vstms_fixup, | 160 | .fixup = vstms_fixup, |
159 | .init_irq = s3c24xx_init_irq, | 161 | .init_irq = s3c2412_init_irq, |
160 | .init_machine = vstms_init, | 162 | .init_machine = vstms_init, |
161 | .map_io = vstms_map_io, | 163 | .map_io = vstms_map_io, |
162 | .init_time = s3c24xx_timer_init, | 164 | .init_time = samsung_timer_init, |
163 | .restart = s3c2412_restart, | 165 | .restart = s3c2412_restart, |
164 | MACHINE_END | 166 | MACHINE_END |
diff --git a/arch/arm/mach-s3c24xx/pm-s3c2412.c b/arch/arm/mach-s3c24xx/pm-s3c2412.c index 4c4bc1c83b77..d75f95e487ee 100644 --- a/arch/arm/mach-s3c24xx/pm-s3c2412.c +++ b/arch/arm/mach-s3c24xx/pm-s3c2412.c | |||
@@ -29,6 +29,7 @@ | |||
29 | 29 | ||
30 | #include <plat/cpu.h> | 30 | #include <plat/cpu.h> |
31 | #include <plat/pm.h> | 31 | #include <plat/pm.h> |
32 | #include <plat/wakeup-mask.h> | ||
32 | 33 | ||
33 | #include "regs-dsc.h" | 34 | #include "regs-dsc.h" |
34 | #include "s3c2412-power.h" | 35 | #include "s3c2412-power.h" |
@@ -51,8 +52,15 @@ static int s3c2412_cpu_suspend(unsigned long arg) | |||
51 | return 1; /* Aborting suspend */ | 52 | return 1; /* Aborting suspend */ |
52 | } | 53 | } |
53 | 54 | ||
55 | /* mapping of interrupts to parts of the wakeup mask */ | ||
56 | static struct samsung_wakeup_mask wake_irqs[] = { | ||
57 | { .irq = IRQ_RTC, .bit = S3C2412_PWRCFG_RTC_MASKIRQ, }, | ||
58 | }; | ||
59 | |||
54 | static void s3c2412_pm_prepare(void) | 60 | static void s3c2412_pm_prepare(void) |
55 | { | 61 | { |
62 | samsung_sync_wakemask(S3C2412_PWRCFG, | ||
63 | wake_irqs, ARRAY_SIZE(wake_irqs)); | ||
56 | } | 64 | } |
57 | 65 | ||
58 | static int s3c2412_pm_add(struct device *dev, struct subsys_interface *sif) | 66 | static int s3c2412_pm_add(struct device *dev, struct subsys_interface *sif) |
diff --git a/arch/arm/mach-s3c64xx/Kconfig b/arch/arm/mach-s3c64xx/Kconfig index 131c86284711..283cb77d4721 100644 --- a/arch/arm/mach-s3c64xx/Kconfig +++ b/arch/arm/mach-s3c64xx/Kconfig | |||
@@ -17,11 +17,13 @@ config PLAT_S3C64XX | |||
17 | # Configuration options for the S3C6410 CPU | 17 | # Configuration options for the S3C6410 CPU |
18 | 18 | ||
19 | config CPU_S3C6400 | 19 | config CPU_S3C6400 |
20 | select SAMSUNG_HRT | ||
20 | bool | 21 | bool |
21 | help | 22 | help |
22 | Enable S3C6400 CPU support | 23 | Enable S3C6400 CPU support |
23 | 24 | ||
24 | config CPU_S3C6410 | 25 | config CPU_S3C6410 |
26 | select SAMSUNG_HRT | ||
25 | bool | 27 | bool |
26 | help | 28 | help |
27 | Enable S3C6410 CPU support | 29 | Enable S3C6410 CPU support |
diff --git a/arch/arm/mach-s3c64xx/mach-anw6410.c b/arch/arm/mach-s3c64xx/mach-anw6410.c index 728eef3296b2..35e3f54574ef 100644 --- a/arch/arm/mach-s3c64xx/mach-anw6410.c +++ b/arch/arm/mach-s3c64xx/mach-anw6410.c | |||
@@ -49,6 +49,7 @@ | |||
49 | #include <plat/devs.h> | 49 | #include <plat/devs.h> |
50 | #include <plat/cpu.h> | 50 | #include <plat/cpu.h> |
51 | #include <mach/regs-gpio.h> | 51 | #include <mach/regs-gpio.h> |
52 | #include <plat/samsung-time.h> | ||
52 | 53 | ||
53 | #include "common.h" | 54 | #include "common.h" |
54 | #include "regs-modem.h" | 55 | #include "regs-modem.h" |
@@ -208,6 +209,7 @@ static void __init anw6410_map_io(void) | |||
208 | s3c64xx_init_io(anw6410_iodesc, ARRAY_SIZE(anw6410_iodesc)); | 209 | s3c64xx_init_io(anw6410_iodesc, ARRAY_SIZE(anw6410_iodesc)); |
209 | s3c24xx_init_clocks(12000000); | 210 | s3c24xx_init_clocks(12000000); |
210 | s3c24xx_init_uarts(anw6410_uartcfgs, ARRAY_SIZE(anw6410_uartcfgs)); | 211 | s3c24xx_init_uarts(anw6410_uartcfgs, ARRAY_SIZE(anw6410_uartcfgs)); |
212 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
211 | 213 | ||
212 | anw6410_lcd_mode_set(); | 214 | anw6410_lcd_mode_set(); |
213 | } | 215 | } |
@@ -232,6 +234,6 @@ MACHINE_START(ANW6410, "A&W6410") | |||
232 | .map_io = anw6410_map_io, | 234 | .map_io = anw6410_map_io, |
233 | .init_machine = anw6410_machine_init, | 235 | .init_machine = anw6410_machine_init, |
234 | .init_late = s3c64xx_init_late, | 236 | .init_late = s3c64xx_init_late, |
235 | .init_time = s3c24xx_timer_init, | 237 | .init_time = samsung_timer_init, |
236 | .restart = s3c64xx_restart, | 238 | .restart = s3c64xx_restart, |
237 | MACHINE_END | 239 | MACHINE_END |
diff --git a/arch/arm/mach-s3c64xx/mach-crag6410.c b/arch/arm/mach-s3c64xx/mach-crag6410.c index 1acf02bace57..8ad88ace795a 100644 --- a/arch/arm/mach-s3c64xx/mach-crag6410.c +++ b/arch/arm/mach-s3c64xx/mach-crag6410.c | |||
@@ -64,6 +64,7 @@ | |||
64 | #include <plat/adc.h> | 64 | #include <plat/adc.h> |
65 | #include <linux/platform_data/i2c-s3c2410.h> | 65 | #include <linux/platform_data/i2c-s3c2410.h> |
66 | #include <plat/pm.h> | 66 | #include <plat/pm.h> |
67 | #include <plat/samsung-time.h> | ||
67 | 68 | ||
68 | #include "common.h" | 69 | #include "common.h" |
69 | #include "crag6410.h" | 70 | #include "crag6410.h" |
@@ -744,6 +745,7 @@ static void __init crag6410_map_io(void) | |||
744 | s3c64xx_init_io(NULL, 0); | 745 | s3c64xx_init_io(NULL, 0); |
745 | s3c24xx_init_clocks(12000000); | 746 | s3c24xx_init_clocks(12000000); |
746 | s3c24xx_init_uarts(crag6410_uartcfgs, ARRAY_SIZE(crag6410_uartcfgs)); | 747 | s3c24xx_init_uarts(crag6410_uartcfgs, ARRAY_SIZE(crag6410_uartcfgs)); |
748 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
747 | 749 | ||
748 | /* LCD type and Bypass set by bootloader */ | 750 | /* LCD type and Bypass set by bootloader */ |
749 | } | 751 | } |
@@ -868,6 +870,6 @@ MACHINE_START(WLF_CRAGG_6410, "Wolfson Cragganmore 6410") | |||
868 | .map_io = crag6410_map_io, | 870 | .map_io = crag6410_map_io, |
869 | .init_machine = crag6410_machine_init, | 871 | .init_machine = crag6410_machine_init, |
870 | .init_late = s3c64xx_init_late, | 872 | .init_late = s3c64xx_init_late, |
871 | .init_time = s3c24xx_timer_init, | 873 | .init_time = samsung_timer_init, |
872 | .restart = s3c64xx_restart, | 874 | .restart = s3c64xx_restart, |
873 | MACHINE_END | 875 | MACHINE_END |
diff --git a/arch/arm/mach-s3c64xx/mach-hmt.c b/arch/arm/mach-s3c64xx/mach-hmt.c index 7212eb9cfeb9..5b7f357d8c22 100644 --- a/arch/arm/mach-s3c64xx/mach-hmt.c +++ b/arch/arm/mach-s3c64xx/mach-hmt.c | |||
@@ -41,6 +41,7 @@ | |||
41 | #include <plat/clock.h> | 41 | #include <plat/clock.h> |
42 | #include <plat/devs.h> | 42 | #include <plat/devs.h> |
43 | #include <plat/cpu.h> | 43 | #include <plat/cpu.h> |
44 | #include <plat/samsung-time.h> | ||
44 | 45 | ||
45 | #include "common.h" | 46 | #include "common.h" |
46 | 47 | ||
@@ -248,6 +249,7 @@ static void __init hmt_map_io(void) | |||
248 | s3c64xx_init_io(hmt_iodesc, ARRAY_SIZE(hmt_iodesc)); | 249 | s3c64xx_init_io(hmt_iodesc, ARRAY_SIZE(hmt_iodesc)); |
249 | s3c24xx_init_clocks(12000000); | 250 | s3c24xx_init_clocks(12000000); |
250 | s3c24xx_init_uarts(hmt_uartcfgs, ARRAY_SIZE(hmt_uartcfgs)); | 251 | s3c24xx_init_uarts(hmt_uartcfgs, ARRAY_SIZE(hmt_uartcfgs)); |
252 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
251 | } | 253 | } |
252 | 254 | ||
253 | static void __init hmt_machine_init(void) | 255 | static void __init hmt_machine_init(void) |
@@ -275,6 +277,6 @@ MACHINE_START(HMT, "Airgoo-HMT") | |||
275 | .map_io = hmt_map_io, | 277 | .map_io = hmt_map_io, |
276 | .init_machine = hmt_machine_init, | 278 | .init_machine = hmt_machine_init, |
277 | .init_late = s3c64xx_init_late, | 279 | .init_late = s3c64xx_init_late, |
278 | .init_time = s3c24xx_timer_init, | 280 | .init_time = samsung_timer_init, |
279 | .restart = s3c64xx_restart, | 281 | .restart = s3c64xx_restart, |
280 | MACHINE_END | 282 | MACHINE_END |
diff --git a/arch/arm/mach-s3c64xx/mach-mini6410.c b/arch/arm/mach-s3c64xx/mach-mini6410.c index 4b41fcdaa7b6..fc043e3ecdf8 100644 --- a/arch/arm/mach-s3c64xx/mach-mini6410.c +++ b/arch/arm/mach-s3c64xx/mach-mini6410.c | |||
@@ -41,6 +41,7 @@ | |||
41 | 41 | ||
42 | #include <video/platform_lcd.h> | 42 | #include <video/platform_lcd.h> |
43 | #include <video/samsung_fimd.h> | 43 | #include <video/samsung_fimd.h> |
44 | #include <plat/samsung-time.h> | ||
44 | 45 | ||
45 | #include "common.h" | 46 | #include "common.h" |
46 | #include "regs-modem.h" | 47 | #include "regs-modem.h" |
@@ -232,6 +233,7 @@ static void __init mini6410_map_io(void) | |||
232 | s3c64xx_init_io(NULL, 0); | 233 | s3c64xx_init_io(NULL, 0); |
233 | s3c24xx_init_clocks(12000000); | 234 | s3c24xx_init_clocks(12000000); |
234 | s3c24xx_init_uarts(mini6410_uartcfgs, ARRAY_SIZE(mini6410_uartcfgs)); | 235 | s3c24xx_init_uarts(mini6410_uartcfgs, ARRAY_SIZE(mini6410_uartcfgs)); |
236 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
235 | 237 | ||
236 | /* set the LCD type */ | 238 | /* set the LCD type */ |
237 | tmp = __raw_readl(S3C64XX_SPCON); | 239 | tmp = __raw_readl(S3C64XX_SPCON); |
@@ -354,6 +356,6 @@ MACHINE_START(MINI6410, "MINI6410") | |||
354 | .map_io = mini6410_map_io, | 356 | .map_io = mini6410_map_io, |
355 | .init_machine = mini6410_machine_init, | 357 | .init_machine = mini6410_machine_init, |
356 | .init_late = s3c64xx_init_late, | 358 | .init_late = s3c64xx_init_late, |
357 | .init_time = s3c24xx_timer_init, | 359 | .init_time = samsung_timer_init, |
358 | .restart = s3c64xx_restart, | 360 | .restart = s3c64xx_restart, |
359 | MACHINE_END | 361 | MACHINE_END |
diff --git a/arch/arm/mach-s3c64xx/mach-ncp.c b/arch/arm/mach-s3c64xx/mach-ncp.c index 8d3cedd995ff..7e2c3908f1f8 100644 --- a/arch/arm/mach-s3c64xx/mach-ncp.c +++ b/arch/arm/mach-s3c64xx/mach-ncp.c | |||
@@ -43,6 +43,7 @@ | |||
43 | #include <plat/clock.h> | 43 | #include <plat/clock.h> |
44 | #include <plat/devs.h> | 44 | #include <plat/devs.h> |
45 | #include <plat/cpu.h> | 45 | #include <plat/cpu.h> |
46 | #include <plat/samsung-time.h> | ||
46 | 47 | ||
47 | #include "common.h" | 48 | #include "common.h" |
48 | 49 | ||
@@ -87,6 +88,7 @@ static void __init ncp_map_io(void) | |||
87 | s3c64xx_init_io(ncp_iodesc, ARRAY_SIZE(ncp_iodesc)); | 88 | s3c64xx_init_io(ncp_iodesc, ARRAY_SIZE(ncp_iodesc)); |
88 | s3c24xx_init_clocks(12000000); | 89 | s3c24xx_init_clocks(12000000); |
89 | s3c24xx_init_uarts(ncp_uartcfgs, ARRAY_SIZE(ncp_uartcfgs)); | 90 | s3c24xx_init_uarts(ncp_uartcfgs, ARRAY_SIZE(ncp_uartcfgs)); |
91 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
90 | } | 92 | } |
91 | 93 | ||
92 | static void __init ncp_machine_init(void) | 94 | static void __init ncp_machine_init(void) |
@@ -103,6 +105,6 @@ MACHINE_START(NCP, "NCP") | |||
103 | .map_io = ncp_map_io, | 105 | .map_io = ncp_map_io, |
104 | .init_machine = ncp_machine_init, | 106 | .init_machine = ncp_machine_init, |
105 | .init_late = s3c64xx_init_late, | 107 | .init_late = s3c64xx_init_late, |
106 | .init_time = s3c24xx_timer_init, | 108 | .init_time = samsung_timer_init, |
107 | .restart = s3c64xx_restart, | 109 | .restart = s3c64xx_restart, |
108 | MACHINE_END | 110 | MACHINE_END |
diff --git a/arch/arm/mach-s3c64xx/mach-real6410.c b/arch/arm/mach-s3c64xx/mach-real6410.c index fa12bd21ad82..8bed37b3d5ac 100644 --- a/arch/arm/mach-s3c64xx/mach-real6410.c +++ b/arch/arm/mach-s3c64xx/mach-real6410.c | |||
@@ -42,6 +42,7 @@ | |||
42 | 42 | ||
43 | #include <video/platform_lcd.h> | 43 | #include <video/platform_lcd.h> |
44 | #include <video/samsung_fimd.h> | 44 | #include <video/samsung_fimd.h> |
45 | #include <plat/samsung-time.h> | ||
45 | 46 | ||
46 | #include "common.h" | 47 | #include "common.h" |
47 | #include "regs-modem.h" | 48 | #include "regs-modem.h" |
@@ -211,6 +212,7 @@ static void __init real6410_map_io(void) | |||
211 | s3c64xx_init_io(NULL, 0); | 212 | s3c64xx_init_io(NULL, 0); |
212 | s3c24xx_init_clocks(12000000); | 213 | s3c24xx_init_clocks(12000000); |
213 | s3c24xx_init_uarts(real6410_uartcfgs, ARRAY_SIZE(real6410_uartcfgs)); | 214 | s3c24xx_init_uarts(real6410_uartcfgs, ARRAY_SIZE(real6410_uartcfgs)); |
215 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
214 | 216 | ||
215 | /* set the LCD type */ | 217 | /* set the LCD type */ |
216 | tmp = __raw_readl(S3C64XX_SPCON); | 218 | tmp = __raw_readl(S3C64XX_SPCON); |
@@ -333,6 +335,6 @@ MACHINE_START(REAL6410, "REAL6410") | |||
333 | .map_io = real6410_map_io, | 335 | .map_io = real6410_map_io, |
334 | .init_machine = real6410_machine_init, | 336 | .init_machine = real6410_machine_init, |
335 | .init_late = s3c64xx_init_late, | 337 | .init_late = s3c64xx_init_late, |
336 | .init_time = s3c24xx_timer_init, | 338 | .init_time = samsung_timer_init, |
337 | .restart = s3c64xx_restart, | 339 | .restart = s3c64xx_restart, |
338 | MACHINE_END | 340 | MACHINE_END |
diff --git a/arch/arm/mach-s3c64xx/mach-smartq.c b/arch/arm/mach-s3c64xx/mach-smartq.c index fc3e9b32e26f..58ac99041274 100644 --- a/arch/arm/mach-s3c64xx/mach-smartq.c +++ b/arch/arm/mach-s3c64xx/mach-smartq.c | |||
@@ -38,6 +38,7 @@ | |||
38 | #include <linux/platform_data/touchscreen-s3c2410.h> | 38 | #include <linux/platform_data/touchscreen-s3c2410.h> |
39 | 39 | ||
40 | #include <video/platform_lcd.h> | 40 | #include <video/platform_lcd.h> |
41 | #include <plat/samsung-time.h> | ||
41 | 42 | ||
42 | #include "common.h" | 43 | #include "common.h" |
43 | #include "regs-modem.h" | 44 | #include "regs-modem.h" |
@@ -378,6 +379,7 @@ void __init smartq_map_io(void) | |||
378 | s3c64xx_init_io(smartq_iodesc, ARRAY_SIZE(smartq_iodesc)); | 379 | s3c64xx_init_io(smartq_iodesc, ARRAY_SIZE(smartq_iodesc)); |
379 | s3c24xx_init_clocks(12000000); | 380 | s3c24xx_init_clocks(12000000); |
380 | s3c24xx_init_uarts(smartq_uartcfgs, ARRAY_SIZE(smartq_uartcfgs)); | 381 | s3c24xx_init_uarts(smartq_uartcfgs, ARRAY_SIZE(smartq_uartcfgs)); |
382 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
381 | 383 | ||
382 | smartq_lcd_mode_set(); | 384 | smartq_lcd_mode_set(); |
383 | } | 385 | } |
diff --git a/arch/arm/mach-s3c64xx/mach-smartq5.c b/arch/arm/mach-s3c64xx/mach-smartq5.c index ca2afcfce573..8aca5daf3d05 100644 --- a/arch/arm/mach-s3c64xx/mach-smartq5.c +++ b/arch/arm/mach-s3c64xx/mach-smartq5.c | |||
@@ -28,6 +28,7 @@ | |||
28 | #include <plat/devs.h> | 28 | #include <plat/devs.h> |
29 | #include <plat/fb.h> | 29 | #include <plat/fb.h> |
30 | #include <plat/gpio-cfg.h> | 30 | #include <plat/gpio-cfg.h> |
31 | #include <plat/samsung-time.h> | ||
31 | 32 | ||
32 | #include "common.h" | 33 | #include "common.h" |
33 | #include "mach-smartq.h" | 34 | #include "mach-smartq.h" |
@@ -155,6 +156,6 @@ MACHINE_START(SMARTQ5, "SmartQ 5") | |||
155 | .map_io = smartq_map_io, | 156 | .map_io = smartq_map_io, |
156 | .init_machine = smartq5_machine_init, | 157 | .init_machine = smartq5_machine_init, |
157 | .init_late = s3c64xx_init_late, | 158 | .init_late = s3c64xx_init_late, |
158 | .init_time = s3c24xx_timer_init, | 159 | .init_time = samsung_timer_init, |
159 | .restart = s3c64xx_restart, | 160 | .restart = s3c64xx_restart, |
160 | MACHINE_END | 161 | MACHINE_END |
diff --git a/arch/arm/mach-s3c64xx/mach-smartq7.c b/arch/arm/mach-s3c64xx/mach-smartq7.c index 37bb0c632a5e..a052e107c0b4 100644 --- a/arch/arm/mach-s3c64xx/mach-smartq7.c +++ b/arch/arm/mach-s3c64xx/mach-smartq7.c | |||
@@ -28,6 +28,7 @@ | |||
28 | #include <plat/devs.h> | 28 | #include <plat/devs.h> |
29 | #include <plat/fb.h> | 29 | #include <plat/fb.h> |
30 | #include <plat/gpio-cfg.h> | 30 | #include <plat/gpio-cfg.h> |
31 | #include <plat/samsung-time.h> | ||
31 | 32 | ||
32 | #include "common.h" | 33 | #include "common.h" |
33 | #include "mach-smartq.h" | 34 | #include "mach-smartq.h" |
@@ -171,6 +172,6 @@ MACHINE_START(SMARTQ7, "SmartQ 7") | |||
171 | .map_io = smartq_map_io, | 172 | .map_io = smartq_map_io, |
172 | .init_machine = smartq7_machine_init, | 173 | .init_machine = smartq7_machine_init, |
173 | .init_late = s3c64xx_init_late, | 174 | .init_late = s3c64xx_init_late, |
174 | .init_time = s3c24xx_timer_init, | 175 | .init_time = samsung_timer_init, |
175 | .restart = s3c64xx_restart, | 176 | .restart = s3c64xx_restart, |
176 | MACHINE_END | 177 | MACHINE_END |
diff --git a/arch/arm/mach-s3c64xx/mach-smdk6400.c b/arch/arm/mach-s3c64xx/mach-smdk6400.c index a392869c8342..d70c0843aea2 100644 --- a/arch/arm/mach-s3c64xx/mach-smdk6400.c +++ b/arch/arm/mach-s3c64xx/mach-smdk6400.c | |||
@@ -35,6 +35,7 @@ | |||
35 | #include <plat/devs.h> | 35 | #include <plat/devs.h> |
36 | #include <plat/cpu.h> | 36 | #include <plat/cpu.h> |
37 | #include <linux/platform_data/i2c-s3c2410.h> | 37 | #include <linux/platform_data/i2c-s3c2410.h> |
38 | #include <plat/samsung-time.h> | ||
38 | 39 | ||
39 | #include "common.h" | 40 | #include "common.h" |
40 | 41 | ||
@@ -66,6 +67,7 @@ static void __init smdk6400_map_io(void) | |||
66 | s3c64xx_init_io(smdk6400_iodesc, ARRAY_SIZE(smdk6400_iodesc)); | 67 | s3c64xx_init_io(smdk6400_iodesc, ARRAY_SIZE(smdk6400_iodesc)); |
67 | s3c24xx_init_clocks(12000000); | 68 | s3c24xx_init_clocks(12000000); |
68 | s3c24xx_init_uarts(smdk6400_uartcfgs, ARRAY_SIZE(smdk6400_uartcfgs)); | 69 | s3c24xx_init_uarts(smdk6400_uartcfgs, ARRAY_SIZE(smdk6400_uartcfgs)); |
70 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
69 | } | 71 | } |
70 | 72 | ||
71 | static struct platform_device *smdk6400_devices[] __initdata = { | 73 | static struct platform_device *smdk6400_devices[] __initdata = { |
@@ -92,6 +94,6 @@ MACHINE_START(SMDK6400, "SMDK6400") | |||
92 | .map_io = smdk6400_map_io, | 94 | .map_io = smdk6400_map_io, |
93 | .init_machine = smdk6400_machine_init, | 95 | .init_machine = smdk6400_machine_init, |
94 | .init_late = s3c64xx_init_late, | 96 | .init_late = s3c64xx_init_late, |
95 | .init_time = s3c24xx_timer_init, | 97 | .init_time = samsung_timer_init, |
96 | .restart = s3c64xx_restart, | 98 | .restart = s3c64xx_restart, |
97 | MACHINE_END | 99 | MACHINE_END |
diff --git a/arch/arm/mach-s3c64xx/mach-smdk6410.c b/arch/arm/mach-s3c64xx/mach-smdk6410.c index ba7544e2d04d..bd3295a19ad7 100644 --- a/arch/arm/mach-s3c64xx/mach-smdk6410.c +++ b/arch/arm/mach-s3c64xx/mach-smdk6410.c | |||
@@ -69,6 +69,7 @@ | |||
69 | #include <linux/platform_data/touchscreen-s3c2410.h> | 69 | #include <linux/platform_data/touchscreen-s3c2410.h> |
70 | #include <plat/keypad.h> | 70 | #include <plat/keypad.h> |
71 | #include <plat/backlight.h> | 71 | #include <plat/backlight.h> |
72 | #include <plat/samsung-time.h> | ||
72 | 73 | ||
73 | #include "common.h" | 74 | #include "common.h" |
74 | #include "regs-modem.h" | 75 | #include "regs-modem.h" |
@@ -634,6 +635,7 @@ static void __init smdk6410_map_io(void) | |||
634 | s3c64xx_init_io(smdk6410_iodesc, ARRAY_SIZE(smdk6410_iodesc)); | 635 | s3c64xx_init_io(smdk6410_iodesc, ARRAY_SIZE(smdk6410_iodesc)); |
635 | s3c24xx_init_clocks(12000000); | 636 | s3c24xx_init_clocks(12000000); |
636 | s3c24xx_init_uarts(smdk6410_uartcfgs, ARRAY_SIZE(smdk6410_uartcfgs)); | 637 | s3c24xx_init_uarts(smdk6410_uartcfgs, ARRAY_SIZE(smdk6410_uartcfgs)); |
638 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
637 | 639 | ||
638 | /* set the LCD type */ | 640 | /* set the LCD type */ |
639 | 641 | ||
@@ -702,6 +704,6 @@ MACHINE_START(SMDK6410, "SMDK6410") | |||
702 | .map_io = smdk6410_map_io, | 704 | .map_io = smdk6410_map_io, |
703 | .init_machine = smdk6410_machine_init, | 705 | .init_machine = smdk6410_machine_init, |
704 | .init_late = s3c64xx_init_late, | 706 | .init_late = s3c64xx_init_late, |
705 | .init_time = s3c24xx_timer_init, | 707 | .init_time = samsung_timer_init, |
706 | .restart = s3c64xx_restart, | 708 | .restart = s3c64xx_restart, |
707 | MACHINE_END | 709 | MACHINE_END |
diff --git a/arch/arm/mach-s5p64x0/Kconfig b/arch/arm/mach-s5p64x0/Kconfig index e8742cb7ddd9..5a707bdb9ea0 100644 --- a/arch/arm/mach-s5p64x0/Kconfig +++ b/arch/arm/mach-s5p64x0/Kconfig | |||
@@ -9,16 +9,16 @@ if ARCH_S5P64X0 | |||
9 | 9 | ||
10 | config CPU_S5P6440 | 10 | config CPU_S5P6440 |
11 | bool | 11 | bool |
12 | select S5P_HRT | ||
13 | select S5P_SLEEP if PM | 12 | select S5P_SLEEP if PM |
14 | select SAMSUNG_DMADEV | 13 | select SAMSUNG_DMADEV |
14 | select SAMSUNG_HRT | ||
15 | select SAMSUNG_WAKEMASK if PM | 15 | select SAMSUNG_WAKEMASK if PM |
16 | help | 16 | help |
17 | Enable S5P6440 CPU support | 17 | Enable S5P6440 CPU support |
18 | 18 | ||
19 | config CPU_S5P6450 | 19 | config CPU_S5P6450 |
20 | bool | 20 | bool |
21 | select S5P_HRT | 21 | select SAMSUNG_HRT |
22 | select S5P_SLEEP if PM | 22 | select S5P_SLEEP if PM |
23 | select SAMSUNG_DMADEV | 23 | select SAMSUNG_DMADEV |
24 | select SAMSUNG_WAKEMASK if PM | 24 | select SAMSUNG_WAKEMASK if PM |
diff --git a/arch/arm/mach-s5p64x0/mach-smdk6440.c b/arch/arm/mach-s5p64x0/mach-smdk6440.c index e23723a5a214..73f71a698a34 100644 --- a/arch/arm/mach-s5p64x0/mach-smdk6440.c +++ b/arch/arm/mach-s5p64x0/mach-smdk6440.c | |||
@@ -48,7 +48,7 @@ | |||
48 | #include <plat/pll.h> | 48 | #include <plat/pll.h> |
49 | #include <plat/adc.h> | 49 | #include <plat/adc.h> |
50 | #include <linux/platform_data/touchscreen-s3c2410.h> | 50 | #include <linux/platform_data/touchscreen-s3c2410.h> |
51 | #include <plat/s5p-time.h> | 51 | #include <plat/samsung-time.h> |
52 | #include <plat/backlight.h> | 52 | #include <plat/backlight.h> |
53 | #include <plat/fb.h> | 53 | #include <plat/fb.h> |
54 | #include <plat/sdhci.h> | 54 | #include <plat/sdhci.h> |
@@ -229,7 +229,7 @@ static void __init smdk6440_map_io(void) | |||
229 | s5p64x0_init_io(NULL, 0); | 229 | s5p64x0_init_io(NULL, 0); |
230 | s3c24xx_init_clocks(12000000); | 230 | s3c24xx_init_clocks(12000000); |
231 | s3c24xx_init_uarts(smdk6440_uartcfgs, ARRAY_SIZE(smdk6440_uartcfgs)); | 231 | s3c24xx_init_uarts(smdk6440_uartcfgs, ARRAY_SIZE(smdk6440_uartcfgs)); |
232 | s5p_set_timer_source(S5P_PWM3, S5P_PWM4); | 232 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); |
233 | } | 233 | } |
234 | 234 | ||
235 | static void s5p6440_set_lcd_interface(void) | 235 | static void s5p6440_set_lcd_interface(void) |
@@ -273,6 +273,6 @@ MACHINE_START(SMDK6440, "SMDK6440") | |||
273 | .init_irq = s5p6440_init_irq, | 273 | .init_irq = s5p6440_init_irq, |
274 | .map_io = smdk6440_map_io, | 274 | .map_io = smdk6440_map_io, |
275 | .init_machine = smdk6440_machine_init, | 275 | .init_machine = smdk6440_machine_init, |
276 | .init_time = s5p_timer_init, | 276 | .init_time = samsung_timer_init, |
277 | .restart = s5p64x0_restart, | 277 | .restart = s5p64x0_restart, |
278 | MACHINE_END | 278 | MACHINE_END |
diff --git a/arch/arm/mach-s5p64x0/mach-smdk6450.c b/arch/arm/mach-s5p64x0/mach-smdk6450.c index ca10963a959e..18303e12019f 100644 --- a/arch/arm/mach-s5p64x0/mach-smdk6450.c +++ b/arch/arm/mach-s5p64x0/mach-smdk6450.c | |||
@@ -48,7 +48,7 @@ | |||
48 | #include <plat/pll.h> | 48 | #include <plat/pll.h> |
49 | #include <plat/adc.h> | 49 | #include <plat/adc.h> |
50 | #include <linux/platform_data/touchscreen-s3c2410.h> | 50 | #include <linux/platform_data/touchscreen-s3c2410.h> |
51 | #include <plat/s5p-time.h> | 51 | #include <plat/samsung-time.h> |
52 | #include <plat/backlight.h> | 52 | #include <plat/backlight.h> |
53 | #include <plat/fb.h> | 53 | #include <plat/fb.h> |
54 | #include <plat/sdhci.h> | 54 | #include <plat/sdhci.h> |
@@ -248,7 +248,7 @@ static void __init smdk6450_map_io(void) | |||
248 | s5p64x0_init_io(NULL, 0); | 248 | s5p64x0_init_io(NULL, 0); |
249 | s3c24xx_init_clocks(19200000); | 249 | s3c24xx_init_clocks(19200000); |
250 | s3c24xx_init_uarts(smdk6450_uartcfgs, ARRAY_SIZE(smdk6450_uartcfgs)); | 250 | s3c24xx_init_uarts(smdk6450_uartcfgs, ARRAY_SIZE(smdk6450_uartcfgs)); |
251 | s5p_set_timer_source(S5P_PWM3, S5P_PWM4); | 251 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); |
252 | } | 252 | } |
253 | 253 | ||
254 | static void s5p6450_set_lcd_interface(void) | 254 | static void s5p6450_set_lcd_interface(void) |
@@ -292,6 +292,6 @@ MACHINE_START(SMDK6450, "SMDK6450") | |||
292 | .init_irq = s5p6450_init_irq, | 292 | .init_irq = s5p6450_init_irq, |
293 | .map_io = smdk6450_map_io, | 293 | .map_io = smdk6450_map_io, |
294 | .init_machine = smdk6450_machine_init, | 294 | .init_machine = smdk6450_machine_init, |
295 | .init_time = s5p_timer_init, | 295 | .init_time = samsung_timer_init, |
296 | .restart = s5p64x0_restart, | 296 | .restart = s5p64x0_restart, |
297 | MACHINE_END | 297 | MACHINE_END |
diff --git a/arch/arm/mach-s5pc100/Kconfig b/arch/arm/mach-s5pc100/Kconfig index 15170be97a74..2f456a4533ba 100644 --- a/arch/arm/mach-s5pc100/Kconfig +++ b/arch/arm/mach-s5pc100/Kconfig | |||
@@ -11,6 +11,7 @@ config CPU_S5PC100 | |||
11 | bool | 11 | bool |
12 | select S5P_EXT_INT | 12 | select S5P_EXT_INT |
13 | select SAMSUNG_DMADEV | 13 | select SAMSUNG_DMADEV |
14 | select SAMSUNG_HRT | ||
14 | help | 15 | help |
15 | Enable S5PC100 CPU support | 16 | Enable S5PC100 CPU support |
16 | 17 | ||
diff --git a/arch/arm/mach-s5pc100/mach-smdkc100.c b/arch/arm/mach-s5pc100/mach-smdkc100.c index 185a19583898..8c880f76f274 100644 --- a/arch/arm/mach-s5pc100/mach-smdkc100.c +++ b/arch/arm/mach-s5pc100/mach-smdkc100.c | |||
@@ -51,6 +51,7 @@ | |||
51 | #include <linux/platform_data/touchscreen-s3c2410.h> | 51 | #include <linux/platform_data/touchscreen-s3c2410.h> |
52 | #include <linux/platform_data/asoc-s3c.h> | 52 | #include <linux/platform_data/asoc-s3c.h> |
53 | #include <plat/backlight.h> | 53 | #include <plat/backlight.h> |
54 | #include <plat/samsung-time.h> | ||
54 | 55 | ||
55 | #include "common.h" | 56 | #include "common.h" |
56 | 57 | ||
@@ -221,6 +222,7 @@ static void __init smdkc100_map_io(void) | |||
221 | s5pc100_init_io(NULL, 0); | 222 | s5pc100_init_io(NULL, 0); |
222 | s3c24xx_init_clocks(12000000); | 223 | s3c24xx_init_clocks(12000000); |
223 | s3c24xx_init_uarts(smdkc100_uartcfgs, ARRAY_SIZE(smdkc100_uartcfgs)); | 224 | s3c24xx_init_uarts(smdkc100_uartcfgs, ARRAY_SIZE(smdkc100_uartcfgs)); |
225 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); | ||
224 | } | 226 | } |
225 | 227 | ||
226 | static void __init smdkc100_machine_init(void) | 228 | static void __init smdkc100_machine_init(void) |
@@ -255,6 +257,6 @@ MACHINE_START(SMDKC100, "SMDKC100") | |||
255 | .init_irq = s5pc100_init_irq, | 257 | .init_irq = s5pc100_init_irq, |
256 | .map_io = smdkc100_map_io, | 258 | .map_io = smdkc100_map_io, |
257 | .init_machine = smdkc100_machine_init, | 259 | .init_machine = smdkc100_machine_init, |
258 | .init_time = s3c24xx_timer_init, | 260 | .init_time = samsung_timer_init, |
259 | .restart = s5pc100_restart, | 261 | .restart = s5pc100_restart, |
260 | MACHINE_END | 262 | MACHINE_END |
diff --git a/arch/arm/mach-s5pv210/Kconfig b/arch/arm/mach-s5pv210/Kconfig index 92ad72f0ef98..0963283a7c5d 100644 --- a/arch/arm/mach-s5pv210/Kconfig +++ b/arch/arm/mach-s5pv210/Kconfig | |||
@@ -12,10 +12,10 @@ if ARCH_S5PV210 | |||
12 | config CPU_S5PV210 | 12 | config CPU_S5PV210 |
13 | bool | 13 | bool |
14 | select S5P_EXT_INT | 14 | select S5P_EXT_INT |
15 | select S5P_HRT | ||
16 | select S5P_PM if PM | 15 | select S5P_PM if PM |
17 | select S5P_SLEEP if PM | 16 | select S5P_SLEEP if PM |
18 | select SAMSUNG_DMADEV | 17 | select SAMSUNG_DMADEV |
18 | select SAMSUNG_HRT | ||
19 | help | 19 | help |
20 | Enable S5PV210 CPU support | 20 | Enable S5PV210 CPU support |
21 | 21 | ||
diff --git a/arch/arm/mach-s5pv210/mach-aquila.c b/arch/arm/mach-s5pv210/mach-aquila.c index 11900a8e88a3..ed2b85485b9d 100644 --- a/arch/arm/mach-s5pv210/mach-aquila.c +++ b/arch/arm/mach-s5pv210/mach-aquila.c | |||
@@ -38,7 +38,7 @@ | |||
38 | #include <plat/fb.h> | 38 | #include <plat/fb.h> |
39 | #include <plat/fimc-core.h> | 39 | #include <plat/fimc-core.h> |
40 | #include <plat/sdhci.h> | 40 | #include <plat/sdhci.h> |
41 | #include <plat/s5p-time.h> | 41 | #include <plat/samsung-time.h> |
42 | 42 | ||
43 | #include "common.h" | 43 | #include "common.h" |
44 | 44 | ||
@@ -651,7 +651,7 @@ static void __init aquila_map_io(void) | |||
651 | s5pv210_init_io(NULL, 0); | 651 | s5pv210_init_io(NULL, 0); |
652 | s3c24xx_init_clocks(24000000); | 652 | s3c24xx_init_clocks(24000000); |
653 | s3c24xx_init_uarts(aquila_uartcfgs, ARRAY_SIZE(aquila_uartcfgs)); | 653 | s3c24xx_init_uarts(aquila_uartcfgs, ARRAY_SIZE(aquila_uartcfgs)); |
654 | s5p_set_timer_source(S5P_PWM3, S5P_PWM4); | 654 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); |
655 | } | 655 | } |
656 | 656 | ||
657 | static void __init aquila_machine_init(void) | 657 | static void __init aquila_machine_init(void) |
@@ -686,6 +686,6 @@ MACHINE_START(AQUILA, "Aquila") | |||
686 | .init_irq = s5pv210_init_irq, | 686 | .init_irq = s5pv210_init_irq, |
687 | .map_io = aquila_map_io, | 687 | .map_io = aquila_map_io, |
688 | .init_machine = aquila_machine_init, | 688 | .init_machine = aquila_machine_init, |
689 | .init_time = s5p_timer_init, | 689 | .init_time = samsung_timer_init, |
690 | .restart = s5pv210_restart, | 690 | .restart = s5pv210_restart, |
691 | MACHINE_END | 691 | MACHINE_END |
diff --git a/arch/arm/mach-s5pv210/mach-goni.c b/arch/arm/mach-s5pv210/mach-goni.c index e373de44a8b6..30b24ad84f49 100644 --- a/arch/arm/mach-s5pv210/mach-goni.c +++ b/arch/arm/mach-s5pv210/mach-goni.c | |||
@@ -47,7 +47,7 @@ | |||
47 | #include <plat/keypad.h> | 47 | #include <plat/keypad.h> |
48 | #include <plat/sdhci.h> | 48 | #include <plat/sdhci.h> |
49 | #include <plat/clock.h> | 49 | #include <plat/clock.h> |
50 | #include <plat/s5p-time.h> | 50 | #include <plat/samsung-time.h> |
51 | #include <plat/mfc.h> | 51 | #include <plat/mfc.h> |
52 | #include <plat/camport.h> | 52 | #include <plat/camport.h> |
53 | 53 | ||
@@ -908,7 +908,7 @@ static void __init goni_map_io(void) | |||
908 | s5pv210_init_io(NULL, 0); | 908 | s5pv210_init_io(NULL, 0); |
909 | s3c24xx_init_clocks(clk_xusbxti.rate); | 909 | s3c24xx_init_clocks(clk_xusbxti.rate); |
910 | s3c24xx_init_uarts(goni_uartcfgs, ARRAY_SIZE(goni_uartcfgs)); | 910 | s3c24xx_init_uarts(goni_uartcfgs, ARRAY_SIZE(goni_uartcfgs)); |
911 | s5p_set_timer_source(S5P_PWM3, S5P_PWM4); | 911 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); |
912 | } | 912 | } |
913 | 913 | ||
914 | static void __init goni_reserve(void) | 914 | static void __init goni_reserve(void) |
@@ -973,7 +973,7 @@ MACHINE_START(GONI, "GONI") | |||
973 | .init_irq = s5pv210_init_irq, | 973 | .init_irq = s5pv210_init_irq, |
974 | .map_io = goni_map_io, | 974 | .map_io = goni_map_io, |
975 | .init_machine = goni_machine_init, | 975 | .init_machine = goni_machine_init, |
976 | .init_time = s5p_timer_init, | 976 | .init_time = samsung_timer_init, |
977 | .reserve = &goni_reserve, | 977 | .reserve = &goni_reserve, |
978 | .restart = s5pv210_restart, | 978 | .restart = s5pv210_restart, |
979 | MACHINE_END | 979 | MACHINE_END |
diff --git a/arch/arm/mach-s5pv210/mach-smdkc110.c b/arch/arm/mach-s5pv210/mach-smdkc110.c index 28bd0248a3e2..7c0ed07a78a3 100644 --- a/arch/arm/mach-s5pv210/mach-smdkc110.c +++ b/arch/arm/mach-s5pv210/mach-smdkc110.c | |||
@@ -29,7 +29,7 @@ | |||
29 | #include <linux/platform_data/ata-samsung_cf.h> | 29 | #include <linux/platform_data/ata-samsung_cf.h> |
30 | #include <linux/platform_data/i2c-s3c2410.h> | 30 | #include <linux/platform_data/i2c-s3c2410.h> |
31 | #include <plat/pm.h> | 31 | #include <plat/pm.h> |
32 | #include <plat/s5p-time.h> | 32 | #include <plat/samsung-time.h> |
33 | #include <plat/mfc.h> | 33 | #include <plat/mfc.h> |
34 | 34 | ||
35 | #include "common.h" | 35 | #include "common.h" |
@@ -120,7 +120,7 @@ static void __init smdkc110_map_io(void) | |||
120 | s5pv210_init_io(NULL, 0); | 120 | s5pv210_init_io(NULL, 0); |
121 | s3c24xx_init_clocks(24000000); | 121 | s3c24xx_init_clocks(24000000); |
122 | s3c24xx_init_uarts(smdkv210_uartcfgs, ARRAY_SIZE(smdkv210_uartcfgs)); | 122 | s3c24xx_init_uarts(smdkv210_uartcfgs, ARRAY_SIZE(smdkv210_uartcfgs)); |
123 | s5p_set_timer_source(S5P_PWM3, S5P_PWM4); | 123 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); |
124 | } | 124 | } |
125 | 125 | ||
126 | static void __init smdkc110_reserve(void) | 126 | static void __init smdkc110_reserve(void) |
@@ -153,7 +153,7 @@ MACHINE_START(SMDKC110, "SMDKC110") | |||
153 | .init_irq = s5pv210_init_irq, | 153 | .init_irq = s5pv210_init_irq, |
154 | .map_io = smdkc110_map_io, | 154 | .map_io = smdkc110_map_io, |
155 | .init_machine = smdkc110_machine_init, | 155 | .init_machine = smdkc110_machine_init, |
156 | .init_time = s5p_timer_init, | 156 | .init_time = samsung_timer_init, |
157 | .restart = s5pv210_restart, | 157 | .restart = s5pv210_restart, |
158 | .reserve = &smdkc110_reserve, | 158 | .reserve = &smdkc110_reserve, |
159 | MACHINE_END | 159 | MACHINE_END |
diff --git a/arch/arm/mach-s5pv210/mach-smdkv210.c b/arch/arm/mach-s5pv210/mach-smdkv210.c index 3c73f36869bb..d50b6f124465 100644 --- a/arch/arm/mach-s5pv210/mach-smdkv210.c +++ b/arch/arm/mach-s5pv210/mach-smdkv210.c | |||
@@ -44,7 +44,7 @@ | |||
44 | #include <plat/keypad.h> | 44 | #include <plat/keypad.h> |
45 | #include <plat/pm.h> | 45 | #include <plat/pm.h> |
46 | #include <plat/fb.h> | 46 | #include <plat/fb.h> |
47 | #include <plat/s5p-time.h> | 47 | #include <plat/samsung-time.h> |
48 | #include <plat/backlight.h> | 48 | #include <plat/backlight.h> |
49 | #include <plat/mfc.h> | 49 | #include <plat/mfc.h> |
50 | #include <plat/clock.h> | 50 | #include <plat/clock.h> |
@@ -285,7 +285,7 @@ static void __init smdkv210_map_io(void) | |||
285 | s5pv210_init_io(NULL, 0); | 285 | s5pv210_init_io(NULL, 0); |
286 | s3c24xx_init_clocks(clk_xusbxti.rate); | 286 | s3c24xx_init_clocks(clk_xusbxti.rate); |
287 | s3c24xx_init_uarts(smdkv210_uartcfgs, ARRAY_SIZE(smdkv210_uartcfgs)); | 287 | s3c24xx_init_uarts(smdkv210_uartcfgs, ARRAY_SIZE(smdkv210_uartcfgs)); |
288 | s5p_set_timer_source(S5P_PWM2, S5P_PWM4); | 288 | samsung_set_timer_source(SAMSUNG_PWM2, SAMSUNG_PWM4); |
289 | } | 289 | } |
290 | 290 | ||
291 | static void __init smdkv210_reserve(void) | 291 | static void __init smdkv210_reserve(void) |
@@ -329,7 +329,7 @@ MACHINE_START(SMDKV210, "SMDKV210") | |||
329 | .init_irq = s5pv210_init_irq, | 329 | .init_irq = s5pv210_init_irq, |
330 | .map_io = smdkv210_map_io, | 330 | .map_io = smdkv210_map_io, |
331 | .init_machine = smdkv210_machine_init, | 331 | .init_machine = smdkv210_machine_init, |
332 | .init_time = s5p_timer_init, | 332 | .init_time = samsung_timer_init, |
333 | .restart = s5pv210_restart, | 333 | .restart = s5pv210_restart, |
334 | .reserve = &smdkv210_reserve, | 334 | .reserve = &smdkv210_reserve, |
335 | MACHINE_END | 335 | MACHINE_END |
diff --git a/arch/arm/mach-s5pv210/mach-torbreck.c b/arch/arm/mach-s5pv210/mach-torbreck.c index 2d4c5531819c..579afe89842a 100644 --- a/arch/arm/mach-s5pv210/mach-torbreck.c +++ b/arch/arm/mach-s5pv210/mach-torbreck.c | |||
@@ -26,7 +26,7 @@ | |||
26 | #include <plat/devs.h> | 26 | #include <plat/devs.h> |
27 | #include <plat/cpu.h> | 27 | #include <plat/cpu.h> |
28 | #include <linux/platform_data/i2c-s3c2410.h> | 28 | #include <linux/platform_data/i2c-s3c2410.h> |
29 | #include <plat/s5p-time.h> | 29 | #include <plat/samsung-time.h> |
30 | 30 | ||
31 | #include "common.h" | 31 | #include "common.h" |
32 | 32 | ||
@@ -106,7 +106,7 @@ static void __init torbreck_map_io(void) | |||
106 | s5pv210_init_io(NULL, 0); | 106 | s5pv210_init_io(NULL, 0); |
107 | s3c24xx_init_clocks(24000000); | 107 | s3c24xx_init_clocks(24000000); |
108 | s3c24xx_init_uarts(torbreck_uartcfgs, ARRAY_SIZE(torbreck_uartcfgs)); | 108 | s3c24xx_init_uarts(torbreck_uartcfgs, ARRAY_SIZE(torbreck_uartcfgs)); |
109 | s5p_set_timer_source(S5P_PWM3, S5P_PWM4); | 109 | samsung_set_timer_source(SAMSUNG_PWM3, SAMSUNG_PWM4); |
110 | } | 110 | } |
111 | 111 | ||
112 | static void __init torbreck_machine_init(void) | 112 | static void __init torbreck_machine_init(void) |
@@ -130,6 +130,6 @@ MACHINE_START(TORBRECK, "TORBRECK") | |||
130 | .init_irq = s5pv210_init_irq, | 130 | .init_irq = s5pv210_init_irq, |
131 | .map_io = torbreck_map_io, | 131 | .map_io = torbreck_map_io, |
132 | .init_machine = torbreck_machine_init, | 132 | .init_machine = torbreck_machine_init, |
133 | .init_time = s5p_timer_init, | 133 | .init_time = samsung_timer_init, |
134 | .restart = s5pv210_restart, | 134 | .restart = s5pv210_restart, |
135 | MACHINE_END | 135 | MACHINE_END |
diff --git a/arch/arm/mach-shmobile/Kconfig b/arch/arm/mach-shmobile/Kconfig index 9255546e7bf6..75d413c004b6 100644 --- a/arch/arm/mach-shmobile/Kconfig +++ b/arch/arm/mach-shmobile/Kconfig | |||
@@ -16,6 +16,7 @@ config ARCH_SH73A0 | |||
16 | select CPU_V7 | 16 | select CPU_V7 |
17 | select I2C | 17 | select I2C |
18 | select SH_CLK_CPG | 18 | select SH_CLK_CPG |
19 | select RENESAS_INTC_IRQPIN | ||
19 | 20 | ||
20 | config ARCH_R8A7740 | 21 | config ARCH_R8A7740 |
21 | bool "R-Mobile A1 (R8A77400)" | 22 | bool "R-Mobile A1 (R8A77400)" |
@@ -31,6 +32,7 @@ config ARCH_R8A7779 | |||
31 | select SH_CLK_CPG | 32 | select SH_CLK_CPG |
32 | select USB_ARCH_HAS_EHCI | 33 | select USB_ARCH_HAS_EHCI |
33 | select USB_ARCH_HAS_OHCI | 34 | select USB_ARCH_HAS_OHCI |
35 | select RENESAS_INTC_IRQPIN | ||
34 | 36 | ||
35 | config ARCH_EMEV2 | 37 | config ARCH_EMEV2 |
36 | bool "Emma Mobile EV2" | 38 | bool "Emma Mobile EV2" |
diff --git a/arch/arm/mach-shmobile/board-kzm9g.c b/arch/arm/mach-shmobile/board-kzm9g.c index a385f570bbfc..95fe396f9604 100644 --- a/arch/arm/mach-shmobile/board-kzm9g.c +++ b/arch/arm/mach-shmobile/board-kzm9g.c | |||
@@ -81,7 +81,7 @@ static struct resource smsc9221_resources[] = { | |||
81 | .flags = IORESOURCE_MEM, | 81 | .flags = IORESOURCE_MEM, |
82 | }, | 82 | }, |
83 | [1] = { | 83 | [1] = { |
84 | .start = intcs_evt2irq(0x260), /* IRQ3 */ | 84 | .start = irq_pin(3), /* IRQ3 */ |
85 | .flags = IORESOURCE_IRQ, | 85 | .flags = IORESOURCE_IRQ, |
86 | }, | 86 | }, |
87 | }; | 87 | }; |
@@ -115,7 +115,7 @@ static struct resource usb_resources[] = { | |||
115 | .flags = IORESOURCE_MEM, | 115 | .flags = IORESOURCE_MEM, |
116 | }, | 116 | }, |
117 | [1] = { | 117 | [1] = { |
118 | .start = intcs_evt2irq(0x220), /* IRQ1 */ | 118 | .start = irq_pin(1), /* IRQ1 */ |
119 | .flags = IORESOURCE_IRQ, | 119 | .flags = IORESOURCE_IRQ, |
120 | }, | 120 | }, |
121 | }; | 121 | }; |
@@ -138,7 +138,7 @@ struct usbhs_private { | |||
138 | struct renesas_usbhs_platform_info info; | 138 | struct renesas_usbhs_platform_info info; |
139 | }; | 139 | }; |
140 | 140 | ||
141 | #define IRQ15 intcs_evt2irq(0x03e0) | 141 | #define IRQ15 irq_pin(15) |
142 | #define USB_PHY_MODE (1 << 4) | 142 | #define USB_PHY_MODE (1 << 4) |
143 | #define USB_PHY_INT_EN ((1 << 3) | (1 << 2)) | 143 | #define USB_PHY_INT_EN ((1 << 3) | (1 << 2)) |
144 | #define USB_PHY_ON (1 << 1) | 144 | #define USB_PHY_ON (1 << 1) |
@@ -567,25 +567,25 @@ static struct i2c_board_info i2c0_devices[] = { | |||
567 | }, | 567 | }, |
568 | { | 568 | { |
569 | I2C_BOARD_INFO("ak8975", 0x0c), | 569 | I2C_BOARD_INFO("ak8975", 0x0c), |
570 | .irq = intcs_evt2irq(0x3380), /* IRQ28 */ | 570 | .irq = irq_pin(28), /* IRQ28 */ |
571 | }, | 571 | }, |
572 | { | 572 | { |
573 | I2C_BOARD_INFO("adxl34x", 0x1d), | 573 | I2C_BOARD_INFO("adxl34x", 0x1d), |
574 | .irq = intcs_evt2irq(0x3340), /* IRQ26 */ | 574 | .irq = irq_pin(26), /* IRQ26 */ |
575 | }, | 575 | }, |
576 | }; | 576 | }; |
577 | 577 | ||
578 | static struct i2c_board_info i2c1_devices[] = { | 578 | static struct i2c_board_info i2c1_devices[] = { |
579 | { | 579 | { |
580 | I2C_BOARD_INFO("st1232-ts", 0x55), | 580 | I2C_BOARD_INFO("st1232-ts", 0x55), |
581 | .irq = intcs_evt2irq(0x300), /* IRQ8 */ | 581 | .irq = irq_pin(8), /* IRQ8 */ |
582 | }, | 582 | }, |
583 | }; | 583 | }; |
584 | 584 | ||
585 | static struct i2c_board_info i2c3_devices[] = { | 585 | static struct i2c_board_info i2c3_devices[] = { |
586 | { | 586 | { |
587 | I2C_BOARD_INFO("pcf8575", 0x20), | 587 | I2C_BOARD_INFO("pcf8575", 0x20), |
588 | .irq = intcs_evt2irq(0x3260), /* IRQ19 */ | 588 | .irq = irq_pin(19), /* IRQ19 */ |
589 | .platform_data = &pcf8575_pdata, | 589 | .platform_data = &pcf8575_pdata, |
590 | }, | 590 | }, |
591 | }; | 591 | }; |
diff --git a/arch/arm/mach-shmobile/include/mach/common.h b/arch/arm/mach-shmobile/include/mach/common.h index 62c04c252418..1fef737a4c1a 100644 --- a/arch/arm/mach-shmobile/include/mach/common.h +++ b/arch/arm/mach-shmobile/include/mach/common.h | |||
@@ -58,6 +58,7 @@ extern void r8a7740_pm_init(void); | |||
58 | 58 | ||
59 | extern void r8a7779_init_delay(void); | 59 | extern void r8a7779_init_delay(void); |
60 | extern void r8a7779_init_irq(void); | 60 | extern void r8a7779_init_irq(void); |
61 | extern void r8a7779_init_irq_extpin(int irlm); | ||
61 | extern void r8a7779_init_irq_dt(void); | 62 | extern void r8a7779_init_irq_dt(void); |
62 | extern void r8a7779_map_io(void); | 63 | extern void r8a7779_map_io(void); |
63 | extern void r8a7779_earlytimer_init(void); | 64 | extern void r8a7779_earlytimer_init(void); |
diff --git a/arch/arm/mach-shmobile/include/mach/irqs.h b/arch/arm/mach-shmobile/include/mach/irqs.h index 992ed213cec1..b2074e2acb15 100644 --- a/arch/arm/mach-shmobile/include/mach/irqs.h +++ b/arch/arm/mach-shmobile/include/mach/irqs.h | |||
@@ -12,4 +12,8 @@ | |||
12 | #define INTCS_VECT(n, vect) INTC_VECT((n), INTCS_VECT_BASE + (vect)) | 12 | #define INTCS_VECT(n, vect) INTC_VECT((n), INTCS_VECT_BASE + (vect)) |
13 | #define intcs_evt2irq(evt) evt2irq(INTCS_VECT_BASE + (evt)) | 13 | #define intcs_evt2irq(evt) evt2irq(INTCS_VECT_BASE + (evt)) |
14 | 14 | ||
15 | /* External IRQ pins */ | ||
16 | #define IRQPIN_BASE 2000 | ||
17 | #define irq_pin(nr) ((nr) + IRQPIN_BASE) | ||
18 | |||
15 | #endif /* __ASM_MACH_IRQS_H */ | 19 | #endif /* __ASM_MACH_IRQS_H */ |
diff --git a/arch/arm/mach-shmobile/intc-r8a7779.c b/arch/arm/mach-shmobile/intc-r8a7779.c index f9cc4bc9c798..b86dc8908724 100644 --- a/arch/arm/mach-shmobile/intc-r8a7779.c +++ b/arch/arm/mach-shmobile/intc-r8a7779.c | |||
@@ -19,13 +19,16 @@ | |||
19 | */ | 19 | */ |
20 | #include <linux/kernel.h> | 20 | #include <linux/kernel.h> |
21 | #include <linux/init.h> | 21 | #include <linux/init.h> |
22 | #include <linux/platform_device.h> | ||
22 | #include <linux/interrupt.h> | 23 | #include <linux/interrupt.h> |
23 | #include <linux/irq.h> | 24 | #include <linux/irq.h> |
24 | #include <linux/io.h> | 25 | #include <linux/io.h> |
25 | #include <linux/irqchip/arm-gic.h> | 26 | #include <linux/irqchip/arm-gic.h> |
26 | #include <mach/common.h> | 27 | #include <linux/platform_data/irq-renesas-intc-irqpin.h> |
27 | #include <linux/irqchip.h> | 28 | #include <linux/irqchip.h> |
29 | #include <mach/common.h> | ||
28 | #include <mach/intc.h> | 30 | #include <mach/intc.h> |
31 | #include <mach/irqs.h> | ||
29 | #include <mach/r8a7779.h> | 32 | #include <mach/r8a7779.h> |
30 | #include <asm/mach-types.h> | 33 | #include <asm/mach-types.h> |
31 | #include <asm/mach/arch.h> | 34 | #include <asm/mach/arch.h> |
@@ -39,6 +42,54 @@ | |||
39 | #define INT2NTSR0 IOMEM(0xfe700060) | 42 | #define INT2NTSR0 IOMEM(0xfe700060) |
40 | #define INT2NTSR1 IOMEM(0xfe700064) | 43 | #define INT2NTSR1 IOMEM(0xfe700064) |
41 | 44 | ||
45 | static struct renesas_intc_irqpin_config irqpin0_platform_data = { | ||
46 | .irq_base = irq_pin(0), /* IRQ0 -> IRQ3 */ | ||
47 | .sense_bitfield_width = 2, | ||
48 | }; | ||
49 | |||
50 | static struct resource irqpin0_resources[] = { | ||
51 | DEFINE_RES_MEM(0xfe78001c, 4), /* ICR1 */ | ||
52 | DEFINE_RES_MEM(0xfe780010, 4), /* INTPRI */ | ||
53 | DEFINE_RES_MEM(0xfe780024, 4), /* INTREQ */ | ||
54 | DEFINE_RES_MEM(0xfe780044, 4), /* INTMSK0 */ | ||
55 | DEFINE_RES_MEM(0xfe780064, 4), /* INTMSKCLR0 */ | ||
56 | DEFINE_RES_IRQ(gic_spi(27)), /* IRQ0 */ | ||
57 | DEFINE_RES_IRQ(gic_spi(28)), /* IRQ1 */ | ||
58 | DEFINE_RES_IRQ(gic_spi(29)), /* IRQ2 */ | ||
59 | DEFINE_RES_IRQ(gic_spi(30)), /* IRQ3 */ | ||
60 | }; | ||
61 | |||
62 | static struct platform_device irqpin0_device = { | ||
63 | .name = "renesas_intc_irqpin", | ||
64 | .id = 0, | ||
65 | .resource = irqpin0_resources, | ||
66 | .num_resources = ARRAY_SIZE(irqpin0_resources), | ||
67 | .dev = { | ||
68 | .platform_data = &irqpin0_platform_data, | ||
69 | }, | ||
70 | }; | ||
71 | |||
72 | void __init r8a7779_init_irq_extpin(int irlm) | ||
73 | { | ||
74 | void __iomem *icr0 = ioremap_nocache(0xfe780000, PAGE_SIZE); | ||
75 | unsigned long tmp; | ||
76 | |||
77 | if (icr0) { | ||
78 | tmp = ioread32(icr0); | ||
79 | if (irlm) | ||
80 | tmp |= 1 << 23; /* IRQ0 -> IRQ3 as individual pins */ | ||
81 | else | ||
82 | tmp &= ~(1 << 23); /* IRL mode - not supported */ | ||
83 | tmp |= (1 << 21); /* LVLMODE = 1 */ | ||
84 | iowrite32(tmp, icr0); | ||
85 | iounmap(icr0); | ||
86 | |||
87 | if (irlm) | ||
88 | platform_device_register(&irqpin0_device); | ||
89 | } else | ||
90 | pr_warn("r8a7779: unable to setup external irq pin mode\n"); | ||
91 | } | ||
92 | |||
42 | static int r8a7779_set_wake(struct irq_data *data, unsigned int on) | 93 | static int r8a7779_set_wake(struct irq_data *data, unsigned int on) |
43 | { | 94 | { |
44 | return 0; /* always allow wakeup */ | 95 | return 0; /* always allow wakeup */ |
diff --git a/arch/arm/mach-shmobile/intc-sh73a0.c b/arch/arm/mach-shmobile/intc-sh73a0.c index a81a1d804e2e..19a26f4579b3 100644 --- a/arch/arm/mach-shmobile/intc-sh73a0.c +++ b/arch/arm/mach-shmobile/intc-sh73a0.c | |||
@@ -260,108 +260,6 @@ static int sh73a0_set_wake(struct irq_data *data, unsigned int on) | |||
260 | return 0; /* always allow wakeup */ | 260 | return 0; /* always allow wakeup */ |
261 | } | 261 | } |
262 | 262 | ||
263 | #define RELOC_BASE 0x1200 | ||
264 | |||
265 | /* INTCA IRQ pins at INTCS + RELOC_BASE to make space for GIC+INTC handling */ | ||
266 | #define INTCS_VECT_RELOC(n, vect) INTCS_VECT((n), (vect) + RELOC_BASE) | ||
267 | |||
268 | INTC_IRQ_PINS_32(intca_irq_pins, 0xe6900000, | ||
269 | INTCS_VECT_RELOC, "sh73a0-intca-irq-pins"); | ||
270 | |||
271 | static int to_gic_irq(struct irq_data *data) | ||
272 | { | ||
273 | unsigned int vect = irq2evt(data->irq) - INTCS_VECT_BASE; | ||
274 | |||
275 | if (vect >= 0x3200) | ||
276 | vect -= 0x3000; | ||
277 | else | ||
278 | vect -= 0x0200; | ||
279 | |||
280 | return gic_spi((vect >> 5) + 1); | ||
281 | } | ||
282 | |||
283 | static int to_intca_reloc_irq(struct irq_data *data) | ||
284 | { | ||
285 | return data->irq + (RELOC_BASE >> 5); | ||
286 | } | ||
287 | |||
288 | #define irq_cb(cb, irq) irq_get_chip(irq)->cb(irq_get_irq_data(irq)) | ||
289 | #define irq_cbp(cb, irq, p...) irq_get_chip(irq)->cb(irq_get_irq_data(irq), p) | ||
290 | |||
291 | static void intca_gic_enable(struct irq_data *data) | ||
292 | { | ||
293 | irq_cb(irq_unmask, to_intca_reloc_irq(data)); | ||
294 | irq_cb(irq_unmask, to_gic_irq(data)); | ||
295 | } | ||
296 | |||
297 | static void intca_gic_disable(struct irq_data *data) | ||
298 | { | ||
299 | irq_cb(irq_mask, to_gic_irq(data)); | ||
300 | irq_cb(irq_mask, to_intca_reloc_irq(data)); | ||
301 | } | ||
302 | |||
303 | static void intca_gic_mask_ack(struct irq_data *data) | ||
304 | { | ||
305 | irq_cb(irq_mask, to_gic_irq(data)); | ||
306 | irq_cb(irq_mask_ack, to_intca_reloc_irq(data)); | ||
307 | } | ||
308 | |||
309 | static void intca_gic_eoi(struct irq_data *data) | ||
310 | { | ||
311 | irq_cb(irq_eoi, to_gic_irq(data)); | ||
312 | } | ||
313 | |||
314 | static int intca_gic_set_type(struct irq_data *data, unsigned int type) | ||
315 | { | ||
316 | return irq_cbp(irq_set_type, to_intca_reloc_irq(data), type); | ||
317 | } | ||
318 | |||
319 | #ifdef CONFIG_SMP | ||
320 | static int intca_gic_set_affinity(struct irq_data *data, | ||
321 | const struct cpumask *cpumask, | ||
322 | bool force) | ||
323 | { | ||
324 | return irq_cbp(irq_set_affinity, to_gic_irq(data), cpumask, force); | ||
325 | } | ||
326 | #endif | ||
327 | |||
328 | struct irq_chip intca_gic_irq_chip = { | ||
329 | .name = "INTCA-GIC", | ||
330 | .irq_mask = intca_gic_disable, | ||
331 | .irq_unmask = intca_gic_enable, | ||
332 | .irq_mask_ack = intca_gic_mask_ack, | ||
333 | .irq_eoi = intca_gic_eoi, | ||
334 | .irq_enable = intca_gic_enable, | ||
335 | .irq_disable = intca_gic_disable, | ||
336 | .irq_shutdown = intca_gic_disable, | ||
337 | .irq_set_type = intca_gic_set_type, | ||
338 | .irq_set_wake = sh73a0_set_wake, | ||
339 | #ifdef CONFIG_SMP | ||
340 | .irq_set_affinity = intca_gic_set_affinity, | ||
341 | #endif | ||
342 | }; | ||
343 | |||
344 | static int to_intc_vect(int irq) | ||
345 | { | ||
346 | unsigned int irq_pin = irq - gic_spi(1); | ||
347 | unsigned int offs; | ||
348 | |||
349 | if (irq_pin < 16) | ||
350 | offs = 0x0200; | ||
351 | else | ||
352 | offs = 0x3000; | ||
353 | |||
354 | return offs + (irq_pin << 5); | ||
355 | } | ||
356 | |||
357 | static irqreturn_t sh73a0_irq_pin_demux(int irq, void *dev_id) | ||
358 | { | ||
359 | generic_handle_irq(intcs_evt2irq(to_intc_vect(irq))); | ||
360 | return IRQ_HANDLED; | ||
361 | } | ||
362 | |||
363 | static struct irqaction sh73a0_irq_pin_cascade[32]; | ||
364 | |||
365 | #define PINTER0_PHYS 0xe69000a0 | 263 | #define PINTER0_PHYS 0xe69000a0 |
366 | #define PINTER1_PHYS 0xe69000a4 | 264 | #define PINTER1_PHYS 0xe69000a4 |
367 | #define PINTER0_VIRT IOMEM(0xe69000a0) | 265 | #define PINTER0_VIRT IOMEM(0xe69000a0) |
@@ -422,13 +320,11 @@ void __init sh73a0_init_irq(void) | |||
422 | void __iomem *gic_dist_base = IOMEM(0xf0001000); | 320 | void __iomem *gic_dist_base = IOMEM(0xf0001000); |
423 | void __iomem *gic_cpu_base = IOMEM(0xf0000100); | 321 | void __iomem *gic_cpu_base = IOMEM(0xf0000100); |
424 | void __iomem *intevtsa = ioremap_nocache(0xffd20100, PAGE_SIZE); | 322 | void __iomem *intevtsa = ioremap_nocache(0xffd20100, PAGE_SIZE); |
425 | int k, n; | ||
426 | 323 | ||
427 | gic_init(0, 29, gic_dist_base, gic_cpu_base); | 324 | gic_init(0, 29, gic_dist_base, gic_cpu_base); |
428 | gic_arch_extn.irq_set_wake = sh73a0_set_wake; | 325 | gic_arch_extn.irq_set_wake = sh73a0_set_wake; |
429 | 326 | ||
430 | register_intc_controller(&intcs_desc); | 327 | register_intc_controller(&intcs_desc); |
431 | register_intc_controller(&intca_irq_pins_desc); | ||
432 | register_intc_controller(&intc_pint0_desc); | 328 | register_intc_controller(&intc_pint0_desc); |
433 | register_intc_controller(&intc_pint1_desc); | 329 | register_intc_controller(&intc_pint1_desc); |
434 | 330 | ||
@@ -438,19 +334,6 @@ void __init sh73a0_init_irq(void) | |||
438 | sh73a0_intcs_cascade.dev_id = intevtsa; | 334 | sh73a0_intcs_cascade.dev_id = intevtsa; |
439 | setup_irq(gic_spi(50), &sh73a0_intcs_cascade); | 335 | setup_irq(gic_spi(50), &sh73a0_intcs_cascade); |
440 | 336 | ||
441 | /* IRQ pins require special handling through INTCA and GIC */ | ||
442 | for (k = 0; k < 32; k++) { | ||
443 | sh73a0_irq_pin_cascade[k].name = "INTCA-GIC cascade"; | ||
444 | sh73a0_irq_pin_cascade[k].handler = sh73a0_irq_pin_demux; | ||
445 | setup_irq(gic_spi(1 + k), &sh73a0_irq_pin_cascade[k]); | ||
446 | |||
447 | n = intcs_evt2irq(to_intc_vect(gic_spi(1 + k))); | ||
448 | WARN_ON(irq_alloc_desc_at(n, numa_node_id()) != n); | ||
449 | irq_set_chip_and_handler_name(n, &intca_gic_irq_chip, | ||
450 | handle_level_irq, "level"); | ||
451 | set_irq_flags(n, IRQF_VALID); /* yuck */ | ||
452 | } | ||
453 | |||
454 | /* PINT pins are sanely tied to the GIC as SPI */ | 337 | /* PINT pins are sanely tied to the GIC as SPI */ |
455 | sh73a0_pint0_cascade.name = "PINT0 cascade"; | 338 | sh73a0_pint0_cascade.name = "PINT0 cascade"; |
456 | sh73a0_pint0_cascade.handler = sh73a0_pint0_demux; | 339 | sh73a0_pint0_cascade.handler = sh73a0_pint0_demux; |
diff --git a/arch/arm/mach-shmobile/setup-sh73a0.c b/arch/arm/mach-shmobile/setup-sh73a0.c index 2257a915746d..e8cd93a5c550 100644 --- a/arch/arm/mach-shmobile/setup-sh73a0.c +++ b/arch/arm/mach-shmobile/setup-sh73a0.c | |||
@@ -33,6 +33,7 @@ | |||
33 | #include <linux/sh_intc.h> | 33 | #include <linux/sh_intc.h> |
34 | #include <linux/sh_timer.h> | 34 | #include <linux/sh_timer.h> |
35 | #include <linux/platform_data/sh_ipmmu.h> | 35 | #include <linux/platform_data/sh_ipmmu.h> |
36 | #include <linux/platform_data/irq-renesas-intc-irqpin.h> | ||
36 | #include <mach/dma-register.h> | 37 | #include <mach/dma-register.h> |
37 | #include <mach/hardware.h> | 38 | #include <mach/hardware.h> |
38 | #include <mach/irqs.h> | 39 | #include <mach/irqs.h> |
@@ -811,6 +812,127 @@ static struct platform_device ipmmu_device = { | |||
811 | .num_resources = ARRAY_SIZE(ipmmu_resources), | 812 | .num_resources = ARRAY_SIZE(ipmmu_resources), |
812 | }; | 813 | }; |
813 | 814 | ||
815 | static struct renesas_intc_irqpin_config irqpin0_platform_data = { | ||
816 | .irq_base = irq_pin(0), /* IRQ0 -> IRQ7 */ | ||
817 | }; | ||
818 | |||
819 | static struct resource irqpin0_resources[] = { | ||
820 | DEFINE_RES_MEM(0xe6900000, 4), /* ICR1A */ | ||
821 | DEFINE_RES_MEM(0xe6900010, 4), /* INTPRI00A */ | ||
822 | DEFINE_RES_MEM(0xe6900020, 1), /* INTREQ00A */ | ||
823 | DEFINE_RES_MEM(0xe6900040, 1), /* INTMSK00A */ | ||
824 | DEFINE_RES_MEM(0xe6900060, 1), /* INTMSKCLR00A */ | ||
825 | DEFINE_RES_IRQ(gic_spi(1)), /* IRQ0 */ | ||
826 | DEFINE_RES_IRQ(gic_spi(2)), /* IRQ1 */ | ||
827 | DEFINE_RES_IRQ(gic_spi(3)), /* IRQ2 */ | ||
828 | DEFINE_RES_IRQ(gic_spi(4)), /* IRQ3 */ | ||
829 | DEFINE_RES_IRQ(gic_spi(5)), /* IRQ4 */ | ||
830 | DEFINE_RES_IRQ(gic_spi(6)), /* IRQ5 */ | ||
831 | DEFINE_RES_IRQ(gic_spi(7)), /* IRQ6 */ | ||
832 | DEFINE_RES_IRQ(gic_spi(8)), /* IRQ7 */ | ||
833 | }; | ||
834 | |||
835 | static struct platform_device irqpin0_device = { | ||
836 | .name = "renesas_intc_irqpin", | ||
837 | .id = 0, | ||
838 | .resource = irqpin0_resources, | ||
839 | .num_resources = ARRAY_SIZE(irqpin0_resources), | ||
840 | .dev = { | ||
841 | .platform_data = &irqpin0_platform_data, | ||
842 | }, | ||
843 | }; | ||
844 | |||
845 | static struct renesas_intc_irqpin_config irqpin1_platform_data = { | ||
846 | .irq_base = irq_pin(8), /* IRQ8 -> IRQ15 */ | ||
847 | .control_parent = true, /* Disable spurious IRQ10 */ | ||
848 | }; | ||
849 | |||
850 | static struct resource irqpin1_resources[] = { | ||
851 | DEFINE_RES_MEM(0xe6900004, 4), /* ICR2A */ | ||
852 | DEFINE_RES_MEM(0xe6900014, 4), /* INTPRI10A */ | ||
853 | DEFINE_RES_MEM(0xe6900024, 1), /* INTREQ10A */ | ||
854 | DEFINE_RES_MEM(0xe6900044, 1), /* INTMSK10A */ | ||
855 | DEFINE_RES_MEM(0xe6900064, 1), /* INTMSKCLR10A */ | ||
856 | DEFINE_RES_IRQ(gic_spi(9)), /* IRQ8 */ | ||
857 | DEFINE_RES_IRQ(gic_spi(10)), /* IRQ9 */ | ||
858 | DEFINE_RES_IRQ(gic_spi(11)), /* IRQ10 */ | ||
859 | DEFINE_RES_IRQ(gic_spi(12)), /* IRQ11 */ | ||
860 | DEFINE_RES_IRQ(gic_spi(13)), /* IRQ12 */ | ||
861 | DEFINE_RES_IRQ(gic_spi(14)), /* IRQ13 */ | ||
862 | DEFINE_RES_IRQ(gic_spi(15)), /* IRQ14 */ | ||
863 | DEFINE_RES_IRQ(gic_spi(16)), /* IRQ15 */ | ||
864 | }; | ||
865 | |||
866 | static struct platform_device irqpin1_device = { | ||
867 | .name = "renesas_intc_irqpin", | ||
868 | .id = 1, | ||
869 | .resource = irqpin1_resources, | ||
870 | .num_resources = ARRAY_SIZE(irqpin1_resources), | ||
871 | .dev = { | ||
872 | .platform_data = &irqpin1_platform_data, | ||
873 | }, | ||
874 | }; | ||
875 | |||
876 | static struct renesas_intc_irqpin_config irqpin2_platform_data = { | ||
877 | .irq_base = irq_pin(16), /* IRQ16 -> IRQ23 */ | ||
878 | }; | ||
879 | |||
880 | static struct resource irqpin2_resources[] = { | ||
881 | DEFINE_RES_MEM(0xe6900008, 4), /* ICR3A */ | ||
882 | DEFINE_RES_MEM(0xe6900018, 4), /* INTPRI20A */ | ||
883 | DEFINE_RES_MEM(0xe6900028, 1), /* INTREQ20A */ | ||
884 | DEFINE_RES_MEM(0xe6900048, 1), /* INTMSK20A */ | ||
885 | DEFINE_RES_MEM(0xe6900068, 1), /* INTMSKCLR20A */ | ||
886 | DEFINE_RES_IRQ(gic_spi(17)), /* IRQ16 */ | ||
887 | DEFINE_RES_IRQ(gic_spi(18)), /* IRQ17 */ | ||
888 | DEFINE_RES_IRQ(gic_spi(19)), /* IRQ18 */ | ||
889 | DEFINE_RES_IRQ(gic_spi(20)), /* IRQ19 */ | ||
890 | DEFINE_RES_IRQ(gic_spi(21)), /* IRQ20 */ | ||
891 | DEFINE_RES_IRQ(gic_spi(22)), /* IRQ21 */ | ||
892 | DEFINE_RES_IRQ(gic_spi(23)), /* IRQ22 */ | ||
893 | DEFINE_RES_IRQ(gic_spi(24)), /* IRQ23 */ | ||
894 | }; | ||
895 | |||
896 | static struct platform_device irqpin2_device = { | ||
897 | .name = "renesas_intc_irqpin", | ||
898 | .id = 2, | ||
899 | .resource = irqpin2_resources, | ||
900 | .num_resources = ARRAY_SIZE(irqpin2_resources), | ||
901 | .dev = { | ||
902 | .platform_data = &irqpin2_platform_data, | ||
903 | }, | ||
904 | }; | ||
905 | |||
906 | static struct renesas_intc_irqpin_config irqpin3_platform_data = { | ||
907 | .irq_base = irq_pin(24), /* IRQ24 -> IRQ31 */ | ||
908 | }; | ||
909 | |||
910 | static struct resource irqpin3_resources[] = { | ||
911 | DEFINE_RES_MEM(0xe690000c, 4), /* ICR4A */ | ||
912 | DEFINE_RES_MEM(0xe690001c, 4), /* INTPRI30A */ | ||
913 | DEFINE_RES_MEM(0xe690002c, 1), /* INTREQ30A */ | ||
914 | DEFINE_RES_MEM(0xe690004c, 1), /* INTMSK30A */ | ||
915 | DEFINE_RES_MEM(0xe690006c, 1), /* INTMSKCLR30A */ | ||
916 | DEFINE_RES_IRQ(gic_spi(25)), /* IRQ24 */ | ||
917 | DEFINE_RES_IRQ(gic_spi(26)), /* IRQ25 */ | ||
918 | DEFINE_RES_IRQ(gic_spi(27)), /* IRQ26 */ | ||
919 | DEFINE_RES_IRQ(gic_spi(28)), /* IRQ27 */ | ||
920 | DEFINE_RES_IRQ(gic_spi(29)), /* IRQ28 */ | ||
921 | DEFINE_RES_IRQ(gic_spi(30)), /* IRQ29 */ | ||
922 | DEFINE_RES_IRQ(gic_spi(31)), /* IRQ30 */ | ||
923 | DEFINE_RES_IRQ(gic_spi(32)), /* IRQ31 */ | ||
924 | }; | ||
925 | |||
926 | static struct platform_device irqpin3_device = { | ||
927 | .name = "renesas_intc_irqpin", | ||
928 | .id = 3, | ||
929 | .resource = irqpin3_resources, | ||
930 | .num_resources = ARRAY_SIZE(irqpin3_resources), | ||
931 | .dev = { | ||
932 | .platform_data = &irqpin3_platform_data, | ||
933 | }, | ||
934 | }; | ||
935 | |||
814 | static struct platform_device *sh73a0_devices_dt[] __initdata = { | 936 | static struct platform_device *sh73a0_devices_dt[] __initdata = { |
815 | &scif0_device, | 937 | &scif0_device, |
816 | &scif1_device, | 938 | &scif1_device, |
@@ -839,6 +961,10 @@ static struct platform_device *sh73a0_late_devices[] __initdata = { | |||
839 | &dma0_device, | 961 | &dma0_device, |
840 | &mpdma0_device, | 962 | &mpdma0_device, |
841 | &pmu_device, | 963 | &pmu_device, |
964 | &irqpin0_device, | ||
965 | &irqpin1_device, | ||
966 | &irqpin2_device, | ||
967 | &irqpin3_device, | ||
842 | }; | 968 | }; |
843 | 969 | ||
844 | #define SRCR2 IOMEM(0xe61580b0) | 970 | #define SRCR2 IOMEM(0xe61580b0) |
diff --git a/arch/arm/mach-tegra/tegra.c b/arch/arm/mach-tegra/tegra.c index 9cf1ab17afeb..0d1e4128d460 100644 --- a/arch/arm/mach-tegra/tegra.c +++ b/arch/arm/mach-tegra/tegra.c | |||
@@ -34,6 +34,7 @@ | |||
34 | #include <linux/slab.h> | 34 | #include <linux/slab.h> |
35 | #include <linux/sys_soc.h> | 35 | #include <linux/sys_soc.h> |
36 | #include <linux/usb/tegra_usb_phy.h> | 36 | #include <linux/usb/tegra_usb_phy.h> |
37 | #include <linux/clk/tegra.h> | ||
37 | 38 | ||
38 | #include <asm/mach-types.h> | 39 | #include <asm/mach-types.h> |
39 | #include <asm/mach/arch.h> | 40 | #include <asm/mach/arch.h> |
@@ -85,6 +86,8 @@ static void __init tegra_dt_init(void) | |||
85 | struct soc_device *soc_dev; | 86 | struct soc_device *soc_dev; |
86 | struct device *parent = NULL; | 87 | struct device *parent = NULL; |
87 | 88 | ||
89 | tegra_clocks_apply_init_table(); | ||
90 | |||
88 | soc_dev_attr = kzalloc(sizeof(*soc_dev_attr), GFP_KERNEL); | 91 | soc_dev_attr = kzalloc(sizeof(*soc_dev_attr), GFP_KERNEL); |
89 | if (!soc_dev_attr) | 92 | if (!soc_dev_attr) |
90 | goto out; | 93 | goto out; |
diff --git a/arch/arm/mach-ux500/board-mop500-pins.c b/arch/arm/mach-ux500/board-mop500-pins.c index f3976f9c404a..947bd9eca079 100644 --- a/arch/arm/mach-ux500/board-mop500-pins.c +++ b/arch/arm/mach-ux500/board-mop500-pins.c | |||
@@ -46,8 +46,12 @@ BIAS(slpm_in_nopull_wkup, PIN_SLEEPMODE_ENABLED| | |||
46 | PIN_SLPM_DIR_INPUT|PIN_SLPM_PULL_NONE|PIN_SLPM_WAKEUP_ENABLE); | 46 | PIN_SLPM_DIR_INPUT|PIN_SLPM_PULL_NONE|PIN_SLPM_WAKEUP_ENABLE); |
47 | BIAS(slpm_in_wkup_pdis, PIN_SLEEPMODE_ENABLED| | 47 | BIAS(slpm_in_wkup_pdis, PIN_SLEEPMODE_ENABLED| |
48 | PIN_SLPM_DIR_INPUT|PIN_SLPM_WAKEUP_ENABLE|PIN_SLPM_PDIS_DISABLED); | 48 | PIN_SLPM_DIR_INPUT|PIN_SLPM_WAKEUP_ENABLE|PIN_SLPM_PDIS_DISABLED); |
49 | BIAS(slpm_in_wkup_pdis_en, PIN_SLEEPMODE_ENABLED| | ||
50 | PIN_SLPM_DIR_INPUT|PIN_SLPM_WAKEUP_ENABLE|PIN_SLPM_PDIS_ENABLED); | ||
49 | BIAS(slpm_wkup_pdis, PIN_SLEEPMODE_ENABLED| | 51 | BIAS(slpm_wkup_pdis, PIN_SLEEPMODE_ENABLED| |
50 | PIN_SLPM_WAKEUP_ENABLE|PIN_SLPM_PDIS_DISABLED); | 52 | PIN_SLPM_WAKEUP_ENABLE|PIN_SLPM_PDIS_DISABLED); |
53 | BIAS(slpm_wkup_pdis_en, PIN_SLEEPMODE_ENABLED| | ||
54 | PIN_SLPM_WAKEUP_ENABLE|PIN_SLPM_PDIS_ENABLED); | ||
51 | BIAS(slpm_out_lo_pdis, PIN_SLEEPMODE_ENABLED| | 55 | BIAS(slpm_out_lo_pdis, PIN_SLEEPMODE_ENABLED| |
52 | PIN_SLPM_OUTPUT_LOW|PIN_SLPM_WAKEUP_DISABLE|PIN_SLPM_PDIS_DISABLED); | 56 | PIN_SLPM_OUTPUT_LOW|PIN_SLPM_WAKEUP_DISABLE|PIN_SLPM_PDIS_DISABLED); |
53 | BIAS(slpm_out_lo_wkup, PIN_SLEEPMODE_ENABLED| | 57 | BIAS(slpm_out_lo_wkup, PIN_SLEEPMODE_ENABLED| |
@@ -76,9 +80,6 @@ BIAS(out_wkup_pdis, PIN_SLPM_DIR_OUTPUT|PIN_SLPM_WAKEUP_ENABLE| | |||
76 | PIN_MAP_MUX_GROUP_HOG_DEFAULT("pinctrl-db8500", group, func) | 80 | PIN_MAP_MUX_GROUP_HOG_DEFAULT("pinctrl-db8500", group, func) |
77 | #define DB8500_PIN_HOG(pin,conf) \ | 81 | #define DB8500_PIN_HOG(pin,conf) \ |
78 | PIN_MAP_CONFIGS_PIN_HOG_DEFAULT("pinctrl-db8500", pin, conf) | 82 | PIN_MAP_CONFIGS_PIN_HOG_DEFAULT("pinctrl-db8500", pin, conf) |
79 | #define DB8500_PIN_SLEEP(pin, conf, dev) \ | ||
80 | PIN_MAP_CONFIGS_PIN(dev, PINCTRL_STATE_SLEEP, "pinctrl-db8500", \ | ||
81 | pin, conf) | ||
82 | 83 | ||
83 | /* These are default states associated with device and changed runtime */ | 84 | /* These are default states associated with device and changed runtime */ |
84 | #define DB8500_MUX(group,func,dev) \ | 85 | #define DB8500_MUX(group,func,dev) \ |
@@ -307,8 +308,23 @@ static struct pinctrl_map __initdata mop500_family_pinmap[] = { | |||
307 | DB8500_PIN_SLEEP("GPIO207_AJ23", slpm_in_wkup_pdis, "sdi4"), /* DAT4 */ | 308 | DB8500_PIN_SLEEP("GPIO207_AJ23", slpm_in_wkup_pdis, "sdi4"), /* DAT4 */ |
308 | 309 | ||
309 | /* Mux in USB pins, drive STP high */ | 310 | /* Mux in USB pins, drive STP high */ |
310 | DB8500_MUX("usb_a_1", "usb", "musb-ux500.0"), | 311 | /* USB default state */ |
311 | DB8500_PIN("GPIO257_AE29", out_hi, "musb-ux500.0"), /* STP */ | 312 | DB8500_MUX("usb_a_1", "usb", "ab8500-usb.0"), |
313 | DB8500_PIN("GPIO257_AE29", out_hi, "ab8500-usb.0"), /* STP */ | ||
314 | /* USB sleep state */ | ||
315 | DB8500_PIN_SLEEP("GPIO256_AF28", slpm_wkup_pdis_en, "ab8500-usb.0"), /* NXT */ | ||
316 | DB8500_PIN_SLEEP("GPIO257_AE29", slpm_out_hi_wkup_pdis, "ab8500-usb.0"), /* STP */ | ||
317 | DB8500_PIN_SLEEP("GPIO258_AD29", slpm_wkup_pdis_en, "ab8500-usb.0"), /* XCLK */ | ||
318 | DB8500_PIN_SLEEP("GPIO259_AC29", slpm_wkup_pdis_en, "ab8500-usb.0"), /* DIR */ | ||
319 | DB8500_PIN_SLEEP("GPIO260_AD28", slpm_in_wkup_pdis_en, "ab8500-usb.0"), /* DAT7 */ | ||
320 | DB8500_PIN_SLEEP("GPIO261_AD26", slpm_in_wkup_pdis_en, "ab8500-usb.0"), /* DAT6 */ | ||
321 | DB8500_PIN_SLEEP("GPIO262_AE26", slpm_in_wkup_pdis_en, "ab8500-usb.0"), /* DAT5 */ | ||
322 | DB8500_PIN_SLEEP("GPIO263_AG29", slpm_in_wkup_pdis_en, "ab8500-usb.0"), /* DAT4 */ | ||
323 | DB8500_PIN_SLEEP("GPIO264_AE27", slpm_in_wkup_pdis_en, "ab8500-usb.0"), /* DAT3 */ | ||
324 | DB8500_PIN_SLEEP("GPIO265_AD27", slpm_in_wkup_pdis_en, "ab8500-usb.0"), /* DAT2 */ | ||
325 | DB8500_PIN_SLEEP("GPIO266_AC28", slpm_in_wkup_pdis_en, "ab8500-usb.0"), /* DAT1 */ | ||
326 | DB8500_PIN_SLEEP("GPIO267_AC27", slpm_in_wkup_pdis_en, "ab8500-usb.0"), /* DAT0 */ | ||
327 | |||
312 | /* Mux in SPI2 pins on the "other C1" altfunction */ | 328 | /* Mux in SPI2 pins on the "other C1" altfunction */ |
313 | DB8500_MUX("spi2_oc1_2", "spi2", "spi2"), | 329 | DB8500_MUX("spi2_oc1_2", "spi2", "spi2"), |
314 | DB8500_PIN("GPIO216_AG12", gpio_out_hi, "spi2"), /* FRM */ | 330 | DB8500_PIN("GPIO216_AG12", gpio_out_hi, "spi2"), /* FRM */ |
@@ -316,9 +332,9 @@ static struct pinctrl_map __initdata mop500_family_pinmap[] = { | |||
316 | DB8500_PIN("GPIO215_AH13", out_lo, "spi2"), /* TXD */ | 332 | DB8500_PIN("GPIO215_AH13", out_lo, "spi2"), /* TXD */ |
317 | DB8500_PIN("GPIO217_AH12", out_lo, "spi2"), /* CLK */ | 333 | DB8500_PIN("GPIO217_AH12", out_lo, "spi2"), /* CLK */ |
318 | /* SPI2 idle state */ | 334 | /* SPI2 idle state */ |
319 | DB8500_PIN_SLEEP("GPIO218_AH11", slpm_in_wkup_pdis, "spi2"), /* RXD */ | 335 | DB8500_PIN_IDLE("GPIO218_AH11", slpm_in_wkup_pdis, "spi2"), /* RXD */ |
320 | DB8500_PIN_SLEEP("GPIO215_AH13", slpm_out_lo_wkup_pdis, "spi2"), /* TXD */ | 336 | DB8500_PIN_IDLE("GPIO215_AH13", slpm_out_lo_wkup_pdis, "spi2"), /* TXD */ |
321 | DB8500_PIN_SLEEP("GPIO217_AH12", slpm_wkup_pdis, "spi2"), /* CLK */ | 337 | DB8500_PIN_IDLE("GPIO217_AH12", slpm_wkup_pdis, "spi2"), /* CLK */ |
322 | /* SPI2 sleep state */ | 338 | /* SPI2 sleep state */ |
323 | DB8500_PIN_SLEEP("GPIO216_AG12", slpm_in_wkup_pdis, "spi2"), /* FRM */ | 339 | DB8500_PIN_SLEEP("GPIO216_AG12", slpm_in_wkup_pdis, "spi2"), /* FRM */ |
324 | DB8500_PIN_SLEEP("GPIO218_AH11", slpm_in_wkup_pdis, "spi2"), /* RXD */ | 340 | DB8500_PIN_SLEEP("GPIO218_AH11", slpm_in_wkup_pdis, "spi2"), /* RXD */ |
@@ -745,6 +761,8 @@ static struct pinctrl_map __initdata snowball_pinmap[] = { | |||
745 | DB8500_PIN_HOG("GPIO21_AB3", out_hi), | 761 | DB8500_PIN_HOG("GPIO21_AB3", out_hi), |
746 | /* Mux in "SM" which is used for the SMSC911x Ethernet adapter */ | 762 | /* Mux in "SM" which is used for the SMSC911x Ethernet adapter */ |
747 | DB8500_MUX_HOG("sm_b_1", "sm"), | 763 | DB8500_MUX_HOG("sm_b_1", "sm"), |
764 | /* User LED */ | ||
765 | DB8500_PIN_HOG("GPIO142_C11", gpio_out_hi), | ||
748 | /* Drive RSTn_LAN high */ | 766 | /* Drive RSTn_LAN high */ |
749 | DB8500_PIN_HOG("GPIO141_C12", gpio_out_hi), | 767 | DB8500_PIN_HOG("GPIO141_C12", gpio_out_hi), |
750 | /* Accelerometer/Magnetometer */ | 768 | /* Accelerometer/Magnetometer */ |
diff --git a/arch/arm/mach-vt8500/Kconfig b/arch/arm/mach-vt8500/Kconfig index e3e94b2fa145..9b252934b206 100644 --- a/arch/arm/mach-vt8500/Kconfig +++ b/arch/arm/mach-vt8500/Kconfig | |||
@@ -7,6 +7,7 @@ config ARCH_VT8500 | |||
7 | select GENERIC_CLOCKEVENTS | 7 | select GENERIC_CLOCKEVENTS |
8 | select HAVE_CLK | 8 | select HAVE_CLK |
9 | select VT8500_TIMER | 9 | select VT8500_TIMER |
10 | select PINCTRL | ||
10 | help | 11 | help |
11 | Support for VIA/WonderMedia VT8500/WM85xx System-on-Chip. | 12 | Support for VIA/WonderMedia VT8500/WM85xx System-on-Chip. |
12 | 13 | ||
diff --git a/arch/arm/mach-vt8500/Makefile b/arch/arm/mach-vt8500/Makefile index 92ceb2436b60..4c8a84637594 100644 --- a/arch/arm/mach-vt8500/Makefile +++ b/arch/arm/mach-vt8500/Makefile | |||
@@ -1 +1 @@ | |||
obj-$(CONFIG_ARCH_VT8500) += irq.o vt8500.o | obj-$(CONFIG_ARCH_VT8500) += vt8500.o | ||
diff --git a/arch/arm/mach-vt8500/common.h b/arch/arm/mach-vt8500/common.h index 77611a6968d6..087787af62f1 100644 --- a/arch/arm/mach-vt8500/common.h +++ b/arch/arm/mach-vt8500/common.h | |||
@@ -18,13 +18,7 @@ | |||
18 | 18 | ||
19 | #include <linux/of.h> | 19 | #include <linux/of.h> |
20 | 20 | ||
21 | int __init vt8500_irq_init(struct device_node *node, | ||
22 | struct device_node *parent); | ||
23 | |||
24 | /* defined in drivers/clk/clk-vt8500.c */ | 21 | /* defined in drivers/clk/clk-vt8500.c */ |
25 | void __init vtwm_clk_init(void __iomem *pmc_base); | 22 | void __init vtwm_clk_init(void __iomem *pmc_base); |
26 | 23 | ||
27 | /* defined in irq.c */ | ||
28 | asmlinkage void vt8500_handle_irq(struct pt_regs *regs); | ||
29 | |||
30 | #endif | 24 | #endif |
diff --git a/arch/arm/mach-vt8500/irq.c b/arch/arm/mach-vt8500/irq.c deleted file mode 100644 index b9cf5ce9efbb..000000000000 --- a/arch/arm/mach-vt8500/irq.c +++ /dev/null | |||
@@ -1,253 +0,0 @@ | |||
1 | /* | ||
2 | * arch/arm/mach-vt8500/irq.c | ||
3 | * | ||
4 | * Copyright (C) 2012 Tony Prisk <linux@prisktech.co.nz> | ||
5 | * Copyright (C) 2010 Alexey Charkov <alchark@gmail.com> | ||
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 as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | |||
22 | /* | ||
23 | * This file is copied and modified from the original irq.c provided by | ||
24 | * Alexey Charkov. Minor changes have been made for Device Tree Support. | ||
25 | */ | ||
26 | |||
27 | #include <linux/slab.h> | ||
28 | #include <linux/io.h> | ||
29 | #include <linux/irq.h> | ||
30 | #include <linux/irqdomain.h> | ||
31 | #include <linux/interrupt.h> | ||
32 | #include <linux/bitops.h> | ||
33 | |||
34 | #include <linux/of.h> | ||
35 | #include <linux/of_irq.h> | ||
36 | #include <linux/of_address.h> | ||
37 | |||
38 | #include <asm/irq.h> | ||
39 | #include <asm/exception.h> | ||
40 | |||
41 | #define VT8500_ICPC_IRQ 0x20 | ||
42 | #define VT8500_ICPC_FIQ 0x24 | ||
43 | #define VT8500_ICDC 0x40 /* Destination Control 64*u32 */ | ||
44 | #define VT8500_ICIS 0x80 /* Interrupt status, 16*u32 */ | ||
45 | |||
46 | /* ICPC */ | ||
47 | #define ICPC_MASK 0x3F | ||
48 | #define ICPC_ROTATE BIT(6) | ||
49 | |||
50 | /* IC_DCTR */ | ||
51 | #define ICDC_IRQ 0x00 | ||
52 | #define ICDC_FIQ 0x01 | ||
53 | #define ICDC_DSS0 0x02 | ||
54 | #define ICDC_DSS1 0x03 | ||
55 | #define ICDC_DSS2 0x04 | ||
56 | #define ICDC_DSS3 0x05 | ||
57 | #define ICDC_DSS4 0x06 | ||
58 | #define ICDC_DSS5 0x07 | ||
59 | |||
60 | #define VT8500_INT_DISABLE 0 | ||
61 | #define VT8500_INT_ENABLE BIT(3) | ||
62 | |||
63 | #define VT8500_TRIGGER_HIGH 0 | ||
64 | #define VT8500_TRIGGER_RISING BIT(5) | ||
65 | #define VT8500_TRIGGER_FALLING BIT(6) | ||
66 | #define VT8500_EDGE ( VT8500_TRIGGER_RISING \ | ||
67 | | VT8500_TRIGGER_FALLING) | ||
68 | |||
69 | /* vt8500 has 1 intc, wm8505 and wm8650 have 2 */ | ||
70 | #define VT8500_INTC_MAX 2 | ||
71 | |||
72 | struct vt8500_irq_data { | ||
73 | void __iomem *base; /* IO Memory base address */ | ||
74 | struct irq_domain *domain; /* Domain for this controller */ | ||
75 | }; | ||
76 | |||
77 | /* Global variable for accessing io-mem addresses */ | ||
78 | static struct vt8500_irq_data intc[VT8500_INTC_MAX]; | ||
79 | static u32 active_cnt = 0; | ||
80 | |||
81 | static void vt8500_irq_mask(struct irq_data *d) | ||
82 | { | ||
83 | struct vt8500_irq_data *priv = d->domain->host_data; | ||
84 | void __iomem *base = priv->base; | ||
85 | void __iomem *stat_reg = base + VT8500_ICIS + (d->hwirq < 32 ? 0 : 4); | ||
86 | u8 edge, dctr; | ||
87 | u32 status; | ||
88 | |||
89 | edge = readb(base + VT8500_ICDC + d->hwirq) & VT8500_EDGE; | ||
90 | if (edge) { | ||
91 | status = readl(stat_reg); | ||
92 | |||
93 | status |= (1 << (d->hwirq & 0x1f)); | ||
94 | writel(status, stat_reg); | ||
95 | } else { | ||
96 | dctr = readb(base + VT8500_ICDC + d->hwirq); | ||
97 | dctr &= ~VT8500_INT_ENABLE; | ||
98 | writeb(dctr, base + VT8500_ICDC + d->hwirq); | ||
99 | } | ||
100 | } | ||
101 | |||
102 | static void vt8500_irq_unmask(struct irq_data *d) | ||
103 | { | ||
104 | struct vt8500_irq_data *priv = d->domain->host_data; | ||
105 | void __iomem *base = priv->base; | ||
106 | u8 dctr; | ||
107 | |||
108 | dctr = readb(base + VT8500_ICDC + d->hwirq); | ||
109 | dctr |= VT8500_INT_ENABLE; | ||
110 | writeb(dctr, base + VT8500_ICDC + d->hwirq); | ||
111 | } | ||
112 | |||
113 | static int vt8500_irq_set_type(struct irq_data *d, unsigned int flow_type) | ||
114 | { | ||
115 | struct vt8500_irq_data *priv = d->domain->host_data; | ||
116 | void __iomem *base = priv->base; | ||
117 | u8 dctr; | ||
118 | |||
119 | dctr = readb(base + VT8500_ICDC + d->hwirq); | ||
120 | dctr &= ~VT8500_EDGE; | ||
121 | |||
122 | switch (flow_type) { | ||
123 | case IRQF_TRIGGER_LOW: | ||
124 | return -EINVAL; | ||
125 | case IRQF_TRIGGER_HIGH: | ||
126 | dctr |= VT8500_TRIGGER_HIGH; | ||
127 | __irq_set_handler_locked(d->irq, handle_level_irq); | ||
128 | break; | ||
129 | case IRQF_TRIGGER_FALLING: | ||
130 | dctr |= VT8500_TRIGGER_FALLING; | ||
131 | __irq_set_handler_locked(d->irq, handle_edge_irq); | ||
132 | break; | ||
133 | case IRQF_TRIGGER_RISING: | ||
134 | dctr |= VT8500_TRIGGER_RISING; | ||
135 | __irq_set_handler_locked(d->irq, handle_edge_irq); | ||
136 | break; | ||
137 | } | ||
138 | writeb(dctr, base + VT8500_ICDC + d->hwirq); | ||
139 | |||
140 | return 0; | ||
141 | } | ||
142 | |||
143 | static struct irq_chip vt8500_irq_chip = { | ||
144 | .name = "vt8500", | ||
145 | .irq_ack = vt8500_irq_mask, | ||
146 | .irq_mask = vt8500_irq_mask, | ||
147 | .irq_unmask = vt8500_irq_unmask, | ||
148 | .irq_set_type = vt8500_irq_set_type, | ||
149 | }; | ||
150 | |||
151 | static void __init vt8500_init_irq_hw(void __iomem *base) | ||
152 | { | ||
153 | u32 i; | ||
154 | |||
155 | /* Enable rotating priority for IRQ */ | ||
156 | writel(ICPC_ROTATE, base + VT8500_ICPC_IRQ); | ||
157 | writel(0x00, base + VT8500_ICPC_FIQ); | ||
158 | |||
159 | /* Disable all interrupts and route them to IRQ */ | ||
160 | for (i = 0; i < 64; i++) | ||
161 | writeb(VT8500_INT_DISABLE | ICDC_IRQ, base + VT8500_ICDC + i); | ||
162 | } | ||
163 | |||
164 | static int vt8500_irq_map(struct irq_domain *h, unsigned int virq, | ||
165 | irq_hw_number_t hw) | ||
166 | { | ||
167 | irq_set_chip_and_handler(virq, &vt8500_irq_chip, handle_level_irq); | ||
168 | set_irq_flags(virq, IRQF_VALID); | ||
169 | |||
170 | return 0; | ||
171 | } | ||
172 | |||
173 | static struct irq_domain_ops vt8500_irq_domain_ops = { | ||
174 | .map = vt8500_irq_map, | ||
175 | .xlate = irq_domain_xlate_onecell, | ||
176 | }; | ||
177 | |||
178 | asmlinkage void __exception_irq_entry vt8500_handle_irq(struct pt_regs *regs) | ||
179 | { | ||
180 | u32 stat, i; | ||
181 | int irqnr, virq; | ||
182 | void __iomem *base; | ||
183 | |||
184 | /* Loop through each active controller */ | ||
185 | for (i=0; i<active_cnt; i++) { | ||
186 | base = intc[i].base; | ||
187 | irqnr = readl_relaxed(base) & 0x3F; | ||
188 | /* | ||
189 | Highest Priority register default = 63, so check that this | ||
190 | is a real interrupt by checking the status register | ||
191 | */ | ||
192 | if (irqnr == 63) { | ||
193 | stat = readl_relaxed(base + VT8500_ICIS + 4); | ||
194 | if (!(stat & BIT(31))) | ||
195 | continue; | ||
196 | } | ||
197 | |||
198 | virq = irq_find_mapping(intc[i].domain, irqnr); | ||
199 | handle_IRQ(virq, regs); | ||
200 | } | ||
201 | } | ||
202 | |||
203 | int __init vt8500_irq_init(struct device_node *node, struct device_node *parent) | ||
204 | { | ||
205 | int irq, i; | ||
206 | struct device_node *np = node; | ||
207 | |||
208 | if (active_cnt == VT8500_INTC_MAX) { | ||
209 | pr_err("%s: Interrupt controllers > VT8500_INTC_MAX\n", | ||
210 | __func__); | ||
211 | goto out; | ||
212 | } | ||
213 | |||
214 | intc[active_cnt].base = of_iomap(np, 0); | ||
215 | intc[active_cnt].domain = irq_domain_add_linear(node, 64, | ||
216 | &vt8500_irq_domain_ops, &intc[active_cnt]); | ||
217 | |||
218 | if (!intc[active_cnt].base) { | ||
219 | pr_err("%s: Unable to map IO memory\n", __func__); | ||
220 | goto out; | ||
221 | } | ||
222 | |||
223 | if (!intc[active_cnt].domain) { | ||
224 | pr_err("%s: Unable to add irq domain!\n", __func__); | ||
225 | goto out; | ||
226 | } | ||
227 | |||
228 | vt8500_init_irq_hw(intc[active_cnt].base); | ||
229 | |||
230 | pr_info("vt8500-irq: Added interrupt controller\n"); | ||
231 | |||
232 | active_cnt++; | ||
233 | |||
234 | /* check if this is a slaved controller */ | ||
235 | if (of_irq_count(np) != 0) { | ||
236 | /* check that we have the correct number of interrupts */ | ||
237 | if (of_irq_count(np) != 8) { | ||
238 | pr_err("%s: Incorrect IRQ map for slaved controller\n", | ||
239 | __func__); | ||
240 | return -EINVAL; | ||
241 | } | ||
242 | |||
243 | for (i = 0; i < 8; i++) { | ||
244 | irq = irq_of_parse_and_map(np, i); | ||
245 | enable_irq(irq); | ||
246 | } | ||
247 | |||
248 | pr_info("vt8500-irq: Enabled slave->parent interrupts\n"); | ||
249 | } | ||
250 | out: | ||
251 | return 0; | ||
252 | } | ||
253 | |||
diff --git a/arch/arm/mach-vt8500/vt8500.c b/arch/arm/mach-vt8500/vt8500.c index 49e80053d828..1dd281efc020 100644 --- a/arch/arm/mach-vt8500/vt8500.c +++ b/arch/arm/mach-vt8500/vt8500.c | |||
@@ -20,6 +20,7 @@ | |||
20 | 20 | ||
21 | #include <linux/clocksource.h> | 21 | #include <linux/clocksource.h> |
22 | #include <linux/io.h> | 22 | #include <linux/io.h> |
23 | #include <linux/irqchip.h> | ||
23 | #include <linux/pm.h> | 24 | #include <linux/pm.h> |
24 | 25 | ||
25 | #include <asm/mach-types.h> | 26 | #include <asm/mach-types.h> |
@@ -166,16 +167,6 @@ void __init vt8500_init(void) | |||
166 | of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL); | 167 | of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL); |
167 | } | 168 | } |
168 | 169 | ||
169 | static const struct of_device_id vt8500_irq_match[] __initconst = { | ||
170 | { .compatible = "via,vt8500-intc", .data = vt8500_irq_init, }, | ||
171 | { /* sentinel */ }, | ||
172 | }; | ||
173 | |||
174 | static void __init vt8500_init_irq(void) | ||
175 | { | ||
176 | of_irq_init(vt8500_irq_match); | ||
177 | }; | ||
178 | |||
179 | static const char * const vt8500_dt_compat[] = { | 170 | static const char * const vt8500_dt_compat[] = { |
180 | "via,vt8500", | 171 | "via,vt8500", |
181 | "wm,wm8650", | 172 | "wm,wm8650", |
@@ -187,10 +178,9 @@ static const char * const vt8500_dt_compat[] = { | |||
187 | DT_MACHINE_START(WMT_DT, "VIA/Wondermedia SoC (Device Tree Support)") | 178 | DT_MACHINE_START(WMT_DT, "VIA/Wondermedia SoC (Device Tree Support)") |
188 | .dt_compat = vt8500_dt_compat, | 179 | .dt_compat = vt8500_dt_compat, |
189 | .map_io = vt8500_map_io, | 180 | .map_io = vt8500_map_io, |
190 | .init_irq = vt8500_init_irq, | 181 | .init_irq = irqchip_init, |
191 | .init_machine = vt8500_init, | 182 | .init_machine = vt8500_init, |
192 | .init_time = clocksource_of_init, | 183 | .init_time = clocksource_of_init, |
193 | .restart = vt8500_restart, | 184 | .restart = vt8500_restart, |
194 | .handle_irq = vt8500_handle_irq, | ||
195 | MACHINE_END | 185 | MACHINE_END |
196 | 186 | ||
diff --git a/arch/arm/mach-zynq/Kconfig b/arch/arm/mach-zynq/Kconfig index 138b5891f4ef..cf3226b041f5 100644 --- a/arch/arm/mach-zynq/Kconfig +++ b/arch/arm/mach-zynq/Kconfig | |||
@@ -11,5 +11,6 @@ config ARCH_ZYNQ | |||
11 | select MIGHT_HAVE_CACHE_L2X0 | 11 | select MIGHT_HAVE_CACHE_L2X0 |
12 | select USE_OF | 12 | select USE_OF |
13 | select SPARSE_IRQ | 13 | select SPARSE_IRQ |
14 | select CADENCE_TTC_TIMER | ||
14 | help | 15 | help |
15 | Support for Xilinx Zynq ARM Cortex A9 Platform | 16 | Support for Xilinx Zynq ARM Cortex A9 Platform |
diff --git a/arch/arm/mach-zynq/Makefile b/arch/arm/mach-zynq/Makefile index 397268c1b250..320faedeb484 100644 --- a/arch/arm/mach-zynq/Makefile +++ b/arch/arm/mach-zynq/Makefile | |||
@@ -3,4 +3,4 @@ | |||
3 | # | 3 | # |
4 | 4 | ||
5 | # Common support | 5 | # Common support |
6 | obj-y := common.o timer.o | 6 | obj-y := common.o |
diff --git a/arch/arm/mach-zynq/common.c b/arch/arm/mach-zynq/common.c index 5c8983218183..68e0907de5d0 100644 --- a/arch/arm/mach-zynq/common.c +++ b/arch/arm/mach-zynq/common.c | |||
@@ -20,6 +20,7 @@ | |||
20 | #include <linux/platform_device.h> | 20 | #include <linux/platform_device.h> |
21 | #include <linux/clk.h> | 21 | #include <linux/clk.h> |
22 | #include <linux/clk/zynq.h> | 22 | #include <linux/clk/zynq.h> |
23 | #include <linux/clocksource.h> | ||
23 | #include <linux/of_address.h> | 24 | #include <linux/of_address.h> |
24 | #include <linux/of_irq.h> | 25 | #include <linux/of_irq.h> |
25 | #include <linux/of_platform.h> | 26 | #include <linux/of_platform.h> |
@@ -77,7 +78,7 @@ static void __init xilinx_zynq_timer_init(void) | |||
77 | 78 | ||
78 | xilinx_zynq_clocks_init(slcr); | 79 | xilinx_zynq_clocks_init(slcr); |
79 | 80 | ||
80 | xttcps_timer_init(); | 81 | clocksource_of_init(); |
81 | } | 82 | } |
82 | 83 | ||
83 | /** | 84 | /** |
diff --git a/arch/arm/mach-zynq/common.h b/arch/arm/mach-zynq/common.h index 8b4dbbaa01cf..5050bb10bb12 100644 --- a/arch/arm/mach-zynq/common.h +++ b/arch/arm/mach-zynq/common.h | |||
@@ -17,6 +17,4 @@ | |||
17 | #ifndef __MACH_ZYNQ_COMMON_H__ | 17 | #ifndef __MACH_ZYNQ_COMMON_H__ |
18 | #define __MACH_ZYNQ_COMMON_H__ | 18 | #define __MACH_ZYNQ_COMMON_H__ |
19 | 19 | ||
20 | void __init xttcps_timer_init(void); | ||
21 | |||
22 | #endif | 20 | #endif |
diff --git a/arch/arm/mach-zynq/timer.c b/arch/arm/mach-zynq/timer.c deleted file mode 100644 index f9fbc9c1e7a6..000000000000 --- a/arch/arm/mach-zynq/timer.c +++ /dev/null | |||
@@ -1,324 +0,0 @@ | |||
1 | /* | ||
2 | * This file contains driver for the Xilinx PS Timer Counter IP. | ||
3 | * | ||
4 | * Copyright (C) 2011 Xilinx | ||
5 | * | ||
6 | * based on arch/mips/kernel/time.c timer driver | ||
7 | * | ||
8 | * This software is licensed under the terms of the GNU General Public | ||
9 | * License version 2, as published by the Free Software Foundation, and | ||
10 | * may be copied, distributed, and modified under those terms. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | */ | ||
17 | |||
18 | #include <linux/interrupt.h> | ||
19 | #include <linux/clockchips.h> | ||
20 | #include <linux/of_address.h> | ||
21 | #include <linux/of_irq.h> | ||
22 | #include <linux/slab.h> | ||
23 | #include <linux/clk-provider.h> | ||
24 | #include "common.h" | ||
25 | |||
26 | /* | ||
27 | * Timer Register Offset Definitions of Timer 1, Increment base address by 4 | ||
28 | * and use same offsets for Timer 2 | ||
29 | */ | ||
30 | #define XTTCPS_CLK_CNTRL_OFFSET 0x00 /* Clock Control Reg, RW */ | ||
31 | #define XTTCPS_CNT_CNTRL_OFFSET 0x0C /* Counter Control Reg, RW */ | ||
32 | #define XTTCPS_COUNT_VAL_OFFSET 0x18 /* Counter Value Reg, RO */ | ||
33 | #define XTTCPS_INTR_VAL_OFFSET 0x24 /* Interval Count Reg, RW */ | ||
34 | #define XTTCPS_ISR_OFFSET 0x54 /* Interrupt Status Reg, RO */ | ||
35 | #define XTTCPS_IER_OFFSET 0x60 /* Interrupt Enable Reg, RW */ | ||
36 | |||
37 | #define XTTCPS_CNT_CNTRL_DISABLE_MASK 0x1 | ||
38 | |||
39 | /* | ||
40 | * Setup the timers to use pre-scaling, using a fixed value for now that will | ||
41 | * work across most input frequency, but it may need to be more dynamic | ||
42 | */ | ||
43 | #define PRESCALE_EXPONENT 11 /* 2 ^ PRESCALE_EXPONENT = PRESCALE */ | ||
44 | #define PRESCALE 2048 /* The exponent must match this */ | ||
45 | #define CLK_CNTRL_PRESCALE ((PRESCALE_EXPONENT - 1) << 1) | ||
46 | #define CLK_CNTRL_PRESCALE_EN 1 | ||
47 | #define CNT_CNTRL_RESET (1<<4) | ||
48 | |||
49 | /** | ||
50 | * struct xttcps_timer - This definition defines local timer structure | ||
51 | * | ||
52 | * @base_addr: Base address of timer | ||
53 | **/ | ||
54 | struct xttcps_timer { | ||
55 | void __iomem *base_addr; | ||
56 | }; | ||
57 | |||
58 | struct xttcps_timer_clocksource { | ||
59 | struct xttcps_timer xttc; | ||
60 | struct clocksource cs; | ||
61 | }; | ||
62 | |||
63 | #define to_xttcps_timer_clksrc(x) \ | ||
64 | container_of(x, struct xttcps_timer_clocksource, cs) | ||
65 | |||
66 | struct xttcps_timer_clockevent { | ||
67 | struct xttcps_timer xttc; | ||
68 | struct clock_event_device ce; | ||
69 | struct clk *clk; | ||
70 | }; | ||
71 | |||
72 | #define to_xttcps_timer_clkevent(x) \ | ||
73 | container_of(x, struct xttcps_timer_clockevent, ce) | ||
74 | |||
75 | /** | ||
76 | * xttcps_set_interval - Set the timer interval value | ||
77 | * | ||
78 | * @timer: Pointer to the timer instance | ||
79 | * @cycles: Timer interval ticks | ||
80 | **/ | ||
81 | static void xttcps_set_interval(struct xttcps_timer *timer, | ||
82 | unsigned long cycles) | ||
83 | { | ||
84 | u32 ctrl_reg; | ||
85 | |||
86 | /* Disable the counter, set the counter value and re-enable counter */ | ||
87 | ctrl_reg = __raw_readl(timer->base_addr + XTTCPS_CNT_CNTRL_OFFSET); | ||
88 | ctrl_reg |= XTTCPS_CNT_CNTRL_DISABLE_MASK; | ||
89 | __raw_writel(ctrl_reg, timer->base_addr + XTTCPS_CNT_CNTRL_OFFSET); | ||
90 | |||
91 | __raw_writel(cycles, timer->base_addr + XTTCPS_INTR_VAL_OFFSET); | ||
92 | |||
93 | /* | ||
94 | * Reset the counter (0x10) so that it starts from 0, one-shot | ||
95 | * mode makes this needed for timing to be right. | ||
96 | */ | ||
97 | ctrl_reg |= CNT_CNTRL_RESET; | ||
98 | ctrl_reg &= ~XTTCPS_CNT_CNTRL_DISABLE_MASK; | ||
99 | __raw_writel(ctrl_reg, timer->base_addr + XTTCPS_CNT_CNTRL_OFFSET); | ||
100 | } | ||
101 | |||
102 | /** | ||
103 | * xttcps_clock_event_interrupt - Clock event timer interrupt handler | ||
104 | * | ||
105 | * @irq: IRQ number of the Timer | ||
106 | * @dev_id: void pointer to the xttcps_timer instance | ||
107 | * | ||
108 | * returns: Always IRQ_HANDLED - success | ||
109 | **/ | ||
110 | static irqreturn_t xttcps_clock_event_interrupt(int irq, void *dev_id) | ||
111 | { | ||
112 | struct xttcps_timer_clockevent *xttce = dev_id; | ||
113 | struct xttcps_timer *timer = &xttce->xttc; | ||
114 | |||
115 | /* Acknowledge the interrupt and call event handler */ | ||
116 | __raw_readl(timer->base_addr + XTTCPS_ISR_OFFSET); | ||
117 | |||
118 | xttce->ce.event_handler(&xttce->ce); | ||
119 | |||
120 | return IRQ_HANDLED; | ||
121 | } | ||
122 | |||
123 | /** | ||
124 | * __xttc_clocksource_read - Reads the timer counter register | ||
125 | * | ||
126 | * returns: Current timer counter register value | ||
127 | **/ | ||
128 | static cycle_t __xttc_clocksource_read(struct clocksource *cs) | ||
129 | { | ||
130 | struct xttcps_timer *timer = &to_xttcps_timer_clksrc(cs)->xttc; | ||
131 | |||
132 | return (cycle_t)__raw_readl(timer->base_addr + | ||
133 | XTTCPS_COUNT_VAL_OFFSET); | ||
134 | } | ||
135 | |||
136 | /** | ||
137 | * xttcps_set_next_event - Sets the time interval for next event | ||
138 | * | ||
139 | * @cycles: Timer interval ticks | ||
140 | * @evt: Address of clock event instance | ||
141 | * | ||
142 | * returns: Always 0 - success | ||
143 | **/ | ||
144 | static int xttcps_set_next_event(unsigned long cycles, | ||
145 | struct clock_event_device *evt) | ||
146 | { | ||
147 | struct xttcps_timer_clockevent *xttce = to_xttcps_timer_clkevent(evt); | ||
148 | struct xttcps_timer *timer = &xttce->xttc; | ||
149 | |||
150 | xttcps_set_interval(timer, cycles); | ||
151 | return 0; | ||
152 | } | ||
153 | |||
154 | /** | ||
155 | * xttcps_set_mode - Sets the mode of timer | ||
156 | * | ||
157 | * @mode: Mode to be set | ||
158 | * @evt: Address of clock event instance | ||
159 | **/ | ||
160 | static void xttcps_set_mode(enum clock_event_mode mode, | ||
161 | struct clock_event_device *evt) | ||
162 | { | ||
163 | struct xttcps_timer_clockevent *xttce = to_xttcps_timer_clkevent(evt); | ||
164 | struct xttcps_timer *timer = &xttce->xttc; | ||
165 | u32 ctrl_reg; | ||
166 | |||
167 | switch (mode) { | ||
168 | case CLOCK_EVT_MODE_PERIODIC: | ||
169 | xttcps_set_interval(timer, | ||
170 | DIV_ROUND_CLOSEST(clk_get_rate(xttce->clk), | ||
171 | PRESCALE * HZ)); | ||
172 | break; | ||
173 | case CLOCK_EVT_MODE_ONESHOT: | ||
174 | case CLOCK_EVT_MODE_UNUSED: | ||
175 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
176 | ctrl_reg = __raw_readl(timer->base_addr + | ||
177 | XTTCPS_CNT_CNTRL_OFFSET); | ||
178 | ctrl_reg |= XTTCPS_CNT_CNTRL_DISABLE_MASK; | ||
179 | __raw_writel(ctrl_reg, | ||
180 | timer->base_addr + XTTCPS_CNT_CNTRL_OFFSET); | ||
181 | break; | ||
182 | case CLOCK_EVT_MODE_RESUME: | ||
183 | ctrl_reg = __raw_readl(timer->base_addr + | ||
184 | XTTCPS_CNT_CNTRL_OFFSET); | ||
185 | ctrl_reg &= ~XTTCPS_CNT_CNTRL_DISABLE_MASK; | ||
186 | __raw_writel(ctrl_reg, | ||
187 | timer->base_addr + XTTCPS_CNT_CNTRL_OFFSET); | ||
188 | break; | ||
189 | } | ||
190 | } | ||
191 | |||
192 | static void __init zynq_ttc_setup_clocksource(struct device_node *np, | ||
193 | void __iomem *base) | ||
194 | { | ||
195 | struct xttcps_timer_clocksource *ttccs; | ||
196 | struct clk *clk; | ||
197 | int err; | ||
198 | u32 reg; | ||
199 | |||
200 | ttccs = kzalloc(sizeof(*ttccs), GFP_KERNEL); | ||
201 | if (WARN_ON(!ttccs)) | ||
202 | return; | ||
203 | |||
204 | err = of_property_read_u32(np, "reg", ®); | ||
205 | if (WARN_ON(err)) | ||
206 | return; | ||
207 | |||
208 | clk = of_clk_get_by_name(np, "cpu_1x"); | ||
209 | if (WARN_ON(IS_ERR(clk))) | ||
210 | return; | ||
211 | |||
212 | err = clk_prepare_enable(clk); | ||
213 | if (WARN_ON(err)) | ||
214 | return; | ||
215 | |||
216 | ttccs->xttc.base_addr = base + reg * 4; | ||
217 | |||
218 | ttccs->cs.name = np->name; | ||
219 | ttccs->cs.rating = 200; | ||
220 | ttccs->cs.read = __xttc_clocksource_read; | ||
221 | ttccs->cs.mask = CLOCKSOURCE_MASK(16); | ||
222 | ttccs->cs.flags = CLOCK_SOURCE_IS_CONTINUOUS; | ||
223 | |||
224 | __raw_writel(0x0, ttccs->xttc.base_addr + XTTCPS_IER_OFFSET); | ||
225 | __raw_writel(CLK_CNTRL_PRESCALE | CLK_CNTRL_PRESCALE_EN, | ||
226 | ttccs->xttc.base_addr + XTTCPS_CLK_CNTRL_OFFSET); | ||
227 | __raw_writel(CNT_CNTRL_RESET, | ||
228 | ttccs->xttc.base_addr + XTTCPS_CNT_CNTRL_OFFSET); | ||
229 | |||
230 | err = clocksource_register_hz(&ttccs->cs, clk_get_rate(clk) / PRESCALE); | ||
231 | if (WARN_ON(err)) | ||
232 | return; | ||
233 | } | ||
234 | |||
235 | static void __init zynq_ttc_setup_clockevent(struct device_node *np, | ||
236 | void __iomem *base) | ||
237 | { | ||
238 | struct xttcps_timer_clockevent *ttcce; | ||
239 | int err, irq; | ||
240 | u32 reg; | ||
241 | |||
242 | ttcce = kzalloc(sizeof(*ttcce), GFP_KERNEL); | ||
243 | if (WARN_ON(!ttcce)) | ||
244 | return; | ||
245 | |||
246 | err = of_property_read_u32(np, "reg", ®); | ||
247 | if (WARN_ON(err)) | ||
248 | return; | ||
249 | |||
250 | ttcce->xttc.base_addr = base + reg * 4; | ||
251 | |||
252 | ttcce->clk = of_clk_get_by_name(np, "cpu_1x"); | ||
253 | if (WARN_ON(IS_ERR(ttcce->clk))) | ||
254 | return; | ||
255 | |||
256 | err = clk_prepare_enable(ttcce->clk); | ||
257 | if (WARN_ON(err)) | ||
258 | return; | ||
259 | |||
260 | irq = irq_of_parse_and_map(np, 0); | ||
261 | if (WARN_ON(!irq)) | ||
262 | return; | ||
263 | |||
264 | ttcce->ce.name = np->name; | ||
265 | ttcce->ce.features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT; | ||
266 | ttcce->ce.set_next_event = xttcps_set_next_event; | ||
267 | ttcce->ce.set_mode = xttcps_set_mode; | ||
268 | ttcce->ce.rating = 200; | ||
269 | ttcce->ce.irq = irq; | ||
270 | ttcce->ce.cpumask = cpu_possible_mask; | ||
271 | |||
272 | __raw_writel(0x23, ttcce->xttc.base_addr + XTTCPS_CNT_CNTRL_OFFSET); | ||
273 | __raw_writel(CLK_CNTRL_PRESCALE | CLK_CNTRL_PRESCALE_EN, | ||
274 | ttcce->xttc.base_addr + XTTCPS_CLK_CNTRL_OFFSET); | ||
275 | __raw_writel(0x1, ttcce->xttc.base_addr + XTTCPS_IER_OFFSET); | ||
276 | |||
277 | err = request_irq(irq, xttcps_clock_event_interrupt, IRQF_TIMER, | ||
278 | np->name, ttcce); | ||
279 | if (WARN_ON(err)) | ||
280 | return; | ||
281 | |||
282 | clockevents_config_and_register(&ttcce->ce, | ||
283 | clk_get_rate(ttcce->clk) / PRESCALE, | ||
284 | 1, 0xfffe); | ||
285 | } | ||
286 | |||
287 | static const __initconst struct of_device_id zynq_ttc_match[] = { | ||
288 | { .compatible = "xlnx,ttc-counter-clocksource", | ||
289 | .data = zynq_ttc_setup_clocksource, }, | ||
290 | { .compatible = "xlnx,ttc-counter-clockevent", | ||
291 | .data = zynq_ttc_setup_clockevent, }, | ||
292 | {} | ||
293 | }; | ||
294 | |||
295 | /** | ||
296 | * xttcps_timer_init - Initialize the timer | ||
297 | * | ||
298 | * Initializes the timer hardware and register the clock source and clock event | ||
299 | * timers with Linux kernal timer framework | ||
300 | **/ | ||
301 | void __init xttcps_timer_init(void) | ||
302 | { | ||
303 | struct device_node *np; | ||
304 | |||
305 | for_each_compatible_node(np, NULL, "xlnx,ttc") { | ||
306 | struct device_node *np_chld; | ||
307 | void __iomem *base; | ||
308 | |||
309 | base = of_iomap(np, 0); | ||
310 | if (WARN_ON(!base)) | ||
311 | return; | ||
312 | |||
313 | for_each_available_child_of_node(np, np_chld) { | ||
314 | int (*cb)(struct device_node *np, void __iomem *base); | ||
315 | const struct of_device_id *match; | ||
316 | |||
317 | match = of_match_node(zynq_ttc_match, np_chld); | ||
318 | if (match) { | ||
319 | cb = match->data; | ||
320 | cb(np_chld, base); | ||
321 | } | ||
322 | } | ||
323 | } | ||
324 | } | ||
diff --git a/arch/arm/plat-samsung/Kconfig b/arch/arm/plat-samsung/Kconfig index 91c2d72e689b..54d186106f9f 100644 --- a/arch/arm/plat-samsung/Kconfig +++ b/arch/arm/plat-samsung/Kconfig | |||
@@ -25,7 +25,7 @@ config PLAT_S5P | |||
25 | select PLAT_SAMSUNG | 25 | select PLAT_SAMSUNG |
26 | select S3C_GPIO_TRACK | 26 | select S3C_GPIO_TRACK |
27 | select S5P_GPIO_DRVSTR | 27 | select S5P_GPIO_DRVSTR |
28 | select SAMSUNG_CLKSRC | 28 | select SAMSUNG_CLKSRC if !COMMON_CLK |
29 | select SAMSUNG_GPIOLIB_4BIT | 29 | select SAMSUNG_GPIOLIB_4BIT |
30 | select SAMSUNG_IRQ_VIC_TIMER | 30 | select SAMSUNG_IRQ_VIC_TIMER |
31 | help | 31 | help |
@@ -62,7 +62,7 @@ config S3C_LOWLEVEL_UART_PORT | |||
62 | 62 | ||
63 | # timer options | 63 | # timer options |
64 | 64 | ||
65 | config S5P_HRT | 65 | config SAMSUNG_HRT |
66 | bool | 66 | bool |
67 | select SAMSUNG_DEV_PWM | 67 | select SAMSUNG_DEV_PWM |
68 | help | 68 | help |
@@ -81,7 +81,7 @@ config SAMSUNG_CLKSRC | |||
81 | used by newer systems such as the S3C64XX. | 81 | used by newer systems such as the S3C64XX. |
82 | 82 | ||
83 | config S5P_CLOCK | 83 | config S5P_CLOCK |
84 | def_bool (ARCH_S5P64X0 || ARCH_S5PC100 || ARCH_S5PV210 || ARCH_EXYNOS) | 84 | def_bool (ARCH_S5P64X0 || ARCH_S5PC100 || ARCH_S5PV210) |
85 | help | 85 | help |
86 | Support common clock part for ARCH_S5P and ARCH_EXYNOS SoCs | 86 | Support common clock part for ARCH_S5P and ARCH_EXYNOS SoCs |
87 | 87 | ||
diff --git a/arch/arm/plat-samsung/Makefile b/arch/arm/plat-samsung/Makefile index 3a7c64d1814a..a23c460299a1 100644 --- a/arch/arm/plat-samsung/Makefile +++ b/arch/arm/plat-samsung/Makefile | |||
@@ -12,8 +12,7 @@ obj- := | |||
12 | # Objects we always build independent of SoC choice | 12 | # Objects we always build independent of SoC choice |
13 | 13 | ||
14 | obj-y += init.o cpu.o | 14 | obj-y += init.o cpu.o |
15 | obj-$(CONFIG_ARCH_USES_GETTIMEOFFSET) += time.o | 15 | obj-$(CONFIG_SAMSUNG_HRT) += samsung-time.o |
16 | obj-$(CONFIG_S5P_HRT) += s5p-time.o | ||
17 | 16 | ||
18 | obj-$(CONFIG_SAMSUNG_CLOCK) += clock.o | 17 | obj-$(CONFIG_SAMSUNG_CLOCK) += clock.o |
19 | obj-$(CONFIG_SAMSUNG_CLOCK) += pwm-clock.o | 18 | obj-$(CONFIG_SAMSUNG_CLOCK) += pwm-clock.o |
diff --git a/arch/arm/plat-samsung/devs.c b/arch/arm/plat-samsung/devs.c index 33ad3f32c2b9..30c2fe243f76 100644 --- a/arch/arm/plat-samsung/devs.c +++ b/arch/arm/plat-samsung/devs.c | |||
@@ -1074,7 +1074,7 @@ struct platform_device s5p_device_onenand = { | |||
1074 | 1074 | ||
1075 | /* PMU */ | 1075 | /* PMU */ |
1076 | 1076 | ||
1077 | #ifdef CONFIG_PLAT_S5P | 1077 | #if defined(CONFIG_PLAT_S5P) && !defined(CONFIG_ARCH_EXYNOS) |
1078 | static struct resource s5p_pmu_resource[] = { | 1078 | static struct resource s5p_pmu_resource[] = { |
1079 | DEFINE_RES_IRQ(IRQ_PMU) | 1079 | DEFINE_RES_IRQ(IRQ_PMU) |
1080 | }; | 1080 | }; |
diff --git a/arch/arm/plat-samsung/include/plat/cpu.h b/arch/arm/plat-samsung/include/plat/cpu.h index 37703ef6dfc7..989fefe18be6 100644 --- a/arch/arm/plat-samsung/include/plat/cpu.h +++ b/arch/arm/plat-samsung/include/plat/cpu.h | |||
@@ -23,6 +23,9 @@ extern unsigned long samsung_cpu_id; | |||
23 | #define S3C24XX_CPU_ID 0x32400000 | 23 | #define S3C24XX_CPU_ID 0x32400000 |
24 | #define S3C24XX_CPU_MASK 0xFFF00000 | 24 | #define S3C24XX_CPU_MASK 0xFFF00000 |
25 | 25 | ||
26 | #define S3C2412_CPU_ID 0x32412000 | ||
27 | #define S3C2412_CPU_MASK 0xFFFFF000 | ||
28 | |||
26 | #define S3C6400_CPU_ID 0x36400000 | 29 | #define S3C6400_CPU_ID 0x36400000 |
27 | #define S3C6410_CPU_ID 0x36410000 | 30 | #define S3C6410_CPU_ID 0x36410000 |
28 | #define S3C64XX_CPU_MASK 0xFFFFF000 | 31 | #define S3C64XX_CPU_MASK 0xFFFFF000 |
@@ -53,6 +56,7 @@ static inline int is_samsung_##name(void) \ | |||
53 | } | 56 | } |
54 | 57 | ||
55 | IS_SAMSUNG_CPU(s3c24xx, S3C24XX_CPU_ID, S3C24XX_CPU_MASK) | 58 | IS_SAMSUNG_CPU(s3c24xx, S3C24XX_CPU_ID, S3C24XX_CPU_MASK) |
59 | IS_SAMSUNG_CPU(s3c2412, S3C2412_CPU_ID, S3C2412_CPU_MASK) | ||
56 | IS_SAMSUNG_CPU(s3c6400, S3C6400_CPU_ID, S3C64XX_CPU_MASK) | 60 | IS_SAMSUNG_CPU(s3c6400, S3C6400_CPU_ID, S3C64XX_CPU_MASK) |
57 | IS_SAMSUNG_CPU(s3c6410, S3C6410_CPU_ID, S3C64XX_CPU_MASK) | 61 | IS_SAMSUNG_CPU(s3c6410, S3C6410_CPU_ID, S3C64XX_CPU_MASK) |
58 | IS_SAMSUNG_CPU(s5p6440, S5P6440_CPU_ID, S5P64XX_CPU_MASK) | 62 | IS_SAMSUNG_CPU(s5p6440, S5P6440_CPU_ID, S5P64XX_CPU_MASK) |
@@ -74,6 +78,12 @@ IS_SAMSUNG_CPU(exynos5440, EXYNOS5440_SOC_ID, EXYNOS5_SOC_MASK) | |||
74 | # define soc_is_s3c24xx() 0 | 78 | # define soc_is_s3c24xx() 0 |
75 | #endif | 79 | #endif |
76 | 80 | ||
81 | #if defined(CONFIG_CPU_S3C2412) | ||
82 | # define soc_is_s3c2412() is_samsung_s3c2412() | ||
83 | #else | ||
84 | # define soc_is_s3c2412() 0 | ||
85 | #endif | ||
86 | |||
77 | #if defined(CONFIG_CPU_S3C6400) || defined(CONFIG_CPU_S3C6410) | 87 | #if defined(CONFIG_CPU_S3C6400) || defined(CONFIG_CPU_S3C6410) |
78 | # define soc_is_s3c64xx() (is_samsung_s3c6400() || is_samsung_s3c6410()) | 88 | # define soc_is_s3c64xx() (is_samsung_s3c6400() || is_samsung_s3c6410()) |
79 | #else | 89 | #else |
@@ -173,7 +183,6 @@ extern void s3c_init_cpu(unsigned long idcode, | |||
173 | 183 | ||
174 | /* core initialisation functions */ | 184 | /* core initialisation functions */ |
175 | 185 | ||
176 | extern void s3c24xx_init_irq(void); | ||
177 | extern void s5p_init_irq(u32 *vic, u32 num_vic); | 186 | extern void s5p_init_irq(u32 *vic, u32 num_vic); |
178 | 187 | ||
179 | extern void s3c24xx_init_io(struct map_desc *mach_desc, int size); | 188 | extern void s3c24xx_init_io(struct map_desc *mach_desc, int size); |
@@ -192,10 +201,6 @@ extern void s3c24xx_init_uartdevs(char *name, | |||
192 | struct s3c24xx_uart_resources *res, | 201 | struct s3c24xx_uart_resources *res, |
193 | struct s3c2410_uartcfg *cfg, int no); | 202 | struct s3c2410_uartcfg *cfg, int no); |
194 | 203 | ||
195 | /* timer for 2410/2440 */ | ||
196 | |||
197 | extern void s3c24xx_timer_init(void); | ||
198 | |||
199 | extern struct syscore_ops s3c2410_pm_syscore_ops; | 204 | extern struct syscore_ops s3c2410_pm_syscore_ops; |
200 | extern struct syscore_ops s3c2412_pm_syscore_ops; | 205 | extern struct syscore_ops s3c2412_pm_syscore_ops; |
201 | extern struct syscore_ops s3c2416_pm_syscore_ops; | 206 | extern struct syscore_ops s3c2416_pm_syscore_ops; |
diff --git a/arch/arm/plat-samsung/include/plat/s5p-time.h b/arch/arm/plat-samsung/include/plat/s5p-time.h deleted file mode 100644 index 9c96f3586ce0..000000000000 --- a/arch/arm/plat-samsung/include/plat/s5p-time.h +++ /dev/null | |||
@@ -1,40 +0,0 @@ | |||
1 | /* linux/arch/arm/plat-samsung/include/plat/s5p-time.h | ||
2 | * | ||
3 | * Copyright 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com/ | ||
5 | * | ||
6 | * Header file for s5p time support | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_PLAT_S5P_TIME_H | ||
14 | #define __ASM_PLAT_S5P_TIME_H __FILE__ | ||
15 | |||
16 | /* S5P HR-Timer Clock mode */ | ||
17 | enum s5p_timer_mode { | ||
18 | S5P_PWM0, | ||
19 | S5P_PWM1, | ||
20 | S5P_PWM2, | ||
21 | S5P_PWM3, | ||
22 | S5P_PWM4, | ||
23 | }; | ||
24 | |||
25 | struct s5p_timer_source { | ||
26 | unsigned int event_id; | ||
27 | unsigned int source_id; | ||
28 | }; | ||
29 | |||
30 | /* Be able to sleep for atleast 4 seconds (usually more) */ | ||
31 | #define S5PTIMER_MIN_RANGE 4 | ||
32 | |||
33 | #define TCNT_MAX 0xffffffff | ||
34 | #define NON_PERIODIC 0 | ||
35 | #define PERIODIC 1 | ||
36 | |||
37 | extern void __init s5p_set_timer_source(enum s5p_timer_mode event, | ||
38 | enum s5p_timer_mode source); | ||
39 | extern void s5p_timer_init(void); | ||
40 | #endif /* __ASM_PLAT_S5P_TIME_H */ | ||
diff --git a/arch/arm/plat-samsung/include/plat/samsung-time.h b/arch/arm/plat-samsung/include/plat/samsung-time.h new file mode 100644 index 000000000000..4cc99bb1f176 --- /dev/null +++ b/arch/arm/plat-samsung/include/plat/samsung-time.h | |||
@@ -0,0 +1,53 @@ | |||
1 | /* linux/arch/arm/plat-samsung/include/plat/samsung-time.h | ||
2 | * | ||
3 | * Copyright 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com/ | ||
5 | * | ||
6 | * Header file for samsung s3c and s5p time support | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_PLAT_SAMSUNG_TIME_H | ||
14 | #define __ASM_PLAT_SAMSUNG_TIME_H __FILE__ | ||
15 | |||
16 | /* SAMSUNG HR-Timer Clock mode */ | ||
17 | enum samsung_timer_mode { | ||
18 | SAMSUNG_PWM0, | ||
19 | SAMSUNG_PWM1, | ||
20 | SAMSUNG_PWM2, | ||
21 | SAMSUNG_PWM3, | ||
22 | SAMSUNG_PWM4, | ||
23 | }; | ||
24 | |||
25 | struct samsung_timer_source { | ||
26 | unsigned int event_id; | ||
27 | unsigned int source_id; | ||
28 | }; | ||
29 | |||
30 | /* Be able to sleep for atleast 4 seconds (usually more) */ | ||
31 | #define SAMSUNG_TIMER_MIN_RANGE 4 | ||
32 | |||
33 | #if defined(CONFIG_ARCH_S3C24XX) || defined(CONFIG_ARCH_S5PC100) | ||
34 | #define TCNT_MAX 0xffff | ||
35 | #define TSCALER_DIV 25 | ||
36 | #define TDIV 50 | ||
37 | #define TSIZE 16 | ||
38 | #else | ||
39 | #define TCNT_MAX 0xffffffff | ||
40 | #define TSCALER_DIV 2 | ||
41 | #define TDIV 2 | ||
42 | #define TSIZE 32 | ||
43 | #endif | ||
44 | |||
45 | #define NON_PERIODIC 0 | ||
46 | #define PERIODIC 1 | ||
47 | |||
48 | extern void __init samsung_set_timer_source(enum samsung_timer_mode event, | ||
49 | enum samsung_timer_mode source); | ||
50 | |||
51 | extern void __init samsung_timer_init(void); | ||
52 | |||
53 | #endif /* __ASM_PLAT_SAMSUNG_TIME_H */ | ||
diff --git a/arch/arm/plat-samsung/s5p-time.c b/arch/arm/plat-samsung/samsung-time.c index e92510cf82ee..f899cbc9b288 100644 --- a/arch/arm/plat-samsung/s5p-time.c +++ b/arch/arm/plat-samsung/samsung-time.c | |||
@@ -2,7 +2,7 @@ | |||
2 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | 2 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. |
3 | * http://www.samsung.com/ | 3 | * http://www.samsung.com/ |
4 | * | 4 | * |
5 | * S5P - Common hr-timer support | 5 | * samsung - Common hr-timer support (s3c and s5p) |
6 | * | 6 | * |
7 | * This program is free software; you can redistribute it and/or modify | 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 | 8 | * it under the terms of the GNU General Public License version 2 as |
@@ -25,41 +25,41 @@ | |||
25 | #include <mach/map.h> | 25 | #include <mach/map.h> |
26 | #include <plat/devs.h> | 26 | #include <plat/devs.h> |
27 | #include <plat/regs-timer.h> | 27 | #include <plat/regs-timer.h> |
28 | #include <plat/s5p-time.h> | 28 | #include <plat/samsung-time.h> |
29 | 29 | ||
30 | static struct clk *tin_event; | 30 | static struct clk *tin_event; |
31 | static struct clk *tin_source; | 31 | static struct clk *tin_source; |
32 | static struct clk *tdiv_event; | 32 | static struct clk *tdiv_event; |
33 | static struct clk *tdiv_source; | 33 | static struct clk *tdiv_source; |
34 | static struct clk *timerclk; | 34 | static struct clk *timerclk; |
35 | static struct s5p_timer_source timer_source; | 35 | static struct samsung_timer_source timer_source; |
36 | static unsigned long clock_count_per_tick; | 36 | static unsigned long clock_count_per_tick; |
37 | static void s5p_timer_resume(void); | 37 | static void samsung_timer_resume(void); |
38 | 38 | ||
39 | static void s5p_time_stop(enum s5p_timer_mode mode) | 39 | static void samsung_time_stop(enum samsung_timer_mode mode) |
40 | { | 40 | { |
41 | unsigned long tcon; | 41 | unsigned long tcon; |
42 | 42 | ||
43 | tcon = __raw_readl(S3C2410_TCON); | 43 | tcon = __raw_readl(S3C2410_TCON); |
44 | 44 | ||
45 | switch (mode) { | 45 | switch (mode) { |
46 | case S5P_PWM0: | 46 | case SAMSUNG_PWM0: |
47 | tcon &= ~S3C2410_TCON_T0START; | 47 | tcon &= ~S3C2410_TCON_T0START; |
48 | break; | 48 | break; |
49 | 49 | ||
50 | case S5P_PWM1: | 50 | case SAMSUNG_PWM1: |
51 | tcon &= ~S3C2410_TCON_T1START; | 51 | tcon &= ~S3C2410_TCON_T1START; |
52 | break; | 52 | break; |
53 | 53 | ||
54 | case S5P_PWM2: | 54 | case SAMSUNG_PWM2: |
55 | tcon &= ~S3C2410_TCON_T2START; | 55 | tcon &= ~S3C2410_TCON_T2START; |
56 | break; | 56 | break; |
57 | 57 | ||
58 | case S5P_PWM3: | 58 | case SAMSUNG_PWM3: |
59 | tcon &= ~S3C2410_TCON_T3START; | 59 | tcon &= ~S3C2410_TCON_T3START; |
60 | break; | 60 | break; |
61 | 61 | ||
62 | case S5P_PWM4: | 62 | case SAMSUNG_PWM4: |
63 | tcon &= ~S3C2410_TCON_T4START; | 63 | tcon &= ~S3C2410_TCON_T4START; |
64 | break; | 64 | break; |
65 | 65 | ||
@@ -70,7 +70,7 @@ static void s5p_time_stop(enum s5p_timer_mode mode) | |||
70 | __raw_writel(tcon, S3C2410_TCON); | 70 | __raw_writel(tcon, S3C2410_TCON); |
71 | } | 71 | } |
72 | 72 | ||
73 | static void s5p_time_setup(enum s5p_timer_mode mode, unsigned long tcnt) | 73 | static void samsung_time_setup(enum samsung_timer_mode mode, unsigned long tcnt) |
74 | { | 74 | { |
75 | unsigned long tcon; | 75 | unsigned long tcon; |
76 | 76 | ||
@@ -79,27 +79,27 @@ static void s5p_time_setup(enum s5p_timer_mode mode, unsigned long tcnt) | |||
79 | tcnt--; | 79 | tcnt--; |
80 | 80 | ||
81 | switch (mode) { | 81 | switch (mode) { |
82 | case S5P_PWM0: | 82 | case SAMSUNG_PWM0: |
83 | tcon &= ~(0x0f << 0); | 83 | tcon &= ~(0x0f << 0); |
84 | tcon |= S3C2410_TCON_T0MANUALUPD; | 84 | tcon |= S3C2410_TCON_T0MANUALUPD; |
85 | break; | 85 | break; |
86 | 86 | ||
87 | case S5P_PWM1: | 87 | case SAMSUNG_PWM1: |
88 | tcon &= ~(0x0f << 8); | 88 | tcon &= ~(0x0f << 8); |
89 | tcon |= S3C2410_TCON_T1MANUALUPD; | 89 | tcon |= S3C2410_TCON_T1MANUALUPD; |
90 | break; | 90 | break; |
91 | 91 | ||
92 | case S5P_PWM2: | 92 | case SAMSUNG_PWM2: |
93 | tcon &= ~(0x0f << 12); | 93 | tcon &= ~(0x0f << 12); |
94 | tcon |= S3C2410_TCON_T2MANUALUPD; | 94 | tcon |= S3C2410_TCON_T2MANUALUPD; |
95 | break; | 95 | break; |
96 | 96 | ||
97 | case S5P_PWM3: | 97 | case SAMSUNG_PWM3: |
98 | tcon &= ~(0x0f << 16); | 98 | tcon &= ~(0x0f << 16); |
99 | tcon |= S3C2410_TCON_T3MANUALUPD; | 99 | tcon |= S3C2410_TCON_T3MANUALUPD; |
100 | break; | 100 | break; |
101 | 101 | ||
102 | case S5P_PWM4: | 102 | case SAMSUNG_PWM4: |
103 | tcon &= ~(0x07 << 20); | 103 | tcon &= ~(0x07 << 20); |
104 | tcon |= S3C2410_TCON_T4MANUALUPD; | 104 | tcon |= S3C2410_TCON_T4MANUALUPD; |
105 | break; | 105 | break; |
@@ -114,14 +114,14 @@ static void s5p_time_setup(enum s5p_timer_mode mode, unsigned long tcnt) | |||
114 | __raw_writel(tcon, S3C2410_TCON); | 114 | __raw_writel(tcon, S3C2410_TCON); |
115 | } | 115 | } |
116 | 116 | ||
117 | static void s5p_time_start(enum s5p_timer_mode mode, bool periodic) | 117 | static void samsung_time_start(enum samsung_timer_mode mode, bool periodic) |
118 | { | 118 | { |
119 | unsigned long tcon; | 119 | unsigned long tcon; |
120 | 120 | ||
121 | tcon = __raw_readl(S3C2410_TCON); | 121 | tcon = __raw_readl(S3C2410_TCON); |
122 | 122 | ||
123 | switch (mode) { | 123 | switch (mode) { |
124 | case S5P_PWM0: | 124 | case SAMSUNG_PWM0: |
125 | tcon |= S3C2410_TCON_T0START; | 125 | tcon |= S3C2410_TCON_T0START; |
126 | tcon &= ~S3C2410_TCON_T0MANUALUPD; | 126 | tcon &= ~S3C2410_TCON_T0MANUALUPD; |
127 | 127 | ||
@@ -131,7 +131,7 @@ static void s5p_time_start(enum s5p_timer_mode mode, bool periodic) | |||
131 | tcon &= ~S3C2410_TCON_T0RELOAD; | 131 | tcon &= ~S3C2410_TCON_T0RELOAD; |
132 | break; | 132 | break; |
133 | 133 | ||
134 | case S5P_PWM1: | 134 | case SAMSUNG_PWM1: |
135 | tcon |= S3C2410_TCON_T1START; | 135 | tcon |= S3C2410_TCON_T1START; |
136 | tcon &= ~S3C2410_TCON_T1MANUALUPD; | 136 | tcon &= ~S3C2410_TCON_T1MANUALUPD; |
137 | 137 | ||
@@ -141,7 +141,7 @@ static void s5p_time_start(enum s5p_timer_mode mode, bool periodic) | |||
141 | tcon &= ~S3C2410_TCON_T1RELOAD; | 141 | tcon &= ~S3C2410_TCON_T1RELOAD; |
142 | break; | 142 | break; |
143 | 143 | ||
144 | case S5P_PWM2: | 144 | case SAMSUNG_PWM2: |
145 | tcon |= S3C2410_TCON_T2START; | 145 | tcon |= S3C2410_TCON_T2START; |
146 | tcon &= ~S3C2410_TCON_T2MANUALUPD; | 146 | tcon &= ~S3C2410_TCON_T2MANUALUPD; |
147 | 147 | ||
@@ -151,7 +151,7 @@ static void s5p_time_start(enum s5p_timer_mode mode, bool periodic) | |||
151 | tcon &= ~S3C2410_TCON_T2RELOAD; | 151 | tcon &= ~S3C2410_TCON_T2RELOAD; |
152 | break; | 152 | break; |
153 | 153 | ||
154 | case S5P_PWM3: | 154 | case SAMSUNG_PWM3: |
155 | tcon |= S3C2410_TCON_T3START; | 155 | tcon |= S3C2410_TCON_T3START; |
156 | tcon &= ~S3C2410_TCON_T3MANUALUPD; | 156 | tcon &= ~S3C2410_TCON_T3MANUALUPD; |
157 | 157 | ||
@@ -161,7 +161,7 @@ static void s5p_time_start(enum s5p_timer_mode mode, bool periodic) | |||
161 | tcon &= ~S3C2410_TCON_T3RELOAD; | 161 | tcon &= ~S3C2410_TCON_T3RELOAD; |
162 | break; | 162 | break; |
163 | 163 | ||
164 | case S5P_PWM4: | 164 | case SAMSUNG_PWM4: |
165 | tcon |= S3C2410_TCON_T4START; | 165 | tcon |= S3C2410_TCON_T4START; |
166 | tcon &= ~S3C2410_TCON_T4MANUALUPD; | 166 | tcon &= ~S3C2410_TCON_T4MANUALUPD; |
167 | 167 | ||
@@ -178,24 +178,24 @@ static void s5p_time_start(enum s5p_timer_mode mode, bool periodic) | |||
178 | __raw_writel(tcon, S3C2410_TCON); | 178 | __raw_writel(tcon, S3C2410_TCON); |
179 | } | 179 | } |
180 | 180 | ||
181 | static int s5p_set_next_event(unsigned long cycles, | 181 | static int samsung_set_next_event(unsigned long cycles, |
182 | struct clock_event_device *evt) | 182 | struct clock_event_device *evt) |
183 | { | 183 | { |
184 | s5p_time_setup(timer_source.event_id, cycles); | 184 | samsung_time_setup(timer_source.event_id, cycles); |
185 | s5p_time_start(timer_source.event_id, NON_PERIODIC); | 185 | samsung_time_start(timer_source.event_id, NON_PERIODIC); |
186 | 186 | ||
187 | return 0; | 187 | return 0; |
188 | } | 188 | } |
189 | 189 | ||
190 | static void s5p_set_mode(enum clock_event_mode mode, | 190 | static void samsung_set_mode(enum clock_event_mode mode, |
191 | struct clock_event_device *evt) | 191 | struct clock_event_device *evt) |
192 | { | 192 | { |
193 | s5p_time_stop(timer_source.event_id); | 193 | samsung_time_stop(timer_source.event_id); |
194 | 194 | ||
195 | switch (mode) { | 195 | switch (mode) { |
196 | case CLOCK_EVT_MODE_PERIODIC: | 196 | case CLOCK_EVT_MODE_PERIODIC: |
197 | s5p_time_setup(timer_source.event_id, clock_count_per_tick); | 197 | samsung_time_setup(timer_source.event_id, clock_count_per_tick); |
198 | s5p_time_start(timer_source.event_id, PERIODIC); | 198 | samsung_time_start(timer_source.event_id, PERIODIC); |
199 | break; | 199 | break; |
200 | 200 | ||
201 | case CLOCK_EVT_MODE_ONESHOT: | 201 | case CLOCK_EVT_MODE_ONESHOT: |
@@ -206,24 +206,24 @@ static void s5p_set_mode(enum clock_event_mode mode, | |||
206 | break; | 206 | break; |
207 | 207 | ||
208 | case CLOCK_EVT_MODE_RESUME: | 208 | case CLOCK_EVT_MODE_RESUME: |
209 | s5p_timer_resume(); | 209 | samsung_timer_resume(); |
210 | break; | 210 | break; |
211 | } | 211 | } |
212 | } | 212 | } |
213 | 213 | ||
214 | static void s5p_timer_resume(void) | 214 | static void samsung_timer_resume(void) |
215 | { | 215 | { |
216 | /* event timer restart */ | 216 | /* event timer restart */ |
217 | s5p_time_setup(timer_source.event_id, clock_count_per_tick); | 217 | samsung_time_setup(timer_source.event_id, clock_count_per_tick); |
218 | s5p_time_start(timer_source.event_id, PERIODIC); | 218 | samsung_time_start(timer_source.event_id, PERIODIC); |
219 | 219 | ||
220 | /* source timer restart */ | 220 | /* source timer restart */ |
221 | s5p_time_setup(timer_source.source_id, TCNT_MAX); | 221 | samsung_time_setup(timer_source.source_id, TCNT_MAX); |
222 | s5p_time_start(timer_source.source_id, PERIODIC); | 222 | samsung_time_start(timer_source.source_id, PERIODIC); |
223 | } | 223 | } |
224 | 224 | ||
225 | void __init s5p_set_timer_source(enum s5p_timer_mode event, | 225 | void __init samsung_set_timer_source(enum samsung_timer_mode event, |
226 | enum s5p_timer_mode source) | 226 | enum samsung_timer_mode source) |
227 | { | 227 | { |
228 | s3c_device_timer[event].dev.bus = &platform_bus_type; | 228 | s3c_device_timer[event].dev.bus = &platform_bus_type; |
229 | s3c_device_timer[source].dev.bus = &platform_bus_type; | 229 | s3c_device_timer[source].dev.bus = &platform_bus_type; |
@@ -233,14 +233,14 @@ void __init s5p_set_timer_source(enum s5p_timer_mode event, | |||
233 | } | 233 | } |
234 | 234 | ||
235 | static struct clock_event_device time_event_device = { | 235 | static struct clock_event_device time_event_device = { |
236 | .name = "s5p_event_timer", | 236 | .name = "samsung_event_timer", |
237 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, | 237 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, |
238 | .rating = 200, | 238 | .rating = 200, |
239 | .set_next_event = s5p_set_next_event, | 239 | .set_next_event = samsung_set_next_event, |
240 | .set_mode = s5p_set_mode, | 240 | .set_mode = samsung_set_mode, |
241 | }; | 241 | }; |
242 | 242 | ||
243 | static irqreturn_t s5p_clock_event_isr(int irq, void *dev_id) | 243 | static irqreturn_t samsung_clock_event_isr(int irq, void *dev_id) |
244 | { | 244 | { |
245 | struct clock_event_device *evt = dev_id; | 245 | struct clock_event_device *evt = dev_id; |
246 | 246 | ||
@@ -249,14 +249,14 @@ static irqreturn_t s5p_clock_event_isr(int irq, void *dev_id) | |||
249 | return IRQ_HANDLED; | 249 | return IRQ_HANDLED; |
250 | } | 250 | } |
251 | 251 | ||
252 | static struct irqaction s5p_clock_event_irq = { | 252 | static struct irqaction samsung_clock_event_irq = { |
253 | .name = "s5p_time_irq", | 253 | .name = "samsung_time_irq", |
254 | .flags = IRQF_DISABLED | IRQF_TIMER | IRQF_IRQPOLL, | 254 | .flags = IRQF_DISABLED | IRQF_TIMER | IRQF_IRQPOLL, |
255 | .handler = s5p_clock_event_isr, | 255 | .handler = samsung_clock_event_isr, |
256 | .dev_id = &time_event_device, | 256 | .dev_id = &time_event_device, |
257 | }; | 257 | }; |
258 | 258 | ||
259 | static void __init s5p_clockevent_init(void) | 259 | static void __init samsung_clockevent_init(void) |
260 | { | 260 | { |
261 | unsigned long pclk; | 261 | unsigned long pclk; |
262 | unsigned long clock_rate; | 262 | unsigned long clock_rate; |
@@ -267,8 +267,8 @@ static void __init s5p_clockevent_init(void) | |||
267 | 267 | ||
268 | tscaler = clk_get_parent(tdiv_event); | 268 | tscaler = clk_get_parent(tdiv_event); |
269 | 269 | ||
270 | clk_set_rate(tscaler, pclk / 2); | 270 | clk_set_rate(tscaler, pclk / TSCALER_DIV); |
271 | clk_set_rate(tdiv_event, pclk / 2); | 271 | clk_set_rate(tdiv_event, pclk / TDIV); |
272 | clk_set_parent(tin_event, tdiv_event); | 272 | clk_set_parent(tin_event, tdiv_event); |
273 | 273 | ||
274 | clock_rate = clk_get_rate(tin_event); | 274 | clock_rate = clk_get_rate(tin_event); |
@@ -278,22 +278,22 @@ static void __init s5p_clockevent_init(void) | |||
278 | clockevents_config_and_register(&time_event_device, clock_rate, 1, -1); | 278 | clockevents_config_and_register(&time_event_device, clock_rate, 1, -1); |
279 | 279 | ||
280 | irq_number = timer_source.event_id + IRQ_TIMER0; | 280 | irq_number = timer_source.event_id + IRQ_TIMER0; |
281 | setup_irq(irq_number, &s5p_clock_event_irq); | 281 | setup_irq(irq_number, &samsung_clock_event_irq); |
282 | } | 282 | } |
283 | 283 | ||
284 | static void __iomem *s5p_timer_reg(void) | 284 | static void __iomem *samsung_timer_reg(void) |
285 | { | 285 | { |
286 | unsigned long offset = 0; | 286 | unsigned long offset = 0; |
287 | 287 | ||
288 | switch (timer_source.source_id) { | 288 | switch (timer_source.source_id) { |
289 | case S5P_PWM0: | 289 | case SAMSUNG_PWM0: |
290 | case S5P_PWM1: | 290 | case SAMSUNG_PWM1: |
291 | case S5P_PWM2: | 291 | case SAMSUNG_PWM2: |
292 | case S5P_PWM3: | 292 | case SAMSUNG_PWM3: |
293 | offset = (timer_source.source_id * 0x0c) + 0x14; | 293 | offset = (timer_source.source_id * 0x0c) + 0x14; |
294 | break; | 294 | break; |
295 | 295 | ||
296 | case S5P_PWM4: | 296 | case SAMSUNG_PWM4: |
297 | offset = 0x40; | 297 | offset = 0x40; |
298 | break; | 298 | break; |
299 | 299 | ||
@@ -312,9 +312,9 @@ static void __iomem *s5p_timer_reg(void) | |||
312 | * this wraps around for now, since it is just a relative time | 312 | * this wraps around for now, since it is just a relative time |
313 | * stamp. (Inspired by U300 implementation.) | 313 | * stamp. (Inspired by U300 implementation.) |
314 | */ | 314 | */ |
315 | static u32 notrace s5p_read_sched_clock(void) | 315 | static u32 notrace samsung_read_sched_clock(void) |
316 | { | 316 | { |
317 | void __iomem *reg = s5p_timer_reg(); | 317 | void __iomem *reg = samsung_timer_reg(); |
318 | 318 | ||
319 | if (!reg) | 319 | if (!reg) |
320 | return 0; | 320 | return 0; |
@@ -322,29 +322,29 @@ static u32 notrace s5p_read_sched_clock(void) | |||
322 | return ~__raw_readl(reg); | 322 | return ~__raw_readl(reg); |
323 | } | 323 | } |
324 | 324 | ||
325 | static void __init s5p_clocksource_init(void) | 325 | static void __init samsung_clocksource_init(void) |
326 | { | 326 | { |
327 | unsigned long pclk; | 327 | unsigned long pclk; |
328 | unsigned long clock_rate; | 328 | unsigned long clock_rate; |
329 | 329 | ||
330 | pclk = clk_get_rate(timerclk); | 330 | pclk = clk_get_rate(timerclk); |
331 | 331 | ||
332 | clk_set_rate(tdiv_source, pclk / 2); | 332 | clk_set_rate(tdiv_source, pclk / TDIV); |
333 | clk_set_parent(tin_source, tdiv_source); | 333 | clk_set_parent(tin_source, tdiv_source); |
334 | 334 | ||
335 | clock_rate = clk_get_rate(tin_source); | 335 | clock_rate = clk_get_rate(tin_source); |
336 | 336 | ||
337 | s5p_time_setup(timer_source.source_id, TCNT_MAX); | 337 | samsung_time_setup(timer_source.source_id, TCNT_MAX); |
338 | s5p_time_start(timer_source.source_id, PERIODIC); | 338 | samsung_time_start(timer_source.source_id, PERIODIC); |
339 | 339 | ||
340 | setup_sched_clock(s5p_read_sched_clock, 32, clock_rate); | 340 | setup_sched_clock(samsung_read_sched_clock, TSIZE, clock_rate); |
341 | 341 | ||
342 | if (clocksource_mmio_init(s5p_timer_reg(), "s5p_clocksource_timer", | 342 | if (clocksource_mmio_init(samsung_timer_reg(), "samsung_clocksource_timer", |
343 | clock_rate, 250, 32, clocksource_mmio_readl_down)) | 343 | clock_rate, 250, TSIZE, clocksource_mmio_readl_down)) |
344 | panic("s5p_clocksource_timer: can't register clocksource\n"); | 344 | panic("samsung_clocksource_timer: can't register clocksource\n"); |
345 | } | 345 | } |
346 | 346 | ||
347 | static void __init s5p_timer_resources(void) | 347 | static void __init samsung_timer_resources(void) |
348 | { | 348 | { |
349 | 349 | ||
350 | unsigned long event_id = timer_source.event_id; | 350 | unsigned long event_id = timer_source.event_id; |
@@ -386,9 +386,9 @@ static void __init s5p_timer_resources(void) | |||
386 | clk_enable(tin_source); | 386 | clk_enable(tin_source); |
387 | } | 387 | } |
388 | 388 | ||
389 | void __init s5p_timer_init(void) | 389 | void __init samsung_timer_init(void) |
390 | { | 390 | { |
391 | s5p_timer_resources(); | 391 | samsung_timer_resources(); |
392 | s5p_clockevent_init(); | 392 | samsung_clockevent_init(); |
393 | s5p_clocksource_init(); | 393 | samsung_clocksource_init(); |
394 | } | 394 | } |
diff --git a/arch/arm/plat-samsung/time.c b/arch/arm/plat-samsung/time.c deleted file mode 100644 index 73defd00c3e4..000000000000 --- a/arch/arm/plat-samsung/time.c +++ /dev/null | |||
@@ -1,287 +0,0 @@ | |||
1 | /* linux/arch/arm/plat-samsung/time.c | ||
2 | * | ||
3 | * Copyright (C) 2003-2005 Simtec Electronics | ||
4 | * Ben Dooks, <ben@simtec.co.uk> | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License as published by | ||
8 | * the Free Software Foundation; either version 2 of the License, or | ||
9 | * (at your option) any later version. | ||
10 | * | ||
11 | * This program is distributed in the hope that it will be useful, | ||
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
14 | * GNU General Public License for more details. | ||
15 | * | ||
16 | * You should have received a copy of the GNU General Public License | ||
17 | * along with this program; if not, write to the Free Software | ||
18 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
19 | */ | ||
20 | |||
21 | #include <linux/kernel.h> | ||
22 | #include <linux/sched.h> | ||
23 | #include <linux/init.h> | ||
24 | #include <linux/interrupt.h> | ||
25 | #include <linux/irq.h> | ||
26 | #include <linux/err.h> | ||
27 | #include <linux/clk.h> | ||
28 | #include <linux/io.h> | ||
29 | #include <linux/platform_device.h> | ||
30 | #include <linux/syscore_ops.h> | ||
31 | |||
32 | #include <asm/mach-types.h> | ||
33 | |||
34 | #include <asm/irq.h> | ||
35 | #include <mach/map.h> | ||
36 | #include <plat/regs-timer.h> | ||
37 | #include <mach/regs-irq.h> | ||
38 | #include <asm/mach/time.h> | ||
39 | #include <mach/tick.h> | ||
40 | |||
41 | #include <plat/clock.h> | ||
42 | #include <plat/cpu.h> | ||
43 | |||
44 | static unsigned long timer_startval; | ||
45 | static unsigned long timer_usec_ticks; | ||
46 | |||
47 | #ifndef TICK_MAX | ||
48 | #define TICK_MAX (0xffff) | ||
49 | #endif | ||
50 | |||
51 | #define TIMER_USEC_SHIFT 16 | ||
52 | |||
53 | /* we use the shifted arithmetic to work out the ratio of timer ticks | ||
54 | * to usecs, as often the peripheral clock is not a nice even multiple | ||
55 | * of 1MHz. | ||
56 | * | ||
57 | * shift of 14 and 15 are too low for the 12MHz, 16 seems to be ok | ||
58 | * for the current HZ value of 200 without producing overflows. | ||
59 | * | ||
60 | * Original patch by Dimitry Andric, updated by Ben Dooks | ||
61 | */ | ||
62 | |||
63 | |||
64 | /* timer_mask_usec_ticks | ||
65 | * | ||
66 | * given a clock and divisor, make the value to pass into timer_ticks_to_usec | ||
67 | * to scale the ticks into usecs | ||
68 | */ | ||
69 | |||
70 | static inline unsigned long | ||
71 | timer_mask_usec_ticks(unsigned long scaler, unsigned long pclk) | ||
72 | { | ||
73 | unsigned long den = pclk / 1000; | ||
74 | |||
75 | return ((1000 << TIMER_USEC_SHIFT) * scaler + (den >> 1)) / den; | ||
76 | } | ||
77 | |||
78 | /* timer_ticks_to_usec | ||
79 | * | ||
80 | * convert timer ticks to usec. | ||
81 | */ | ||
82 | |||
83 | static inline unsigned long timer_ticks_to_usec(unsigned long ticks) | ||
84 | { | ||
85 | unsigned long res; | ||
86 | |||
87 | res = ticks * timer_usec_ticks; | ||
88 | res += 1 << (TIMER_USEC_SHIFT - 4); /* round up slightly */ | ||
89 | |||
90 | return res >> TIMER_USEC_SHIFT; | ||
91 | } | ||
92 | |||
93 | /*** | ||
94 | * Returns microsecond since last clock interrupt. Note that interrupts | ||
95 | * will have been disabled by do_gettimeoffset() | ||
96 | * IRQs are disabled before entering here from do_gettimeofday() | ||
97 | */ | ||
98 | |||
99 | static u32 s3c2410_gettimeoffset(void) | ||
100 | { | ||
101 | unsigned long tdone; | ||
102 | unsigned long tval; | ||
103 | |||
104 | /* work out how many ticks have gone since last timer interrupt */ | ||
105 | |||
106 | tval = __raw_readl(S3C2410_TCNTO(4)); | ||
107 | tdone = timer_startval - tval; | ||
108 | |||
109 | /* check to see if there is an interrupt pending */ | ||
110 | |||
111 | if (s3c24xx_ostimer_pending()) { | ||
112 | /* re-read the timer, and try and fix up for the missed | ||
113 | * interrupt. Note, the interrupt may go off before the | ||
114 | * timer has re-loaded from wrapping. | ||
115 | */ | ||
116 | |||
117 | tval = __raw_readl(S3C2410_TCNTO(4)); | ||
118 | tdone = timer_startval - tval; | ||
119 | |||
120 | if (tval != 0) | ||
121 | tdone += timer_startval; | ||
122 | } | ||
123 | |||
124 | return timer_ticks_to_usec(tdone) * 1000; | ||
125 | } | ||
126 | |||
127 | |||
128 | /* | ||
129 | * IRQ handler for the timer | ||
130 | */ | ||
131 | static irqreturn_t | ||
132 | s3c2410_timer_interrupt(int irq, void *dev_id) | ||
133 | { | ||
134 | timer_tick(); | ||
135 | return IRQ_HANDLED; | ||
136 | } | ||
137 | |||
138 | static struct irqaction s3c2410_timer_irq = { | ||
139 | .name = "S3C2410 Timer Tick", | ||
140 | .flags = IRQF_DISABLED | IRQF_TIMER | IRQF_IRQPOLL, | ||
141 | .handler = s3c2410_timer_interrupt, | ||
142 | }; | ||
143 | |||
144 | #define use_tclk1_12() ( \ | ||
145 | machine_is_bast() || \ | ||
146 | machine_is_vr1000() || \ | ||
147 | machine_is_anubis() || \ | ||
148 | machine_is_osiris()) | ||
149 | |||
150 | static struct clk *tin; | ||
151 | static struct clk *tdiv; | ||
152 | static struct clk *timerclk; | ||
153 | |||
154 | /* | ||
155 | * Set up timer interrupt, and return the current time in seconds. | ||
156 | * | ||
157 | * Currently we only use timer4, as it is the only timer which has no | ||
158 | * other function that can be exploited externally | ||
159 | */ | ||
160 | static void s3c2410_timer_setup (void) | ||
161 | { | ||
162 | unsigned long tcon; | ||
163 | unsigned long tcnt; | ||
164 | unsigned long tcfg1; | ||
165 | unsigned long tcfg0; | ||
166 | |||
167 | tcnt = TICK_MAX; /* default value for tcnt */ | ||
168 | |||
169 | /* configure the system for whichever machine is in use */ | ||
170 | |||
171 | if (use_tclk1_12()) { | ||
172 | /* timer is at 12MHz, scaler is 1 */ | ||
173 | timer_usec_ticks = timer_mask_usec_ticks(1, 12000000); | ||
174 | tcnt = 12000000 / HZ; | ||
175 | |||
176 | tcfg1 = __raw_readl(S3C2410_TCFG1); | ||
177 | tcfg1 &= ~S3C2410_TCFG1_MUX4_MASK; | ||
178 | tcfg1 |= S3C2410_TCFG1_MUX4_TCLK1; | ||
179 | __raw_writel(tcfg1, S3C2410_TCFG1); | ||
180 | } else { | ||
181 | unsigned long pclk; | ||
182 | struct clk *tscaler; | ||
183 | |||
184 | /* for the h1940 (and others), we use the pclk from the core | ||
185 | * to generate the timer values. since values around 50 to | ||
186 | * 70MHz are not values we can directly generate the timer | ||
187 | * value from, we need to pre-scale and divide before using it. | ||
188 | * | ||
189 | * for instance, using 50.7MHz and dividing by 6 gives 8.45MHz | ||
190 | * (8.45 ticks per usec) | ||
191 | */ | ||
192 | |||
193 | pclk = clk_get_rate(timerclk); | ||
194 | |||
195 | /* configure clock tick */ | ||
196 | |||
197 | timer_usec_ticks = timer_mask_usec_ticks(6, pclk); | ||
198 | |||
199 | tscaler = clk_get_parent(tdiv); | ||
200 | |||
201 | clk_set_rate(tscaler, pclk / 3); | ||
202 | clk_set_rate(tdiv, pclk / 6); | ||
203 | clk_set_parent(tin, tdiv); | ||
204 | |||
205 | tcnt = clk_get_rate(tin) / HZ; | ||
206 | } | ||
207 | |||
208 | tcon = __raw_readl(S3C2410_TCON); | ||
209 | tcfg0 = __raw_readl(S3C2410_TCFG0); | ||
210 | tcfg1 = __raw_readl(S3C2410_TCFG1); | ||
211 | |||
212 | /* timers reload after counting zero, so reduce the count by 1 */ | ||
213 | |||
214 | tcnt--; | ||
215 | |||
216 | printk(KERN_DEBUG "timer tcon=%08lx, tcnt %04lx, tcfg %08lx,%08lx, usec %08lx\n", | ||
217 | tcon, tcnt, tcfg0, tcfg1, timer_usec_ticks); | ||
218 | |||
219 | /* check to see if timer is within 16bit range... */ | ||
220 | if (tcnt > TICK_MAX) { | ||
221 | panic("setup_timer: HZ is too small, cannot configure timer!"); | ||
222 | return; | ||
223 | } | ||
224 | |||
225 | __raw_writel(tcfg1, S3C2410_TCFG1); | ||
226 | __raw_writel(tcfg0, S3C2410_TCFG0); | ||
227 | |||
228 | timer_startval = tcnt; | ||
229 | __raw_writel(tcnt, S3C2410_TCNTB(4)); | ||
230 | |||
231 | /* ensure timer is stopped... */ | ||
232 | |||
233 | tcon &= ~(7<<20); | ||
234 | tcon |= S3C2410_TCON_T4RELOAD; | ||
235 | tcon |= S3C2410_TCON_T4MANUALUPD; | ||
236 | |||
237 | __raw_writel(tcon, S3C2410_TCON); | ||
238 | __raw_writel(tcnt, S3C2410_TCNTB(4)); | ||
239 | __raw_writel(tcnt, S3C2410_TCMPB(4)); | ||
240 | |||
241 | /* start the timer running */ | ||
242 | tcon |= S3C2410_TCON_T4START; | ||
243 | tcon &= ~S3C2410_TCON_T4MANUALUPD; | ||
244 | __raw_writel(tcon, S3C2410_TCON); | ||
245 | } | ||
246 | |||
247 | static void __init s3c2410_timer_resources(void) | ||
248 | { | ||
249 | struct platform_device tmpdev; | ||
250 | |||
251 | tmpdev.dev.bus = &platform_bus_type; | ||
252 | tmpdev.id = 4; | ||
253 | |||
254 | timerclk = clk_get(NULL, "timers"); | ||
255 | if (IS_ERR(timerclk)) | ||
256 | panic("failed to get clock for system timer"); | ||
257 | |||
258 | clk_enable(timerclk); | ||
259 | |||
260 | if (!use_tclk1_12()) { | ||
261 | tmpdev.id = 4; | ||
262 | tmpdev.dev.init_name = "s3c24xx-pwm.4"; | ||
263 | tin = clk_get(&tmpdev.dev, "pwm-tin"); | ||
264 | if (IS_ERR(tin)) | ||
265 | panic("failed to get pwm-tin clock for system timer"); | ||
266 | |||
267 | tdiv = clk_get(&tmpdev.dev, "pwm-tdiv"); | ||
268 | if (IS_ERR(tdiv)) | ||
269 | panic("failed to get pwm-tdiv clock for system timer"); | ||
270 | } | ||
271 | |||
272 | clk_enable(tin); | ||
273 | } | ||
274 | |||
275 | static struct syscore_ops s3c24xx_syscore_ops = { | ||
276 | .resume = s3c2410_timer_setup, | ||
277 | }; | ||
278 | |||
279 | void __init s3c24xx_timer_init(void) | ||
280 | { | ||
281 | arch_gettimeoffset = s3c2410_gettimeoffset; | ||
282 | |||
283 | s3c2410_timer_resources(); | ||
284 | s3c2410_timer_setup(); | ||
285 | setup_irq(IRQ_TIMER4, &s3c2410_timer_irq); | ||
286 | register_syscore_ops(&s3c24xx_syscore_ops); | ||
287 | } | ||