Разработка динамических сайтов
SEO услуги
Управление контекстной рекламой

Вход на хостинг

Имя пользователя:*

Пароль пользователя:*

IT-новости

20.04.2016 iPhone 2017 года поместят в водонепроницаемый корпус из стекла

Линейка iPhone в новом году серьезно поменяется. В этом уверен аналитический исследователь Мин Чи Ку......

подробнее

30.07.2015 Ищем уникальный контент для сайта

Ищем уникальный контент для сайта Без уникального контента Ваш сайт обречен на то, что его страницы......

подробнее

11.05.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++) {

 


Предыдущая страницаОглавлениеСледующая страница
 
[001] [002] [003] [004] [005] [006] [007] [008] [009] [010] [011] [012] [013] [014] [015] [016] [017] [018] [019] [020]
[021] [022] [023] [024] [025] [026] [027] [028] [029] [030] [031] [032] [033] [034] [035] [036] [037] [038] [039] [040]
[041] [042] [043] [044] [045] [046] [047] [048] [049] [050] [051] [052] [053] [054] [055] [056] [057] [058] [059] [060]
[061] [062] [063] [064] [065] [066] [067] [068] [069] [070] [071] [072] [073] [074] [075] [076] [077] [078] [079] [080]
[081] [082] [083] [084] [085] [086] [087] [088] [089] [090] [091] [092] [093] [094] [095] [096] [097] [098] [099] [100]
[101] [102] [103] [104] [105] [106] [107] [108] [109] [110] [111] [112] [113] [114] [115] [116] [117] [118] [119] [120]
[121] [122] [123] [124] [125] [126] [127] [128] [129] [130] [131] [132] [133] [134] [135] [136] [137] [138] [139] [140]
[141] [142] [143] [144] [145] [146] [147] [148] [149] [150] [151] [152] [153] [154] [155] [156] [157]

+7 (831) 413-63-27
ООО Дельта-Технология ©2007 - 2023 год
Нижний Новгород, ул. Дальняя, 17А.
Rambler's Top100