forked from KolibriOS/kolibrios
Ivan Baravy
707e7037f0
* Detect last PCI bus via PCI Root Bridge IO protocol (uefi64kos only). * fastcall macro by Tomasz is much cleaner than eficall from osdev board. git-svn-id: svn://kolibrios.org@9227 a494cfbc-eb01-0410-851d-a64ba20cac60
53 lines
1.9 KiB
PHP
53 lines
1.9 KiB
PHP
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
;; ;;
|
|
;; Copyright (C) KolibriOS team 2004-2015. All rights reserved. ;;
|
|
;; Distributed under terms of the GNU General Public License ;;
|
|
;; ;;
|
|
;; PCI16.INC ;;
|
|
;; ;;
|
|
;; 16 bit PCI driver code ;;
|
|
;; ;;
|
|
;; Version 0.2 December 21st, 2002 ;;
|
|
;; ;;
|
|
;; Author: Victor Prodan, victorprodan@yahoo.com ;;
|
|
;; ;;
|
|
;; See file COPYING for details ;;
|
|
;; ;;
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
$Revision$
|
|
|
|
|
|
init_pci_16:
|
|
|
|
pushad
|
|
|
|
xor ax, ax
|
|
mov es, ax
|
|
mov [es:BOOT_LO.pci_data.access_mechanism], 1;default mechanism:1
|
|
mov ax, 0xb101
|
|
int 0x1a
|
|
or ah, ah
|
|
jnz pci16skip
|
|
|
|
mov [es:BOOT_LO.pci_data.last_bus], cl
|
|
mov [es:BOOT_LO.pci_data.version], bx
|
|
mov [es:BOOT_LO.pci_data.pm_entry], edi
|
|
|
|
; we have a PCI BIOS, so check which configuration mechanism(s)
|
|
; it supports
|
|
; AL = PCI hardware characteristics (bit0 => mechanism1, bit1 => mechanism2)
|
|
test al, 1
|
|
jnz pci16skip
|
|
test al, 2
|
|
jz pci16skip
|
|
; if (al&3)==2 => mechanism 2
|
|
mov [es:BOOT_LO.pci_data.access_mechanism], 2
|
|
|
|
pci16skip:
|
|
|
|
mov ax, 0x1000
|
|
mov es, ax
|
|
|
|
popad
|