Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1415807imu; Sat, 26 Jan 2019 02:20:44 -0800 (PST) X-Google-Smtp-Source: ALg8bN5WiTgRxbfRBqjPZeARhSHhVF2fDPdwX/WIyT23d16pNsJKUJd8d8sNw+vkTdBByK8Ssner X-Received: by 2002:a17:902:7e0d:: with SMTP id b13mr14770733plm.154.1548498044532; Sat, 26 Jan 2019 02:20:44 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1548498044; cv=none; d=google.com; s=arc-20160816; b=L6yqS+ulqRolZdJ8t0ekFPSF+QERPEzsb0HQTvdWcOwlbWh9Y0TF+oc0s30phlQie/ FCdfglrF6OyqHJPO/WO9/kTRXW9ALpCQsdM+4wcwQlCM/nVgxjLS0hfQOs6g4GY0Q0Q1 JCbQdl9uHfP5U9Qy/VBDGCauRDj1RDZj0eaYWTmyk7FEV7cbrEj8BKSujnaTT6jJa0lT 6/ZPgpmUvMwXicACsrqpZtzsg+fhqVF6dKQA3tqtDUQWRoKM/XkMmQm1ZC9YNh4eH7Mo 83tASfEbfve+/m5p815whOkI/QMq0x5cPwqFgb97dT/z+OZZC8wzMHoCHtuI/VsbDQ7f mPjA== 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:in-reply-to :mime-version:user-agent:date:message-id:references:cc:to:subject :from; bh=huiy3nOHA4/V97TT9C10grqwhTg37xhXzZOWGzNWxpg=; b=h8qwafByQsfP1r3Va8jILMP9ddX7LSZ4YTYzjSb4iUb9nU1MSzlhRREY2U9uC5RFz1 3eHSFmtQAnDIiU5uYUpqjP3n7gwosDM8Ew6wvHtmePsD4xhTlTomUZeWskmQ5ckhqd0c Grjw2tkOKLAsZ+K1W1uaCcVrLiHd/LB1m6QFlyEz/z+u0BZYwoxdvuv0acOujDPfabhV KttRSV9gnkzrVKNkBHU6N7KQn1fbW5okrBDlm6F8lJKTzPvYDiSvCmYMKjESLIPpPFnD ixHdmcJ63/CWUJ19LTKq901f+yR/H+MtRtRHsp1YUWY+i7wnhy7bq2DR/fAH/FPXW0s8 c+Iw== 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 m38si27166211pgl.125.2019.01.26.02.20.29; Sat, 26 Jan 2019 02:20:44 -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 S1726895AbfAZKUY (ORCPT + 99 others); Sat, 26 Jan 2019 05:20:24 -0500 Received: from szxga05-in.huawei.com ([45.249.212.191]:2780 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726174AbfAZKUY (ORCPT ); Sat, 26 Jan 2019 05:20:24 -0500 Received: from DGGEMS405-HUB.china.huawei.com (unknown [172.30.72.60]) by Forcepoint Email with ESMTP id 55EE481A7C89EC101583; Sat, 26 Jan 2019 18:20:22 +0800 (CST) Received: from [127.0.0.1] (10.184.212.80) by DGGEMS405-HUB.china.huawei.com (10.3.19.205) with Microsoft SMTP Server id 14.3.408.0; Sat, 26 Jan 2019 18:20:17 +0800 From: "liwei (GF)" Subject: Re: [PATCH v9 22/26] irqchip/gic-v3: Allow interrupts to be set as pseudo-NMI To: Julien Thierry , CC: , , , , , , , , , Thomas Gleixner , Jason Cooper References: <1548084825-8803-1-git-send-email-julien.thierry@arm.com> <1548084825-8803-23-git-send-email-julien.thierry@arm.com> Message-ID: <8c0efe3f-1fc7-cbc7-0086-bd9c379cf0fc@huawei.com> Date: Sat, 26 Jan 2019 18:19:52 +0800 User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:60.0) Gecko/20100101 Thunderbird/60.4.0 MIME-Version: 1.0 In-Reply-To: <1548084825-8803-23-git-send-email-julien.thierry@arm.com> Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-Originating-IP: [10.184.212.80] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2019/1/21 23:33, Julien Thierry wrote: > Implement NMI callbacks for GICv3 irqchip. Install NMI safe handlers > when setting up interrupt line as NMI. > > Only SPIs and PPIs are allowed to be set up as NMI. > > Signed-off-by: Julien Thierry > Cc: Thomas Gleixner > Cc: Jason Cooper > Cc: Marc Zyngier > --- > drivers/irqchip/irq-gic-v3.c | 84 ++++++++++++++++++++++++++++++++++++++++++++ > 1 file changed, 84 insertions(+) > > diff --git a/drivers/irqchip/irq-gic-v3.c b/drivers/irqchip/irq-gic-v3.c > index 4df1e94..447d8ab 100644 > --- a/drivers/irqchip/irq-gic-v3.c > +++ b/drivers/irqchip/irq-gic-v3.c (snip) > > +static int gic_irq_nmi_setup(struct irq_data *d) > +{ > + struct irq_desc *desc = irq_to_desc(d->irq); > + > + if (!gic_supports_nmi()) > + return -EINVAL; > + > + if (gic_peek_irq(d, GICD_ISENABLER)) { > + pr_err("Cannot set NMI property of enabled IRQ %u\n", d->irq); > + return -EINVAL; > + } > + > + /* > + * A secondary irq_chip should be in charge of LPI request, > + * it should not be possible to get there > + */ > + if (WARN_ON(gic_irq(d) >= 8192)) > + return -EINVAL; > + > + /* desc lock should already be held */ > + if (gic_irq(d) < 32) { > + /* Setting up PPI as NMI, only switch handler for first NMI */ > + if (!refcount_inc_not_zero(&ppi_nmi_refs[gic_irq(d) - 16])) { > + refcount_set(&ppi_nmi_refs[gic_irq(d) - 16], 1); > + desc->handle_irq = handle_percpu_devid_fasteoi_nmi; > + } > + } else { > + desc->handle_irq = handle_fasteoi_nmi; > + } > + > + gic_set_irq_prio(gic_irq(d), gic_dist_base(d), GICD_INT_NMI_PRI); > + > + return 0; > +} > + > +static void gic_irq_nmi_teardown(struct irq_data *d) > +{ > + struct irq_desc *desc = irq_to_desc(d->irq); > + > + if (WARN_ON(!gic_supports_nmi())) > + return; > + > + if (gic_peek_irq(d, GICD_ISENABLER)) { > + pr_err("Cannot set NMI property of enabled IRQ %u\n", d->irq); > + return; > + } > + > + /* > + * A secondary irq_chip should be in charge of LPI request, > + * it should not be possible to get there > + */ > + if (WARN_ON(gic_irq(d) >= 8192)) > + return; > + > + /* desc lock should already be held */ > + if (gic_irq(d) < 32) { > + /* Tearing down NMI, only switch handler for last NMI */ > + if (refcount_dec_and_test(&ppi_nmi_refs[gic_irq(d) - 16])) > + desc->handle_irq = handle_percpu_devid_irq; > + } else { > + desc->handle_irq = handle_fasteoi_irq; > + } > + > + gic_set_irq_prio(gic_irq(d), gic_dist_base(d), GICD_INT_DEF_PRI); > +} > + Hello Julien, I am afraid the setting of priority is not correct here. If the irq is in redistributor(gic_irq(d) < 32), we should set the priority on each cpu, while we just set the priority on the current cpu here. static inline void __iomem *gic_dist_base(struct irq_data *d) { if (gic_irq_in_rdist(d)) /* SGI+PPI -> SGI_base for this CPU */ return gic_data_rdist_sgi_base(); if (d->hwirq <= 1023) /* SPI -> dist_base */ return gic_data.dist_base; return NULL; } I tried to add a smp_call_function here, but the kernel reported a warning as we have disabled irq when calling raw_spin_lock_irqsave in request_nmi or ready_percpu_nmi. [ 2.137262] Call trace: [ 2.137265] smp_call_function_many+0xf8/0x3a0 [ 2.137267] smp_call_function+0x40/0x58 [ 2.137271] gic_irq_nmi_setup+0xe8/0x118 [ 2.137275] ready_percpu_nmi+0x6c/0xf0 [ 2.137279] armpmu_request_irq+0x228/0x250 [ 2.137281] arm_pmu_acpi_init+0x150/0x2f0 [ 2.137284] do_one_initcall+0x54/0x218 [ 2.137289] kernel_init_freeable+0x230/0x354 [ 2.137293] kernel_init+0x18/0x118 [ 2.137295] ret_from_fork+0x10/0x18 I am exploring a better way to solve this issue. Thanks, Wei Li