mirror of
https://git.missingno.dev/kolibrios-nvme-driver/
synced 2025-01-18 11:26:05 +01:00
tidy up queue allocation
This commit is contained in:
parent
e2c2254a5b
commit
8557d0a450
@ -664,11 +664,17 @@ proc nvme_init stdcall, pci:dword
|
|||||||
end if
|
end if
|
||||||
|
|
||||||
; check maximum queue entries supported
|
; check maximum queue entries supported
|
||||||
mov ax, word [edi + NVME_MMIO.CAP]
|
mov eax, dword [edi + NVME_MMIO.CAP]
|
||||||
cmp ax, SQ_ENTRIES
|
cmp ax, SQ_ENTRIES
|
||||||
jb .exit_fail
|
jb .exit_fail
|
||||||
DEBUGF DBG_INFO, "nvme%u: OK... maximum queue entries is %u\n", [esi + pcidev.num], ax
|
DEBUGF DBG_INFO, "nvme%u: OK... maximum queue entries is %u\n", [esi + pcidev.num], ax
|
||||||
|
|
||||||
|
if __DEBUG__
|
||||||
|
test eax, CAP_CQR
|
||||||
|
setnz al
|
||||||
|
DEBUGF DBG_INFO, "nvme%u: Contiguous queues required: %u\n", [esi + pcidev.num], al
|
||||||
|
end if
|
||||||
|
|
||||||
; For some reason, bit 7 (No I/O command set supported) is also set to 1 despite bit 0 (NVM command set)
|
; For some reason, bit 7 (No I/O command set supported) is also set to 1 despite bit 0 (NVM command set)
|
||||||
; being set to 1.. so I am not sure if bit 7 should be checked at all.. investigate later.
|
; being set to 1.. so I am not sure if bit 7 should be checked at all.. investigate later.
|
||||||
mov eax, dword [edi + NVME_MMIO.CAP + 4]
|
mov eax, dword [edi + NVME_MMIO.CAP + 4]
|
||||||
@ -721,34 +727,25 @@ proc nvme_init stdcall, pci:dword
|
|||||||
stdcall memsetdz, eax, sizeof.NVM_QUEUE_ENTRY * (LAST_QUEUE_ID + 1) / 4
|
stdcall memsetdz, eax, sizeof.NVM_QUEUE_ENTRY * (LAST_QUEUE_ID + 1) / 4
|
||||||
|
|
||||||
; Allocate submission/completion queue pointers
|
; Allocate submission/completion queue pointers
|
||||||
; TODO: Make these queues physically contiguous
|
xor ebx, ebx
|
||||||
xor ecx, ecx
|
|
||||||
|
|
||||||
.init_queues:
|
.init_queues:
|
||||||
push ecx
|
invoke KernelAlloc, PAGE_SIZE * 2
|
||||||
invoke CreateRingBuffer, 0x1000, PG_SW
|
|
||||||
pop ecx
|
|
||||||
test eax, eax
|
test eax, eax
|
||||||
jz .exit_fail
|
jz .exit_fail
|
||||||
mov dword [edi + ecx + NVM_QUEUE_ENTRY.sq_ptr], eax
|
mov dword [edi + ebx + NVM_QUEUE_ENTRY.sq_ptr], eax
|
||||||
push ecx
|
add eax, PAGE_SIZE
|
||||||
stdcall memsetdz, eax, sizeof.SQ_ENTRY * SQ_ENTRIES / 4
|
mov dword [edi + ebx + NVM_QUEUE_ENTRY.cq_ptr], eax
|
||||||
invoke CreateRingBuffer, 0x1000, PG_SW
|
sub eax, PAGE_SIZE
|
||||||
pop ecx
|
stdcall memsetdz, eax, PAGE_SIZE * 2 / 4
|
||||||
test eax, eax
|
|
||||||
jz .exit_fail
|
|
||||||
mov dword [edi + ecx + NVM_QUEUE_ENTRY.cq_ptr], eax
|
|
||||||
push ecx
|
|
||||||
stdcall memsetdz, eax, sizeof.CQ_ENTRY * CQ_ENTRIES / 4
|
|
||||||
|
|
||||||
; Initialize command entries
|
; Initialize command entries
|
||||||
invoke KernelAlloc, sizeof.NVMQCMD * CQ_ENTRIES
|
invoke KernelAlloc, sizeof.NVMQCMD * CQ_ENTRIES
|
||||||
pop ecx
|
|
||||||
test eax, eax
|
test eax, eax
|
||||||
jz .exit_fail
|
jz .exit_fail
|
||||||
mov dword [edi + ecx + NVM_QUEUE_ENTRY.cmd_ptr], eax
|
mov dword [edi + ebx + NVM_QUEUE_ENTRY.cmd_ptr], eax
|
||||||
mov esi, eax
|
mov esi, eax
|
||||||
push ecx
|
push ebx
|
||||||
xor ebx, ebx
|
xor ebx, ebx
|
||||||
|
|
||||||
.init_cmd_entries:
|
.init_cmd_entries:
|
||||||
@ -765,9 +762,9 @@ proc nvme_init stdcall, pci:dword
|
|||||||
cmp ebx, CQ_ENTRIES
|
cmp ebx, CQ_ENTRIES
|
||||||
jne .init_cmd_entries
|
jne .init_cmd_entries
|
||||||
|
|
||||||
pop ecx
|
pop ebx
|
||||||
add ecx, sizeof.NVM_QUEUE_ENTRY
|
add ebx, sizeof.NVM_QUEUE_ENTRY
|
||||||
cmp ecx, (LAST_QUEUE_ID + 1) * sizeof.NVM_QUEUE_ENTRY
|
cmp ebx, (LAST_QUEUE_ID + 1) * sizeof.NVM_QUEUE_ENTRY
|
||||||
jne .init_queues
|
jne .init_queues
|
||||||
|
|
||||||
; Configure Admin Submission/Completion Queue Base Address
|
; Configure Admin Submission/Completion Queue Base Address
|
||||||
@ -1126,7 +1123,7 @@ proc sqytdbl_write stdcall, pci:dword, y:word, cmd:dword
|
|||||||
shl edx, cl
|
shl edx, cl
|
||||||
imul edx, ebx
|
imul edx, ebx
|
||||||
add edx, 0x1000
|
add edx, 0x1000
|
||||||
DEBUGF DBG_INFO, "nvme%u: Writing to SQ%u doorbell register 0x%x: %u\n", [esi + pcidev.num], [y], dx, ax
|
;DEBUGF DBG_INFO, "nvme%u: Writing to SQ%u doorbell register 0x%x: %u\n", [esi + pcidev.num], [y], dx, ax
|
||||||
mov word [edi + NVM_QUEUE_ENTRY.tail], ax
|
mov word [edi + NVM_QUEUE_ENTRY.tail], ax
|
||||||
mov esi, dword [esi + pcidev.io_addr]
|
mov esi, dword [esi + pcidev.io_addr]
|
||||||
mov word [esi + edx], ax
|
mov word [esi + edx], ax
|
||||||
|
Loading…
Reference in New Issue
Block a user