summaryrefslogtreecommitdiffhomepage
path: root/src/kernel/StorageKit/NVME.h
diff options
context:
space:
mode:
authorAmlal El Mahrouss <amlal@nekernel.org>2025-11-23 21:06:27 -0500
committerGitHub <noreply@github.com>2025-11-23 21:06:27 -0500
commit23040fad647634c08697451fc22ee2ca999629c8 (patch)
tree72888f88c7728c82f3f6df1f4f70591de15eab36 /src/kernel/StorageKit/NVME.h
parente5cc7351f0577b54c528fb827a7c7e6306c3e843 (diff)
parent83d870e58457a1d335a1d9b9966a6a1887cc297b (diff)
Merge pull request #81 from nekernel-org/dev
feat! breaking changes on kernel sources.
Diffstat (limited to 'src/kernel/StorageKit/NVME.h')
-rw-r--r--src/kernel/StorageKit/NVME.h32
1 files changed, 32 insertions, 0 deletions
diff --git a/src/kernel/StorageKit/NVME.h b/src/kernel/StorageKit/NVME.h
new file mode 100644
index 00000000..d1c036ab
--- /dev/null
+++ b/src/kernel/StorageKit/NVME.h
@@ -0,0 +1,32 @@
+/* ========================================
+
+ Copyright (C) 2024-2025, Amlal El Mahrouss, licensed under the Apache 2.0 license.
+
+======================================== */
+
+#pragma once
+
+#include <KernelKit/DeviceMgr.h>
+#include <KernelKit/DriveMgr.h>
+
+namespace Kernel {
+class NVMEDeviceInterface final NE_DEVICE<IMountpoint*> {
+ public:
+ explicit NVMEDeviceInterface(Void (*out)(DeviceInterface*, IMountpoint* out_packet),
+ Void (*in)(DeviceInterface*, IMountpoint* in_packet),
+ Void (*cleanup)(Void));
+
+ ~NVMEDeviceInterface() override;
+
+ public:
+ NE_COPY_DEFAULT(NVMEDeviceInterface)
+
+ const Char* Name() const override;
+
+ public:
+ OwnPtr<IMountpoint*> operator()(UInt32 dma_low, UInt32 dma_high, SizeT dma_sz);
+
+ private:
+ Void (*fCleanup)(Void) = {nullptr};
+};
+} // namespace Kernel