Commit 8114cd44c8 for qemu.org
commit 8114cd44c8a18d92a715fa77d6c136c67f807d20
Author: Nikolai Barybin <nikolai.barybin@virtuozzo.com>
Date: Thu Sep 11 15:36:55 2025 +0300
dump: enhance dump_state_prepare fd initialization
Initializing descriptor with zero is unsafe: during cleanup we risk to
unconditional close of fd == 0 in case dump state wasn't fully
initialized. Thus, let's init fd with -1 value and check its value
before closing it.
Signed-off-by: Nikolai Barybin <nikolai.barybin@virtuozzo.com>
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <20250911123656.413160-2-nikolai.barybin@virtuozzo.com>
diff --git a/dump/dump.c b/dump/dump.c
index 80ed6c8d21..1f216e74f5 100644
--- a/dump/dump.c
+++ b/dump/dump.c
@@ -104,7 +104,10 @@ static int dump_cleanup(DumpState *s)
guest_phys_blocks_free(&s->guest_phys_blocks);
memory_mapping_list_free(&s->list);
- close(s->fd);
+ if (s->fd != -1) {
+ close(s->fd);
+ }
+ s->fd = -1;
g_free(s->guest_note);
g_clear_pointer(&s->string_table_buf, g_array_unref);
s->guest_note = NULL;
@@ -1709,8 +1712,8 @@ static DumpState dump_state_global = { .status = DUMP_STATUS_NONE };
static void dump_state_prepare(DumpState *s)
{
- /* zero the struct, setting status to active */
- *s = (DumpState) { .status = DUMP_STATUS_ACTIVE };
+ /* zero the struct, setting status to active and fd to -1 */
+ *s = (DumpState) { .fd = -1, .status = DUMP_STATUS_ACTIVE };
}
bool qemu_system_dump_in_progress(void)