aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/arm/mach-s5p64x0/Kconfig1
-rw-r--r--arch/arm/mach-s5p64x0/mach-smdk6440.c43
2 files changed, 44 insertions, 0 deletions
diff --git a/arch/arm/mach-s5p64x0/Kconfig b/arch/arm/mach-s5p64x0/Kconfig
index 164d2783d381..be5888a0e20b 100644
--- a/arch/arm/mach-s5p64x0/Kconfig
+++ b/arch/arm/mach-s5p64x0/Kconfig
@@ -34,6 +34,7 @@ config MACH_SMDK6440
34 select S3C_DEV_WDT 34 select S3C_DEV_WDT
35 select S3C64XX_DEV_SPI 35 select S3C64XX_DEV_SPI
36 select SAMSUNG_DEV_ADC 36 select SAMSUNG_DEV_ADC
37 select SAMSUNG_DEV_PWM
37 select SAMSUNG_DEV_TS 38 select SAMSUNG_DEV_TS
38 select S5P64X0_SETUP_I2C1 39 select S5P64X0_SETUP_I2C1
39 help 40 help
diff --git a/arch/arm/mach-s5p64x0/mach-smdk6440.c b/arch/arm/mach-s5p64x0/mach-smdk6440.c
index e5beb84e2393..366dca4ec794 100644
--- a/arch/arm/mach-s5p64x0/mach-smdk6440.c
+++ b/arch/arm/mach-s5p64x0/mach-smdk6440.c
@@ -22,6 +22,7 @@
22#include <linux/module.h> 22#include <linux/module.h>
23#include <linux/clk.h> 23#include <linux/clk.h>
24#include <linux/gpio.h> 24#include <linux/gpio.h>
25#include <linux/pwm_backlight.h>
25 26
26#include <asm/mach/arch.h> 27#include <asm/mach/arch.h>
27#include <asm/mach/map.h> 28#include <asm/mach/map.h>
@@ -32,6 +33,7 @@
32#include <mach/map.h> 33#include <mach/map.h>
33#include <mach/regs-clock.h> 34#include <mach/regs-clock.h>
34#include <mach/i2c.h> 35#include <mach/i2c.h>
36#include <mach/regs-gpio.h>
35 37
36#include <plat/regs-serial.h> 38#include <plat/regs-serial.h>
37#include <plat/gpio-cfg.h> 39#include <plat/gpio-cfg.h>
@@ -88,6 +90,45 @@ static struct s3c2410_uartcfg smdk6440_uartcfgs[] __initdata = {
88 }, 90 },
89}; 91};
90 92
93static int smdk6440_backlight_init(struct device *dev)
94{
95 int ret;
96
97 ret = gpio_request(S5P6440_GPF(15), "Backlight");
98 if (ret) {
99 printk(KERN_ERR "failed to request GPF for PWM-OUT1\n");
100 return ret;
101 }
102
103 /* Configure GPIO pin with S5P6440_GPF15_PWM_TOUT1 */
104 s3c_gpio_cfgpin(S5P6440_GPF(15), S3C_GPIO_SFN(2));
105
106 return 0;
107}
108
109static void smdk6440_backlight_exit(struct device *dev)
110{
111 s3c_gpio_cfgpin(S5P6440_GPF(15), S3C_GPIO_OUTPUT);
112 gpio_free(S5P6440_GPF(15));
113}
114
115static struct platform_pwm_backlight_data smdk6440_backlight_data = {
116 .pwm_id = 1,
117 .max_brightness = 255,
118 .dft_brightness = 255,
119 .pwm_period_ns = 78770,
120 .init = smdk6440_backlight_init,
121 .exit = smdk6440_backlight_exit,
122};
123
124static struct platform_device smdk6440_backlight_device = {
125 .name = "pwm-backlight",
126 .dev = {
127 .parent = &s3c_device_timer[1].dev,
128 .platform_data = &smdk6440_backlight_data,
129 },
130};
131
91static struct platform_device *smdk6440_devices[] __initdata = { 132static struct platform_device *smdk6440_devices[] __initdata = {
92 &s3c_device_adc, 133 &s3c_device_adc,
93 &s3c_device_rtc, 134 &s3c_device_rtc,
@@ -97,6 +138,8 @@ static struct platform_device *smdk6440_devices[] __initdata = {
97 &s3c_device_wdt, 138 &s3c_device_wdt,
98 &samsung_asoc_dma, 139 &samsung_asoc_dma,
99 &s5p6440_device_iis, 140 &s5p6440_device_iis,
141 &s3c_device_timer[1],
142 &smdk6440_backlight_device,
100}; 143};
101 144
102static struct s3c2410_platform_i2c s5p6440_i2c0_data __initdata = { 145static struct s3c2410_platform_i2c s5p6440_i2c0_data __initdata = {