Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp1598929ybh; Mon, 20 Jul 2020 02:25:34 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx0wa82r608Z3er99wyK0SQiRLZOA0IKbxb0zktcgGN43fWO0N7RKms4fIGHmoVwOC1yzIV X-Received: by 2002:a05:6402:128c:: with SMTP id w12mr21386084edv.65.1595237133937; Mon, 20 Jul 2020 02:25:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595237133; cv=none; d=google.com; s=arc-20160816; b=CNmCTfK2FP2ApUW+qroB73fBJz2ohCya9Y/Ia5NPYrWrC6odEG2gDxc0kg4MH/oPsY 2deuf2Jfe8u2QPnO/ToPubWaHu1yTPeDrhh9bWFJOWv5+x4POGkBf9j+cvaEcYndJvO9 rUZHxAJTHlrzADkzamsA3KLyZOksNJPXYsUrjlR0akpbYBRClR0lyfZjHiJFYkBNUf37 iWbiD5WGyzJw5MHoLKjEGCkCVSqdjpjmMHEF4d8LGsVb+4G0DJNjoYfM1uKxybm6raTw F1romPB2Qc78ERO0B7VxidEtFd5MAHpCrLpOoFDv1QvmQ4LEMfvV6FFqXTuCB+FjveTl Gthw== 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 :message-id:date:subject:cc:to:from; bh=4Wx8xrk9jOF5L4BudNGqTpOXcHRn0qJdIzwzSdm2JbU=; b=WeEfxv8X3VDs9iz/p4mULBf8/HQ3ujjncDFa8U8mbK4Y4YSiqsD6pvFd5oPw9CvocC +J8stgl/lM2o4qHR1hEJaKqcm4/K8fu7ivFEHVOM/DdZnhrr2yWy6HVJd0uGycohrFJ3 gEldUriTzq5NvHBHxyU0/IKXzRiW3syw4AHVS0jTYk4KsvKZSRlpKTvURdyPryKIDDKD L7X9t27C4wGGn6JRCuY0KnQ8syYkH7EO+e7pqemouZ7/jApU3zJCYHa1aSvhADXOqQ9q 8UzMo7alvR7dd1CTdDF1fgdqqMF2XuN2jS/lz6I5LCBT8NFLbgXjWPO8Bou7ANufH3TW KY+A== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id co28si10170233edb.540.2020.07.20.02.25.11; Mon, 20 Jul 2020 02:25:33 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728209AbgGTJXz (ORCPT + 99 others); Mon, 20 Jul 2020 05:23:55 -0400 Received: from szxga06-in.huawei.com ([45.249.212.32]:50256 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1727961AbgGTJXw (ORCPT ); Mon, 20 Jul 2020 05:23:52 -0400 Received: from DGGEMS406-HUB.china.huawei.com (unknown [172.30.72.58]) by Forcepoint Email with ESMTP id 0EF2B8CE758EB4A7A53B; Mon, 20 Jul 2020 17:23:51 +0800 (CST) Received: from DESKTOP-8RFUVS3.china.huawei.com (10.174.185.226) by DGGEMS406-HUB.china.huawei.com (10.3.19.206) with Microsoft SMTP Server id 14.3.487.0; Mon, 20 Jul 2020 17:23:44 +0800 From: Zenghui Yu To: , CC: , , , Zenghui Yu , Subject: [PATCH v2] irqchip/gic-v4.1: Ensure accessing the correct RD when writing INVALLR Date: Mon, 20 Jul 2020 17:23:28 +0800 Message-ID: <20200720092328.708-1-yuzenghui@huawei.com> X-Mailer: git-send-email 2.23.0.windows.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.174.185.226] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The GICv4.1 spec tells us that it's CONSTRAINED UNPREDICTABLE to issue a register-based invalidation operation for a vPEID not mapped to that RD, or another RD within the same CommonLPIAff group. To follow this rule, commit f3a059219bc7 ("irqchip/gic-v4.1: Ensure mutual exclusion between vPE affinity change and RD access") tried to address the race between the RD accesses and the vPE affinity change, but somehow forgot to take GICR_INVALLR into account. Let's take the vpe_lock before evaluating vpe->col_idx to fix it. Fixes: f3a059219bc7 ("irqchip/gic-v4.1: Ensure mutual exclusion between vPE affinity change and RD access") Cc: stable@vger.kernel.org Signed-off-by: Zenghui Yu --- * From v1: - Add a proper Fixes: tag - Cc stable drivers/irqchip/irq-gic-v3-its.c | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/drivers/irqchip/irq-gic-v3-its.c b/drivers/irqchip/irq-gic-v3-its.c index beac4caefad9..5bf2263bdbcc 100644 --- a/drivers/irqchip/irq-gic-v3-its.c +++ b/drivers/irqchip/irq-gic-v3-its.c @@ -4087,18 +4087,22 @@ static void its_vpe_4_1_deschedule(struct its_vpe *vpe, static void its_vpe_4_1_invall(struct its_vpe *vpe) { void __iomem *rdbase; + unsigned long flags; u64 val; + int cpu; val = GICR_INVALLR_V; val |= FIELD_PREP(GICR_INVALLR_VPEID, vpe->vpe_id); /* Target the redistributor this vPE is currently known on */ - raw_spin_lock(&gic_data_rdist_cpu(vpe->col_idx)->rd_lock); - rdbase = per_cpu_ptr(gic_rdists->rdist, vpe->col_idx)->rd_base; + cpu = vpe_to_cpuid_lock(vpe, &flags); + raw_spin_lock(&gic_data_rdist_cpu(cpu)->rd_lock); + rdbase = per_cpu_ptr(gic_rdists->rdist, cpu)->rd_base; gic_write_lpir(val, rdbase + GICR_INVALLR); wait_for_syncr(rdbase); - raw_spin_unlock(&gic_data_rdist_cpu(vpe->col_idx)->rd_lock); + raw_spin_unlock(&gic_data_rdist_cpu(cpu)->rd_lock); + vpe_to_cpuid_unlock(vpe, flags); } static int its_vpe_4_1_set_vcpu_affinity(struct irq_data *d, void *vcpu_info) -- 2.19.1