|
|
@@ -809,9 +809,11 @@ struct kvm_x86_state *vcpu_save_state(struct kvm_vm *vm, uint32_t vcpuid)
|
|
|
TEST_ASSERT(r == 0, "Unexpected result from KVM_GET_XSAVE, r: %i",
|
|
|
r);
|
|
|
|
|
|
- r = ioctl(vcpu->fd, KVM_GET_XCRS, &state->xcrs);
|
|
|
- TEST_ASSERT(r == 0, "Unexpected result from KVM_GET_XCRS, r: %i",
|
|
|
- r);
|
|
|
+ if (kvm_check_cap(KVM_CAP_XCRS)) {
|
|
|
+ r = ioctl(vcpu->fd, KVM_GET_XCRS, &state->xcrs);
|
|
|
+ TEST_ASSERT(r == 0, "Unexpected result from KVM_GET_XCRS, r: %i",
|
|
|
+ r);
|
|
|
+ }
|
|
|
|
|
|
r = ioctl(vcpu->fd, KVM_GET_SREGS, &state->sregs);
|
|
|
TEST_ASSERT(r == 0, "Unexpected result from KVM_GET_SREGS, r: %i",
|
|
|
@@ -858,9 +860,11 @@ void vcpu_load_state(struct kvm_vm *vm, uint32_t vcpuid, struct kvm_x86_state *s
|
|
|
TEST_ASSERT(r == 0, "Unexpected result from KVM_SET_XSAVE, r: %i",
|
|
|
r);
|
|
|
|
|
|
- r = ioctl(vcpu->fd, KVM_SET_XCRS, &state->xcrs);
|
|
|
- TEST_ASSERT(r == 0, "Unexpected result from KVM_SET_XCRS, r: %i",
|
|
|
- r);
|
|
|
+ if (kvm_check_cap(KVM_CAP_XCRS)) {
|
|
|
+ r = ioctl(vcpu->fd, KVM_SET_XCRS, &state->xcrs);
|
|
|
+ TEST_ASSERT(r == 0, "Unexpected result from KVM_SET_XCRS, r: %i",
|
|
|
+ r);
|
|
|
+ }
|
|
|
|
|
|
r = ioctl(vcpu->fd, KVM_SET_SREGS, &state->sregs);
|
|
|
TEST_ASSERT(r == 0, "Unexpected result from KVM_SET_SREGS, r: %i",
|