GNU Linux-libre 6.9.1-gnu
[releases.git] / arch / arm64 / kvm / nested.c
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Copyright (C) 2017 - Columbia University and Linaro Ltd.
4  * Author: Jintack Lim <jintack.lim@linaro.org>
5  */
6
7 #include <linux/kvm.h>
8 #include <linux/kvm_host.h>
9
10 #include <asm/kvm_emulate.h>
11 #include <asm/kvm_nested.h>
12 #include <asm/sysreg.h>
13
14 #include "sys_regs.h"
15
16 /* Protection against the sysreg repainting madness... */
17 #define NV_FTR(r, f)            ID_AA64##r##_EL1_##f
18
19 /*
20  * Our emulated CPU doesn't support all the possible features. For the
21  * sake of simplicity (and probably mental sanity), wipe out a number
22  * of feature bits we don't intend to support for the time being.
23  * This list should get updated as new features get added to the NV
24  * support, and new extension to the architecture.
25  */
26 static u64 limit_nv_id_reg(u32 id, u64 val)
27 {
28         u64 tmp;
29
30         switch (id) {
31         case SYS_ID_AA64ISAR0_EL1:
32                 /* Support everything but TME, O.S. and Range TLBIs */
33                 val &= ~(NV_FTR(ISAR0, TLB)             |
34                          NV_FTR(ISAR0, TME));
35                 break;
36
37         case SYS_ID_AA64ISAR1_EL1:
38                 /* Support everything but PtrAuth and Spec Invalidation */
39                 val &= ~(GENMASK_ULL(63, 56)    |
40                          NV_FTR(ISAR1, SPECRES) |
41                          NV_FTR(ISAR1, GPI)     |
42                          NV_FTR(ISAR1, GPA)     |
43                          NV_FTR(ISAR1, API)     |
44                          NV_FTR(ISAR1, APA));
45                 break;
46
47         case SYS_ID_AA64PFR0_EL1:
48                 /* No AMU, MPAM, S-EL2, RAS or SVE */
49                 val &= ~(GENMASK_ULL(55, 52)    |
50                          NV_FTR(PFR0, AMU)      |
51                          NV_FTR(PFR0, MPAM)     |
52                          NV_FTR(PFR0, SEL2)     |
53                          NV_FTR(PFR0, RAS)      |
54                          NV_FTR(PFR0, SVE)      |
55                          NV_FTR(PFR0, EL3)      |
56                          NV_FTR(PFR0, EL2)      |
57                          NV_FTR(PFR0, EL1));
58                 /* 64bit EL1/EL2/EL3 only */
59                 val |= FIELD_PREP(NV_FTR(PFR0, EL1), 0b0001);
60                 val |= FIELD_PREP(NV_FTR(PFR0, EL2), 0b0001);
61                 val |= FIELD_PREP(NV_FTR(PFR0, EL3), 0b0001);
62                 break;
63
64         case SYS_ID_AA64PFR1_EL1:
65                 /* Only support SSBS */
66                 val &= NV_FTR(PFR1, SSBS);
67                 break;
68
69         case SYS_ID_AA64MMFR0_EL1:
70                 /* Hide ECV, ExS, Secure Memory */
71                 val &= ~(NV_FTR(MMFR0, ECV)             |
72                          NV_FTR(MMFR0, EXS)             |
73                          NV_FTR(MMFR0, TGRAN4_2)        |
74                          NV_FTR(MMFR0, TGRAN16_2)       |
75                          NV_FTR(MMFR0, TGRAN64_2)       |
76                          NV_FTR(MMFR0, SNSMEM));
77
78                 /* Disallow unsupported S2 page sizes */
79                 switch (PAGE_SIZE) {
80                 case SZ_64K:
81                         val |= FIELD_PREP(NV_FTR(MMFR0, TGRAN16_2), 0b0001);
82                         fallthrough;
83                 case SZ_16K:
84                         val |= FIELD_PREP(NV_FTR(MMFR0, TGRAN4_2), 0b0001);
85                         fallthrough;
86                 case SZ_4K:
87                         /* Support everything */
88                         break;
89                 }
90                 /*
91                  * Since we can't support a guest S2 page size smaller than
92                  * the host's own page size (due to KVM only populating its
93                  * own S2 using the kernel's page size), advertise the
94                  * limitation using FEAT_GTG.
95                  */
96                 switch (PAGE_SIZE) {
97                 case SZ_4K:
98                         val |= FIELD_PREP(NV_FTR(MMFR0, TGRAN4_2), 0b0010);
99                         fallthrough;
100                 case SZ_16K:
101                         val |= FIELD_PREP(NV_FTR(MMFR0, TGRAN16_2), 0b0010);
102                         fallthrough;
103                 case SZ_64K:
104                         val |= FIELD_PREP(NV_FTR(MMFR0, TGRAN64_2), 0b0010);
105                         break;
106                 }
107                 /* Cap PARange to 48bits */
108                 tmp = FIELD_GET(NV_FTR(MMFR0, PARANGE), val);
109                 if (tmp > 0b0101) {
110                         val &= ~NV_FTR(MMFR0, PARANGE);
111                         val |= FIELD_PREP(NV_FTR(MMFR0, PARANGE), 0b0101);
112                 }
113                 break;
114
115         case SYS_ID_AA64MMFR1_EL1:
116                 val &= (NV_FTR(MMFR1, HCX)      |
117                         NV_FTR(MMFR1, PAN)      |
118                         NV_FTR(MMFR1, LO)       |
119                         NV_FTR(MMFR1, HPDS)     |
120                         NV_FTR(MMFR1, VH)       |
121                         NV_FTR(MMFR1, VMIDBits));
122                 break;
123
124         case SYS_ID_AA64MMFR2_EL1:
125                 val &= ~(NV_FTR(MMFR2, BBM)     |
126                          NV_FTR(MMFR2, TTL)     |
127                          GENMASK_ULL(47, 44)    |
128                          NV_FTR(MMFR2, ST)      |
129                          NV_FTR(MMFR2, CCIDX)   |
130                          NV_FTR(MMFR2, VARange));
131
132                 /* Force TTL support */
133                 val |= FIELD_PREP(NV_FTR(MMFR2, TTL), 0b0001);
134                 break;
135
136         case SYS_ID_AA64MMFR4_EL1:
137                 val = 0;
138                 if (!cpus_have_final_cap(ARM64_HAS_HCR_NV1))
139                         val |= FIELD_PREP(NV_FTR(MMFR4, E2H0),
140                                           ID_AA64MMFR4_EL1_E2H0_NI_NV1);
141                 break;
142
143         case SYS_ID_AA64DFR0_EL1:
144                 /* Only limited support for PMU, Debug, BPs and WPs */
145                 val &= (NV_FTR(DFR0, PMUVer)    |
146                         NV_FTR(DFR0, WRPs)      |
147                         NV_FTR(DFR0, BRPs)      |
148                         NV_FTR(DFR0, DebugVer));
149
150                 /* Cap Debug to ARMv8.1 */
151                 tmp = FIELD_GET(NV_FTR(DFR0, DebugVer), val);
152                 if (tmp > 0b0111) {
153                         val &= ~NV_FTR(DFR0, DebugVer);
154                         val |= FIELD_PREP(NV_FTR(DFR0, DebugVer), 0b0111);
155                 }
156                 break;
157
158         default:
159                 /* Unknown register, just wipe it clean */
160                 val = 0;
161                 break;
162         }
163
164         return val;
165 }
166
167 u64 kvm_vcpu_sanitise_vncr_reg(const struct kvm_vcpu *vcpu, enum vcpu_sysreg sr)
168 {
169         u64 v = ctxt_sys_reg(&vcpu->arch.ctxt, sr);
170         struct kvm_sysreg_masks *masks;
171
172         masks = vcpu->kvm->arch.sysreg_masks;
173
174         if (masks) {
175                 sr -= __VNCR_START__;
176
177                 v &= ~masks->mask[sr].res0;
178                 v |= masks->mask[sr].res1;
179         }
180
181         return v;
182 }
183
184 static void set_sysreg_masks(struct kvm *kvm, int sr, u64 res0, u64 res1)
185 {
186         int i = sr - __VNCR_START__;
187
188         kvm->arch.sysreg_masks->mask[i].res0 = res0;
189         kvm->arch.sysreg_masks->mask[i].res1 = res1;
190 }
191
192 int kvm_init_nv_sysregs(struct kvm *kvm)
193 {
194         u64 res0, res1;
195         int ret = 0;
196
197         mutex_lock(&kvm->arch.config_lock);
198
199         if (kvm->arch.sysreg_masks)
200                 goto out;
201
202         kvm->arch.sysreg_masks = kzalloc(sizeof(*(kvm->arch.sysreg_masks)),
203                                          GFP_KERNEL);
204         if (!kvm->arch.sysreg_masks) {
205                 ret = -ENOMEM;
206                 goto out;
207         }
208
209         for (int i = 0; i < KVM_ARM_ID_REG_NUM; i++)
210                 kvm->arch.id_regs[i] = limit_nv_id_reg(IDX_IDREG(i),
211                                                        kvm->arch.id_regs[i]);
212
213         /* VTTBR_EL2 */
214         res0 = res1 = 0;
215         if (!kvm_has_feat_enum(kvm, ID_AA64MMFR1_EL1, VMIDBits, 16))
216                 res0 |= GENMASK(63, 56);
217         if (!kvm_has_feat(kvm, ID_AA64MMFR2_EL1, CnP, IMP))
218                 res0 |= VTTBR_CNP_BIT;
219         set_sysreg_masks(kvm, VTTBR_EL2, res0, res1);
220
221         /* VTCR_EL2 */
222         res0 = GENMASK(63, 32) | GENMASK(30, 20);
223         res1 = BIT(31);
224         set_sysreg_masks(kvm, VTCR_EL2, res0, res1);
225
226         /* VMPIDR_EL2 */
227         res0 = GENMASK(63, 40) | GENMASK(30, 24);
228         res1 = BIT(31);
229         set_sysreg_masks(kvm, VMPIDR_EL2, res0, res1);
230
231         /* HCR_EL2 */
232         res0 = BIT(48);
233         res1 = HCR_RW;
234         if (!kvm_has_feat(kvm, ID_AA64MMFR1_EL1, TWED, IMP))
235                 res0 |= GENMASK(63, 59);
236         if (!kvm_has_feat(kvm, ID_AA64PFR1_EL1, MTE, MTE2))
237                 res0 |= (HCR_TID5 | HCR_DCT | HCR_ATA);
238         if (!kvm_has_feat(kvm, ID_AA64MMFR2_EL1, EVT, TTLBxS))
239                 res0 |= (HCR_TTLBIS | HCR_TTLBOS);
240         if (!kvm_has_feat(kvm, ID_AA64PFR0_EL1, CSV2, CSV2_2) &&
241             !kvm_has_feat(kvm, ID_AA64PFR1_EL1, CSV2_frac, CSV2_1p2))
242                 res0 |= HCR_ENSCXT;
243         if (!kvm_has_feat(kvm, ID_AA64MMFR2_EL1, EVT, IMP))
244                 res0 |= (HCR_TOCU | HCR_TICAB | HCR_TID4);
245         if (!kvm_has_feat(kvm, ID_AA64PFR0_EL1, AMU, V1P1))
246                 res0 |= HCR_AMVOFFEN;
247         if (!kvm_has_feat(kvm, ID_AA64PFR0_EL1, RAS, V1P1))
248                 res0 |= HCR_FIEN;
249         if (!kvm_has_feat(kvm, ID_AA64MMFR2_EL1, FWB, IMP))
250                 res0 |= HCR_FWB;
251         if (!kvm_has_feat(kvm, ID_AA64MMFR2_EL1, NV, NV2))
252                 res0 |= HCR_NV2;
253         if (!kvm_has_feat(kvm, ID_AA64MMFR2_EL1, NV, IMP))
254                 res0 |= (HCR_AT | HCR_NV1 | HCR_NV);
255         if (!(__vcpu_has_feature(&kvm->arch, KVM_ARM_VCPU_PTRAUTH_ADDRESS) &&
256               __vcpu_has_feature(&kvm->arch, KVM_ARM_VCPU_PTRAUTH_GENERIC)))
257                 res0 |= (HCR_API | HCR_APK);
258         if (!kvm_has_feat(kvm, ID_AA64ISAR0_EL1, TME, IMP))
259                 res0 |= BIT(39);
260         if (!kvm_has_feat(kvm, ID_AA64PFR0_EL1, RAS, IMP))
261                 res0 |= (HCR_TEA | HCR_TERR);
262         if (!kvm_has_feat(kvm, ID_AA64MMFR1_EL1, LO, IMP))
263                 res0 |= HCR_TLOR;
264         if (!kvm_has_feat(kvm, ID_AA64MMFR4_EL1, E2H0, IMP))
265                 res1 |= HCR_E2H;
266         set_sysreg_masks(kvm, HCR_EL2, res0, res1);
267
268         /* HCRX_EL2 */
269         res0 = HCRX_EL2_RES0;
270         res1 = HCRX_EL2_RES1;
271         if (!kvm_has_feat(kvm, ID_AA64ISAR3_EL1, PACM, TRIVIAL_IMP))
272                 res0 |= HCRX_EL2_PACMEn;
273         if (!kvm_has_feat(kvm, ID_AA64PFR2_EL1, FPMR, IMP))
274                 res0 |= HCRX_EL2_EnFPM;
275         if (!kvm_has_feat(kvm, ID_AA64PFR1_EL1, GCS, IMP))
276                 res0 |= HCRX_EL2_GCSEn;
277         if (!kvm_has_feat(kvm, ID_AA64ISAR2_EL1, SYSREG_128, IMP))
278                 res0 |= HCRX_EL2_EnIDCP128;
279         if (!kvm_has_feat(kvm, ID_AA64MMFR3_EL1, ADERR, DEV_ASYNC))
280                 res0 |= (HCRX_EL2_EnSDERR | HCRX_EL2_EnSNERR);
281         if (!kvm_has_feat(kvm, ID_AA64PFR1_EL1, DF2, IMP))
282                 res0 |= HCRX_EL2_TMEA;
283         if (!kvm_has_feat(kvm, ID_AA64MMFR3_EL1, D128, IMP))
284                 res0 |= HCRX_EL2_D128En;
285         if (!kvm_has_feat(kvm, ID_AA64PFR1_EL1, THE, IMP))
286                 res0 |= HCRX_EL2_PTTWI;
287         if (!kvm_has_feat(kvm, ID_AA64MMFR3_EL1, SCTLRX, IMP))
288                 res0 |= HCRX_EL2_SCTLR2En;
289         if (!kvm_has_feat(kvm, ID_AA64MMFR3_EL1, TCRX, IMP))
290                 res0 |= HCRX_EL2_TCR2En;
291         if (!kvm_has_feat(kvm, ID_AA64ISAR2_EL1, MOPS, IMP))
292                 res0 |= (HCRX_EL2_MSCEn | HCRX_EL2_MCE2);
293         if (!kvm_has_feat(kvm, ID_AA64MMFR1_EL1, CMOW, IMP))
294                 res0 |= HCRX_EL2_CMOW;
295         if (!kvm_has_feat(kvm, ID_AA64PFR1_EL1, NMI, IMP))
296                 res0 |= (HCRX_EL2_VFNMI | HCRX_EL2_VINMI | HCRX_EL2_TALLINT);
297         if (!kvm_has_feat(kvm, ID_AA64PFR1_EL1, SME, IMP) ||
298             !(read_sysreg_s(SYS_SMIDR_EL1) & SMIDR_EL1_SMPS))
299                 res0 |= HCRX_EL2_SMPME;
300         if (!kvm_has_feat(kvm, ID_AA64ISAR1_EL1, XS, IMP))
301                 res0 |= (HCRX_EL2_FGTnXS | HCRX_EL2_FnXS);
302         if (!kvm_has_feat(kvm, ID_AA64ISAR1_EL1, LS64, LS64_V))
303                 res0 |= HCRX_EL2_EnASR;
304         if (!kvm_has_feat(kvm, ID_AA64ISAR1_EL1, LS64, LS64))
305                 res0 |= HCRX_EL2_EnALS;
306         if (!kvm_has_feat(kvm, ID_AA64ISAR1_EL1, LS64, LS64_ACCDATA))
307                 res0 |= HCRX_EL2_EnAS0;
308         set_sysreg_masks(kvm, HCRX_EL2, res0, res1);
309
310         /* HFG[RW]TR_EL2 */
311         res0 = res1 = 0;
312         if (!(__vcpu_has_feature(&kvm->arch, KVM_ARM_VCPU_PTRAUTH_ADDRESS) &&
313               __vcpu_has_feature(&kvm->arch, KVM_ARM_VCPU_PTRAUTH_GENERIC)))
314                 res0 |= (HFGxTR_EL2_APDAKey | HFGxTR_EL2_APDBKey |
315                          HFGxTR_EL2_APGAKey | HFGxTR_EL2_APIAKey |
316                          HFGxTR_EL2_APIBKey);
317         if (!kvm_has_feat(kvm, ID_AA64MMFR1_EL1, LO, IMP))
318                 res0 |= (HFGxTR_EL2_LORC_EL1 | HFGxTR_EL2_LOREA_EL1 |
319                          HFGxTR_EL2_LORID_EL1 | HFGxTR_EL2_LORN_EL1 |
320                          HFGxTR_EL2_LORSA_EL1);
321         if (!kvm_has_feat(kvm, ID_AA64PFR0_EL1, CSV2, CSV2_2) &&
322             !kvm_has_feat(kvm, ID_AA64PFR1_EL1, CSV2_frac, CSV2_1p2))
323                 res0 |= (HFGxTR_EL2_SCXTNUM_EL1 | HFGxTR_EL2_SCXTNUM_EL0);
324         if (!kvm_has_feat(kvm, ID_AA64PFR0_EL1, GIC, IMP))
325                 res0 |= HFGxTR_EL2_ICC_IGRPENn_EL1;
326         if (!kvm_has_feat(kvm, ID_AA64PFR0_EL1, RAS, IMP))
327                 res0 |= (HFGxTR_EL2_ERRIDR_EL1 | HFGxTR_EL2_ERRSELR_EL1 |
328                          HFGxTR_EL2_ERXFR_EL1 | HFGxTR_EL2_ERXCTLR_EL1 |
329                          HFGxTR_EL2_ERXSTATUS_EL1 | HFGxTR_EL2_ERXMISCn_EL1 |
330                          HFGxTR_EL2_ERXPFGF_EL1 | HFGxTR_EL2_ERXPFGCTL_EL1 |
331                          HFGxTR_EL2_ERXPFGCDN_EL1 | HFGxTR_EL2_ERXADDR_EL1);
332         if (!kvm_has_feat(kvm, ID_AA64ISAR1_EL1, LS64, LS64_ACCDATA))
333                 res0 |= HFGxTR_EL2_nACCDATA_EL1;
334         if (!kvm_has_feat(kvm, ID_AA64PFR1_EL1, GCS, IMP))
335                 res0 |= (HFGxTR_EL2_nGCS_EL0 | HFGxTR_EL2_nGCS_EL1);
336         if (!kvm_has_feat(kvm, ID_AA64PFR1_EL1, SME, IMP))
337                 res0 |= (HFGxTR_EL2_nSMPRI_EL1 | HFGxTR_EL2_nTPIDR2_EL0);
338         if (!kvm_has_feat(kvm, ID_AA64PFR1_EL1, THE, IMP))
339                 res0 |= HFGxTR_EL2_nRCWMASK_EL1;
340         if (!kvm_has_feat(kvm, ID_AA64MMFR3_EL1, S1PIE, IMP))
341                 res0 |= (HFGxTR_EL2_nPIRE0_EL1 | HFGxTR_EL2_nPIR_EL1);
342         if (!kvm_has_feat(kvm, ID_AA64MMFR3_EL1, S1POE, IMP))
343                 res0 |= (HFGxTR_EL2_nPOR_EL0 | HFGxTR_EL2_nPOR_EL1);
344         if (!kvm_has_feat(kvm, ID_AA64MMFR3_EL1, S2POE, IMP))
345                 res0 |= HFGxTR_EL2_nS2POR_EL1;
346         if (!kvm_has_feat(kvm, ID_AA64MMFR3_EL1, AIE, IMP))
347                 res0 |= (HFGxTR_EL2_nMAIR2_EL1 | HFGxTR_EL2_nAMAIR2_EL1);
348         set_sysreg_masks(kvm, HFGRTR_EL2, res0 | __HFGRTR_EL2_RES0, res1);
349         set_sysreg_masks(kvm, HFGWTR_EL2, res0 | __HFGWTR_EL2_RES0, res1);
350
351         /* HDFG[RW]TR_EL2 */
352         res0 = res1 = 0;
353         if (!kvm_has_feat(kvm, ID_AA64DFR0_EL1, DoubleLock, IMP))
354                 res0 |= HDFGRTR_EL2_OSDLR_EL1;
355         if (!kvm_has_feat(kvm, ID_AA64DFR0_EL1, PMUVer, IMP))
356                 res0 |= (HDFGRTR_EL2_PMEVCNTRn_EL0 | HDFGRTR_EL2_PMEVTYPERn_EL0 |
357                          HDFGRTR_EL2_PMCCFILTR_EL0 | HDFGRTR_EL2_PMCCNTR_EL0 |
358                          HDFGRTR_EL2_PMCNTEN | HDFGRTR_EL2_PMINTEN |
359                          HDFGRTR_EL2_PMOVS | HDFGRTR_EL2_PMSELR_EL0 |
360                          HDFGRTR_EL2_PMMIR_EL1 | HDFGRTR_EL2_PMUSERENR_EL0 |
361                          HDFGRTR_EL2_PMCEIDn_EL0);
362         if (!kvm_has_feat(kvm, ID_AA64DFR0_EL1, PMSVer, IMP))
363                 res0 |= (HDFGRTR_EL2_PMBLIMITR_EL1 | HDFGRTR_EL2_PMBPTR_EL1 |
364                          HDFGRTR_EL2_PMBSR_EL1 | HDFGRTR_EL2_PMSCR_EL1 |
365                          HDFGRTR_EL2_PMSEVFR_EL1 | HDFGRTR_EL2_PMSFCR_EL1 |
366                          HDFGRTR_EL2_PMSICR_EL1 | HDFGRTR_EL2_PMSIDR_EL1 |
367                          HDFGRTR_EL2_PMSIRR_EL1 | HDFGRTR_EL2_PMSLATFR_EL1 |
368                          HDFGRTR_EL2_PMBIDR_EL1);
369         if (!kvm_has_feat(kvm, ID_AA64DFR0_EL1, TraceVer, IMP))
370                 res0 |= (HDFGRTR_EL2_TRC | HDFGRTR_EL2_TRCAUTHSTATUS |
371                          HDFGRTR_EL2_TRCAUXCTLR | HDFGRTR_EL2_TRCCLAIM |
372                          HDFGRTR_EL2_TRCCNTVRn | HDFGRTR_EL2_TRCID |
373                          HDFGRTR_EL2_TRCIMSPECn | HDFGRTR_EL2_TRCOSLSR |
374                          HDFGRTR_EL2_TRCPRGCTLR | HDFGRTR_EL2_TRCSEQSTR |
375                          HDFGRTR_EL2_TRCSSCSRn | HDFGRTR_EL2_TRCSTATR |
376                          HDFGRTR_EL2_TRCVICTLR);
377         if (!kvm_has_feat(kvm, ID_AA64DFR0_EL1, TraceBuffer, IMP))
378                 res0 |= (HDFGRTR_EL2_TRBBASER_EL1 | HDFGRTR_EL2_TRBIDR_EL1 |
379                          HDFGRTR_EL2_TRBLIMITR_EL1 | HDFGRTR_EL2_TRBMAR_EL1 |
380                          HDFGRTR_EL2_TRBPTR_EL1 | HDFGRTR_EL2_TRBSR_EL1 |
381                          HDFGRTR_EL2_TRBTRG_EL1);
382         if (!kvm_has_feat(kvm, ID_AA64DFR0_EL1, BRBE, IMP))
383                 res0 |= (HDFGRTR_EL2_nBRBIDR | HDFGRTR_EL2_nBRBCTL |
384                          HDFGRTR_EL2_nBRBDATA);
385         if (!kvm_has_feat(kvm, ID_AA64DFR0_EL1, PMSVer, V1P2))
386                 res0 |= HDFGRTR_EL2_nPMSNEVFR_EL1;
387         set_sysreg_masks(kvm, HDFGRTR_EL2, res0 | HDFGRTR_EL2_RES0, res1);
388
389         /* Reuse the bits from the read-side and add the write-specific stuff */
390         if (!kvm_has_feat(kvm, ID_AA64DFR0_EL1, PMUVer, IMP))
391                 res0 |= (HDFGWTR_EL2_PMCR_EL0 | HDFGWTR_EL2_PMSWINC_EL0);
392         if (!kvm_has_feat(kvm, ID_AA64DFR0_EL1, TraceVer, IMP))
393                 res0 |= HDFGWTR_EL2_TRCOSLAR;
394         if (!kvm_has_feat(kvm, ID_AA64DFR0_EL1, TraceFilt, IMP))
395                 res0 |= HDFGWTR_EL2_TRFCR_EL1;
396         set_sysreg_masks(kvm, HFGWTR_EL2, res0 | HDFGWTR_EL2_RES0, res1);
397
398         /* HFGITR_EL2 */
399         res0 = HFGITR_EL2_RES0;
400         res1 = HFGITR_EL2_RES1;
401         if (!kvm_has_feat(kvm, ID_AA64ISAR1_EL1, DPB, DPB2))
402                 res0 |= HFGITR_EL2_DCCVADP;
403         if (!kvm_has_feat(kvm, ID_AA64MMFR1_EL1, PAN, PAN2))
404                 res0 |= (HFGITR_EL2_ATS1E1RP | HFGITR_EL2_ATS1E1WP);
405         if (!kvm_has_feat(kvm, ID_AA64ISAR0_EL1, TLB, OS))
406                 res0 |= (HFGITR_EL2_TLBIRVAALE1OS | HFGITR_EL2_TLBIRVALE1OS |
407                          HFGITR_EL2_TLBIRVAAE1OS | HFGITR_EL2_TLBIRVAE1OS |
408                          HFGITR_EL2_TLBIVAALE1OS | HFGITR_EL2_TLBIVALE1OS |
409                          HFGITR_EL2_TLBIVAAE1OS | HFGITR_EL2_TLBIASIDE1OS |
410                          HFGITR_EL2_TLBIVAE1OS | HFGITR_EL2_TLBIVMALLE1OS);
411         if (!kvm_has_feat(kvm, ID_AA64ISAR0_EL1, TLB, RANGE))
412                 res0 |= (HFGITR_EL2_TLBIRVAALE1 | HFGITR_EL2_TLBIRVALE1 |
413                          HFGITR_EL2_TLBIRVAAE1 | HFGITR_EL2_TLBIRVAE1 |
414                          HFGITR_EL2_TLBIRVAALE1IS | HFGITR_EL2_TLBIRVALE1IS |
415                          HFGITR_EL2_TLBIRVAAE1IS | HFGITR_EL2_TLBIRVAE1IS |
416                          HFGITR_EL2_TLBIRVAALE1OS | HFGITR_EL2_TLBIRVALE1OS |
417                          HFGITR_EL2_TLBIRVAAE1OS | HFGITR_EL2_TLBIRVAE1OS);
418         if (!kvm_has_feat(kvm, ID_AA64ISAR1_EL1, SPECRES, IMP))
419                 res0 |= (HFGITR_EL2_CFPRCTX | HFGITR_EL2_DVPRCTX |
420                          HFGITR_EL2_CPPRCTX);
421         if (!kvm_has_feat(kvm, ID_AA64DFR0_EL1, BRBE, IMP))
422                 res0 |= (HFGITR_EL2_nBRBINJ | HFGITR_EL2_nBRBIALL);
423         if (!kvm_has_feat(kvm, ID_AA64PFR1_EL1, GCS, IMP))
424                 res0 |= (HFGITR_EL2_nGCSPUSHM_EL1 | HFGITR_EL2_nGCSSTR_EL1 |
425                          HFGITR_EL2_nGCSEPP);
426         if (!kvm_has_feat(kvm, ID_AA64ISAR1_EL1, SPECRES, COSP_RCTX))
427                 res0 |= HFGITR_EL2_COSPRCTX;
428         if (!kvm_has_feat(kvm, ID_AA64ISAR2_EL1, ATS1A, IMP))
429                 res0 |= HFGITR_EL2_ATS1E1A;
430         set_sysreg_masks(kvm, HFGITR_EL2, res0, res1);
431
432         /* HAFGRTR_EL2 - not a lot to see here */
433         res0 = HAFGRTR_EL2_RES0;
434         res1 = HAFGRTR_EL2_RES1;
435         if (!kvm_has_feat(kvm, ID_AA64PFR0_EL1, AMU, V1P1))
436                 res0 |= ~(res0 | res1);
437         set_sysreg_masks(kvm, HAFGRTR_EL2, res0, res1);
438 out:
439         mutex_unlock(&kvm->arch.config_lock);
440
441         return ret;
442 }