mirror of
https://github.com/eledio-devices/thirdparty-littlefs.git
synced 2025-11-01 00:38:29 +01:00
Changed callbacks to take user-provided context directly
This is a style change to make littlefs's callbacks consistent with most callback declarations found in C. That is, taking in a user-provided `void*`. Previously, these callbacks took a pointer to the config struct itself, which indirectly contained a user provided context, and this gets the job done, but taking in a callback with a `void*` is arguably more expected, has a better chance of integrating with C++/OS-specific code, and is more likely to be optimized out by a clever compiler. --- As a part of these changes, the geometry for the test bds needed to be moved into bd specific configuration objects. This is a good change as it also allows for testing situations where littlefs's geometry does not match the underlying bd.
This commit is contained in:
@@ -98,15 +98,15 @@ code = '''
|
||||
lfs_dir_close(&lfs, &dir) => 0;
|
||||
lfs_unmount(&lfs) => 0;
|
||||
uint8_t bbuffer[LFS_BLOCK_SIZE];
|
||||
cfg.read(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_read(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
int off = LFS_BLOCK_SIZE-1;
|
||||
while (off >= 0 && bbuffer[off] == LFS_ERASE_VALUE) {
|
||||
off -= 1;
|
||||
}
|
||||
memset(&bbuffer[off-3], LFS_BLOCK_SIZE, 3);
|
||||
cfg.erase(&cfg, block) => 0;
|
||||
cfg.prog(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
cfg.sync(&cfg) => 0;
|
||||
lfs_testbd_erase(&bd, block) => 0;
|
||||
lfs_testbd_prog(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_sync(&bd) => 0;
|
||||
|
||||
lfs_mountcfg(&lfs, &cfg) => 0;
|
||||
lfs_dir_open(&lfs, &dir, "a") => 0;
|
||||
@@ -174,15 +174,15 @@ code = '''
|
||||
lfs_dir_close(&lfs, &dir) => 0;
|
||||
lfs_unmount(&lfs) => 0;
|
||||
uint8_t bbuffer[LFS_BLOCK_SIZE];
|
||||
cfg.read(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_read(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
int off = LFS_BLOCK_SIZE-1;
|
||||
while (off >= 0 && bbuffer[off] == LFS_ERASE_VALUE) {
|
||||
off -= 1;
|
||||
}
|
||||
memset(&bbuffer[off-3], LFS_BLOCK_SIZE, 3);
|
||||
cfg.erase(&cfg, block) => 0;
|
||||
cfg.prog(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
cfg.sync(&cfg) => 0;
|
||||
lfs_testbd_erase(&bd, block) => 0;
|
||||
lfs_testbd_prog(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_sync(&bd) => 0;
|
||||
|
||||
// corrupt the destination
|
||||
lfs_mountcfg(&lfs, &cfg) => 0;
|
||||
@@ -190,15 +190,15 @@ code = '''
|
||||
block = dir.m.pair[0];
|
||||
lfs_dir_close(&lfs, &dir) => 0;
|
||||
lfs_unmount(&lfs) => 0;
|
||||
cfg.read(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_read(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
off = LFS_BLOCK_SIZE-1;
|
||||
while (off >= 0 && bbuffer[off] == LFS_ERASE_VALUE) {
|
||||
off -= 1;
|
||||
}
|
||||
memset(&bbuffer[off-3], LFS_BLOCK_SIZE, 3);
|
||||
cfg.erase(&cfg, block) => 0;
|
||||
cfg.prog(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
cfg.sync(&cfg) => 0;
|
||||
lfs_testbd_erase(&bd, block) => 0;
|
||||
lfs_testbd_prog(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_sync(&bd) => 0;
|
||||
|
||||
lfs_mountcfg(&lfs, &cfg) => 0;
|
||||
lfs_dir_open(&lfs, &dir, "a") => 0;
|
||||
@@ -266,15 +266,15 @@ code = '''
|
||||
lfs_dir_close(&lfs, &dir) => 0;
|
||||
lfs_unmount(&lfs) => 0;
|
||||
uint8_t bbuffer[LFS_BLOCK_SIZE];
|
||||
cfg.read(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_read(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
int off = LFS_BLOCK_SIZE-1;
|
||||
while (off >= 0 && bbuffer[off] == LFS_ERASE_VALUE) {
|
||||
off -= 1;
|
||||
}
|
||||
memset(&bbuffer[off-3], LFS_BLOCK_SIZE, 3);
|
||||
cfg.erase(&cfg, block) => 0;
|
||||
cfg.prog(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
cfg.sync(&cfg) => 0;
|
||||
lfs_testbd_erase(&bd, block) => 0;
|
||||
lfs_testbd_prog(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_sync(&bd) => 0;
|
||||
|
||||
// corrupt the destination
|
||||
lfs_mountcfg(&lfs, &cfg) => 0;
|
||||
@@ -282,15 +282,15 @@ code = '''
|
||||
block = dir.m.pair[0];
|
||||
lfs_dir_close(&lfs, &dir) => 0;
|
||||
lfs_unmount(&lfs) => 0;
|
||||
cfg.read(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_read(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
off = LFS_BLOCK_SIZE-1;
|
||||
while (off >= 0 && bbuffer[off] == LFS_ERASE_VALUE) {
|
||||
off -= 1;
|
||||
}
|
||||
memset(&bbuffer[off-3], LFS_BLOCK_SIZE, 3);
|
||||
cfg.erase(&cfg, block) => 0;
|
||||
cfg.prog(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
cfg.sync(&cfg) => 0;
|
||||
lfs_testbd_erase(&bd, block) => 0;
|
||||
lfs_testbd_prog(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_sync(&bd) => 0;
|
||||
|
||||
// continue move
|
||||
lfs_mountcfg(&lfs, &cfg) => 0;
|
||||
@@ -536,15 +536,15 @@ code = '''
|
||||
lfs_dir_close(&lfs, &dir) => 0;
|
||||
lfs_unmount(&lfs) => 0;
|
||||
uint8_t bbuffer[LFS_BLOCK_SIZE];
|
||||
cfg.read(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_read(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
int off = LFS_BLOCK_SIZE-1;
|
||||
while (off >= 0 && bbuffer[off] == LFS_ERASE_VALUE) {
|
||||
off -= 1;
|
||||
}
|
||||
memset(&bbuffer[off-3], LFS_BLOCK_SIZE, 3);
|
||||
cfg.erase(&cfg, block) => 0;
|
||||
cfg.prog(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
cfg.sync(&cfg) => 0;
|
||||
lfs_testbd_erase(&bd, block) => 0;
|
||||
lfs_testbd_prog(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_sync(&bd) => 0;
|
||||
|
||||
lfs_mountcfg(&lfs, &cfg) => 0;
|
||||
lfs_dir_open(&lfs, &dir, "a") => 0;
|
||||
@@ -620,15 +620,15 @@ code = '''
|
||||
lfs_dir_close(&lfs, &dir) => 0;
|
||||
lfs_unmount(&lfs) => 0;
|
||||
uint8_t bbuffer[LFS_BLOCK_SIZE];
|
||||
cfg.read(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_read(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
int off = LFS_BLOCK_SIZE-1;
|
||||
while (off >= 0 && bbuffer[off] == LFS_ERASE_VALUE) {
|
||||
off -= 1;
|
||||
}
|
||||
memset(&bbuffer[off-3], LFS_BLOCK_SIZE, 3);
|
||||
cfg.erase(&cfg, block) => 0;
|
||||
cfg.prog(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
cfg.sync(&cfg) => 0;
|
||||
lfs_testbd_erase(&bd, block) => 0;
|
||||
lfs_testbd_prog(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_sync(&bd) => 0;
|
||||
|
||||
// corrupt the destination
|
||||
lfs_mountcfg(&lfs, &cfg) => 0;
|
||||
@@ -636,15 +636,15 @@ code = '''
|
||||
block = dir.m.pair[0];
|
||||
lfs_dir_close(&lfs, &dir) => 0;
|
||||
lfs_unmount(&lfs) => 0;
|
||||
cfg.read(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_read(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
off = LFS_BLOCK_SIZE-1;
|
||||
while (off >= 0 && bbuffer[off] == LFS_ERASE_VALUE) {
|
||||
off -= 1;
|
||||
}
|
||||
memset(&bbuffer[off-3], LFS_BLOCK_SIZE, 3);
|
||||
cfg.erase(&cfg, block) => 0;
|
||||
cfg.prog(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
cfg.sync(&cfg) => 0;
|
||||
lfs_testbd_erase(&bd, block) => 0;
|
||||
lfs_testbd_prog(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_sync(&bd) => 0;
|
||||
|
||||
lfs_mountcfg(&lfs, &cfg) => 0;
|
||||
lfs_dir_open(&lfs, &dir, "a") => 0;
|
||||
@@ -720,15 +720,15 @@ code = '''
|
||||
lfs_dir_close(&lfs, &dir) => 0;
|
||||
lfs_unmount(&lfs) => 0;
|
||||
uint8_t bbuffer[LFS_BLOCK_SIZE];
|
||||
cfg.read(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_read(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
int off = LFS_BLOCK_SIZE-1;
|
||||
while (off >= 0 && bbuffer[off] == LFS_ERASE_VALUE) {
|
||||
off -= 1;
|
||||
}
|
||||
memset(&bbuffer[off-3], LFS_BLOCK_SIZE, 3);
|
||||
cfg.erase(&cfg, block) => 0;
|
||||
cfg.prog(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
cfg.sync(&cfg) => 0;
|
||||
lfs_testbd_erase(&bd, block) => 0;
|
||||
lfs_testbd_prog(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_sync(&bd) => 0;
|
||||
|
||||
// corrupt the destination
|
||||
lfs_mountcfg(&lfs, &cfg) => 0;
|
||||
@@ -736,15 +736,15 @@ code = '''
|
||||
block = dir.m.pair[0];
|
||||
lfs_dir_close(&lfs, &dir) => 0;
|
||||
lfs_unmount(&lfs) => 0;
|
||||
cfg.read(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_read(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
off = LFS_BLOCK_SIZE-1;
|
||||
while (off >= 0 && bbuffer[off] == LFS_ERASE_VALUE) {
|
||||
off -= 1;
|
||||
}
|
||||
memset(&bbuffer[off-3], LFS_BLOCK_SIZE, 3);
|
||||
cfg.erase(&cfg, block) => 0;
|
||||
cfg.prog(&cfg, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
cfg.sync(&cfg) => 0;
|
||||
lfs_testbd_erase(&bd, block) => 0;
|
||||
lfs_testbd_prog(&bd, block, 0, bbuffer, LFS_BLOCK_SIZE) => 0;
|
||||
lfs_testbd_sync(&bd) => 0;
|
||||
|
||||
// continue move
|
||||
lfs_mountcfg(&lfs, &cfg) => 0;
|
||||
@@ -1569,14 +1569,14 @@ code = '''
|
||||
// force specific directories to relocate
|
||||
if (RELOCATIONS & 0x1) {
|
||||
lfs_dir_open(&lfs, &dir, "/parent");
|
||||
lfs_testbd_setwear(&cfg, dir.m.pair[0], 0xffffffff) => 0;
|
||||
lfs_testbd_setwear(&cfg, dir.m.pair[1], 0xffffffff) => 0;
|
||||
lfs_testbd_setwear(&bd, dir.m.pair[0], 0xffffffff) => 0;
|
||||
lfs_testbd_setwear(&bd, dir.m.pair[1], 0xffffffff) => 0;
|
||||
lfs_dir_close(&lfs, &dir) => 0;
|
||||
}
|
||||
if (RELOCATIONS & 0x2) {
|
||||
lfs_dir_open(&lfs, &dir, "/parent/child");
|
||||
lfs_testbd_setwear(&cfg, dir.m.pair[0], 0xffffffff) => 0;
|
||||
lfs_testbd_setwear(&cfg, dir.m.pair[1], 0xffffffff) => 0;
|
||||
lfs_testbd_setwear(&bd, dir.m.pair[0], 0xffffffff) => 0;
|
||||
lfs_testbd_setwear(&bd, dir.m.pair[1], 0xffffffff) => 0;
|
||||
lfs_dir_close(&lfs, &dir) => 0;
|
||||
}
|
||||
|
||||
@@ -1707,20 +1707,20 @@ code = '''
|
||||
// force specific directories to relocate
|
||||
if (RELOCATIONS & 0x1) {
|
||||
lfs_dir_open(&lfs, &dir, "/parent");
|
||||
lfs_testbd_setwear(&cfg, dir.m.pair[0], 0xffffffff) => 0;
|
||||
lfs_testbd_setwear(&cfg, dir.m.pair[1], 0xffffffff) => 0;
|
||||
lfs_testbd_setwear(&bd, dir.m.pair[0], 0xffffffff) => 0;
|
||||
lfs_testbd_setwear(&bd, dir.m.pair[1], 0xffffffff) => 0;
|
||||
lfs_dir_close(&lfs, &dir) => 0;
|
||||
}
|
||||
if (RELOCATIONS & 0x2) {
|
||||
lfs_dir_open(&lfs, &dir, "/parent/sibling");
|
||||
lfs_testbd_setwear(&cfg, dir.m.pair[0], 0xffffffff) => 0;
|
||||
lfs_testbd_setwear(&cfg, dir.m.pair[1], 0xffffffff) => 0;
|
||||
lfs_testbd_setwear(&bd, dir.m.pair[0], 0xffffffff) => 0;
|
||||
lfs_testbd_setwear(&bd, dir.m.pair[1], 0xffffffff) => 0;
|
||||
lfs_dir_close(&lfs, &dir) => 0;
|
||||
}
|
||||
if (RELOCATIONS & 0x4) {
|
||||
lfs_dir_open(&lfs, &dir, "/parent/child");
|
||||
lfs_testbd_setwear(&cfg, dir.m.pair[0], 0xffffffff) => 0;
|
||||
lfs_testbd_setwear(&cfg, dir.m.pair[1], 0xffffffff) => 0;
|
||||
lfs_testbd_setwear(&bd, dir.m.pair[0], 0xffffffff) => 0;
|
||||
lfs_testbd_setwear(&bd, dir.m.pair[1], 0xffffffff) => 0;
|
||||
lfs_dir_close(&lfs, &dir) => 0;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user