mirror of https://github.com/ARMmbed/mbed-os.git
				
				
				
			Merge pull request #6338 from geky/fix-littlefs-dir-chain
littlefs: Fix issue updating dir struct when extended dir chainpull/6401/merge
						commit
						7ab4b064e5
					
				| 
						 | 
				
			
			@ -658,17 +658,17 @@ static int lfs_dir_append(lfs_t *lfs, lfs_dir_t *dir,
 | 
			
		|||
 | 
			
		||||
        // we need to allocate a new dir block
 | 
			
		||||
        if (!(0x80000000 & dir->d.size)) {
 | 
			
		||||
            lfs_dir_t newdir;
 | 
			
		||||
            int err = lfs_dir_alloc(lfs, &newdir);
 | 
			
		||||
            lfs_dir_t olddir = *dir;
 | 
			
		||||
            int err = lfs_dir_alloc(lfs, dir);
 | 
			
		||||
            if (err) {
 | 
			
		||||
                return err;
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            newdir.d.tail[0] = dir->d.tail[0];
 | 
			
		||||
            newdir.d.tail[1] = dir->d.tail[1];
 | 
			
		||||
            entry->off = newdir.d.size - 4;
 | 
			
		||||
            dir->d.tail[0] = olddir.d.tail[0];
 | 
			
		||||
            dir->d.tail[1] = olddir.d.tail[1];
 | 
			
		||||
            entry->off = dir->d.size - 4;
 | 
			
		||||
            lfs_entry_tole32(&entry->d);
 | 
			
		||||
            err = lfs_dir_commit(lfs, &newdir, (struct lfs_region[]){
 | 
			
		||||
            err = lfs_dir_commit(lfs, dir, (struct lfs_region[]){
 | 
			
		||||
                    {entry->off, 0, &entry->d, sizeof(entry->d)},
 | 
			
		||||
                    {entry->off, 0, data, entry->d.nlen}
 | 
			
		||||
                }, 2);
 | 
			
		||||
| 
						 | 
				
			
			@ -677,10 +677,10 @@ static int lfs_dir_append(lfs_t *lfs, lfs_dir_t *dir,
 | 
			
		|||
                return err;
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            dir->d.size |= 0x80000000;
 | 
			
		||||
            dir->d.tail[0] = newdir.pair[0];
 | 
			
		||||
            dir->d.tail[1] = newdir.pair[1];
 | 
			
		||||
            return lfs_dir_commit(lfs, dir, NULL, 0);
 | 
			
		||||
            olddir.d.size |= 0x80000000;
 | 
			
		||||
            olddir.d.tail[0] = dir->pair[0];
 | 
			
		||||
            olddir.d.tail[1] = dir->pair[1];
 | 
			
		||||
            return lfs_dir_commit(lfs, &olddir, NULL, 0);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        int err = lfs_dir_fetch(lfs, dir, dir->d.tail);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -118,6 +118,7 @@ tests/test.py << TEST
 | 
			
		|||
        sprintf((char*)buffer, "test%d", i);
 | 
			
		||||
        lfs_dir_read(&lfs, &dir[0], &info) => 1;
 | 
			
		||||
        strcmp(info.name, (char*)buffer) => 0;
 | 
			
		||||
        info.type => LFS_TYPE_DIR;
 | 
			
		||||
    }
 | 
			
		||||
    lfs_dir_read(&lfs, &dir[0], &info) => 0;
 | 
			
		||||
    lfs_unmount(&lfs) => 0;
 | 
			
		||||
| 
						 | 
				
			
			@ -355,5 +356,70 @@ tests/test.py << TEST
 | 
			
		|||
    lfs_unmount(&lfs) => 0;
 | 
			
		||||
TEST
 | 
			
		||||
 | 
			
		||||
echo "--- Multi-block directory with files ---"
 | 
			
		||||
tests/test.py << TEST
 | 
			
		||||
    lfs_mount(&lfs, &cfg) => 0;
 | 
			
		||||
    lfs_mkdir(&lfs, "prickly-pear") => 0;
 | 
			
		||||
    for (int i = 0; i < $LARGESIZE; i++) {
 | 
			
		||||
        sprintf((char*)buffer, "prickly-pear/test%d", i);
 | 
			
		||||
        lfs_file_open(&lfs, &file[0], (char*)buffer,
 | 
			
		||||
                LFS_O_WRONLY | LFS_O_CREAT) => 0;
 | 
			
		||||
        size = 6;
 | 
			
		||||
        memcpy(wbuffer, "Hello", size);
 | 
			
		||||
        lfs_file_write(&lfs, &file[0], wbuffer, size) => size;
 | 
			
		||||
        lfs_file_close(&lfs, &file[0]) => 0;
 | 
			
		||||
    }
 | 
			
		||||
    lfs_unmount(&lfs) => 0;
 | 
			
		||||
TEST
 | 
			
		||||
tests/test.py << TEST
 | 
			
		||||
    lfs_mount(&lfs, &cfg) => 0;
 | 
			
		||||
    lfs_dir_open(&lfs, &dir[0], "prickly-pear") => 0;
 | 
			
		||||
    lfs_dir_read(&lfs, &dir[0], &info) => 1;
 | 
			
		||||
    strcmp(info.name, ".") => 0;
 | 
			
		||||
    info.type => LFS_TYPE_DIR;
 | 
			
		||||
    lfs_dir_read(&lfs, &dir[0], &info) => 1;
 | 
			
		||||
    strcmp(info.name, "..") => 0;
 | 
			
		||||
    info.type => LFS_TYPE_DIR;
 | 
			
		||||
    for (int i = 0; i < $LARGESIZE; i++) {
 | 
			
		||||
        sprintf((char*)buffer, "test%d", i);
 | 
			
		||||
        lfs_dir_read(&lfs, &dir[0], &info) => 1;
 | 
			
		||||
        strcmp(info.name, (char*)buffer) => 0;
 | 
			
		||||
        info.type => LFS_TYPE_REG;
 | 
			
		||||
        info.size => 6;
 | 
			
		||||
    }
 | 
			
		||||
    lfs_dir_read(&lfs, &dir[0], &info) => 0;
 | 
			
		||||
    lfs_unmount(&lfs) => 0;
 | 
			
		||||
TEST
 | 
			
		||||
 | 
			
		||||
echo "--- Multi-block remove with files ---"
 | 
			
		||||
tests/test.py << TEST
 | 
			
		||||
    lfs_mount(&lfs, &cfg) => 0;
 | 
			
		||||
    lfs_remove(&lfs, "prickly-pear") => LFS_ERR_NOTEMPTY;
 | 
			
		||||
 | 
			
		||||
    for (int i = 0; i < $LARGESIZE; i++) {
 | 
			
		||||
        sprintf((char*)buffer, "prickly-pear/test%d", i);
 | 
			
		||||
        lfs_remove(&lfs, (char*)buffer) => 0;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    lfs_remove(&lfs, "prickly-pear") => 0;
 | 
			
		||||
    lfs_unmount(&lfs) => 0;
 | 
			
		||||
TEST
 | 
			
		||||
tests/test.py << TEST
 | 
			
		||||
    lfs_mount(&lfs, &cfg) => 0;
 | 
			
		||||
    lfs_dir_open(&lfs, &dir[0], "/") => 0;
 | 
			
		||||
    lfs_dir_read(&lfs, &dir[0], &info) => 1;
 | 
			
		||||
    strcmp(info.name, ".") => 0;
 | 
			
		||||
    info.type => LFS_TYPE_DIR;
 | 
			
		||||
    lfs_dir_read(&lfs, &dir[0], &info) => 1;
 | 
			
		||||
    strcmp(info.name, "..") => 0;
 | 
			
		||||
    info.type => LFS_TYPE_DIR;
 | 
			
		||||
    lfs_dir_read(&lfs, &dir[0], &info) => 1;
 | 
			
		||||
    strcmp(info.name, "burito") => 0;
 | 
			
		||||
    info.type => LFS_TYPE_REG;
 | 
			
		||||
    lfs_dir_read(&lfs, &dir[0], &info) => 0;
 | 
			
		||||
    lfs_dir_close(&lfs, &dir[0]) => 0;
 | 
			
		||||
    lfs_unmount(&lfs) => 0;
 | 
			
		||||
TEST
 | 
			
		||||
 | 
			
		||||
echo "--- Results ---"
 | 
			
		||||
tests/stats.py
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -135,5 +135,24 @@ tests/test.py << TEST
 | 
			
		|||
    lfs_unmount(&lfs) => 0;
 | 
			
		||||
TEST
 | 
			
		||||
 | 
			
		||||
echo "--- Many file test ---"
 | 
			
		||||
tests/test.py << TEST
 | 
			
		||||
    lfs_format(&lfs, &cfg) => 0;
 | 
			
		||||
TEST
 | 
			
		||||
tests/test.py << TEST
 | 
			
		||||
    // Create 300 files of 6 bytes
 | 
			
		||||
    lfs_mount(&lfs, &cfg) => 0;
 | 
			
		||||
    lfs_mkdir(&lfs, "directory") => 0;
 | 
			
		||||
    for (unsigned i = 0; i < 300; i++) {
 | 
			
		||||
        snprintf((char*)buffer, sizeof(buffer), "file_%03d", i);
 | 
			
		||||
        lfs_file_open(&lfs, &file[0], (char*)buffer, LFS_O_WRONLY | LFS_O_CREAT) => 0;
 | 
			
		||||
        size = 6;
 | 
			
		||||
        memcpy(wbuffer, "Hello", size);
 | 
			
		||||
        lfs_file_write(&lfs, &file[0], wbuffer, size) => size;
 | 
			
		||||
        lfs_file_close(&lfs, &file[0]) => 0;
 | 
			
		||||
    }
 | 
			
		||||
    lfs_unmount(&lfs) => 0;
 | 
			
		||||
TEST
 | 
			
		||||
 | 
			
		||||
echo "--- Results ---"
 | 
			
		||||
tests/stats.py
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue