From: Antonino D. <ad...@po...> - 2002-12-21 03:56:31
|
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. |