VirtualBox

source: vbox/trunk/src/VBox/Devices/PC/BIOS-new/pcibios.inc@ 41668

Last change on this file since 41668 was 40694, checked in by vboxsync, 13 years ago

BIOS: Make last searched bus/dev/fn configurable.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 10.9 KB
Line 
1;;
2;; Copyright (C) 2006-2011 Oracle Corporation
3;;
4;; This file is part of VirtualBox Open Source Edition (OSE), as
5;; available from http://www.virtualbox.org. This file is free software;
6;; you can redistribute it and/or modify it under the terms of the GNU
7;; General Public License (GPL) as published by the Free Software
8;; Foundation, in version 2 as it comes in the "COPYING" file of the
9;; VirtualBox OSE distribution. VirtualBox OSE is distributed in the
10;; hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
11;; --------------------------------------------------------------------
12;;
13;; This code is based on:
14;;
15;; ROM BIOS for use with Bochs/Plex86/QEMU emulation environment
16;;
17;; Copyright (C) 2002 MandrakeSoft S.A.
18;;
19;; MandrakeSoft S.A.
20;; 43, rue d'Aboukir
21;; 75002 Paris - France
22;; http://www.linux-mandrake.com/
23;; http://www.mandrakesoft.com/
24;;
25;; This library is free software; you can redistribute it and/or
26;; modify it under the terms of the GNU Lesser General Public
27;; License as published by the Free Software Foundation; either
28;; version 2 of the License, or (at your option) any later version.
29;;
30;; This library is distributed in the hope that it will be useful,
31;; but WITHOUT ANY WARRANTY; without even the implied warranty of
32;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
33;; Lesser General Public License for more details.
34;;
35;; You should have received a copy of the GNU Lesser General Public
36;; License along with this library; if not, write to the Free Software
37;; Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
38;;
39;;
40
41include pcicfg.inc
42
43if BX_PCIBIOS
44
45extrn pcibios_protected:near ; in a 32-bit segment
46
47ifdef DEBUG
48
49; Publics for easier debugging and disassembly
50
51public pcibios_real
52public pci_present
53public pci_real_f02
54public pci_real_devloop
55public pci_real_nextdev
56public pci_real_f03
57public pci_real_devloop2
58public pci_real_nextdev2
59public pci_real_ok
60public pci_real_fail
61public pci_real_select_reg
62public pcibios_init_iomem_bases
63public pci_init_io_loop1
64public pci_init_io_loop2
65public init_io_base
66public next_pci_base
67public enable_iomem_space
68public next_pci_dev
69public pcibios_init_set_elcr
70public is_master_pic
71public pcibios_init_irqs
72public pci_init_irq_loop1
73public pci_init_irq_loop2
74public pci_test_int_pin
75public pirq_found
76public next_pci_func
77public next_pir_entry
78public pci_init_end
79
80endif
81
82.386
83pcibios_real:
84 push eax
85 push dx
86ifdef PCI_FIXED_HOST_BRIDGE_1
87 mov eax, 80000000h
88 mov dx, PCI_CFG1
89 out dx, eax
90 mov dx, PCI_CFG2
91 in eax, dx
92 cmp eax, PCI_FIXED_HOST_BRIDGE_1
93 je pci_present
94endif
95
96ifdef PCI_FIXED_HOST_BRIDGE_2
97 ; 1Eh << 11
98 mov eax, 8000f000h
99 mov dx, PCI_CFG1
100 out dx, eax
101 mov dx, PCI_CFG2
102 in eax, dx
103 cmp eax, PCI_FIXED_HOST_BRIDGE_2
104 je pci_present
105endif
106 pop dx
107 pop eax
108 mov ah, 0FFh
109 stc
110 ret
111pci_present:
112 pop dx
113 pop eax
114 cmp al, 1 ; installation check
115 jne pci_real_f02
116 mov ax, 0001h
117 mov bx, 0210h
118 mov cx, 0
119 mov edx, ' ICP' ; #0x20494350 "PCI "
120;; @todo!
121if 0
122 mov edi, 0f0000h
123 mov di, pcibios_protected
124else
125 mov edi, pcibios_protected
126endif
127 clc
128 ret
129
130pci_real_f02: ;; find pci device
131 push esi
132 push edi
133 push edx
134 cmp al, 2
135 jne pci_real_f03
136
137 shl ecx, 16
138 mov cx, dx
139 xor ebx, ebx
140 mov di, 0
141pci_real_devloop:
142 call pci_real_select_reg
143 mov dx, PCI_CFG2
144 in eax, dx
145 cmp eax, ecx
146 jne pci_real_nextdev
147
148 cmp si, 0
149 je pci_real_ok
150
151 dec si
152pci_real_nextdev:
153 inc ebx
154 cmp ebx, MAX_BUSDEVFN
155 jne pci_real_devloop
156
157 mov dx, cx
158 shr ecx, 16
159 mov ax, 8602h
160 jmp pci_real_fail
161pci_real_f03: ;; find class code
162 cmp al, 3
163 jne pci_real_f08
164 xor ebx, ebx
165 mov di, 8
166pci_real_devloop2:
167 call pci_real_select_reg
168 mov dx, PCI_CFG2
169 in eax, dx
170 shr eax, 8
171 cmp eax, ecx
172 jne pci_real_nextdev2
173
174 cmp si, 0
175 je pci_real_ok
176
177 dec si
178pci_real_nextdev2:
179 inc ebx
180 cmp ebx, MAX_BUSDEVFN
181 jne pci_real_devloop2
182
183 mov ax, 8603h
184 jmp pci_real_fail
185
186pci_real_f08: ;; read configuration byte
187 cmp al, 8
188 jne pci_real_f09
189
190 call pci_real_select_reg
191 push dx
192 mov dx, di
193 and dx, 3
194 add dx, PCI_CFG2
195 in al, dx
196 pop dx
197 mov cl, al
198 jmp pci_real_ok
199
200pci_real_f09: ;; read configuration word
201 cmp al, 9
202 jne pci_real_f0a
203
204 call pci_real_select_reg
205 push dx
206 mov dx, di
207 and dx, 2
208 add dx, PCI_CFG2
209 in ax, dx
210 pop dx
211 mov cx, ax
212 jmp pci_real_ok
213pci_real_f0a: ;; read configuration dword
214 cmp al, 0Ah
215 jne pci_real_f0b
216
217 call pci_real_select_reg
218 push dx
219 mov dx, PCI_CFG2
220 in eax, dx
221 pop dx
222 mov ecx, eax
223 jmp pci_real_ok
224
225pci_real_f0b: ;; write configuration byte
226 cmp al, 0Bh
227 jne pci_real_f0c
228
229 call pci_real_select_reg
230 push dx
231 mov dx, di
232 and dx, 3
233 add dx, PCI_CFG2
234 mov al, cl
235 out dx, al
236 pop dx
237 jmp pci_real_ok
238
239pci_real_f0c: ;; write configuration word
240 cmp al, 0Ch
241 jne pci_real_f0d
242
243 call pci_real_select_reg
244 push dx
245 mov dx, di
246 and dx, 2
247 add dx, PCI_CFG2
248 mov ax, cx
249 out dx, ax
250 pop dx
251 jmp pci_real_ok
252
253pci_real_f0d: ;; write configuration dword
254 cmp al, 0Dh
255 jne pci_real_f0e
256
257 call pci_real_select_reg
258 push dx
259 mov dx, PCI_CFG2
260 mov eax, ecx
261 out dx, eax
262 pop dx
263 jmp pci_real_ok
264
265pci_real_f0e: ;; get irq routing options
266 cmp al, 0Eh
267 jne pci_real_unknown
268
269 cmp word ptr es:[di], pci_routing_table_structure_end - pci_routing_table_structure_start
270 jb pci_real_too_small
271
272 mov word ptr es:[di], pci_routing_table_structure_end - pci_routing_table_structure_start
273 pushf
274 push ds
275 push es
276 push cx
277 push si
278 push di
279 cld
280 mov si, pci_routing_table_structure_start
281 push cs
282 pop ds
283 mov cx, es:[di+2]
284 mov es, es:[di+4]
285 mov di, cx
286 mov cx, pci_routing_table_structure_end - pci_routing_table_structure_start
287 rep movsb
288 pop di
289 pop si
290 pop cx
291 pop es
292 pop ds
293 popf
294 mov bx, (1 shl 9) or (1 shl 11) ; #(1 << 9) | (1 << 11) ;; irq 9 and 11 are used
295 jmp pci_real_ok
296
297pci_real_too_small:
298 mov word ptr es:[di], pci_routing_table_structure_end - pci_routing_table_structure_start
299 mov ah, 89h
300 jmp pci_real_fail
301
302pci_real_unknown:
303 mov ah, 81h
304pci_real_fail:
305 pop edx
306 pop edi
307 pop esi
308 stc
309 ret
310pci_real_ok:
311 xor ah, ah
312 pop edx
313 pop edi
314 pop esi
315 clc
316 ret
317
318;; prepare from reading the PCI config space; on input:
319;; bx = bus/dev/fn
320;; di = offset into config space header
321;; destroys eax and may modify di
322pci_real_select_reg:
323 push dx
324 mov eax, 800000h
325 mov ax, bx
326 shl eax, 8
327 and di, 0FFh
328 or ax, di
329 and al, 0FCh
330 mov dx, PCI_CFG1
331 out dx, eax
332 pop dx
333 ret
334
335if not BX_ROMBIOS32
336pci_irq_list:
337 db 11, 10, 9, 5;
338
339pcibios_init_sel_reg:
340 push eax
341 mov eax, 800000h
342 mov ax, bx
343 shl eax, 8
344 and dl, 0FCh
345 or al, dl
346 mov dx, PCI_CFG1
347 out dx, eax
348 pop eax
349 ret
350
351pcibios_init_iomem_bases:
352 push bp
353 mov bp, sp
354 mov eax, 0E0000000h ; base for memory init
355 push eax
356 mov ax, 0D000h ; base for i/o init
357 push ax
358 mov ax, 010h ; start at base address #0
359 push ax
360 mov bx, 8
361pci_init_io_loop1:
362 mov dl, 0
363 call pcibios_init_sel_reg
364 mov dx, PCI_CFG2
365 in ax, dx
366 cmp ax, 0FFFFh
367 jz next_pci_dev
368
369ifndef VBOX ; This currently breaks restoring a previously saved state. */
370 mov dl, 4 ; disable i/o and memory space access
371 call pcibios_init_sel_reg
372 mov dx, PCI_CFG2
373 in al, dx
374 and al, 0FCh
375 out dx, al
376pci_init_io_loop2:
377 mov dl, [bp-8]
378 call pcibios_init_sel_reg
379 mov dx, PCI_CFG2
380 in eax, dx
381 test al, 1
382 jnz init_io_base
383
384 mov ecx, eax
385 mov eax, 0FFFFFFFFh
386 out dx, eax
387 in eax, dx
388 cmp eax, ecx
389 je next_pci_base
390 xor eax, 0FFFFFFFFh
391 mov ecx, eax
392 mov eax, [bp-4]
393 out dx, eax
394 add eax, ecx ; calculate next free mem base
395 add eax, 01000000h
396 and eax, 0FF000000h
397 mov [bp-4], eax
398 jmp next_pci_base
399
400init_io_base:
401 mov cx, ax
402 mov ax, 0FFFFh
403 out dx, eax
404 in eax, dx
405 cmp ax, cx
406 je next_pci_base
407
408 xor ax, 0FFFEh
409 mov cx, ax
410 mov ax, [bp-6]
411 out dx, eax
412 add ax, cx ; calculate next free i/o base
413 add ax, 00100h
414 and ax, 0FF00h
415 mov [bp-6], ax
416next_pci_base:
417 mov al, [bp-8]
418 add al, 4
419 cmp al, 28h
420 je enable_iomem_space
421
422 mov byte ptr[bp-8], al
423 jmp pci_init_io_loop2
424endif ; !VBOX
425
426enable_iomem_space:
427 mov dl, 4 ;; enable i/o and memory space access if available
428 call pcibios_init_sel_reg
429 mov dx, PCI_CFG2
430 in al, dx
431 or al, 7
432 out dx, al
433ifdef VBOX
434 mov dl, 0 ; check if PCI device is AMD PCNet
435 call pcibios_init_sel_reg
436 mov dx, PCI_CFG2
437 in eax, dx
438 cmp eax, 020001022h
439 jne next_pci_dev
440
441 mov dl, 10h ; get I/O address
442 call pcibios_init_sel_reg
443 mov dx, PCI_CFG2
444 in ax, dx
445 and ax, 0FFFCh
446 mov cx, ax
447 mov dx, cx
448 add dx, 14h ; reset register if PCNet is in word I/O mode
449 in ax, dx ; reset is performed by reading the reset register
450 mov dx, cx
451 add dx, 18h ; reset register if PCNet is in word I/O mode
452 in eax, dx ; reset is performed by reading the reset register
453endif ; VBOX
454next_pci_dev:
455 mov byte ptr[bp-8], 10h
456 inc bx
457 cmp bx, 0100h
458 jne pci_init_io_loop1
459 mov sp, bp
460 pop bp
461 ret
462
463pcibios_init_set_elcr:
464 push ax
465 push cx
466 mov dx, 04D0h
467 test al, 8
468 jz is_master_pic
469
470 inc dx
471 and al, 7
472is_master_pic:
473 mov cl, al
474 mov bl, 1
475 shl bl, cl
476 in al, dx
477 or al, bl
478 out dx, al
479 pop cx
480 pop ax
481 ret
482
483pcibios_init_irqs:
484 push ds
485 push bp
486 mov ax, 0F000h
487 mov ds, ax
488 mov dx, 04D0h ;; reset ELCR1 + ELCR2
489 mov al, 0
490 out dx, al
491 inc dx
492 out dx, al
493 mov si, pci_routing_table_structure
494 mov bh, [si+8]
495 mov bl, [si+9]
496 mov dl, 0
497 call pcibios_init_sel_reg
498 mov dx, PCI_CFG2
499 in eax, dx
500 cmp eax, [si+12] ;; check irq router
501 jne pci_init_end
502
503 mov dl, [si+34]
504 call pcibios_init_sel_reg
505 push bx ;; save irq router bus + devfunc
506 mov dx, PCI_CFG2
507 mov ax, 8080h
508 out dx, ax ;; reset PIRQ route control
509 add dx, 2
510 out dx, ax
511 mov ax, [si+6]
512 sub ax, 20h
513 shr ax, 4
514 mov cx, ax
515 add si, 20h ;; set pointer to 1st entry
516 mov bp, sp
517 mov ax, pci_irq_list
518 push ax
519 xor ax, ax
520 push ax
521pci_init_irq_loop1:
522 mov bh, [si]
523 mov bl, [si+1]
524pci_init_irq_loop2:
525 mov dl, 0
526 call pcibios_init_sel_reg
527 mov dx, PCI_CFG2
528 in ax, dx
529 cmp ax, 0FFFFh
530 jnz pci_test_int_pin
531
532 test bl, 7
533 jz next_pir_entry
534
535 jmp next_pci_func
536
537pci_test_int_pin:
538 mov dl, 3Ch
539 call pcibios_init_sel_reg
540 mov dx, PCI_CFG2 + 1 ; TODO: was #0x0cfd - is that right?
541 in al, dx
542 and al, 7
543 jz next_pci_func
544
545 dec al ;; determine pirq reg
546 mov dl, 3
547 mul dl
548 add al, 2
549 xor ah, ah
550 mov bx, ax
551 mov al, [si+bx]
552 mov dl, al
553 mov bx, [bp]
554 call pcibios_init_sel_reg
555 mov dx, PCI_CFG2
556 and al, 3
557 add dl, al
558 in al, dx
559 cmp al, 80h
560 jb pirq_found
561
562 mov bx, [bp-2] ;; pci irq list pointer
563 mov al, [bx]
564 out dx, al
565 inc bx
566 mov [bp-2], bx
567 call pcibios_init_set_elcr
568pirq_found:
569 mov bh, [si]
570 mov bl, [si+1]
571 add bl, [bp-3] ;; pci function number
572 mov dl, 3Ch
573 call pcibios_init_sel_reg
574 mov dx, PCI_CFG2
575 out dx, al
576next_pci_func:
577 inc byte ptr[bp-3]
578 inc bl
579 test bl, 7
580 jnz pci_init_irq_loop2
581
582next_pir_entry:
583 add si, 10h
584 mov byte ptr[bp-3], 0
585 loop pci_init_irq_loop1
586
587 mov sp, bp
588 pop bx
589pci_init_end:
590 pop bp
591 pop ds
592 ret
593
594.286
595
596endif ; !BX_ROMBIOS32
597
598endif ; BX_PCIBIOS
599
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette