From: Jim Hague Handle 24bit on big-endian by leaving the hardware in RGB and using the colour offset to reverse red/blue. Leaving the hardware in RGB means that fbi displays images correctly (abeit fortuitously) and the console is correct, thanks to a recent patch to the console code correcting an endian bug in fbcon_putc(). Signed-off-by: Jim Hague Signed-off-by: Andrew Morton --- 25-akpm/drivers/video/pm2fb.c | 16 +++++++++++----- 1 files changed, 11 insertions(+), 5 deletions(-) diff -puN drivers/video/pm2fb.c~pm2fb-fix-fbi-image-display-on-24-bit-depth-big-endian drivers/video/pm2fb.c --- 25/drivers/video/pm2fb.c~pm2fb-fix-fbi-image-display-on-24-bit-depth-big-endian Fri Dec 10 15:08:09 2004 +++ 25-akpm/drivers/video/pm2fb.c Fri Dec 10 15:08:09 2004 @@ -646,12 +646,22 @@ static int pm2fb_check_var(struct fb_var case 32: var->transp.offset = 24; var->transp.length = 8; - case 24: var->red.offset = 16; var->green.offset = 8; var->blue.offset = 0; var->red.length = var->green.length = var->blue.length = 8; break; + case 24: +#ifdef __BIG_ENDIAN + var->red.offset = 0; + var->blue.offset = 16; +#else + var->red.offset = 16; + var->blue.offset = 0; +#endif + var->green.offset = 8; + var->red.length = var->green.length = var->blue.length = 8; + break; } var->height = var->width = -1; @@ -789,10 +799,6 @@ static int pm2fb_set_par(struct fb_info case 24: pm2_WR(par, PM2R_FB_READ_PIXEL, 4); clrmode |= PM2F_RD_TRUECOLOR | PM2F_RD_PIXELFORMAT_RGB888; -#ifdef __BIG_ENDIAN - /* Use BGR not RGB */ - clrmode &= ~PM2F_RD_COLOR_MODE_RGB; -#endif txtmap = PM2F_TEXTEL_SIZE_24; pixsize = 4; clrformat = 0x20; _