summaryrefslogtreecommitdiff
path: root/arch/arm64/kvm/vgic-sys-reg-v3.c
diff options
context:
space:
mode:
authorMarc Zyngier <maz@kernel.org>2022-07-04 10:07:44 +0300
committerMarc Zyngier <maz@kernel.org>2022-07-17 13:55:33 +0300
commitdb25081e147c3cc496b8cd8c9d67f992546df6d5 (patch)
tree652a47469902ee86f6bc1f433b560cdb56843475 /arch/arm64/kvm/vgic-sys-reg-v3.c
parentb61fc0857a3ad4cdee44128ad13685033e237367 (diff)
downloadlinux-db25081e147c3cc496b8cd8c9d67f992546df6d5.tar.xz
KVM: arm64: vgic-v3: Push user access into vgic_v3_cpu_sysregs_uaccess()
In order to start making the vgic sysreg access from userspace similar to all the other sysregs, push the userspace memory access one level down into vgic_v3_cpu_sysregs_uaccess(). The next step will be to rely on the sysreg infrastructure to perform this task. Reviewed-by: Reiji Watanabe <reijiw@google.com> Signed-off-by: Marc Zyngier <maz@kernel.org>
Diffstat (limited to 'arch/arm64/kvm/vgic-sys-reg-v3.c')
-rw-r--r--arch/arm64/kvm/vgic-sys-reg-v3.c22
1 files changed, 15 insertions, 7 deletions
diff --git a/arch/arm64/kvm/vgic-sys-reg-v3.c b/arch/arm64/kvm/vgic-sys-reg-v3.c
index 85a5e1d15e9f..88eb5b049c2c 100644
--- a/arch/arm64/kvm/vgic-sys-reg-v3.c
+++ b/arch/arm64/kvm/vgic-sys-reg-v3.c
@@ -278,15 +278,21 @@ int vgic_v3_has_cpu_sysregs_attr(struct kvm_vcpu *vcpu, struct kvm_device_attr *
return -ENXIO;
}
-int vgic_v3_cpu_sysregs_uaccess(struct kvm_vcpu *vcpu, bool is_write, u64 id,
- u64 *reg)
+int vgic_v3_cpu_sysregs_uaccess(struct kvm_vcpu *vcpu,
+ struct kvm_device_attr *attr,
+ bool is_write)
{
+ u64 __user *uaddr = (u64 __user *)(long)attr->addr;
struct sys_reg_params params;
const struct sys_reg_desc *r;
- u64 sysreg = (id & KVM_DEV_ARM_VGIC_SYSREG_MASK) | KVM_REG_SIZE_U64;
+ u64 sysreg;
- if (is_write)
- params.regval = *reg;
+ sysreg = attr_to_id(attr->attr);
+
+ if (is_write) {
+ if (get_user(params.regval, uaddr))
+ return -EFAULT;
+ }
params.is_write = is_write;
r = find_reg_by_id(sysreg, &params, gic_v3_icc_reg_descs,
@@ -297,8 +303,10 @@ int vgic_v3_cpu_sysregs_uaccess(struct kvm_vcpu *vcpu, bool is_write, u64 id,
if (!r->access(vcpu, &params, r))
return -EINVAL;
- if (!is_write)
- *reg = params.regval;
+ if (!is_write) {
+ if (put_user(params.regval, uaddr))
+ return -EFAULT;
+ }
return 0;
}