mx53loco_video.c 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (C) 2012 Freescale Semiconductor, Inc.
  4. * Fabio Estevam <fabio.estevam@freescale.com>
  5. */
  6. #include <common.h>
  7. #include <linux/list.h>
  8. #include <asm/gpio.h>
  9. #include <asm/arch/iomux-mx53.h>
  10. #include <linux/fb.h>
  11. #include <ipu_pixfmt.h>
  12. #define MX53LOCO_LCD_POWER IMX_GPIO_NR(3, 24)
  13. static struct fb_videomode const claa_wvga = {
  14. .name = "CLAA07LC0ACW",
  15. .refresh = 57,
  16. .xres = 800,
  17. .yres = 480,
  18. .pixclock = 37037,
  19. .left_margin = 40,
  20. .right_margin = 60,
  21. .upper_margin = 10,
  22. .lower_margin = 10,
  23. .hsync_len = 20,
  24. .vsync_len = 10,
  25. .sync = 0,
  26. .vmode = FB_VMODE_NONINTERLACED
  27. };
  28. static struct fb_videomode const seiko_wvga = {
  29. .name = "Seiko-43WVF1G",
  30. .refresh = 60,
  31. .xres = 800,
  32. .yres = 480,
  33. .pixclock = 29851, /* picosecond (33.5 MHz) */
  34. .left_margin = 89,
  35. .right_margin = 164,
  36. .upper_margin = 23,
  37. .lower_margin = 10,
  38. .hsync_len = 10,
  39. .vsync_len = 10,
  40. .sync = 0,
  41. };
  42. void setup_iomux_lcd(void)
  43. {
  44. static const iomux_v3_cfg_t lcd_pads[] = {
  45. MX53_PAD_DI0_DISP_CLK__IPU_DI0_DISP_CLK,
  46. MX53_PAD_DI0_PIN15__IPU_DI0_PIN15,
  47. MX53_PAD_DI0_PIN2__IPU_DI0_PIN2,
  48. MX53_PAD_DI0_PIN3__IPU_DI0_PIN3,
  49. MX53_PAD_DISP0_DAT0__IPU_DISP0_DAT_0,
  50. MX53_PAD_DISP0_DAT1__IPU_DISP0_DAT_1,
  51. MX53_PAD_DISP0_DAT2__IPU_DISP0_DAT_2,
  52. MX53_PAD_DISP0_DAT3__IPU_DISP0_DAT_3,
  53. MX53_PAD_DISP0_DAT4__IPU_DISP0_DAT_4,
  54. MX53_PAD_DISP0_DAT5__IPU_DISP0_DAT_5,
  55. MX53_PAD_DISP0_DAT6__IPU_DISP0_DAT_6,
  56. MX53_PAD_DISP0_DAT7__IPU_DISP0_DAT_7,
  57. MX53_PAD_DISP0_DAT8__IPU_DISP0_DAT_8,
  58. MX53_PAD_DISP0_DAT9__IPU_DISP0_DAT_9,
  59. MX53_PAD_DISP0_DAT10__IPU_DISP0_DAT_10,
  60. MX53_PAD_DISP0_DAT11__IPU_DISP0_DAT_11,
  61. MX53_PAD_DISP0_DAT12__IPU_DISP0_DAT_12,
  62. MX53_PAD_DISP0_DAT13__IPU_DISP0_DAT_13,
  63. MX53_PAD_DISP0_DAT14__IPU_DISP0_DAT_14,
  64. MX53_PAD_DISP0_DAT15__IPU_DISP0_DAT_15,
  65. MX53_PAD_DISP0_DAT16__IPU_DISP0_DAT_16,
  66. MX53_PAD_DISP0_DAT17__IPU_DISP0_DAT_17,
  67. MX53_PAD_DISP0_DAT18__IPU_DISP0_DAT_18,
  68. MX53_PAD_DISP0_DAT19__IPU_DISP0_DAT_19,
  69. MX53_PAD_DISP0_DAT20__IPU_DISP0_DAT_20,
  70. MX53_PAD_DISP0_DAT21__IPU_DISP0_DAT_21,
  71. MX53_PAD_DISP0_DAT22__IPU_DISP0_DAT_22,
  72. MX53_PAD_DISP0_DAT23__IPU_DISP0_DAT_23,
  73. };
  74. imx_iomux_v3_setup_multiple_pads(lcd_pads, ARRAY_SIZE(lcd_pads));
  75. /* Turn on GPIO backlight */
  76. imx_iomux_v3_setup_pad(MX53_PAD_EIM_D24__GPIO3_24);
  77. gpio_direction_output(MX53LOCO_LCD_POWER, 1);
  78. /* Turn on display contrast */
  79. imx_iomux_v3_setup_pad(MX53_PAD_GPIO_1__GPIO1_1);
  80. gpio_direction_output(IMX_GPIO_NR(1, 1), 1);
  81. }
  82. int board_video_skip(void)
  83. {
  84. int ret;
  85. char const *e = env_get("panel");
  86. if (e) {
  87. if (strcmp(e, "seiko") == 0) {
  88. ret = ipuv3_fb_init(&seiko_wvga, 0, IPU_PIX_FMT_RGB24);
  89. if (ret)
  90. printf("Seiko cannot be configured: %d\n", ret);
  91. return ret;
  92. }
  93. }
  94. /*
  95. * 'panel' env variable not found or has different value than 'seiko'
  96. * Defaulting to claa lcd.
  97. */
  98. ret = ipuv3_fb_init(&claa_wvga, 0, IPU_PIX_FMT_RGB565);
  99. if (ret)
  100. printf("CLAA cannot be configured: %d\n", ret);
  101. return ret;
  102. }