2018-05-17 08:19:29 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "ff.h"
|
|
|
|
#include "esp_partition.h"
|
|
|
|
#include "wear_levelling.h"
|
|
|
|
#include "diskio.h"
|
2018-06-08 12:09:00 +00:00
|
|
|
#include "diskio_wl.h"
|
2018-05-17 08:19:29 +00:00
|
|
|
|
|
|
|
#include "catch.hpp"
|
|
|
|
|
2018-06-21 08:51:44 +00:00
|
|
|
extern "C" void init_spi_flash(const char* chip_size, size_t block_size, size_t sector_size, size_t page_size, const char* partition_bin);
|
2018-05-26 06:58:01 +00:00
|
|
|
|
2018-05-17 08:19:29 +00:00
|
|
|
TEST_CASE("create volume, open file, write and read back data", "[fatfs]")
|
|
|
|
{
|
2018-06-21 08:51:44 +00:00
|
|
|
init_spi_flash(CONFIG_ESPTOOLPY_FLASHSIZE, CONFIG_WL_SECTOR_SIZE * 16, CONFIG_WL_SECTOR_SIZE, CONFIG_WL_SECTOR_SIZE, "partition_table.bin");
|
2018-05-26 06:58:01 +00:00
|
|
|
|
2018-05-17 08:19:29 +00:00
|
|
|
FRESULT fr_result;
|
|
|
|
BYTE pdrv;
|
|
|
|
FATFS fs;
|
|
|
|
FIL file;
|
|
|
|
UINT bw;
|
|
|
|
|
|
|
|
esp_err_t esp_result;
|
|
|
|
|
2018-05-26 06:58:01 +00:00
|
|
|
const esp_partition_t *partition = esp_partition_find_first(ESP_PARTITION_TYPE_DATA, ESP_PARTITION_SUBTYPE_DATA_FAT, "storage");
|
2018-05-22 08:47:30 +00:00
|
|
|
|
2018-05-17 08:19:29 +00:00
|
|
|
// Mount wear-levelled partition
|
|
|
|
wl_handle_t wl_handle;
|
2018-05-26 06:58:01 +00:00
|
|
|
esp_result = wl_mount(partition, &wl_handle);
|
2018-05-17 08:19:29 +00:00
|
|
|
REQUIRE(esp_result == ESP_OK);
|
|
|
|
|
|
|
|
// Get a physical drive
|
|
|
|
esp_result = ff_diskio_get_drive(&pdrv);
|
|
|
|
REQUIRE(esp_result == ESP_OK);
|
|
|
|
|
|
|
|
// Register physical drive as wear-levelled partition
|
|
|
|
esp_result = ff_diskio_register_wl_partition(pdrv, wl_handle);
|
|
|
|
|
|
|
|
// Create FAT volume on the entire disk
|
|
|
|
DWORD part_list[] = {100, 0, 0, 0};
|
|
|
|
BYTE work_area[FF_MAX_SS];
|
|
|
|
|
|
|
|
fr_result = f_fdisk(pdrv, part_list, work_area);
|
|
|
|
REQUIRE(fr_result == FR_OK);
|
|
|
|
fr_result = f_mkfs("", FM_ANY, 0, work_area, sizeof(work_area)); // Use default volume
|
|
|
|
|
|
|
|
// Mount the volume
|
|
|
|
fr_result = f_mount(&fs, "", 0);
|
|
|
|
REQUIRE(fr_result == FR_OK);
|
|
|
|
|
|
|
|
// Open, write and read data
|
|
|
|
fr_result = f_open(&file, "test.txt", FA_OPEN_ALWAYS | FA_READ | FA_WRITE);
|
|
|
|
REQUIRE(fr_result == FR_OK);
|
|
|
|
|
2018-05-26 06:58:01 +00:00
|
|
|
// Generate data
|
|
|
|
uint32_t data_size = 100000;
|
|
|
|
|
|
|
|
char *data = (char*) malloc(data_size);
|
|
|
|
char *read = (char*) malloc(data_size);
|
2018-05-17 08:19:29 +00:00
|
|
|
|
2018-05-26 06:58:01 +00:00
|
|
|
for(uint32_t i = 0; i < data_size; i += sizeof(i))
|
|
|
|
{
|
|
|
|
*((uint32_t*)(data + i)) = i;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Write generated data
|
|
|
|
fr_result = f_write(&file, data, data_size, &bw);
|
2018-05-17 08:19:29 +00:00
|
|
|
REQUIRE(fr_result == FR_OK);
|
2018-05-26 06:58:01 +00:00
|
|
|
REQUIRE(bw == data_size);
|
2018-05-17 08:19:29 +00:00
|
|
|
|
|
|
|
// Move to beginning of file
|
|
|
|
fr_result = f_lseek(&file, 0);
|
|
|
|
REQUIRE(fr_result == FR_OK);
|
|
|
|
|
2018-05-26 06:58:01 +00:00
|
|
|
// Read written data
|
|
|
|
fr_result = f_read(&file, read, data_size, &bw);
|
2018-05-17 08:19:29 +00:00
|
|
|
REQUIRE(fr_result == FR_OK);
|
2018-05-26 06:58:01 +00:00
|
|
|
REQUIRE(bw == data_size);
|
2018-05-17 08:19:29 +00:00
|
|
|
|
2018-05-26 06:58:01 +00:00
|
|
|
REQUIRE(memcmp(data, read, data_size) == 0);
|
2018-05-17 08:19:29 +00:00
|
|
|
|
|
|
|
// Close file
|
|
|
|
fr_result = f_close(&file);
|
|
|
|
REQUIRE(fr_result == FR_OK);
|
|
|
|
|
|
|
|
// Unmount default volume
|
|
|
|
fr_result = f_mount(0, "", 0);
|
|
|
|
REQUIRE(fr_result == FR_OK);
|
|
|
|
|
|
|
|
free(read);
|
2018-05-26 06:58:01 +00:00
|
|
|
free(data);
|
2018-05-22 08:47:30 +00:00
|
|
|
}
|