1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
/*
* Visual control
*
* (C) Copyright 2001 Geert Uytterhoeven
*
* This file is subject to the terms and conditions of the GNU General Public
* License. See the file COPYING in the main directory of this archive for
* more details.
*/
#include <stdlib.h>
#include "types.h"
#include "visual.h"
#include "visops.h"
#include "fb.h"
#include "util.h"
/*
* Set the visual
*/
int visual_set(enum visual_id id)
{
return visops.set_visual(id);
}
/*
* Monochrome
*/
pixel_t black_pixel, white_pixel;
/*
* Grayscale
*/
u32 gray_len, gray_bits;
const pixel_t *gray_pixel;
/*
* CLUT for Pseudocolor and Directcolor
*/
u32 idx_len, idx_bits;
const pixel_t *idx_pixel;
rgba_t *clut;
void clut_update(void)
{
if (visops.update_cmap)
visops.update_cmap();
}
/*
* RGB(A) for Truecolor and DirectColor
*/
u32 red_len, green_len, blue_len, alpha_len;
u32 red_bits, green_bits, blue_bits, alpha_bits;
const pixel_t *red_pixel, *green_pixel, *blue_pixel, *alpha_pixel;
/*
* Reverse the bits in a 32-bit word
*/
static u32 reverse32(u32 x)
{
x = ((x & 0xffff0000) >> 16) | ((x & 0x0000ffff) << 16);
x = ((x & 0xff00ff00) >> 8) | ((x & 0x00ff00ff) << 8);
x = ((x & 0xf0f0f0f0) >> 4) | ((x & 0x0f0f0f0f) << 4);
x = ((x & 0xcccccccc) >> 2) | ((x & 0x33333333) << 2);
x = ((x & 0xaaaaaaaa) >> 1) | ((x & 0x55555555) << 1);
return x;
}
/*
* Create an indexed table for one color component, based on the color
* bitfield
*/
pixel_t *create_component_table(u32 size, u32 offset, int msb_right, u32 bpp)
{
pixel_t *table, pixel;
int i;
if (!size)
return NULL;
table = malloc(size*sizeof(pixel_t));
for (i = 0; i < size; i++) {
pixel = i<<offset;
table[i] = msb_right ? reverse32(pixel)>>(32-bpp) : pixel;
}
return table;
}
|