VFS.h 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. /**
  2. * @file VFS.h
  3. * @author fslongjin ([email protected])
  4. * @brief 虚拟文件系统
  5. * @version 0.1
  6. * @date 2022-04-20
  7. *
  8. * @copyright Copyright (c) 2022
  9. *
  10. */
  11. #pragma once
  12. #include <common/glib.h>
  13. #include <common/fcntl.h>
  14. struct vfs_superblock_t *vfs_root_sb = NULL;
  15. #define VFS_DPT_MBR 0 // MBR分区表
  16. #define VFS_DPT_GPT 1 // GPT分区表
  17. #define VFS_SUCCESS 0
  18. #define VFS_E_FS_EXISTED 1 // 错误:文件系统已存在
  19. #define VFS_E_FS_NOT_EXIST 2 // 错误:文件系统不存在
  20. /**
  21. * @brief 目录项的属性
  22. *
  23. */
  24. #define VFS_ATTR_FILE (1UL << 0)
  25. #define VFS_ATTR_DIR (1UL << 1)
  26. #define VFS_ATTR_DEVICE (1UL << 2)
  27. struct vfs_super_block_operations_t;
  28. struct vfs_inode_operations_t;
  29. struct vfs_index_node_t;
  30. struct vfs_dir_entry_operations_t;
  31. struct vfs_dir_entry_t
  32. {
  33. char *name;
  34. int name_length;
  35. struct List child_node_list;
  36. struct List subdirs_list;
  37. struct vfs_index_node_t *dir_inode;
  38. struct vfs_dir_entry_t *parent;
  39. struct vfs_dir_entry_operations_t *dir_ops;
  40. };
  41. struct vfs_superblock_t
  42. {
  43. struct vfs_dir_entry_t *root;
  44. struct vfs_super_block_operations_t *sb_ops;
  45. void *private_sb_info;
  46. };
  47. /**
  48. * @brief inode结构体
  49. *
  50. */
  51. struct vfs_index_node_t
  52. {
  53. uint64_t file_size; // 文件大小
  54. uint64_t blocks; // 占用的扇区数
  55. uint64_t attribute;
  56. struct vfs_superblock_t *sb;
  57. struct vfs_file_operations_t *file_ops;
  58. struct vfs_inode_operations_t *inode_ops;
  59. void *private_inode_info;
  60. };
  61. /**
  62. * @brief 文件描述符
  63. *
  64. */
  65. struct vfs_file_t
  66. {
  67. long position;
  68. uint64_t mode;
  69. struct vfs_dir_entry_t *dEntry;
  70. struct vfs_file_operations_t *file_ops;
  71. void *private_data;
  72. };
  73. struct vfs_filesystem_type_t
  74. {
  75. char *name;
  76. int fs_flags;
  77. struct vfs_superblock_t *(*read_superblock)(void *DPTE, uint8_t DPT_type, void *buf, int8_t ahci_ctrl_num, int8_t ahci_port_num, int8_t part_num); // 解析文件系统引导扇区的函数,为文件系统创建超级块结构。其中DPTE为磁盘分区表entry(MBR、GPT不同)
  78. struct vfs_filesystem_type_t *next;
  79. };
  80. struct vfs_super_block_operations_t
  81. {
  82. void (*write_superblock)(struct vfs_superblock_t *sb); // 将超级块信息写入磁盘
  83. void (*put_superblock)(struct vfs_superblock_t *sb);
  84. void (*write_inode)(struct vfs_index_node_t *inode); // 将inode信息写入磁盘
  85. };
  86. /**
  87. * @brief 对vfs的inode的操作抽象
  88. *
  89. */
  90. struct vfs_inode_operations_t
  91. {
  92. /**
  93. * @brief 创建新的文件
  94. * @param parent_inode 父目录的inode结构体
  95. * @param dest_dEntry 新文件的dentry
  96. * @param mode 创建模式
  97. */
  98. long (*create)(struct vfs_index_node_t *parent_inode, struct vfs_dir_entry_t *dest_dEntry, int mode);
  99. /**
  100. * @brief 在文件系统中查找指定的目录项
  101. * @param parent_inode 父目录项(在这个目录下查找)
  102. * @param dest_dEntry 构造的目标目录项的结构体(传入名称,然后更多的详细信息将在本函数中完成填写)
  103. *
  104. */
  105. struct vfs_dir_entry_t *(*lookup)(struct vfs_index_node_t *parent_inode, struct vfs_dir_entry_t *dest_dEntry);
  106. /**
  107. * @brief 创建文件夹
  108. * @param inode 父目录的inode
  109. * @param dEntry 新的文件夹的dentry
  110. * @param mode 创建文件夹的mode
  111. */
  112. long (*mkdir)(struct vfs_index_node_t *inode, struct vfs_dir_entry_t *dEntry, int mode);
  113. long (*rmdir)(struct vfs_index_node_t *inode, struct vfs_dir_entry_t *dEntry);
  114. long (*rename)(struct vfs_index_node_t *old_inode, struct vfs_dir_entry_t *old_dEntry, struct vfs_index_node_t *new_inode, struct vfs_dir_entry_t *new_dEntry);
  115. long (*getAttr)(struct vfs_dir_entry_t *dEntry, uint64_t *attr);
  116. long (*setAttr)(struct vfs_dir_entry_t *dEntry, uint64_t *attr);
  117. };
  118. struct vfs_dir_entry_operations_t
  119. {
  120. long (*compare)(struct vfs_dir_entry_t *parent_dEntry, char *source_filename, char *dest_filename);
  121. long (*hash)(struct vfs_dir_entry_t *dEntry, char *filename);
  122. long (*release)(struct vfs_dir_entry_t *dEntry);
  123. long (*iput)(struct vfs_dir_entry_t *dEntry, struct vfs_index_node_t *inode);
  124. };
  125. /**
  126. * @brief 填充dirent的函数指针的类型定义
  127. *
  128. */
  129. typedef int (*vfs_filldir_t)(void *buf, ino_t d_ino, char *name, int namelen, unsigned char type, off_t offset);
  130. struct vfs_file_operations_t
  131. {
  132. long (*open)(struct vfs_index_node_t *inode, struct vfs_file_t *file_ptr);
  133. long (*close)(struct vfs_index_node_t *inode, struct vfs_file_t *file_ptr);
  134. long (*read)(struct vfs_file_t *file_ptr, char *buf, int64_t count, long *position);
  135. long (*write)(struct vfs_file_t *file_ptr, char *buf, int64_t count, long *position);
  136. long (*lseek)(struct vfs_file_t *file_ptr, long offset, long origin);
  137. long (*ioctl)(struct vfs_index_node_t *inode, struct vfs_file_t *file_ptr, uint64_t cmd, uint64_t arg);
  138. long (*readdir)(struct vfs_file_t *file_ptr, void *dirent, vfs_filldir_t filler); // 读取文件夹
  139. };
  140. /**
  141. * @brief 在VFS中注册文件系统
  142. *
  143. * @param fs 文件系统类型结构体
  144. * @return uint64_t
  145. */
  146. uint64_t vfs_register_filesystem(struct vfs_filesystem_type_t *fs);
  147. uint64_t vfs_unregister_filesystem(struct vfs_filesystem_type_t *fs);
  148. /**
  149. * @brief 挂载文件系统
  150. *
  151. * @param name 文件系统名
  152. * @param DPTE 分区表entry
  153. * @param DPT_type 分区表类型
  154. * @param buf 文件系统的引导扇区
  155. * @return struct vfs_superblock_t*
  156. */
  157. struct vfs_superblock_t *vfs_mount_fs(char *name, void *DPTE, uint8_t DPT_type, void *buf, int8_t ahci_ctrl_num, int8_t ahci_port_num, int8_t part_num);
  158. /**
  159. * @brief 按照路径查找文件
  160. *
  161. * @param path 路径
  162. * @param flags 1:返回父目录项, 0:返回结果目录项
  163. * @return struct vfs_dir_entry_t* 目录项
  164. */
  165. struct vfs_dir_entry_t *vfs_path_walk(const char *path, uint64_t flags);
  166. /**
  167. * @brief 填充dentry
  168. *
  169. */
  170. int vfs_fill_dentry(void *buf, ino_t d_ino, char *name, int namelen, unsigned char type, off_t offset);