From: Stefano Babic <sbabic@denx.de>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH] mx51evk: Add LCD support
Date: Thu, 10 May 2012 12:11:08 +0200 [thread overview]
Message-ID: <4FAB943C.1020605@denx.de> (raw)
In-Reply-To: <1336581581-7841-1-git-send-email-fabio.estevam@freescale.com>
On 09/05/2012 18:39, Fabio Estevam wrote:
> Add support for CLAA07LC0ACW LCD that connects to the mx51evk board.
>
> Configure the board to show the Linux logo on the LCD.
>
> Also increase the size of CONFIG_SYS_MALLOC_LEN variable to take into account
> the framebuffer usage.
>
> Signed-off-by: Fabio Estevam <fabio.estevam@freescale.com>
> ---
> board/freescale/mx51evk/mx51evk.c | 59 +++++++++++++++++++++++++++++++++++++
> include/configs/mx51evk.h | 13 +++++++-
> 2 files changed, 71 insertions(+), 1 deletions(-)
>
> diff --git a/board/freescale/mx51evk/mx51evk.c b/board/freescale/mx51evk/mx51evk.c
> index b505a71..90dbabb 100644
> --- a/board/freescale/mx51evk/mx51evk.c
> +++ b/board/freescale/mx51evk/mx51evk.c
> @@ -36,6 +36,12 @@
> #include <fsl_pmic.h>
> #include <mc13892.h>
> #include <usb/ehci-fsl.h>
> +#include <linux/fb.h>
> +#include <ipu_pixfmt.h>
> +
> +#define MX51EVK_LCD_3V3 (3 * 32 + 9) /* GPIO4_9 */
> +#define MX51EVK_LCD_5V (3 * 32 + 10) /* GPIO4_10 */
> +#define MX51EVK_LCD_BACKLIGHT (2 * 32 + 4) /* GPIO3_4 */
>
> DECLARE_GLOBAL_DATA_PTR;
>
> @@ -453,6 +459,54 @@ int board_mmc_init(bd_t *bis)
> }
> #endif
>
> +static struct fb_videomode claa_wvga = {
> + .name = "CLAA07LC0ACW",
> + .refresh = 57,
> + .xres = 800,
> + .yres = 480,
> + .pixclock = 37037,
> + .left_margin = 40,
> + .right_margin = 60,
> + .upper_margin = 10,
> + .lower_margin = 10,
> + .hsync_len = 20,
> + .vsync_len = 10,
> + .sync = 0,
> + .vmode = FB_VMODE_NONINTERLACED
> +};
> +
> +void lcd_iomux(void)
> +{
> + /* DI2_PIN15 */
> + mxc_request_iomux(MX51_PIN_DI_GP4, IOMUX_CONFIG_ALT4);
> +
> + /* Pad settings for MX51_PIN_DI2_DISP_CLK */
> + mxc_iomux_set_pad(MX51_PIN_DI2_DISP_CLK, PAD_CTL_HYS_NONE |
> + PAD_CTL_PKE_ENABLE | PAD_CTL_PUE_KEEPER |
> + PAD_CTL_DRV_MAX | PAD_CTL_SRE_SLOW);
> +
> + /* Turn on 3.3V voltage for LCD */
> + mxc_request_iomux(MX51_PIN_CSI2_D12, IOMUX_CONFIG_ALT3);
> + gpio_direction_output(MX51EVK_LCD_3V3, 1);
> +
> + /* Turn on 5V voltage for LCD */
> + mxc_request_iomux(MX51_PIN_CSI2_D13, IOMUX_CONFIG_ALT3);
> + gpio_direction_output(MX51EVK_LCD_5V, 1);
> +
> + /* Turn on GPIO backlight */
> + mxc_request_iomux(MX51_PIN_DI1_D1_CS, IOMUX_CONFIG_ALT4);
> + mxc_iomux_set_input(MX51_GPIO3_IPP_IND_G_IN_4_SELECT_INPUT,
> + INPUT_CTL_PATH1);
> + gpio_direction_output(MX51EVK_LCD_BACKLIGHT, 1);
> +}
> +
> +void lcd_enable(void)
> +{
> + int ret = mx51_fb_init(&claa_wvga, 1, IPU_PIX_FMT_RGB565);
> + if (ret)
> + printf("LCD cannot be configured: %d\n", ret);
> +}
> +
> int board_early_init_f(void)
> {
> setup_iomux_uart();
> @@ -460,6 +514,7 @@ int board_early_init_f(void)
> #ifdef CONFIG_USB_EHCI_MX5
> setup_usb_h1();
> #endif
> + lcd_iomux();
>
> return 0;
> }
> @@ -469,6 +524,8 @@ int board_init(void)
> /* address of boot parameters */
> gd->bd->bi_boot_params = PHYS_SDRAM_1 + 0x100;
>
> + lcd_enable();
> +
> return 0;
> }
>
> @@ -479,6 +536,8 @@ int board_late_init(void)
> setup_iomux_spi();
> power_init();
> #endif
> + setenv("stdout", "serial");
> +
> return 0;
> }
> #endif
> diff --git a/include/configs/mx51evk.h b/include/configs/mx51evk.h
> index 1477b21..58b6f1c 100644
> --- a/include/configs/mx51evk.h
> +++ b/include/configs/mx51evk.h
> @@ -51,7 +51,7 @@
> /*
> * Size of malloc() pool
> */
> -#define CONFIG_SYS_MALLOC_LEN (CONFIG_ENV_SIZE + 2 * 1024 * 1024)
> +#define CONFIG_SYS_MALLOC_LEN (10 * 1024 * 1024)
>
> #define CONFIG_BOARD_LATE_INIT
>
> @@ -123,6 +123,17 @@
> #define CONFIG_MXC_USB_PORTSC PORT_PTS_ULPI
> #define CONFIG_MXC_USB_FLAGS MXC_EHCI_POWER_PINS_ENABLED
>
> +/* Framebuffer and LCD */
> +#define CONFIG_PREBOOT
> +#define CONFIG_VIDEO
> +#define CONFIG_VIDEO_MX5
> +#define CONFIG_CFB_CONSOLE
> +#define CONFIG_VGA_AS_SINGLE_DEVICE
> +#define CONFIG_VIDEO_BMP_RLE8
> +#define CONFIG_SPLASH_SCREEN
> +#define CONFIG_BMP_16BPP
> +#define CONFIG_VIDEO_LOGO
> +
> /* allow to overwrite serial and ethaddr */
> #define CONFIG_ENV_OVERWRITE
> #define CONFIG_CONS_INDEX 1
No issue on my side, here my:
Acked-by: Stefano Babic <sbabic@denx.de>
Best regards,
Stefano Babic
--
=====================================================================
DENX Software Engineering GmbH, MD: Wolfgang Denk & Detlev Zundel
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: +49-8142-66989-53 Fax: +49-8142-66989-80 Email: sbabic at denx.de
=====================================================================
next prev parent reply other threads:[~2012-05-10 10:11 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-05-09 16:39 [U-Boot] [PATCH] mx51evk: Add LCD support Fabio Estevam
2012-05-10 10:11 ` Stefano Babic [this message]
2012-05-25 8:09 ` Anatolij Gustschin
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4FAB943C.1020605@denx.de \
--to=sbabic@denx.de \
--cc=u-boot@lists.denx.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.