Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp2202783yba; Mon, 6 May 2019 01:24:12 -0700 (PDT) X-Google-Smtp-Source: APXvYqz9XJH8ifg0ygzYE04DhFUdVVmLwuRs5FEmcWEPAq1RNLuz3o7FYT5LEEbt5Y94WPBpTewZ X-Received: by 2002:a63:a41:: with SMTP id z1mr30277415pgk.389.1557131052278; Mon, 06 May 2019 01:24:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1557131052; cv=none; d=google.com; s=arc-20160816; b=qoeRrr2Qjjrc2yQ6SLZFee3G9WmooczQxKC02Q6LasV2+yvSHnluuDyYTmFJ61VpJz OdaHebWIxDK8UHwdbLP83NW4MtplF0dH+ioQMUxl846ubhHKtDBSPqbr1wqbPTp/QkE8 udPWDq1+705qBpIfdf9dRQQ/MdFA5NhU7X84oVNrDRANiY4g3tY/XVW6S6coPlVM7O3e YPpEptzuYdaspkD+qkJwYOYeL/OqotRbpkOYxEVEk2++Ns5tnlXg8JfPCzTtqEX+WOJd A1ORs/j0lIYt1ca1cmkOmT9w2FWYHaOEVZLmsb2UQjZbXrJuaSvM+HLsGkV52R6KuUnk kXPw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from; bh=X887l4RyLKiKNHj9A3fp/hig7otg15vTZWUC+SvksG8=; b=oQHFXat88e56nBpAhqQj5ue0Qgdmov8zzoWmmuMGPJwW672LY4tB0JNUcJs1P3o9Z1 uB0Uddg8HHIjDJ8oGjwDxh8ZAHBLj2nvYOrkBY0oTfTn7/ZBr5YRFU+ho14YYukgPAAA 2cGZLk0eJ1Dzfd9TK4ua8dnAfkud5jYYDlLSMNtDXMnbyUcl/mq11fyigiycm6Oaor8z HcjjjORw+gt3q4iiDDWguiHxwgSuSEV54uUIAOPSpWs/Dxu3uK9gVsGBK/d9VrS/hggg nOUJYc3pCS14Rj3jJ2FSjHyLWZdHSIvOeoCJOv6KqlZYpKLHxmAE3Gx9FKRZK2VvJ85V t7EA== 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 h8si15058259pgg.573.2019.05.06.01.23.56; Mon, 06 May 2019 01:24:12 -0700 (PDT) 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 S1726381AbfEFIV0 (ORCPT + 99 others); Mon, 6 May 2019 04:21:26 -0400 Received: from szxga04-in.huawei.com ([45.249.212.190]:7171 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726657AbfEFIUq (ORCPT ); Mon, 6 May 2019 04:20:46 -0400 Received: from DGGEMS408-HUB.china.huawei.com (unknown [172.30.72.59]) by Forcepoint Email with ESMTP id 510C3F015AB8680A8616; Mon, 6 May 2019 16:20:44 +0800 (CST) Received: from euler.huawei.com (10.175.104.193) by DGGEMS408-HUB.china.huawei.com (10.3.19.208) with Microsoft SMTP Server id 14.3.439.0; Mon, 6 May 2019 16:20:41 +0800 From: Wei Li To: , , , , CC: , , , , , , , , Subject: [PATCH 2/3] arm64: Add support for on-demand backtrace of other CPUs Date: Mon, 6 May 2019 16:25:41 +0800 Message-ID: <20190506082542.11357-3-liwei391@huawei.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20190506082542.11357-1-liwei391@huawei.com> References: <20190506082542.11357-1-liwei391@huawei.com> MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.175.104.193] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org To support backtracing of other CPUs in the system on lockups, add the implementation of arch_trigger_cpumask_backtrace() for arm64. In this patch, we add an arm64 NMI-like IPI based backtracer, referring to the implementation on arm by Russell King and Chris Metcalf. Signed-off-by: Wei Li --- arch/arm64/include/asm/hardirq.h | 2 +- arch/arm64/include/asm/irq.h | 6 ++++++ arch/arm64/kernel/smp.c | 22 +++++++++++++++++++++- 3 files changed, 28 insertions(+), 2 deletions(-) diff --git a/arch/arm64/include/asm/hardirq.h b/arch/arm64/include/asm/hardirq.h index 89691c86640a..a5d94aa59c7c 100644 --- a/arch/arm64/include/asm/hardirq.h +++ b/arch/arm64/include/asm/hardirq.h @@ -24,7 +24,7 @@ #include #include -#define NR_IPI 7 +#define NR_IPI 8 typedef struct { unsigned int __softirq_pending; diff --git a/arch/arm64/include/asm/irq.h b/arch/arm64/include/asm/irq.h index b2b0c6405eb0..28471df488c0 100644 --- a/arch/arm64/include/asm/irq.h +++ b/arch/arm64/include/asm/irq.h @@ -13,5 +13,11 @@ static inline int nr_legacy_irqs(void) return 0; } +#ifdef CONFIG_SMP +extern void arch_trigger_cpumask_backtrace(const cpumask_t *mask, + bool exclude_self); +#define arch_trigger_cpumask_backtrace arch_trigger_cpumask_backtrace +#endif + #endif /* !__ASSEMBLER__ */ #endif diff --git a/arch/arm64/kernel/smp.c b/arch/arm64/kernel/smp.c index bd8fdf6fcd8e..7e862f9124f3 100644 --- a/arch/arm64/kernel/smp.c +++ b/arch/arm64/kernel/smp.c @@ -35,6 +35,7 @@ #include #include #include +#include #include #include #include @@ -83,7 +84,8 @@ enum ipi_msg_type { IPI_CPU_CRASH_STOP, IPI_TIMER, IPI_IRQ_WORK, - IPI_WAKEUP + IPI_WAKEUP, + IPI_CPU_BACKTRACE }; #ifdef CONFIG_HOTPLUG_CPU @@ -787,6 +789,7 @@ static const char *ipi_types[NR_IPI] __tracepoint_string = { S(IPI_TIMER, "Timer broadcast interrupts"), S(IPI_IRQ_WORK, "IRQ work interrupts"), S(IPI_WAKEUP, "CPU wake-up interrupts"), + S(IPI_CPU_BACKTRACE, "Backtrace interrupts"), }; static void smp_cross_call(const struct cpumask *target, unsigned int ipinr) @@ -946,6 +949,12 @@ void handle_IPI(int ipinr, struct pt_regs *regs) break; #endif + case IPI_CPU_BACKTRACE: + nmi_enter(); + nmi_cpu_backtrace(regs); + nmi_exit(); + break; + default: pr_crit("CPU%u: Unknown IPI message 0x%x\n", cpu, ipinr); break; @@ -1070,4 +1079,15 @@ bool cpus_are_stuck_in_kernel(void) void ipi_gic_nmi_setup(void __iomem *base) { + gic_sgi_set_prio(base, IPI_CPU_BACKTRACE, GICD_INT_NMI_PRI); +} + +static void raise_nmi(cpumask_t *mask) +{ + smp_cross_call(mask, IPI_CPU_BACKTRACE); +} + +void arch_trigger_cpumask_backtrace(const cpumask_t *mask, bool exclude_self) +{ + nmi_trigger_cpumask_backtrace(mask, exclude_self, raise_nmi); } -- 2.17.1