mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
Merge pull request #8273 from OTAkeys/pr/spiffs-multi-partitions
pkg/spiffs: add multi-partitions support
This commit is contained in:
commit
dcc4a5ae9f
@ -136,10 +136,16 @@ static int prepare(spiffs_desc_t *fs_desc)
|
||||
#if SPIFFS_SINGLETON == 0
|
||||
DEBUG("spiffs: mount: mtd page_size=%" PRIu32 ", pages_per_sector=%" PRIu32
|
||||
", sector_count=%" PRIu32 "\n", dev->page_size, dev->pages_per_sector, dev->sector_count);
|
||||
fs_desc->config.phys_size = dev->page_size * dev->pages_per_sector * dev->sector_count;
|
||||
uint32_t sector_count = (fs_desc->block_count == 0) ? dev->sector_count : fs_desc->block_count;
|
||||
/* inside memory area */
|
||||
assert(((fs_desc->base_addr / (dev->page_size * dev->pages_per_sector)) + sector_count)
|
||||
<= dev->sector_count);
|
||||
/* base addr is aligned on a sector */
|
||||
assert(fs_desc->base_addr % (dev->pages_per_sector * dev->page_size) == 0);
|
||||
fs_desc->config.phys_size = dev->page_size * dev->pages_per_sector * sector_count;
|
||||
fs_desc->config.log_block_size = dev->page_size * dev->pages_per_sector;
|
||||
fs_desc->config.log_page_size = dev->page_size;
|
||||
fs_desc->config.phys_addr = 0;
|
||||
fs_desc->config.phys_addr = fs_desc->base_addr;
|
||||
fs_desc->config.phys_erase_block = dev->page_size * dev->pages_per_sector;
|
||||
#endif
|
||||
|
||||
|
@ -116,6 +116,11 @@ typedef struct spiffs_desc {
|
||||
#if (SPIFFS_HAL_CALLBACK_EXTRA == 1) || defined(DOXYGEN)
|
||||
mtd_dev_t *dev; /**< The underlying mtd device, must be set by user */
|
||||
#endif
|
||||
#if (SPIFFS_SINGLETON == 0) || defined(DOXYGEN)
|
||||
uint32_t base_addr; /**< Base address of partition */
|
||||
uint32_t block_count; /**< Number of blocks in current partition,
|
||||
* if 0, the mtd number of sector is used */
|
||||
#endif
|
||||
} spiffs_desc_t;
|
||||
|
||||
/** The SPIFFS vfs driver, a pointer to a spiffs_desc_t must be provided as vfs_mountp::private_data */
|
||||
|
@ -143,6 +143,9 @@ static void test_spiffs_teardown(void)
|
||||
vfs_unlink("/test-spiffs/test1.txt");
|
||||
vfs_unlink("/test-spiffs/a/test2.txt");
|
||||
vfs_umount(&_test_spiffs_mount);
|
||||
|
||||
spiffs_desc.base_addr = 0;
|
||||
spiffs_desc.block_count = 0;
|
||||
}
|
||||
|
||||
static void tests_spiffs_format(void)
|
||||
@ -382,6 +385,58 @@ static void tests_spiffs_statvfs(void)
|
||||
TEST_ASSERT(sizeof(buf) <= (stat1.f_bavail - stat2.f_bavail));
|
||||
}
|
||||
|
||||
static void tests_spiffs_partition(void)
|
||||
{
|
||||
vfs_umount(&_test_spiffs_mount);
|
||||
|
||||
spiffs_desc.base_addr = _dev->page_size * _dev->pages_per_sector;
|
||||
spiffs_desc.block_count = 2;
|
||||
mtd_erase(_dev, 0, _dev->page_size * _dev->pages_per_sector * _dev->sector_count);
|
||||
|
||||
int res = vfs_format(&_test_spiffs_mount);
|
||||
TEST_ASSERT_EQUAL_INT(0, res);
|
||||
|
||||
res = vfs_mount(&_test_spiffs_mount);
|
||||
TEST_ASSERT_EQUAL_INT(0, res);
|
||||
|
||||
#if SPIFFS_USE_MAGIC
|
||||
/* if SPIFFS_USE_MAGIC is used, a magic word is written in each sector */
|
||||
uint8_t buf[4];
|
||||
const uint8_t buf_erased[4] = {0xff, 0xff, 0xff, 0xff};
|
||||
int nread;
|
||||
res = 0;
|
||||
for (size_t i = 0; i < _dev->page_size * _dev->pages_per_sector; i += sizeof(buf)) {
|
||||
nread = mtd_read(_dev, buf, _dev->page_size * _dev->pages_per_sector + i, sizeof(buf));
|
||||
TEST_ASSERT_EQUAL_INT(sizeof(buf), nread);
|
||||
res |= memcmp(buf, buf_erased, sizeof(buf));
|
||||
}
|
||||
TEST_ASSERT(res != 0);
|
||||
res = 0;
|
||||
for (size_t i = 0; i < _dev->page_size * _dev->pages_per_sector; i += sizeof(buf)) {
|
||||
nread = mtd_read(_dev, buf, (2 * _dev->page_size * _dev->pages_per_sector) + i, sizeof(buf));
|
||||
TEST_ASSERT_EQUAL_INT(sizeof(buf), nread);
|
||||
res |= memcmp(buf, buf_erased, sizeof(buf));
|
||||
}
|
||||
TEST_ASSERT(res != 0);
|
||||
/* Check previous sector (must be erased) */
|
||||
res = 0;
|
||||
for (size_t i = 0; i < _dev->page_size * _dev->pages_per_sector; i += sizeof(buf)) {
|
||||
nread = mtd_read(_dev, buf, i, sizeof(buf));
|
||||
TEST_ASSERT_EQUAL_INT(sizeof(buf), nread);
|
||||
res |= memcmp(buf, buf_erased, sizeof(buf));
|
||||
}
|
||||
TEST_ASSERT(res == 0);
|
||||
/* Check next sector (must be erased) */
|
||||
res = 0;
|
||||
for (size_t i = 0; i < _dev->page_size * _dev->pages_per_sector; i += sizeof(buf)) {
|
||||
nread = mtd_read(_dev, buf, (3 * _dev->page_size * _dev->pages_per_sector) + i, sizeof(buf));
|
||||
TEST_ASSERT_EQUAL_INT(sizeof(buf), nread);
|
||||
res |= memcmp(buf, buf_erased, sizeof(buf));
|
||||
}
|
||||
TEST_ASSERT(res == 0);
|
||||
#endif
|
||||
}
|
||||
|
||||
Test *tests_spiffs_tests(void)
|
||||
{
|
||||
EMB_UNIT_TESTFIXTURES(fixtures) {
|
||||
@ -393,6 +448,7 @@ Test *tests_spiffs_tests(void)
|
||||
new_TestFixture(tests_spiffs_readdir),
|
||||
new_TestFixture(tests_spiffs_rename),
|
||||
new_TestFixture(tests_spiffs_statvfs),
|
||||
new_TestFixture(tests_spiffs_partition),
|
||||
};
|
||||
|
||||
EMB_UNIT_TESTCALLER(spiffs_tests, test_spiffs_setup, test_spiffs_teardown, fixtures);
|
||||
|
Loading…
Reference in New Issue
Block a user