2012-07-22 19:47:29 +00:00
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
;; ;;
|
|
|
|
;; Copyright (C) KolibriOS team 2004-2012. All rights reserved. ;;
|
|
|
|
;; Distributed under terms of the GNU General Public License ;;
|
|
|
|
;; ;;
|
|
|
|
;; GNU GENERAL PUBLIC LICENSE ;;
|
|
|
|
;; Version 2, June 1991 ;;
|
|
|
|
;; ;;
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
|
|
|
|
|
|
|
|
; PCI Bus defines
|
|
|
|
|
|
|
|
PCI_HEADER_TYPE = 0x0e ; 8 bit
|
|
|
|
PCI_BASE_ADDRESS_0 = 0x10 ; 32 bit
|
2012-08-25 17:56:09 +00:00
|
|
|
PCI_BASE_ADDRESS_1 = 0x14 ; 32 bits
|
|
|
|
PCI_BASE_ADDRESS_2 = 0x18 ; 32 bits
|
|
|
|
PCI_BASE_ADDRESS_3 = 0x1c ; 32 bits
|
|
|
|
PCI_BASE_ADDRESS_4 = 0x20 ; 32 bits
|
2012-07-22 19:47:29 +00:00
|
|
|
PCI_BASE_ADDRESS_5 = 0x24 ; 32 bits
|
|
|
|
PCI_BASE_ADDRESS_SPACE_IO = 0x01
|
|
|
|
PCI_BASE_ADDRESS_IO_MASK = 0xFFFFFFFC
|
2012-08-25 17:56:09 +00:00
|
|
|
PCI_BASE_ADDRESS_MEM_MASK = 0xFFFFFFF0
|
2012-07-22 19:47:29 +00:00
|
|
|
|
|
|
|
; PCI programming
|
|
|
|
|
2012-08-25 17:56:09 +00:00
|
|
|
PCI_VENDOR_ID = 0x00 ; 16 bit
|
|
|
|
PCI_DEVICE_ID = 0x02 ; 16 bits
|
2012-07-22 19:47:29 +00:00
|
|
|
PCI_REG_COMMAND = 0x4 ; command register
|
|
|
|
PCI_REG_STATUS = 0x6 ; status register
|
2012-08-25 17:56:09 +00:00
|
|
|
PCI_REVISION_ID = 0x08 ; 8 bits
|
2012-07-22 19:47:29 +00:00
|
|
|
PCI_REG_LATENCY = 0xd ; latency timer register
|
|
|
|
PCI_REG_CAP_PTR = 0x34 ; capabilities pointer
|
2012-08-25 17:56:09 +00:00
|
|
|
PCI_REG_IRQ = 0x3c
|
2012-07-22 19:47:29 +00:00
|
|
|
PCI_REG_CAPABILITY_ID = 0x0 ; capapility ID in pm register block
|
|
|
|
PCI_REG_PM_STATUS = 0x4 ; power management status register
|
|
|
|
PCI_REG_PM_CTRL = 0x4 ; power management control register
|
|
|
|
PCI_BIT_PIO = 1 ; bit0: io space control
|
|
|
|
PCI_BIT_MMIO = 2 ; bit1: memory space control
|
|
|
|
PCI_BIT_MASTER = 4 ; bit2: device acts as a PCI master
|
|
|
|
|
|
|
|
|
2013-01-31 13:10:10 +00:00
|
|
|
macro PCI_find_io {
|
2012-07-22 19:47:29 +00:00
|
|
|
|
|
|
|
local .check, .inc, .got
|
|
|
|
|
|
|
|
xor eax, eax
|
|
|
|
mov esi, PCI_BASE_ADDRESS_0
|
|
|
|
.check:
|
2013-01-31 13:10:10 +00:00
|
|
|
stdcall PciRead32, [device.pci_bus], [device.pci_dev], esi
|
2012-07-22 19:47:29 +00:00
|
|
|
|
|
|
|
test eax, PCI_BASE_ADDRESS_IO_MASK
|
|
|
|
jz .inc
|
|
|
|
|
|
|
|
test eax, PCI_BASE_ADDRESS_SPACE_IO
|
|
|
|
jz .inc
|
|
|
|
|
|
|
|
and eax, PCI_BASE_ADDRESS_IO_MASK
|
|
|
|
jmp .got
|
|
|
|
|
|
|
|
.inc:
|
|
|
|
add esi, 4
|
|
|
|
cmp esi, PCI_BASE_ADDRESS_5
|
2012-08-15 10:50:36 +00:00
|
|
|
jbe .check
|
|
|
|
xor eax, eax
|
2012-07-22 19:47:29 +00:00
|
|
|
|
|
|
|
.got:
|
2013-01-31 13:10:10 +00:00
|
|
|
mov [device.io_addr], eax
|
2012-07-22 19:47:29 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-01-31 13:10:10 +00:00
|
|
|
macro PCI_find_mmio32 {
|
2012-07-22 19:47:29 +00:00
|
|
|
|
2012-08-15 10:50:36 +00:00
|
|
|
local .check, .inc, .got
|
2012-07-22 19:47:29 +00:00
|
|
|
|
|
|
|
mov esi, PCI_BASE_ADDRESS_0
|
|
|
|
.check:
|
2013-01-31 13:10:10 +00:00
|
|
|
stdcall PciRead32, [device.pci_bus], [device.pci_dev], esi
|
2012-07-22 19:47:29 +00:00
|
|
|
|
2012-08-15 10:50:36 +00:00
|
|
|
test eax, PCI_BASE_ADDRESS_SPACE_IO ; mmio address?
|
|
|
|
jnz .inc
|
2012-07-22 19:47:29 +00:00
|
|
|
|
2012-08-15 10:50:36 +00:00
|
|
|
test eax, 100b ; 64 bit?
|
|
|
|
jnz .inc
|
|
|
|
and eax, not 1111b
|
|
|
|
jmp .got
|
|
|
|
|
|
|
|
.inc:
|
2012-07-22 19:47:29 +00:00
|
|
|
add esi, 4
|
|
|
|
cmp esi, PCI_BASE_ADDRESS_5
|
2012-08-15 10:50:36 +00:00
|
|
|
jbe .check
|
2012-07-22 19:47:29 +00:00
|
|
|
xor eax, eax
|
2012-08-15 10:50:36 +00:00
|
|
|
|
2012-07-22 19:47:29 +00:00
|
|
|
.got:
|
2013-01-31 13:10:10 +00:00
|
|
|
mov [device.mmio_addr], eax
|
2012-07-22 19:47:29 +00:00
|
|
|
}
|
|
|
|
|
2013-01-31 13:10:10 +00:00
|
|
|
macro PCI_find_irq {
|
2012-07-22 19:47:29 +00:00
|
|
|
|
2013-01-31 13:10:10 +00:00
|
|
|
stdcall PciRead8, [device.pci_bus], [device.pci_dev], PCI_REG_IRQ
|
|
|
|
mov [device.irq_line], al
|
2012-07-22 19:47:29 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2013-01-31 13:10:10 +00:00
|
|
|
macro PCI_find_rev {
|
2012-07-22 19:47:29 +00:00
|
|
|
|
2013-01-31 13:10:10 +00:00
|
|
|
stdcall PciRead8, [device.pci_bus], [device.pci_dev], PCI_REVISION_ID
|
|
|
|
mov [device.revision], al
|
2012-07-22 19:47:29 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2013-01-31 13:10:10 +00:00
|
|
|
macro PCI_make_bus_master bus, dev {
|
2012-07-22 19:47:29 +00:00
|
|
|
|
2013-01-31 13:10:10 +00:00
|
|
|
stdcall PciRead32, [device.pci_bus], [device.pci_dev], PCI_REG_COMMAND
|
2012-08-07 20:26:26 +00:00
|
|
|
or al, PCI_BIT_MASTER
|
2013-01-31 13:10:10 +00:00
|
|
|
stdcall PciWrite32, [device.pci_bus], [device.pci_dev], PCI_REG_COMMAND, eax
|
2012-07-22 19:47:29 +00:00
|
|
|
|
2012-08-07 20:26:26 +00:00
|
|
|
}
|
|
|
|
|
2013-01-31 13:10:10 +00:00
|
|
|
macro PCI_adjust_latency min {
|
2012-07-22 19:47:29 +00:00
|
|
|
|
2013-01-31 13:10:10 +00:00
|
|
|
local .not
|
|
|
|
|
|
|
|
stdcall PciRead8, [device.pci_bus], [device.pci_dev], PCI_REG_LATENCY
|
2012-08-07 20:26:26 +00:00
|
|
|
cmp al, min
|
2013-01-31 13:10:10 +00:00
|
|
|
ja .not
|
2012-08-07 20:26:26 +00:00
|
|
|
mov al, min
|
2013-01-31 13:10:10 +00:00
|
|
|
stdcall PciWrite8, [device.pci_bus], [device.pci_dev], PCI_REG_LATENCY, eax
|
|
|
|
.not:
|
2012-08-07 20:26:26 +00:00
|
|
|
|
|
|
|
}
|