]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
KVM: x86: Drop the "EX" part of "EXREG" to avoid collision with APX
authorSean Christopherson <seanjc@google.com>
Thu, 9 Apr 2026 22:42:31 +0000 (15:42 -0700)
committerPaolo Bonzini <pbonzini@redhat.com>
Wed, 13 May 2026 16:38:06 +0000 (12:38 -0400)
Now that NR_VCPU_REGS is no longer a thing, and now that now that RIP is
effectively an EXREG, drop the "EX" is for extended (or maybe extra?")
prefix from non-GPR registers to avoid a collision with APX (Advanced
Performance Extensions), which adds:

  16 additional general-purpose registers (GPRs) R16–R31, also referred
  to as Extended GPRs (EGPRs)  in this document;

I.e. KVM's version of "extended" won't match with APX's definition.

No functional change intended.

Signed-off-by: Sean Christopherson <seanjc@google.com>
Reviewed-by: Kai Huang <kai.huang@intel.com>
Tested-by: Kai Huang <kai.huang@intel.com>
Message-ID: <20260409224236.2021562-3-seanjc@google.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
arch/x86/include/asm/kvm_host.h
arch/x86/kvm/kvm_cache_regs.h
arch/x86/kvm/svm/svm.c
arch/x86/kvm/svm/svm.h
arch/x86/kvm/vmx/nested.c
arch/x86/kvm/vmx/tdx.c
arch/x86/kvm/vmx/vmx.c
arch/x86/kvm/vmx/vmx.h
arch/x86/kvm/x86.c

index 68a11325e8bc8b9d8dcad2191d400b650a4a9294..b1eae1e7b04f15bb1a0717d0b3922a4f0b5b7d1d 100644 (file)
@@ -195,8 +195,8 @@ enum kvm_reg {
 
        VCPU_REG_RIP = NR_VCPU_GENERAL_PURPOSE_REGS,
 
-       VCPU_EXREG_PDPTR,
-       VCPU_EXREG_CR0,
+       VCPU_REG_PDPTR,
+       VCPU_REG_CR0,
        /*
         * Alias AMD's ERAPS (not a real register) to CR3 so that common code
         * can trigger emulation of the RAP (Return Address Predictor) with
@@ -204,13 +204,13 @@ enum kvm_reg {
         * is cleared on writes to CR3, i.e. marking CR3 dirty will naturally
         * mark ERAPS dirty as well.
         */
-       VCPU_EXREG_CR3,
-       VCPU_EXREG_ERAPS = VCPU_EXREG_CR3,
-       VCPU_EXREG_CR4,
-       VCPU_EXREG_RFLAGS,
-       VCPU_EXREG_SEGMENTS,
-       VCPU_EXREG_EXIT_INFO_1,
-       VCPU_EXREG_EXIT_INFO_2,
+       VCPU_REG_CR3,
+       VCPU_REG_ERAPS = VCPU_REG_CR3,
+       VCPU_REG_CR4,
+       VCPU_REG_RFLAGS,
+       VCPU_REG_SEGMENTS,
+       VCPU_REG_EXIT_INFO_1,
+       VCPU_REG_EXIT_INFO_2,
 };
 
 enum {
index 9b7df9de0e879fc0ff9fd7a5f3e074265f6be85c..ac1f9867a2340a59d48e5bd67c32152c66d5456d 100644 (file)
@@ -159,8 +159,8 @@ static inline u64 kvm_pdptr_read(struct kvm_vcpu *vcpu, int index)
 {
        might_sleep();  /* on svm */
 
-       if (!kvm_register_is_available(vcpu, VCPU_EXREG_PDPTR))
-               kvm_x86_call(cache_reg)(vcpu, VCPU_EXREG_PDPTR);
+       if (!kvm_register_is_available(vcpu, VCPU_REG_PDPTR))
+               kvm_x86_call(cache_reg)(vcpu, VCPU_REG_PDPTR);
 
        return vcpu->arch.walk_mmu->pdptrs[index];
 }
@@ -174,8 +174,8 @@ static inline ulong kvm_read_cr0_bits(struct kvm_vcpu *vcpu, ulong mask)
 {
        ulong tmask = mask & KVM_POSSIBLE_CR0_GUEST_BITS;
        if ((tmask & vcpu->arch.cr0_guest_owned_bits) &&
-           !kvm_register_is_available(vcpu, VCPU_EXREG_CR0))
-               kvm_x86_call(cache_reg)(vcpu, VCPU_EXREG_CR0);
+           !kvm_register_is_available(vcpu, VCPU_REG_CR0))
+               kvm_x86_call(cache_reg)(vcpu, VCPU_REG_CR0);
        return vcpu->arch.cr0 & mask;
 }
 
@@ -196,8 +196,8 @@ static inline ulong kvm_read_cr4_bits(struct kvm_vcpu *vcpu, ulong mask)
 {
        ulong tmask = mask & KVM_POSSIBLE_CR4_GUEST_BITS;
        if ((tmask & vcpu->arch.cr4_guest_owned_bits) &&
-           !kvm_register_is_available(vcpu, VCPU_EXREG_CR4))
-               kvm_x86_call(cache_reg)(vcpu, VCPU_EXREG_CR4);
+           !kvm_register_is_available(vcpu, VCPU_REG_CR4))
+               kvm_x86_call(cache_reg)(vcpu, VCPU_REG_CR4);
        return vcpu->arch.cr4 & mask;
 }
 
