aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-s3c64xx/mach-smartq.c
diff options
context:
space:
mode:
authorMaurus Cuelenaere <mcuelenaere@gmail.com>2010-08-13 15:17:52 -0400
committerBen Dooks <ben-linux@fluff.org>2010-08-14 11:13:06 -0400
commit49f91b9ed14f6c2dd90d99c65a2ab47bd93652b1 (patch)
tree645b41420616623f4113de7a5ad40074d0eccf47 /arch/arm/mach-s3c64xx/mach-smartq.c
parentce611d7b98eec03b2b1036ac55b7604b268154d8 (diff)
ARM: S3C64XX: Move SmartQ LCD control platform definition to shared file
This shares the common LCD control platform definition used in the SmartQ 5 and 7. This also corrects it as a GPIO bitbanged SPI device instead of an I²C one, which was wrong. Signed-off-by: Maurus Cuelenaere <mcuelenaere@gmail.com> Signed-off-by: Ben Dooks <ben-linux@fluff.org>
Diffstat (limited to 'arch/arm/mach-s3c64xx/mach-smartq.c')
-rw-r--r--arch/arm/mach-s3c64xx/mach-smartq.c32
1 files changed, 30 insertions, 2 deletions
diff --git a/arch/arm/mach-s3c64xx/mach-smartq.c b/arch/arm/mach-s3c64xx/mach-smartq.c
index 028d080dcd35..54309dad3e0e 100644
--- a/arch/arm/mach-s3c64xx/mach-smartq.c
+++ b/arch/arm/mach-s3c64xx/mach-smartq.c
@@ -16,6 +16,7 @@
16#include <linux/platform_device.h> 16#include <linux/platform_device.h>
17#include <linux/pwm_backlight.h> 17#include <linux/pwm_backlight.h>
18#include <linux/serial_core.h> 18#include <linux/serial_core.h>
19#include <linux/spi/spi_gpio.h>
19#include <linux/usb/gpio_vbus.h> 20#include <linux/usb/gpio_vbus.h>
20 21
21#include <asm/mach-types.h> 22#include <asm/mach-types.h>
@@ -184,6 +185,33 @@ static struct s3c_hwmon_pdata smartq_hwmon_pdata __initdata = {
184 }, 185 },
185}; 186};
186 187
188static int __init smartq_lcd_setup_gpio(void)
189{
190 int ret;
191
192 ret = gpio_request(S3C64XX_GPM(3), "LCD power");
193 if (ret < 0)
194 return ret;
195
196 /* turn power off */
197 gpio_direction_output(S3C64XX_GPM(3), 0);
198
199 return 0;
200}
201
202/* GPM0 -> CS */
203static struct spi_gpio_platform_data smartq_lcd_control = {
204 .sck = S3C64XX_GPM(1),
205 .mosi = S3C64XX_GPM(2),
206 .miso = S3C64XX_GPM(2),
207};
208
209static struct platform_device smartq_lcd_control_device = {
210 .name = "spi-gpio",
211 .id = 1,
212 .dev.platform_data = &smartq_lcd_control,
213};
214
187static void smartq_lcd_power_set(struct plat_lcd_data *pd, unsigned int power) 215static void smartq_lcd_power_set(struct plat_lcd_data *pd, unsigned int power)
188{ 216{
189 gpio_direction_output(S3C64XX_GPM(3), power); 217 gpio_direction_output(S3C64XX_GPM(3), power);
@@ -199,7 +227,6 @@ static struct platform_device smartq_lcd_power_device = {
199 .dev.platform_data = &smartq_lcd_power_data, 227 .dev.platform_data = &smartq_lcd_power_data,
200}; 228};
201 229
202
203static struct platform_device *smartq_devices[] __initdata = { 230static struct platform_device *smartq_devices[] __initdata = {
204 &s3c_device_hsmmc1, /* Init iNAND first, ... */ 231 &s3c_device_hsmmc1, /* Init iNAND first, ... */
205 &s3c_device_hsmmc0, /* ... then the external SD card */ 232 &s3c_device_hsmmc0, /* ... then the external SD card */
@@ -214,6 +241,7 @@ static struct platform_device *smartq_devices[] __initdata = {
214 &s3c_device_ts, 241 &s3c_device_ts,
215 &s3c_device_usb_hsotg, 242 &s3c_device_usb_hsotg,
216 &smartq_backlight_device, 243 &smartq_backlight_device,
244 &smartq_lcd_control_device,
217 &smartq_lcd_power_device, 245 &smartq_lcd_power_device,
218 &smartq_usb_otg_vbus_dev, 246 &smartq_usb_otg_vbus_dev,
219}; 247};
@@ -252,7 +280,6 @@ static int __init smartq_power_off_init(void)
252 /* leave power on */ 280 /* leave power on */
253 gpio_direction_output(S3C64XX_GPK(15), 0); 281 gpio_direction_output(S3C64XX_GPK(15), 0);
254 282
255
256 pm_power_off = smartq_power_off; 283 pm_power_off = smartq_power_off;
257 284
258 return ret; 285 return ret;
@@ -354,6 +381,7 @@ void __init smartq_machine_init(void)
354 s3c_sdhci2_set_platdata(&smartq_internal_hsmmc_pdata); 381 s3c_sdhci2_set_platdata(&smartq_internal_hsmmc_pdata);
355 s3c24xx_ts_set_platdata(&smartq_touchscreen_pdata); 382 s3c24xx_ts_set_platdata(&smartq_touchscreen_pdata);
356 383
384 WARN_ON(smartq_lcd_setup_gpio());
357 WARN_ON(smartq_power_off_init()); 385 WARN_ON(smartq_power_off_init());
358 WARN_ON(smartq_usb_host_init()); 386 WARN_ON(smartq_usb_host_init());
359 WARN_ON(smartq_usb_otg_init()); 387 WARN_ON(smartq_usb_otg_init());