kvm: qemu: move tpr-patch routine to qemu-kvm-x86.c
[kvm-userspace.git] / vgabios / vgatables.h
blob3ac96bbbb1a489fdfd9b5d91a4c59d11eff59d1b
1 /*
3 * BIOS Memory
5 */
6 #define BIOSMEM_SEG 0x40
8 #define BIOSMEM_INITIAL_MODE 0x10
9 #define BIOSMEM_CURRENT_MODE 0x49
10 #define BIOSMEM_NB_COLS 0x4A
11 #define BIOSMEM_PAGE_SIZE 0x4C
12 #define BIOSMEM_CURRENT_START 0x4E
13 #define BIOSMEM_CURSOR_POS 0x50
14 #define BIOSMEM_CURSOR_TYPE 0x60
15 #define BIOSMEM_CURRENT_PAGE 0x62
16 #define BIOSMEM_CRTC_ADDRESS 0x63
17 #define BIOSMEM_CURRENT_MSR 0x65
18 #define BIOSMEM_CURRENT_PAL 0x66
19 #define BIOSMEM_NB_ROWS 0x84
20 #define BIOSMEM_CHAR_HEIGHT 0x85
21 #define BIOSMEM_VIDEO_CTL 0x87
22 #define BIOSMEM_SWITCHES 0x88
23 #define BIOSMEM_MODESET_CTL 0x89
24 #define BIOSMEM_DCC_INDEX 0x8A
25 #define BIOSMEM_VS_POINTER 0xA8
26 #define BIOSMEM_VBE_FLAG 0xB9
27 #define BIOSMEM_VBE_MODE 0xBA
32 * VGA registers
35 #define VGAREG_ACTL_ADDRESS 0x3c0
36 #define VGAREG_ACTL_WRITE_DATA 0x3c0
37 #define VGAREG_ACTL_READ_DATA 0x3c1
39 #define VGAREG_INPUT_STATUS 0x3c2
40 #define VGAREG_WRITE_MISC_OUTPUT 0x3c2
41 #define VGAREG_VIDEO_ENABLE 0x3c3
42 #define VGAREG_SEQU_ADDRESS 0x3c4
43 #define VGAREG_SEQU_DATA 0x3c5
45 #define VGAREG_PEL_MASK 0x3c6
46 #define VGAREG_DAC_STATE 0x3c7
47 #define VGAREG_DAC_READ_ADDRESS 0x3c7
48 #define VGAREG_DAC_WRITE_ADDRESS 0x3c8
49 #define VGAREG_DAC_DATA 0x3c9
51 #define VGAREG_READ_FEATURE_CTL 0x3ca
52 #define VGAREG_READ_MISC_OUTPUT 0x3cc
54 #define VGAREG_GRDC_ADDRESS 0x3ce
55 #define VGAREG_GRDC_DATA 0x3cf
57 #define VGAREG_MDA_CRTC_ADDRESS 0x3b4
58 #define VGAREG_MDA_CRTC_DATA 0x3b5
59 #define VGAREG_VGA_CRTC_ADDRESS 0x3d4
60 #define VGAREG_VGA_CRTC_DATA 0x3d5
62 #define VGAREG_MDA_WRITE_FEATURE_CTL 0x3ba
63 #define VGAREG_VGA_WRITE_FEATURE_CTL 0x3da
64 #define VGAREG_ACTL_RESET 0x3da
66 #define VGAREG_MDA_MODECTL 0x3b8
67 #define VGAREG_CGA_MODECTL 0x3d8
68 #define VGAREG_CGA_PALETTE 0x3d9
70 /* Video memory */
71 #define VGAMEM_GRAPH 0xA000
72 #define VGAMEM_CTEXT 0xB800
73 #define VGAMEM_MTEXT 0xB000
77 * Tables of default values for each mode
80 #define MODE_MAX 15
81 #define TEXT 0x00
82 #define GRAPH 0x01
84 #define CTEXT 0x00
85 #define MTEXT 0x01
86 #define CGA 0x02
87 #define PLANAR1 0x03
88 #define PLANAR4 0x04
89 #define LINEAR8 0x05
91 // for SVGA
92 #define LINEAR15 0x10
93 #define LINEAR16 0x11
94 #define LINEAR24 0x12
95 #define LINEAR32 0x13
97 typedef struct
98 {Bit8u svgamode;
99 Bit8u class; /* TEXT, GRAPH */
100 Bit8u memmodel; /* CTEXT,MTEXT,CGA,PL1,PL2,PL4,P8,P15,P16,P24,P32 */
101 Bit8u pixbits;
102 Bit16u sstart;
103 Bit8u pelmask;
104 Bit8u dacmodel; /* 0 1 2 3 */
105 } VGAMODES;
107 static VGAMODES vga_modes[MODE_MAX+1]=
108 {//mode class model bits sstart pelm dac
109 {0x00, TEXT, CTEXT, 4, 0xB800, 0xFF, 0x02},
110 {0x01, TEXT, CTEXT, 4, 0xB800, 0xFF, 0x02},
111 {0x02, TEXT, CTEXT, 4, 0xB800, 0xFF, 0x02},
112 {0x03, TEXT, CTEXT, 4, 0xB800, 0xFF, 0x02},
113 {0x04, GRAPH, CGA, 2, 0xB800, 0xFF, 0x01},
114 {0x05, GRAPH, CGA, 2, 0xB800, 0xFF, 0x01},
115 {0x06, GRAPH, CGA, 1, 0xB800, 0xFF, 0x01},
116 {0x07, TEXT, MTEXT, 4, 0xB000, 0xFF, 0x00},
117 {0x0D, GRAPH, PLANAR4, 4, 0xA000, 0xFF, 0x01},
118 {0x0E, GRAPH, PLANAR4, 4, 0xA000, 0xFF, 0x01},
119 {0x0F, GRAPH, PLANAR1, 1, 0xA000, 0xFF, 0x00},
120 {0x10, GRAPH, PLANAR4, 4, 0xA000, 0xFF, 0x02},
121 {0x11, GRAPH, PLANAR1, 1, 0xA000, 0xFF, 0x02},
122 {0x12, GRAPH, PLANAR4, 4, 0xA000, 0xFF, 0x02},
123 {0x13, GRAPH, LINEAR8, 8, 0xA000, 0xFF, 0x03},
124 {0x6A, GRAPH, PLANAR4, 4, 0xA000, 0xFF, 0x02}
127 /* convert index in vga_modes[] to index in video_param_table[] */
128 static Bit8u line_to_vpti[MODE_MAX+1]={
129 0x17, 0x17, 0x18, 0x18, 0x04, 0x05, 0x06, 0x07,
130 0x0d, 0x0e, 0x11, 0x12, 0x1a, 0x1b, 0x1c, 0x1d,
133 /* Default Palette */
134 #define DAC_MAX_MODEL 3
136 static Bit8u dac_regs[DAC_MAX_MODEL+1]=
137 {0x3f,0x3f,0x3f,0xff};
139 /* standard BIOS Video Parameter Table */
140 typedef struct {
141 Bit8u twidth;
142 Bit8u theightm1;
143 Bit8u cheight;
144 Bit8u slength_l;
145 Bit8u slength_h;
146 Bit8u sequ_regs[4];
147 Bit8u miscreg;
148 Bit8u crtc_regs[25];
149 Bit8u actl_regs[20];
150 Bit8u grdc_regs[9];
151 } VideoParamTableEntry;
153 static VideoParamTableEntry video_param_table[30] = {
155 /* index=0x00 no mode defined */
156 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
157 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
158 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
159 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
160 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
161 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
162 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
163 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
166 /* index=0x01 no mode defined */
167 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
168 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
169 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
170 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
171 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
172 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
173 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
174 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
177 /* index=0x02 no mode defined */
178 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
179 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
180 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
181 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
182 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
183 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
184 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
185 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
188 /* index=0x03 no mode defined */
189 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
190 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
191 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
192 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
193 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
194 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
195 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
196 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
199 /* index=0x04 vga mode 0x04 */
200 40, 24, 8, 0x00, 0x08, /* tw, th-1, ch, slength */
201 0x09, 0x03, 0x00, 0x02, /* sequ_regs */
202 0x63, /* miscreg */
203 0x2d, 0x27, 0x28, 0x90, 0x2b, 0x80, 0xbf, 0x1f,
204 0x00, 0xc1, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
205 0x9c, 0x8e, 0x8f, 0x14, 0x00, 0x96, 0xb9, 0xa2,
206 0xff, /* crtc_regs */
207 0x00, 0x13, 0x15, 0x17, 0x02, 0x04, 0x06, 0x07,
208 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17,
209 0x01, 0x00, 0x03, 0x00, /* actl_regs */
210 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, 0x0f, 0x0f, 0xff, /* grdc_regs */
213 /* index=0x05 vga mode 0x05 */
214 40, 24, 8, 0x00, 0x08, /* tw, th-1, ch, slength */
215 0x09, 0x03, 0x00, 0x02, /* sequ_regs */
216 0x63, /* miscreg */
217 0x2d, 0x27, 0x28, 0x90, 0x2b, 0x80, 0xbf, 0x1f,
218 0x00, 0xc1, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
219 0x9c, 0x8e, 0x8f, 0x14, 0x00, 0x96, 0xb9, 0xa2,
220 0xff, /* crtc_regs */
221 0x00, 0x13, 0x15, 0x17, 0x02, 0x04, 0x06, 0x07,
222 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17,
223 0x01, 0x00, 0x03, 0x00, /* actl_regs */
224 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, 0x0f, 0x0f, 0xff, /* grdc_regs */
227 /* index=0x06 vga mode 0x06 */
228 80, 24, 8, 0x00, 0x10, /* tw, th-1, ch, slength */
229 0x01, 0x01, 0x00, 0x06, /* sequ_regs */
230 0x63, /* miscreg */
231 0x5f, 0x4f, 0x50, 0x82, 0x54, 0x80, 0xbf, 0x1f,
232 0x00, 0xc1, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
233 0x9c, 0x8e, 0x8f, 0x28, 0x00, 0x96, 0xb9, 0xc2,
234 0xff, /* crtc_regs */
235 0x00, 0x17, 0x17, 0x17, 0x17, 0x17, 0x17, 0x17,
236 0x17, 0x17, 0x17, 0x17, 0x17, 0x17, 0x17, 0x17,
237 0x01, 0x00, 0x01, 0x00, /* actl_regs */
238 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0d, 0x0f, 0xff, /* grdc_regs */
241 /* index=0x07 vga mode 0x07 */
242 80, 24, 16, 0x00, 0x10, /* tw, th-1, ch, slength */
243 0x00, 0x03, 0x00, 0x02, /* sequ_regs */
244 0x66, /* miscreg */
245 0x5f, 0x4f, 0x50, 0x82, 0x55, 0x81, 0xbf, 0x1f,
246 0x00, 0x4f, 0x0d, 0x0e, 0x00, 0x00, 0x00, 0x00,
247 0x9c, 0x8e, 0x8f, 0x28, 0x0f, 0x96, 0xb9, 0xa3,
248 0xff, /* crtc_regs */
249 0x00, 0x08, 0x08, 0x08, 0x08, 0x08, 0x08, 0x08,
250 0x10, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
251 0x0e, 0x00, 0x0f, 0x08, /* actl_regs */
252 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x0a, 0x0f, 0xff, /* grdc_regs */
255 /* index=0x08 no mode defined */
256 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
257 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
258 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
259 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
260 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
261 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
262 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
263 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
266 /* index=0x09 no mode defined */
267 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
268 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
269 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
270 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
271 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
272 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
273 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
274 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
277 /* index=0x0a no mode defined */
278 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
279 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
280 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
281 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
282 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
283 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
284 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
285 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
288 /* index=0x0b no mode defined */
289 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
290 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
291 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
292 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
293 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
294 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
295 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
296 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
299 /* index=0x0c no mode defined */
300 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
301 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
302 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
303 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
304 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
305 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
306 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
307 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
310 /* index=0x0d vga mode 0x0d */
311 40, 24, 8, 0x00, 0x20, /* tw, th-1, ch, slength */
312 0x09, 0x0f, 0x00, 0x06, /* sequ_regs */
313 0x63, /* miscreg */
314 0x2d, 0x27, 0x28, 0x90, 0x2b, 0x80, 0xbf, 0x1f,
315 0x00, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
316 0x9c, 0x8e, 0x8f, 0x14, 0x00, 0x96, 0xb9, 0xe3,
317 0xff, /* crtc_regs */
318 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
319 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17,
320 0x01, 0x00, 0x0f, 0x00, /* actl_regs */
321 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x05, 0x0f, 0xff, /* grdc_regs */
324 /* index=0x0e vga mode 0x0e */
325 80, 24, 8, 0x00, 0x40, /* tw, th-1, ch, slength */
326 0x01, 0x0f, 0x00, 0x06, /* sequ_regs */
327 0x63, /* miscreg */
328 0x5f, 0x4f, 0x50, 0x82, 0x54, 0x80, 0xbf, 0x1f,
329 0x00, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
330 0x9c, 0x8e, 0x8f, 0x28, 0x00, 0x96, 0xb9, 0xe3,
331 0xff, /* crtc_regs */
332 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
333 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17,
334 0x01, 0x00, 0x0f, 0x00, /* actl_regs */
335 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x05, 0x0f, 0xff, /* grdc_regs */
338 /* index=0x0f no mode defined */
339 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
340 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
341 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
342 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
343 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
344 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
345 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
346 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
349 /* index=0x10 no mode defined */
350 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
351 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
352 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
353 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
354 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
355 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
356 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
357 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
360 /* index=0x11 vga mode 0x0f */
361 80, 24, 14, 0x00, 0x80, /* tw, th-1, ch, slength */
362 0x01, 0x0f, 0x00, 0x06, /* sequ_regs */
363 0xa3, /* miscreg */
364 0x5f, 0x4f, 0x50, 0x82, 0x54, 0x80, 0xbf, 0x1f,
365 0x00, 0x40, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
366 0x83, 0x85, 0x5d, 0x28, 0x0f, 0x63, 0xba, 0xe3,
367 0xff, /* crtc_regs */
368 0x00, 0x08, 0x00, 0x00, 0x18, 0x18, 0x00, 0x00,
369 0x00, 0x08, 0x00, 0x00, 0x00, 0x18, 0x00, 0x00,
370 0x01, 0x00, 0x01, 0x00, /* actl_regs */
371 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x05, 0x0f, 0xff, /* grdc_regs */
374 /* index=0x12 vga mode 0x10 */
375 80, 24, 14, 0x00, 0x80, /* tw, th-1, ch, slength */
376 0x01, 0x0f, 0x00, 0x06, /* sequ_regs */
377 0xa3, /* miscreg */
378 0x5f, 0x4f, 0x50, 0x82, 0x54, 0x80, 0xbf, 0x1f,
379 0x00, 0x40, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
380 0x83, 0x85, 0x5d, 0x28, 0x0f, 0x63, 0xba, 0xe3,
381 0xff, /* crtc_regs */
382 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x14, 0x07,
383 0x38, 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f,
384 0x01, 0x00, 0x0f, 0x00, /* actl_regs */
385 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x05, 0x0f, 0xff, /* grdc_regs */
388 /* index=0x13 no mode defined */
389 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
390 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
391 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
392 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
393 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
394 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
395 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
396 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
399 /* index=0x14 no mode defined */
400 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
401 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
402 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
403 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
404 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
405 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
406 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
407 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
410 /* index=0x15 no mode defined */
411 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
412 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
413 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
414 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
415 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
416 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
417 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
418 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
421 /* index=0x16 no mode defined */
422 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
423 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
424 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
425 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
426 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
427 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
428 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
429 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
432 /* index=0x17 vga mode 0x01 */
433 40, 24, 16, 0x00, 0x08, /* tw, th-1, ch, slength */
434 0x08, 0x03, 0x00, 0x02, /* sequ_regs */
435 0x67, /* miscreg */
436 0x2d, 0x27, 0x28, 0x90, 0x2b, 0xa0, 0xbf, 0x1f,
437 0x00, 0x4f, 0x0d, 0x0e, 0x00, 0x00, 0x00, 0x00,
438 0x9c, 0x8e, 0x8f, 0x14, 0x1f, 0x96, 0xb9, 0xa3,
439 0xff, /* crtc_regs */
440 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x14, 0x07,
441 0x38, 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f,
442 0x0c, 0x00, 0x0f, 0x08, /* actl_regs */
443 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x0e, 0x0f, 0xff, /* grdc_regs */
446 /* index=0x18 vga mode 0x03 */
447 80, 24, 16, 0x00, 0x10, /* tw, th-1, ch, slength */
448 0x00, 0x03, 0x00, 0x02, /* sequ_regs */
449 0x67, /* miscreg */
450 0x5f, 0x4f, 0x50, 0x82, 0x55, 0x81, 0xbf, 0x1f,
451 0x00, 0x4f, 0x0d, 0x0e, 0x00, 0x00, 0x00, 0x00,
452 0x9c, 0x8e, 0x8f, 0x28, 0x1f, 0x96, 0xb9, 0xa3,
453 0xff, /* crtc_regs */
454 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x14, 0x07,
455 0x38, 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f,
456 0x0c, 0x00, 0x0f, 0x08, /* actl_regs */
457 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x0e, 0x0f, 0xff, /* grdc_regs */
460 /* index=0x19 vga mode 0x07 */
461 80, 24, 16, 0x00, 0x10, /* tw, th-1, ch, slength */
462 0x00, 0x03, 0x00, 0x02, /* sequ_regs */
463 0x66, /* miscreg */
464 0x5f, 0x4f, 0x50, 0x82, 0x55, 0x81, 0xbf, 0x1f,
465 0x00, 0x4f, 0x0d, 0x0e, 0x00, 0x00, 0x00, 0x00,
466 0x9c, 0x8e, 0x8f, 0x28, 0x0f, 0x96, 0xb9, 0xa3,
467 0xff, /* crtc_regs */
468 0x00, 0x08, 0x08, 0x08, 0x08, 0x08, 0x08, 0x08,
469 0x10, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
470 0x0e, 0x00, 0x0f, 0x08, /* actl_regs */
471 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x0a, 0x0f, 0xff, /* grdc_regs */
474 /* index=0x1a vga mode 0x11 */
475 80, 29, 16, 0x00, 0x00, /* tw, th-1, ch, slength */
476 0x01, 0x0f, 0x00, 0x06, /* sequ_regs */
477 0xe3, /* miscreg */
478 0x5f, 0x4f, 0x50, 0x82, 0x54, 0x80, 0x0b, 0x3e,
479 0x00, 0x40, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
480 0xea, 0x8c, 0xdf, 0x28, 0x00, 0xe7, 0x04, 0xe3,
481 0xff, /* crtc_regs */
482 0x00, 0x3f, 0x00, 0x3f, 0x00, 0x3f, 0x00, 0x3f,
483 0x00, 0x3f, 0x00, 0x3f, 0x00, 0x3f, 0x00, 0x3f,
484 0x01, 0x00, 0x0f, 0x00, /* actl_regs */
485 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x05, 0x0f, 0xff, /* grdc_regs */
488 /* index=0x1b vga mode 0x12 */
489 80, 29, 16, 0x00, 0x00, /* tw, th-1, ch, slength */
490 0x01, 0x0f, 0x00, 0x06, /* sequ_regs */
491 0xe3, /* miscreg */
492 0x5f, 0x4f, 0x50, 0x82, 0x54, 0x80, 0x0b, 0x3e,
493 0x00, 0x40, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
494 0xea, 0x8c, 0xdf, 0x28, 0x00, 0xe7, 0x04, 0xe3,
495 0xff, /* crtc_regs */
496 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x14, 0x07,
497 0x38, 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f,
498 0x01, 0x00, 0x0f, 0x00, /* actl_regs */
499 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x05, 0x0f, 0xff, /* grdc_regs */
502 /* index=0x1c vga mode 0x13 */
503 40, 24, 8, 0x00, 0x00, /* tw, th-1, ch, slength */
504 0x01, 0x0f, 0x00, 0x0e, /* sequ_regs */
505 0x63, /* miscreg */
506 0x5f, 0x4f, 0x50, 0x82, 0x54, 0x80, 0xbf, 0x1f,
507 0x00, 0x41, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
508 0x9c, 0x8e, 0x8f, 0x28, 0x40, 0x96, 0xb9, 0xa3,
509 0xff, /* crtc_regs */
510 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
511 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,
512 0x41, 0x00, 0x0f, 0x00, /* actl_regs */
513 0x00, 0x00, 0x00, 0x00, 0x00, 0x40, 0x05, 0x0f, 0xff, /* grdc_regs */
516 /* index=0x1d vga mode 0x6a */
517 100, 36, 16, 0x00, 0x00, /* tw, th-1, ch, slength */
518 0x01, 0x0f, 0x00, 0x06, /* sequ_regs */
519 0xe3, /* miscreg */
520 0x7f, 0x63, 0x63, 0x83, 0x6b, 0x1b, 0x72, 0xf0,
521 0x00, 0x60, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
522 0x59, 0x8d, 0x57, 0x32, 0x00, 0x57, 0x73, 0xe3,
523 0xff, /* crtc_regs */
524 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x14, 0x07,
525 0x38, 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f,
526 0x01, 0x00, 0x0f, 0x00, /* actl_regs */
527 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x05, 0x0f, 0xff, /* grdc_regs */
531 /* Mono */
532 static Bit8u palette0[63+1][3]=
534 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00,
535 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a,
536 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a,
537 0x3f,0x3f,0x3f, 0x3f,0x3f,0x3f, 0x3f,0x3f,0x3f, 0x3f,0x3f,0x3f, 0x3f,0x3f,0x3f, 0x3f,0x3f,0x3f, 0x3f,0x3f,0x3f, 0x3f,0x3f,0x3f,
538 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00,
539 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a,
540 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a, 0x2a,0x2a,0x2a,
541 0x3f,0x3f,0x3f, 0x3f,0x3f,0x3f, 0x3f,0x3f,0x3f, 0x3f,0x3f,0x3f, 0x3f,0x3f,0x3f, 0x3f,0x3f,0x3f, 0x3f,0x3f,0x3f, 0x3f,0x3f,0x3f
544 static Bit8u palette1[63+1][3]=
546 0x00,0x00,0x00, 0x00,0x00,0x2a, 0x00,0x2a,0x00, 0x00,0x2a,0x2a, 0x2a,0x00,0x00, 0x2a,0x00,0x2a, 0x2a,0x15,0x00, 0x2a,0x2a,0x2a,
547 0x00,0x00,0x00, 0x00,0x00,0x2a, 0x00,0x2a,0x00, 0x00,0x2a,0x2a, 0x2a,0x00,0x00, 0x2a,0x00,0x2a, 0x2a,0x15,0x00, 0x2a,0x2a,0x2a,
548 0x15,0x15,0x15, 0x15,0x15,0x3f, 0x15,0x3f,0x15, 0x15,0x3f,0x3f, 0x3f,0x15,0x15, 0x3f,0x15,0x3f, 0x3f,0x3f,0x15, 0x3f,0x3f,0x3f,
549 0x15,0x15,0x15, 0x15,0x15,0x3f, 0x15,0x3f,0x15, 0x15,0x3f,0x3f, 0x3f,0x15,0x15, 0x3f,0x15,0x3f, 0x3f,0x3f,0x15, 0x3f,0x3f,0x3f,
550 0x00,0x00,0x00, 0x00,0x00,0x2a, 0x00,0x2a,0x00, 0x00,0x2a,0x2a, 0x2a,0x00,0x00, 0x2a,0x00,0x2a, 0x2a,0x15,0x00, 0x2a,0x2a,0x2a,
551 0x00,0x00,0x00, 0x00,0x00,0x2a, 0x00,0x2a,0x00, 0x00,0x2a,0x2a, 0x2a,0x00,0x00, 0x2a,0x00,0x2a, 0x2a,0x15,0x00, 0x2a,0x2a,0x2a,
552 0x15,0x15,0x15, 0x15,0x15,0x3f, 0x15,0x3f,0x15, 0x15,0x3f,0x3f, 0x3f,0x15,0x15, 0x3f,0x15,0x3f, 0x3f,0x3f,0x15, 0x3f,0x3f,0x3f,
553 0x15,0x15,0x15, 0x15,0x15,0x3f, 0x15,0x3f,0x15, 0x15,0x3f,0x3f, 0x3f,0x15,0x15, 0x3f,0x15,0x3f, 0x3f,0x3f,0x15, 0x3f,0x3f,0x3f
556 static Bit8u palette2[63+1][3]=
558 0x00,0x00,0x00, 0x00,0x00,0x2a, 0x00,0x2a,0x00, 0x00,0x2a,0x2a, 0x2a,0x00,0x00, 0x2a,0x00,0x2a, 0x2a,0x2a,0x00, 0x2a,0x2a,0x2a,
559 0x00,0x00,0x15, 0x00,0x00,0x3f, 0x00,0x2a,0x15, 0x00,0x2a,0x3f, 0x2a,0x00,0x15, 0x2a,0x00,0x3f, 0x2a,0x2a,0x15, 0x2a,0x2a,0x3f,
560 0x00,0x15,0x00, 0x00,0x15,0x2a, 0x00,0x3f,0x00, 0x00,0x3f,0x2a, 0x2a,0x15,0x00, 0x2a,0x15,0x2a, 0x2a,0x3f,0x00, 0x2a,0x3f,0x2a,
561 0x00,0x15,0x15, 0x00,0x15,0x3f, 0x00,0x3f,0x15, 0x00,0x3f,0x3f, 0x2a,0x15,0x15, 0x2a,0x15,0x3f, 0x2a,0x3f,0x15, 0x2a,0x3f,0x3f,
562 0x15,0x00,0x00, 0x15,0x00,0x2a, 0x15,0x2a,0x00, 0x15,0x2a,0x2a, 0x3f,0x00,0x00, 0x3f,0x00,0x2a, 0x3f,0x2a,0x00, 0x3f,0x2a,0x2a,
563 0x15,0x00,0x15, 0x15,0x00,0x3f, 0x15,0x2a,0x15, 0x15,0x2a,0x3f, 0x3f,0x00,0x15, 0x3f,0x00,0x3f, 0x3f,0x2a,0x15, 0x3f,0x2a,0x3f,
564 0x15,0x15,0x00, 0x15,0x15,0x2a, 0x15,0x3f,0x00, 0x15,0x3f,0x2a, 0x3f,0x15,0x00, 0x3f,0x15,0x2a, 0x3f,0x3f,0x00, 0x3f,0x3f,0x2a,
565 0x15,0x15,0x15, 0x15,0x15,0x3f, 0x15,0x3f,0x15, 0x15,0x3f,0x3f, 0x3f,0x15,0x15, 0x3f,0x15,0x3f, 0x3f,0x3f,0x15, 0x3f,0x3f,0x3f
568 static Bit8u palette3[256][3]=
570 0x00,0x00,0x00, 0x00,0x00,0x2a, 0x00,0x2a,0x00, 0x00,0x2a,0x2a, 0x2a,0x00,0x00, 0x2a,0x00,0x2a, 0x2a,0x15,0x00, 0x2a,0x2a,0x2a,
571 0x15,0x15,0x15, 0x15,0x15,0x3f, 0x15,0x3f,0x15, 0x15,0x3f,0x3f, 0x3f,0x15,0x15, 0x3f,0x15,0x3f, 0x3f,0x3f,0x15, 0x3f,0x3f,0x3f,
572 0x00,0x00,0x00, 0x05,0x05,0x05, 0x08,0x08,0x08, 0x0b,0x0b,0x0b, 0x0e,0x0e,0x0e, 0x11,0x11,0x11, 0x14,0x14,0x14, 0x18,0x18,0x18,
573 0x1c,0x1c,0x1c, 0x20,0x20,0x20, 0x24,0x24,0x24, 0x28,0x28,0x28, 0x2d,0x2d,0x2d, 0x32,0x32,0x32, 0x38,0x38,0x38, 0x3f,0x3f,0x3f,
574 0x00,0x00,0x3f, 0x10,0x00,0x3f, 0x1f,0x00,0x3f, 0x2f,0x00,0x3f, 0x3f,0x00,0x3f, 0x3f,0x00,0x2f, 0x3f,0x00,0x1f, 0x3f,0x00,0x10,
575 0x3f,0x00,0x00, 0x3f,0x10,0x00, 0x3f,0x1f,0x00, 0x3f,0x2f,0x00, 0x3f,0x3f,0x00, 0x2f,0x3f,0x00, 0x1f,0x3f,0x00, 0x10,0x3f,0x00,
576 0x00,0x3f,0x00, 0x00,0x3f,0x10, 0x00,0x3f,0x1f, 0x00,0x3f,0x2f, 0x00,0x3f,0x3f, 0x00,0x2f,0x3f, 0x00,0x1f,0x3f, 0x00,0x10,0x3f,
577 0x1f,0x1f,0x3f, 0x27,0x1f,0x3f, 0x2f,0x1f,0x3f, 0x37,0x1f,0x3f, 0x3f,0x1f,0x3f, 0x3f,0x1f,0x37, 0x3f,0x1f,0x2f, 0x3f,0x1f,0x27,
579 0x3f,0x1f,0x1f, 0x3f,0x27,0x1f, 0x3f,0x2f,0x1f, 0x3f,0x37,0x1f, 0x3f,0x3f,0x1f, 0x37,0x3f,0x1f, 0x2f,0x3f,0x1f, 0x27,0x3f,0x1f,
580 0x1f,0x3f,0x1f, 0x1f,0x3f,0x27, 0x1f,0x3f,0x2f, 0x1f,0x3f,0x37, 0x1f,0x3f,0x3f, 0x1f,0x37,0x3f, 0x1f,0x2f,0x3f, 0x1f,0x27,0x3f,
581 0x2d,0x2d,0x3f, 0x31,0x2d,0x3f, 0x36,0x2d,0x3f, 0x3a,0x2d,0x3f, 0x3f,0x2d,0x3f, 0x3f,0x2d,0x3a, 0x3f,0x2d,0x36, 0x3f,0x2d,0x31,
582 0x3f,0x2d,0x2d, 0x3f,0x31,0x2d, 0x3f,0x36,0x2d, 0x3f,0x3a,0x2d, 0x3f,0x3f,0x2d, 0x3a,0x3f,0x2d, 0x36,0x3f,0x2d, 0x31,0x3f,0x2d,
583 0x2d,0x3f,0x2d, 0x2d,0x3f,0x31, 0x2d,0x3f,0x36, 0x2d,0x3f,0x3a, 0x2d,0x3f,0x3f, 0x2d,0x3a,0x3f, 0x2d,0x36,0x3f, 0x2d,0x31,0x3f,
584 0x00,0x00,0x1c, 0x07,0x00,0x1c, 0x0e,0x00,0x1c, 0x15,0x00,0x1c, 0x1c,0x00,0x1c, 0x1c,0x00,0x15, 0x1c,0x00,0x0e, 0x1c,0x00,0x07,
585 0x1c,0x00,0x00, 0x1c,0x07,0x00, 0x1c,0x0e,0x00, 0x1c,0x15,0x00, 0x1c,0x1c,0x00, 0x15,0x1c,0x00, 0x0e,0x1c,0x00, 0x07,0x1c,0x00,
586 0x00,0x1c,0x00, 0x00,0x1c,0x07, 0x00,0x1c,0x0e, 0x00,0x1c,0x15, 0x00,0x1c,0x1c, 0x00,0x15,0x1c, 0x00,0x0e,0x1c, 0x00,0x07,0x1c,
588 0x0e,0x0e,0x1c, 0x11,0x0e,0x1c, 0x15,0x0e,0x1c, 0x18,0x0e,0x1c, 0x1c,0x0e,0x1c, 0x1c,0x0e,0x18, 0x1c,0x0e,0x15, 0x1c,0x0e,0x11,
589 0x1c,0x0e,0x0e, 0x1c,0x11,0x0e, 0x1c,0x15,0x0e, 0x1c,0x18,0x0e, 0x1c,0x1c,0x0e, 0x18,0x1c,0x0e, 0x15,0x1c,0x0e, 0x11,0x1c,0x0e,
590 0x0e,0x1c,0x0e, 0x0e,0x1c,0x11, 0x0e,0x1c,0x15, 0x0e,0x1c,0x18, 0x0e,0x1c,0x1c, 0x0e,0x18,0x1c, 0x0e,0x15,0x1c, 0x0e,0x11,0x1c,
591 0x14,0x14,0x1c, 0x16,0x14,0x1c, 0x18,0x14,0x1c, 0x1a,0x14,0x1c, 0x1c,0x14,0x1c, 0x1c,0x14,0x1a, 0x1c,0x14,0x18, 0x1c,0x14,0x16,
592 0x1c,0x14,0x14, 0x1c,0x16,0x14, 0x1c,0x18,0x14, 0x1c,0x1a,0x14, 0x1c,0x1c,0x14, 0x1a,0x1c,0x14, 0x18,0x1c,0x14, 0x16,0x1c,0x14,
593 0x14,0x1c,0x14, 0x14,0x1c,0x16, 0x14,0x1c,0x18, 0x14,0x1c,0x1a, 0x14,0x1c,0x1c, 0x14,0x1a,0x1c, 0x14,0x18,0x1c, 0x14,0x16,0x1c,
594 0x00,0x00,0x10, 0x04,0x00,0x10, 0x08,0x00,0x10, 0x0c,0x00,0x10, 0x10,0x00,0x10, 0x10,0x00,0x0c, 0x10,0x00,0x08, 0x10,0x00,0x04,
595 0x10,0x00,0x00, 0x10,0x04,0x00, 0x10,0x08,0x00, 0x10,0x0c,0x00, 0x10,0x10,0x00, 0x0c,0x10,0x00, 0x08,0x10,0x00, 0x04,0x10,0x00,
597 0x00,0x10,0x00, 0x00,0x10,0x04, 0x00,0x10,0x08, 0x00,0x10,0x0c, 0x00,0x10,0x10, 0x00,0x0c,0x10, 0x00,0x08,0x10, 0x00,0x04,0x10,
598 0x08,0x08,0x10, 0x0a,0x08,0x10, 0x0c,0x08,0x10, 0x0e,0x08,0x10, 0x10,0x08,0x10, 0x10,0x08,0x0e, 0x10,0x08,0x0c, 0x10,0x08,0x0a,
599 0x10,0x08,0x08, 0x10,0x0a,0x08, 0x10,0x0c,0x08, 0x10,0x0e,0x08, 0x10,0x10,0x08, 0x0e,0x10,0x08, 0x0c,0x10,0x08, 0x0a,0x10,0x08,
600 0x08,0x10,0x08, 0x08,0x10,0x0a, 0x08,0x10,0x0c, 0x08,0x10,0x0e, 0x08,0x10,0x10, 0x08,0x0e,0x10, 0x08,0x0c,0x10, 0x08,0x0a,0x10,
601 0x0b,0x0b,0x10, 0x0c,0x0b,0x10, 0x0d,0x0b,0x10, 0x0f,0x0b,0x10, 0x10,0x0b,0x10, 0x10,0x0b,0x0f, 0x10,0x0b,0x0d, 0x10,0x0b,0x0c,
602 0x10,0x0b,0x0b, 0x10,0x0c,0x0b, 0x10,0x0d,0x0b, 0x10,0x0f,0x0b, 0x10,0x10,0x0b, 0x0f,0x10,0x0b, 0x0d,0x10,0x0b, 0x0c,0x10,0x0b,
603 0x0b,0x10,0x0b, 0x0b,0x10,0x0c, 0x0b,0x10,0x0d, 0x0b,0x10,0x0f, 0x0b,0x10,0x10, 0x0b,0x0f,0x10, 0x0b,0x0d,0x10, 0x0b,0x0c,0x10,
604 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00, 0x00,0x00,0x00
607 static Bit8u static_functionality[0x10]=
609 /* 0 */ 0xff, // All modes supported #1
610 /* 1 */ 0xe0, // All modes supported #2
611 /* 2 */ 0x0f, // All modes supported #3
612 /* 3 */ 0x00, 0x00, 0x00, 0x00, // reserved
613 /* 7 */ 0x07, // 200, 350, 400 scan lines
614 /* 8 */ 0x02, // mamimum number of visible charsets in text mode
615 /* 9 */ 0x08, // total number of charset blocks in text mode
616 /* a */ 0xe7, // Change to add new functions
617 /* b */ 0x0c, // Change to add new functions
618 /* c */ 0x00, // reserved
619 /* d */ 0x00, // reserved
620 /* e */ 0x00, // Change to add new functions
621 /* f */ 0x00 // reserved