fat32.h 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. /**
  2. * @file fat32.h
  3. * @author fslongjin ([email protected])
  4. * @brief fat32文件系统
  5. * @version 0.1
  6. * @date 2022-04-19
  7. *
  8. * @copyright Copyright (c) 2022
  9. *
  10. */
  11. #pragma once
  12. #include <filesystem/MBR.h>
  13. #define FAT32_MAX_PARTITION_NUM 128 // 系统支持的最大的fat32分区数量
  14. /**
  15. * @brief fat32文件系统引导扇区结构体
  16. *
  17. */
  18. struct fat32_BootSector_t
  19. {
  20. uint8_t BS_jmpBoot[3]; // 跳转指令
  21. uint8_t BS_OEMName[8]; // 生产厂商名
  22. uint16_t BPB_BytesPerSec; // 每扇区字节数
  23. uint8_t BPB_SecPerClus; // 每簇扇区数
  24. uint16_t BPB_RsvdSecCnt; // 保留扇区数
  25. uint8_t BPB_NumFATs; // FAT表数量
  26. uint16_t BPB_RootEntCnt; // 根目录文件数最大值
  27. uint16_t BPB_TotSec16; // 16位扇区总数
  28. uint8_t BPB_Media; // 介质描述符
  29. uint16_t BPB_FATSz16; // FAT12/16每FAT扇区数
  30. uint16_t BPB_SecPerTrk; // 每磁道扇区数
  31. uint16_t BPB_NumHeads; // 磁头数
  32. uint32_t BPB_HiddSec; // 隐藏扇区数
  33. uint32_t BPB_TotSec32; // 32位扇区总数
  34. uint32_t BPB_FATSz32; // FAT32每FAT扇区数
  35. uint16_t BPB_ExtFlags; // 扩展标志
  36. uint16_t BPB_FSVer; // 文件系统版本号
  37. uint32_t BPB_RootClus; // 根目录起始簇号
  38. uint16_t BPB_FSInfo; // FS info结构体的扇区号
  39. uint16_t BPB_BkBootSec; // 引导扇区的备份扇区号
  40. uint8_t BPB_Reserved0[12];
  41. uint8_t BS_DrvNum; // int0x13的驱动器号
  42. uint8_t BS_Reserved1;
  43. uint8_t BS_BootSig; // 扩展引导标记
  44. uint32_t BS_VolID; // 卷序列号
  45. uint8_t BS_VolLab[11]; // 卷标
  46. uint8_t BS_FilSysType[8]; // 文件系统类型
  47. uint8_t BootCode[420]; // 引导代码、数据
  48. uint16_t BS_TrailSig; // 结束标志0xAA55
  49. } __attribute__((packed));
  50. /**
  51. * @brief fat32文件系统的FSInfo扇区结构体
  52. *
  53. */
  54. struct fat32_FSInfo_t
  55. {
  56. uint32_t FSI_LeadSig; // FS info扇区标志符 数值为0x41615252
  57. uint8_t FSI_Reserved1[480]; // 保留使用,全部置为0
  58. uint32_t FSI_StrucSig; // 另一个标志符,数值为0x61417272
  59. uint32_t FSI_Free_Count; // 上一次记录的空闲簇数量,这是一个参考值
  60. uint32_t FSI_Nxt_Free; // 空闲簇的起始搜索位置,这是为驱动程序提供的参考值
  61. uint8_t FSI_Reserved2[12]; // 保留使用,全部置为0
  62. uint32_t FSI_TrailSig; // 结束标志,数值为0xaa550000
  63. } __attribute__((packed));
  64. #define ATTR_READ_ONLY (1 << 0)
  65. #define ATTR_HIDDEN (1 << 1)
  66. #define ATTR_SYSTEM (1 << 2)
  67. #define ATTR_VOLUME_ID (1 << 3)
  68. #define ATTR_DIRECTORY (1 << 4)
  69. #define ATTR_ARCHIVE (1 << 5)
  70. #define ATTR_LONG_NAME (ATTR_READ_ONLY | ATTR_HIDDEN | ATTR_SYSTEM | ATTR_VOLUME_ID)
  71. /**
  72. * @brief fat32文件系统短目录项,大小为32bytes
  73. *
  74. */
  75. struct fat32_Directory_t
  76. {
  77. unsigned char DIR_Name[11];
  78. unsigned char DIR_Attr; // 文件属性
  79. unsigned char DIR_NTRes; // EXT|BASE => 8(BASE).3(EXT)
  80. // BASE:LowerCase(8),UpperCase(0)
  81. // EXT:LowerCase(16),UpperCase(0)
  82. unsigned char DIR_CrtTimeTenth; // 文件创建的毫秒级时间戳
  83. unsigned short DIR_CrtTime; // 文件创建时间
  84. unsigned short DIR_CrtDate; // 文件创建日期
  85. unsigned short DIR_LastAccDate; // 文件的最后访问日期
  86. unsigned short DIR_FstClusHI; // 起始簇号(高16bit)
  87. unsigned short DIR_WrtTime; // 最后写入时间
  88. unsigned short DIR_WrtDate; // 最后写入日期
  89. unsigned short DIR_FstClusLO; // 起始簇号(低16bit)
  90. unsigned int DIR_FileSize; // 文件大小
  91. } __attribute__((packed));
  92. #define LOWERCASE_BASE (8)
  93. #define LOWERCASE_EXT (16)
  94. /**
  95. * @brief fat32文件系统长目录项,大小为32bytes
  96. *
  97. */
  98. struct fat32_LongDirectory_t
  99. {
  100. unsigned char LDIR_Ord; // 长目录项的序号
  101. unsigned short LDIR_Name1[5]; // 长文件名的第1-5个字符,每个字符占2bytes
  102. unsigned char LDIR_Attr; // 目录项属性必须为ATTR_LONG_NAME
  103. unsigned char LDIR_Type; // 如果为0,则说明这是长目录项的子项
  104. unsigned char LDIR_Chksum; // 短文件名的校验和
  105. unsigned short LDIR_Name2[6]; // 长文件名的第6-11个字符,每个字符占2bytes
  106. unsigned short LDIR_FstClusLO; // 必须为0
  107. unsigned short LDIR_Name3[2]; // 长文件名的12-13个字符,每个字符占2bytes
  108. } __attribute__((packed));
  109. struct fat32_partition_info_t
  110. {
  111. uint16_t partition_id; // 全局fat32分区id
  112. uint8_t ahci_ctrl_num;
  113. uint8_t ahci_port_num;
  114. uint8_t part_num; // 硬盘中的分区号
  115. struct fat32_BootSector_t bootsector;
  116. struct fat32_FSInfo_t fsinfo;
  117. uint64_t first_data_sector; // 数据区起始扇区号
  118. uint64_t bytes_per_clus; // 每簇字节数
  119. uint64_t FAT1_base_sector; // FAT1表的起始簇号
  120. uint64_t FAT2_base_sector; // FAT2表的起始簇号
  121. };
  122. /**
  123. * @brief 注册指定磁盘上的指定分区的fat32文件系统
  124. *
  125. * @param ahci_ctrl_num ahci控制器编号
  126. * @param ahci_port_num ahci控制器端口编号
  127. * @param part_num 磁盘分区编号
  128. */
  129. int fat32_register_partition(uint8_t ahci_ctrl_num, uint8_t ahci_port_num, uint8_t part_num);
  130. /**
  131. * @brief 按照路径查找文件
  132. *
  133. * @param part_id fat32分区id
  134. * @param path
  135. * @param flags
  136. * @return struct fat32_Directory_t*
  137. */
  138. struct fat32_Directory_t *fat32_path_walk(uint32_t part_id, char *path, uint64_t flags);
  139. void fat32_init();