Перейти к содержанию
    

vasilijvs

Участник
  • Постов

    13
  • Зарегистрирован

  • Посещение

Репутация

0 Обычный
  1. Спасибо большое! Всё заработало. Действительно проблема была в выравнивании границ стирания.
  2. Потому что указывается адрес стираемого блока, значит они начальные 512. А то что после,перезаписывается.
  3. Вот как все происходит. Чтение 3584 байт, которые после нужных нам 512. Стирание 4096. Запись оставшихся 3584 с начального адреса + 512. void Flash::eraseBlock512(uint32_t address) { uint8_t source[7 * 512]; readArray(address + 512, sizeof(source), source); eraseBlock(address, Block4k); uint8_t temp[256]; for(int i = 0; i < 14; ++i) { for(int j = 0; j < sizeof(temp); ++j) { temp[j] = source[i * 256 + j]; } writeData(address + 512 + i * 256, sizeof(temp), temp); } }
  4. Да в том и дело, что всё уже проанализировал. Читается/пишется всё как надо. С f_mount вопрос решился, файл создается,а вот данные туда записать не получается
  5. Да, их тестировал disk_read(),disk_write() Это адрес начальный, откуда читать/писать
  6. Вылетает в первом return 0, после того как в цикле побегает. ncl = scl; /* Start cluster */ for (;;) { ncl++; /* Next cluster */ if (ncl >= fs->n_fatent) { /* Wrap around */ ncl = 2; if (ncl > scl) return 0; /* No free cluster */ } cs = get_fat(fs, ncl); /* Get the cluster status */ if (cs == 0) break; /* Found a free cluster */ if (cs == 0xFFFFFFFF || cs == 1)/* An error occurred */ return cs; if (ncl == scl) return 0; /* No free cluster */ }
  7. Написал, попробывал, читаю/пишу, всё корректно, но та же проблема. Привожу полный код diskio.cpp #include "diskio.h" #include "ff_gen_drv.h" #include "flash.h" #include "spi.h" extern Disk_drvTypeDef disk; extern Spi spi(GPIO_PIN_10, GPIO_PIN_11, GPIO_PIN_12, GPIO_PIN_2); extern Flash flash(spi); /** * @brief Initializes a Drive * @param pdrv: Physical drive number (0..) * @retval DSTATUS: Operation status */ DSTATUS disk_initialize(BYTE pdrv) { DSTATUS stat = RES_OK; if(disk.is_initialized[pdrv] == 0) { disk.is_initialized[pdrv] = 1; stat = disk.drv[pdrv]->disk_initialize(); } return stat; } /** * @brief Gets Disk Status * @param pdrv: Physical drive number (0..) * @retval DSTATUS: Operation status */ DSTATUS disk_status(BYTE pdrv) { DSTATUS stat; stat = disk.drv[pdrv]->disk_status(); return stat; } /** * @brief Reads Sector(s) * @param pdrv: Physical drive number (0..) * @param *buff: Data buffer to store read data * @param sector: Sector address (LBA) * @param count: Number of sectors to read (1..128) * @retval DRESULT: Operation result */ DRESULT disk_read(BYTE pdrv, BYTE *buff, DWORD sector, BYTE count) { DWORD realSector = sector * 512; flash.readArray(realSector, count * 512, buff); return RES_OK; } /** * @brief Writes Sector(s) * @param pdrv: Physical drive number (0..) * @param *buff: Data to be written * @param sector: Sector address (LBA) * @param count: Number of sectors to write (1..128) * @retval DRESULT: Operation result */ #if _USE_WRITE == 1 DRESULT disk_write(BYTE pdrv, const BYTE *buff, DWORD sector, BYTE count) { DWORD realSector = sector * 512; for (int i = 0; i < count; ++i) { flash.eraseBlock512(realSector + i * 512); } for(int i = 0; i < (count * 2); ++i) { uint8_t temp[256]; for(int j = 0; j < sizeof(temp); ++j) { temp[j] = buff[i * 256 + j]; } flash.writeData(realSector + i * 256, sizeof(temp), temp); } return RES_OK; } #endif /* _USE_WRITE == 1 */ /** * @brief I/O control operation * @param pdrv: Physical drive number (0..) * @param cmd: Control code * @param *buff: Buffer to send/receive control data * @retval DRESULT: Operation result */ #if _USE_IOCTL == 1 DRESULT disk_ioctl(BYTE pdrv, BYTE cmd, void *buff) { DRESULT res = RES_ERROR; switch (cmd) { case CTRL_SYNC: res = RES_OK; break; case GET_SECTOR_COUNT: *(DWORD*)buff = 2048; res = RES_OK; break; case GET_SECTOR_SIZE: *(DWORD*)buff = 512; res = RES_OK; break; case GET_BLOCK_SIZE: *(DWORD*)buff = 512; res = RES_OK; break; } return res; } #endif /* _USE_IOCTL == 1 */ /** * @brief Gets Time from RTC * @param None * @retval Time in DWORD */ DWORD get_fattime (void) { return 0; }
  8. Всем спасибо за советы, сделал по 512 сектор. И действительно, получилось смонтировать систему и создать файл. Но записывать данные в файл всё равно упорно не хочет :( Заходя в функцию f_write(), в первой строке пытается выбрать новый кластер, а следом вылетает из функции. fp->sclust = clst = create_chain(fp->fs, 0); /* Create a new cluster chain */ if (clst == 0) break; /* Could not allocate a new cluster (disk full) */ Есть идеи как можно полечить? Почему он не может найти свободный кластер?
  9. Спасибо,за мнения. Увеличил _MAX_SS, в HardFault уже не падает. Следующая функция check_fs() вызывается в find_volume() и возвращает значение 2 из-за которого в функции f_open() возвращается FR_NO_FILESYSTEM. Что ещё можно сделать? Все функции чтения, записи реализованы, что может быть не так? static BYTE check_fs ( /* 0:FAT boor sector, 1:Valid boor sector but not FAT, 2:Not a boot sector, 3:Disk error */ FATFS* fs, /* File system object */ DWORD sect /* Sector# (lba) to check if it is an FAT boot record or not */ ) { fs->wflag = 0; fs->winsect = 0xFFFFFFFF; /* Invaidate window */ if (move_window(fs, sect) != FR_OK) /* Load boot record */ return 3; if (LD_WORD(&fs->win.d8[BS_55AA]) != 0xAA55) /* Check boot record signature (always placed at offset 510 even if the sector size is >512) */ return 2; if ((LD_DWORD(&fs->win.d8[BS_FilSysType]) & 0xFFFFFF) == 0x544146) /* Check "FAT" string */ return 0; if ((LD_DWORD(&fs->win.d8[BS_FilSysType32]) & 0xFFFFFF) == 0x544146) /* Check "FAT" string */ return 0; return 1; }
  10. Да,спасибо,сейчас проходит этот момент,но на функции f_open в HardFault падает( Вот в этом куске кода падает, условие не проходит, хотя внутри disk_read всё выполняется и возвращается RES_OK, а обратно управление не возвращается if (disk_read(fs->drv, fs->win.d8, sector, 1)) return FR_DISK_ERR; Что это может быть?
  11. Появился следующий вопрос. У меня флешка на 1 Мбайт, имеет 16 секторов по 64 Кбайта. В функции f_mkfs, есть следующий код, который возвращает FR_DISK_ERR и не дает успешно завершить это функцию. /* Create a partition in this function */ if (disk_ioctl(pdrv, GET_SECTOR_COUNT, &n_vol) != RES_OK || n_vol < 128) return FR_DISK_ERR; Как раз не проходит по второму условию, т.к. количество секторов на моей флешке 16. Как быть?
  12. А можете ткнуть,куда именно глядеть? Я отчаялся уже Разобрался f_mkfs()
  13. stm32f373 + flash(at25df081) + fatFs

    Добрый день, прошу помочь всех знатоков. Хочу смонтировать раздел с помощью fatfs, возвращает FR_NO_FILESYSTEM, получается флеш не отформатирована под Fat. Расскажите, каким образом её отформатировать или как добиться успешного выполнения f_mount()? Вот здесь fResult получает это значение. FATFS fatFs; FRESULT fResult; fResult = f_mount(&fatFs, "0", 1);
×
×
  • Создать...