fat_ent.h 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. #pragma once
  2. #include "fat32.h"
  3. #include <filesystem/VFS/VFS.h>
  4. #include <stdbool.h>
  5. /**
  6. * @brief 请求分配指定数量的簇
  7. *
  8. * @param inode 要分配簇的inode
  9. * @param clusters 返回的被分配的簇的簇号结构体
  10. * @param num_clusters 要分配的簇的数量
  11. * @return int 错误码
  12. */
  13. int fat32_alloc_clusters(struct vfs_index_node_t *inode, uint32_t *clusters, int32_t num_clusters);
  14. /**
  15. * @brief 释放从属于inode的,从cluster开始的所有簇
  16. *
  17. * @param inode 指定的文件的inode
  18. * @param cluster 指定簇
  19. * @return int 错误码
  20. */
  21. int fat32_free_clusters(struct vfs_index_node_t *inode, int32_t cluster);
  22. /**
  23. * @brief 读取指定簇的FAT表项
  24. *
  25. * @param blk 块设备结构体
  26. * @param fsbi fat32超级块私有信息结构体
  27. * @param cluster 指定簇
  28. * @return uint32_t 下一个簇的簇号
  29. */
  30. uint32_t fat32_read_FAT_entry(struct block_device * blk, fat32_sb_info_t *fsbi, uint32_t cluster);
  31. /**
  32. * @brief 写入指定簇的FAT表项
  33. *
  34. * @param blk 块设备结构体
  35. * @param fsbi fat32超级块私有信息结构体
  36. * @param cluster 指定簇
  37. * @param value 要写入该fat表项的值
  38. * @return uint32_t errcode
  39. */
  40. uint32_t fat32_write_FAT_entry(struct block_device * blk, fat32_sb_info_t *fsbi, uint32_t cluster, uint32_t value);
  41. /**
  42. * @brief 在父亲inode的目录项簇中,寻找连续num个空的目录项
  43. *
  44. * @param parent_inode 父inode
  45. * @param num 请求的目录项数量
  46. * @param mode 操作模式
  47. * @param res_sector 返回信息:缓冲区对应的扇区号
  48. * @param res_cluster 返回信息:缓冲区对应的簇号
  49. * @param res_data_buf_base 返回信息:缓冲区的内存基地址(记得要释放缓冲区内存!!!!)
  50. * @return struct fat32_Directory_t* 符合要求的entry的指针(指向地址高处的空目录项,也就是说,有连续num个≤这个指针的空目录项)
  51. */
  52. struct fat32_Directory_t *fat32_find_empty_dentry(struct vfs_index_node_t *parent_inode, uint32_t num, uint32_t mode, uint32_t *res_sector, uint64_t *res_cluster, uint64_t *res_data_buf_base);
  53. /**
  54. * @brief 检查文件名是否合法
  55. *
  56. * @param name 文件名
  57. * @param namelen 文件名长度
  58. * @param reserved 保留字段
  59. * @return int 合法:0, 其他:错误码
  60. */
  61. int fat32_check_name_available(const char *name, int namelen, int8_t reserved);
  62. /**
  63. * @brief 检查字符在短目录项中是否合法
  64. *
  65. * @param c 给定字符
  66. * @param index 字符在文件名中处于第几位
  67. * @return true 合法
  68. * @return false 不合法
  69. */
  70. bool fat32_check_char_available_in_short_name(const char c, int index);
  71. /**
  72. * @brief 填充短目录项的函数
  73. *
  74. * @param dEntry 目标dentry
  75. * @param target 目标dentry对应的短目录项
  76. * @param cluster 短目录项对应的文件/文件夹起始簇
  77. */
  78. void fat32_fill_shortname(struct vfs_dir_entry_t *dEntry, struct fat32_Directory_t *target, uint32_t cluster);
  79. /**
  80. * @brief 填充长目录项的函数
  81. *
  82. * @param dEntry 目标dentry
  83. * @param target 起始长目录项
  84. * @param checksum 短目录项的校验和
  85. * @param cnt_longname 总的长目录项的个数
  86. */
  87. void fat32_fill_longname(struct vfs_dir_entry_t *dEntry, struct fat32_LongDirectory_t *target, uint8_t checksum, uint32_t cnt_longname);