解析扩展分区的数量
文章目錄
- 1 解析擴展分區的數量
- 1.1 需求
- 1.2 實現原理
- 1.3 代碼實現
1 解析擴展分區的數量
1.1 需求
怎么樣在一個磁盤上劃分超過4個分區呢?
1.2 實現原理
可以通過在擴展分區下任意劃分多個邏輯分區,來突破主分區4個的限制。
擴展分區的各個邏輯分區,通過“鏈式”結構來連接。
1.3 代碼實現
/*** 獲取擴展分區下的子分區數量* @param disk 擴展分區所在的存儲設備* @param start_sector 擴展分區所在的起始扇區* @param count 查詢得到的子分區數量* @return*/ static xfat_err_t disk_get_extend_part_count(xdisk_t * disk, u32_t start_sector, u32_t * count) {int r_count = 0;u8_t * disk_buffer = temp_buffer;u32_t ext_start_sector = start_sector;do {mbr_part_t * part;// 讀取擴展分區的mbrint err = xdisk_read_sector(disk, disk_buffer, start_sector, 1);if (err < 0) {return err;}// 當前分區無效,立即退出part = ((mbr_t *)disk_buffer)->part_info;if (part->system_id == FS_NOT_VALID) {break;}r_count++;// 沒有后續分區, 立即退出if ((++part)->system_id != FS_EXTEND) {break;}// 尋找下一分區start_sector = ext_start_sector + part->relative_sectors;} while (1);*count = r_count;return FS_ERR_OK; }/*** 獲取設備上總的分區數量* @param disk 查詢的存儲設備* @param count 分區數存儲的位置* @return*/ xfat_err_t xdisk_get_part_count(xdisk_t *disk, u32_t *count) {int r_count = 0, i = 0;mbr_part_t * part;u8_t * disk_buffer = temp_buffer;u8_t extend_part_flag = 0;u32_t start_sector[4];// 讀取mbr區int err = xdisk_read_sector(disk, disk_buffer, 0, 1);if (err < 0) {return err;}// 解析統計主分區的數量,并標記出哪個分區是擴展分區part = ((mbr_t *)disk_buffer)->part_info;for (i = 0; i < MBR_PRIMARY_PART_NR; i++, part++) {if (part->system_id == FS_NOT_VALID) {continue;} else if (part->system_id == FS_EXTEND) {start_sector[i] = part->relative_sectors;extend_part_flag |= 1 << i;} else {r_count++;}}// 統計各個擴展分區下有多少個子分區if (extend_part_flag) {for (i = 0; i < MBR_PRIMARY_PART_NR; i++) {if (extend_part_flag & (1 << i)) {u32_t ext_count = 0;err = disk_get_extend_part_count(disk, start_sector[i], &ext_count);if (err < 0) {return err;}r_count += ext_count;}}}*count = r_count;return FS_ERR_OK; }參考資料:
總結
- 上一篇: 服务端程序的初步实现
- 下一篇: 七人座轿车是双排座轿车吗