aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorWilliam Roche <william.roche@oracle.com>2025-01-22 19:40:53 +0000
committerPeter Xu <peterx@redhat.com>2025-02-11 16:37:05 -0500
commitf051a9c4dc70cd1b6eafa61aec8f3b9344e02e85 (patch)
tree5468f3003ace14e070bba5976578bae3c36e5917
parentffaf7f0376f8040ce9068d71ae9ae8722505c42e (diff)
downloadqemu-f051a9c4dc70cd1b6eafa61aec8f3b9344e02e85.zip
qemu-f051a9c4dc70cd1b6eafa61aec8f3b9344e02e85.tar.gz
qemu-f051a9c4dc70cd1b6eafa61aec8f3b9344e02e85.tar.bz2
system/physmem: take into account fd_offset for file fallocate
Punching a hole in a file with fallocate needs to take into account the fd_offset value for a correct file location. But guest_memfd internal use doesn't currently consider fd_offset. Fixes: 4b870dc4d0c0 ("hostmem-file: add offset option") Signed-off-by: William Roche <william.roche@oracle.com> Reviewed-by: Peter Xu <peterx@redhat.com> Reviewed-by: David Hildenbrand <david@redhat.com> Link: https://lore.kernel.org/r/20250122194053.3103617-2-william.roche@oracle.com Signed-off-by: Peter Xu <peterx@redhat.com>
-rw-r--r--system/physmem.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/system/physmem.c b/system/physmem.c
index 67c9db9..235015f 100644
--- a/system/physmem.c
+++ b/system/physmem.c
@@ -3797,18 +3797,19 @@ int ram_block_discard_range(RAMBlock *rb, uint64_t start, size_t length)
}
ret = fallocate(rb->fd, FALLOC_FL_PUNCH_HOLE | FALLOC_FL_KEEP_SIZE,
- start, length);
+ start + rb->fd_offset, length);
if (ret) {
ret = -errno;
- error_report("%s: Failed to fallocate %s:%" PRIx64 " +%zx (%d)",
- __func__, rb->idstr, start, length, ret);
+ error_report("%s: Failed to fallocate %s:%" PRIx64 "+%" PRIx64
+ " +%zx (%d)", __func__, rb->idstr, start,
+ rb->fd_offset, length, ret);
goto err;
}
#else
ret = -ENOSYS;
error_report("%s: fallocate not available/file"
- "%s:%" PRIx64 " +%zx (%d)",
- __func__, rb->idstr, start, length, ret);
+ "%s:%" PRIx64 "+%" PRIx64 " +%zx (%d)", __func__,
+ rb->idstr, start, rb->fd_offset, length, ret);
goto err;
#endif
}
@@ -3855,6 +3856,7 @@ int ram_block_discard_guest_memfd_range(RAMBlock *rb, uint64_t start,
int ret = -1;
#ifdef CONFIG_FALLOCATE_PUNCH_HOLE
+ /* ignore fd_offset with guest_memfd */
ret = fallocate(rb->guest_memfd, FALLOC_FL_PUNCH_HOLE | FALLOC_FL_KEEP_SIZE,
start, length);