xref: /openbmc/linux/arch/arm/mach-sa1100/h3600.c (revision 9a87ffc99ec8eb8d35eed7c4f816d75f5cc9662e)
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