]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
x86/umip: Fix decoding of register forms of 0F 01 (SGDT and SIDT aliases)
authorSean Christopherson <seanjc@google.com>
Fri, 8 Aug 2025 17:23:57 +0000 (10:23 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 29 Oct 2025 12:59:54 +0000 (13:59 +0100)
commit 27b1fd62012dfe9d3eb8ecde344d7aa673695ecf upstream.

Filter out the register forms of 0F 01 when determining whether or not to
emulate in response to a potential UMIP violation #GP, as SGDT and SIDT only
accept memory operands.  The register variants of 0F 01 are used to encode
instructions for things like VMX and SGX, i.e. not checking the Mod field
would cause the kernel to incorrectly emulate on #GP, e.g. due to a CPL
violation on VMLAUNCH.

Fixes: 1e5db223696a ("x86/umip: Add emulation code for UMIP instructions")
Signed-off-by: Sean Christopherson <seanjc@google.com>
Signed-off-by: Borislav Petkov (AMD) <bp@alien8.de>
Acked-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Cc: stable@vger.kernel.org
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/x86/kernel/umip.c

index aadb819ed91bf4cda9c7b8eb437c39cd82f9d81d..b97323edb4f451a34a4c8b69ff79b58f970067b6 100644 (file)
@@ -162,8 +162,19 @@ static int identify_insn(struct insn *insn)
        if (insn->opcode.bytes[1] == 0x1) {
                switch (X86_MODRM_REG(insn->modrm.value)) {
                case 0:
+                       /* The reg form of 0F 01 /0 encodes VMX instructions. */
+                       if (X86_MODRM_MOD(insn->modrm.value) == 3)
+                               return -EINVAL;
+
                        return UMIP_INST_SGDT;
                case 1:
+                       /*
+                        * The reg form of 0F 01 /1 encodes MONITOR/MWAIT,
+                        * STAC/CLAC, and ENCLS.
+                        */
+                       if (X86_MODRM_MOD(insn->modrm.value) == 3)
+                               return -EINVAL;
+
                        return UMIP_INST_SIDT;
                case 4:
                        return UMIP_INST_SMSW;