mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-09 22:50:41 +00:00
[PATCH] fbcmap.c: mark structs const or __read_mostly
- Mark the default colormaps read-only, as nobody should be allowed to modify them - Additionally mark color values as __read_mostly since they will only be modified (very seldom) by fb_invert_cmaps() - Add named C99-initializers in fb_cmap structs and use the ARRAY_SIZE() macro Signed-off-by: Helge Deller <deller@gmx.de> Acked-by: James Simmons <jsimmons@infradead.org> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
parent
357b819dda
commit
adf6b20654
@ -18,63 +18,64 @@
|
|||||||
|
|
||||||
#include <asm/uaccess.h>
|
#include <asm/uaccess.h>
|
||||||
|
|
||||||
static u16 red2[] = {
|
static u16 red2[] __read_mostly = {
|
||||||
0x0000, 0xaaaa
|
0x0000, 0xaaaa
|
||||||
};
|
};
|
||||||
static u16 green2[] = {
|
static u16 green2[] __read_mostly = {
|
||||||
0x0000, 0xaaaa
|
0x0000, 0xaaaa
|
||||||
};
|
};
|
||||||
static u16 blue2[] = {
|
static u16 blue2[] __read_mostly = {
|
||||||
0x0000, 0xaaaa
|
0x0000, 0xaaaa
|
||||||
};
|
};
|
||||||
|
|
||||||
static u16 red4[] = {
|
static u16 red4[] __read_mostly = {
|
||||||
0x0000, 0xaaaa, 0x5555, 0xffff
|
0x0000, 0xaaaa, 0x5555, 0xffff
|
||||||
};
|
};
|
||||||
static u16 green4[] = {
|
static u16 green4[] __read_mostly = {
|
||||||
0x0000, 0xaaaa, 0x5555, 0xffff
|
0x0000, 0xaaaa, 0x5555, 0xffff
|
||||||
};
|
};
|
||||||
static u16 blue4[] = {
|
static u16 blue4[] __read_mostly = {
|
||||||
0x0000, 0xaaaa, 0x5555, 0xffff
|
0x0000, 0xaaaa, 0x5555, 0xffff
|
||||||
};
|
};
|
||||||
|
|
||||||
static u16 red8[] = {
|
static u16 red8[] __read_mostly = {
|
||||||
0x0000, 0x0000, 0x0000, 0x0000, 0xaaaa, 0xaaaa, 0xaaaa, 0xaaaa
|
0x0000, 0x0000, 0x0000, 0x0000, 0xaaaa, 0xaaaa, 0xaaaa, 0xaaaa
|
||||||
};
|
};
|
||||||
static u16 green8[] = {
|
static u16 green8[] __read_mostly = {
|
||||||
0x0000, 0x0000, 0xaaaa, 0xaaaa, 0x0000, 0x0000, 0x5555, 0xaaaa
|
0x0000, 0x0000, 0xaaaa, 0xaaaa, 0x0000, 0x0000, 0x5555, 0xaaaa
|
||||||
};
|
};
|
||||||
static u16 blue8[] = {
|
static u16 blue8[] __read_mostly = {
|
||||||
0x0000, 0xaaaa, 0x0000, 0xaaaa, 0x0000, 0xaaaa, 0x0000, 0xaaaa
|
0x0000, 0xaaaa, 0x0000, 0xaaaa, 0x0000, 0xaaaa, 0x0000, 0xaaaa
|
||||||
};
|
};
|
||||||
|
|
||||||
static u16 red16[] = {
|
static u16 red16[] __read_mostly = {
|
||||||
0x0000, 0x0000, 0x0000, 0x0000, 0xaaaa, 0xaaaa, 0xaaaa, 0xaaaa,
|
0x0000, 0x0000, 0x0000, 0x0000, 0xaaaa, 0xaaaa, 0xaaaa, 0xaaaa,
|
||||||
0x5555, 0x5555, 0x5555, 0x5555, 0xffff, 0xffff, 0xffff, 0xffff
|
0x5555, 0x5555, 0x5555, 0x5555, 0xffff, 0xffff, 0xffff, 0xffff
|
||||||
};
|
};
|
||||||
static u16 green16[] = {
|
static u16 green16[] __read_mostly = {
|
||||||
0x0000, 0x0000, 0xaaaa, 0xaaaa, 0x0000, 0x0000, 0x5555, 0xaaaa,
|
0x0000, 0x0000, 0xaaaa, 0xaaaa, 0x0000, 0x0000, 0x5555, 0xaaaa,
|
||||||
0x5555, 0x5555, 0xffff, 0xffff, 0x5555, 0x5555, 0xffff, 0xffff
|
0x5555, 0x5555, 0xffff, 0xffff, 0x5555, 0x5555, 0xffff, 0xffff
|
||||||
};
|
};
|
||||||
static u16 blue16[] = {
|
static u16 blue16[] __read_mostly = {
|
||||||
0x0000, 0xaaaa, 0x0000, 0xaaaa, 0x0000, 0xaaaa, 0x0000, 0xaaaa,
|
0x0000, 0xaaaa, 0x0000, 0xaaaa, 0x0000, 0xaaaa, 0x0000, 0xaaaa,
|
||||||
0x5555, 0xffff, 0x5555, 0xffff, 0x5555, 0xffff, 0x5555, 0xffff
|
0x5555, 0xffff, 0x5555, 0xffff, 0x5555, 0xffff, 0x5555, 0xffff
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct fb_cmap default_2_colors = {
|
static const struct fb_cmap default_2_colors = {
|
||||||
0, 2, red2, green2, blue2, NULL
|
.len=2, .red=red2, .green=green2, .blue=blue2
|
||||||
};
|
};
|
||||||
static struct fb_cmap default_8_colors = {
|
static const struct fb_cmap default_8_colors = {
|
||||||
0, 8, red8, green8, blue8, NULL
|
.len=8, .red=red8, .green=green8, .blue=blue8
|
||||||
};
|
};
|
||||||
static struct fb_cmap default_4_colors = {
|
static const struct fb_cmap default_4_colors = {
|
||||||
0, 4, red4, green4, blue4, NULL
|
.len=4, .red=red4, .green=green4, .blue=blue4
|
||||||
};
|
};
|
||||||
static struct fb_cmap default_16_colors = {
|
static const struct fb_cmap default_16_colors = {
|
||||||
0, 16, red16, green16, blue16, NULL
|
.len=16, .red=red16, .green=green16, .blue=blue16
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* fb_alloc_cmap - allocate a colormap
|
* fb_alloc_cmap - allocate a colormap
|
||||||
* @cmap: frame buffer colormap structure
|
* @cmap: frame buffer colormap structure
|
||||||
@ -146,7 +147,7 @@ void fb_dealloc_cmap(struct fb_cmap *cmap)
|
|||||||
* Copy contents of colormap from @from to @to.
|
* Copy contents of colormap from @from to @to.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
int fb_copy_cmap(struct fb_cmap *from, struct fb_cmap *to)
|
int fb_copy_cmap(const struct fb_cmap *from, struct fb_cmap *to)
|
||||||
{
|
{
|
||||||
int tooff = 0, fromoff = 0;
|
int tooff = 0, fromoff = 0;
|
||||||
int size;
|
int size;
|
||||||
@ -170,7 +171,7 @@ int fb_copy_cmap(struct fb_cmap *from, struct fb_cmap *to)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int fb_cmap_to_user(struct fb_cmap *from, struct fb_cmap_user *to)
|
int fb_cmap_to_user(const struct fb_cmap *from, struct fb_cmap_user *to)
|
||||||
{
|
{
|
||||||
int tooff = 0, fromoff = 0;
|
int tooff = 0, fromoff = 0;
|
||||||
int size;
|
int size;
|
||||||
@ -282,7 +283,7 @@ int fb_set_user_cmap(struct fb_cmap_user *cmap, struct fb_info *info)
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
struct fb_cmap *fb_default_cmap(int len)
|
const struct fb_cmap *fb_default_cmap(int len)
|
||||||
{
|
{
|
||||||
if (len <= 2)
|
if (len <= 2)
|
||||||
return &default_2_colors;
|
return &default_2_colors;
|
||||||
@ -305,22 +306,22 @@ void fb_invert_cmaps(void)
|
|||||||
{
|
{
|
||||||
u_int i;
|
u_int i;
|
||||||
|
|
||||||
for (i = 0; i < 2; i++) {
|
for (i = 0; i < ARRAY_SIZE(red2); i++) {
|
||||||
red2[i] = ~red2[i];
|
red2[i] = ~red2[i];
|
||||||
green2[i] = ~green2[i];
|
green2[i] = ~green2[i];
|
||||||
blue2[i] = ~blue2[i];
|
blue2[i] = ~blue2[i];
|
||||||
}
|
}
|
||||||
for (i = 0; i < 4; i++) {
|
for (i = 0; i < ARRAY_SIZE(red4); i++) {
|
||||||
red4[i] = ~red4[i];
|
red4[i] = ~red4[i];
|
||||||
green4[i] = ~green4[i];
|
green4[i] = ~green4[i];
|
||||||
blue4[i] = ~blue4[i];
|
blue4[i] = ~blue4[i];
|
||||||
}
|
}
|
||||||
for (i = 0; i < 8; i++) {
|
for (i = 0; i < ARRAY_SIZE(red8); i++) {
|
||||||
red8[i] = ~red8[i];
|
red8[i] = ~red8[i];
|
||||||
green8[i] = ~green8[i];
|
green8[i] = ~green8[i];
|
||||||
blue8[i] = ~blue8[i];
|
blue8[i] = ~blue8[i];
|
||||||
}
|
}
|
||||||
for (i = 0; i < 16; i++) {
|
for (i = 0; i < ARRAY_SIZE(red16); i++) {
|
||||||
red16[i] = ~red16[i];
|
red16[i] = ~red16[i];
|
||||||
green16[i] = ~green16[i];
|
green16[i] = ~green16[i];
|
||||||
blue16[i] = ~blue16[i];
|
blue16[i] = ~blue16[i];
|
||||||
|
@ -970,11 +970,11 @@ extern struct fb_videomode *fb_find_best_display(struct fb_monspecs *specs,
|
|||||||
/* drivers/video/fbcmap.c */
|
/* drivers/video/fbcmap.c */
|
||||||
extern int fb_alloc_cmap(struct fb_cmap *cmap, int len, int transp);
|
extern int fb_alloc_cmap(struct fb_cmap *cmap, int len, int transp);
|
||||||
extern void fb_dealloc_cmap(struct fb_cmap *cmap);
|
extern void fb_dealloc_cmap(struct fb_cmap *cmap);
|
||||||
extern int fb_copy_cmap(struct fb_cmap *from, struct fb_cmap *to);
|
extern int fb_copy_cmap(const struct fb_cmap *from, struct fb_cmap *to);
|
||||||
extern int fb_cmap_to_user(struct fb_cmap *from, struct fb_cmap_user *to);
|
extern int fb_cmap_to_user(const struct fb_cmap *from, struct fb_cmap_user *to);
|
||||||
extern int fb_set_cmap(struct fb_cmap *cmap, struct fb_info *fb_info);
|
extern int fb_set_cmap(struct fb_cmap *cmap, struct fb_info *fb_info);
|
||||||
extern int fb_set_user_cmap(struct fb_cmap_user *cmap, struct fb_info *fb_info);
|
extern int fb_set_user_cmap(struct fb_cmap_user *cmap, struct fb_info *fb_info);
|
||||||
extern struct fb_cmap *fb_default_cmap(int len);
|
extern const struct fb_cmap *fb_default_cmap(int len);
|
||||||
extern void fb_invert_cmaps(void);
|
extern void fb_invert_cmaps(void);
|
||||||
|
|
||||||
struct fb_videomode {
|
struct fb_videomode {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user