1*d2912cb1SThomas Gleixner // SPDX-License-Identifier: GPL-2.0-only
21da177e4SLinus Torvalds /*
36e23fcb3SDmitry Artamonow * Support for Compaq iPAQ H3600 handheld computer
41da177e4SLinus Torvalds *
56e23fcb3SDmitry Artamonow * Copyright (c) 2000,1 Compaq Computer Corporation. (Author: Jamey Hicks)
66e23fcb3SDmitry Artamonow * Copyright (c) 2009 Dmitry Artamonow <mad_soft@inbox.ru>
71da177e4SLinus Torvalds */
86e23fcb3SDmitry Artamonow
91da177e4SLinus Torvalds #include <linux/init.h>
101da177e4SLinus Torvalds #include <linux/kernel.h>
110831e3e4SRussell King #include <linux/gpio.h>
121da177e4SLinus Torvalds
13e1b7a72aSRussell King #include <video/sa1100fb.h>
14e1b7a72aSRussell King
151da177e4SLinus Torvalds #include <asm/mach-types.h>
161da177e4SLinus Torvalds #include <asm/mach/arch.h>
171da177e4SLinus Torvalds
188715b29dSDmitry Artamonow #include <mach/h3xxx.h>
19f314f33bSRob Herring #include <mach/irqs.h>
201da177e4SLinus Torvalds
211da177e4SLinus Torvalds #include "generic.h"
221da177e4SLinus Torvalds
23cf5a87d8SDmitry Artamonow /*
24cf5a87d8SDmitry Artamonow * helper for sa1100fb
25cf5a87d8SDmitry Artamonow */
268bed576cSDmitry Eremin-Solenikov static struct gpio h3600_lcd_gpio[] = {
278bed576cSDmitry Eremin-Solenikov { H3XXX_EGPIO_LCD_ON, GPIOF_OUT_INIT_LOW, "LCD power" },
288bed576cSDmitry Eremin-Solenikov { H3600_EGPIO_LCD_PCI, GPIOF_OUT_INIT_LOW, "LCD control" },
298bed576cSDmitry Eremin-Solenikov { H3600_EGPIO_LCD_5V_ON, GPIOF_OUT_INIT_LOW, "LCD 5v" },
308bed576cSDmitry Eremin-Solenikov { H3600_EGPIO_LVDD_ON, GPIOF_OUT_INIT_LOW, "LCD 9v/-6.5v" },
318bed576cSDmitry Eremin-Solenikov };
328bed576cSDmitry Eremin-Solenikov
h3600_lcd_request(void)338bed576cSDmitry Eremin-Solenikov static bool h3600_lcd_request(void)
348bed576cSDmitry Eremin-Solenikov {
358bed576cSDmitry Eremin-Solenikov static bool h3600_lcd_ok;
368bed576cSDmitry Eremin-Solenikov int rc;
378bed576cSDmitry Eremin-Solenikov
388bed576cSDmitry Eremin-Solenikov if (h3600_lcd_ok)
398bed576cSDmitry Eremin-Solenikov return true;
408bed576cSDmitry Eremin-Solenikov
418bed576cSDmitry Eremin-Solenikov rc = gpio_request_array(h3600_lcd_gpio, ARRAY_SIZE(h3600_lcd_gpio));
428bed576cSDmitry Eremin-Solenikov if (rc)
438bed576cSDmitry Eremin-Solenikov pr_err("%s: can't request GPIOs\n", __func__);
448bed576cSDmitry Eremin-Solenikov else
458bed576cSDmitry Eremin-Solenikov h3600_lcd_ok = true;
468bed576cSDmitry Eremin-Solenikov
478bed576cSDmitry Eremin-Solenikov return h3600_lcd_ok;
488bed576cSDmitry Eremin-Solenikov }
498bed576cSDmitry Eremin-Solenikov
h3600_lcd_power(int enable)50cf5a87d8SDmitry Artamonow static void h3600_lcd_power(int enable)
51cf5a87d8SDmitry Artamonow {
528bed576cSDmitry Eremin-Solenikov if (!h3600_lcd_request())
538bed576cSDmitry Eremin-Solenikov return;
5422f97405SDmitry Artamonow
5522f97405SDmitry Artamonow gpio_direction_output(H3XXX_EGPIO_LCD_ON, enable);
5622f97405SDmitry Artamonow gpio_direction_output(H3600_EGPIO_LCD_PCI, enable);
5722f97405SDmitry Artamonow gpio_direction_output(H3600_EGPIO_LCD_5V_ON, enable);
5822f97405SDmitry Artamonow gpio_direction_output(H3600_EGPIO_LVDD_ON, enable);
59cf5a87d8SDmitry Artamonow }
60cf5a87d8SDmitry Artamonow
61e1b7a72aSRussell King static const struct sa1100fb_rgb h3600_rgb_16 = {
62e1b7a72aSRussell King .red = { .offset = 12, .length = 4, },
63e1b7a72aSRussell King .green = { .offset = 7, .length = 4, },
64e1b7a72aSRussell King .blue = { .offset = 1, .length = 4, },
65e1b7a72aSRussell King .transp = { .offset = 0, .length = 0, },
66e1b7a72aSRussell King };
67e1b7a72aSRussell King
68e1b7a72aSRussell King static struct sa1100fb_mach_info h3600_lcd_info = {
69e1b7a72aSRussell King .pixclock = 174757, .bpp = 16,
70e1b7a72aSRussell King .xres = 320, .yres = 240,
71e1b7a72aSRussell King
72e1b7a72aSRussell King .hsync_len = 3, .vsync_len = 3,
73e1b7a72aSRussell King .left_margin = 12, .upper_margin = 10,
74e1b7a72aSRussell King .right_margin = 17, .lower_margin = 1,
75e1b7a72aSRussell King
76e1b7a72aSRussell King .cmap_static = 1,
77e1b7a72aSRussell King
78e1b7a72aSRussell King .lccr0 = LCCR0_Color | LCCR0_Sngl | LCCR0_Act,
79e1b7a72aSRussell King .lccr3 = LCCR3_OutEnH | LCCR3_PixRsEdg | LCCR3_ACBsDiv(2),
80e1b7a72aSRussell King
81e1b7a72aSRussell King .rgb[RGB_16] = &h3600_rgb_16,
82086ada54SRussell King
83086ada54SRussell King .lcd_power = h3600_lcd_power,
84e1b7a72aSRussell King };
85e1b7a72aSRussell King
86e1b7a72aSRussell King
h3600_map_io(void)871da177e4SLinus Torvalds static void __init h3600_map_io(void)
881da177e4SLinus Torvalds {
891da177e4SLinus Torvalds h3xxx_map_io();
901da177e4SLinus Torvalds }
911da177e4SLinus Torvalds
h3600_mach_init(void)92e55b20e8SDmitry Artamonow static void __init h3600_mach_init(void)
93898e810eSRussell King {
94898e810eSRussell King h3xxx_mach_init();
95e1b7a72aSRussell King
96e1b7a72aSRussell King sa11x0_register_lcd(&h3600_lcd_info);
97898e810eSRussell King }
98898e810eSRussell King
991da177e4SLinus Torvalds MACHINE_START(H3600, "Compaq iPAQ H3600")
10017f4425dSNicolas Pitre .atag_offset = 0x100,
101e9dea0c6SRussell King .map_io = h3600_map_io,
102f314f33bSRob Herring .nr_irqs = SA1100_NR_IRQS,
103e9dea0c6SRussell King .init_irq = sa1100_init_irq,
1046bb27d73SStephen Warren .init_time = sa1100_timer_init,
105898e810eSRussell King .init_machine = h3600_mach_init,
1067fea1ba5SShawn Guo .init_late = sa11x0_init_late,
107d9ca5839SRussell King .restart = sa11x0_restart,
1081da177e4SLinus Torvalds MACHINE_END
1091da177e4SLinus Torvalds
110