xref: /rk3399_rockchip-uboot/board/freescale/mx51evk/mx51evk_video.c (revision 00caae6d47645e68d6e5277aceb69592b49381a6)
15d71bd21SVikram Narayanan /*
25d71bd21SVikram Narayanan  * Copyright (C) 2012 Freescale Semiconductor, Inc.
35d71bd21SVikram Narayanan  * Fabio Estevam <fabio.estevam@freescale.com>
45d71bd21SVikram Narayanan  *
51a459660SWolfgang Denk  * SPDX-License-Identifier:	GPL-2.0+
65d71bd21SVikram Narayanan  */
75d71bd21SVikram Narayanan 
85d71bd21SVikram Narayanan #include <common.h>
95d71bd21SVikram Narayanan #include <linux/list.h>
105d71bd21SVikram Narayanan #include <asm/gpio.h>
114d15d36cSBenoît Thébaudeau #include <asm/arch/iomux-mx51.h>
125d71bd21SVikram Narayanan #include <linux/fb.h>
135d71bd21SVikram Narayanan #include <ipu_pixfmt.h>
145d71bd21SVikram Narayanan 
155d71bd21SVikram Narayanan #define MX51EVK_LCD_3V3		IMX_GPIO_NR(4, 9)
165d71bd21SVikram Narayanan #define MX51EVK_LCD_5V		IMX_GPIO_NR(4, 10)
175d71bd21SVikram Narayanan #define MX51EVK_LCD_BACKLIGHT	IMX_GPIO_NR(3, 4)
185d71bd21SVikram Narayanan 
195d71bd21SVikram Narayanan static struct fb_videomode const claa_wvga = {
205d71bd21SVikram Narayanan 	.name		= "CLAA07LC0ACW",
215d71bd21SVikram Narayanan 	.refresh	= 57,
225d71bd21SVikram Narayanan 	.xres		= 800,
235d71bd21SVikram Narayanan 	.yres		= 480,
245d71bd21SVikram Narayanan 	.pixclock	= 37037,
255d71bd21SVikram Narayanan 	.left_margin	= 40,
265d71bd21SVikram Narayanan 	.right_margin	= 60,
275d71bd21SVikram Narayanan 	.upper_margin	= 10,
285d71bd21SVikram Narayanan 	.lower_margin	= 10,
295d71bd21SVikram Narayanan 	.hsync_len	= 20,
305d71bd21SVikram Narayanan 	.vsync_len	= 10,
315d71bd21SVikram Narayanan 	.sync		= 0,
325d71bd21SVikram Narayanan 	.vmode		= FB_VMODE_NONINTERLACED
335d71bd21SVikram Narayanan };
345d71bd21SVikram Narayanan 
3511d80af4SFabio Estevam static struct fb_videomode const dvi = {
3611d80af4SFabio Estevam 	.name		= "DVI panel",
3711d80af4SFabio Estevam 	.refresh	= 60,
3811d80af4SFabio Estevam 	.xres		= 1024,
3911d80af4SFabio Estevam 	.yres		= 768,
4011d80af4SFabio Estevam 	.pixclock	= 15385,
4111d80af4SFabio Estevam 	.left_margin	= 220,
4211d80af4SFabio Estevam 	.right_margin	= 40,
4311d80af4SFabio Estevam 	.upper_margin	= 21,
4411d80af4SFabio Estevam 	.lower_margin	= 7,
4511d80af4SFabio Estevam 	.hsync_len	= 60,
4611d80af4SFabio Estevam 	.vsync_len	= 10,
4711d80af4SFabio Estevam 	.sync		= 0,
4811d80af4SFabio Estevam 	.vmode		= FB_VMODE_NONINTERLACED
4911d80af4SFabio Estevam };
5011d80af4SFabio Estevam 
setup_iomux_lcd(void)515d71bd21SVikram Narayanan void setup_iomux_lcd(void)
525d71bd21SVikram Narayanan {
535d71bd21SVikram Narayanan 	/* DI2_PIN15 */
544d15d36cSBenoît Thébaudeau 	imx_iomux_v3_setup_pad(MX51_PAD_DI_GP4__DI2_PIN15);
555d71bd21SVikram Narayanan 
564d15d36cSBenoît Thébaudeau 	/* Pad settings for DI2_DISP_CLK */
574d15d36cSBenoît Thébaudeau 	imx_iomux_v3_setup_pad(NEW_PAD_CTRL(MX51_PAD_DI2_DISP_CLK__DI2_DISP_CLK,
584d15d36cSBenoît Thébaudeau 			    PAD_CTL_PKE | PAD_CTL_DSE_MAX | PAD_CTL_SRE_SLOW));
595d71bd21SVikram Narayanan 
605d71bd21SVikram Narayanan 	/* Turn on 3.3V voltage for LCD */
614d15d36cSBenoît Thébaudeau 	imx_iomux_v3_setup_pad(NEW_PAD_CTRL(MX51_PAD_CSI2_D12__GPIO4_9,
624d15d36cSBenoît Thébaudeau 						NO_PAD_CTRL));
635d71bd21SVikram Narayanan 	gpio_direction_output(MX51EVK_LCD_3V3, 1);
645d71bd21SVikram Narayanan 
655d71bd21SVikram Narayanan 	/* Turn on 5V voltage for LCD */
664d15d36cSBenoît Thébaudeau 	imx_iomux_v3_setup_pad(NEW_PAD_CTRL(MX51_PAD_CSI2_D13__GPIO4_10,
674d15d36cSBenoît Thébaudeau 						NO_PAD_CTRL));
685d71bd21SVikram Narayanan 	gpio_direction_output(MX51EVK_LCD_5V, 1);
695d71bd21SVikram Narayanan 
705d71bd21SVikram Narayanan 	/* Turn on GPIO backlight */
714d15d36cSBenoît Thébaudeau 	imx_iomux_v3_setup_pad(NEW_PAD_CTRL(MX51_PAD_DI1_D1_CS__GPIO3_4,
724d15d36cSBenoît Thébaudeau 						NO_PAD_CTRL));
735d71bd21SVikram Narayanan 	gpio_direction_output(MX51EVK_LCD_BACKLIGHT, 1);
745d71bd21SVikram Narayanan }
755d71bd21SVikram Narayanan 
board_video_skip(void)7611d80af4SFabio Estevam int board_video_skip(void)
775d71bd21SVikram Narayanan {
7811d80af4SFabio Estevam 	int ret;
79*00caae6dSSimon Glass 	char const *e = env_get("panel");
8011d80af4SFabio Estevam 
8111d80af4SFabio Estevam 	if (e) {
8211d80af4SFabio Estevam 		if (strcmp(e, "claa") == 0) {
8311d80af4SFabio Estevam 			ret = ipuv3_fb_init(&claa_wvga, 1, IPU_PIX_FMT_RGB565);
845d71bd21SVikram Narayanan 			if (ret)
8511d80af4SFabio Estevam 				printf("claa cannot be configured: %d\n", ret);
8611d80af4SFabio Estevam 			return ret;
8711d80af4SFabio Estevam 		}
8811d80af4SFabio Estevam 	}
8911d80af4SFabio Estevam 
9011d80af4SFabio Estevam 	/*
9111d80af4SFabio Estevam 	 * 'panel' env variable not found or has different value than 'claa'
9211d80af4SFabio Estevam 	 *  Defaulting to dvi output.
9311d80af4SFabio Estevam 	 */
9411d80af4SFabio Estevam 	ret = ipuv3_fb_init(&dvi, 0, IPU_PIX_FMT_RGB24);
9511d80af4SFabio Estevam 	if (ret)
9611d80af4SFabio Estevam 		printf("dvi cannot be configured: %d\n", ret);
9711d80af4SFabio Estevam 	return ret;
985d71bd21SVikram Narayanan }
99