Re: [Linux-fbdev-devel] [PATCH] fix endian problem in

Antonino Daplas (adaplas@pol.net)
21 Dec 2002 11:45:44 +0800


On Sat, 2002-12-21 at 03:54, James Simmons wrote:
>
> > Nice catch :-) We also need a similar fix for slow_imageblit(), so
> > James can you apply the attached patch also:
>
> Applied.
>
> > Also, I noticed that some drivers load the pseudo_palette with entries
> > whose length matches the length of the pixel. The cfb_* functions
> > always assume that each pseudo_palette entry is an "unsigned long", so
> > bpp16 will segfault, and so will bpp24/32 for 64-bit machines.
>
> I just noticed that as well. Russell King pointed to it too. I fixed
> the unsigned long problem in color_imageblit. All the pseudo_palette
> in cfb_* are assumed u32. Is this safe for 16bpp or 8 bpp modes? I will

The pseudopalette will only matter for truecolor and directcolor as the
rest of the visuals bypasses the pseudopalette. Typecasting to
"unsigned long" rather than "u32" is also safer (even for bpp16) since
in 64-bit machines, the drawing functions use fb_writeq instead of
fb_writel. So, all drivers using the cfb_* functions should change from
"u32" to "unsigned long" _whatever_ the bit depth when loading the
pseudopalette.

Of course, drivers with their own drawing functions can use whatever
they want.

Tony

PS: cfb_fillrect is still limited to u32 though which can hopefully be
fixed in the future.

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/