Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp1882502ybc; Wed, 20 Nov 2019 05:40:53 -0800 (PST) X-Google-Smtp-Source: APXvYqyAkbPJxU6ahvt82yNZtKKUa5hstfjj0kB9LBst08LCJiwd/w1BahwSj6GZaE7YZmQhYB4w X-Received: by 2002:a17:906:1d19:: with SMTP id n25mr5370557ejh.151.1574257253099; Wed, 20 Nov 2019 05:40:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574257253; cv=none; d=google.com; s=arc-20160816; b=uvbtxKWvWte81m2DZjzoAveeVtoYcMDMlDYQiXjctRlslSVyuK1inYjTj7maf4cta1 D98IbI+T56IftWSnL3oxWUQ3SjtHbhxSj047IWlbeuWz/NKTRPvF2Uz5CH/8gsKu3ukR 6fXv/viY/4giym0Lr/ic8TISVpld6dPfNQE3BBHKTIDS4pHnNfhE5qXQcjbzAoxWLgyl jWx4RKadUNhKtBB+ipADRESRxEQx9yZ0/mGCRWmQTx0OdjVO7vp/TXMJK1TuovCn1U3N pUGrMpKKdWfFZYFXoAHmrRVN6E9Dl/qTjuRJ/+ix6sWO2C3jnf8m3VtUSizLzPoVVlA0 v2qw== 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 :robot-unsubscribe:robot-id:message-id:mime-version:references :in-reply-to:cc:subject:to:reply-to:from:date; bh=quoN+Mgc8PeDDaxyvYk2QIBp+u1hvNuzf4tVGvVRBjU=; b=07On3FxIlSe0uwMbpMHD1eO6z7AfWc8zEOgc3SLsUu0K8vJ760EzDGxkfh1gVlWh9j PoJdk9AOd9LU97qNILcwVcgJp/bmHw63TpnNi/550AJsG6vHXSLmqnIThkSdjOTodqxR 5bZHa1xLxNAObwMZPeCtbwD1250nfjmcLknUaPsZglM20I9onwY/B8xu6x+52EZkrC6i 3lZh2OJOo96i6qq2YvR/zkH32UO75E17LJhlcw8ovU82gV03mbRleJVBpdKq43/zLiML m9AOH3054nprnIYcL6m+khp+5fiZICXm7y2/9aAOOtAB2F38k0t+fwx8aXjFtzdxKIJF fbJw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y9si15936428eju.209.2019.11.20.05.40.29; Wed, 20 Nov 2019 05:40:53 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730431AbfKTNWW (ORCPT + 99 others); Wed, 20 Nov 2019 08:22:22 -0500 Received: from Galois.linutronix.de ([193.142.43.55]:56804 "EHLO Galois.linutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729073AbfKTNVX (ORCPT ); Wed, 20 Nov 2019 08:21:23 -0500 Received: from [5.158.153.53] (helo=tip-bot2.lab.linutronix.de) by Galois.linutronix.de with esmtpsa (TLS1.2:DHE_RSA_AES_256_CBC_SHA256:256) (Exim 4.80) (envelope-from ) id 1iXPv0-0007BD-C9; Wed, 20 Nov 2019 14:21:14 +0100 Received: from [127.0.1.1] (localhost [IPv6:::1]) by tip-bot2.lab.linutronix.de (Postfix) with ESMTP id F21441C1A18; Wed, 20 Nov 2019 14:21:04 +0100 (CET) Date: Wed, 20 Nov 2019 13:21:04 -0000 From: "tip-bot2 for Marc Zyngier" Reply-to: linux-kernel@vger.kernel.org To: linux-tip-commits@vger.kernel.org Subject: [tip: irq/core] irqchip/gic-v3-its: Factor out wait_for_syncr primitive Cc: Marc Zyngier , Zenghui Yu , Ingo Molnar , Borislav Petkov , linux-kernel@vger.kernel.org In-Reply-To: <20191027144234.8395-3-maz@kernel.org> References: <20191027144234.8395-3-maz@kernel.org> MIME-Version: 1.0 Message-ID: <157425606492.12247.5343904804762133353.tip-bot2@tip-bot2> X-Mailer: tip-git-log-daemon Robot-ID: Robot-Unsubscribe: Contact to get blacklisted from these emails Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-Linutronix-Spam-Score: -1.0 X-Linutronix-Spam-Level: - X-Linutronix-Spam-Status: No , -1.0 points, 5.0 required, ALL_TRUSTED=-1,SHORTCIRCUIT=-0.0001 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The following commit has been merged into the irq/core branch of tip: Commit-ID: 2f4f064b31315c7c8986522cf38ef6d11fb77986 Gitweb: https://git.kernel.org/tip/2f4f064b31315c7c8986522cf38ef6d11fb77986 Author: Marc Zyngier AuthorDate: Fri, 08 Nov 2019 16:57:56 Committer: Marc Zyngier CommitterDate: Sun, 10 Nov 2019 18:47:50 irqchip/gic-v3-its: Factor out wait_for_syncr primitive Waiting for a redistributor to have performed an operation is a common thing to do, and the idiom is already spread around. As we're going to make even more use of this, let's have a primitive that does just that. Signed-off-by: Marc Zyngier Reviewed-by: Zenghui Yu Link: https://lore.kernel.org/r/20191027144234.8395-3-maz@kernel.org Link: https://lore.kernel.org/r/20191108165805.3071-3-maz@kernel.org --- drivers/irqchip/irq-gic-v3-its.c | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/drivers/irqchip/irq-gic-v3-its.c b/drivers/irqchip/irq-gic-v3-its.c index d5d8f8f..78d3e73 100644 --- a/drivers/irqchip/irq-gic-v3-its.c +++ b/drivers/irqchip/irq-gic-v3-its.c @@ -1093,6 +1093,12 @@ static void lpi_write_config(struct irq_data *d, u8 clr, u8 set) dsb(ishst); } +static void wait_for_syncr(void __iomem *rdbase) +{ + while (gic_read_lpir(rdbase + GICR_SYNCR) & 1) + cpu_relax(); +} + static void lpi_update_config(struct irq_data *d, u8 clr, u8 set) { struct its_device *its_dev = irq_data_get_irq_chip_data(d); @@ -2775,8 +2781,7 @@ static void its_vpe_db_proxy_move(struct its_vpe *vpe, int from, int to) rdbase = per_cpu_ptr(gic_rdists->rdist, from)->rd_base; gic_write_lpir(vpe->vpe_db_lpi, rdbase + GICR_CLRLPIR); - while (gic_read_lpir(rdbase + GICR_SYNCR) & 1) - cpu_relax(); + wait_for_syncr(rdbase); return; } @@ -2932,8 +2937,7 @@ static void its_vpe_send_inv(struct irq_data *d) rdbase = per_cpu_ptr(gic_rdists->rdist, vpe->col_idx)->rd_base; gic_write_lpir(vpe->vpe_db_lpi, rdbase + GICR_INVLPIR); - while (gic_read_lpir(rdbase + GICR_SYNCR) & 1) - cpu_relax(); + wait_for_syncr(rdbase); } else { its_vpe_send_cmd(vpe, its_send_inv); } @@ -2975,8 +2979,7 @@ static int its_vpe_set_irqchip_state(struct irq_data *d, gic_write_lpir(vpe->vpe_db_lpi, rdbase + GICR_SETLPIR); } else { gic_write_lpir(vpe->vpe_db_lpi, rdbase + GICR_CLRLPIR); - while (gic_read_lpir(rdbase + GICR_SYNCR) & 1) - cpu_relax(); + wait_for_syncr(rdbase); } } else { if (state)