Commit 208df1e4 authored by Hector Palacios's avatar Hector Palacios Committed by Tomi Valkeinen

video: mxsfb: fix color settings for 18bit data bus and 32bpp

For a combination of 18bit LCD data bus width and a color
mode of 32bpp, the driver was setting the color mapping to
rgb666, which is wrong, as the color in memory realy has an
rgb888 layout.

This patch also removes the setting of flag CTRL_DF24 that
makes the driver dimiss the upper 2 bits when handling 32/24bpp
colors in a diplay with 18bit data bus width. This flag made
true color images display wrong in such configurations.

Finally, the color mapping rgb666 has also been removed as nobody
is using it and high level applications like Qt5 cannot work
with it either.

Reference: https://lkml.org/lkml/2013/5/23/220Signed-off-by: default avatarHector Palacios <hector.palacios@digi.com>
Acked-by: default avatarJuergen Beisert <jbe@pengutronix.de>
Acked-by: default avatarMaxime Ripard <maxime.ripard@free-electrons.com>
Signed-off-by: default avatarMaxime Ripard <maxime.ripard@free-electrons.com>
Signed-off-by: default avatarTomi Valkeinen <tomi.valkeinen@ti.com>
parent 005358c8
...@@ -239,24 +239,6 @@ static const struct fb_bitfield def_rgb565[] = { ...@@ -239,24 +239,6 @@ static const struct fb_bitfield def_rgb565[] = {
} }
}; };
static const struct fb_bitfield def_rgb666[] = {
[RED] = {
.offset = 16,
.length = 6,
},
[GREEN] = {
.offset = 8,
.length = 6,
},
[BLUE] = {
.offset = 0,
.length = 6,
},
[TRANSP] = { /* no support for transparency */
.length = 0,
}
};
static const struct fb_bitfield def_rgb888[] = { static const struct fb_bitfield def_rgb888[] = {
[RED] = { [RED] = {
.offset = 16, .offset = 16,
...@@ -309,9 +291,6 @@ static int mxsfb_check_var(struct fb_var_screeninfo *var, ...@@ -309,9 +291,6 @@ static int mxsfb_check_var(struct fb_var_screeninfo *var,
break; break;
case STMLCDIF_16BIT: case STMLCDIF_16BIT:
case STMLCDIF_18BIT: case STMLCDIF_18BIT:
/* 24 bit to 18 bit mapping */
rgb = def_rgb666;
break;
case STMLCDIF_24BIT: case STMLCDIF_24BIT:
/* real 24 bit */ /* real 24 bit */
rgb = def_rgb888; rgb = def_rgb888;
...@@ -453,11 +432,6 @@ static int mxsfb_set_par(struct fb_info *fb_info) ...@@ -453,11 +432,6 @@ static int mxsfb_set_par(struct fb_info *fb_info)
return -EINVAL; return -EINVAL;
case STMLCDIF_16BIT: case STMLCDIF_16BIT:
case STMLCDIF_18BIT: case STMLCDIF_18BIT:
/* 24 bit to 18 bit mapping */
ctrl |= CTRL_DF24; /* ignore the upper 2 bits in
* each colour component
*/
break;
case STMLCDIF_24BIT: case STMLCDIF_24BIT:
/* real 24 bit */ /* real 24 bit */
break; break;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment