Message ID | 1509712671-16299-1-git-send-email-shankerd@codeaurora.org (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Hi Shanker, On 03/11/2017 13:37, Shanker Donthineni wrote: > The commit cddafd8f353d ("hw/intc/arm_gicv3_its: Implement state save > /restore") breaks the backward compatibility with the older kernels > where vITS save/restore support is not available. The vmstate function > vm_change_state_handler() should not be registered if the running kernel > doesn't support ITS save/restore feature. Otherwise VM instance will be > killed whenever vmstate callback function is invoked. > > Observed a virtual machine shutdown with QEMU-2.10+linux-4.11 when testing > the reboot command "virsh reboot <domain> --mode acpi" instead of reboot. > > KVM Error: 'KVM_SET_DEVICE_ATTR failed: Group 4 attr 0x00000000000001' > > Signed-off-by: Shanker Donthineni <shankerd@codeaurora.org> Reviewed-by: Eric Auger <eric.auger@redhat.com> Thanks for the fix. Best Regards Eric > --- > hw/intc/arm_gicv3_its_kvm.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) > > diff --git a/hw/intc/arm_gicv3_its_kvm.c b/hw/intc/arm_gicv3_its_kvm.c > index 39903d5..9b00ce5 100644 > --- a/hw/intc/arm_gicv3_its_kvm.c > +++ b/hw/intc/arm_gicv3_its_kvm.c > @@ -111,13 +111,13 @@ static void kvm_arm_its_realize(DeviceState *dev, Error **errp) > error_free(s->migration_blocker); > return; > } > + } else { > + qemu_add_vm_change_state_handler(vm_change_state_handler, s); > } > > kvm_msi_use_devid = true; > kvm_gsi_direct_mapping = false; > kvm_msi_via_irqfd_allowed = kvm_irqfds_enabled(); > - > - qemu_add_vm_change_state_handler(vm_change_state_handler, s); > } > > /** >
On 6 November 2017 at 07:30, Auger Eric <eric.auger@redhat.com> wrote: > Hi Shanker, > > On 03/11/2017 13:37, Shanker Donthineni wrote: >> The commit cddafd8f353d ("hw/intc/arm_gicv3_its: Implement state save >> /restore") breaks the backward compatibility with the older kernels >> where vITS save/restore support is not available. The vmstate function >> vm_change_state_handler() should not be registered if the running kernel >> doesn't support ITS save/restore feature. Otherwise VM instance will be >> killed whenever vmstate callback function is invoked. >> >> Observed a virtual machine shutdown with QEMU-2.10+linux-4.11 when testing >> the reboot command "virsh reboot <domain> --mode acpi" instead of reboot. >> >> KVM Error: 'KVM_SET_DEVICE_ATTR failed: Group 4 attr 0x00000000000001' >> >> Signed-off-by: Shanker Donthineni <shankerd@codeaurora.org> > Reviewed-by: Eric Auger <eric.auger@redhat.com> Applied to target-arm.next, thanks. -- PMM
diff --git a/hw/intc/arm_gicv3_its_kvm.c b/hw/intc/arm_gicv3_its_kvm.c index 39903d5..9b00ce5 100644 --- a/hw/intc/arm_gicv3_its_kvm.c +++ b/hw/intc/arm_gicv3_its_kvm.c @@ -111,13 +111,13 @@ static void kvm_arm_its_realize(DeviceState *dev, Error **errp) error_free(s->migration_blocker); return; } + } else { + qemu_add_vm_change_state_handler(vm_change_state_handler, s); } kvm_msi_use_devid = true; kvm_gsi_direct_mapping = false; kvm_msi_via_irqfd_allowed = kvm_irqfds_enabled(); - - qemu_add_vm_change_state_handler(vm_change_state_handler, s); } /**
The commit cddafd8f353d ("hw/intc/arm_gicv3_its: Implement state save /restore") breaks the backward compatibility with the older kernels where vITS save/restore support is not available. The vmstate function vm_change_state_handler() should not be registered if the running kernel doesn't support ITS save/restore feature. Otherwise VM instance will be killed whenever vmstate callback function is invoked. Observed a virtual machine shutdown with QEMU-2.10+linux-4.11 when testing the reboot command "virsh reboot <domain> --mode acpi" instead of reboot. KVM Error: 'KVM_SET_DEVICE_ATTR failed: Group 4 attr 0x00000000000001' Signed-off-by: Shanker Donthineni <shankerd@codeaurora.org> --- hw/intc/arm_gicv3_its_kvm.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-)