@@ -211,8 +211,8 @@ static __always_inline bool kvm_is_cr4_bit_set(struct kvm_vcpu *vcpu,
 
 static inline ulong kvm_read_cr3(struct kvm_vcpu *vcpu)
 {
-       if (!kvm_register_is_available(vcpu, VCPU_EXREG_CR3))
-               kvm_x86_call(cache_reg)(vcpu, VCPU_EXREG_CR3);
+       if (!kvm_register_is_available(vcpu, VCPU_REG_CR3))
+               kvm_x86_call(cache_reg)(vcpu, VCPU_REG_CR3);
        return vcpu->arch.cr3;
 }
 
index 85edaee27b03e3aafde6f2ed667ce22e7d71b69d..ee5749d8b3e839b8188d51593d7ea3feeef5030b 100644 (file)
@@ -1517,7 +1517,7 @@ static void svm_cache_reg(struct kvm_vcpu *vcpu, enum kvm_reg reg)
        kvm_register_mark_available(vcpu, reg);
 
        switch (reg) {
-       case VCPU_EXREG_PDPTR:
+       case VCPU_REG_PDPTR:
                /*
                 * When !npt_enabled, mmu->pdptrs[] is already available since
                 * it is always updated per SDM when moving to CRs.
@@ -4179,7 +4179,7 @@ static void svm_flush_tlb_gva(struct kvm_vcpu *vcpu, gva_t gva)
 
 static void svm_flush_tlb_guest(struct kvm_vcpu *vcpu)
 {
-       kvm_register_mark_dirty(vcpu, VCPU_EXREG_ERAPS);
+       kvm_register_mark_dirty(vcpu, VCPU_REG_ERAPS);
 
        svm_flush_tlb_asid(vcpu);
 }
@@ -4457,7 +4457,7 @@ static __no_kcsan fastpath_t svm_vcpu_run(struct kvm_vcpu *vcpu, u64 run_flags)
        svm->vmcb->save.cr2 = vcpu->arch.cr2;
 
        if (guest_cpu_cap_has(vcpu, X86_FEATURE_ERAPS) &&
-           kvm_register_is_dirty(vcpu, VCPU_EXREG_ERAPS))
+           kvm_register_is_dirty(vcpu, VCPU_REG_ERAPS))
                svm->vmcb->control.erap_ctl |= ERAP_CONTROL_CLEAR_RAP;
 
        svm_fixup_nested_rips(vcpu);
index a10668d17a16a0e32714c8c81feaf3eaea4966ba..0a4f7db7afbc27a08cab820e3db92fff6895be0b 100644 (file)
@@ -484,7 +484,7 @@ static inline bool svm_is_vmrun_failure(u64 exit_code)
  * KVM_REQ_LOAD_MMU_PGD is always requested when the cached vcpu->arch.cr3
  * is changed.  svm_load_mmu_pgd() then syncs the new CR3 value into the VMCB.
  */
-#define SVM_REGS_LAZY_LOAD_SET (1 << VCPU_EXREG_PDPTR)
+#define SVM_REGS_LAZY_LOAD_SET (1 << VCPU_REG_PDPTR)
 
 static inline void __vmcb_set_intercept(unsigned long *intercepts, u32 bit)
 {
index 3fe88f29be7a94559f4e081f06e44c752a0c96dc..22b1f06a9d403e87fec7501a742b1820a0795785 100644 (file)
@@ -1189,7 +1189,7 @@ static int nested_vmx_load_cr3(struct kvm_vcpu *vcpu, unsigned long cr3,
        }
 
        vcpu->arch.cr3 = cr3;
-       kvm_register_mark_dirty(vcpu, VCPU_EXREG_CR3);
+       kvm_register_mark_dirty(vcpu, VCPU_REG_CR3);
 
        /* Re-initialize the MMU, e.g. to pick up CR4 MMU role changes. */
        kvm_init_mmu(vcpu);
@@ -4972,7 +4972,7 @@ static void nested_vmx_restore_host_state(struct kvm_vcpu *vcpu)
 
        nested_ept_uninit_mmu_context(vcpu);
        vcpu->arch.cr3 = vmcs_readl(GUEST_CR3);
-       kvm_register_mark_available(vcpu, VCPU_EXREG_CR3);
+       kvm_register_mark_available(vcpu, VCPU_REG_CR3);
 
        /*
         * Use ept_save_pdptrs(vcpu) to load the MMU's cached PDPTRs
@@ -5074,7 +5074,7 @@ void __nested_vmx_vmexit(struct kvm_vcpu *vcpu, u32 vm_exit_reason,
        kvm_service_local_tlb_flush_requests(vcpu);
 
        /*
-        * VCPU_EXREG_PDPTR will be clobbered in arch/x86/kvm/vmx/vmx.h between
+        * VCPU_REG_PDPTR will be clobbered in arch/x86/kvm/vmx/vmx.h between
         * now and the new vmentry.  Ensure that the VMCS02 PDPTR fields are
         * up-to-date before switching to L1.
         */
index 1e47c194af53c71ea45da7b998d4b5d0d3dcccde..c23ec4ac8bc842aa996e5259630bdd0dacdab76d 100644 (file)
@@ -1013,8 +1013,8 @@ static fastpath_t tdx_exit_handlers_fastpath(struct kvm_vcpu *vcpu)
        return EXIT_FASTPATH_NONE;
 }
 
-#define TDX_REGS_AVAIL_SET     (BIT_ULL(VCPU_EXREG_EXIT_INFO_1) | \
-                                BIT_ULL(VCPU_EXREG_EXIT_INFO_2) | \
+#define TDX_REGS_AVAIL_SET     (BIT_ULL(VCPU_REG_EXIT_INFO_1) | \
+                                BIT_ULL(VCPU_REG_EXIT_INFO_2) | \
                                 BIT_ULL(VCPU_REGS_RAX) | \
                                 BIT_ULL(VCPU_REGS_RBX) | \
                                 BIT_ULL(VCPU_REGS_RCX) | \
index 577b0c6286ad499fd6503102f38e0365fa310ba3..aa1c260184397ec9ce7c65719e1ec22bdcf3975b 100644 (file)
@@ -843,8 +843,8 @@ static bool vmx_segment_cache_test_set(struct vcpu_vmx *vmx, unsigned seg,
        bool ret;
        u32 mask = 1 << (seg * SEG_FIELD_NR + field);
 
-       if (!kvm_register_is_available(&vmx->vcpu, VCPU_EXREG_SEGMENTS)) {
-               kvm_register_mark_available(&vmx->vcpu, VCPU_EXREG_SEGMENTS);
+       if (!kvm_register_is_available(&vmx->vcpu, VCPU_REG_SEGMENTS)) {
+               kvm_register_mark_available(&vmx->vcpu, VCPU_REG_SEGMENTS);
                vmx->segment_cache.bitmask = 0;
        }
        ret = vmx->segment_cache.bitmask & mask;
@@ -1609,8 +1609,8 @@ unsigned long vmx_get_rflags(struct kvm_vcpu *vcpu)
        struct vcpu_vmx *vmx = to_vmx(vcpu);
        unsigned long rflags, save_rflags;
 
-       if (!kvm_register_is_available(vcpu, VCPU_EXREG_RFLAGS)) {
-               kvm_register_mark_available(vcpu, VCPU_EXREG_RFLAGS);
+       if (!kvm_register_is_available(vcpu, VCPU_REG_RFLAGS)) {
+               kvm_register_mark_available(vcpu, VCPU_REG_RFLAGS);
                rflags = vmcs_readl(GUEST_RFLAGS);
                if (vmx->rmode.vm86_active) {
                        rflags &= RMODE_GUEST_OWNED_EFLAGS_BITS;
@@ -1633,7 +1633,7 @@ void vmx_set_rflags(struct kvm_vcpu *vcpu, unsigned long rflags)
         * if L1 runs L2 as a restricted guest.
         */
        if (is_unrestricted_guest(vcpu)) {
-               kvm_register_mark_available(vcpu, VCPU_EXREG_RFLAGS);
+               kvm_register_mark_available(vcpu, VCPU_REG_RFLAGS);
                vmx->rflags = rflags;
                vmcs_writel(GUEST_RFLAGS, rflags);
                return;
@@ -2607,17 +2607,17 @@ void vmx_cache_reg(struct kvm_vcpu *vcpu, enum kvm_reg reg)
        case VCPU_REG_RIP:
                vcpu->arch.rip = vmcs_readl(GUEST_RIP);
                break;
-       case VCPU_EXREG_PDPTR:
+       case VCPU_REG_PDPTR:
                if (enable_ept)
                        ept_save_pdptrs(vcpu);
                break;
-       case VCPU_EXREG_CR0:
+       case VCPU_REG_CR0:
                guest_owned_bits = vcpu->arch.cr0_guest_owned_bits;
 
                vcpu->arch.cr0 &= ~guest_owned_bits;
                vcpu->arch.cr0 |= vmcs_readl(GUEST_CR0) & guest_owned_bits;
                break;
-       case VCPU_EXREG_CR3:
+       case VCPU_REG_CR3:
                /*
                 * When intercepting CR3 loads, e.g. for shadowing paging, KVM's
                 * CR3 is loaded into hardware, not the guest's CR3.
@@ -2625,7 +2625,7 @@ void vmx_cache_reg(struct kvm_vcpu *vcpu, enum kvm_reg reg)
                if (!(exec_controls_get(to_vmx(vcpu)) & CPU_BASED_CR3_LOAD_EXITING))
                        vcpu->arch.cr3 = vmcs_readl(GUEST_CR3);
                break;
-       case VCPU_EXREG_CR4:
+       case VCPU_REG_CR4:
                guest_owned_bits = vcpu->arch.cr4_guest_owned_bits;
 
                vcpu->arch.cr4 &= ~guest_owned_bits;
@@ -3350,7 +3350,7 @@ void vmx_ept_load_pdptrs(struct kvm_vcpu *vcpu)
 {
        struct kvm_mmu *mmu = vcpu->arch.walk_mmu;
 
-       if (!kvm_register_is_dirty(vcpu, VCPU_EXREG_PDPTR))
+       if (!kvm_register_is_dirty(vcpu, VCPU_REG_PDPTR))
                return;
 
        if (is_pae_paging(vcpu)) {
@@ -3373,7 +3373,7 @@ void ept_save_pdptrs(struct kvm_vcpu *vcpu)
        mmu->pdptrs[2] = vmcs_read64(GUEST_PDPTR2);
        mmu->pdptrs[3] = vmcs_read64(GUEST_PDPTR3);
 
-       kvm_register_mark_available(vcpu, VCPU_EXREG_PDPTR);
+       kvm_register_mark_available(vcpu, VCPU_REG_PDPTR);
 }
 
 #define CR3_EXITING_BITS (CPU_BASED_CR3_LOAD_EXITING | \
@@ -3416,7 +3416,7 @@ void vmx_set_cr0(struct kvm_vcpu *vcpu, unsigned long cr0)
        vmcs_writel(CR0_READ_SHADOW, cr0);
        vmcs_writel(GUEST_CR0, hw_cr0);
        vcpu->arch.cr0 = cr0;
-       kvm_register_mark_available(vcpu, VCPU_EXREG_CR0);
+       kvm_register_mark_available(vcpu, VCPU_REG_CR0);
 
 #ifdef CONFIG_X86_64
        if (vcpu->arch.efer & EFER_LME) {
@@ -3434,8 +3434,8 @@ void vmx_set_cr0(struct kvm_vcpu *vcpu, unsigned long cr0)
                 * (correctly) stop reading vmcs.GUEST_CR3 because it thinks
                 * KVM's CR3 is installed.
                 */
-               if (!kvm_register_is_available(vcpu, VCPU_EXREG_CR3))
-                       vmx_cache_reg(vcpu, VCPU_EXREG_CR3);
+               if (!kvm_register_is_available(vcpu, VCPU_REG_CR3))
+                       vmx_cache_reg(vcpu, VCPU_REG_CR3);
 
                /*
                 * When running with EPT but not unrestricted guest, KVM must
@@ -3472,7 +3472,7 @@ void vmx_set_cr0(struct kvm_vcpu *vcpu, unsigned long cr0)
                 * GUEST_CR3 is still vmx->ept_identity_map_addr if EPT + !URG.
                 */
                if (!(old_cr0_pg & X86_CR0_PG) && (cr0 & X86_CR0_PG))
-                       kvm_register_mark_dirty(vcpu, VCPU_EXREG_CR3);
+                       kvm_register_mark_dirty(vcpu, VCPU_REG_CR3);
        }
 
        /* depends on vcpu->arch.cr0 to be set to a new value */
@@ -3501,7 +3501,7 @@ void vmx_load_mmu_pgd(struct kvm_vcpu *vcpu, hpa_t root_hpa, int root_level)
 
                if (!enable_unrestricted_guest && !is_paging(vcpu))
                        guest_cr3 = to_kvm_vmx(kvm)->ept_identity_map_addr;
-               else if (kvm_register_is_dirty(vcpu, VCPU_EXREG_CR3))
+               else if (kvm_register_is_dirty(vcpu, VCPU_REG_CR3))
                        guest_cr3 = vcpu->arch.cr3;
                else /* vmcs.GUEST_CR3 is already up-to-date. */
                        update_guest_cr3 = false;
@@ -3561,7 +3561,7 @@ void vmx_set_cr4(struct kvm_vcpu *vcpu, unsigned long cr4)
        }
 
        vcpu->arch.cr4 = cr4;
-       kvm_register_mark_available(vcpu, VCPU_EXREG_CR4);
+       kvm_register_mark_available(vcpu, VCPU_REG_CR4);
 
        if (!enable_unrestricted_guest) {
                if (enable_ept) {
@@ -5021,7 +5021,7 @@ void vmx_vcpu_reset(struct kvm_vcpu *vcpu, bool init_event)
        vmcs_write32(GUEST_IDTR_LIMIT, 0xffff);
 
        vmx_segment_cache_clear(vmx);
-       kvm_register_mark_available(vcpu, VCPU_EXREG_SEGMENTS);
+       kvm_register_mark_available(vcpu, VCPU_REG_SEGMENTS);
 
        vmcs_write32(GUEST_ACTIVITY_STATE, GUEST_ACTIVITY_ACTIVE);
        vmcs_write32(GUEST_INTERRUPTIBILITY_INFO, 0);
@@ -7514,9 +7514,9 @@ fastpath_t vmx_vcpu_run(struct kvm_vcpu *vcpu, u64 run_flags)
 
                vmx->vt.exit_reason.full = EXIT_REASON_INVALID_STATE;
                vmx->vt.exit_reason.failed_vmentry = 1;
-               kvm_register_mark_available(vcpu, VCPU_EXREG_EXIT_INFO_1);
+               kvm_register_mark_available(vcpu, VCPU_REG_EXIT_INFO_1);
                vmx->vt.exit_qualification = ENTRY_FAIL_DEFAULT;
-               kvm_register_mark_available(vcpu, VCPU_EXREG_EXIT_INFO_2);
+               kvm_register_mark_available(vcpu, VCPU_REG_EXIT_INFO_2);
                vmx->vt.exit_intr_info = 0;
                return EXIT_FASTPATH_NONE;
        }
index d0cc5f6c6879d30021150ba83037436ea657585e..9fb76ea48cafa1265bd69474745704ae33202cf8 100644 (file)
@@ -317,7 +317,7 @@ static __always_inline unsigned long vmx_get_exit_qual(struct kvm_vcpu *vcpu)
 {
        struct vcpu_vt *vt = to_vt(vcpu);
 
-       if (!kvm_register_test_and_mark_available(vcpu, VCPU_EXREG_EXIT_INFO_1) &&
+       if (!kvm_register_test_and_mark_available(vcpu, VCPU_REG_EXIT_INFO_1) &&
            !WARN_ON_ONCE(is_td_vcpu(vcpu)))
                vt->exit_qualification = vmcs_readl(EXIT_QUALIFICATION);
 
@@ -328,7 +328,7 @@ static __always_inline u32 vmx_get_intr_info(struct kvm_vcpu *vcpu)
 {
        struct vcpu_vt *vt = to_vt(vcpu);
 
-       if (!kvm_register_test_and_mark_available(vcpu, VCPU_EXREG_EXIT_INFO_2) &&
+       if (!kvm_register_test_and_mark_available(vcpu, VCPU_REG_EXIT_INFO_2) &&
            !WARN_ON_ONCE(is_td_vcpu(vcpu)))
                vt->exit_intr_info = vmcs_read32(VM_EXIT_INTR_INFO);
 
@@ -622,14 +622,14 @@ BUILD_CONTROLS_SHADOW(tertiary_exec, TERTIARY_VM_EXEC_CONTROL, 64)
  */
 #define VMX_REGS_LAZY_LOAD_SET ((1 << VCPU_REG_RIP) |         \
                                (1 << VCPU_REGS_RSP) |          \
-                               (1 << VCPU_EXREG_RFLAGS) |      \
-                               (1 << VCPU_EXREG_PDPTR) |       \
-                               (1 << VCPU_EXREG_SEGMENTS) |    \
-                               (1 << VCPU_EXREG_CR0) |         \
-                               (1 << VCPU_EXREG_CR3) |         \
-                               (1 << VCPU_EXREG_CR4) |         \
-                               (1 << VCPU_EXREG_EXIT_INFO_1) | \
-                               (1 << VCPU_EXREG_EXIT_INFO_2))
+                               (1 << VCPU_REG_RFLAGS) |      \
+                               (1 << VCPU_REG_PDPTR) |       \
+                               (1 << VCPU_REG_SEGMENTS) |    \
+                               (1 << VCPU_REG_CR0) |         \
+                               (1 << VCPU_REG_CR3) |         \
+                               (1 << VCPU_REG_CR4) |         \
+                               (1 << VCPU_REG_EXIT_INFO_1) | \
+                               (1 << VCPU_REG_EXIT_INFO_2))
 
 static inline unsigned long vmx_l1_guest_owned_cr0_bits(void)
 {
index 0a1b63c63d1a9cdf6c2f1748ebf8c1e5f28f8bb6..ac05cc289b566ed23d060e7d544f0b72f74666a7 100644 (file)
@@ -1090,14 +1090,14 @@ int load_pdptrs(struct kvm_vcpu *vcpu, unsigned long cr3)
        }
 
        /*
-        * Marking VCPU_EXREG_PDPTR dirty doesn't work for !tdp_enabled.
+        * Marking VCPU_REG_PDPTR dirty doesn't work for !tdp_enabled.
         * Shadow page roots need to be reconstructed instead.
         */
        if (!tdp_enabled && memcmp(mmu->pdptrs, pdpte, sizeof(mmu->pdptrs)))
                kvm_mmu_free_roots(vcpu->kvm, mmu, KVM_MMU_ROOT_CURRENT);
 
        memcpy(mmu->pdptrs, pdpte, sizeof(mmu->pdptrs));
-       kvm_register_mark_dirty(vcpu, VCPU_EXREG_PDPTR);
+       kvm_register_mark_dirty(vcpu, VCPU_REG_PDPTR);
        kvm_make_request(KVM_REQ_LOAD_MMU_PGD, vcpu);
        vcpu->arch.pdptrs_from_userspace = false;
 
@@ -1478,7 +1478,7 @@ int kvm_set_cr3(struct kvm_vcpu *vcpu, unsigned long cr3)
                kvm_mmu_new_pgd(vcpu, cr3);
 
        vcpu->arch.cr3 = cr3;
-       kvm_register_mark_dirty(vcpu, VCPU_EXREG_CR3);
+       kvm_register_mark_dirty(vcpu, VCPU_REG_CR3);
        /* Do not call post_set_cr3, we do not get here for confidential guests.  */
 
 handle_tlb_flush:
@@ -12473,7 +12473,7 @@ static int __set_sregs_common(struct kvm_vcpu *vcpu, struct kvm_sregs *sregs,
        vcpu->arch.cr2 = sregs->cr2;
        *mmu_reset_needed |= kvm_read_cr3(vcpu) != sregs->cr3;
        vcpu->arch.cr3 = sregs->cr3;
-       kvm_register_mark_dirty(vcpu, VCPU_EXREG_CR3);
+       kvm_register_mark_dirty(vcpu, VCPU_REG_CR3);
        kvm_x86_call(post_set_cr3)(vcpu, sregs->cr3);
 
        kvm_set_cr8(vcpu, sregs->cr8);
@@ -12566,7 +12566,7 @@ static int __set_sregs2(struct kvm_vcpu *vcpu, struct kvm_sregs2 *sregs2)
                for (i = 0; i < 4 ; i++)
                        kvm_pdptr_write(vcpu, i, sregs2->pdptrs[i]);
 
-               kvm_register_mark_dirty(vcpu, VCPU_EXREG_PDPTR);
+               kvm_register_mark_dirty(vcpu, VCPU_REG_PDPTR);
                mmu_reset_needed = 1;
                vcpu->arch.pdptrs_from_userspace = true;
        }
@@ -13111,7 +13111,7 @@ void kvm_vcpu_reset(struct kvm_vcpu *vcpu, bool init_event)
        kvm_rip_write(vcpu, 0xfff0);
 
        vcpu->arch.cr3 = 0;
-       kvm_register_mark_dirty(vcpu, VCPU_EXREG_CR3);
+       kvm_register_mark_dirty(vcpu, VCPU_REG_CR3);
 
        /*
         * CR0.CD/NW are set on RESET, preserved on INIT.  Note, some versions
@@ -14323,7 +14323,7 @@ int kvm_handle_invpcid(struct kvm_vcpu *vcpu, unsigned long type, gva_t gva)
                 * the RAP (Return Address Predicator).
                 */
                if (guest_cpu_cap_has(vcpu, X86_FEATURE_ERAPS))
-                       kvm_register_is_dirty(vcpu, VCPU_EXREG_ERAPS);
+                       kvm_register_is_dirty(vcpu, VCPU_REG_ERAPS);
 
                kvm_invalidate_pcid(vcpu, operand.pcid);
                return kvm_skip_emulated_instruction(vcpu);
@@ -14339,7 +14339,7 @@ int kvm_handle_invpcid(struct kvm_vcpu *vcpu, unsigned long type, gva_t gva)
                fallthrough;
        case INVPCID_TYPE_ALL_INCL_GLOBAL:
                /*
-                * Don't bother marking VCPU_EXREG_ERAPS dirty, SVM will take
+                * Don't bother marking VCPU_REG_ERAPS dirty, SVM will take
                 * care of doing so when emulating the full guest TLB flush
                 * (the RAP is cleared on all implicit TLB flushes).
                 */