fix: memory leakage in file descriptor allocation
[lunaix-os.git] / lunaix-os / includes / lunaix / block.h
index df481d82c32bb245986ee80bba0fe4081b8c5c99..4b0c824d1ca06f77e3da46c9a53628da3b15ea09 100644 (file)
@@ -2,52 +2,58 @@
 #define __LUNAIX_BLOCK_H
 
 #include <hal/ahci/hba.h>
+#include <lunaix/blkio.h>
 #include <lunaix/device.h>
 
 #define LPT_SIG 0x414e554c
 #define PARTITION_NAME_SIZE 48
 #define DEV_ID_SIZE 32
 
-typedef uint64_t partition_t;
-typedef uint32_t bdev_t;
-
 struct block_dev
 {
     char bdev_id[DEV_ID_SIZE];
     char name[PARTITION_NAME_SIZE];
-    struct hba_device* hd_dev;
+    struct blkio_context* blkio;
     struct device* dev;
-    uint64_t base_lba;
-    uint64_t end_lba;
+    void* driver;
+    u64_t end_lba;
+    u32_t blk_size;
 };
 
 struct lpt_entry
 {
     char part_name[PARTITION_NAME_SIZE];
-    uint64_t base_lba;
-    uint64_t end_lba;
+    u64_t base_lba;
+    u64_t end_lba;
 } __attribute__((packed));
 
 // Lunaix Partition Table
 struct lpt_header
 {
-    uint32_t signature;
-    uint32_t crc;
-    uint32_t pt_start_lba;
-    uint32_t pt_end_lba;
-    uint32_t table_len;
+    u32_t signature;
+    u32_t crc;
+    u32_t pt_start_lba;
+    u32_t pt_end_lba;
+    u32_t table_len;
 } __attribute__((packed));
 
+typedef u64_t partition_t;
+typedef uint32_t bdev_t;
+typedef void (*devfs_exporter)(struct block_dev* bdev, void* fsnode);
+
 void
 block_init();
 
+struct block_dev*
+block_alloc_dev(const char* blk_id, void* driver, req_handler ioreq_handler);
+
 int
-block_mount_disk(struct hba_device* hd_dev);
+block_mount(struct block_dev* bdev, devfs_exporter export);
 
 void
 blk_mapping_init();
 
 void
-blk_set_blkmapping(struct block_dev* bdev);
+blk_set_blkmapping(struct block_dev* bdev, void* fsnode);
 
 #endif /* __LUNAIX_BLOCK_H */