root / pc-bios / bios.diff @ c5d6edc3
History | View | Annotate | Download (8.5 kB)
1 | a1e75473 | bellard | Index: apmbios.S
|
---|---|---|---|
2 | a1e75473 | bellard | ===================================================================
|
3 | a1e75473 | bellard | RCS file: /cvsroot/bochs/bochs/bios/apmbios.S,v
|
4 | a1e75473 | bellard | retrieving revision 1.4
|
5 | a1e75473 | bellard | diff -u -w -r1.4 apmbios.S
|
6 | a1e75473 | bellard | --- apmbios.S 26 Dec 2005 10:35:51 -0000 1.4
|
7 | 10765455 | bellard | +++ apmbios.S 3 May 2006 21:22:46 -0000
|
8 | a1e75473 | bellard | @@ -225,6 +225,7 @@
|
9 | a1e75473 | bellard | APMSYM(05): |
10 | a1e75473 | bellard | cmp al, #0x05 |
11 | a1e75473 | bellard | jne APMSYM(07) |
12 | a1e75473 | bellard | + sti
|
13 | a1e75473 | bellard | hlt |
14 | a1e75473 | bellard | jmp APMSYM(ok) |
15 | a1e75473 | bellard | |
16 | 3f433d2c | bellard | Index: rombios.c
|
17 | 3f433d2c | bellard | ===================================================================
|
18 | 3f433d2c | bellard | RCS file: /cvsroot/bochs/bochs/bios/rombios.c,v
|
19 | 307b0c24 | bellard | retrieving revision 1.160
|
20 | 307b0c24 | bellard | diff -u -w -r1.160 rombios.c
|
21 | 307b0c24 | bellard | --- rombios.c 25 Jan 2006 17:51:49 -0000 1.160
|
22 | 10765455 | bellard | +++ rombios.c 3 May 2006 21:22:48 -0000
|
23 | 307b0c24 | bellard | @@ -1816,6 +1816,7 @@
|
24 | 307b0c24 | bellard | { |
25 | 307b0c24 | bellard | printf(BX_APPNAME" BIOS - build: %s\n%s\nOptions: ",
|
26 | 307b0c24 | bellard | BIOS_BUILD_DATE, bios_cvs_version_string); |
27 | 307b0c24 | bellard | +#if 0
|
28 | 307b0c24 | bellard | printf( |
29 | 307b0c24 | bellard | #ifdef BX_APM
|
30 | 307b0c24 | bellard | "apmbios "
|
31 | 307b0c24 | bellard | @@ -1827,6 +1828,9 @@
|
32 | 307b0c24 | bellard | "eltorito "
|
33 | 307b0c24 | bellard | #endif
|
34 | 307b0c24 | bellard | "\n\n");
|
35 | 307b0c24 | bellard | +#else
|
36 | 307b0c24 | bellard | + printf("apmbios pcibios eltorito \n\n");
|
37 | 307b0c24 | bellard | +#endif
|
38 | 307b0c24 | bellard | } |
39 | a5ba1ca6 | bellard | |
40 | 307b0c24 | bellard | //--------------------------------------------------------------------------
|
41 | 10765455 | bellard | @@ -3999,6 +4003,29 @@
|
42 | 10765455 | bellard | } |
43 | 10765455 | bellard | #endif
|
44 | 10765455 | bellard | |
45 | 10765455 | bellard | +
|
46 | 10765455 | bellard | +void set_e820_range(ES, DI, start, end, type)
|
47 | 10765455 | bellard | + Bit16u ES;
|
48 | 10765455 | bellard | + Bit16u DI;
|
49 | 10765455 | bellard | + Bit32u start;
|
50 | 10765455 | bellard | + Bit32u end;
|
51 | 10765455 | bellard | + Bit16u type;
|
52 | 10765455 | bellard | +{
|
53 | 10765455 | bellard | + write_word(ES, DI, start);
|
54 | 10765455 | bellard | + write_word(ES, DI+2, start >> 16);
|
55 | 10765455 | bellard | + write_word(ES, DI+4, 0x00);
|
56 | 10765455 | bellard | + write_word(ES, DI+6, 0x00);
|
57 | 10765455 | bellard | +
|
58 | 10765455 | bellard | + end -= start;
|
59 | 10765455 | bellard | + write_word(ES, DI+8, end);
|
60 | 10765455 | bellard | + write_word(ES, DI+10, end >> 16);
|
61 | 10765455 | bellard | + write_word(ES, DI+12, 0x0000);
|
62 | 10765455 | bellard | + write_word(ES, DI+14, 0x0000);
|
63 | 10765455 | bellard | +
|
64 | 10765455 | bellard | + write_word(ES, DI+16, type);
|
65 | 10765455 | bellard | + write_word(ES, DI+18, 0x0);
|
66 | 10765455 | bellard | +}
|
67 | 10765455 | bellard | +
|
68 | 10765455 | bellard | void
|
69 | 10765455 | bellard | int15_function32(regs, ES, DS, FLAGS) |
70 | 10765455 | bellard | pushad_regs_t regs; // REGS pushed via pushad
|
71 | 10765455 | bellard | @@ -4063,19 +4090,8 @@
|
72 | 10765455 | bellard | switch(regs.u.r16.bx)
|
73 | 10765455 | bellard | { |
74 | 10765455 | bellard | case 0: |
75 | 10765455 | bellard | - write_word(ES, regs.u.r16.di, 0x00);
|
76 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+2, 0x00);
|
77 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+4, 0x00);
|
78 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+6, 0x00);
|
79 | 10765455 | bellard | -
|
80 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+8, 0xFC00);
|
81 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+10, 0x0009);
|
82 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+12, 0x0000);
|
83 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+14, 0x0000);
|
84 | 10765455 | bellard | -
|
85 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+16, 0x1);
|
86 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+18, 0x0);
|
87 | 10765455 | bellard | -
|
88 | 10765455 | bellard | + set_e820_range(ES, regs.u.r16.di,
|
89 | 10765455 | bellard | + 0x0000000L, 0x0009fc00L, 1);
|
90 | 10765455 | bellard | regs.u.r32.ebx = 1;
|
91 | 10765455 | bellard | regs.u.r32.eax = 0x534D4150;
|
92 | 10765455 | bellard | regs.u.r32.ecx = 0x14;
|
93 | 10765455 | bellard | @@ -4083,6 +4099,24 @@
|
94 | 10765455 | bellard | return;
|
95 | 10765455 | bellard | break;
|
96 | 10765455 | bellard | case 1: |
97 | 10765455 | bellard | + set_e820_range(ES, regs.u.r16.di,
|
98 | 10765455 | bellard | + 0x0009fc00L, 0x000a0000L, 2);
|
99 | 10765455 | bellard | + regs.u.r32.ebx = 2;
|
100 | 10765455 | bellard | + regs.u.r32.eax = 0x534D4150;
|
101 | 10765455 | bellard | + regs.u.r32.ecx = 0x14;
|
102 | 10765455 | bellard | + CLEAR_CF();
|
103 | 10765455 | bellard | + return;
|
104 | 10765455 | bellard | + break;
|
105 | 10765455 | bellard | + case 2:
|
106 | 10765455 | bellard | + set_e820_range(ES, regs.u.r16.di,
|
107 | 10765455 | bellard | + 0x000e8000L, 0x00100000L, 2);
|
108 | 10765455 | bellard | + regs.u.r32.ebx = 3;
|
109 | 10765455 | bellard | + regs.u.r32.eax = 0x534D4150;
|
110 | 10765455 | bellard | + regs.u.r32.ecx = 0x14;
|
111 | 10765455 | bellard | + CLEAR_CF();
|
112 | 10765455 | bellard | + return;
|
113 | 10765455 | bellard | + break;
|
114 | 10765455 | bellard | + case 3:
|
115 | 10765455 | bellard | extended_memory_size = inb_cmos(0x35);
|
116 | 10765455 | bellard | extended_memory_size <<= 8;
|
117 | 10765455 | bellard | extended_memory_size |= inb_cmos(0x34);
|
118 | 10765455 | bellard | @@ -4092,9 +4126,9 @@
|
119 | 10765455 | bellard | extended_memory_size = 0x3bc000; // everything after this is reserved memory until we get to 0x100000000 |
120 | 10765455 | bellard | } |
121 | 10765455 | bellard | extended_memory_size *= 1024;
|
122 | 10765455 | bellard | - extended_memory_size += 15728640; // make up for the 16mb of memory that is chopped off
|
123 | 10765455 | bellard | + extended_memory_size += (16L * 1024 * 1024);
|
124 | 10765455 | bellard | |
125 | 10765455 | bellard | - if(extended_memory_size <= 15728640)
|
126 | 10765455 | bellard | + if(extended_memory_size <= (16L * 1024 * 1024))
|
127 | 10765455 | bellard | { |
128 | 10765455 | bellard | extended_memory_size = inb_cmos(0x31);
|
129 | 10765455 | bellard | extended_memory_size <<= 8;
|
130 | 10765455 | bellard | @@ -4102,28 +4136,23 @@
|
131 | 10765455 | bellard | extended_memory_size *= 1024;
|
132 | 10765455 | bellard | } |
133 | 10765455 | bellard | |
134 | 10765455 | bellard | - write_word(ES, regs.u.r16.di, 0x0000);
|
135 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+2, 0x0010);
|
136 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+4, 0x0000);
|
137 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+6, 0x0000);
|
138 | 10765455 | bellard | -
|
139 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+8, extended_memory_size);
|
140 | 10765455 | bellard | - extended_memory_size >>= 16;
|
141 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+10, extended_memory_size);
|
142 | 10765455 | bellard | - extended_memory_size >>= 16;
|
143 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+12, extended_memory_size);
|
144 | 10765455 | bellard | - extended_memory_size >>= 16;
|
145 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+14, extended_memory_size);
|
146 | 10765455 | bellard | -
|
147 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+16, 0x1);
|
148 | 10765455 | bellard | - write_word(ES, regs.u.r16.di+18, 0x0);
|
149 | 10765455 | bellard | -
|
150 | 10765455 | bellard | - regs.u.r32.ebx = 0;
|
151 | 10765455 | bellard | + set_e820_range(ES, regs.u.r16.di,
|
152 | 10765455 | bellard | + 0x00100000L, extended_memory_size, 1);
|
153 | 10765455 | bellard | + regs.u.r32.ebx = 4;
|
154 | 10765455 | bellard | regs.u.r32.eax = 0x534D4150;
|
155 | 10765455 | bellard | regs.u.r32.ecx = 0x14;
|
156 | 10765455 | bellard | CLEAR_CF(); |
157 | 10765455 | bellard | return;
|
158 | 10765455 | bellard | break;
|
159 | 10765455 | bellard | + case 4:
|
160 | 10765455 | bellard | + /* 256KB BIOS area at the end of 4 GB */
|
161 | 10765455 | bellard | + set_e820_range(ES, regs.u.r16.di,
|
162 | 10765455 | bellard | + 0xfffc0000L, 0x00000000L, 2);
|
163 | 10765455 | bellard | + regs.u.r32.ebx = 0;
|
164 | 10765455 | bellard | + regs.u.r32.eax = 0x534D4150;
|
165 | 10765455 | bellard | + regs.u.r32.ecx = 0x14;
|
166 | 10765455 | bellard | + CLEAR_CF();
|
167 | 10765455 | bellard | + return;
|
168 | 10765455 | bellard | default: /* AX=E820, DX=534D4150, BX unrecognized */ |
169 | 10765455 | bellard | goto int15_unimplemented;
|
170 | 10765455 | bellard | break;
|
171 | 10765455 | bellard | @@ -8713,6 +8742,7 @@
|
172 | e0b3073f | bellard | mov al, #0x80
|
173 | e0b3073f | bellard | bios32_end:
|
174 | e0b3073f | bellard | popf |
175 | e0b3073f | bellard | + and dword ptr[esp+4],0xfffffffc ;; reset CS.RPL for kqemu
|
176 | e0b3073f | bellard | retf |
177 | e0b3073f | bellard | |
178 | e0b3073f | bellard | .align 16
|
179 | 10765455 | bellard | @@ -8823,17 +8853,17 @@
|
180 | e0b3073f | bellard | pci_pro_fail:
|
181 | e0b3073f | bellard | pop edi |
182 | e0b3073f | bellard | pop esi |
183 | e0b3073f | bellard | - sti
|
184 | e0b3073f | bellard | popf |
185 | e0b3073f | bellard | stc |
186 | e0b3073f | bellard | + and dword ptr[esp+4],0xfffffffc ;; reset CS.RPL for kqemu
|
187 | e0b3073f | bellard | retf |
188 | e0b3073f | bellard | pci_pro_ok:
|
189 | e0b3073f | bellard | xor ah, ah |
190 | e0b3073f | bellard | pop edi |
191 | e0b3073f | bellard | pop esi |
192 | e0b3073f | bellard | - sti
|
193 | e0b3073f | bellard | popf |
194 | e0b3073f | bellard | clc |
195 | e0b3073f | bellard | + and dword ptr[esp+4],0xfffffffc ;; reset CS.RPL for kqemu
|
196 | e0b3073f | bellard | retf |
197 | e0b3073f | bellard | |
198 | e0b3073f | bellard | pci_pro_select_reg:
|
199 | 10765455 | bellard | @@ -8971,7 +9001,7 @@
|
200 | 307b0c24 | bellard | jmp pci_real_ok |
201 | 307b0c24 | bellard | pci_real_f0d: ;; write configuration dword
|
202 | 307b0c24 | bellard | cmp al, #0x0d
|
203 | 307b0c24 | bellard | - jne pci_real_unknown
|
204 | 307b0c24 | bellard | + jne pci_real_f0e
|
205 | 307b0c24 | bellard | call pci_real_select_reg |
206 | 307b0c24 | bellard | push dx |
207 | 307b0c24 | bellard | mov dx, #0x0cfc
|
208 | 10765455 | bellard | @@ -8979,6 +9009,46 @@
|
209 | 307b0c24 | bellard | out dx, eax |
210 | 307b0c24 | bellard | pop dx |
211 | 307b0c24 | bellard | jmp pci_real_ok |
212 | 307b0c24 | bellard | +pci_real_f0e: ;; get irq routing options
|
213 | 307b0c24 | bellard | + cmp al, #0x0e
|
214 | 307b0c24 | bellard | + jne pci_real_unknown
|
215 | 307b0c24 | bellard | + SEG ES
|
216 | 307b0c24 | bellard | + cmp word ptr [di], #pci_routing_table_structure_end - pci_routing_table_structure_start
|
217 | 307b0c24 | bellard | + jb pci_real_too_small
|
218 | 307b0c24 | bellard | + SEG ES
|
219 | 307b0c24 | bellard | + mov word ptr [di], #pci_routing_table_structure_end - pci_routing_table_structure_start
|
220 | 307b0c24 | bellard | + pushf
|
221 | 307b0c24 | bellard | + push ds
|
222 | 307b0c24 | bellard | + push es
|
223 | 307b0c24 | bellard | + push cx
|
224 | 307b0c24 | bellard | + push si
|
225 | 307b0c24 | bellard | + push di
|
226 | 307b0c24 | bellard | + cld
|
227 | 307b0c24 | bellard | + mov si, #pci_routing_table_structure_start
|
228 | 307b0c24 | bellard | + push cs
|
229 | 307b0c24 | bellard | + pop ds
|
230 | 307b0c24 | bellard | + SEG ES
|
231 | 307b0c24 | bellard | + mov cx, [di+2]
|
232 | 307b0c24 | bellard | + SEG ES
|
233 | 307b0c24 | bellard | + mov es, [di+4]
|
234 | 307b0c24 | bellard | + mov di, cx
|
235 | 307b0c24 | bellard | + mov cx, #pci_routing_table_structure_end - pci_routing_table_structure_start
|
236 | 307b0c24 | bellard | + rep
|
237 | 307b0c24 | bellard | + movsb
|
238 | 307b0c24 | bellard | + pop di
|
239 | 307b0c24 | bellard | + pop si
|
240 | 307b0c24 | bellard | + pop cx
|
241 | 307b0c24 | bellard | + pop es
|
242 | 307b0c24 | bellard | + pop ds
|
243 | 307b0c24 | bellard | + popf
|
244 | 307b0c24 | bellard | + mov bx, #(1 << 9) | (1 << 11) ;; irq 9 and 11 are used
|
245 | 307b0c24 | bellard | + jmp pci_real_ok
|
246 | 307b0c24 | bellard | +pci_real_too_small:
|
247 | 307b0c24 | bellard | + SEG ES
|
248 | 307b0c24 | bellard | + mov word ptr [di], #pci_routing_table_structure_end - pci_routing_table_structure_start
|
249 | 307b0c24 | bellard | + mov ah, #0x89
|
250 | 307b0c24 | bellard | + jmp pci_real_fail
|
251 | a5ba1ca6 | bellard | +
|
252 | 307b0c24 | bellard | pci_real_unknown:
|
253 | 307b0c24 | bellard | mov ah, #0x81
|
254 | 307b0c24 | bellard | pci_real_fail:
|
255 | 10765455 | bellard | @@ -9019,6 +9089,7 @@
|
256 | 307b0c24 | bellard | dw 0,0 ;; Miniport data |
257 | 307b0c24 | bellard | db 0,0,0,0,0,0,0,0,0,0,0 ;; reserved |
258 | 307b0c24 | bellard | db 0x07 ;; checksum
|
259 | 307b0c24 | bellard | +pci_routing_table_structure_start:
|
260 | 307b0c24 | bellard | ;; first slot entry PCI-to-ISA (embedded) |
261 | 307b0c24 | bellard | db 0 ;; pci bus number
|
262 | 307b0c24 | bellard | db 0x08 ;; pci device number (bit 7-3) |
263 | 10765455 | bellard | @@ -9097,6 +9168,7 @@
|
264 | 307b0c24 | bellard | dw 0xdef8 ;; IRQ bitmap INTD# |
265 | 307b0c24 | bellard | db 5 ;; physical slot (0 = embedded) |
266 | 307b0c24 | bellard | db 0 ;; reserved
|
267 | 307b0c24 | bellard | +pci_routing_table_structure_end:
|
268 | fb9f9444 | bellard | |
269 | 307b0c24 | bellard | pci_irq_list:
|
270 | 307b0c24 | bellard | db 11, 10, 9, 5; |