diff options
Diffstat (limited to 'arch/arm/mach-s3c24xx')
-rw-r--r-- | arch/arm/mach-s3c24xx/Kconfig | 6 | ||||
-rw-r--r-- | arch/arm/mach-s3c24xx/clock-s3c2410.c | 1 | ||||
-rw-r--r-- | arch/arm/mach-s3c24xx/clock-s3c2412.c | 1 | ||||
-rw-r--r-- | arch/arm/mach-s3c24xx/clock-s3c2416.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-s3c24xx/clock-s3c2443.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-s3c24xx/common.c | 27 | ||||
-rw-r--r-- | arch/arm/mach-s3c24xx/include/mach/map.h | 2 | ||||
-rw-r--r-- | arch/arm/mach-s3c24xx/mach-h1940.c | 4 | ||||
-rw-r--r-- | arch/arm/mach-s3c24xx/mach-rx1950.c | 5 |
9 files changed, 33 insertions, 17 deletions
diff --git a/arch/arm/mach-s3c24xx/Kconfig b/arch/arm/mach-s3c24xx/Kconfig index 7791ac76f945..dba2173e70f3 100644 --- a/arch/arm/mach-s3c24xx/Kconfig +++ b/arch/arm/mach-s3c24xx/Kconfig | |||
@@ -30,7 +30,6 @@ config CPU_S3C2410 | |||
30 | select S3C2410_CLOCK | 30 | select S3C2410_CLOCK |
31 | select ARM_S3C2410_CPUFREQ if ARM_S3C24XX_CPUFREQ | 31 | select ARM_S3C2410_CPUFREQ if ARM_S3C24XX_CPUFREQ |
32 | select S3C2410_PM if PM | 32 | select S3C2410_PM if PM |
33 | select SAMSUNG_HRT | ||
34 | select SAMSUNG_WDT_RESET | 33 | select SAMSUNG_WDT_RESET |
35 | help | 34 | help |
36 | Support for S3C2410 and S3C2410A family from the S3C24XX line | 35 | Support for S3C2410 and S3C2410A family from the S3C24XX line |
@@ -42,7 +41,6 @@ config CPU_S3C2412 | |||
42 | select CPU_LLSERIAL_S3C2440 | 41 | select CPU_LLSERIAL_S3C2440 |
43 | select S3C2412_DMA if S3C24XX_DMA | 42 | select S3C2412_DMA if S3C24XX_DMA |
44 | select S3C2412_PM if PM | 43 | select S3C2412_PM if PM |
45 | select SAMSUNG_HRT | ||
46 | help | 44 | help |
47 | Support for the S3C2412 and S3C2413 SoCs from the S3C24XX line | 45 | Support for the S3C2412 and S3C2413 SoCs from the S3C24XX line |
48 | 46 | ||
@@ -54,7 +52,6 @@ config CPU_S3C2416 | |||
54 | select S3C2443_COMMON | 52 | select S3C2443_COMMON |
55 | select S3C2443_DMA if S3C24XX_DMA | 53 | select S3C2443_DMA if S3C24XX_DMA |
56 | select SAMSUNG_CLKSRC | 54 | select SAMSUNG_CLKSRC |
57 | select SAMSUNG_HRT | ||
58 | help | 55 | help |
59 | Support for the S3C2416 SoC from the S3C24XX line | 56 | Support for the S3C2416 SoC from the S3C24XX line |
60 | 57 | ||
@@ -65,7 +62,6 @@ config CPU_S3C2440 | |||
65 | select S3C2410_CLOCK | 62 | select S3C2410_CLOCK |
66 | select S3C2410_PM if PM | 63 | select S3C2410_PM if PM |
67 | select S3C2440_DMA if S3C24XX_DMA | 64 | select S3C2440_DMA if S3C24XX_DMA |
68 | select SAMSUNG_HRT | ||
69 | help | 65 | help |
70 | Support for S3C2440 Samsung Mobile CPU based systems. | 66 | Support for S3C2440 Samsung Mobile CPU based systems. |
71 | 67 | ||
@@ -75,7 +71,6 @@ config CPU_S3C2442 | |||
75 | select CPU_LLSERIAL_S3C2440 | 71 | select CPU_LLSERIAL_S3C2440 |
76 | select S3C2410_CLOCK | 72 | select S3C2410_CLOCK |
77 | select S3C2410_PM if PM | 73 | select S3C2410_PM if PM |
78 | select SAMSUNG_HRT | ||
79 | help | 74 | help |
80 | Support for S3C2442 Samsung Mobile CPU based systems. | 75 | Support for S3C2442 Samsung Mobile CPU based systems. |
81 | 76 | ||
@@ -91,7 +86,6 @@ config CPU_S3C2443 | |||
91 | select S3C2443_COMMON | 86 | select S3C2443_COMMON |
92 | select S3C2443_DMA if S3C24XX_DMA | 87 | select S3C2443_DMA if S3C24XX_DMA |
93 | select SAMSUNG_CLKSRC | 88 | select SAMSUNG_CLKSRC |
94 | select SAMSUNG_HRT | ||
95 | help | 89 | help |
96 | Support for the S3C2443 SoC from the S3C24XX line | 90 | Support for the S3C2443 SoC from the S3C24XX line |
97 | 91 | ||
diff --git a/arch/arm/mach-s3c24xx/clock-s3c2410.c b/arch/arm/mach-s3c24xx/clock-s3c2410.c index 564553694b54..d39d3c787580 100644 --- a/arch/arm/mach-s3c24xx/clock-s3c2410.c +++ b/arch/arm/mach-s3c24xx/clock-s3c2410.c | |||
@@ -281,6 +281,5 @@ int __init s3c2410_baseclk_add(void) | |||
281 | (clkslow & S3C2410_CLKSLOW_MPLL_OFF) ? "off" : "on", | 281 | (clkslow & S3C2410_CLKSLOW_MPLL_OFF) ? "off" : "on", |
282 | (clkslow & S3C2410_CLKSLOW_UCLK_OFF) ? "off" : "on"); | 282 | (clkslow & S3C2410_CLKSLOW_UCLK_OFF) ? "off" : "on"); |
283 | 283 | ||
284 | s3c_pwmclk_init(); | ||
285 | return 0; | 284 | return 0; |
286 | } | 285 | } |
diff --git a/arch/arm/mach-s3c24xx/clock-s3c2412.c b/arch/arm/mach-s3c24xx/clock-s3c2412.c index 2cc017da88fe..d8f253f2b486 100644 --- a/arch/arm/mach-s3c24xx/clock-s3c2412.c +++ b/arch/arm/mach-s3c24xx/clock-s3c2412.c | |||
@@ -757,6 +757,5 @@ int __init s3c2412_baseclk_add(void) | |||
757 | } | 757 | } |
758 | 758 | ||
759 | clkdev_add_table(s3c2412_clk_lookup, ARRAY_SIZE(s3c2412_clk_lookup)); | 759 | clkdev_add_table(s3c2412_clk_lookup, ARRAY_SIZE(s3c2412_clk_lookup)); |
760 | s3c_pwmclk_init(); | ||
761 | return 0; | 760 | return 0; |
762 | } | 761 | } |
diff --git a/arch/arm/mach-s3c24xx/clock-s3c2416.c b/arch/arm/mach-s3c24xx/clock-s3c2416.c index 036056cea57c..d421a72920a5 100644 --- a/arch/arm/mach-s3c24xx/clock-s3c2416.c +++ b/arch/arm/mach-s3c24xx/clock-s3c2416.c | |||
@@ -168,6 +168,4 @@ void __init s3c2416_init_clocks(int xtal) | |||
168 | s3c24xx_register_clock(&hsmmc0_clk); | 168 | s3c24xx_register_clock(&hsmmc0_clk); |
169 | clkdev_add_table(s3c2416_clk_lookup, ARRAY_SIZE(s3c2416_clk_lookup)); | 169 | clkdev_add_table(s3c2416_clk_lookup, ARRAY_SIZE(s3c2416_clk_lookup)); |
170 | 170 | ||
171 | s3c_pwmclk_init(); | ||
172 | |||
173 | } | 171 | } |
diff --git a/arch/arm/mach-s3c24xx/clock-s3c2443.c b/arch/arm/mach-s3c24xx/clock-s3c2443.c index 0a53051b0787..76cd31f7804e 100644 --- a/arch/arm/mach-s3c24xx/clock-s3c2443.c +++ b/arch/arm/mach-s3c24xx/clock-s3c2443.c | |||
@@ -209,6 +209,4 @@ void __init s3c2443_init_clocks(int xtal) | |||
209 | s3c_register_clocks(init_clocks_off, ARRAY_SIZE(init_clocks_off)); | 209 | s3c_register_clocks(init_clocks_off, ARRAY_SIZE(init_clocks_off)); |
210 | s3c_disable_clocks(init_clocks_off, ARRAY_SIZE(init_clocks_off)); | 210 | s3c_disable_clocks(init_clocks_off, ARRAY_SIZE(init_clocks_off)); |
211 | clkdev_add_table(s3c2443_clk_lookup, ARRAY_SIZE(s3c2443_clk_lookup)); | 211 | clkdev_add_table(s3c2443_clk_lookup, ARRAY_SIZE(s3c2443_clk_lookup)); |
212 | |||
213 | s3c_pwmclk_init(); | ||
214 | } | 212 | } |
diff --git a/arch/arm/mach-s3c24xx/common.c b/arch/arm/mach-s3c24xx/common.c index c157103ed8eb..457261c98433 100644 --- a/arch/arm/mach-s3c24xx/common.c +++ b/arch/arm/mach-s3c24xx/common.c | |||
@@ -27,6 +27,7 @@ | |||
27 | #include <linux/interrupt.h> | 27 | #include <linux/interrupt.h> |
28 | #include <linux/ioport.h> | 28 | #include <linux/ioport.h> |
29 | #include <linux/serial_core.h> | 29 | #include <linux/serial_core.h> |
30 | #include <clocksource/samsung_pwm.h> | ||
30 | #include <linux/platform_device.h> | 31 | #include <linux/platform_device.h> |
31 | #include <linux/delay.h> | 32 | #include <linux/delay.h> |
32 | #include <linux/io.h> | 33 | #include <linux/io.h> |
@@ -49,6 +50,7 @@ | |||
49 | #include <plat/clock.h> | 50 | #include <plat/clock.h> |
50 | #include <plat/cpu-freq.h> | 51 | #include <plat/cpu-freq.h> |
51 | #include <plat/pll.h> | 52 | #include <plat/pll.h> |
53 | #include <plat/pwm-core.h> | ||
52 | 54 | ||
53 | #include "common.h" | 55 | #include "common.h" |
54 | 56 | ||
@@ -216,6 +218,13 @@ static void s3c24xx_default_idle(void) | |||
216 | S3C2410_CLKCON); | 218 | S3C2410_CLKCON); |
217 | } | 219 | } |
218 | 220 | ||
221 | static struct samsung_pwm_variant s3c24xx_pwm_variant = { | ||
222 | .bits = 16, | ||
223 | .div_base = 1, | ||
224 | .has_tint_cstat = false, | ||
225 | .tclk_mask = (1 << 4), | ||
226 | }; | ||
227 | |||
219 | void __init s3c24xx_init_io(struct map_desc *mach_desc, int size) | 228 | void __init s3c24xx_init_io(struct map_desc *mach_desc, int size) |
220 | { | 229 | { |
221 | arm_pm_idle = s3c24xx_default_idle; | 230 | arm_pm_idle = s3c24xx_default_idle; |
@@ -232,6 +241,24 @@ void __init s3c24xx_init_io(struct map_desc *mach_desc, int size) | |||
232 | s3c24xx_init_cpu(); | 241 | s3c24xx_init_cpu(); |
233 | 242 | ||
234 | s3c_init_cpu(samsung_cpu_id, cpu_ids, ARRAY_SIZE(cpu_ids)); | 243 | s3c_init_cpu(samsung_cpu_id, cpu_ids, ARRAY_SIZE(cpu_ids)); |
244 | |||
245 | samsung_pwm_set_platdata(&s3c24xx_pwm_variant); | ||
246 | } | ||
247 | |||
248 | void __init samsung_set_timer_source(unsigned int event, unsigned int source) | ||
249 | { | ||
250 | s3c24xx_pwm_variant.output_mask = BIT(SAMSUNG_PWM_NUM) - 1; | ||
251 | s3c24xx_pwm_variant.output_mask &= ~(BIT(event) | BIT(source)); | ||
252 | } | ||
253 | |||
254 | void __init samsung_timer_init(void) | ||
255 | { | ||
256 | unsigned int timer_irqs[SAMSUNG_PWM_NUM] = { | ||
257 | IRQ_TIMER0, IRQ_TIMER1, IRQ_TIMER2, IRQ_TIMER3, IRQ_TIMER4, | ||
258 | }; | ||
259 | |||
260 | samsung_pwm_clocksource_init(S3C_VA_TIMER, | ||
261 | timer_irqs, &s3c24xx_pwm_variant); | ||
235 | } | 262 | } |
236 | 263 | ||
237 | /* Serial port registrations */ | 264 | /* Serial port registrations */ |
diff --git a/arch/arm/mach-s3c24xx/include/mach/map.h b/arch/arm/mach-s3c24xx/include/mach/map.h index 8ba381f2dbe1..444793f0f5f1 100644 --- a/arch/arm/mach-s3c24xx/include/mach/map.h +++ b/arch/arm/mach-s3c24xx/include/mach/map.h | |||
@@ -167,4 +167,6 @@ | |||
167 | #define S3C_PA_SPI0 S3C2443_PA_SPI0 | 167 | #define S3C_PA_SPI0 S3C2443_PA_SPI0 |
168 | #define S3C_PA_SPI1 S3C2443_PA_SPI1 | 168 | #define S3C_PA_SPI1 S3C2443_PA_SPI1 |
169 | 169 | ||
170 | #define SAMSUNG_PA_TIMER S3C2410_PA_TIMER | ||
171 | |||
170 | #endif /* __ASM_ARCH_MAP_H */ | 172 | #endif /* __ASM_ARCH_MAP_H */ |
diff --git a/arch/arm/mach-s3c24xx/mach-h1940.c b/arch/arm/mach-s3c24xx/mach-h1940.c index af4334d6b4d5..74dd47988b41 100644 --- a/arch/arm/mach-s3c24xx/mach-h1940.c +++ b/arch/arm/mach-s3c24xx/mach-h1940.c | |||
@@ -512,7 +512,7 @@ static struct platform_pwm_backlight_data backlight_data = { | |||
512 | static struct platform_device h1940_backlight = { | 512 | static struct platform_device h1940_backlight = { |
513 | .name = "pwm-backlight", | 513 | .name = "pwm-backlight", |
514 | .dev = { | 514 | .dev = { |
515 | .parent = &s3c_device_timer[0].dev, | 515 | .parent = &samsung_device_pwm.dev, |
516 | .platform_data = &backlight_data, | 516 | .platform_data = &backlight_data, |
517 | }, | 517 | }, |
518 | .id = -1, | 518 | .id = -1, |
@@ -632,7 +632,7 @@ static struct platform_device *h1940_devices[] __initdata = { | |||
632 | &h1940_device_bluetooth, | 632 | &h1940_device_bluetooth, |
633 | &s3c_device_sdi, | 633 | &s3c_device_sdi, |
634 | &s3c_device_rtc, | 634 | &s3c_device_rtc, |
635 | &s3c_device_timer[0], | 635 | &samsung_device_pwm, |
636 | &h1940_backlight, | 636 | &h1940_backlight, |
637 | &h1940_lcd_powerdev, | 637 | &h1940_lcd_powerdev, |
638 | &s3c_device_adc, | 638 | &s3c_device_adc, |
diff --git a/arch/arm/mach-s3c24xx/mach-rx1950.c b/arch/arm/mach-s3c24xx/mach-rx1950.c index 44ca018e1f96..206b1f7546d1 100644 --- a/arch/arm/mach-s3c24xx/mach-rx1950.c +++ b/arch/arm/mach-s3c24xx/mach-rx1950.c | |||
@@ -530,7 +530,7 @@ static struct platform_pwm_backlight_data rx1950_backlight_data = { | |||
530 | static struct platform_device rx1950_backlight = { | 530 | static struct platform_device rx1950_backlight = { |
531 | .name = "pwm-backlight", | 531 | .name = "pwm-backlight", |
532 | .dev = { | 532 | .dev = { |
533 | .parent = &s3c_device_timer[0].dev, | 533 | .parent = &samsung_device_pwm.dev, |
534 | .platform_data = &rx1950_backlight_data, | 534 | .platform_data = &rx1950_backlight_data, |
535 | }, | 535 | }, |
536 | }; | 536 | }; |
@@ -717,8 +717,7 @@ static struct platform_device *rx1950_devices[] __initdata = { | |||
717 | &s3c_device_sdi, | 717 | &s3c_device_sdi, |
718 | &s3c_device_adc, | 718 | &s3c_device_adc, |
719 | &s3c_device_ts, | 719 | &s3c_device_ts, |
720 | &s3c_device_timer[0], | 720 | &samsung_device_pwm, |
721 | &s3c_device_timer[1], | ||
722 | &rx1950_backlight, | 721 | &rx1950_backlight, |
723 | &rx1950_device_gpiokeys, | 722 | &rx1950_device_gpiokeys, |
724 | &power_supply, | 723 | &power_supply, |