VFS.h 5.8 KB

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