Вход на хостинг
IT-новости
20.04.2016 iPhone 2017 года поместят в водонепроницаемый корпус из стекла
Линейка iPhone в новом году серьезно поменяется. В этом уверен аналитический исследователь Мин Чи Ку......
30.07.2015 Ищем уникальный контент для сайта
Ищем уникальный контент для сайта Без уникального контента Ваш сайт обречен на то, что его страницы......
3) функция read_fat32() считывает таблицу FAT32:
int read_fat32()
{
__u64 seek = (__u64)fbs.reserved * 512 + start_seek;
fat32 = (void *)malloc(fat32_size);
if(!fat32) return -1;
if(pread64(hard, (__u8 *)fat32, fat32_size, seek) < 0) return -1;
return 0;
}
Функция read_cluster() выполняет чтения кластера с указанным номером:
int read_cluster(__u32 cluster_num, __u8 *tmp_buff)
{
__u64 seek = (__u64)(byte_per_cluster) * (cluster_num - 2) + data_start + start_seek;
if(pread64(hard, tmp_buff, byte_per_cluster, seek) < 0) return -1;
return 0;
}
Чтением каталогов (в том числе и корневого) занимается функция read_directory():
int read_directory(__u32 start_cluster)
{
int i = 2;
__u32 next_cluster;
Параметры функции – стартовый кластер каталога. Считываем содержимое каталога в глобальный буфер dir_entry:
if(read_cluster(start_cluster, dir_entry) < 0) return -1;
next_cluster = fat32[start_cluster];
Если каталог занимает один кластер – выходим, если нет – увеличиваем размер памяти и продолжаем чтение:
if((next_cluster == EOF_FAT32) || (next_cluster == 0xFFFFFF8)) return 0;
for(; ;i++) {
start_cluster = next_cluster;
dir_entry = (__u8 *)realloc(dir_entry, i * byte_per_cluster);
if(!dir_entry) return -1;
if(read_cluster(start_cluster, (dir_entry + (i - 1) * byte_per_cluster)) < 0) return -1;
next_cluster = fat32[start_cluster];
if((next_cluster == EOF_FAT32) || (next_cluster == 0xFFFFFF8)) return 0;
}
return 0;
}
Последняя функция, которую мы рассмотрим, ищет в содержимом каталога элемент, соответствующий искомому файлу:
int get_dentry(struct split_name *sn)
{
int i = 0;
Указатель dir_entry настроен на область памяти, содержащую массив записей каталога, в котором мы собираемся искать файл (или каталог). Для поиска организуем цикл и найденную запись поместим в глобальную структуру dentry:
for(;;i++) {