Commit 68d5736aeeda5ced448737a071b0b4c890341be7
1 parent
e872aa81
Remove obsolete VGABIOS patch.
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com> git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@6116 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
1 changed file
with
0 additions
and
896 deletions
pc-bios/vgabios.diff deleted
100644 → 0
| 1 | -Index: Makefile | |
| 2 | -=================================================================== | |
| 3 | -RCS file: /sources/vgabios/vgabios/Makefile,v | |
| 4 | -retrieving revision 1.17 | |
| 5 | -diff -u -w -r1.17 Makefile | |
| 6 | ---- Makefile 6 Mar 2005 13:06:47 -0000 1.17 | |
| 7 | -+++ Makefile 14 Jun 2006 00:51:06 -0000 | |
| 8 | -@@ -22,7 +22,7 @@ | |
| 9 | - cirrus-bios: vgabios-cirrus.bin vgabios-cirrus.debug.bin | |
| 10 | - | |
| 11 | - clean: | |
| 12 | -- /bin/rm -f biossums *.o *.s *.ld86 \ | |
| 13 | -+ /bin/rm -f biossums vbetables-gen vbetables.h *.o *.s *.ld86 \ | |
| 14 | - temp.awk.* vgabios*.orig _vgabios_* _vgabios-debug_* core vgabios*.bin vgabios*.txt $(RELEASE).bin *.bak | |
| 15 | - | |
| 16 | - dist-clean: clean | |
| 17 | -@@ -79,3 +79,9 @@ | |
| 18 | - | |
| 19 | - biossums: biossums.c | |
| 20 | - $(CC) -o biossums biossums.c | |
| 21 | -+ | |
| 22 | -+vbetables-gen: vbetables-gen.c | |
| 23 | -+ $(CC) -o vbetables-gen vbetables-gen.c | |
| 24 | -+ | |
| 25 | -+vbetables.h: vbetables-gen | |
| 26 | -+ ./vbetables-gen > $@ | |
| 27 | -Index: clext.c | |
| 28 | -=================================================================== | |
| 29 | -RCS file: /sources/vgabios/vgabios/clext.c,v | |
| 30 | -retrieving revision 1.10 | |
| 31 | -diff -u -w -r1.10 clext.c | |
| 32 | ---- clext.c 25 Mar 2006 10:19:15 -0000 1.10 | |
| 33 | -+++ clext.c 14 Jun 2006 00:51:06 -0000 | |
| 34 | -@@ -544,6 +544,13 @@ | |
| 35 | - cirrus_set_video_mode_extended: | |
| 36 | - call cirrus_switch_mode | |
| 37 | - pop ax ;; mode | |
| 38 | -+ test al, #0x80 | |
| 39 | -+ jnz cirrus_set_video_mode_extended_1 | |
| 40 | -+ push ax | |
| 41 | -+ mov ax, #0xffff ; set to 0xff to keep win 2K happy | |
| 42 | -+ call cirrus_clear_vram | |
| 43 | -+ pop ax | |
| 44 | -+cirrus_set_video_mode_extended_1: | |
| 45 | - and al, #0x7f | |
| 46 | - | |
| 47 | - push ds | |
| 48 | -@@ -1011,6 +1018,13 @@ | |
| 49 | - jnz cirrus_vesa_02h_3 | |
| 50 | - call cirrus_enable_16k_granularity | |
| 51 | - cirrus_vesa_02h_3: | |
| 52 | -+ test bx, #0x8000 ;; no clear | |
| 53 | -+ jnz cirrus_vesa_02h_4 | |
| 54 | -+ push ax | |
| 55 | -+ xor ax,ax | |
| 56 | -+ call cirrus_clear_vram | |
| 57 | -+ pop ax | |
| 58 | -+cirrus_vesa_02h_4: | |
| 59 | - pop ax | |
| 60 | - push ds | |
| 61 | - #ifdef CIRRUS_VESA3_PMINFO | |
| 62 | -@@ -1479,6 +1493,38 @@ | |
| 63 | - pop bx | |
| 64 | - ret | |
| 65 | - | |
| 66 | -+cirrus_clear_vram: | |
| 67 | -+ pusha | |
| 68 | -+ push es | |
| 69 | -+ mov si, ax | |
| 70 | -+ | |
| 71 | -+ call cirrus_enable_16k_granularity | |
| 72 | -+ call cirrus_extbios_85h | |
| 73 | -+ shl al, #2 | |
| 74 | -+ mov bl, al | |
| 75 | -+ xor ah,ah | |
| 76 | -+cirrus_clear_vram_1: | |
| 77 | -+ mov al, #0x09 | |
| 78 | -+ mov dx, #0x3ce | |
| 79 | -+ out dx, ax | |
| 80 | -+ push ax | |
| 81 | -+ mov cx, #0xa000 | |
| 82 | -+ mov es, cx | |
| 83 | -+ xor di, di | |
| 84 | -+ mov ax, si | |
| 85 | -+ mov cx, #8192 | |
| 86 | -+ cld | |
| 87 | -+ rep | |
| 88 | -+ stosw | |
| 89 | -+ pop ax | |
| 90 | -+ inc ah | |
| 91 | -+ cmp ah, bl | |
| 92 | -+ jne cirrus_clear_vram_1 | |
| 93 | -+ | |
| 94 | -+ pop es | |
| 95 | -+ popa | |
| 96 | -+ ret | |
| 97 | -+ | |
| 98 | - cirrus_extbios_handlers: | |
| 99 | - ;; 80h | |
| 100 | - dw cirrus_extbios_80h | |
| 101 | -Index: vbe.c | |
| 102 | -=================================================================== | |
| 103 | -RCS file: /sources/vgabios/vgabios/vbe.c,v | |
| 104 | -retrieving revision 1.48 | |
| 105 | -diff -u -w -r1.48 vbe.c | |
| 106 | ---- vbe.c 26 Dec 2005 19:50:26 -0000 1.48 | |
| 107 | -+++ vbe.c 14 Jun 2006 00:51:07 -0000 | |
| 108 | -@@ -118,21 +118,114 @@ | |
| 109 | - .word VBE_VESA_MODE_END_OF_LIST | |
| 110 | - #endif | |
| 111 | - | |
| 112 | -+ .align 2 | |
| 113 | - vesa_pm_start: | |
| 114 | - dw vesa_pm_set_window - vesa_pm_start | |
| 115 | -- dw vesa_pm_set_display_strt - vesa_pm_start | |
| 116 | -+ dw vesa_pm_set_display_start - vesa_pm_start | |
| 117 | - dw vesa_pm_unimplemented - vesa_pm_start | |
| 118 | -- dw 0 | |
| 119 | -+ dw vesa_pm_io_ports_table - vesa_pm_start | |
| 120 | -+vesa_pm_io_ports_table: | |
| 121 | -+ dw VBE_DISPI_IOPORT_INDEX | |
| 122 | -+ dw VBE_DISPI_IOPORT_INDEX + 1 | |
| 123 | -+ dw VBE_DISPI_IOPORT_DATA | |
| 124 | -+ dw VBE_DISPI_IOPORT_DATA + 1 | |
| 125 | -+ dw 0xffff | |
| 126 | -+ dw 0xffff | |
| 127 | - | |
| 128 | - USE32 | |
| 129 | - vesa_pm_set_window: | |
| 130 | -- mov ax, #0x4f05 | |
| 131 | -- int #0x10 | |
| 132 | -+ cmp bx, #0x00 | |
| 133 | -+ je vesa_pm_set_display_window1 | |
| 134 | -+ mov ax, #0x0100 | |
| 135 | -+ ret | |
| 136 | -+vesa_pm_set_display_window1: | |
| 137 | -+ mov ax, dx | |
| 138 | -+ push dx | |
| 139 | -+ push ax | |
| 140 | -+ mov dx, # VBE_DISPI_IOPORT_INDEX | |
| 141 | -+ mov ax, # VBE_DISPI_INDEX_BANK | |
| 142 | -+ out dx, ax | |
| 143 | -+ pop ax | |
| 144 | -+ mov dx, # VBE_DISPI_IOPORT_DATA | |
| 145 | -+ out dx, ax | |
| 146 | -+ pop dx | |
| 147 | -+ mov ax, #0x004f | |
| 148 | - ret | |
| 149 | - | |
| 150 | - vesa_pm_set_display_start: | |
| 151 | -- mov ax, #0x4f07 | |
| 152 | -- int #0x10 | |
| 153 | -+ cmp bl, #0x80 | |
| 154 | -+ je vesa_pm_set_display_start1 | |
| 155 | -+ cmp bl, #0x00 | |
| 156 | -+ je vesa_pm_set_display_start1 | |
| 157 | -+ mov ax, #0x0100 | |
| 158 | -+ ret | |
| 159 | -+vesa_pm_set_display_start1: | |
| 160 | -+; convert offset to (X, Y) coordinate | |
| 161 | -+; (would be simpler to change Bochs VBE API...) | |
| 162 | -+ push eax | |
| 163 | -+ push ecx | |
| 164 | -+ push edx | |
| 165 | -+ push esi | |
| 166 | -+ push edi | |
| 167 | -+ shl edx, #16 | |
| 168 | -+ and ecx, #0xffff | |
| 169 | -+ or ecx, edx | |
| 170 | -+ shl ecx, #2 | |
| 171 | -+ mov eax, ecx | |
| 172 | -+ | |
| 173 | -+ push eax | |
| 174 | -+ mov dx, # VBE_DISPI_IOPORT_INDEX | |
| 175 | -+ mov ax, # VBE_DISPI_INDEX_VIRT_WIDTH | |
| 176 | -+ out dx, ax | |
| 177 | -+ mov dx, # VBE_DISPI_IOPORT_DATA | |
| 178 | -+ in ax, dx | |
| 179 | -+ movzx ecx, ax | |
| 180 | -+ | |
| 181 | -+ mov dx, # VBE_DISPI_IOPORT_INDEX | |
| 182 | -+ mov ax, # VBE_DISPI_INDEX_BPP | |
| 183 | -+ out dx, ax | |
| 184 | -+ mov dx, # VBE_DISPI_IOPORT_DATA | |
| 185 | -+ in ax, dx | |
| 186 | -+ movzx esi, ax | |
| 187 | -+ pop eax | |
| 188 | -+ | |
| 189 | -+ add esi, #7 | |
| 190 | -+ shr esi, #3 | |
| 191 | -+ imul ecx, esi | |
| 192 | -+ xor edx, edx | |
| 193 | -+ div ecx | |
| 194 | -+ mov edi, eax | |
| 195 | -+ mov eax, edx | |
| 196 | -+ xor edx, edx | |
| 197 | -+ div esi | |
| 198 | -+ | |
| 199 | -+ push dx | |
| 200 | -+ push ax | |
| 201 | -+ mov dx, # VBE_DISPI_IOPORT_INDEX | |
| 202 | -+ mov ax, # VBE_DISPI_INDEX_X_OFFSET | |
| 203 | -+ out dx, ax | |
| 204 | -+ pop ax | |
| 205 | -+ mov dx, # VBE_DISPI_IOPORT_DATA | |
| 206 | -+ out dx, ax | |
| 207 | -+ pop dx | |
| 208 | -+ | |
| 209 | -+ mov ax, di | |
| 210 | -+ push dx | |
| 211 | -+ push ax | |
| 212 | -+ mov dx, # VBE_DISPI_IOPORT_INDEX | |
| 213 | -+ mov ax, # VBE_DISPI_INDEX_Y_OFFSET | |
| 214 | -+ out dx, ax | |
| 215 | -+ pop ax | |
| 216 | -+ mov dx, # VBE_DISPI_IOPORT_DATA | |
| 217 | -+ out dx, ax | |
| 218 | -+ pop dx | |
| 219 | -+ | |
| 220 | -+ pop edi | |
| 221 | -+ pop esi | |
| 222 | -+ pop edx | |
| 223 | -+ pop ecx | |
| 224 | -+ pop eax | |
| 225 | -+ mov ax, #0x004f | |
| 226 | - ret | |
| 227 | - | |
| 228 | - vesa_pm_unimplemented: | |
| 229 | -@@ -835,6 +928,64 @@ | |
| 230 | - ASM_END | |
| 231 | - | |
| 232 | - | |
| 233 | -+Bit16u vbe_biosfn_read_video_state_size() | |
| 234 | -+{ | |
| 235 | -+ return 9 * 2; | |
| 236 | -+} | |
| 237 | -+ | |
| 238 | -+void vbe_biosfn_save_video_state(ES, BX) | |
| 239 | -+ Bit16u ES; Bit16u BX; | |
| 240 | -+{ | |
| 241 | -+ Bit16u enable, i; | |
| 242 | -+ | |
| 243 | -+ outw(VBE_DISPI_IOPORT_INDEX,VBE_DISPI_INDEX_ENABLE); | |
| 244 | -+ enable = inw(VBE_DISPI_IOPORT_DATA); | |
| 245 | -+ write_word(ES, BX, enable); | |
| 246 | -+ BX += 2; | |
| 247 | -+ if (!(enable & VBE_DISPI_ENABLED)) | |
| 248 | -+ return; | |
| 249 | -+ for(i = VBE_DISPI_INDEX_XRES; i <= VBE_DISPI_INDEX_Y_OFFSET; i++) { | |
| 250 | -+ if (i != VBE_DISPI_INDEX_ENABLE) { | |
| 251 | -+ outw(VBE_DISPI_IOPORT_INDEX, i); | |
| 252 | -+ write_word(ES, BX, inw(VBE_DISPI_IOPORT_DATA)); | |
| 253 | -+ BX += 2; | |
| 254 | -+ } | |
| 255 | -+ } | |
| 256 | -+} | |
| 257 | -+ | |
| 258 | -+ | |
| 259 | -+void vbe_biosfn_restore_video_state(ES, BX) | |
| 260 | -+ Bit16u ES; Bit16u BX; | |
| 261 | -+{ | |
| 262 | -+ Bit16u enable, i; | |
| 263 | -+ | |
| 264 | -+ enable = read_word(ES, BX); | |
| 265 | -+ BX += 2; | |
| 266 | -+ | |
| 267 | -+ if (!(enable & VBE_DISPI_ENABLED)) { | |
| 268 | -+ outw(VBE_DISPI_IOPORT_INDEX,VBE_DISPI_INDEX_ENABLE); | |
| 269 | -+ outw(VBE_DISPI_IOPORT_DATA, enable); | |
| 270 | -+ } else { | |
| 271 | -+ outw(VBE_DISPI_IOPORT_INDEX, VBE_DISPI_INDEX_XRES); | |
| 272 | -+ outw(VBE_DISPI_IOPORT_DATA, read_word(ES, BX)); | |
| 273 | -+ BX += 2; | |
| 274 | -+ outw(VBE_DISPI_IOPORT_INDEX, VBE_DISPI_INDEX_YRES); | |
| 275 | -+ outw(VBE_DISPI_IOPORT_DATA, read_word(ES, BX)); | |
| 276 | -+ BX += 2; | |
| 277 | -+ outw(VBE_DISPI_IOPORT_INDEX, VBE_DISPI_INDEX_BPP); | |
| 278 | -+ outw(VBE_DISPI_IOPORT_DATA, read_word(ES, BX)); | |
| 279 | -+ BX += 2; | |
| 280 | -+ outw(VBE_DISPI_IOPORT_INDEX,VBE_DISPI_INDEX_ENABLE); | |
| 281 | -+ outw(VBE_DISPI_IOPORT_DATA, enable); | |
| 282 | -+ | |
| 283 | -+ for(i = VBE_DISPI_INDEX_BANK; i <= VBE_DISPI_INDEX_Y_OFFSET; i++) { | |
| 284 | -+ outw(VBE_DISPI_IOPORT_INDEX, i); | |
| 285 | -+ outw(VBE_DISPI_IOPORT_DATA, read_word(ES, BX)); | |
| 286 | -+ BX += 2; | |
| 287 | -+ } | |
| 288 | -+ } | |
| 289 | -+} | |
| 290 | -+ | |
| 291 | - /** Function 04h - Save/Restore State | |
| 292 | - * | |
| 293 | - * Input: | |
| 294 | -@@ -849,10 +1000,48 @@ | |
| 295 | - * BX = Number of 64-byte blocks to hold the state buffer (if DL=00h) | |
| 296 | - * | |
| 297 | - */ | |
| 298 | --void vbe_biosfn_save_restore_state(AX, DL, CX, ES, BX) | |
| 299 | -+void vbe_biosfn_save_restore_state(AX, CX, DX, ES, BX) | |
| 300 | -+Bit16u *AX; Bit16u CX; Bit16u DX; Bit16u ES; Bit16u *BX; | |
| 301 | - { | |
| 302 | --} | |
| 303 | -+ Bit16u ss=get_SS(); | |
| 304 | -+ Bit16u result, val; | |
| 305 | - | |
| 306 | -+ result = 0x4f; | |
| 307 | -+ switch(GET_DL()) { | |
| 308 | -+ case 0x00: | |
| 309 | -+ val = biosfn_read_video_state_size2(CX); | |
| 310 | -+#ifdef DEBUG | |
| 311 | -+ printf("VGA state size=%x\n", val); | |
| 312 | -+#endif | |
| 313 | -+ if (CX & 8) | |
| 314 | -+ val += vbe_biosfn_read_video_state_size(); | |
| 315 | -+ write_word(ss, BX, val); | |
| 316 | -+ break; | |
| 317 | -+ case 0x01: | |
| 318 | -+ val = read_word(ss, BX); | |
| 319 | -+ val = biosfn_save_video_state(CX, ES, val); | |
| 320 | -+#ifdef DEBUG | |
| 321 | -+ printf("VGA save_state offset=%x\n", val); | |
| 322 | -+#endif | |
| 323 | -+ if (CX & 8) | |
| 324 | -+ vbe_biosfn_save_video_state(ES, val); | |
| 325 | -+ break; | |
| 326 | -+ case 0x02: | |
| 327 | -+ val = read_word(ss, BX); | |
| 328 | -+ val = biosfn_restore_video_state(CX, ES, val); | |
| 329 | -+#ifdef DEBUG | |
| 330 | -+ printf("VGA restore_state offset=%x\n", val); | |
| 331 | -+#endif | |
| 332 | -+ if (CX & 8) | |
| 333 | -+ vbe_biosfn_restore_video_state(ES, val); | |
| 334 | -+ break; | |
| 335 | -+ default: | |
| 336 | -+ // function failed | |
| 337 | -+ result = 0x100; | |
| 338 | -+ break; | |
| 339 | -+ } | |
| 340 | -+ write_word(ss, AX, result); | |
| 341 | -+} | |
| 342 | - | |
| 343 | - /** Function 05h - Display Window Control | |
| 344 | - * | |
| 345 | -@@ -1090,7 +1279,7 @@ | |
| 346 | - */ | |
| 347 | - ASM_START | |
| 348 | - vbe_biosfn_return_protected_mode_interface: | |
| 349 | -- test bx, bx | |
| 350 | -+ test bl, bl | |
| 351 | - jnz _fail | |
| 352 | - mov di, #0xc000 | |
| 353 | - mov es, di | |
| 354 | -Index: vbe.h | |
| 355 | -=================================================================== | |
| 356 | -RCS file: /sources/vgabios/vgabios/vbe.h,v | |
| 357 | -retrieving revision 1.24 | |
| 358 | -diff -u -w -r1.24 vbe.h | |
| 359 | ---- vbe.h 9 May 2004 20:31:31 -0000 1.24 | |
| 360 | -+++ vbe.h 14 Jun 2006 00:51:07 -0000 | |
| 361 | -@@ -14,7 +14,7 @@ | |
| 362 | - void vbe_biosfn_return_controller_information(AX, ES, DI); | |
| 363 | - void vbe_biosfn_return_mode_information(AX, CX, ES, DI); | |
| 364 | - void vbe_biosfn_set_mode(AX, BX, ES, DI); | |
| 365 | --void vbe_biosfn_save_restore_state(AX, DL, CX, ES, BX); | |
| 366 | -+void vbe_biosfn_save_restore_state(AX, CX, DX, ES, BX); | |
| 367 | - void vbe_biosfn_set_get_palette_data(AX); | |
| 368 | - void vbe_biosfn_return_protected_mode_interface(AX); | |
| 369 | - | |
| 370 | -@@ -151,6 +151,12 @@ | |
| 371 | - Bit8u Reserved[189]; | |
| 372 | - } ModeInfoBlock; | |
| 373 | - | |
| 374 | -+typedef struct ModeInfoListItem | |
| 375 | -+{ | |
| 376 | -+ Bit16u mode; | |
| 377 | -+ ModeInfoBlockCompact info; | |
| 378 | -+} ModeInfoListItem; | |
| 379 | -+ | |
| 380 | - // VBE Return Status Info | |
| 381 | - // AL | |
| 382 | - #define VBE_RETURN_STATUS_SUPPORTED 0x4F | |
| 383 | -@@ -193,6 +199,10 @@ | |
| 384 | - #define VBE_VESA_MODE_1280X1024X1555 0x119 | |
| 385 | - #define VBE_VESA_MODE_1280X1024X565 0x11A | |
| 386 | - #define VBE_VESA_MODE_1280X1024X888 0x11B | |
| 387 | -+#define VBE_VESA_MODE_1600X1200X8 0x11C | |
| 388 | -+#define VBE_VESA_MODE_1600X1200X1555 0x11D | |
| 389 | -+#define VBE_VESA_MODE_1600X1200X565 0x11E | |
| 390 | -+#define VBE_VESA_MODE_1600X1200X888 0x11F | |
| 391 | - | |
| 392 | - // BOCHS/PLEX86 'own' mode numbers | |
| 393 | - #define VBE_OWN_MODE_320X200X8888 0x140 | |
| 394 | -@@ -202,6 +212,12 @@ | |
| 395 | - #define VBE_OWN_MODE_1024X768X8888 0x144 | |
| 396 | - #define VBE_OWN_MODE_1280X1024X8888 0x145 | |
| 397 | - #define VBE_OWN_MODE_320X200X8 0x146 | |
| 398 | -+#define VBE_OWN_MODE_1600X1200X8888 0x147 | |
| 399 | -+#define VBE_OWN_MODE_1152X864X8 0x148 | |
| 400 | -+#define VBE_OWN_MODE_1152X864X1555 0x149 | |
| 401 | -+#define VBE_OWN_MODE_1152X864X565 0x14a | |
| 402 | -+#define VBE_OWN_MODE_1152X864X888 0x14b | |
| 403 | -+#define VBE_OWN_MODE_1152X864X8888 0x14c | |
| 404 | - | |
| 405 | - #define VBE_VESA_MODE_END_OF_LIST 0xFFFF | |
| 406 | - | |
| 407 | -@@ -259,7 +275,7 @@ | |
| 408 | - // like 0xE0000000 | |
| 409 | - | |
| 410 | - | |
| 411 | -- #define VBE_DISPI_TOTAL_VIDEO_MEMORY_MB 4 | |
| 412 | -+ #define VBE_DISPI_TOTAL_VIDEO_MEMORY_MB 8 | |
| 413 | - | |
| 414 | - #define VBE_DISPI_BANK_ADDRESS 0xA0000 | |
| 415 | - #define VBE_DISPI_BANK_SIZE_KB 64 | |
| 416 | -Index: vgabios.c | |
| 417 | -=================================================================== | |
| 418 | -RCS file: /sources/vgabios/vgabios/vgabios.c,v | |
| 419 | -retrieving revision 1.64 | |
| 420 | -diff -u -w -r1.64 vgabios.c | |
| 421 | ---- vgabios.c 25 Mar 2006 10:19:16 -0000 1.64 | |
| 422 | -+++ vgabios.c 14 Jun 2006 00:51:07 -0000 | |
| 423 | -@@ -109,8 +109,8 @@ | |
| 424 | - static void biosfn_write_string(); | |
| 425 | - static void biosfn_read_state_info(); | |
| 426 | - static void biosfn_read_video_state_size(); | |
| 427 | --static void biosfn_save_video_state(); | |
| 428 | --static void biosfn_restore_video_state(); | |
| 429 | -+static Bit16u biosfn_save_video_state(); | |
| 430 | -+static Bit16u biosfn_restore_video_state(); | |
| 431 | - extern Bit8u video_save_pointer_table[]; | |
| 432 | - | |
| 433 | - // This is for compiling with gcc2 and gcc3 | |
| 434 | -@@ -748,12 +748,7 @@ | |
| 435 | - vbe_biosfn_set_mode(&AX,BX,ES,DI); | |
| 436 | - break; | |
| 437 | - case 0x04: | |
| 438 | -- //FIXME | |
| 439 | --#ifdef DEBUG | |
| 440 | -- unimplemented(); | |
| 441 | --#endif | |
| 442 | -- // function failed | |
| 443 | -- AX=0x100; | |
| 444 | -+ vbe_biosfn_save_restore_state(&AX, CX, DX, ES, &BX); | |
| 445 | - break; | |
| 446 | - case 0x09: | |
| 447 | - //FIXME | |
| 448 | -@@ -3138,23 +3133,215 @@ | |
| 449 | - } | |
| 450 | - | |
| 451 | - // -------------------------------------------------------------------------------------------- | |
| 452 | --static void biosfn_read_video_state_size (CX,ES,BX) Bit16u CX;Bit16u ES;Bit16u BX; | |
| 453 | -+// -------------------------------------------------------------------------------------------- | |
| 454 | -+static Bit16u biosfn_read_video_state_size2 (CX) | |
| 455 | -+ Bit16u CX; | |
| 456 | - { | |
| 457 | --#ifdef DEBUG | |
| 458 | -- unimplemented(); | |
| 459 | --#endif | |
| 460 | -+ Bit16u size; | |
| 461 | -+ size = 0; | |
| 462 | -+ if (CX & 1) { | |
| 463 | -+ size += 0x46; | |
| 464 | -+ } | |
| 465 | -+ if (CX & 2) { | |
| 466 | -+ size += (5 + 8 + 5) * 2 + 6; | |
| 467 | -+ } | |
| 468 | -+ if (CX & 4) { | |
| 469 | -+ size += 3 + 256 * 3 + 1; | |
| 470 | - } | |
| 471 | --static void biosfn_save_video_state (CX,ES,BX) Bit16u CX;Bit16u ES;Bit16u BX; | |
| 472 | -+ return size; | |
| 473 | -+} | |
| 474 | -+ | |
| 475 | -+static void biosfn_read_video_state_size (CX, BX) | |
| 476 | -+ Bit16u CX; Bit16u *BX; | |
| 477 | - { | |
| 478 | --#ifdef DEBUG | |
| 479 | -- unimplemented(); | |
| 480 | --#endif | |
| 481 | -+ Bit16u ss=get_SS(); | |
| 482 | -+ write_word(ss, BX, biosfn_read_video_state_size2(CX)); | |
| 483 | - } | |
| 484 | --static void biosfn_restore_video_state (CX,ES,BX) Bit16u CX;Bit16u ES;Bit16u BX; | |
| 485 | -+ | |
| 486 | -+static Bit16u biosfn_save_video_state (CX,ES,BX) | |
| 487 | -+ Bit16u CX;Bit16u ES;Bit16u BX; | |
| 488 | - { | |
| 489 | --#ifdef DEBUG | |
| 490 | -- unimplemented(); | |
| 491 | --#endif | |
| 492 | -+ Bit16u i, v, crtc_addr, ar_index; | |
| 493 | -+ | |
| 494 | -+ crtc_addr = read_word(BIOSMEM_SEG, BIOSMEM_CRTC_ADDRESS); | |
| 495 | -+ if (CX & 1) { | |
| 496 | -+ write_byte(ES, BX, inb(VGAREG_SEQU_ADDRESS)); BX++; | |
| 497 | -+ write_byte(ES, BX, inb(crtc_addr)); BX++; | |
| 498 | -+ write_byte(ES, BX, inb(VGAREG_GRDC_ADDRESS)); BX++; | |
| 499 | -+ inb(VGAREG_ACTL_RESET); | |
| 500 | -+ ar_index = inb(VGAREG_ACTL_ADDRESS); | |
| 501 | -+ write_byte(ES, BX, ar_index); BX++; | |
| 502 | -+ write_byte(ES, BX, inb(VGAREG_READ_FEATURE_CTL)); BX++; | |
| 503 | -+ | |
| 504 | -+ for(i=1;i<=4;i++){ | |
| 505 | -+ outb(VGAREG_SEQU_ADDRESS, i); | |
| 506 | -+ write_byte(ES, BX, inb(VGAREG_SEQU_DATA)); BX++; | |
| 507 | -+ } | |
| 508 | -+ outb(VGAREG_SEQU_ADDRESS, 0); | |
| 509 | -+ write_byte(ES, BX, inb(VGAREG_SEQU_DATA)); BX++; | |
| 510 | -+ | |
| 511 | -+ for(i=0;i<=0x18;i++) { | |
| 512 | -+ outb(crtc_addr,i); | |
| 513 | -+ write_byte(ES, BX, inb(crtc_addr+1)); BX++; | |
| 514 | -+ } | |
| 515 | -+ | |
| 516 | -+ for(i=0;i<=0x13;i++) { | |
| 517 | -+ inb(VGAREG_ACTL_RESET); | |
| 518 | -+ outb(VGAREG_ACTL_ADDRESS, i | (ar_index & 0x20)); | |
| 519 | -+ write_byte(ES, BX, inb(VGAREG_ACTL_READ_DATA)); BX++; | |
| 520 | -+ } | |
| 521 | -+ inb(VGAREG_ACTL_RESET); | |
| 522 | -+ | |
| 523 | -+ for(i=0;i<=8;i++) { | |
| 524 | -+ outb(VGAREG_GRDC_ADDRESS,i); | |
| 525 | -+ write_byte(ES, BX, inb(VGAREG_GRDC_DATA)); BX++; | |
| 526 | -+ } | |
| 527 | -+ | |
| 528 | -+ write_word(ES, BX, crtc_addr); BX+= 2; | |
| 529 | -+ | |
| 530 | -+ /* XXX: read plane latches */ | |
| 531 | -+ write_byte(ES, BX, 0); BX++; | |
| 532 | -+ write_byte(ES, BX, 0); BX++; | |
| 533 | -+ write_byte(ES, BX, 0); BX++; | |
| 534 | -+ write_byte(ES, BX, 0); BX++; | |
| 535 | -+ } | |
| 536 | -+ if (CX & 2) { | |
| 537 | -+ write_byte(ES, BX, read_byte(BIOSMEM_SEG,BIOSMEM_CURRENT_MODE)); BX++; | |
| 538 | -+ write_word(ES, BX, read_word(BIOSMEM_SEG,BIOSMEM_NB_COLS)); BX += 2; | |
| 539 | -+ write_word(ES, BX, read_word(BIOSMEM_SEG,BIOSMEM_PAGE_SIZE)); BX += 2; | |
| 540 | -+ write_word(ES, BX, read_word(BIOSMEM_SEG,BIOSMEM_CRTC_ADDRESS)); BX += 2; | |
| 541 | -+ write_byte(ES, BX, read_byte(BIOSMEM_SEG,BIOSMEM_NB_ROWS)); BX++; | |
| 542 | -+ write_word(ES, BX, read_word(BIOSMEM_SEG,BIOSMEM_CHAR_HEIGHT)); BX += 2; | |
| 543 | -+ write_byte(ES, BX, read_byte(BIOSMEM_SEG,BIOSMEM_VIDEO_CTL)); BX++; | |
| 544 | -+ write_byte(ES, BX, read_byte(BIOSMEM_SEG,BIOSMEM_SWITCHES)); BX++; | |
| 545 | -+ write_byte(ES, BX, read_byte(BIOSMEM_SEG,BIOSMEM_MODESET_CTL)); BX++; | |
| 546 | -+ write_word(ES, BX, read_word(BIOSMEM_SEG,BIOSMEM_CURSOR_TYPE)); BX += 2; | |
| 547 | -+ for(i=0;i<8;i++) { | |
| 548 | -+ write_word(ES, BX, read_word(BIOSMEM_SEG, BIOSMEM_CURSOR_POS+2*i)); | |
| 549 | -+ BX += 2; | |
| 550 | -+ } | |
| 551 | -+ write_word(ES, BX, read_word(BIOSMEM_SEG,BIOSMEM_CURRENT_START)); BX += 2; | |
| 552 | -+ write_byte(ES, BX, read_byte(BIOSMEM_SEG,BIOSMEM_CURRENT_PAGE)); BX++; | |
| 553 | -+ /* current font */ | |
| 554 | -+ write_word(ES, BX, read_word(0, 0x1f * 4)); BX += 2; | |
| 555 | -+ write_word(ES, BX, read_word(0, 0x1f * 4 + 2)); BX += 2; | |
| 556 | -+ write_word(ES, BX, read_word(0, 0x43 * 4)); BX += 2; | |
| 557 | -+ write_word(ES, BX, read_word(0, 0x43 * 4 + 2)); BX += 2; | |
| 558 | -+ } | |
| 559 | -+ if (CX & 4) { | |
| 560 | -+ /* XXX: check this */ | |
| 561 | -+ write_byte(ES, BX, inb(VGAREG_DAC_STATE)); BX++; /* read/write mode dac */ | |
| 562 | -+ write_byte(ES, BX, inb(VGAREG_DAC_WRITE_ADDRESS)); BX++; /* pix address */ | |
| 563 | -+ write_byte(ES, BX, inb(VGAREG_PEL_MASK)); BX++; | |
| 564 | -+ // Set the whole dac always, from 0 | |
| 565 | -+ outb(VGAREG_DAC_WRITE_ADDRESS,0x00); | |
| 566 | -+ for(i=0;i<256*3;i++) { | |
| 567 | -+ write_byte(ES, BX, inb(VGAREG_DAC_DATA)); BX++; | |
| 568 | -+ } | |
| 569 | -+ write_byte(ES, BX, 0); BX++; /* color select register */ | |
| 570 | -+ } | |
| 571 | -+ return BX; | |
| 572 | -+} | |
| 573 | -+ | |
| 574 | -+static Bit16u biosfn_restore_video_state (CX,ES,BX) | |
| 575 | -+ Bit16u CX;Bit16u ES;Bit16u BX; | |
| 576 | -+{ | |
| 577 | -+ Bit16u i, crtc_addr, v, addr1, ar_index; | |
| 578 | -+ | |
| 579 | -+ if (CX & 1) { | |
| 580 | -+ // Reset Attribute Ctl flip-flop | |
| 581 | -+ inb(VGAREG_ACTL_RESET); | |
| 582 | -+ | |
| 583 | -+ crtc_addr = read_word(ES, BX + 0x40); | |
| 584 | -+ addr1 = BX; | |
| 585 | -+ BX += 5; | |
| 586 | -+ | |
| 587 | -+ for(i=1;i<=4;i++){ | |
| 588 | -+ outb(VGAREG_SEQU_ADDRESS, i); | |
| 589 | -+ outb(VGAREG_SEQU_DATA, read_byte(ES, BX)); BX++; | |
| 590 | -+ } | |
| 591 | -+ outb(VGAREG_SEQU_ADDRESS, 0); | |
| 592 | -+ outb(VGAREG_SEQU_DATA, read_byte(ES, BX)); BX++; | |
| 593 | -+ | |
| 594 | -+ // Disable CRTC write protection | |
| 595 | -+ outw(crtc_addr,0x0011); | |
| 596 | -+ // Set CRTC regs | |
| 597 | -+ for(i=0;i<=0x18;i++) { | |
| 598 | -+ if (i != 0x11) { | |
| 599 | -+ outb(crtc_addr,i); | |
| 600 | -+ outb(crtc_addr+1, read_byte(ES, BX)); | |
| 601 | -+ } | |
| 602 | -+ BX++; | |
| 603 | -+ } | |
| 604 | -+ // select crtc base address | |
| 605 | -+ v = inb(VGAREG_READ_MISC_OUTPUT) & ~0x01; | |
| 606 | -+ if (crtc_addr = 0x3d4) | |
| 607 | -+ v |= 0x01; | |
| 608 | -+ outb(VGAREG_WRITE_MISC_OUTPUT, v); | |
| 609 | -+ | |
| 610 | -+ // enable write protection if needed | |
| 611 | -+ outb(crtc_addr, 0x11); | |
| 612 | -+ outb(crtc_addr+1, read_byte(ES, BX - 0x18 + 0x11)); | |
| 613 | -+ | |
| 614 | -+ // Set Attribute Ctl | |
| 615 | -+ ar_index = read_byte(ES, addr1 + 0x03); | |
| 616 | -+ inb(VGAREG_ACTL_RESET); | |
| 617 | -+ for(i=0;i<=0x13;i++) { | |
| 618 | -+ outb(VGAREG_ACTL_ADDRESS, i | (ar_index & 0x20)); | |
| 619 | -+ outb(VGAREG_ACTL_WRITE_DATA, read_byte(ES, BX)); BX++; | |
| 620 | -+ } | |
| 621 | -+ outb(VGAREG_ACTL_ADDRESS, ar_index); | |
| 622 | -+ inb(VGAREG_ACTL_RESET); | |
| 623 | -+ | |
| 624 | -+ for(i=0;i<=8;i++) { | |
| 625 | -+ outb(VGAREG_GRDC_ADDRESS,i); | |
| 626 | -+ outb(VGAREG_GRDC_DATA, read_byte(ES, BX)); BX++; | |
| 627 | -+ } | |
| 628 | -+ BX += 2; /* crtc_addr */ | |
| 629 | -+ BX += 4; /* plane latches */ | |
| 630 | -+ | |
| 631 | -+ outb(VGAREG_SEQU_ADDRESS, read_byte(ES, addr1)); addr1++; | |
| 632 | -+ outb(crtc_addr, read_byte(ES, addr1)); addr1++; | |
| 633 | -+ outb(VGAREG_GRDC_ADDRESS, read_byte(ES, addr1)); addr1++; | |
| 634 | -+ addr1++; | |
| 635 | -+ outb(crtc_addr - 0x4 + 0xa, read_byte(ES, addr1)); addr1++; | |
| 636 | -+ } | |
| 637 | -+ if (CX & 2) { | |
| 638 | -+ write_byte(BIOSMEM_SEG,BIOSMEM_CURRENT_MODE, read_byte(ES, BX)); BX++; | |
| 639 | -+ write_word(BIOSMEM_SEG,BIOSMEM_NB_COLS, read_word(ES, BX)); BX += 2; | |
| 640 | -+ write_word(BIOSMEM_SEG,BIOSMEM_PAGE_SIZE, read_word(ES, BX)); BX += 2; | |
| 641 | -+ write_word(BIOSMEM_SEG,BIOSMEM_CRTC_ADDRESS, read_word(ES, BX)); BX += 2; | |
| 642 | -+ write_byte(BIOSMEM_SEG,BIOSMEM_NB_ROWS, read_byte(ES, BX)); BX++; | |
| 643 | -+ write_word(BIOSMEM_SEG,BIOSMEM_CHAR_HEIGHT, read_word(ES, BX)); BX += 2; | |
| 644 | -+ write_byte(BIOSMEM_SEG,BIOSMEM_VIDEO_CTL, read_byte(ES, BX)); BX++; | |
| 645 | -+ write_byte(BIOSMEM_SEG,BIOSMEM_SWITCHES, read_byte(ES, BX)); BX++; | |
| 646 | -+ write_byte(BIOSMEM_SEG,BIOSMEM_MODESET_CTL, read_byte(ES, BX)); BX++; | |
| 647 | -+ write_word(BIOSMEM_SEG,BIOSMEM_CURSOR_TYPE, read_word(ES, BX)); BX += 2; | |
| 648 | -+ for(i=0;i<8;i++) { | |
| 649 | -+ write_word(BIOSMEM_SEG, BIOSMEM_CURSOR_POS+2*i, read_word(ES, BX)); | |
| 650 | -+ BX += 2; | |
| 651 | -+ } | |
| 652 | -+ write_word(BIOSMEM_SEG,BIOSMEM_CURRENT_START, read_word(ES, BX)); BX += 2; | |
| 653 | -+ write_byte(BIOSMEM_SEG,BIOSMEM_CURRENT_PAGE, read_byte(ES, BX)); BX++; | |
| 654 | -+ /* current font */ | |
| 655 | -+ write_word(0, 0x1f * 4, read_word(ES, BX)); BX += 2; | |
| 656 | -+ write_word(0, 0x1f * 4 + 2, read_word(ES, BX)); BX += 2; | |
| 657 | -+ write_word(0, 0x43 * 4, read_word(ES, BX)); BX += 2; | |
| 658 | -+ write_word(0, 0x43 * 4 + 2, read_word(ES, BX)); BX += 2; | |
| 659 | -+ } | |
| 660 | -+ if (CX & 4) { | |
| 661 | -+ BX++; | |
| 662 | -+ v = read_byte(ES, BX); BX++; | |
| 663 | -+ outb(VGAREG_PEL_MASK, read_byte(ES, BX)); BX++; | |
| 664 | -+ // Set the whole dac always, from 0 | |
| 665 | -+ outb(VGAREG_DAC_WRITE_ADDRESS,0x00); | |
| 666 | -+ for(i=0;i<256*3;i++) { | |
| 667 | -+ outb(VGAREG_DAC_DATA, read_byte(ES, BX)); BX++; | |
| 668 | -+ } | |
| 669 | -+ BX++; | |
| 670 | -+ outb(VGAREG_DAC_WRITE_ADDRESS, v); | |
| 671 | -+ } | |
| 672 | -+ return BX; | |
| 673 | - } | |
| 674 | - | |
| 675 | - // ============================================================================================ | |
| 676 | -diff -u -w vbetables-gen.c | |
| 677 | ---- vbetables-gen.c 1970-01-01 01:00:00.000000000 +0100 | |
| 678 | -+++ vbetables-gen.c 2006-06-14 00:52:18.000000000 +0200 | |
| 679 | -@@ -0,0 +1,217 @@ | |
| 680 | -+/* Generate the VGABIOS VBE Tables */ | |
| 681 | -+#include <stdlib.h> | |
| 682 | -+#include <stdio.h> | |
| 683 | -+ | |
| 684 | -+typedef struct { | |
| 685 | -+ int width; | |
| 686 | -+ int height; | |
| 687 | -+ int depth; | |
| 688 | -+ int mode; | |
| 689 | -+} ModeInfo; | |
| 690 | -+ | |
| 691 | -+ModeInfo modes[] = { | |
| 692 | -+ /* standard VESA modes */ | |
| 693 | -+{ 640, 400, 8 , 0x100}, | |
| 694 | -+{ 640, 480, 8 , 0x101}, | |
| 695 | -+{ 800, 600, 4 , 0x102}, | |
| 696 | -+{ 800, 600, 8 , 0x103}, | |
| 697 | -+ //{ 1024, 768, 4 , 0x104}, | |
| 698 | -+{ 1024, 768, 8 , 0x105}, | |
| 699 | -+ //{ 1280, 1024, 4 , 0x106}, | |
| 700 | -+{ 1280, 1024, 8 , 0x107}, | |
| 701 | -+{ 320, 200, 15 , 0x10D}, | |
| 702 | -+{ 320, 200, 16 , 0x10E}, | |
| 703 | -+{ 320, 200, 24 , 0x10F}, | |
| 704 | -+{ 640, 480, 15 , 0x110}, | |
| 705 | -+{ 640, 480, 16 , 0x111}, | |
| 706 | -+{ 640, 480, 24 , 0x112}, | |
| 707 | -+{ 800, 600, 15 , 0x113}, | |
| 708 | -+{ 800, 600, 16 , 0x114}, | |
| 709 | -+{ 800, 600, 24 , 0x115}, | |
| 710 | -+{ 1024, 768, 15 , 0x116}, | |
| 711 | -+{ 1024, 768, 16 , 0x117}, | |
| 712 | -+{ 1024, 768, 24 , 0x118}, | |
| 713 | -+{ 1280, 1024, 15 , 0x119}, | |
| 714 | -+{ 1280, 1024, 16 , 0x11A}, | |
| 715 | -+{ 1280, 1024, 24 , 0x11B}, | |
| 716 | -+{ 1600, 1200, 8 , 0x11C}, | |
| 717 | -+{ 1600, 1200, 15 , 0x11D}, | |
| 718 | -+{ 1600, 1200, 16 , 0x11E}, | |
| 719 | -+{ 1600, 1200, 24 , 0x11F}, | |
| 720 | -+ | |
| 721 | -+ /* BOCHS/PLE, 86 'own' mode numbers */ | |
| 722 | -+{ 320, 200, 32 , 0x140}, | |
| 723 | -+{ 640, 400, 32 , 0x141}, | |
| 724 | -+{ 640, 480, 32 , 0x142}, | |
| 725 | -+{ 800, 600, 32 , 0x143}, | |
| 726 | -+{ 1024, 768, 32 , 0x144}, | |
| 727 | -+{ 1280, 1024, 32 , 0x145}, | |
| 728 | -+{ 320, 200, 8 , 0x146}, | |
| 729 | -+{ 1600, 1200, 32 , 0x147}, | |
| 730 | -+{ 1152, 864, 8 , 0x148}, | |
| 731 | -+{ 1152, 864, 15 , 0x149}, | |
| 732 | -+{ 1152, 864, 16 , 0x14a}, | |
| 733 | -+{ 1152, 864, 24 , 0x14b}, | |
| 734 | -+{ 1152, 864, 32 , 0x14c}, | |
| 735 | -+{ 0, }, | |
| 736 | -+}; | |
| 737 | -+ | |
| 738 | -+int main(int argc, char **argv) | |
| 739 | -+{ | |
| 740 | -+ const ModeInfo *pm; | |
| 741 | -+ int pitch, r_size, r_pos, g_size, g_pos, b_size, b_pos, a_size, a_pos; | |
| 742 | -+ const char *str; | |
| 743 | -+ | |
| 744 | -+ printf("/* THIS FILE IS AUTOMATICALLY GENERATED - DO NOT EDIT */\n"); | |
| 745 | -+ printf("static ModeInfoListItem mode_info_list[]=\n"); | |
| 746 | -+ printf("{\n"); | |
| 747 | -+ for(pm = modes; pm->mode != 0; pm++) { | |
| 748 | -+ printf("{ 0x%04x, /* %dx%dx%d */\n", | |
| 749 | -+ pm->mode, pm->width, pm->height, pm->depth); | |
| 750 | -+ printf("{ /*Bit16u ModeAttributes*/ %s,\n", | |
| 751 | -+ "VBE_MODE_ATTRIBUTE_SUPPORTED | " | |
| 752 | -+ "VBE_MODE_ATTRIBUTE_EXTENDED_INFORMATION_AVAILABLE | " | |
| 753 | -+ "VBE_MODE_ATTRIBUTE_COLOR_MODE | " | |
| 754 | -+ "VBE_MODE_ATTRIBUTE_LINEAR_FRAME_BUFFER_MODE | " | |
| 755 | -+ "VBE_MODE_ATTRIBUTE_GRAPHICS_MODE"); | |
| 756 | -+ | |
| 757 | -+ printf("/*Bit8u WinAAttributes*/ %s,\n", | |
| 758 | -+ "VBE_WINDOW_ATTRIBUTE_RELOCATABLE | " | |
| 759 | -+ "VBE_WINDOW_ATTRIBUTE_READABLE | " | |
| 760 | -+ "VBE_WINDOW_ATTRIBUTE_WRITEABLE"); | |
| 761 | -+ | |
| 762 | -+ printf("/*Bit8u WinBAttributes*/ %d,\n", 0); | |
| 763 | -+ | |
| 764 | -+ printf("/*Bit16u WinGranularity*/ %s,\n", "VBE_DISPI_BANK_SIZE_KB"); | |
| 765 | -+ | |
| 766 | -+ printf("/*Bit16u WinSize*/ %s,\n", "VBE_DISPI_BANK_SIZE_KB"); | |
| 767 | -+ | |
| 768 | -+ printf("/*Bit16u WinASegment*/ %s,\n", "VGAMEM_GRAPH"); | |
| 769 | -+ | |
| 770 | -+ printf("/*Bit16u WinBSegment*/ 0x%04x,\n", 0); | |
| 771 | -+ | |
| 772 | -+ printf("/*Bit32u WinFuncPtr*/ %d,\n", 0); | |
| 773 | -+ | |
| 774 | -+ if (pm->depth == 4) | |
| 775 | -+ pitch = (pm->width + 7) / 8; | |
| 776 | -+ else | |
| 777 | -+ pitch = pm->width * ((pm->depth + 7) / 8); | |
| 778 | -+ printf("/*Bit16u BytesPerScanLine*/ %d,\n", pitch); | |
| 779 | -+ | |
| 780 | -+ // Mandatory information for VBE 1.2 and above | |
| 781 | -+ printf("/*Bit16u XResolution*/ %d,\n", pm->width); | |
| 782 | -+ printf("/*Bit16u YResolution*/ %d,\n", pm->height); | |
| 783 | -+ printf("/*Bit8u XCharSize*/ %d,\n", 8); | |
| 784 | -+ printf("/*Bit8u YCharSize*/ %d,\n", 16); | |
| 785 | -+ if (pm->depth == 4) { | |
| 786 | -+ printf("/*Bit8u NumberOfPlanes*/ %d,\n", 4); | |
| 787 | -+ printf("/*Bit8u BitsPerPixel*/ %d,\n", pm->depth); | |
| 788 | -+ } else { | |
| 789 | -+ printf("/*Bit8u NumberOfPlanes*/ %d,\n", 1); | |
| 790 | -+ printf("/*Bit8u BitsPerPixel*/ %d,\n", pm->depth); | |
| 791 | -+ } | |
| 792 | -+ printf("/*Bit8u NumberOfBanks*/ %d,\n", | |
| 793 | -+ (pm->height * pitch + 65535) / 65536); | |
| 794 | -+ | |
| 795 | -+ if (pm->depth == 4) | |
| 796 | -+ str = "VBE_MEMORYMODEL_PLANAR"; | |
| 797 | -+ else if (pm->depth == 8) | |
| 798 | -+ str = "VBE_MEMORYMODEL_PACKED_PIXEL"; | |
| 799 | -+ else | |
| 800 | -+ str = "VBE_MEMORYMODEL_DIRECT_COLOR"; | |
| 801 | -+ printf("/*Bit8u MemoryModel*/ %s,\n", str); | |
| 802 | -+ printf("/*Bit8u BankSize*/ %d,\n", 0); | |
| 803 | -+ /* XXX: check */ | |
| 804 | -+ printf("/*Bit8u NumberOfImagePages*/ %d,\n", 0); | |
| 805 | -+ printf("/*Bit8u Reserved_page*/ %d,\n", 0); | |
| 806 | -+ | |
| 807 | -+ // Direct Color fields (required for direct/6 and YUV/7 memory models) | |
| 808 | -+ switch(pm->depth) { | |
| 809 | -+ case 15: | |
| 810 | -+ r_size = 5; | |
| 811 | -+ r_pos = 10; | |
| 812 | -+ g_size = 5; | |
| 813 | -+ g_pos = 5; | |
| 814 | -+ b_size = 5; | |
| 815 | -+ b_pos = 0; | |
| 816 | -+ a_size = 1; | |
| 817 | -+ a_pos = 15; | |
| 818 | -+ break; | |
| 819 | -+ case 16: | |
| 820 | -+ r_size = 5; | |
| 821 | -+ r_pos = 11; | |
| 822 | -+ g_size = 6; | |
| 823 | -+ g_pos = 5; | |
| 824 | -+ b_size = 5; | |
| 825 | -+ b_pos = 0; | |
| 826 | -+ a_size = 0; | |
| 827 | -+ a_pos = 0; | |
| 828 | -+ break; | |
| 829 | -+ case 24: | |
| 830 | -+ r_size = 8; | |
| 831 | -+ r_pos = 16; | |
| 832 | -+ g_size = 8; | |
| 833 | -+ g_pos = 8; | |
| 834 | -+ b_size = 8; | |
| 835 | -+ b_pos = 0; | |
| 836 | -+ a_size = 0; | |
| 837 | -+ a_pos = 0; | |
| 838 | -+ break; | |
| 839 | -+ case 32: | |
| 840 | -+ r_size = 8; | |
| 841 | -+ r_pos = 16; | |
| 842 | -+ g_size = 8; | |
| 843 | -+ g_pos = 8; | |
| 844 | -+ b_size = 8; | |
| 845 | -+ b_pos = 0; | |
| 846 | -+ a_size = 8; | |
| 847 | -+ a_pos = 24; | |
| 848 | -+ break; | |
| 849 | -+ default: | |
| 850 | -+ r_size = 0; | |
| 851 | -+ r_pos = 0; | |
| 852 | -+ g_size = 0; | |
| 853 | -+ g_pos = 0; | |
| 854 | -+ b_size = 0; | |
| 855 | -+ b_pos = 0; | |
| 856 | -+ a_size = 0; | |
| 857 | -+ a_pos = 0; | |
| 858 | -+ break; | |
| 859 | -+ } | |
| 860 | -+ | |
| 861 | -+ printf("/*Bit8u RedMaskSize*/ %d,\n", r_size); | |
| 862 | -+ printf("/*Bit8u RedFieldPosition*/ %d,\n", r_pos); | |
| 863 | -+ printf("/*Bit8u GreenMaskSize*/ %d,\n", g_size); | |
| 864 | -+ printf("/*Bit8u GreenFieldPosition*/ %d,\n", g_pos); | |
| 865 | -+ printf("/*Bit8u BlueMaskSize*/ %d,\n", b_size); | |
| 866 | -+ printf("/*Bit8u BlueFieldPosition*/ %d,\n", b_pos); | |
| 867 | -+ printf("/*Bit8u RsvdMaskSize*/ %d,\n", a_size); | |
| 868 | -+ printf("/*Bit8u RsvdFieldPosition*/ %d,\n", a_pos); | |
| 869 | -+ printf("/*Bit8u DirectColorModeInfo*/ %d,\n", 0); | |
| 870 | -+ | |
| 871 | -+// Mandatory information for VBE 2.0 and above | |
| 872 | -+ printf("/*Bit32u PhysBasePtr*/ %s,\n", | |
| 873 | -+ "VBE_DISPI_LFB_PHYSICAL_ADDRESS"); | |
| 874 | -+ printf("/*Bit32u OffScreenMemOffset*/ %d,\n", 0); | |
| 875 | -+ printf("/*Bit16u OffScreenMemSize*/ %d,\n", 0); | |
| 876 | -+ // Mandatory information for VBE 3.0 and above | |
| 877 | -+ printf("/*Bit16u LinBytesPerScanLine*/ %d,\n", pitch); | |
| 878 | -+ printf("/*Bit8u BnkNumberOfPages*/ %d,\n", 0); | |
| 879 | -+ printf("/*Bit8u LinNumberOfPages*/ %d,\n", 0); | |
| 880 | -+ printf("/*Bit8u LinRedMaskSize*/ %d,\n", r_size); | |
| 881 | -+ printf("/*Bit8u LinRedFieldPosition*/ %d,\n", r_pos); | |
| 882 | -+ printf("/*Bit8u LinGreenMaskSize*/ %d,\n", g_size); | |
| 883 | -+ printf("/*Bit8u LinGreenFieldPosition*/ %d,\n", g_pos); | |
| 884 | -+ printf("/*Bit8u LinBlueMaskSize*/ %d,\n", b_size); | |
| 885 | -+ printf("/*Bit8u LinBlueFieldPosition*/ %d,\n", b_pos); | |
| 886 | -+ printf("/*Bit8u LinRsvdMaskSize*/ %d,\n", a_size); | |
| 887 | -+ printf("/*Bit8u LinRsvdFieldPosition*/ %d,\n", a_pos); | |
| 888 | -+ printf("/*Bit32u MaxPixelClock*/ %d,\n", 0); | |
| 889 | -+ printf("} },\n"); | |
| 890 | -+ } | |
| 891 | -+ printf("{ VBE_VESA_MODE_END_OF_LIST,\n"); | |
| 892 | -+ printf("{ 0,\n"); | |
| 893 | -+ printf("} },\n"); | |
| 894 | -+ printf("};\n"); | |
| 895 | -+ return 0; | |
| 896 | -+} |