[PATCH] framebuffer: cmap-setting return values
A set of 3 small bugfixes, all of which are related to bogus return values of fb colormap-setting functions. First, fb_alloc_cmap returns -1 if memory allocation fails. This is a hard condition to reproduce since you'd have to be really low on memory, but from studying the contexts in which it is called, I think this function should be returning a negative errno, and the -1 will be seen as an EPERM. Switching it to -ENOMEM makes sense. Second, the store_cmap function which is called for writes to /sys/class/graphics/fb0/color_map returns 0 for success, but it should be returning the count of bytes written since its return value ends up in userspace as the result of the write() syscall. Third, radeonfb returns 1 instead of a negative errno when FBIOPUTCMAP is called with an oversized colormap. This is seen in userspace as a return value of 1 from the ioctl() syscall with errno left unchanged. A more useful return value would be -EINVAL. Signed-off-by: Alan Curry <pacman@TheWorld.com> Cc: "Antonino A. Daplas" <adaplas@pol.net> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
parent
59153f7d7e
commit
db77ec270d
|
@ -1067,7 +1067,7 @@ static int radeon_setcolreg (unsigned regno, unsigned red, unsigned green,
|
||||||
|
|
||||||
|
|
||||||
if (regno > 255)
|
if (regno > 255)
|
||||||
return 1;
|
return -EINVAL;
|
||||||
|
|
||||||
red >>= 8;
|
red >>= 8;
|
||||||
green >>= 8;
|
green >>= 8;
|
||||||
|
@ -1086,9 +1086,9 @@ static int radeon_setcolreg (unsigned regno, unsigned red, unsigned green,
|
||||||
pindex = regno * 8;
|
pindex = regno * 8;
|
||||||
|
|
||||||
if (rinfo->depth == 16 && regno > 63)
|
if (rinfo->depth == 16 && regno > 63)
|
||||||
return 1;
|
return -EINVAL;
|
||||||
if (rinfo->depth == 15 && regno > 31)
|
if (rinfo->depth == 15 && regno > 31)
|
||||||
return 1;
|
return -EINVAL;
|
||||||
|
|
||||||
/* For 565, the green component is mixed one order
|
/* For 565, the green component is mixed one order
|
||||||
* below
|
* below
|
||||||
|
|
|
@ -85,7 +85,7 @@ static struct fb_cmap default_16_colors = {
|
||||||
* Allocates memory for a colormap @cmap. @len is the
|
* Allocates memory for a colormap @cmap. @len is the
|
||||||
* number of entries in the palette.
|
* number of entries in the palette.
|
||||||
*
|
*
|
||||||
* Returns -1 errno on error, or zero on success.
|
* Returns negative errno on error, or zero on success.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -116,7 +116,7 @@ int fb_alloc_cmap(struct fb_cmap *cmap, int len, int transp)
|
||||||
|
|
||||||
fail:
|
fail:
|
||||||
fb_dealloc_cmap(cmap);
|
fb_dealloc_cmap(cmap);
|
||||||
return -1;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -348,7 +348,7 @@ static ssize_t store_cmap(struct class_device *class_device, const char *buf,
|
||||||
fb_copy_cmap(&umap, &fb_info->cmap);
|
fb_copy_cmap(&umap, &fb_info->cmap);
|
||||||
fb_dealloc_cmap(&umap);
|
fb_dealloc_cmap(&umap);
|
||||||
|
|
||||||
return rc;
|
return rc ?: count;
|
||||||
}
|
}
|
||||||
for (i = 0; i < length; i++) {
|
for (i = 0; i < length; i++) {
|
||||||
u16 red, blue, green, tsp;
|
u16 red, blue, green, tsp;
|
||||||
|
@ -367,7 +367,7 @@ static ssize_t store_cmap(struct class_device *class_device, const char *buf,
|
||||||
if (transp)
|
if (transp)
|
||||||
fb_info->cmap.transp[i] = tsp;
|
fb_info->cmap.transp[i] = tsp;
|
||||||
}
|
}
|
||||||
return 0;
|
return count;
|
||||||
}
|
}
|
||||||
|
|
||||||
static ssize_t show_cmap(struct class_device *class_device, char *buf)
|
static ssize_t show_cmap(struct class_device *class_device, char *buf)
|
||||||
|
|
Loading…
Reference in New Issue