aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMaksim Kostin <maksim.kostin@ispras.ru>2023-08-09 13:07:33 +0300
committerMichael Tokarev <mjt@tls.msk.ru>2023-09-10 19:39:41 +0300
commitfcb49ea23c39dd93b8e1d4e0edae67967d28e001 (patch)
tree98d76e62dc6f1f423064f8d05876a554579527d0
parente8bb4dc55a9a8e52f55c17ee9b50d7436a672881 (diff)
downloadqemu-fcb49ea23c39dd93b8e1d4e0edae67967d28e001.zip
qemu-fcb49ea23c39dd93b8e1d4e0edae67967d28e001.tar.gz
qemu-fcb49ea23c39dd93b8e1d4e0edae67967d28e001.tar.bz2
hw/ppc/e500: fix broken snapshot replay
ppce500_reset_device_tree is registered for system reset, but after c4b075318eb1 this function rerandomizes rng-seed via qemu_guest_getrandom_nofail. And when loading a snapshot, it tries to read EVENT_RANDOM that doesn't exist, so we have an error: qemu-system-ppc: Missing random event in the replay log To fix this, use qemu_register_reset_nosnapshotload instead of qemu_register_reset. Reported-by: Vitaly Cheptsov <cheptsov@ispras.ru> Fixes: c4b075318eb1 ("hw/ppc: pass random seed to fdt ") Resolves: https://gitlab.com/qemu-project/qemu/-/issues/1634 Signed-off-by: Maksim Kostin <maksim.kostin@ispras.ru> Reviewed-by: Nicholas Piggin <npiggin@gmail.com> Signed-off-by: Cédric Le Goater <clg@kaod.org> (cherry picked from commit 6ec65b69ba17c954414fa23a397fb8a3fcfb4a43) Signed-off-by: Michael Tokarev <mjt@tls.msk.ru>
-rw-r--r--hw/ppc/e500.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/hw/ppc/e500.c b/hw/ppc/e500.c
index 117c9c0..27d83a4 100644
--- a/hw/ppc/e500.c
+++ b/hw/ppc/e500.c
@@ -712,7 +712,7 @@ static int ppce500_prep_device_tree(PPCE500MachineState *machine,
p->kernel_base = kernel_base;
p->kernel_size = kernel_size;
- qemu_register_reset(ppce500_reset_device_tree, p);
+ qemu_register_reset_nosnapshotload(ppce500_reset_device_tree, p);
p->notifier.notify = ppce500_init_notify;
qemu_add_machine_init_done_notifier(&p->notifier);