Received: by 2002:a05:6a10:2726:0:0:0:0 with SMTP id ib38csp921811pxb; Wed, 6 Apr 2022 04:21:42 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyRY0TiFK4Xarh574WjB8+LDCdJgZQ6biHXK6nUfgCIeZ+jWBKQVZ9V9DVhOq4m4AWJI2G1 X-Received: by 2002:a17:90a:8c8e:b0:1c9:c81d:9e13 with SMTP id b14-20020a17090a8c8e00b001c9c81d9e13mr9221692pjo.123.1649244102292; Wed, 06 Apr 2022 04:21:42 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1649244102; cv=pass; d=google.com; s=arc-20160816; b=WY7Bby9Vwf9lLvEeVL6c0R7dBt6JPEk3hJc6fmPRbJ807hjiF9r1G7EdVVLC9AoZ5U GX0tXRvOo57ki5WWMPswNPQa/a8jgLDXgQYJ5iFeoTySd3hQOZZ0Ink6Pc4UEG1V/1bj DxPnRlYk361ZaBDboL2mc5/0Xc6A5iwDgJ2SPmOmiytZY1IcbjZXwxUyl1/TRWmQWTdT fzjoWJKZXDk/fLRZCKCNW7TJ4r5ReCce5SyOw+nSI3137a/sCXaJO2/UXymJanLCsLEB kaO9bL+Jw0AqxrqZ5grI8sdAUJ5TV9fFp72XFID3KL5pHvrEtq5MCq37DGq+RzGXci3T gUOg== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=a+cIZM44K1A6L6EhrP2lWOUKZhgxGlxlqZ/u4F9HDVE=; b=bPuO9uo8N++nqgfdczk+JuYiDBxDr2Gm7ZW7nDW0sFnoxhPjLop4/INU+cL/PwL+KH SohF8856r6SoxudoOAKIG7PxesNqAx1KE5MnvaihmBLNZOGt4/dxA7f6Xkyh6YM40OTw Cladi7nik0CB063sXygU0J1//xyX7DGIU5E2qHNYsl0UO7OUbflCM9EzYo2Tp99xiUlW E8MVSV/TXoG53Qhi3UBnBP0ZSwmxvUMxHUY31zgkTdAjUuZWn7GGUR9nu6IHnH2eEuCZ 4yZXXWo1IMaQaYwv/aP6DV/uhQrtQ3MZwzVzvoUWBRLcllfGFodscV8HOBoVTWAYaLG3 /s4w== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@amd.com header.s=selector1 header.b=f6q64Ija; arc=pass (i=1 spf=pass spfdomain=amd.com dmarc=pass fromdomain=amd.com); spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=amd.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id e123-20020a636981000000b00382773dcd86si15046645pgc.431.2022.04.06.04.21.41 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 06 Apr 2022 04:21:42 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@amd.com header.s=selector1 header.b=f6q64Ija; arc=pass (i=1 spf=pass spfdomain=amd.com dmarc=pass fromdomain=amd.com); spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=amd.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 9697F5EAAA4; Wed, 6 Apr 2022 02:43:31 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1850743AbiDFC7d (ORCPT + 99 others); Tue, 5 Apr 2022 22:59:33 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45126 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1451618AbiDFBQ6 (ORCPT ); Tue, 5 Apr 2022 21:16:58 -0400 Received: from NAM12-BN8-obe.outbound.protection.outlook.com (mail-bn8nam12on2061.outbound.protection.outlook.com [40.107.237.61]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AAF4E5046B; Tue, 5 Apr 2022 16:09:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=gNTzlyUiCsABqJ/F7AaA7b7SFieV8ofEITtfYUWLOZC/e16dz5W/AtBqEwpnq4JVOddRuxfa67BVOJqvRk7mnSbn0XPrjnZLUJImrVcyaJt+WsSl+NGZDfniqOlwZmiM2+p15OOuoftyny/5T1P7sH8yakcxnz1gJrl5YgSxm7aPgPIUL/SGoqveFjq7DlDWvgyEHIe/2JbOV7JBlXqqCnA08bVmt6iBjgTbnRddBQscz0XXMpDWZKCGmkUL/ecaxuolVoAmFy+mXrsbesFwD8w1Q2OMetyEdmofV9xcychx/1Q3QBBi3gQMRxsejZ8aVcA1X03mGk7AkdTdRNJxjg== 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-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=a+cIZM44K1A6L6EhrP2lWOUKZhgxGlxlqZ/u4F9HDVE=; b=eDGrPgoTMOWhjq17sbxP5EY8Kqg1kr383T5/LdLdDs2x2p396rJ1UnepbeDF8Orr2ILvikLguYw0j5sP/u3hrcTshPEjNdkEeV1LTm6K1C3gRRC/azkaB77vvWgmjziqcE+EeeRf/Px1A6GmgfMuGPGtVtvTI1Nd//670V1aE2CWUS+ByTxIHoLTb0L+vnkxy/JLkthrrMCrG3Jr6JvRtKRT9CbXvmxxGiO2Bi4fWcGLB5qJPQ56oUc3UVHRjoc+7d+dsTXBYki9Ic8gn85sf9XhryCXKuxeQyjNbc9gsJfDkc2MzeDRoAem9mxIV9BTNwc7H5BZX0ebiPNeAUiAzA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=vger.kernel.org smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=a+cIZM44K1A6L6EhrP2lWOUKZhgxGlxlqZ/u4F9HDVE=; b=f6q64Ija4Pe7xMtaOZCW3JEke2u1fek4idzox7P6igBuEndNlrbZkEOVD9ypfyFLGIiSvtXTVdCjmAsFqtf2q1g4eknHb2DLE+PQWbFHKDUYKsq3IzcpbaVKB2f7Ni3VDxjJ5XyFrnFR9R14k1Ao7+pwPjZvFmjuuIqY8gH7Ku8= Received: from MW4PR04CA0073.namprd04.prod.outlook.com (2603:10b6:303:6b::18) by BYAPR12MB2630.namprd12.prod.outlook.com (2603:10b6:a03:67::27) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5123.31; Tue, 5 Apr 2022 23:09:29 +0000 Received: from CO1NAM11FT008.eop-nam11.prod.protection.outlook.com (2603:10b6:303:6b:cafe::ef) by MW4PR04CA0073.outlook.office365.com (2603:10b6:303:6b::18) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5123.31 via Frontend Transport; Tue, 5 Apr 2022 23:09:29 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; Received: from SATLEXMB04.amd.com (165.204.84.17) by CO1NAM11FT008.mail.protection.outlook.com (10.13.175.191) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.5144.20 via Frontend Transport; Tue, 5 Apr 2022 23:09:28 +0000 Received: from sp5-759chost.amd.com (10.180.168.240) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.24; Tue, 5 Apr 2022 18:09:22 -0500 From: Suravee Suthikulpanit To: , , CC: , , , , , , , , , , , , Suravee Suthikulpanit Subject: [PATCH 06/12] KVM: SVM: Do not support updating APIC ID when in x2APIC mode Date: Tue, 5 Apr 2022 18:08:49 -0500 Message-ID: <20220405230855.15376-7-suravee.suthikulpanit@amd.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220405230855.15376-1-suravee.suthikulpanit@amd.com> References: <20220405230855.15376-1-suravee.suthikulpanit@amd.com> MIME-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 8bit X-Originating-IP: [10.180.168.240] X-ClientProxiedBy: SATLEXMB03.amd.com (10.181.40.144) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 50654199-fe32-4507-5787-08da1759562b X-MS-TrafficTypeDiagnostic: BYAPR12MB2630:EE_ X-Microsoft-Antispam-PRVS: X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 5pbSeH0RYPFKLvSvhRXrnUBaSHwm0cmkhiaEQArQFUB4C27zcdPR96x1kpbn6VNcArD3V96zGR3pNgFi1hwGvOArRZCBAsvkQXkc1orATfwin1TOWVjlm1ZwWCRu7bF+B15wCk8XtYzFzf46cUOTfhKSPVpHO2E8Bu29Oa9EbiorsPCclxfLJlZCM50C7zMwsvN76WoWcC4T7oNqOiOGNEDa0zWb1Pu/EAZ7+DRO49l4bZfo2sPcXimD5SEQLMlDGynUCwOrhBmW3Vv8n9Q/+xKSAHks9I9ZoL82oXPfG9arY7GOxhl5laoJL/TunxeUk0H9khKzyNOmVmJoSbyLPXsWnCRMa809ef1kXF4PU9qQlloDudWfytCp9ckUR3vFDgZJ7OSzaWTfwNqgcUeOvqi+PDF/VzUnlul6JTLECJSntOBmBVREGb8/43GL2GYjNE/y0Hmh2ibWNf1rjnfyR+VhK/ZQHVt5NkEA8eyM5Gndep69QDdG4oUz8DzE/TZp9UrHDvyNYMbJHw8+SdPp4LLf3cdCS7bsF/zwrVVvQSHuhvmc7dgUULcHlkNJGlWbDuGNqTtD4f//G9Flc4qJg1Vf1eJ2ibFckXZOS/ixJM6/r+DrmL2UCATC0ZV559VtKqvcy6XTVxb5RIWx6OAM6bwO2pHh687vzEnoj5HZSg9+k8Cbfts3erwKXm80KQNB3jJyqtWgHYbinCcz/L57AA== X-Forefront-Antispam-Report: CIP:165.204.84.17;CTRY:US;LANG:en;SCL:1;SRV:;IPV:CAL;SFV:NSPM;H:SATLEXMB04.amd.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230001)(4636009)(46966006)(36840700001)(40470700004)(70206006)(70586007)(316002)(110136005)(54906003)(86362001)(82310400005)(6666004)(1076003)(356005)(2616005)(81166007)(8676002)(7696005)(4326008)(8936002)(508600001)(83380400001)(47076005)(40460700003)(2906002)(36756003)(36860700001)(44832011)(7416002)(186003)(426003)(26005)(5660300002)(336012)(16526019)(36900700001);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 05 Apr 2022 23:09:28.9212 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 50654199-fe32-4507-5787-08da1759562b X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d;Ip=[165.204.84.17];Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: CO1NAM11FT008.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BYAPR12MB2630 X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no 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 In X2APIC mode, the Logical Destination Register is read-only, which provides a fixed mapping between the logical and physical APIC IDs. Therefore, there is no Logical APIC ID table in X2AVIC and the processor uses the X2APIC ID in the backing page to create a vCPU’s logical ID. In addition, KVM does not support updating APIC ID in x2APIC mode, which means AVIC does not need to handle this case. Therefore, check x2APIC mode when handling physical and logical APIC ID update, and when invalidating logical APIC ID table. Suggested-by: Maxim Levitsky Signed-off-by: Suravee Suthikulpanit --- arch/x86/kvm/svm/avic.c | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/arch/x86/kvm/svm/avic.c b/arch/x86/kvm/svm/avic.c index c36a236e1e8a..f378f7810db7 100644 --- a/arch/x86/kvm/svm/avic.c +++ b/arch/x86/kvm/svm/avic.c @@ -424,8 +424,13 @@ static void avic_invalidate_logical_id_entry(struct kvm_vcpu *vcpu) { struct vcpu_svm *svm = to_svm(vcpu); bool flat = svm->dfr_reg == APIC_DFR_FLAT; - u32 *entry = avic_get_logical_id_entry(vcpu, svm->ldr_reg, flat); + u32 *entry; + /* Note: x2AVIC does not use logical APIC ID table */ + if (apic_x2apic_mode(vcpu->arch.apic)) + return; + + entry = avic_get_logical_id_entry(vcpu, svm->ldr_reg, flat); if (entry) clear_bit(AVIC_LOGICAL_ID_ENTRY_VALID_BIT, (unsigned long *)entry); } @@ -437,6 +442,10 @@ static int avic_handle_ldr_update(struct kvm_vcpu *vcpu) u32 ldr = kvm_lapic_get_reg(vcpu->arch.apic, APIC_LDR); u32 id = kvm_xapic_id(vcpu->arch.apic); + /* AVIC does not support LDR update for x2APIC */ + if (apic_x2apic_mode(vcpu->arch.apic)) + return 0; + if (ldr == svm->ldr_reg) return 0; @@ -457,6 +466,14 @@ static int avic_handle_apic_id_update(struct kvm_vcpu *vcpu) struct vcpu_svm *svm = to_svm(vcpu); u32 id = kvm_xapic_id(vcpu->arch.apic); + /* + * KVM does not support apic ID update for x2APIC. + * Also, need to check if the APIC ID exceed 254. + */ + if (apic_x2apic_mode(vcpu->arch.apic) || + (vcpu->vcpu_id >= APIC_BROADCAST)) + return 0; + if (vcpu->vcpu_id == id) return 0; -- 2.25.1