|
@@ -29,9 +29,9 @@ class AsyncBlockDeviceRequest;
|
|
|
class NVMeQueue : public IRQHandler
|
|
|
, public RefCounted<NVMeQueue> {
|
|
|
public:
|
|
|
- static ErrorOr<NonnullRefPtr<NVMeQueue>> try_create(u16 qid, u8 irq, u32 q_depth, OwnPtr<Memory::Region> cq_dma_region, NonnullRefPtrVector<Memory::PhysicalPage> cq_dma_page, OwnPtr<Memory::Region> sq_dma_region, NonnullRefPtrVector<Memory::PhysicalPage> sq_dma_page, Memory::TypedMapping<DoorbellRegister> db_regs);
|
|
|
+ static ErrorOr<NonnullRefPtr<NVMeQueue>> try_create(u16 qid, u8 irq, u32 q_depth, OwnPtr<Memory::Region> cq_dma_region, NonnullRefPtrVector<Memory::PhysicalPage> cq_dma_page, OwnPtr<Memory::Region> sq_dma_region, NonnullRefPtrVector<Memory::PhysicalPage> sq_dma_page, Memory::TypedMapping<volatile DoorbellRegister> db_regs);
|
|
|
ErrorOr<void> create();
|
|
|
- explicit NVMeQueue(u16 qid, u8 irq, u32 q_depth, OwnPtr<Memory::Region> cq_dma_region, NonnullRefPtrVector<Memory::PhysicalPage> cq_dma_page, OwnPtr<Memory::Region> sq_dma_region, NonnullRefPtrVector<Memory::PhysicalPage> sq_dma_page, Memory::TypedMapping<DoorbellRegister> db_regs);
|
|
|
+ explicit NVMeQueue(u16 qid, u8 irq, u32 q_depth, OwnPtr<Memory::Region> cq_dma_region, NonnullRefPtrVector<Memory::PhysicalPage> cq_dma_page, OwnPtr<Memory::Region> sq_dma_region, NonnullRefPtrVector<Memory::PhysicalPage> sq_dma_page, Memory::TypedMapping<volatile DoorbellRegister> db_regs);
|
|
|
bool is_admin_queue() { return m_admin_queue; };
|
|
|
bool handle_irq(const RegisterState&) override;
|
|
|
void submit_sqe(struct NVMeSubmission&);
|
|
@@ -73,7 +73,7 @@ private:
|
|
|
NonnullRefPtrVector<Memory::PhysicalPage> m_sq_dma_page;
|
|
|
Span<NVMeCompletion> m_cqe_array;
|
|
|
OwnPtr<Memory::Region> m_rw_dma_region;
|
|
|
- Memory::TypedMapping<DoorbellRegister> m_db_regs;
|
|
|
+ Memory::TypedMapping<volatile DoorbellRegister> m_db_regs;
|
|
|
RefPtr<Memory::PhysicalPage> m_rw_dma_page;
|
|
|
Spinlock m_request_lock;
|
|
|
RefPtr<AsyncBlockDeviceRequest> m_current_request;
|