Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp5914002imu; Wed, 30 Jan 2019 05:49:26 -0800 (PST) X-Google-Smtp-Source: ALg8bN4P4OPh21sgNmq9XK33qGOSxxhysUYldS1o+0luWq614/bkjxGbDFytmQyBMgxI9hKaCaFV X-Received: by 2002:a17:902:3f81:: with SMTP id a1mr30085598pld.258.1548856166091; Wed, 30 Jan 2019 05:49:26 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1548856166; cv=none; d=google.com; s=arc-20160816; b=FC0F2X9/NesNc4e09A0VvXfPNuf8vqoDvbbLEKQNWcyRtkO8YhI90kvggo7eMVBa4R qGH5X5MhB/1J9b8EgRDD+VUfG6AEzwGxtHd//7QwD1WkPwrubnkBOiWsdXjwFplvcPEq jnLVSLQMP9Mhe9aBY698abWFT7Wmz5lbOrp78iBrPxoU5o0Wwon46BTqR61u84I9G7lo ARLimD+69ZN1ppkCK0C1VcAdRYt49gJMzTzUgr4eRnXMGO247/qUM+VHPgrt841JxlRz QXQjK25d1mCRhZuJoniHDItp8v6Z6Pobq7kB91jzD1yK1BZQMb1nCn1kwhk3bwv58ZB4 4QUg== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=tBfj3jch95rfh4rE5n2tS7S8ZEg2yWGQg2BgSJVoYw4=; b=Hov1WuB7ZJvVe5o7kY/qdiCTHOVf3LJE/5uok9tmce7RgSWfNZC8KzHvAPpoEj+Anq xAJoAyqexheDIW6pSZ9/fAY9LjpWmKpPSC7gQg4mEdApfeNm7WUES4gj/rJkzs3HVRrL OGpcSKeYPYxOgC7OwtN+1CdZGWlZ9TcYmPsz5BHOrLukus2NtbZ77EXKAjcohQvNUONK 3L2aE9tQEq1SXgvd8pL4bnGW28We1qO3Ox+TFhWWh2JMbbD0F2Slz2y23sGFZe1lJXht WKH7mW05JNOeoNHrf2Hx7QySdnzftCmp4VbkVxY5DgQH6K922fqSesPXwXhrcd2krZqA KRAQ== 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 3si1537362plo.217.2019.01.30.05.49.09; Wed, 30 Jan 2019 05:49:26 -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 S1731060AbfA3NrD (ORCPT + 99 others); Wed, 30 Jan 2019 08:47:03 -0500 Received: from foss.arm.com ([217.140.101.70]:54600 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726151AbfA3NrC (ORCPT ); Wed, 30 Jan 2019 08:47:02 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 65B0DEBD; Wed, 30 Jan 2019 05:47:02 -0800 (PST) Received: from [10.1.197.45] (e112298-lin.cambridge.arm.com [10.1.197.45]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 77D1F3F59C; Wed, 30 Jan 2019 05:47:00 -0800 (PST) Subject: Re: [PATCH v9 26/26] arm64: Enable the support of pseudo-NMIs To: Marc Zyngier Cc: linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, daniel.thompson@linaro.org, joel@joelfernandes.org, christoffer.dall@arm.com, james.morse@arm.com, catalin.marinas@arm.com, will.deacon@arm.com, mark.rutland@arm.com References: <1548084825-8803-1-git-send-email-julien.thierry@arm.com> <1548084825-8803-27-git-send-email-julien.thierry@arm.com> <86o981ueyj.wl-marc.zyngier@arm.com> From: Julien Thierry Message-ID: <38589cbc-dbaf-b903-6c56-65e796063680@arm.com> Date: Wed, 30 Jan 2019 13:46:57 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.2.1 MIME-Version: 1.0 In-Reply-To: <86o981ueyj.wl-marc.zyngier@arm.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 28/01/2019 12:47, Marc Zyngier wrote: > On Mon, 21 Jan 2019 15:33:45 +0000, > Julien Thierry wrote: >> >> Add a build option and a command line parameter to build and enable the >> support of pseudo-NMIs. >> >> Signed-off-by: Julien Thierry >> Suggested-by: Daniel Thompson >> Cc: Catalin Marinas >> Cc: Will Deacon >> --- >> Documentation/admin-guide/kernel-parameters.txt | 6 ++++++ >> arch/arm64/Kconfig | 14 ++++++++++++++ >> arch/arm64/kernel/cpufeature.c | 11 ++++++++++- >> 3 files changed, 30 insertions(+), 1 deletion(-) >> >> diff --git a/Documentation/admin-guide/kernel-parameters.txt b/Documentation/admin-guide/kernel-parameters.txt >> index b799bcf..173e2cc 100644 >> --- a/Documentation/admin-guide/kernel-parameters.txt >> +++ b/Documentation/admin-guide/kernel-parameters.txt >> @@ -1197,6 +1197,12 @@ >> to discrete, to make X server driver able to add WB >> entry later. This parameter enables that. >> >> + enable_pseudo_nmi [ARM64] >> + Enables support for pseudo-NMIs in the kernel. This >> + requires both the kernel to be built with >> + CONFIG_ARM64_PSEUDO_NMI and to be running on a >> + platform with GICv3. >> + >> enable_timer_pin_1 [X86] >> Enable PIN 1 of APIC timer >> Can be useful to work around chipset bugs >> diff --git a/arch/arm64/Kconfig b/arch/arm64/Kconfig >> index a4168d3..8d84bfd 100644 >> --- a/arch/arm64/Kconfig >> +++ b/arch/arm64/Kconfig >> @@ -1328,6 +1328,20 @@ config ARM64_MODULE_PLTS >> bool >> select HAVE_MOD_ARCH_SPECIFIC >> >> +config ARM64_PSEUDO_NMI >> + bool "Support for NMI-like interrupts" >> + select CONFIG_ARM_GIC_V3 >> + help >> + Adds support for mimicking Non-Maskable Interrupts through the use of >> + GIC interrupt priority. This support requires version 3 or later of >> + Arm GIC. >> + >> + This high priority configuration for interrupts need to be > > s/need/needs/ > >> + explicitly enabled through the new kernel parameter > > It won't be new forever... ;-) > Good point! >> + "enable_pseudo_nmi". > > I'm not overly keen on this name. We already have "irqchip.gicv3_nolpi", > so why not adopt something similar. "irqchip.gicv3_pseudo_nmi", taking a > boolean value? > Sure, I'm fine with that. >> + >> + If unsure, say N >> + >> config RELOCATABLE >> bool >> help >> diff --git a/arch/arm64/kernel/cpufeature.c b/arch/arm64/kernel/cpufeature.c >> index b530fb24..e66d778 100644 >> --- a/arch/arm64/kernel/cpufeature.c >> +++ b/arch/arm64/kernel/cpufeature.c >> @@ -1207,10 +1207,19 @@ static void cpu_enable_address_auth(struct arm64_cpu_capabilities const *cap) >> #endif /* CONFIG_ARM64_PTR_AUTH */ >> >> #ifdef CONFIG_ARM64_PSEUDO_NMI >> +static bool enable_pseudo_nmi; >> + >> +static int __init early_enable_pseudo_nmi(char *p) >> +{ >> + enable_pseudo_nmi = true; > > And if you're happy with the above, this becomes: > > return strtobool(p, &enable_pseudo_nmi); > Thanks, -- Julien Thierry