mirror of
https://git.missingno.dev/kolibrios-nvme-driver/
synced 2025-01-18 11:26:05 +01:00
disable MSI interrupts if present
This commit is contained in:
parent
3d78f22409
commit
bee583765f
@ -882,8 +882,46 @@ proc nvme_init stdcall, pci:dword
|
||||
and eax, not (1 shl 10)
|
||||
invoke PciWrite16, dword [esi + pcidev.bus], dword [esi + pcidev.devfn], PCI_header00.command, eax
|
||||
|
||||
mov edi, dword [esi + pcidev.io_addr]
|
||||
; Check if the device has a pointer to the capabilities list (status register bit 4 set to 1)
|
||||
; though this check is probably unnecessary since all PCIe devices should have this bit set to 1
|
||||
invoke PciRead16, dword [esi + pcidev.bus], dword [esi + pcidev.devfn], PCI_header00.status
|
||||
test ax, (1 shl 4)
|
||||
jz .exit_fail
|
||||
|
||||
invoke PciRead8, dword [esi + pcidev.bus], dword [esi + pcidev.devfn], PCI_header00.cap_ptr
|
||||
and eax, 0xfc ; bottom two bits are reserved, so mask them before we access the configuration space
|
||||
mov edi, eax
|
||||
DEBUGF DBG_INFO, "nvme%u: Checking capabilities: %x\n", [esi + pcidev.num], edi
|
||||
|
||||
; We need to check if there are any MSI/MSI-X capabilities, and if so, make sure they're disabled since
|
||||
; we're using old fashioned pin-based interrupts (for now)
|
||||
.read_cap:
|
||||
invoke PciRead32, dword [esi + pcidev.bus], dword [esi + pcidev.devfn], edi
|
||||
add edi, 2
|
||||
cmp al, MSICAP_CID
|
||||
je .got_msi_cap
|
||||
cmp al, MSIXCAP_CID
|
||||
je .got_msix_cap
|
||||
movzx edi, ah
|
||||
test edi, edi
|
||||
jnz .read_cap
|
||||
jmp .end_cap_parse
|
||||
|
||||
.got_msi_cap:
|
||||
DEBUGF DBG_INFO, "nvme%u: Found MSI capability\n", [esi + pcidev.num]
|
||||
invoke PciRead32, dword [esi + pcidev.bus], dword [esi + pcidev.devfn], edi
|
||||
and eax, not MSICAP_MSIE
|
||||
invoke PciWrite32, dword [esi + pcidev.bus], dword [esi + pcidev.devfn], edi
|
||||
jmp .end_cap_parse
|
||||
|
||||
.got_msix_cap:
|
||||
DEBUGF DBG_INFO, "nvme%u: Found MSI-X capability\n", [esi + pcidev.num]
|
||||
invoke PciRead32, dword [esi + pcidev.bus], dword [esi + pcidev.devfn], edi
|
||||
and eax, not MSIXCAP_MXE
|
||||
invoke PciWrite32, dword [esi + pcidev.bus], dword [esi + pcidev.devfn], edi
|
||||
|
||||
.end_cap_parse:
|
||||
mov edi, dword [esi + pcidev.io_addr]
|
||||
if 0
|
||||
mov eax, dword [edi + NVME_MMIO.CAP]
|
||||
DEBUGF DBG_INFO, "(NVMe) CAP (0-31): 0x%x\n", eax
|
||||
|
@ -26,6 +26,11 @@ CQ_ENTRIES = NVM_ACQS ; I/O and Admin Completion Queue Size
|
||||
PAGE_SIZE = 4096 shl NVM_MPS
|
||||
SUPPORTED_LBADS = 9 ; KolibriOS only supports LBADS of 512, later on we may remove this restriction
|
||||
|
||||
MSIXCAP_CID = 0x11
|
||||
MSIXCAP_MXE = 1 shl 15 ; MSI-X Enable bit
|
||||
MSICAP_CID = 0x05
|
||||
MSICAP_MSIE = 1 ; MSI Enable bit
|
||||
|
||||
ADMIN_QUEUE = 0 ; Admin Queue ID
|
||||
|
||||
IEN_ON = 2
|
||||
|
Loading…
Reference in New Issue
Block a user