diff options
Diffstat (limited to 'arch/arm/mach-pxa/corgi_lcd.c')
-rw-r--r-- | arch/arm/mach-pxa/corgi_lcd.c | 132 |
1 files changed, 118 insertions, 14 deletions
diff --git a/arch/arm/mach-pxa/corgi_lcd.c b/arch/arm/mach-pxa/corgi_lcd.c index deac29c0029..bfe5efc11b8 100644 --- a/arch/arm/mach-pxa/corgi_lcd.c +++ b/arch/arm/mach-pxa/corgi_lcd.c | |||
@@ -1,10 +1,14 @@ | |||
1 | /* | 1 | /* |
2 | * linux/drivers/video/w100fb.c | 2 | * linux/drivers/video/w100fb.c |
3 | * | 3 | * |
4 | * Corgi LCD Specific Code for ATI Imageon w100 (Wallaby) | 4 | * Corgi/Spitz LCD Specific Code |
5 | * | 5 | * |
6 | * Copyright (C) 2005 Richard Purdie | 6 | * Copyright (C) 2005 Richard Purdie |
7 | * | 7 | * |
8 | * Connectivity: | ||
9 | * Corgi - LCD to ATI Imageon w100 (Wallaby) | ||
10 | * Spitz - LCD to PXA Framebuffer | ||
11 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | 12 | * 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 | 13 | * it under the terms of the GNU General Public License version 2 as |
10 | * published by the Free Software Foundation. | 14 | * published by the Free Software Foundation. |
@@ -14,9 +18,17 @@ | |||
14 | #include <linux/delay.h> | 18 | #include <linux/delay.h> |
15 | #include <linux/kernel.h> | 19 | #include <linux/kernel.h> |
16 | #include <linux/device.h> | 20 | #include <linux/device.h> |
21 | #include <linux/module.h> | ||
22 | #include <asm/mach-types.h> | ||
23 | #include <asm/arch/akita.h> | ||
17 | #include <asm/arch/corgi.h> | 24 | #include <asm/arch/corgi.h> |
25 | #include <asm/arch/hardware.h> | ||
26 | #include <asm/arch/pxa-regs.h> | ||
27 | #include <asm/arch/sharpsl.h> | ||
28 | #include <asm/arch/spitz.h> | ||
29 | #include <asm/hardware/scoop.h> | ||
18 | #include <asm/mach/sharpsl_param.h> | 30 | #include <asm/mach/sharpsl_param.h> |
19 | #include <video/w100fb.h> | 31 | #include "generic.h" |
20 | 32 | ||
21 | /* Register Addresses */ | 33 | /* Register Addresses */ |
22 | #define RESCTL_ADRS 0x00 | 34 | #define RESCTL_ADRS 0x00 |
@@ -134,10 +146,10 @@ static void lcdtg_set_common_voltage(u8 base_data, u8 data) | |||
134 | } | 146 | } |
135 | 147 | ||
136 | /* Set Phase Adjuct */ | 148 | /* Set Phase Adjuct */ |
137 | static void lcdtg_set_phadadj(struct w100fb_par *par) | 149 | static void lcdtg_set_phadadj(int mode) |
138 | { | 150 | { |
139 | int adj; | 151 | int adj; |
140 | switch(par->xres) { | 152 | switch(mode) { |
141 | case 480: | 153 | case 480: |
142 | case 640: | 154 | case 640: |
143 | /* Setting for VGA */ | 155 | /* Setting for VGA */ |
@@ -161,7 +173,7 @@ static void lcdtg_set_phadadj(struct w100fb_par *par) | |||
161 | 173 | ||
162 | static int lcd_inited; | 174 | static int lcd_inited; |
163 | 175 | ||
164 | static void lcdtg_hw_init(struct w100fb_par *par) | 176 | static void lcdtg_hw_init(int mode) |
165 | { | 177 | { |
166 | if (!lcd_inited) { | 178 | if (!lcd_inited) { |
167 | int comadj; | 179 | int comadj; |
@@ -215,7 +227,7 @@ static void lcdtg_hw_init(struct w100fb_par *par) | |||
215 | corgi_ssp_lcdtg_send(PICTRL_ADRS, 0); | 227 | corgi_ssp_lcdtg_send(PICTRL_ADRS, 0); |
216 | 228 | ||
217 | /* Set Phase Adjuct */ | 229 | /* Set Phase Adjuct */ |
218 | lcdtg_set_phadadj(par); | 230 | lcdtg_set_phadadj(mode); |
219 | 231 | ||
220 | /* Initialize for Input Signals from ATI */ | 232 | /* Initialize for Input Signals from ATI */ |
221 | corgi_ssp_lcdtg_send(POLCTRL_ADRS, POLCTRL_SYNC_POL_RISE | POLCTRL_EN_POL_RISE | 233 | corgi_ssp_lcdtg_send(POLCTRL_ADRS, POLCTRL_SYNC_POL_RISE | POLCTRL_EN_POL_RISE |
@@ -224,10 +236,10 @@ static void lcdtg_hw_init(struct w100fb_par *par) | |||
224 | 236 | ||
225 | lcd_inited=1; | 237 | lcd_inited=1; |
226 | } else { | 238 | } else { |
227 | lcdtg_set_phadadj(par); | 239 | lcdtg_set_phadadj(mode); |
228 | } | 240 | } |
229 | 241 | ||
230 | switch(par->xres) { | 242 | switch(mode) { |
231 | case 480: | 243 | case 480: |
232 | case 640: | 244 | case 640: |
233 | /* Set Lcd Resolution (VGA) */ | 245 | /* Set Lcd Resolution (VGA) */ |
@@ -242,7 +254,7 @@ static void lcdtg_hw_init(struct w100fb_par *par) | |||
242 | } | 254 | } |
243 | } | 255 | } |
244 | 256 | ||
245 | static void lcdtg_suspend(struct w100fb_par *par) | 257 | static void lcdtg_suspend(void) |
246 | { | 258 | { |
247 | /* 60Hz x 2 frame = 16.7msec x 2 = 33.4 msec */ | 259 | /* 60Hz x 2 frame = 16.7msec x 2 = 33.4 msec */ |
248 | mdelay(34); | 260 | mdelay(34); |
@@ -276,15 +288,30 @@ static void lcdtg_suspend(struct w100fb_par *par) | |||
276 | lcd_inited = 0; | 288 | lcd_inited = 0; |
277 | } | 289 | } |
278 | 290 | ||
279 | static struct w100_tg_info corgi_lcdtg_info = { | ||
280 | .change=lcdtg_hw_init, | ||
281 | .suspend=lcdtg_suspend, | ||
282 | .resume=lcdtg_hw_init, | ||
283 | }; | ||
284 | 291 | ||
285 | /* | 292 | /* |
286 | * Corgi w100 Frame Buffer Device | 293 | * Corgi w100 Frame Buffer Device |
287 | */ | 294 | */ |
295 | #ifdef CONFIG_PXA_SHARP_C7xx | ||
296 | |||
297 | #include <video/w100fb.h> | ||
298 | |||
299 | static void w100_lcdtg_suspend(struct w100fb_par *par) | ||
300 | { | ||
301 | lcdtg_suspend(); | ||
302 | } | ||
303 | |||
304 | static void w100_lcdtg_init(struct w100fb_par *par) | ||
305 | { | ||
306 | lcdtg_hw_init(par->xres); | ||
307 | } | ||
308 | |||
309 | |||
310 | static struct w100_tg_info corgi_lcdtg_info = { | ||
311 | .change = w100_lcdtg_init, | ||
312 | .suspend = w100_lcdtg_suspend, | ||
313 | .resume = w100_lcdtg_init, | ||
314 | }; | ||
288 | 315 | ||
289 | static struct w100_mem_info corgi_fb_mem = { | 316 | static struct w100_mem_info corgi_fb_mem = { |
290 | .ext_cntl = 0x00040003, | 317 | .ext_cntl = 0x00040003, |
@@ -394,3 +421,80 @@ struct platform_device corgifb_device = { | |||
394 | }, | 421 | }, |
395 | 422 | ||
396 | }; | 423 | }; |
424 | #endif | ||
425 | |||
426 | |||
427 | /* | ||
428 | * Spitz PXA Frame Buffer Device | ||
429 | */ | ||
430 | #ifdef CONFIG_PXA_SHARP_Cxx00 | ||
431 | |||
432 | #include <asm/arch/pxafb.h> | ||
433 | |||
434 | void spitz_lcd_power(int on) | ||
435 | { | ||
436 | if (on) | ||
437 | lcdtg_hw_init(480); | ||
438 | else | ||
439 | lcdtg_suspend(); | ||
440 | } | ||
441 | |||
442 | #endif | ||
443 | |||
444 | |||
445 | /* | ||
446 | * Corgi/Spitz Touchscreen to LCD interface | ||
447 | */ | ||
448 | static unsigned long (*get_hsync_time)(struct device *dev); | ||
449 | |||
450 | static void inline sharpsl_wait_sync(int gpio) | ||
451 | { | ||
452 | while((GPLR(gpio) & GPIO_bit(gpio)) == 0); | ||
453 | while((GPLR(gpio) & GPIO_bit(gpio)) != 0); | ||
454 | } | ||
455 | |||
456 | #ifdef CONFIG_PXA_SHARP_C7xx | ||
457 | unsigned long corgi_get_hsync_len(void) | ||
458 | { | ||
459 | if (!get_hsync_time) | ||
460 | get_hsync_time = symbol_get(w100fb_get_hsynclen); | ||
461 | if (!get_hsync_time) | ||
462 | return 0; | ||
463 | |||
464 | return get_hsync_time(&corgifb_device.dev); | ||
465 | } | ||
466 | |||
467 | void corgi_put_hsync(void) | ||
468 | { | ||
469 | if (get_hsync_time) | ||
470 | symbol_put(w100fb_get_hsynclen); | ||
471 | } | ||
472 | |||
473 | void corgi_wait_hsync(void) | ||
474 | { | ||
475 | sharpsl_wait_sync(CORGI_GPIO_HSYNC); | ||
476 | } | ||
477 | #endif | ||
478 | |||
479 | #ifdef CONFIG_PXA_SHARP_Cxx00 | ||
480 | unsigned long spitz_get_hsync_len(void) | ||
481 | { | ||
482 | if (!get_hsync_time) | ||
483 | get_hsync_time = symbol_get(pxafb_get_hsync_time); | ||
484 | if (!get_hsync_time) | ||
485 | return 0; | ||
486 | |||
487 | return pxafb_get_hsync_time(&pxafb_device.dev); | ||
488 | } | ||
489 | |||
490 | void spitz_put_hsync(void) | ||
491 | { | ||
492 | if (get_hsync_time) | ||
493 | symbol_put(pxafb_get_hsync_time); | ||
494 | } | ||
495 | |||
496 | void spitz_wait_hsync(void) | ||
497 | { | ||
498 | sharpsl_wait_sync(SPITZ_GPIO_HSYNC); | ||
499 | } | ||
500 | #endif | ||