[cases.bench_dir_open] # 0 = in-order # 1 = reversed-order # 2 = random-order defines.ORDER = [0, 1, 2] defines.N = 1024 defines.FILE_SIZE = 8 defines.CHUNK_SIZE = 8 code = ''' lfs_t lfs; lfs_format(&lfs, cfg) => 0; lfs_mount(&lfs, cfg) => 0; // first create the files char name[256]; uint8_t buffer[CHUNK_SIZE]; for (lfs_size_t i = 0; i < N; i++) { sprintf(name, "file%08x", i); lfs_file_t file; lfs_file_open(&lfs, &file, name, LFS_O_WRONLY | LFS_O_CREAT | LFS_O_EXCL) => 0; uint32_t file_prng = i; for (lfs_size_t j = 0; j < FILE_SIZE; j += CHUNK_SIZE) { for (lfs_size_t k = 0; k < CHUNK_SIZE; k++) { buffer[k] = BENCH_PRNG(&file_prng); } lfs_file_write(&lfs, &file, buffer, CHUNK_SIZE) => CHUNK_SIZE; } lfs_file_close(&lfs, &file) => 0; } // then read the files BENCH_START(); uint32_t prng = 42; for (lfs_size_t i = 0; i < N; i++) { lfs_off_t i_ = (ORDER == 0) ? i : (ORDER == 1) ? (N-1-i) : BENCH_PRNG(&prng) % N; sprintf(name, "file%08x", i_); lfs_file_t file; lfs_file_open(&lfs, &file, name, LFS_O_RDONLY) => 0; uint32_t file_prng = i_; for (lfs_size_t j = 0; j < FILE_SIZE; j += CHUNK_SIZE) { lfs_file_read(&lfs, &file, buffer, CHUNK_SIZE) => CHUNK_SIZE; for (lfs_size_t k = 0; k < CHUNK_SIZE; k++) { assert(buffer[k] == BENCH_PRNG(&file_prng)); } } lfs_file_close(&lfs, &file) => 0; } BENCH_STOP(); lfs_unmount(&lfs) => 0; ''' [cases.bench_dir_creat] # 0 = in-order # 1 = reversed-order # 2 = random-order defines.ORDER = [0, 1, 2] defines.N = 1024 defines.FILE_SIZE = 8 defines.CHUNK_SIZE = 8 code = ''' lfs_t lfs; lfs_format(&lfs, cfg) => 0; lfs_mount(&lfs, cfg) => 0; BENCH_START(); uint32_t prng = 42; char name[256]; uint8_t buffer[CHUNK_SIZE]; for (lfs_size_t i = 0; i < N; i++) { lfs_off_t i_ = (ORDER == 0) ? i : (ORDER == 1) ? (N-1-i) : BENCH_PRNG(&prng) % N; sprintf(name, "file%08x", i_); lfs_file_t file; lfs_file_open(&lfs, &file, name, LFS_O_WRONLY | LFS_O_CREAT | LFS_O_TRUNC) => 0; uint32_t file_prng = i_; for (lfs_size_t j = 0; j < FILE_SIZE; j += CHUNK_SIZE) { for (lfs_size_t k = 0; k < CHUNK_SIZE; k++) { buffer[k] = BENCH_PRNG(&file_prng); } lfs_file_write(&lfs, &file, buffer, CHUNK_SIZE) => CHUNK_SIZE; } lfs_file_close(&lfs, &file) => 0; } BENCH_STOP(); lfs_unmount(&lfs) => 0; ''' [cases.bench_dir_remove] # 0 = in-order # 1 = reversed-order # 2 = random-order defines.ORDER = [0, 1, 2] defines.N = 1024 defines.FILE_SIZE = 8 defines.CHUNK_SIZE = 8 code = ''' lfs_t lfs; lfs_format(&lfs, cfg) => 0; lfs_mount(&lfs, cfg) => 0; // first create the files char name[256]; uint8_t buffer[CHUNK_SIZE]; for (lfs_size_t i = 0; i < N; i++) { sprintf(name, "file%08x", i); lfs_file_t file; lfs_file_open(&lfs, &file, name, LFS_O_WRONLY | LFS_O_CREAT | LFS_O_EXCL) => 0; uint32_t file_prng = i; for (lfs_size_t j = 0; j < FILE_SIZE; j += CHUNK_SIZE) { for (lfs_size_t k = 0; k < CHUNK_SIZE; k++) { buffer[k] = BENCH_PRNG(&file_prng); } lfs_file_write(&lfs, &file, buffer, CHUNK_SIZE) => CHUNK_SIZE; } lfs_file_close(&lfs, &file) => 0; } // then remove the files BENCH_START(); uint32_t prng = 42; for (lfs_size_t i = 0; i < N; i++) { lfs_off_t i_ = (ORDER == 0) ? i : (ORDER == 1) ? (N-1-i) : BENCH_PRNG(&prng) % N; sprintf(name, "file%08x", i_); int err = lfs_remove(&lfs, name); assert(!err || err == LFS_ERR_NOENT); } BENCH_STOP(); lfs_unmount(&lfs) => 0; ''' [cases.bench_dir_read] defines.N = 1024 defines.FILE_SIZE = 8 defines.CHUNK_SIZE = 8 code = ''' lfs_t lfs; lfs_format(&lfs, cfg) => 0; lfs_mount(&lfs, cfg) => 0; // first create the files char name[256]; uint8_t buffer[CHUNK_SIZE]; for (lfs_size_t i = 0; i < N; i++) { sprintf(name, "file%08x", i); lfs_file_t file; lfs_file_open(&lfs, &file, name, LFS_O_WRONLY | LFS_O_CREAT | LFS_O_EXCL) => 0; uint32_t file_prng = i; for (lfs_size_t j = 0; j < FILE_SIZE; j += CHUNK_SIZE) { for (lfs_size_t k = 0; k < CHUNK_SIZE; k++) { buffer[k] = BENCH_PRNG(&file_prng); } lfs_file_write(&lfs, &file, buffer, CHUNK_SIZE) => CHUNK_SIZE; } lfs_file_close(&lfs, &file) => 0; } // then read the directory BENCH_START(); lfs_dir_t dir; lfs_dir_open(&lfs, &dir, "/") => 0; struct lfs_info info; lfs_dir_read(&lfs, &dir, &info) => 1; assert(info.type == LFS_TYPE_DIR); assert(strcmp(info.name, ".") == 0); lfs_dir_read(&lfs, &dir, &info) => 1; assert(info.type == LFS_TYPE_DIR); assert(strcmp(info.name, "..") == 0); for (int i = 0; i < N; i++) { sprintf(name, "file%08x", i); lfs_dir_read(&lfs, &dir, &info) => 1; assert(info.type == LFS_TYPE_REG); assert(strcmp(info.name, name) == 0); } lfs_dir_read(&lfs, &dir, &info) => 0; lfs_dir_close(&lfs, &dir) => 0; BENCH_STOP(); lfs_unmount(&lfs) => 0; ''' [cases.bench_dir_mkdir] # 0 = in-order # 1 = reversed-order # 2 = random-order defines.ORDER = [0, 1, 2] defines.N = 8 code = ''' lfs_t lfs; lfs_format(&lfs, cfg) => 0; lfs_mount(&lfs, cfg) => 0; BENCH_START(); uint32_t prng = 42; char name[256]; for (lfs_size_t i = 0; i < N; i++) { lfs_off_t i_ = (ORDER == 0) ? i : (ORDER == 1) ? (N-1-i) : BENCH_PRNG(&prng) % N; printf("hm %d\n", i); sprintf(name, "dir%08x", i_); int err = lfs_mkdir(&lfs, name); assert(!err || err == LFS_ERR_EXIST); } BENCH_STOP(); lfs_unmount(&lfs) => 0; ''' [cases.bench_dir_rmdir] # 0 = in-order # 1 = reversed-order # 2 = random-order defines.ORDER = [0, 1, 2] defines.N = 8 code = ''' lfs_t lfs; lfs_format(&lfs, cfg) => 0; lfs_mount(&lfs, cfg) => 0; // first create the dirs char name[256]; for (lfs_size_t i = 0; i < N; i++) { sprintf(name, "dir%08x", i); lfs_mkdir(&lfs, name) => 0; } // then remove the dirs BENCH_START(); uint32_t prng = 42; for (lfs_size_t i = 0; i < N; i++) { lfs_off_t i_ = (ORDER == 0) ? i : (ORDER == 1) ? (N-1-i) : BENCH_PRNG(&prng) % N; sprintf(name, "dir%08x", i_); int err = lfs_remove(&lfs, name); assert(!err || err == LFS_ERR_NOENT); } BENCH_STOP(); lfs_unmount(&lfs) => 0; '''