Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp1192130pxb; Tue, 26 Oct 2021 04:42:02 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy0oItVvPZjKPdryVaSpM6W7AO14rhRBXJ/dj9iukJpcUSUR9a1LIwke0IKiVQtDlb+I3Wy X-Received: by 2002:a17:902:b716:b0:13f:b2d1:f316 with SMTP id d22-20020a170902b71600b0013fb2d1f316mr22194947pls.24.1635248522763; Tue, 26 Oct 2021 04:42:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1635248522; cv=none; d=google.com; s=arc-20160816; b=b3/TKExoOi2iKd25dn/ohl8eS50Vg7XoZ4nwmS1t0fJMvSQ3kfWy2pY48aY9MHwHnb eT9DKFryHell6XUJS7cSYM+VTSIDjHA3+zecKAhfj0AANwqW8mjY5VeBWWUpNKthIikC 9M9hqJ0ivbMDWDm3W6Kr1QsXqRIqc6JqfRfE/UOFJB/6fqXiGd51lP0tc8xPzCb7n7BH p2ndTI0K1W/kA7xSYoA+FfuzUR4efQLGUeOqab8/lw7fWsbZ6MllIhJ1xafiho1qXttS fCvkQVsO4hiUaQWnK/q0RYtSj9SoH84vphXiysK0XnuZh1at6QenWXA1BcFIqEqe9hq2 +QRg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from; bh=KriZhU45grq27W8Qhu4f4CDPIh+/zh1rgwSmBjR+oNU=; b=emX0kysZuK+2j+a4/V01/iU710j/ApLrO4OZiQ0S3GF0QosjQBO8+T40xpQjgLsSDO bY2TF2abZ4gz/eBxJ5veP8MsjecbQUCGzEC4zyCU1IkhL3VHNeTRKFHIifaJAZW0k9CN dgBM+7bUquKDZdxhkMnG8tRmGhIrL7/q3NVADMOJzaM6/ECOG2Y5aO+rgVvNPMLqhHVn DYg1jN2bGwU2SDvly1mBktRv2N7x9b2ScqA0ZWwNwlLQ+IIrjI9KezrY/ocxPf/Blo2x rMmeDj1aPpGQ50/utXSIOE51M1aI940pgd/XevmljgI9TMkZV7qFC3ScR6/fsMV3AMCV /ITg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id l15si15010519plg.78.2021.10.26.04.41.48; Tue, 26 Oct 2021 04:42:02 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234797AbhJZJ2I (ORCPT + 99 others); Tue, 26 Oct 2021 05:28:08 -0400 Received: from foss.arm.com ([217.140.110.172]:55494 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234847AbhJZJ2C (ORCPT ); Tue, 26 Oct 2021 05:28:02 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 19F491FB; Tue, 26 Oct 2021 02:25:39 -0700 (PDT) Received: from lakrids.cambridge.arm.com (usa-sjc-imap-foss1.foss.arm.com [10.121.207.14]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 6CA273F70D; Tue, 26 Oct 2021 02:25:36 -0700 (PDT) From: Mark Rutland To: linux-kernel@vger.kernel.org Cc: aou@eecs.berkeley.edu, catalin.marinas@arm.com, deanbo422@gmail.com, green.hu@gmail.com, guoren@kernel.org, jonas@southpole.se, kernelfans@gmail.com, linux-arm-kernel@lists.infradead.org, linux@armlinux.org.uk, mark.rutland@arm.com, maz@kernel.org, nickhu@andestech.com, palmer@dabbelt.com, paul.walmsley@sifive.com, shorne@gmail.com, stefan.kristiansson@saunalahti.fi, tglx@linutronix.de, tsbogend@alpha.franken.de, vgupta@kernel.org, vladimir.murzin@arm.com, will@kernel.org Subject: [PATCH v2 07/17] irq: add generic_handle_arch_irq() Date: Tue, 26 Oct 2021 10:24:54 +0100 Message-Id: <20211026092504.27071-8-mark.rutland@arm.com> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20211026092504.27071-1-mark.rutland@arm.com> References: <20211026092504.27071-1-mark.rutland@arm.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Several architectures select GENERIC_IRQ_MULTI_HANDLER and branch to handle_arch_irq() without performing any entry accounting. Add a generic wrapper to handle the common irqentry work when invoking handle_arch_irq(). Where an architecture needs to perform some entry accounting itself, it will need to invoke handle_arch_irq() itself. In subsequent patches it will become the responsibilty of the entry code to set the irq regs when entering an IRQ (rather than deferring this to an irqchip handler), so generic_handle_arch_irq() is made to set the irq regs now. This can be redundant in some cases, but is never harmful as saving/restoring the old regs nests safely. Signed-off-by: Mark Rutland Reviewed-by: Marc Zyngier Reviewed-by: Guo Ren Cc: Thomas Gleixner --- include/linux/irq.h | 1 + kernel/irq/handle.c | 18 ++++++++++++++++++ 2 files changed, 19 insertions(+) diff --git a/include/linux/irq.h b/include/linux/irq.h index c8293c817646..988c225eef2d 100644 --- a/include/linux/irq.h +++ b/include/linux/irq.h @@ -1261,6 +1261,7 @@ int __init set_handle_irq(void (*handle_irq)(struct pt_regs *)); * top-level IRQ handler. */ extern void (*handle_arch_irq)(struct pt_regs *) __ro_after_init; +asmlinkage void generic_handle_arch_irq(struct pt_regs *regs); #else #ifndef set_handle_irq #define set_handle_irq(handle_irq) \ diff --git a/kernel/irq/handle.c b/kernel/irq/handle.c index 221d80c31e94..27182003b879 100644 --- a/kernel/irq/handle.c +++ b/kernel/irq/handle.c @@ -14,6 +14,8 @@ #include #include +#include + #include #include "internals.h" @@ -226,4 +228,20 @@ int __init set_handle_irq(void (*handle_irq)(struct pt_regs *)) handle_arch_irq = handle_irq; return 0; } + +/** + * generic_handle_arch_irq - root irq handler for architectures which do no + * entry accounting themselves + * @regs: Register file coming from the low-level handling code + */ +asmlinkage void noinstr generic_handle_arch_irq(struct pt_regs *regs) +{ + struct pt_regs *old_regs; + + irq_enter(); + old_regs = set_irq_regs(regs); + handle_arch_irq(regs); + set_irq_regs(old_regs); + irq_exit(); +} #endif -- 2.11.0