diff options
Diffstat (limited to 'common/lcd.c')
| -rw-r--r-- | common/lcd.c | 25 | 
1 files changed, 19 insertions, 6 deletions
diff --git a/common/lcd.c b/common/lcd.c index eec1f53b0..25f866434 100644 --- a/common/lcd.c +++ b/common/lcd.c @@ -55,8 +55,6 @@  #include <nand.h>  #endif -#ifdef CONFIG_LCD -  /************************************************************************/  /* ** FONT DATA								*/  /************************************************************************/ @@ -678,6 +676,7 @@ int lcd_display_bitmap(ulong bmp_image, int x, int y)  		/* Set color map */  		for (i=0; i<colors; ++i) {  			bmp_color_table_entry_t cte = bmp->color_table[i]; +#if !defined(CONFIG_ATMEL_LCD)  			ushort colreg =  				( ((cte.red)   << 8) & 0xf800) |  				( ((cte.green) << 3) & 0x07e0) | @@ -692,6 +691,9 @@ int lcd_display_bitmap(ulong bmp_image, int x, int y)  #elif defined(CONFIG_MPC823)  			cmap--;  #endif +#else /* CONFIG_ATMEL_LCD */ +			lcd_setcolreg(i, cte.red, cte.green, cte.blue); +#endif  		}  	}  #endif @@ -727,7 +729,7 @@ int lcd_display_bitmap(ulong bmp_image, int x, int y)  	for (i = 0; i < height; ++i) {  		WATCHDOG_RESET();  		for (j = 0; j < width ; j++) -#if defined(CONFIG_PXA250) +#if defined(CONFIG_PXA250) || defined(CONFIG_ATMEL_LCD)  			*(fb++) = *(bmap++);  #elif defined(CONFIG_MPC823) || defined(CONFIG_MCC200)  			*(fb++)=255-*(bmap++); @@ -740,6 +742,9 @@ int lcd_display_bitmap(ulong bmp_image, int x, int y)  }  #endif +#ifdef CONFIG_VIDEO_BMP_GZIP +extern bmp_image_t *gunzip_bmp(unsigned long addr, unsigned long *lenp); +#endif  static void *lcd_logo (void)  { @@ -761,6 +766,16 @@ static void *lcd_logo (void)  		addr = simple_strtoul(s, NULL, 16);  		do_splash = 0; +#ifdef CONFIG_VIDEO_BMP_GZIP +		bmp_image_t *bmp = (bmp_image_t *)addr; +		unsigned long len; + +		if (!((bmp->header.signature[0]=='B') && +		      (bmp->header.signature[1]=='M'))) { +			addr = (ulong)gunzip_bmp(addr, &len); +		} +#endif +  		if (lcd_display_bitmap (addr, 0, 0) == 0) {  			return ((void *)lcd_base);  		} @@ -776,7 +791,7 @@ static void *lcd_logo (void)  	sprintf (info, "%s (%s - %s) ", U_BOOT_VERSION, __DATE__, __TIME__);  	lcd_drawchars (LCD_INFO_X, LCD_INFO_Y, (uchar *)info, strlen(info)); -	sprintf (info, "(C) 2004 DENX Software Engineering"); +	sprintf (info, "(C) 2008 DENX Software Engineering GmbH");  	lcd_drawchars (LCD_INFO_X, LCD_INFO_Y + VIDEO_FONT_HEIGHT,  					(uchar *)info, strlen(info)); @@ -850,5 +865,3 @@ static void *lcd_logo (void)  /************************************************************************/  /************************************************************************/ - -#endif /* CONFIG_LCD */  |