From: Amjad Alsharafi Date: Sat, 20 Jul 2024 10:13:30 +0000 (+0800) Subject: vvfat: Fix bug in writing to middle of file X-Git-Tag: v8.2.7~34 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=8804697ba635b301cd00733068d0a393bf5f0b6a;p=thirdparty%2Fqemu.git vvfat: Fix bug in writing to middle of file Before this commit, the behavior when calling `commit_one_file` for example with `offset=0x2000` (second cluster), what will happen is that we won't fetch the next cluster from the fat, and instead use the first cluster for the read operation. This is due to off-by-one error here, where `i=0x2000 !< offset=0x2000`, thus not fetching the next cluster. Signed-off-by: Amjad Alsharafi Reviewed-by: Kevin Wolf Tested-by: Kevin Wolf Message-ID: Signed-off-by: Kevin Wolf (cherry picked from commit b881cf00c99e03bc8a3648581f97736ff275b18b) Signed-off-by: Michael Tokarev --- diff --git a/block/vvfat.c b/block/vvfat.c index 9d050ba3aea..19da009a5b0 100644 --- a/block/vvfat.c +++ b/block/vvfat.c @@ -2525,8 +2525,9 @@ commit_one_file(BDRVVVFATState* s, int dir_index, uint32_t offset) return -1; } - for (i = s->cluster_size; i < offset; i += s->cluster_size) + for (i = 0; i < offset; i += s->cluster_size) { c = modified_fat_get(s, c); + } fd = qemu_open_old(mapping->path, O_RDWR | O_CREAT | O_BINARY, 0666); if (fd < 0) {