|
@@ -702,7 +702,7 @@ static int kvm_mips_get_reg(struct kvm_vcpu *vcpu,
|
|
} else if ((reg->id & KVM_REG_SIZE_MASK) == KVM_REG_SIZE_U128) {
|
|
} else if ((reg->id & KVM_REG_SIZE_MASK) == KVM_REG_SIZE_U128) {
|
|
void __user *uaddr = (void __user *)(long)reg->addr;
|
|
void __user *uaddr = (void __user *)(long)reg->addr;
|
|
|
|
|
|
- return copy_to_user(uaddr, vs, 16);
|
|
|
|
|
|
+ return copy_to_user(uaddr, vs, 16) ? -EFAULT : 0;
|
|
} else {
|
|
} else {
|
|
return -EINVAL;
|
|
return -EINVAL;
|
|
}
|
|
}
|
|
@@ -732,7 +732,7 @@ static int kvm_mips_set_reg(struct kvm_vcpu *vcpu,
|
|
} else if ((reg->id & KVM_REG_SIZE_MASK) == KVM_REG_SIZE_U128) {
|
|
} else if ((reg->id & KVM_REG_SIZE_MASK) == KVM_REG_SIZE_U128) {
|
|
void __user *uaddr = (void __user *)(long)reg->addr;
|
|
void __user *uaddr = (void __user *)(long)reg->addr;
|
|
|
|
|
|
- return copy_from_user(vs, uaddr, 16);
|
|
|
|
|
|
+ return copy_from_user(vs, uaddr, 16) ? -EFAULT : 0;
|
|
} else {
|
|
} else {
|
|
return -EINVAL;
|
|
return -EINVAL;
|
|
}
|
|
}
|