Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp1704858ybh; Tue, 14 Jul 2020 05:18:18 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw2TG8/IlTKO+q1L3bCTuRPqMYj1REcxn8faxR0CjxrvLwHiWh9A+KvHVQV7E1xUdIlJ6qA X-Received: by 2002:a17:906:494a:: with SMTP id f10mr4472119ejt.428.1594729098298; Tue, 14 Jul 2020 05:18:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594729098; cv=none; d=google.com; s=arc-20160816; b=lDMxwyJYHKoO4x35olhjUNEAHEgP5jrAerIBeif3xFS8Gp/ryQ/ofCo3oI0xaudNZz jhL//jZARqSnFwyEvy6VO21/bnDksNv79P8MspkJ2tpBDI2MqBz6GZTsAfZnfFUrKiGT GtYqZDjBO6LlELqq7Csf47oOxVBkPjfsNOqwpf8ZyE5iVFbYX0mPc/loF+/H0/1E4NBl m7isVbTI+9Z4i6BRSv59ovyCEM38SqPe5Pgf1rUOiv6PZ9nUVX6IJEMPX9lNo/z+P+XF x4dRwJOE+I1le6QMjM01XHilj3DLCg8k1zx2tl+c6t/t59EqrUxAFlqdXbU2JIFfY/5F 0MZw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=j5pfmInLGMv14LEIYt4HRFTeHk4qiZsxrF1VYPvrsVA=; b=o1ZIepFeXjygqB6crAsU9EAuRo5krrA4uLWUgwO8J59dQDzW4XCNlB6V6yhHlVqHfC yDbp33bqliiX6ytUVNFqNOWsh/hpxaYEKCDdsxTpBOXLDcK7hIH/ZUS0V/V/qaH7Cai9 cy9ZvL90/yfBHIZ3bpx5a4Nq7f5MfG/0vNzeV4tu13qCAxUj9BK024UVsZIBIpgWYQju FquM3PDn1gqp7FAR8MkaRuHmTKGFdOMLroyp+Hnh3WBd1Q+3hwrfJ1UOTpC/Vg23DWFl qPrqYuucXv1P+l2BhvzqqyuXrjWR7a4QKcZ5uOEST/DUw/u/itunWKT2tUv9J7idTY8x 8/pQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=8bytes.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id mf6si11303943ejb.660.2020.07.14.05.17.54; Tue, 14 Jul 2020 05:18:18 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=8bytes.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728618AbgGNMOS (ORCPT + 99 others); Tue, 14 Jul 2020 08:14:18 -0400 Received: from 8bytes.org ([81.169.241.247]:52918 "EHLO theia.8bytes.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728376AbgGNMLA (ORCPT ); Tue, 14 Jul 2020 08:11:00 -0400 Received: from cap.home.8bytes.org (p5b006776.dip0.t-ipconnect.de [91.0.103.118]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) (No client certificate requested) by theia.8bytes.org (Postfix) with ESMTPSA id E55FFF8C; Tue, 14 Jul 2020 14:10:56 +0200 (CEST) From: Joerg Roedel To: x86@kernel.org Cc: Joerg Roedel , Joerg Roedel , hpa@zytor.com, Andy Lutomirski , Dave Hansen , Peter Zijlstra , Jiri Slaby , Dan Williams , Tom Lendacky , Juergen Gross , Kees Cook , David Rientjes , Cfir Cohen , Erdem Aktas , Masami Hiramatsu , Mike Stunes , Sean Christopherson , Martin Radev , linux-kernel@vger.kernel.org, kvm@vger.kernel.org, virtualization@lists.linux-foundation.org Subject: [PATCH v4 44/75] x86/sev-es: Allocate and setup IST entry for #VC Date: Tue, 14 Jul 2020 14:08:46 +0200 Message-Id: <20200714120917.11253-45-joro@8bytes.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200714120917.11253-1-joro@8bytes.org> References: <20200714120917.11253-1-joro@8bytes.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Joerg Roedel Allocate IST entry number 4 for the #VC handler and setup it up in the per-cpu TSS. This will setup the TSS for all CPUs before they even start, so that the boot-code for secondary CPUs can handle #VC exceptions. Signed-off-by: Joerg Roedel --- arch/x86/include/asm/page_64_types.h | 1 + arch/x86/kernel/sev-es.c | 5 +++++ 2 files changed, 6 insertions(+) diff --git a/arch/x86/include/asm/page_64_types.h b/arch/x86/include/asm/page_64_types.h index 288b065955b7..d0c6c10c18a0 100644 --- a/arch/x86/include/asm/page_64_types.h +++ b/arch/x86/include/asm/page_64_types.h @@ -28,6 +28,7 @@ #define IST_INDEX_NMI 1 #define IST_INDEX_DB 2 #define IST_INDEX_MCE 3 +#define IST_INDEX_VC 4 /* * Set __PAGE_OFFSET to the most negative possible address + diff --git a/arch/x86/kernel/sev-es.c b/arch/x86/kernel/sev-es.c index 64002d86a237..d415368f16ec 100644 --- a/arch/x86/kernel/sev-es.c +++ b/arch/x86/kernel/sev-es.c @@ -56,11 +56,13 @@ static void __init sev_es_setup_vc_stacks(int cpu) { struct sev_es_runtime_data *data; struct cpu_entry_area *cea; + struct tss_struct *tss; unsigned long vaddr; phys_addr_t pa; data = per_cpu(runtime_data, cpu); cea = get_cpu_entry_area(cpu); + tss = per_cpu_ptr(&cpu_tss_rw, cpu); /* Map #VC IST stack */ vaddr = CEA_ESTACK_BOT(&cea->estacks, VC); @@ -71,6 +73,9 @@ static void __init sev_es_setup_vc_stacks(int cpu) vaddr = CEA_ESTACK_BOT(&cea->estacks, VC2); pa = __pa(data->fallback_stack); cea_set_pte((void *)vaddr, pa, PAGE_KERNEL); + + /* Set IST entry in TSS */ + tss->x86_tss.ist[IST_INDEX_VC] = CEA_ESTACK_TOP(&cea->estacks, VC); } /* Needed in vc_early_forward_exception */ -- 2.27.0