diff options
author | Vasily Khoruzhick <anarsoul@gmail.com> | 2010-09-27 02:28:00 -0400 |
---|---|---|
committer | Ben Dooks <ben-linux@fluff.org> | 2010-10-29 19:45:28 -0400 |
commit | 53193dd3ba3c7dfdd7fdf2b068c8f92cc46a5693 (patch) | |
tree | 9ee120b4bca209047fb37d4a4efc6a1b9ffb7df6 /arch/arm/mach-s3c2410/mach-h1940.c | |
parent | 48cd65a6a020292e1ab5d0f5ba96571c858964e6 (diff) |
ARM: h1940: Fix backlight and LCD power functions
Current implementation of LCD and backlight power control functions
is not complete, as result PDA consumes power in suspend.
Fix this issue by managing state of some latch bits, just like
WinMobile does.
Signed-off-by: Vasily Khoruzhick <anarsoul@gmail.com>
Signed-off-by: Ben Dooks <ben-linux@fluff.org>
Diffstat (limited to 'arch/arm/mach-s3c2410/mach-h1940.c')
-rw-r--r-- | arch/arm/mach-s3c2410/mach-h1940.c | 80 |
1 files changed, 65 insertions, 15 deletions
diff --git a/arch/arm/mach-s3c2410/mach-h1940.c b/arch/arm/mach-s3c2410/mach-h1940.c index cc8660ec8844..974c6e4fb6ad 100644 --- a/arch/arm/mach-s3c2410/mach-h1940.c +++ b/arch/arm/mach-s3c2410/mach-h1940.c | |||
@@ -106,13 +106,7 @@ static struct s3c2410_uartcfg h1940_uartcfgs[] __initdata = { | |||
106 | 106 | ||
107 | /* Board control latch control */ | 107 | /* Board control latch control */ |
108 | 108 | ||
109 | static unsigned int latch_state = H1940_LATCH_BIT(H1940_LATCH_LCD_P4) | | 109 | static unsigned int latch_state; |
110 | H1940_LATCH_BIT(H1940_LATCH_SM803_ENABLE) | | ||
111 | H1940_LATCH_BIT(H1940_LATCH_SDQ1) | | ||
112 | H1940_LATCH_BIT(H1940_LATCH_LCD_P1) | | ||
113 | H1940_LATCH_BIT(H1940_LATCH_LCD_P2) | | ||
114 | H1940_LATCH_BIT(H1940_LATCH_LCD_P3) | | ||
115 | H1940_LATCH_BIT(H1940_LATCH_MAX1698_nSHUTDOWN); | ||
116 | 110 | ||
117 | static void h1940_latch_control(unsigned int clear, unsigned int set) | 111 | static void h1940_latch_control(unsigned int clear, unsigned int set) |
118 | { | 112 | { |
@@ -275,15 +269,32 @@ static int h1940_backlight_init(struct device *dev) | |||
275 | gpio_direction_output(S3C2410_GPB(0), 0); | 269 | gpio_direction_output(S3C2410_GPB(0), 0); |
276 | s3c_gpio_setpull(S3C2410_GPB(0), S3C_GPIO_PULL_NONE); | 270 | s3c_gpio_setpull(S3C2410_GPB(0), S3C_GPIO_PULL_NONE); |
277 | s3c_gpio_cfgpin(S3C2410_GPB(0), S3C2410_GPB0_TOUT0); | 271 | s3c_gpio_cfgpin(S3C2410_GPB(0), S3C2410_GPB0_TOUT0); |
272 | gpio_set_value(H1940_LATCH_MAX1698_nSHUTDOWN, 1); | ||
278 | 273 | ||
279 | return 0; | 274 | return 0; |
280 | } | 275 | } |
281 | 276 | ||
277 | static int h1940_backlight_notify(struct device *dev, int brightness) | ||
278 | { | ||
279 | if (!brightness) { | ||
280 | gpio_direction_output(S3C2410_GPB(0), 1); | ||
281 | gpio_set_value(H1940_LATCH_MAX1698_nSHUTDOWN, 0); | ||
282 | } else { | ||
283 | gpio_direction_output(S3C2410_GPB(0), 0); | ||
284 | s3c_gpio_setpull(S3C2410_GPB(0), S3C_GPIO_PULL_NONE); | ||
285 | s3c_gpio_cfgpin(S3C2410_GPB(0), S3C2410_GPB0_TOUT0); | ||
286 | gpio_set_value(H1940_LATCH_MAX1698_nSHUTDOWN, 1); | ||
287 | } | ||
288 | return brightness; | ||
289 | } | ||
290 | |||
282 | static void h1940_backlight_exit(struct device *dev) | 291 | static void h1940_backlight_exit(struct device *dev) |
283 | { | 292 | { |
284 | gpio_direction_output(S3C2410_GPB(0), 1); | 293 | gpio_direction_output(S3C2410_GPB(0), 1); |
294 | gpio_set_value(H1940_LATCH_MAX1698_nSHUTDOWN, 0); | ||
285 | } | 295 | } |
286 | 296 | ||
297 | |||
287 | static struct platform_pwm_backlight_data backlight_data = { | 298 | static struct platform_pwm_backlight_data backlight_data = { |
288 | .pwm_id = 0, | 299 | .pwm_id = 0, |
289 | .max_brightness = 100, | 300 | .max_brightness = 100, |
@@ -291,6 +302,7 @@ static struct platform_pwm_backlight_data backlight_data = { | |||
291 | /* tcnt = 0x31 */ | 302 | /* tcnt = 0x31 */ |
292 | .pwm_period_ns = 36296, | 303 | .pwm_period_ns = 36296, |
293 | .init = h1940_backlight_init, | 304 | .init = h1940_backlight_init, |
305 | .notify = h1940_backlight_notify, | ||
294 | .exit = h1940_backlight_exit, | 306 | .exit = h1940_backlight_exit, |
295 | }; | 307 | }; |
296 | 308 | ||
@@ -309,19 +321,37 @@ static void h1940_lcd_power_set(struct plat_lcd_data *pd, | |||
309 | int value; | 321 | int value; |
310 | 322 | ||
311 | if (!power) { | 323 | if (!power) { |
312 | /* set to 3ec */ | 324 | gpio_set_value(S3C2410_GPC(0), 0); |
313 | gpio_direction_output(S3C2410_GPC(0), 0); | ||
314 | /* wait for 3ac */ | 325 | /* wait for 3ac */ |
315 | do { | 326 | do { |
316 | value = gpio_get_value(S3C2410_GPC(6)); | 327 | value = gpio_get_value(S3C2410_GPC(6)); |
317 | } while (value); | 328 | } while (value); |
318 | /* set to 38c */ | 329 | |
319 | gpio_direction_output(S3C2410_GPC(5), 0); | 330 | gpio_set_value(H1940_LATCH_LCD_P2, 0); |
331 | gpio_set_value(H1940_LATCH_LCD_P3, 0); | ||
332 | gpio_set_value(H1940_LATCH_LCD_P4, 0); | ||
333 | |||
334 | gpio_direction_output(S3C2410_GPC(1), 0); | ||
335 | gpio_direction_output(S3C2410_GPC(4), 0); | ||
336 | |||
337 | gpio_set_value(H1940_LATCH_LCD_P1, 0); | ||
338 | gpio_set_value(H1940_LATCH_LCD_P0, 0); | ||
339 | |||
340 | gpio_set_value(S3C2410_GPC(5), 0); | ||
341 | |||
320 | } else { | 342 | } else { |
321 | /* Set to 3ac */ | 343 | gpio_set_value(H1940_LATCH_LCD_P0, 1); |
322 | gpio_direction_output(S3C2410_GPC(5), 1); | 344 | gpio_set_value(H1940_LATCH_LCD_P1, 1); |
323 | /* Set to 3ad */ | 345 | |
324 | gpio_direction_output(S3C2410_GPC(0), 1); | 346 | s3c_gpio_cfgpin(S3C2410_GPC(1), S3C_GPIO_SFN(2)); |
347 | s3c_gpio_cfgpin(S3C2410_GPC(4), S3C_GPIO_SFN(2)); | ||
348 | |||
349 | gpio_set_value(S3C2410_GPC(5), 1); | ||
350 | gpio_set_value(S3C2410_GPC(0), 1); | ||
351 | |||
352 | gpio_set_value(H1940_LATCH_LCD_P3, 1); | ||
353 | gpio_set_value(H1940_LATCH_LCD_P2, 1); | ||
354 | gpio_set_value(H1940_LATCH_LCD_P4, 1); | ||
325 | } | 355 | } |
326 | } | 356 | } |
327 | 357 | ||
@@ -366,6 +396,8 @@ static void __init h1940_map_io(void) | |||
366 | #endif | 396 | #endif |
367 | s3c_pm_init(); | 397 | s3c_pm_init(); |
368 | 398 | ||
399 | /* Add latch gpio chip, set latch initial value */ | ||
400 | h1940_latch_control(0, 0); | ||
369 | WARN_ON(gpiochip_add(&h1940_latch_gpiochip)); | 401 | WARN_ON(gpiochip_add(&h1940_latch_gpiochip)); |
370 | } | 402 | } |
371 | 403 | ||
@@ -404,9 +436,27 @@ static void __init h1940_init(void) | |||
404 | writel(tmp, S3C2410_UPLLCON); | 436 | writel(tmp, S3C2410_UPLLCON); |
405 | 437 | ||
406 | gpio_request(S3C2410_GPC(0), "LCD power"); | 438 | gpio_request(S3C2410_GPC(0), "LCD power"); |
439 | gpio_request(S3C2410_GPC(1), "LCD power"); | ||
440 | gpio_request(S3C2410_GPC(4), "LCD power"); | ||
407 | gpio_request(S3C2410_GPC(5), "LCD power"); | 441 | gpio_request(S3C2410_GPC(5), "LCD power"); |
408 | gpio_request(S3C2410_GPC(6), "LCD power"); | 442 | gpio_request(S3C2410_GPC(6), "LCD power"); |
443 | gpio_request(H1940_LATCH_LCD_P0, "LCD power"); | ||
444 | gpio_request(H1940_LATCH_LCD_P1, "LCD power"); | ||
445 | gpio_request(H1940_LATCH_LCD_P2, "LCD power"); | ||
446 | gpio_request(H1940_LATCH_LCD_P3, "LCD power"); | ||
447 | gpio_request(H1940_LATCH_LCD_P4, "LCD power"); | ||
448 | gpio_request(H1940_LATCH_MAX1698_nSHUTDOWN, "LCD power"); | ||
449 | gpio_direction_output(S3C2410_GPC(0), 0); | ||
450 | gpio_direction_output(S3C2410_GPC(1), 0); | ||
451 | gpio_direction_output(S3C2410_GPC(4), 0); | ||
452 | gpio_direction_output(S3C2410_GPC(5), 0); | ||
409 | gpio_direction_input(S3C2410_GPC(6)); | 453 | gpio_direction_input(S3C2410_GPC(6)); |
454 | gpio_direction_output(H1940_LATCH_LCD_P0, 0); | ||
455 | gpio_direction_output(H1940_LATCH_LCD_P1, 0); | ||
456 | gpio_direction_output(H1940_LATCH_LCD_P2, 0); | ||
457 | gpio_direction_output(H1940_LATCH_LCD_P3, 0); | ||
458 | gpio_direction_output(H1940_LATCH_LCD_P4, 0); | ||
459 | gpio_direction_output(H1940_LATCH_MAX1698_nSHUTDOWN, 0); | ||
410 | 460 | ||
411 | gpio_request(H1940_LATCH_USB_DP, "USB pullup"); | 461 | gpio_request(H1940_LATCH_USB_DP, "USB pullup"); |
412 | gpio_direction_output(H1940_LATCH_USB_DP, 0); | 462 | gpio_direction_output(H1940_LATCH_USB_DP, 0); |