Commit 68d5736aeeda5ced448737a071b0b4c890341be7

Authored by aliguori
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   -+}