diff options
| author | Albert ARIBAUD <albert.u.boot@aribaud.net> | 2013-12-10 14:31:56 +0100 | 
|---|---|---|
| committer | Albert ARIBAUD <albert.u.boot@aribaud.net> | 2013-12-10 22:23:59 +0100 | 
| commit | f15ea6e1d67782a1626d4a4922b6c20e380085e5 (patch) | |
| tree | 57d78f1ee94a2060eaa591533278d2934d4f1da3 /board/compulab/common/omap3_display.c | |
| parent | cb7ee1b98cac6baf244daefb1192adf5a47bc983 (diff) | |
| parent | f44483b57c49282299da0e5c10073b909cdad979 (diff) | |
| download | olio-uboot-2014.01-f15ea6e1d67782a1626d4a4922b6c20e380085e5.tar.xz olio-uboot-2014.01-f15ea6e1d67782a1626d4a4922b6c20e380085e5.zip | |
Merge branch 'u-boot/master' into 'u-boot-arm/master'
Conflicts:
	arch/arm/cpu/armv7/rmobile/Makefile
	doc/README.scrapyard
Needed manual fix:
	arch/arm/cpu/armv7/omap-common/Makefile
	board/compulab/cm_t335/u-boot.lds
Diffstat (limited to 'board/compulab/common/omap3_display.c')
| -rw-r--r-- | board/compulab/common/omap3_display.c | 46 | 
1 files changed, 44 insertions, 2 deletions
| diff --git a/board/compulab/common/omap3_display.c b/board/compulab/common/omap3_display.c index ead821eeb..61707f5b9 100644 --- a/board/compulab/common/omap3_display.c +++ b/board/compulab/common/omap3_display.c @@ -14,6 +14,7 @@  #include <stdio_dev.h>  #include <asm/arch/dss.h>  #include <lcd.h> +#include <scf0403_lcd.h>  #include <asm/arch-omap3/dss.h>  DECLARE_GLOBAL_DATA_PTR; @@ -22,6 +23,7 @@ enum display_type {  	NONE,  	DVI,  	DVI_CUSTOM, +	DATA_IMAGE, /* #define CONFIG_SCF0403_LCD to use */  };  #define CMAP_ADDR	0x80100000 @@ -119,6 +121,18 @@ static const struct panel_config preset_dvi_1280X1024 = {  	.gfx_format	= GFXFORMAT_RGB16,  }; +static const struct panel_config preset_dataimage_480X800 = { +	.lcd_size	= PANEL_LCD_SIZE(480, 800), +	.timing_h	= DSS_HBP(2) | DSS_HFP(2) | DSS_HSW(2), +	.timing_v	= DSS_VBP(17) | DSS_VFP(20) | DSS_VSW(3), +	.pol_freq	= DSS_IVS | DSS_IHS | DSS_IPC | DSS_ONOFF, +	.divisor	= 10 | (1 << 10), +	.data_lines	= LCD_INTERFACE_18_BIT, +	.panel_type	= ACTIVE_DISPLAY, +	.load_mode	= 2, +	.gfx_format	= GFXFORMAT_RGB16, +}; +  /*   * set_resolution_params()   * @@ -146,6 +160,13 @@ static enum display_type set_dvi_preset(const struct panel_config preset,  	return DVI;  } +static enum display_type set_dataimage_preset(const struct panel_config preset, +		int x_res, int y_res) +{ +	set_preset(preset, x_res, y_res); +	return DATA_IMAGE; +} +  /*   * parse_mode() - parse the mode parameter of custom lcd settings   * @@ -369,6 +390,8 @@ static enum display_type env_parse_displaytype(char *displaytype)  		return set_dvi_preset(preset_dvi_1280X960, 1280, 960);  	else if (!strncmp(displaytype, "dvi1280x1024", 12))  		return set_dvi_preset(preset_dvi_1280X1024, 1280, 1024); +	else if (!strncmp(displaytype, "dataimage480x800", 16)) +		return set_dataimage_preset(preset_dataimage_480X800, 480, 800);  	return NONE;  } @@ -401,12 +424,31 @@ void lcd_ctrl_init(void *lcdbase)  	clrsetbits_le32(&prcm->clksel_dss, 0xF, 3);  } +#ifdef CONFIG_SCF0403_LCD +static void scf0403_enable(void) +{ +	gpio_direction_output(58, 1); +	scf0403_init(157); +} +#else +static inline void scf0403_enable(void) {} +#endif +  void lcd_enable(void)  { -	if (lcd_def == DVI || lcd_def == DVI_CUSTOM) { +	switch (lcd_def) { +	case NONE: +		return; +	case DVI: +	case DVI_CUSTOM:  		gpio_direction_output(54, 0); /* Turn on DVI */ -		omap3_dss_enable(); +		break; +	case DATA_IMAGE: +		scf0403_enable(); +		break;  	} + +	omap3_dss_enable();  }  void lcd_setcolreg(ushort regno, ushort red, ushort green, ushort blue) {} |