Write28 Dosent всегда записывать на жесткий диск / диск

У меня проблема с этой функцией Write28(), которая записывает в драйвер ATA (драйвер жесткого диска) в режиме 28-битного PIO. Ну, во-первых, вы можете увидеть в моем kernel.C++ здесь, я называю это:

  ret_chr_arr file_contents=filealgo.File_to_char(sampleFile);
  ret_chr_arr math_wkst_file= filealgo.File_to_char(anotherSampleFile);

  ret_chr_arr file_1_contents = filealgo.File_to_char(file1);
  ret_chr_arr file_2_contents = filealgo.File_to_char(file2);
  ret_chr_arr file_3_contents = filealgo.File_to_char(file3);


  char* res_default = Lib::str::strcat(file_contents.str,math_wkst_file.str);
  res_default = Lib::str::strcat(res_default,file_1_contents.str);
  res_default = Lib::str::strcat(res_default,file_2_contents.str);
  res_default = Lib::str::strcat(res_default,file_3_contents.str);

//printf("\nres_default %s",res_default);

   vata.return_ata().Write28(0, res_default,0, Lib::str::strlen(res_default));
   vata.return_ata().Flush();

Это полностью работает, и пишет на жесткий диск... Но тогда... вот где проблема возникает... Я делаю команду mkfile (для которой сейчас просто по умолчанию генерируется файл для имени файла), которая записывает в драйвер ATA также.

File tempFile;
tempFile.header.name = "FileGenerated";
ret_chr_arr file_contents_temp=filealgo.File_to_char(tempFile);
result_sector_one = Lib::str::strcat(result_sector_one,file_contents_temp.str);
            vata.return_ata().Write28(0, result_sector_one,0, Lib::str::strlen(result_sector_one));
vata.return_ata().Flush();
printf("\n%s\n",vata.return_ata().Read28(0));

Интересно, что это случилось со мной в Read28, где я не мог вызвать Read28 более одного раза... и это было из-за предупреждения, которое я ранее @millenburg возвратил указатель на локальную переменную.. в основном return (char*) str .. когда str является массивом. Я удалил, что это, кажется, работает... Но write28() тоже не использует это.. Я провел несколько раз, пытаясь отладить это и решить, но это не сработает. Вот видео, если кто-то заинтересован в дополнительной информации. Вот моя функция Write28:

void AdvancedTechnologyAttachment::Write28(uint8_t sectorNum, char* data, uint32_t start, uint32_t count)
{
    if(!(accesible))
    {
        printf("Failed : Not Accessible");
        return;
    }
        //Larger Addressing Than 28
    //check first 4 bits are 0
    if(sectorNum > 0x0FFFFFFF)
    {
        printf("ERR");
        return;
    }

    if(count>512)
    {
        printf("ERR");
        return;
    }
//Identify What 
    //Drive You want to comunicate with
    //MASTER || SLAVE
    if(this->type == MASTER)
        p8b.out(0xE0 | ((sectorNum & 0x0F000000) >> 24),port_def + 0x6);
    else
        p8b.out(0xF0 | ((sectorNum & 0x0F000000) >> 24),port_def + 0x6);



    p8b.out(0,port_def + 0x1);
    p8b.out(1,port_def + 0x2);
    p8b.out( sectorNum & 0x000000FF,port_def + 0x3);
    p8b.out((sectorNum & 0x0000FF00) >> 8,port_def + 0x4);
    p8b.out((sectorNum & 0x00FF0000) >> 16,port_def + 0x5);
    p8b.out(0x30,port_def + 0x7); //WRITE COMMAND



 for(uint32_t i = start; i < count; i += 2)
    {
        uint16_t wdata = data[i];
        if(i+1 < count)
            wdata |= ((uint16_t)data[i+1]) << 8;
        p16b.out(wdata,port_def);

        char *text = "  \0";
        text[0] = (wdata >> 8) & 0xFF;
        text[1] = wdata & 0xFF;
 //       printf(text);
    }

    for(int i = count + (count%2); i < 512; i += 2)
        p16b.out(0x0000,port_def);


}

Я показал минимальный возможный код, поэтому, если вы хотите получить еще больше информации, посмотрите на мой исходный код (ata.C++ для ata-кода): https://github.com/amanuel2/OS_Mirror. Я пытаюсь найти эту ошибку активно, но у меня ничего не получается:( . Любые советы или помощь будут высоко оценены!

0 ответов

Другие вопросы по тегам