Received: by 2002:a05:6359:6284:b0:131:369:b2a3 with SMTP id se4csp3220676rwb; Mon, 7 Aug 2023 09:57:27 -0700 (PDT) X-Google-Smtp-Source: AGHT+IH60di5qYFYFtzxyPYkKox15LTPi9YbWTKC08pWQUS/q2I76jNwpjg1dqHjLX6HyE7RKNqE X-Received: by 2002:a9d:6a50:0:b0:6bc:e6bc:5dbf with SMTP id h16-20020a9d6a50000000b006bce6bc5dbfmr6439933otn.23.1691427446976; Mon, 07 Aug 2023 09:57:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1691427446; cv=none; d=google.com; s=arc-20160816; b=uX2DfyBj7oM/a/kjTAh04pG4GI7U9MQ+FpXUycPvZy0UkfW6AbTH9SiuIb6efAzweJ Ogp7ZgjJIwJdDIfJaP+HPicpxxBgV+Y0gLaHxSyZDbnPuKc9Dd3wZjsTEzyVtB/xoK+O W2BJ1HB+gPfB5jut+2YI9XJTW4IidvUC0QmQuNF+Uou6H0bt4m26t6PaLfinz9R4GeYR iPNDnLpA0/wrUCVdZtLoX8ChcLT8oM0SxDu1h39ARxqhmHOx0jAJF3sBHJTY1JY8UKMo DXpOLEI0rnpd7gtp5fanz1+F9wHDgP8sA4f5/3hov03NiKz2nFB1IYpzISweu8r7R1VM 6UwA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:robot-unsubscribe :robot-id:message-id:mime-version:references:in-reply-to:cc:subject :to:reply-to:sender:from:dkim-signature:dkim-signature:date; bh=r1J6/XJHA6bwbRRigYF+K38WbO59nZ7IUa3YfUFyvtM=; fh=6NP+/TG8OVFGzKLFt+qXzpIEim1aRB6t8iizRDPnnoM=; b=TLyh08GpJ0sonP9i37n8MwA7ErH2hS74OAXYASbKsr+Se+hLLscwOevkGwbGaSe0i5 4B4i2kLDKsuVVOL0PKKy8xYNyyjfZhB4V8RHRcgkJvYYtaNaNRMescMHzsUiXrFq2I2N Gqq+O6cFFcdO1Lc/9+vmgG1ZtAO87WM7xx/RmCm1G4KD81oakNvdeS8WR3JhViBRypOS whOpmXJ1qEVC9Wf+KmJDSyGk+wIBul5bjFASUJQpIAVbFVaJCxPCmcUJSsUjBHqeEART GavYK8sI0o6uBHego4UPUdquj1TchCl8a27ilLqyIpqHRJcjMi6WcODq9THvopO6Okcy ZWHA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=3g5LqPra; dkim=neutral (no key) header.i=@linutronix.de; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h21-20020a63e155000000b005636b4c440fsi5620230pgk.52.2023.08.07.09.57.14; Mon, 07 Aug 2023 09:57:26 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=3g5LqPra; dkim=neutral (no key) header.i=@linutronix.de; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229716AbjHGQRL (ORCPT + 99 others); Mon, 7 Aug 2023 12:17:11 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52328 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229456AbjHGQRK (ORCPT ); Mon, 7 Aug 2023 12:17:10 -0400 Received: from galois.linutronix.de (Galois.linutronix.de [193.142.43.55]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 432E810CF; Mon, 7 Aug 2023 09:17:09 -0700 (PDT) Date: Mon, 07 Aug 2023 16:17:07 -0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1691425027; h=from:from:sender:sender:reply-to:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=r1J6/XJHA6bwbRRigYF+K38WbO59nZ7IUa3YfUFyvtM=; b=3g5LqPra0pdThL+PNXAA4M+FT9DFKSGjDficXnuypV4czn9GytEIKs9lu83nWTJ4zm+LG5 ycao8T9X4swT/+2qhqFKRPiKy2SzMtoLaTUesE7NU18z2FVzS/3pMjtCi6jR2pIppri1qn xIZF4zM5uX2o2p41H0C4Tt+RJkbRKA0c3qQS/Y0qNoqnpw3r0WvbGAC5wyvgUzfBYDo/vp uV+QqYvegMr4GvhjwfMXocqP53RIohELfhnfBy/Mvw4r1kwUSeG7Mh36SiyTFDje0g6AdO +Ay6xAP4l+LDf+GF8dc1ZxOv3tUkZMmWuMFZV+J9P6TdYy/wvrLMRIgbv4o2Eg== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1691425027; h=from:from:sender:sender:reply-to:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=r1J6/XJHA6bwbRRigYF+K38WbO59nZ7IUa3YfUFyvtM=; b=6ZqrdrHPAERu1N9ypC7FehYPYwIMptyGtZLlARNovd2NMAc5FBhzgx2AabxnnFO0bQvKPk I0UhbvApgULXdAAg== From: "tip-bot2 for Borislav Petkov (AMD)" Sender: tip-bot2@linutronix.de Reply-to: linux-kernel@vger.kernel.org To: linux-tip-commits@vger.kernel.org Subject: [tip: x86/urgent] x86/sev: Do not try to parse for the CC blob on non-AMD hardware Cc: Tao Liu , "Borislav Petkov (AMD)" , Tom Lendacky , , x86@kernel.org, linux-kernel@vger.kernel.org In-Reply-To: <20230601072043.24439-1-ltao@redhat.com> References: <20230601072043.24439-1-ltao@redhat.com> MIME-Version: 1.0 Message-ID: <169142502710.28540.13313883143989495944.tip-bot2@tip-bot2> Robot-ID: Robot-Unsubscribe: Contact to get blacklisted from these emails Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The following commit has been merged into the x86/urgent branch of tip: Commit-ID: bee6cf1a80b54548a039e224c651bb15b644a480 Gitweb: https://git.kernel.org/tip/bee6cf1a80b54548a039e224c651bb15b644a480 Author: Borislav Petkov (AMD) AuthorDate: Sun, 16 Jul 2023 20:22:20 +02:00 Committer: Borislav Petkov (AMD) CommitterDate: Mon, 07 Aug 2023 18:05:13 +02:00 x86/sev: Do not try to parse for the CC blob on non-AMD hardware Tao Liu reported a boot hang on an Intel Atom machine due to an unmapped EFI config table. The reason being that the CC blob which contains the CPUID page for AMD SNP guests is parsed for before even checking whether the machine runs on AMD hardware. Usually that's not a problem on !AMD hw - it simply won't find the CC blob's GUID and return. However, if any parts of the config table pointers array is not mapped, the kernel will #PF very early in the decompressor stage without any opportunity to recover. Therefore, do a superficial CPUID check before poking for the CC blob. This will fix the current issue on real hardware. It would also work as a guest on a non-lying hypervisor. For the lying hypervisor, the check is done again, *after* parsing the CC blob as the real CPUID page will be present then. Clear the #VC handler in case SEV-{ES,SNP} hasn't been detected, as a precaution. Fixes: c01fce9cef84 ("x86/compressed: Add SEV-SNP feature detection/setup") Reported-by: Tao Liu Signed-off-by: Borislav Petkov (AMD) Acked-by: Tom Lendacky Tested-by: Tao Liu Cc: Link: https://lore.kernel.org/r/20230601072043.24439-1-ltao@redhat.com --- arch/x86/boot/compressed/idt_64.c | 9 ++++++- arch/x86/boot/compressed/sev.c | 37 ++++++++++++++++++++++++++++-- 2 files changed, 43 insertions(+), 3 deletions(-) diff --git a/arch/x86/boot/compressed/idt_64.c b/arch/x86/boot/compressed/idt_64.c index 6debb81..3cdf94b 100644 --- a/arch/x86/boot/compressed/idt_64.c +++ b/arch/x86/boot/compressed/idt_64.c @@ -63,7 +63,14 @@ void load_stage2_idt(void) set_idt_entry(X86_TRAP_PF, boot_page_fault); #ifdef CONFIG_AMD_MEM_ENCRYPT - set_idt_entry(X86_TRAP_VC, boot_stage2_vc); + /* + * Clear the second stage #VC handler in case guest types + * needing #VC have not been detected. + */ + if (sev_status & BIT(1)) + set_idt_entry(X86_TRAP_VC, boot_stage2_vc); + else + set_idt_entry(X86_TRAP_VC, NULL); #endif load_boot_idt(&boot_idt_desc); diff --git a/arch/x86/boot/compressed/sev.c b/arch/x86/boot/compressed/sev.c index 09dc8c1..c3e343b 100644 --- a/arch/x86/boot/compressed/sev.c +++ b/arch/x86/boot/compressed/sev.c @@ -405,12 +405,45 @@ void sev_enable(struct boot_params *bp) bp->cc_blob_address = 0; /* + * Do an initial SEV capability check before snp_init() which + * loads the CPUID page and the same checks afterwards are done + * without the hypervisor and are trustworthy. + * + * If the HV fakes SEV support, the guest will crash'n'burn + * which is good enough. + */ + + /* Check for the SME/SEV support leaf */ + eax = 0x80000000; + ecx = 0; + native_cpuid(&eax, &ebx, &ecx, &edx); + if (eax < 0x8000001f) + return; + + /* + * Check for the SME/SEV feature: + * CPUID Fn8000_001F[EAX] + * - Bit 0 - Secure Memory Encryption support + * - Bit 1 - Secure Encrypted Virtualization support + * CPUID Fn8000_001F[EBX] + * - Bits 5:0 - Pagetable bit position used to indicate encryption + */ + eax = 0x8000001f; + ecx = 0; + native_cpuid(&eax, &ebx, &ecx, &edx); + /* Check whether SEV is supported */ + if (!(eax & BIT(1))) + return; + + /* * Setup/preliminary detection of SNP. This will be sanity-checked * against CPUID/MSR values later. */ snp = snp_init(bp); - /* Check for the SME/SEV support leaf */ + /* Now repeat the checks with the SNP CPUID table. */ + + /* Recheck the SME/SEV support leaf */ eax = 0x80000000; ecx = 0; native_cpuid(&eax, &ebx, &ecx, &edx); @@ -418,7 +451,7 @@ void sev_enable(struct boot_params *bp) return; /* - * Check for the SME/SEV feature: + * Recheck for the SME/SEV feature: * CPUID Fn8000_001F[EAX] * - Bit 0 - Secure Memory Encryption support * - Bit 1 - Secure Encrypted Virtualization support