Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp638375iob; Wed, 18 May 2022 09:36:43 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwP3lJnJLIJr1mT2WD0XApXHBXCTV7WgzwGMEo/PsQe8nb/OKF1uSNseLWio58L10+Bs65b X-Received: by 2002:a05:6a00:996:b0:50b:76b8:3bb1 with SMTP id u22-20020a056a00099600b0050b76b83bb1mr514526pfg.9.1652891803018; Wed, 18 May 2022 09:36:43 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1652891803; cv=pass; d=google.com; s=arc-20160816; b=pDn1KBk2SrYx+WAP2SqH1VxxzhPYwxgO9VXjI7Ub50yKfnQ3rM4FrOT88jlStCOslW KWS2KLIwg7F+ONmkUW09QqBrtUz/0miGPTlA+nYa6HLCgOgwgYmqxw8/jzJERc0etdxf LzNbkZcIUZCR+cmsBeyQAndGAEpPrbqUS9hNrKh8b8o4tv7XCwgq6m1wfC2+OhRrbSmG XrxSxZ//p1ONZIkIY/4FbqTqb4ZfbS6muVGexiLG2/FSonZcD6AYOn2bzt09gtBZBsGc NA6C2s0hWIJKaVAJHD+NF3Fa1V/4Wz7/ndsSJLWx0/pSEnBLLxtfjOHUGbHKvzI998cC dZbQ== 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=mXunKw91AziOXjcu05kGRHnt4FdkawppGowMHSMaU3Y=; b=cXMP4df79eRNGWBIJQq+H7WLx9K1Va0vdHkW/ARXsGIwOVhtlFx/TACCR7sjVbhvX8 Ow+JKVcmxWk5egAopGZy6eoH7eYXMvG4jsorhfId8eFAMPnLbt6ii0Wv+wUztxorUm0T fDOJgtqrRqTeuuc0pfD+mk9EMzwIqC06xh34Pqt+vEkHEPZ7IZzLj6zuCABBIBn9EvEW /4AgP+pepnicV5aXyevZBRT02updvvCKKo+0HSHUkxi/6xwJ+yH0rwWLgL8Mmix67qAl jyD+FuWfC5/4nQMfd8iSunzUwdenG+9Imfzw9Q+oTrWjAB1nvdMb156YDVyHVKez9Mff D2dw== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@amd.com header.s=selector1 header.b=5K3el0lS; 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 u16-20020a17090341d000b001614cd997a6si3819792ple.481.2022.05.18.09.36.42 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 18 May 2022 09:36: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=5K3el0lS; 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 68CAB27FDB; Wed, 18 May 2022 09:30:52 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240280AbiERQ3K (ORCPT + 99 others); Wed, 18 May 2022 12:29:10 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43376 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240211AbiERQ1Y (ORCPT ); Wed, 18 May 2022 12:27:24 -0400 Received: from NAM12-MW2-obe.outbound.protection.outlook.com (mail-mw2nam12on2052.outbound.protection.outlook.com [40.107.244.52]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2EEA1986DD; Wed, 18 May 2022 09:27:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=TWpcWt6D9TG/fZw35N9G4dw4nzwlyVQ39VmU9hAwITMvKKRnW6kyda+UKoaoaxYHLAkPa/E+DT9AFT8MoruOfogkhFXBC6oVnuLJV+7T/DvASxW0g4806GSqyi9zHjn3Lsq4n5bU+KAgUsBWeQYj4U59mQIfDZh+G4yfjx23DfLlwxSUBB5jol4dduv+Zh2lEgI0yOLdHoEDaBiN9i+HLt7iJc1fHyHOVS4DevOk10Ms8wbWC6bMYPE1by+5mogQEQxz9eQ2pahpbxBhLhkid6xjyhRxpkQhP7rXGFpsi+kKl2cg0rZzTtKrlG5C3gzk2Hry6cV06zG6A470Vm7GhA== 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=mXunKw91AziOXjcu05kGRHnt4FdkawppGowMHSMaU3Y=; b=h9QawsoAfRUumOTF05TkAmGt00qzofGaGMzOsxn837Lnqy7ENNeVqe7pAG5Elq8ZTDvJBYmyqpjnBga2Uh6hQT7zo2MzsSnlmb4Z++AHO98xZpwbvznCTrMY9xi3REmKcPlEFT+KORXwvdw77q3iacfyxEj27xk/D4vqZdX2ni/oXyMD10Ht2OGyWljMmXeVrbPOiFuJ5DRa9cbafFCerdT1Nf0YPfiW/9nt4JWkSRcMvPA460MnDuPdvNTVlEk2FGF92pAh6JBdlWnMM+Zw2W+EkYNHvnTqeRvy5bFZkDlE+oYg9ZkbAXyertuLCS7XQ0ETzcM2nFO09nKTw6IXig== 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=mXunKw91AziOXjcu05kGRHnt4FdkawppGowMHSMaU3Y=; b=5K3el0lSJx1aFKdrTMlN1rQMYymoZUAgKZLl3vW7HeqjyjQJOIFJXTVJrALguqKNMppSs4GI2orq7VUZQydo7jk9dTPBX3DktKQrqbws2w68TKhXrEn2z+pLZfSBSE/fgkT+bRE0yErKcWnAosyDhQLCuEb/rPEkgrzRydyK4xA= Received: from BN7PR02CA0011.namprd02.prod.outlook.com (2603:10b6:408:20::24) by BL1PR12MB5176.namprd12.prod.outlook.com (2603:10b6:208:311::19) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5250.14; Wed, 18 May 2022 16:27:18 +0000 Received: from BN8NAM11FT008.eop-nam11.prod.protection.outlook.com (2603:10b6:408:20:cafe::e6) by BN7PR02CA0011.outlook.office365.com (2603:10b6:408:20::24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5250.14 via Frontend Transport; Wed, 18 May 2022 16:27:18 +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; pr=C Received: from SATLEXMB04.amd.com (165.204.84.17) by BN8NAM11FT008.mail.protection.outlook.com (10.13.177.95) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.5273.14 via Frontend Transport; Wed, 18 May 2022 16:27:17 +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; Wed, 18 May 2022 11:27:16 -0500 From: Suravee Suthikulpanit To: , CC: , , , , , , , Suravee Suthikulpanit Subject: [PATCH v5 14/17] KVM: SVM: Use target APIC ID to complete x2AVIC IRQs when possible Date: Wed, 18 May 2022 11:26:49 -0500 Message-ID: <20220518162652.100493-15-suravee.suthikulpanit@amd.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220518162652.100493-1-suravee.suthikulpanit@amd.com> References: <20220518162652.100493-1-suravee.suthikulpanit@amd.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-Originating-IP: [10.180.168.240] X-ClientProxiedBy: SATLEXMB04.amd.com (10.181.40.145) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 7fd94a5d-fd5c-485c-3a72-08da38eb46ab X-MS-TrafficTypeDiagnostic: BL1PR12MB5176: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: xCqVeXDBEPyzbuyT6/2rYVGNDGkWZM9v7J5JFuRqwNhlqPNiy6sEh89RAGII+VoKq+4MzsywT4ttSP8FxmazYUFL23XPkUSK57/3mVchLwz85SwjCcG9i6A1367Bne46QjM7R9a9+U1j0qLY6lmhScy7hnHeVwbVscaYoP4xTgBJGgxTHP/e04rktLlGc0+jrtx7ItH7K0VLlbJ0Ue+6fytvKTLCWZ35HyQjcdPoOyBSpwf3KhQxoNU+/97CzWDjS/QuNmv8qKySLJQjminy5HRlnE9iOJCNB4yNfLP90uMWakToBWzkv6AQyhVBnrtRJQwuOI4L21cQ1w5F14VuwkwoEj5M/z2G+6buRowIMEikY2c+1k6OHZ43uFmfyM3g41oCaNSF1qeNsrgIPgt7AUC+C3woVfL/QQab9ILGt2fwEJcmreNkxw4u/65wMGKrfrgFPXP0qUny9B1/Pm/UHY6a/6T7Nq52oqI6dW7r+b/vNBLd3S4VPLFStgLV8Y4Rai9ty8ZM8G0zy3DYXUtD5rJ+OVLs2n5XhLN6SjesxpicN0UJr57mfNvWhMfzX4PeDl1KwWqw1rMin3j2JywzsJ8dz8yBUq3XfcRcKRLyuiDxTvoQbBvPLZVf9qwA3ORaeYm8NkF4AS7ZgpI6WvZgLf5ntCDmCWi6PTZlDcVYUYfWbco/Va7BAD14RLTq3VYYvePpFZsfgUrIOTlxIOOK1A== 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)(40470700004)(36840700001)(46966006)(5660300002)(16526019)(7696005)(36860700001)(356005)(2616005)(86362001)(508600001)(186003)(44832011)(81166007)(8936002)(36756003)(40460700003)(426003)(47076005)(70586007)(1076003)(316002)(54906003)(82310400005)(110136005)(4326008)(8676002)(70206006)(6666004)(2906002)(26005)(336012)(83380400001)(36900700001);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 18 May 2022 16:27:17.9662 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 7fd94a5d-fd5c-485c-3a72-08da38eb46ab 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: BN8NAM11FT008.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BL1PR12MB5176 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 For x2AVIC, the index from incomplete IPI #vmexit info is invalid for logical cluster mode. Only ICRH/ICRL values can be used to determine the IPI destination APIC ID. Since QEMU defines guest physical APIC ID to be the same as vCPU ID, it can be used to quickly identify the target vCPU to deliver IPI, and avoid the overhead from searching through all vCPUs to match the target vCPU. Reviewed-by: Maxim Levitsky Signed-off-by: Suravee Suthikulpanit --- arch/x86/kvm/svm/avic.c | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/arch/x86/kvm/svm/avic.c b/arch/x86/kvm/svm/avic.c index bac876bb1cf1..9c439a32c343 100644 --- a/arch/x86/kvm/svm/avic.c +++ b/arch/x86/kvm/svm/avic.c @@ -358,7 +358,26 @@ static int avic_kick_target_vcpus_fast(struct kvm *kvm, struct kvm_lapic *source /* For xAPIC logical mode, the index is for logical APIC table. */ apic_id = avic_logical_id_table[index] & 0x1ff; } else { - return -EINVAL; + /* For x2APIC logical mode, cannot leverage the index. + * Instead, calculate physical ID from logical ID in ICRH. + */ + int apic; + int first = ffs(icrh & 0xffff); + int last = fls(icrh & 0xffff); + int cluster = (icrh & 0xffff0000) >> 16; + + /* + * If the x2APIC logical ID sub-field (i.e. icrh[15:0]) contains zero + * or more than 1 bits, we cannot match just one vcpu to kick for + * fast path. + */ + if (!first || (first != last)) + return -EINVAL; + + apic = first - 1; + if ((apic < 0) || (apic > 15) || (cluster >= 0xfffff)) + return -EINVAL; + apic_id = (cluster << 4) + apic; } } -- 2.25.1