diff options
author | Ross Lagerwall <ross.lagerwall@citrix.com> | 2022-08-01 15:25:25 +0100 |
---|---|---|
committer | Stefan Berger <stefanb@linux.ibm.com> | 2022-09-09 17:55:45 -0400 |
commit | a0bcec03761477371ff7c2e80dc07fff14222d92 (patch) | |
tree | 9bdd6968b7d5bfbc7c08ae16a3ba808999bd4e9b | |
parent | 79dfa177ae348bb5ab5f97c0915359b13d6186e2 (diff) | |
download | qemu-a0bcec03761477371ff7c2e80dc07fff14222d92.zip qemu-a0bcec03761477371ff7c2e80dc07fff14222d92.tar.gz qemu-a0bcec03761477371ff7c2e80dc07fff14222d92.tar.bz2 |
tpm_emulator: Avoid double initialization during migration
When resuming after a migration, the backend sends CMD_INIT to the
emulator from the startup callback, then it sends the migration state
from the vmstate to the emulator, then it sends CMD_INIT again. Skip the
first CMD_INIT during a migration to avoid initializing the TPM twice.
Signed-off-by: Ross Lagerwall <ross.lagerwall@citrix.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Tested-by: Stefan Berger <stefanb@linux.ibm.com>
Signed-off-by: Stefan Berger <stefanb@linux.ibm.com>
-rw-r--r-- | backends/tpm/tpm_emulator.c | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/backends/tpm/tpm_emulator.c b/backends/tpm/tpm_emulator.c index 87d061e..9b50c5b 100644 --- a/backends/tpm/tpm_emulator.c +++ b/backends/tpm/tpm_emulator.c @@ -32,6 +32,7 @@ #include "qemu/sockets.h" #include "qemu/lockable.h" #include "io/channel-socket.h" +#include "sysemu/runstate.h" #include "sysemu/tpm_backend.h" #include "sysemu/tpm_util.h" #include "tpm_int.h" @@ -383,6 +384,15 @@ err_exit: static int tpm_emulator_startup_tpm(TPMBackend *tb, size_t buffersize) { + /* TPM startup will be done from post_load hook */ + if (runstate_check(RUN_STATE_INMIGRATE)) { + if (buffersize != 0) { + return tpm_emulator_set_buffer_size(tb, buffersize, NULL); + } + + return 0; + } + return tpm_emulator_startup_tpm_resume(tb, buffersize, false); } |