From patchwork Tue May 12 23:58:56 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: "Moger, Babu" X-Patchwork-Id: 11544301 Return-Path: Received: from mail.kernel.org (pdx-korg-mail-1.web.codeaurora.org [172.30.200.123]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id 82B2615E6 for ; Tue, 12 May 2020 23:59:12 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 6577220740 for ; Tue, 12 May 2020 23:59:12 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=amdcloud.onmicrosoft.com header.i=@amdcloud.onmicrosoft.com header.b="bqmpTVK2" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731798AbgELX7I (ORCPT ); Tue, 12 May 2020 19:59:08 -0400 Received: from mail-bn7nam10on2082.outbound.protection.outlook.com ([40.107.92.82]:6102 "EHLO NAM10-BN7-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1731660AbgELX7I (ORCPT ); Tue, 12 May 2020 19:59:08 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=iyAfCc/DTOJJpJhB3F4RZNwF1boM/xIUefml0M19/bHFikEEENIpUiM6jowGZabe5pGJkdhpZ7fFcdc9n8aMDZL8AwC1h6Yh5vuq7uibjagbfd78AbtKsmZWNGnaR+nMLJRZu8M1nAfY4UV2AQ/whzCEhmvleXb/YggOFIRVubxnwF9G6/lNenAdPxO5lbasFvDruI8m2hByabOYJs9eKkiESjTbYDSk7LU9GpGJ/mQZqbkYNeuI+hk2P2CrqgF+Hso9FSvVhatQGSSxwqzLeH4Sq3XJKsXpra8sRUSpjBaQykL4O24lPr9ilzedJEhDazVDSxM4iD890wBxkPOHUA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=rMZUVX3ZqhJQHCw5uQ3/ZEfIgNnVzw2K9kZ47HJn6jM=; b=jSBC1u0pijRclk6VagsxitA7Kcyxvk8Wvw9HTHSEya3k2uQXRxwespenzkzhEum1o859cqqzMW5HrZQ1xdsWm9znPj21k/LL21ZeIcLEXpl/aA0RdVYEuQbI4+I2OXF9vld/bzFj8Wu1CTRAGdB7sY9i3h9Mmq9hp5R4C5O5SGCFde5rCLCpa+vLeU3iDhQPIeMXpbaJoAKlPCFSgSvVOTX6MpqEYkh1fJQesE4HdyLzPy9xDvvlBsMpEcTbtBF8tz/sZUtPvQi3/V582nrwATeu55FHp8B2CfzMJ+LdJBhBUtNyEgCpR9AlvP8Am13eV9g8KjgASHN+vCP5G0U1VA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=amd.com; dmarc=pass action=none header.from=amd.com; dkim=pass header.d=amd.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amdcloud.onmicrosoft.com; s=selector2-amdcloud-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=rMZUVX3ZqhJQHCw5uQ3/ZEfIgNnVzw2K9kZ47HJn6jM=; b=bqmpTVK2h4g0UcK9EAxCyFqliXl1tgZoafY38dxr/neJgDY8PWYV8FCL7mnuB2n07f3m3A6hSELBUvV7nzSGQWxwOACr9MYRsnbd+cZHI9wrSC7bCTq+q6zOfzGw+Jriv+ylGtTPNTyHnAVqp0oTmJXKrEHCBih7EJATUpLl6Kc= Authentication-Results: tencent.com; dkim=none (message not signed) header.d=none;tencent.com; dmarc=none action=none header.from=amd.com; Received: from SN1PR12MB2560.namprd12.prod.outlook.com (2603:10b6:802:26::19) by SN1PR12MB2512.namprd12.prod.outlook.com (2603:10b6:802:31::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2979.26; Tue, 12 May 2020 23:59:01 +0000 Received: from SN1PR12MB2560.namprd12.prod.outlook.com ([fe80::c0f:2938:784f:ed8d]) by SN1PR12MB2560.namprd12.prod.outlook.com ([fe80::c0f:2938:784f:ed8d%7]) with mapi id 15.20.2979.033; Tue, 12 May 2020 23:59:01 +0000 Subject: [PATCH v4 1/3] arch/x86: Update config and kernel doc for MPK feature on AMD From: Babu Moger To: corbet@lwn.net, tglx@linutronix.de, mingo@redhat.com, bp@alien8.de, hpa@zytor.com, pbonzini@redhat.com, sean.j.christopherson@intel.com Cc: x86@kernel.org, vkuznets@redhat.com, wanpengli@tencent.com, jmattson@google.com, joro@8bytes.org, dave.hansen@linux.intel.com, luto@kernel.org, peterz@infradead.org, mchehab+samsung@kernel.org, babu.moger@amd.com, changbin.du@intel.com, namit@vmware.com, bigeasy@linutronix.de, yang.shi@linux.alibaba.com, asteinhauser@google.com, anshuman.khandual@arm.com, jan.kiszka@siemens.com, akpm@linux-foundation.org, steven.price@arm.com, rppt@linux.vnet.ibm.com, peterx@redhat.com, dan.j.williams@intel.com, arjunroy@google.com, logang@deltatee.com, thellstrom@vmware.com, aarcange@redhat.com, justin.he@arm.com, robin.murphy@arm.com, ira.weiny@intel.com, keescook@chromium.org, jgross@suse.com, andrew.cooper3@citrix.com, pawan.kumar.gupta@linux.intel.com, fenghua.yu@intel.com, vineela.tummalapalli@intel.com, yamada.masahiro@socionext.com, sam@ravnborg.org, acme@redhat.com, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, kvm@vger.kernel.org Date: Tue, 12 May 2020 18:58:56 -0500 Message-ID: <158932793646.44260.2629848287332937779.stgit@naples-babu.amd.com> In-Reply-To: <158932780954.44260.4292038705292213548.stgit@naples-babu.amd.com> References: <158932780954.44260.4292038705292213548.stgit@naples-babu.amd.com> User-Agent: StGit/unknown-version X-ClientProxiedBy: DM6PR11CA0071.namprd11.prod.outlook.com (2603:10b6:5:14c::48) To SN1PR12MB2560.namprd12.prod.outlook.com (2603:10b6:802:26::19) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from naples-babu.amd.com (165.204.78.2) by DM6PR11CA0071.namprd11.prod.outlook.com (2603:10b6:5:14c::48) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3000.20 via Frontend Transport; Tue, 12 May 2020 23:58:57 +0000 X-Originating-IP: [165.204.78.2] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-HT: Tenant X-MS-Office365-Filtering-Correlation-Id: eca43666-d2f6-47b6-f3f8-08d7f6d07104 X-MS-TrafficTypeDiagnostic: SN1PR12MB2512:|SN1PR12MB2512: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:7691; X-Forefront-PRVS: 0401647B7F X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 4vsXpBljR3F2lKU87kweOaMQ1dH+hbuk2vSOTyIna2XMHWimTvG49ZIqQ3m8QYe5QesBod7FGA2KulPzkuzoMwGSnj/8j2XawlKaMhT8opTG9EBNLpg2gnuBl3iNm8JBw60eGm2Y3R+elgGN1CEtuJrhQ0YG4UR+tehWvRkiEUimJu7QHM1+VweUWijILsJfgg0/vC0l4RAcxmIe3FZsbJGn+XlS/GNkFEylMQyesOVGyUwsp4iOVvi5HL4oXfua8SPTNg2HUwY+7xqC9OyzN5jcmh0dnGc1Mdf3BWMTuh3YzdIZWwKkfusiaOPFwGmHCyksQ207t3E5yhRos22Pa3sXvt8eB0GzYBYPqbWO1X2aiiOZxuXfVSrvflnT87AS4UFDCbcTY6EKk/HQEG8ggsZmRhYZIlzVRBURg64xIS/eEQCrg7mUMoeypPacKUp1SCDzOxOFaFXz6kJlzRoStDsBFrFKkB+245HrB1i//2rktiM94PT9fVQcPjUXxh0SPCKA/M/GVJtzBF3SN0f8BA== X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:SN1PR12MB2560.namprd12.prod.outlook.com;PTR:;CAT:NONE;SFTY:;SFS:(4636009)(39860400002)(366004)(136003)(346002)(376002)(396003)(33430700001)(52116002)(26005)(8676002)(7696005)(66556008)(8936002)(5660300002)(16526019)(186003)(2906002)(7416002)(103116003)(15650500001)(956004)(316002)(7406005)(44832011)(55016002)(66946007)(478600001)(33440700001)(4326008)(66476007)(86362001);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData: 9gTfTriU6Cl8kWWfqhv68uZxwrEeuTapphWFZquH+ghyRPigNpO0VSsIBXZKhr4luhTXYoJxjy3JDY1+2lx3MP2bwSBYhRM3eVKev7KwOeU4WcFZ3l++LQUwoJmOS6o8TC0L4ZEADFuBzzD37TyouAnMBJG4I3Ycm994sb+gI28dUBuXA+ZBAPXvrw0WhPzPruZ/egHNrtCzpfeUtVpzw8UZKK2FQUIuajyGRhbjqsj12NbX4DDl6Bv4DBWB6lscZQMzim0QHVqsywVlv43pxgJAQ8MHHbxiYjscjjlgR3xk+0Ov6SLm0qvSYmWWsOltz63W3FLfpPULuRrOrRhwd8ZHJ1ng3MDWmLmURO/dKpsNIfPUwuhh9QE/A1eEwBWu2B663OXYMCCJOfcPSrsODpVC+MJ/imRkKXHywd/Aw3e7zF/imnAkhfAqRQCeoIDJBfvAaBPDLpDTPalGb5cEx5m3prP32pdTqqkusMRNLUI= X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-Network-Message-Id: eca43666-d2f6-47b6-f3f8-08d7f6d07104 X-MS-Exchange-CrossTenant-OriginalArrivalTime: 12 May 2020 23:59:00.9263 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: TK94tmugXx3/1mNf5SJLqbEGpDbeLal3tmMboRpHFngQ3O2/CV51USQwBtVghKP2 X-MS-Exchange-Transport-CrossTenantHeadersStamped: SN1PR12MB2512 Sender: kvm-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: kvm@vger.kernel.org AMD's next generation of EPYC processors support the MPK (Memory Protection Keys) feature. Add a generic X86_MEMORY_PROTECTION_KEYS config shadowing X86_INTEL_MEMORY_PROTECTION_KEYS and update the kernel documentation. No functional changes. Signed-off-by: Babu Moger --- Documentation/core-api/protection-keys.rst | 3 ++- arch/x86/Kconfig | 14 ++++++++++++-- 2 files changed, 14 insertions(+), 3 deletions(-) diff --git a/Documentation/core-api/protection-keys.rst b/Documentation/core-api/protection-keys.rst index 49d9833af871..d25e89e53c59 100644 --- a/Documentation/core-api/protection-keys.rst +++ b/Documentation/core-api/protection-keys.rst @@ -6,7 +6,8 @@ Memory Protection Keys Memory Protection Keys for Userspace (PKU aka PKEYs) is a feature which is found on Intel's Skylake "Scalable Processor" Server CPUs. -It will be avalable in future non-server parts. +It will be available in future non-server parts. Also, AMD64 +Architecture Programmer’s Manual defines PKU feature in AMD processors. For anyone wishing to test or use this feature, it is available in Amazon's EC2 C5 instances and is known to work there using an Ubuntu diff --git a/arch/x86/Kconfig b/arch/x86/Kconfig index 1197b5596d5a..15bda3a60c1d 100644 --- a/arch/x86/Kconfig +++ b/arch/x86/Kconfig @@ -1887,10 +1887,10 @@ config X86_UMIP results are dummy. config X86_INTEL_MEMORY_PROTECTION_KEYS - prompt "Intel Memory Protection Keys" + prompt "Memory Protection Keys" def_bool y # Note: only available in 64-bit mode - depends on CPU_SUP_INTEL && X86_64 + depends on X86_64 && (CPU_SUP_INTEL || CPU_SUP_AMD) select ARCH_USES_HIGH_VMA_FLAGS select ARCH_HAS_PKEYS ---help--- @@ -1902,6 +1902,16 @@ config X86_INTEL_MEMORY_PROTECTION_KEYS If unsure, say y. +config X86_MEMORY_PROTECTION_KEYS + # Both Intel and AMD platforms support "Memory Protection Keys" + # feature. So add a generic option X86_MEMORY_PROTECTION_KEYS + # and set the option whenever X86_INTEL_MEMORY_PROTECTION_KEYS + # is set. This is to avoid the confusion about the feature + # availability on AMD platforms. Also renaming the old option + # would cause the user an extra prompt during the kernel + # configuration. So avoided changing the old config name. + def_bool X86_INTEL_MEMORY_PROTECTION_KEYS + choice prompt "TSX enable mode" depends on CPU_SUP_INTEL From patchwork Tue May 12 23:59:06 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Moger, Babu" X-Patchwork-Id: 11544303 Return-Path: Received: from mail.kernel.org (pdx-korg-mail-1.web.codeaurora.org [172.30.200.123]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id BF2C990 for ; Tue, 12 May 2020 23:59:22 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 9AF1C20740 for ; Tue, 12 May 2020 23:59:22 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=amdcloud.onmicrosoft.com header.i=@amdcloud.onmicrosoft.com header.b="XjVwZ/Tg" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731821AbgELX7T (ORCPT ); Tue, 12 May 2020 19:59:19 -0400 Received: from mail-bn7nam10on2055.outbound.protection.outlook.com ([40.107.92.55]:18017 "EHLO NAM10-BN7-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1731670AbgELX7T (ORCPT ); Tue, 12 May 2020 19:59:19 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=EaLEeX6kVthKLutWfswowdxuOK34ZBtpPjshKN8D4u0RHALKAGqKHytO1bQdCFkrwOYU1wEwe0SGOGn7wt5ctRPVFBSxOWAUrsgb2x20DkYWS+JXS7vssn0KxP/Rd/2PPt/YLcikbWEvccUjjbOH6nsdPRaQWEjy3AvXpaDFfdLbwsizXJUMD3ouYXH4S1W/5he8fX2+n1fGrVZJxTucRSa0hEUDvuTfoWmSLnDzGlYJXXWgyVJAu00kJg/mziRKcAy0d7m+l/wN5rv0KhbcpYNWtc+Cvhsf0q6PLEMN1ycfTRYsokqQFYN/61qRImbWpfJVSWdTMutJUqY7kYdCbA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=znldyMC6F1kTbKS1KKqAHBggcCg8jmIa+CEice6T2E0=; b=Bzd37PEoGa5P2gi3D9fyssUQyIR5mbLCm796QVtduFslU/bE9Pn465v3j71LGdU+7GUIMOVtvxSvYMHm2Sw78+0SwQ+j5GUucpBkmAR9Q0M+mPmLpsPES+aYgJ7ypgyxnSwvZ3fsEW+G1Si8wFoBQrMBq5NFtaskvpesOcW79Yj8jKGzEHzpv97ZHxGDuiViG+x86tB1fXoTSkyRzwYXMwp0+yWmGyVE5IRkOgd5qx84+NC8Amd8wPYN9Gn0Ysyp1I9QCbPZqQdne6uW2qNOKIsCgLoNeEYMJH7kY+HprazKq8WLeqzxH71/DALPL4TUuR1B2I/e74l96epo7NNbZw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=amd.com; dmarc=pass action=none header.from=amd.com; dkim=pass header.d=amd.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amdcloud.onmicrosoft.com; s=selector2-amdcloud-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=znldyMC6F1kTbKS1KKqAHBggcCg8jmIa+CEice6T2E0=; b=XjVwZ/TglONP3THT8X4LyVNMbaf+2gyaudjZ+pAP1VDrZLU7mKBdD01XveJtB2zxQsuaX/REiGy38kOi95JrbtgX+uNNek0E3htvPr41eMKnu9RG+Ilkr7uPYoCk0STsesSAg1EnSNeejuFJqsVbtlwrgVeWIFbkp79f8UV0Nx4= Authentication-Results: tencent.com; dkim=none (message not signed) header.d=none;tencent.com; dmarc=none action=none header.from=amd.com; Received: from SN1PR12MB2560.namprd12.prod.outlook.com (2603:10b6:802:26::19) by SN1PR12MB2512.namprd12.prod.outlook.com (2603:10b6:802:31::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2979.26; Tue, 12 May 2020 23:59:11 +0000 Received: from SN1PR12MB2560.namprd12.prod.outlook.com ([fe80::c0f:2938:784f:ed8d]) by SN1PR12MB2560.namprd12.prod.outlook.com ([fe80::c0f:2938:784f:ed8d%7]) with mapi id 15.20.2979.033; Tue, 12 May 2020 23:59:11 +0000 Subject: [PATCH v4 2/3] KVM: x86: Move pkru save/restore to x86.c From: Babu Moger To: corbet@lwn.net, tglx@linutronix.de, mingo@redhat.com, bp@alien8.de, hpa@zytor.com, pbonzini@redhat.com, sean.j.christopherson@intel.com Cc: x86@kernel.org, vkuznets@redhat.com, wanpengli@tencent.com, jmattson@google.com, joro@8bytes.org, dave.hansen@linux.intel.com, luto@kernel.org, peterz@infradead.org, mchehab+samsung@kernel.org, babu.moger@amd.com, changbin.du@intel.com, namit@vmware.com, bigeasy@linutronix.de, yang.shi@linux.alibaba.com, asteinhauser@google.com, anshuman.khandual@arm.com, jan.kiszka@siemens.com, akpm@linux-foundation.org, steven.price@arm.com, rppt@linux.vnet.ibm.com, peterx@redhat.com, dan.j.williams@intel.com, arjunroy@google.com, logang@deltatee.com, thellstrom@vmware.com, aarcange@redhat.com, justin.he@arm.com, robin.murphy@arm.com, ira.weiny@intel.com, keescook@chromium.org, jgross@suse.com, andrew.cooper3@citrix.com, pawan.kumar.gupta@linux.intel.com, fenghua.yu@intel.com, vineela.tummalapalli@intel.com, yamada.masahiro@socionext.com, sam@ravnborg.org, acme@redhat.com, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, kvm@vger.kernel.org Date: Tue, 12 May 2020 18:59:06 -0500 Message-ID: <158932794619.44260.14508381096663848853.stgit@naples-babu.amd.com> In-Reply-To: <158932780954.44260.4292038705292213548.stgit@naples-babu.amd.com> References: <158932780954.44260.4292038705292213548.stgit@naples-babu.amd.com> User-Agent: StGit/unknown-version X-ClientProxiedBy: DM5PR04CA0035.namprd04.prod.outlook.com (2603:10b6:3:12b::21) To SN1PR12MB2560.namprd12.prod.outlook.com (2603:10b6:802:26::19) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from naples-babu.amd.com (165.204.78.2) by DM5PR04CA0035.namprd04.prod.outlook.com (2603:10b6:3:12b::21) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3000.20 via Frontend Transport; Tue, 12 May 2020 23:59:07 +0000 X-Originating-IP: [165.204.78.2] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-HT: Tenant X-MS-Office365-Filtering-Correlation-Id: cd439882-04ff-4de9-71fe-08d7f6d076cb X-MS-TrafficTypeDiagnostic: SN1PR12MB2512:|SN1PR12MB2512: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:5797; X-Forefront-PRVS: 0401647B7F X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 3vWtWEU+QwTHW3XVybdExwxKx+v1oXZTzK2BiRwdihx+8tyJeCzCHD46iIQV3q/Q8Hx47pievJ+P1kjs+vshTu1boaSKrea5gGA8iW5SBKv8yxx3wza0mQ88unW+YX1HHmdeSmMwiNxC7gMrxw7F4rH+lG8/fn+4ypSZDEwrGCYpSOSRmR7HdMrYH/n37GdoUfNW6Pl7DPUCKIhR6V8AJAMgExoNf8lm73Fhv9Y2AWezgGCFPKylhZbd/t//QrH5f8Ht3VCyy8ShY5oVcMqSs5WNXfN/YbFQdWwxnNcEpvX4H+TWxfTDqPk7vRZe9Iwu3khbzvhv+enio+cRdnmND6524GVNfL0o+9zh/ypRNdr3wqMxz6G3I0tlQKDXrap2cTCuJzDlR21XMD7Fz92O8eHp4KmYZJq4hp3gyH7aumST4SD5V6y9uZgPUiiA6noGLMPaZTghW6T3K+UsBbz29lkkwQhwQmlyTLRHZnLY9Rc2Q5M9sRslZR6rF4gng92Abh0pw3PKBSBr6HYL4sg/mg== X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:SN1PR12MB2560.namprd12.prod.outlook.com;PTR:;CAT:NONE;SFTY:;SFS:(4636009)(39860400002)(366004)(136003)(346002)(376002)(396003)(33430700001)(52116002)(26005)(8676002)(7696005)(66556008)(8936002)(5660300002)(16526019)(186003)(2906002)(7416002)(103116003)(956004)(316002)(7406005)(44832011)(55016002)(66946007)(478600001)(33440700001)(4326008)(66476007)(86362001);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData: uYcpm4oEN+l3ZIZ8YWAF7mxakcmg+dDkGuel1d/qz1WPW51tewg4mLezhj7JncV18cSYxbDXl+eo2ojWlfrLF89GRoPdbv8vYYLItPdrNGx9D3gH4MZjZnJeUdrI07z4MpX3xJpvGemeYpT86txcwk9Frtpt2dMDhQIt1eNPP0ndEp7Z0uwQnie3lFfAmki+h9Isg1U4kEzoDqC5mkrorKuA4aE9S6Tkwy0NW9AmcdBhnL/fPwgitGPdTOKP9vdZOuTSpDq+Zble5tXBGBT98c/gjk2nskkQNhM39DKVJdzuGuc/bpavScZvNpFMirVa+LTi3cU2rMDcFYuf3z+yHU0emMdwdrSksvwccUO64QMqFdkgF0Zd1+17HZmvVjqYpGFcSloUz9ghiiv8grnJoIupJlE0WJlVPPqBakL62X/8l1lz2pICEWmM0TOOo0nRWC7JxGY4FC9ZmHyLlilDrdj4qULeLb4ZFRUfENisW+M= X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-Network-Message-Id: cd439882-04ff-4de9-71fe-08d7f6d076cb X-MS-Exchange-CrossTenant-OriginalArrivalTime: 12 May 2020 23:59:11.0395 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: wc1InbiQjiaTkj1j3ZttkNb2HG48d2rgFd5G+/2suzvUN+6UmU10dIR8veiQoO4I X-MS-Exchange-Transport-CrossTenantHeadersStamped: SN1PR12MB2512 Sender: kvm-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: kvm@vger.kernel.org MPK feature is supported by both VMX and SVM. So we can safely move pkru state save/restore to common code. Also move all the pkru data structure to kvm_vcpu_arch. Also fixes the problem Jim Mattson pointed and suggested below. "Though rdpkru and wrpkru are contingent upon CR4.PKE, the PKRU resource isn't. It can be read with XSAVE and written with XRSTOR. So, if we don't set the guest PKRU value here(kvm_load_guest_xsave_state), the guest can read the host value. In case of kvm_load_host_xsave_state, guest with CR4.PKE clear could potentially use XRSTOR to change the host PKRU value" Signed-off-by: Babu Moger --- arch/x86/include/asm/kvm_host.h | 1 + arch/x86/kvm/vmx/vmx.c | 18 ------------------ arch/x86/kvm/x86.c | 17 +++++++++++++++++ 3 files changed, 18 insertions(+), 18 deletions(-) diff --git a/arch/x86/include/asm/kvm_host.h b/arch/x86/include/asm/kvm_host.h index 42a2d0d3984a..afd8f3780ae0 100644 --- a/arch/x86/include/asm/kvm_host.h +++ b/arch/x86/include/asm/kvm_host.h @@ -578,6 +578,7 @@ struct kvm_vcpu_arch { unsigned long cr4; unsigned long cr4_guest_owned_bits; unsigned long cr8; + u32 host_pkru; u32 pkru; u32 hflags; u64 efer; diff --git a/arch/x86/kvm/vmx/vmx.c b/arch/x86/kvm/vmx/vmx.c index c2c6335a998c..46898a476ba7 100644 --- a/arch/x86/kvm/vmx/vmx.c +++ b/arch/x86/kvm/vmx/vmx.c @@ -1372,7 +1372,6 @@ void vmx_vcpu_load(struct kvm_vcpu *vcpu, int cpu) vmx_vcpu_pi_load(vcpu, cpu); - vmx->host_pkru = read_pkru(); vmx->host_debugctlmsr = get_debugctlmsr(); } @@ -6577,11 +6576,6 @@ static void vmx_vcpu_run(struct kvm_vcpu *vcpu) kvm_load_guest_xsave_state(vcpu); - if (static_cpu_has(X86_FEATURE_PKU) && - kvm_read_cr4_bits(vcpu, X86_CR4_PKE) && - vcpu->arch.pkru != vmx->host_pkru) - __write_pkru(vcpu->arch.pkru); - pt_guest_enter(vmx); if (vcpu_to_pmu(vcpu)->version) @@ -6671,18 +6665,6 @@ static void vmx_vcpu_run(struct kvm_vcpu *vcpu) pt_guest_exit(vmx); - /* - * eager fpu is enabled if PKEY is supported and CR4 is switched - * back on host, so it is safe to read guest PKRU from current - * XSAVE. - */ - if (static_cpu_has(X86_FEATURE_PKU) && - kvm_read_cr4_bits(vcpu, X86_CR4_PKE)) { - vcpu->arch.pkru = rdpkru(); - if (vcpu->arch.pkru != vmx->host_pkru) - __write_pkru(vmx->host_pkru); - } - kvm_load_host_xsave_state(vcpu); vmx->nested.nested_run_pending = 0; diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index c5835f9cb9ad..98baeb74452c 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c @@ -836,11 +836,25 @@ void kvm_load_guest_xsave_state(struct kvm_vcpu *vcpu) vcpu->arch.ia32_xss != host_xss) wrmsrl(MSR_IA32_XSS, vcpu->arch.ia32_xss); } + + if (static_cpu_has(X86_FEATURE_PKU) && + (kvm_read_cr4_bits(vcpu, X86_CR4_PKE) || + (vcpu->arch.xcr0 & XFEATURE_MASK_PKRU)) && + vcpu->arch.pkru != vcpu->arch.host_pkru) + __write_pkru(vcpu->arch.pkru); } EXPORT_SYMBOL_GPL(kvm_load_guest_xsave_state); void kvm_load_host_xsave_state(struct kvm_vcpu *vcpu) { + if (static_cpu_has(X86_FEATURE_PKU) && + (kvm_read_cr4_bits(vcpu, X86_CR4_PKE) || + (vcpu->arch.xcr0 & XFEATURE_MASK_PKRU))) { + vcpu->arch.pkru = rdpkru(); + if (vcpu->arch.pkru != vcpu->arch.host_pkru) + __write_pkru(vcpu->arch.host_pkru); + } + if (kvm_read_cr4_bits(vcpu, X86_CR4_OSXSAVE)) { if (vcpu->arch.xcr0 != host_xcr0) @@ -3570,6 +3584,9 @@ void kvm_arch_vcpu_load(struct kvm_vcpu *vcpu, int cpu) kvm_x86_ops.vcpu_load(vcpu, cpu); + /* Save host pkru register if supported */ + vcpu->arch.host_pkru = read_pkru(); + /* Apply any externally detected TSC adjustments (due to suspend) */ if (unlikely(vcpu->arch.tsc_offset_adjustment)) { adjust_tsc_offset_host(vcpu, vcpu->arch.tsc_offset_adjustment); From patchwork Tue May 12 23:59:16 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Moger, Babu" X-Patchwork-Id: 11544305 Return-Path: Received: from mail.kernel.org (pdx-korg-mail-1.web.codeaurora.org [172.30.200.123]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id 83AFF14C0 for ; Tue, 12 May 2020 23:59:36 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 658F02312A for ; Tue, 12 May 2020 23:59:36 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=amdcloud.onmicrosoft.com header.i=@amdcloud.onmicrosoft.com header.b="27Sm+cTd" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731852AbgELX72 (ORCPT ); Tue, 12 May 2020 19:59:28 -0400 Received: from mail-bn7nam10on2080.outbound.protection.outlook.com ([40.107.92.80]:51040 "EHLO NAM10-BN7-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1731718AbgELX71 (ORCPT ); Tue, 12 May 2020 19:59:27 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=Gm0e76Jzc4ykYQ1jdrhH/2vRtA99M6BYsTXagHVzdUf/oArXCPKyohr/0zlFaeuKT4pqt/fOVZQf6zmVCN/PCK2lp70mnqosL3/RiKCtjqYNEqMCPyGQAPLvicZ1aI9u/n+QfqGXQ7enGA684wyPtp6bZ+NoNmaLrVn3K4TuMepWX4fRpYooJZYfc604TAoxBwb/TX+xvVBqvCrC+qxQN4LeQjlueP93k7j0GHZftcCxMwk/LOllDxrlDY7JVBSCidVCtPiqXsCKgqpD+2ts8IS5iWD3wdtankbRqRmVgPsA9LvpW6fBCd2pgvCoxqeJ8KFru79KxNOwfbcCCMjbCQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=E28rQdLIcibd2sbPFlCXYihTb2HalG61q18REzXIwq0=; b=GRfHuDjDEzI4evLjLj/MJMGYJDT8zPshAGP3d5W82mPJuCxFWv5XsZFyng46E4Z4r1RrTIDsmV8w1POBUddxkbXFfixvApYDWYzctXWFbnZdiHtg/4XMLmHJLF1j2jGG5xJsGQjgRhE1Myk4pPTb9PRrI0wfavqlWj8SdAzQTXiHr2CLCPBEq/8KwH1Yz/Kr2uiwGgZ8dRV4naVOB4cG4KQhJZOfBMY6oNZVNFEkFEDY8vdDP7VOngsneHfdANQtyPyQjhJT1cb+xBB3R5Bliq4dK0MXz6MX1n1BhI6GZqbDNzgxxElEebodOMjgK5CC/oieiRDf2Oaj6/pwCJdF/A== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=amd.com; dmarc=pass action=none header.from=amd.com; dkim=pass header.d=amd.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amdcloud.onmicrosoft.com; s=selector2-amdcloud-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=E28rQdLIcibd2sbPFlCXYihTb2HalG61q18REzXIwq0=; b=27Sm+cTdv/cEqzdZT9zdcAyFnbPhWrHrEsSah8hFaLL+nDzswkxzAEqMppkKYDMsYa7Nkbq9/hMe2dlfR9l1jeGJKiRxVLEbO12HP7OqEROOSYAtRJxz78jlBJ5RvjS35nHvHoD/a2jZrnXSJI/3npcBbzpxpe6QM8llEXIMQUU= Authentication-Results: tencent.com; dkim=none (message not signed) header.d=none;tencent.com; dmarc=none action=none header.from=amd.com; Received: from SN1PR12MB2560.namprd12.prod.outlook.com (2603:10b6:802:26::19) by SN1PR12MB2512.namprd12.prod.outlook.com (2603:10b6:802:31::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2979.26; Tue, 12 May 2020 23:59:20 +0000 Received: from SN1PR12MB2560.namprd12.prod.outlook.com ([fe80::c0f:2938:784f:ed8d]) by SN1PR12MB2560.namprd12.prod.outlook.com ([fe80::c0f:2938:784f:ed8d%7]) with mapi id 15.20.2979.033; Tue, 12 May 2020 23:59:20 +0000 Subject: [PATCH v4 3/3] KVM: x86: Move MPK feature detection to common code From: Babu Moger To: corbet@lwn.net, tglx@linutronix.de, mingo@redhat.com, bp@alien8.de, hpa@zytor.com, pbonzini@redhat.com, sean.j.christopherson@intel.com Cc: x86@kernel.org, vkuznets@redhat.com, wanpengli@tencent.com, jmattson@google.com, joro@8bytes.org, dave.hansen@linux.intel.com, luto@kernel.org, peterz@infradead.org, mchehab+samsung@kernel.org, babu.moger@amd.com, changbin.du@intel.com, namit@vmware.com, bigeasy@linutronix.de, yang.shi@linux.alibaba.com, asteinhauser@google.com, anshuman.khandual@arm.com, jan.kiszka@siemens.com, akpm@linux-foundation.org, steven.price@arm.com, rppt@linux.vnet.ibm.com, peterx@redhat.com, dan.j.williams@intel.com, arjunroy@google.com, logang@deltatee.com, thellstrom@vmware.com, aarcange@redhat.com, justin.he@arm.com, robin.murphy@arm.com, ira.weiny@intel.com, keescook@chromium.org, jgross@suse.com, andrew.cooper3@citrix.com, pawan.kumar.gupta@linux.intel.com, fenghua.yu@intel.com, vineela.tummalapalli@intel.com, yamada.masahiro@socionext.com, sam@ravnborg.org, acme@redhat.com, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, kvm@vger.kernel.org Date: Tue, 12 May 2020 18:59:16 -0500 Message-ID: <158932795627.44260.15144185478040178638.stgit@naples-babu.amd.com> In-Reply-To: <158932780954.44260.4292038705292213548.stgit@naples-babu.amd.com> References: <158932780954.44260.4292038705292213548.stgit@naples-babu.amd.com> User-Agent: StGit/unknown-version X-ClientProxiedBy: DM6PR11CA0045.namprd11.prod.outlook.com (2603:10b6:5:14c::22) To SN1PR12MB2560.namprd12.prod.outlook.com (2603:10b6:802:26::19) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from naples-babu.amd.com (165.204.78.2) by DM6PR11CA0045.namprd11.prod.outlook.com (2603:10b6:5:14c::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3000.20 via Frontend Transport; Tue, 12 May 2020 23:59:17 +0000 X-Originating-IP: [165.204.78.2] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-HT: Tenant X-MS-Office365-Filtering-Correlation-Id: 8e9dcead-2195-4c2b-bc49-08d7f6d07ccb X-MS-TrafficTypeDiagnostic: SN1PR12MB2512:|SN1PR12MB2512: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:7219; X-Forefront-PRVS: 0401647B7F X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: MhJUHAPLTHmyK4gTji9MVZgOSVt1gD8hNw+a7U9xTBn3eILxUDHRYNgqRYiEi+eIV1g27G0QprbnatqmlxQ4ZpoaUAsgV1E62Ep0UYeuKsZN8V2gZpXmkEWEggC6kdU5e+4mhiXi1U7yVmlIs9VHExGuvPBWzK8EY1/R7xGWF2Oiwcy8p2EEzUcUQZ2nkYYbxMFvnonzxzLLnuwSfwo40lTkngqoK3mWZhdp6vkzZQaFzCutXUq+B+VM+LmcYLzAsmPFpN4d+mqL6H/HeRU1d5s1EzLnskEuCWHJYDf2HtfTu/HrZyhsLgJVnXRz7d9O0ynn0W9eNmMUOrDzlzFtVuHSxpHTQha6Qb229284USPv2AULcEp0J03UkdYM+oRZmG4irnpFrohQkRr/prOmW3sOqo1vbkaEq1K8ohoghDQY+gV5ytJJ12Zhu/EN1GiSQRkxH/Pf1s1IzBAgYllFITTQYrJD2CTlegn8VKFBujndmflyQoO7arEolWJllQ02nr/GfCC6wTL6vswLeAva4g== X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:SN1PR12MB2560.namprd12.prod.outlook.com;PTR:;CAT:NONE;SFTY:;SFS:(4636009)(39860400002)(366004)(136003)(346002)(376002)(396003)(33430700001)(52116002)(26005)(8676002)(7696005)(66556008)(8936002)(5660300002)(16526019)(186003)(2906002)(7416002)(103116003)(956004)(316002)(7406005)(44832011)(55016002)(66946007)(478600001)(33440700001)(4326008)(66476007)(86362001);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData: upZ0IZo3EopfDTf8Ag+uHvQV2Via0Cgf5Y+zRWvkFqvuU8N87Y2YaKlT1S0QbplGCMLsu8J2MHpXThwa9a8xpBmg/ZeriswQO57rNls0tALm2TUl3WU4agyjZ3GSNSewuqAdoN/MmS+8z38FAuVKi31LSd6Bqie8nf1GzSUaEbZvPPeO7eq9GuBPMBTkVrDNFNOgf7IkZEqnJxw/UWTS/IWF/Qmd3Kw9ZeTMm4+OSM/vvpRJZ4rHBUt7oZlya9xRVUa6v5SUaqSyp03tqC8zRWPk3Zx9yluXBPwP5SQZsUtsV0b9Qi3P2s7/hgfhC+vnQErSKwV78/UnomRjlH0U7y1AbiQcwNhNRsCedMKrkS5rxbyGSix2gzT/nnr30m+3CNMWLJDAu1r5kCBgtuEqT7t8O1Bglc16SbwC7gVHQowpK0dUO7wCkt2kzgsU/ZVP6/w2mUbxPDCZBePYhvRs5wfjgUMZeBhNXy25FCahKME= X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-Network-Message-Id: 8e9dcead-2195-4c2b-bc49-08d7f6d07ccb X-MS-Exchange-CrossTenant-OriginalArrivalTime: 12 May 2020 23:59:20.7149 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: hpXxFmzvc9b/kEYKuB90RkzxAAfc3SLY6dEjbWGXI5i2xIdltcuxf+V4gmhtzcEp X-MS-Exchange-Transport-CrossTenantHeadersStamped: SN1PR12MB2512 Sender: kvm-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: kvm@vger.kernel.org Both Intel and AMD support (MPK) Memory Protection Key feature. Move the feature detection from VMX to the common code. It should work for both the platforms now. Signed-off-by: Babu Moger --- arch/x86/kvm/cpuid.c | 9 ++++++++- arch/x86/kvm/vmx/vmx.c | 4 ---- 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/arch/x86/kvm/cpuid.c b/arch/x86/kvm/cpuid.c index 901cd1fdecd9..d2c36768667d 100644 --- a/arch/x86/kvm/cpuid.c +++ b/arch/x86/kvm/cpuid.c @@ -326,7 +326,7 @@ void kvm_set_cpu_caps(void) ); kvm_cpu_cap_mask(CPUID_7_ECX, - F(AVX512VBMI) | F(LA57) | 0 /*PKU*/ | 0 /*OSPKE*/ | F(RDPID) | + F(AVX512VBMI) | F(LA57) | F(PKU) | 0 /*OSPKE*/ | F(RDPID) | F(AVX512_VPOPCNTDQ) | F(UMIP) | F(AVX512_VBMI2) | F(GFNI) | F(VAES) | F(VPCLMULQDQ) | F(AVX512_VNNI) | F(AVX512_BITALG) | F(CLDEMOTE) | F(MOVDIRI) | F(MOVDIR64B) | 0 /*WAITPKG*/ @@ -335,6 +335,13 @@ void kvm_set_cpu_caps(void) if (cpuid_ecx(7) & F(LA57)) kvm_cpu_cap_set(X86_FEATURE_LA57); + /* + * PKU not yet implemented for shadow paging and requires OSPKE + * to be set on the host. Clear it if that is not the case + */ + if (!tdp_enabled || !boot_cpu_has(X86_FEATURE_OSPKE)) + kvm_cpu_cap_clear(X86_FEATURE_PKU); + kvm_cpu_cap_mask(CPUID_7_EDX, F(AVX512_4VNNIW) | F(AVX512_4FMAPS) | F(SPEC_CTRL) | F(SPEC_CTRL_SSBD) | F(ARCH_CAPABILITIES) | F(INTEL_STIBP) | diff --git a/arch/x86/kvm/vmx/vmx.c b/arch/x86/kvm/vmx/vmx.c index 46898a476ba7..d153732ed88f 100644 --- a/arch/x86/kvm/vmx/vmx.c +++ b/arch/x86/kvm/vmx/vmx.c @@ -7136,10 +7136,6 @@ static __init void vmx_set_cpu_caps(void) if (vmx_pt_mode_is_host_guest()) kvm_cpu_cap_check_and_set(X86_FEATURE_INTEL_PT); - /* PKU is not yet implemented for shadow paging. */ - if (enable_ept && boot_cpu_has(X86_FEATURE_OSPKE)) - kvm_cpu_cap_check_and_set(X86_FEATURE_PKU); - if (vmx_umip_emulated()) kvm_cpu_cap_set(X86_FEATURE_UMIP);