Skip to content

Commit 01fe5ac

Browse files
Andrew JonesMarc Zyngier
authored andcommitted
KVM: arm64: Consolidate REG_HIDDEN_GUEST/USER
REG_HIDDEN_GUEST and REG_HIDDEN_USER are always used together. Consolidate them into a single REG_HIDDEN flag. We can always add another flag later if some register needs to expose itself differently to the guest than it does to userspace. No functional change intended. Signed-off-by: Andrew Jones <drjones@redhat.com> Signed-off-by: Marc Zyngier <maz@kernel.org> Link: https://lore.kernel.org/r/20201105091022.15373-3-drjones@redhat.com
1 parent f81cb2c commit 01fe5ac

2 files changed

Lines changed: 10 additions & 20 deletions

File tree

arch/arm64/kvm/sys_regs.c

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -1069,7 +1069,7 @@ static bool trap_ptrauth(struct kvm_vcpu *vcpu,
10691069
static unsigned int ptrauth_visibility(const struct kvm_vcpu *vcpu,
10701070
const struct sys_reg_desc *rd)
10711071
{
1072-
return vcpu_has_ptrauth(vcpu) ? 0 : REG_HIDDEN_USER | REG_HIDDEN_GUEST;
1072+
return vcpu_has_ptrauth(vcpu) ? 0 : REG_HIDDEN;
10731073
}
10741074

10751075
#define __PTRAUTH_KEY(k) \
@@ -1190,7 +1190,7 @@ static unsigned int sve_visibility(const struct kvm_vcpu *vcpu,
11901190
if (vcpu_has_sve(vcpu))
11911191
return 0;
11921192

1193-
return REG_HIDDEN_USER | REG_HIDDEN_GUEST;
1193+
return REG_HIDDEN;
11941194
}
11951195

11961196
/* Generate the emulated ID_AA64ZFR0_EL1 value exposed to the guest */
@@ -2153,7 +2153,7 @@ static void perform_access(struct kvm_vcpu *vcpu,
21532153
trace_kvm_sys_access(*vcpu_pc(vcpu), params, r);
21542154

21552155
/* Check for regs disabled by runtime config */
2156-
if (sysreg_hidden_from_guest(vcpu, r)) {
2156+
if (sysreg_hidden(vcpu, r)) {
21572157
kvm_inject_undefined(vcpu);
21582158
return;
21592159
}
@@ -2652,7 +2652,7 @@ int kvm_arm_sys_reg_get_reg(struct kvm_vcpu *vcpu, const struct kvm_one_reg *reg
26522652
return get_invariant_sys_reg(reg->id, uaddr);
26532653

26542654
/* Check for regs disabled by runtime config */
2655-
if (sysreg_hidden_from_user(vcpu, r))
2655+
if (sysreg_hidden(vcpu, r))
26562656
return -ENOENT;
26572657

26582658
if (r->get_user)
@@ -2677,7 +2677,7 @@ int kvm_arm_sys_reg_set_reg(struct kvm_vcpu *vcpu, const struct kvm_one_reg *reg
26772677
return set_invariant_sys_reg(reg->id, uaddr);
26782678

26792679
/* Check for regs disabled by runtime config */
2680-
if (sysreg_hidden_from_user(vcpu, r))
2680+
if (sysreg_hidden(vcpu, r))
26812681
return -ENOENT;
26822682

26832683
if (r->set_user)
@@ -2748,7 +2748,7 @@ static int walk_one_sys_reg(const struct kvm_vcpu *vcpu,
27482748
if (!(rd->reg || rd->get_user))
27492749
return 0;
27502750

2751-
if (sysreg_hidden_from_user(vcpu, rd))
2751+
if (sysreg_hidden(vcpu, rd))
27522752
return 0;
27532753

27542754
if (!copy_reg_to_user(rd, uind))

arch/arm64/kvm/sys_regs.h

Lines changed: 4 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -59,8 +59,7 @@ struct sys_reg_desc {
5959
const struct sys_reg_desc *rd);
6060
};
6161

62-
#define REG_HIDDEN_USER (1 << 0) /* hidden from userspace ioctls */
63-
#define REG_HIDDEN_GUEST (1 << 1) /* hidden from guest */
62+
#define REG_HIDDEN (1 << 0) /* hidden from userspace and guest */
6463

6564
static __printf(2, 3)
6665
inline void print_sys_reg_msg(const struct sys_reg_params *p,
@@ -111,22 +110,13 @@ static inline void reset_val(struct kvm_vcpu *vcpu, const struct sys_reg_desc *r
111110
__vcpu_sys_reg(vcpu, r->reg) = r->val;
112111
}
113112

114-
static inline bool sysreg_hidden_from_guest(const struct kvm_vcpu *vcpu,
115-
const struct sys_reg_desc *r)
116-
{
117-
if (likely(!r->visibility))
118-
return false;
119-
120-
return r->visibility(vcpu, r) & REG_HIDDEN_GUEST;
121-
}
122-
123-
static inline bool sysreg_hidden_from_user(const struct kvm_vcpu *vcpu,
124-
const struct sys_reg_desc *r)
113+
static inline bool sysreg_hidden(const struct kvm_vcpu *vcpu,
114+
const struct sys_reg_desc *r)
125115
{
126116
if (likely(!r->visibility))
127117
return false;
128118

129-
return r->visibility(vcpu, r) & REG_HIDDEN_USER;
119+
return r->visibility(vcpu, r) & REG_HIDDEN;
130120
}
131121

132122
static inline int cmp_sys_reg(const struct sys_reg_desc *i1,

0 commit comments

Comments
 (0)