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