summaryrefslogtreecommitdiffstats
path: root/accel/kvm/kvm-cpus.c
diff options
context:
space:
mode:
authorDr. David Alan Gilbert2020-07-23 18:09:15 +0200
committerPaolo Bonzini2020-10-05 16:41:22 +0200
commitd0a92b353efa2ca3c2847ad38f088b16d1278290 (patch)
tree4462865ab7152fa62114783cd6702ae30ddcd5f6 /accel/kvm/kvm-cpus.c
parentkvm: remove kvm specific functions from global includes (diff)
downloadqemu-d0a92b353efa2ca3c2847ad38f088b16d1278290.tar.gz
qemu-d0a92b353efa2ca3c2847ad38f088b16d1278290.tar.xz
qemu-d0a92b353efa2ca3c2847ad38f088b16d1278290.zip
kvm: kvm_init_vcpu take Error pointer
Clean up the error handling in kvm_init_vcpu so we can see what went wrong more easily. Make it take an Error ** and fill it out with what failed, including the cpu id, so you can tell if it only fails at a given ID. Replace the remaining DPRINTF by a trace. This turns a: kvm_init_vcpu failed: Invalid argument into: kvm_init_vcpu: kvm_get_vcpu failed (256): Invalid argument and with the trace you then get to see: 19049@1595520414.310107:kvm_init_vcpu index: 169 id: 212 19050@1595520414.310635:kvm_init_vcpu index: 170 id: 256 qemu-system-x86_64: kvm_init_vcpu: kvm_get_vcpu failed (256): Invalid argument which makes stuff a lot more obvious. Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com> Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com> Message-Id: <20200723160915.129069-1-dgilbert@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'accel/kvm/kvm-cpus.c')
-rw-r--r--accel/kvm/kvm-cpus.c8
1 files changed, 2 insertions, 6 deletions
diff --git a/accel/kvm/kvm-cpus.c b/accel/kvm/kvm-cpus.c
index a120601564..d809b1e74c 100644
--- a/accel/kvm/kvm-cpus.c
+++ b/accel/kvm/kvm-cpus.c
@@ -20,6 +20,7 @@
#include "sysemu/runstate.h"
#include "sysemu/cpus.h"
#include "qemu/guest-random.h"
+#include "qapi/error.h"
#include "kvm-cpus.h"
@@ -36,12 +37,7 @@ static void *kvm_vcpu_thread_fn(void *arg)
cpu->can_do_io = 1;
current_cpu = cpu;
- r = kvm_init_vcpu(cpu);
- if (r < 0) {
- error_report("kvm_init_vcpu failed: %s", strerror(-r));
- exit(1);
- }
-
+ r = kvm_init_vcpu(cpu, &error_fatal);
kvm_init_cpu_signals(cpu);
/* signal CPU creation */