irqchip: nvic: Use GENERIC_IRQ_MULTI_HANDLER
authorVladimir Murzin <vladimir.murzin@arm.com>
Wed, 1 Dec 2021 11:02:59 +0000 (11:02 +0000)
committerArd Biesheuvel <ardb@kernel.org>
Mon, 6 Dec 2021 11:49:16 +0000 (12:49 +0100)
Rather then restructuring the ARMv7M entrly logic per TODO, just move
NVIC to GENERIC_IRQ_MULTI_HANDLER.

Signed-off-by: Vladimir Murzin <vladimir.murzin@arm.com>
Acked-by: Mark Rutland <mark.rutland@arm.com>
Acked-by: Arnd Bergmann <arnd@arndb.de>
Acked-by: Marc Zyngier <maz@kernel.org>
Signed-off-by: Ard Biesheuvel <ardb@kernel.org>
Tested-by: Marc Zyngier <maz@kernel.org>
Tested-by: Vladimir Murzin <vladimir.murzin@arm.com> # ARMv7M
arch/arm/include/asm/v7m.h
arch/arm/kernel/entry-v7m.S
drivers/irqchip/Kconfig
drivers/irqchip/irq-nvic.c

index 2cb00d15831b93e9e10164134d1f72cdb64c4bb0..4512f7e1918f0000266aeeacd0ca26f3d7d1e684 100644 (file)
@@ -13,6 +13,7 @@
 #define V7M_SCB_ICSR_PENDSVSET                 (1 << 28)
 #define V7M_SCB_ICSR_PENDSVCLR                 (1 << 27)
 #define V7M_SCB_ICSR_RETTOBASE                 (1 << 11)
+#define V7M_SCB_ICSR_VECTACTIVE                        0x000001ff
 
 #define V7M_SCB_VTOR                   0x08
 
@@ -38,7 +39,7 @@
 #define V7M_SCB_SHCSR_MEMFAULTENA              (1 << 16)
 
 #define V7M_xPSR_FRAMEPTRALIGN                 0x00000200
-#define V7M_xPSR_EXCEPTIONNO                   0x000001ff
+#define V7M_xPSR_EXCEPTIONNO                   V7M_SCB_ICSR_VECTACTIVE
 
 /*
  * When branching to an address that has bits [31:28] == 0xf an exception return
index 7bde93c10962da9ffdf56965cf3c81b677808f06..520dd43e7e08305cb08864be7bcc6626944b4705 100644 (file)
@@ -39,14 +39,10 @@ __irq_entry:
        @
        @ Invoke the IRQ handler
        @
-       mrs     r0, ipsr
-       ldr     r1, =V7M_xPSR_EXCEPTIONNO
-       and     r0, r1
-       sub     r0, #16
-       mov     r1, sp
+       mov     r0, sp
        stmdb   sp!, {lr}
-       @ routine called with r0 = irq number, r1 = struct pt_regs *
-       bl      nvic_handle_irq
+       @ routine called with r0 = struct pt_regs *
+       bl      generic_handle_arch_irq
 
        pop     {lr}
        @
index 7038957f4a77a9c8be76875ebe12d931b14e535b..488eaa14d3a742d28415cbdf5777f04379bff9bd 100644 (file)
@@ -58,6 +58,7 @@ config ARM_NVIC
        bool
        select IRQ_DOMAIN_HIERARCHY
        select GENERIC_IRQ_CHIP
+       select GENERIC_IRQ_MULTI_HANDLER
 
 config ARM_VIC
        bool
index 63bac3f78863a71d5e6fce81526ad0715185db24..c0de696b3823d7e25eb31d74cb11a04b8f957e13 100644 (file)
 
 static struct irq_domain *nvic_irq_domain;
 
-static void __nvic_handle_irq(irq_hw_number_t hwirq)
+static void __irq_entry nvic_handle_irq(struct pt_regs *regs)
 {
-       generic_handle_domain_irq(nvic_irq_domain, hwirq);
-}
+       unsigned long icsr = readl_relaxed(BASEADDR_V7M_SCB + V7M_SCB_ICSR);
+       irq_hw_number_t hwirq = (icsr & V7M_SCB_ICSR_VECTACTIVE) - 16;
 
-/*
- * TODO: restructure the ARMv7M entry logic so that this entry logic can live
- * in arch code.
- */
-asmlinkage void __exception_irq_entry
-nvic_handle_irq(irq_hw_number_t hwirq, struct pt_regs *regs)
-{
-       struct pt_regs *old_regs;
-
-       irq_enter();
-       old_regs = set_irq_regs(regs);
-       __nvic_handle_irq(hwirq);
-       set_irq_regs(old_regs);
-       irq_exit();
+       generic_handle_domain_irq(nvic_irq_domain, hwirq);
 }
 
 static int nvic_irq_domain_alloc(struct irq_domain *domain, unsigned int virq,
@@ -141,6 +128,7 @@ static int __init nvic_of_init(struct device_node *node,
        for (i = 0; i < irqs; i += 4)
                writel_relaxed(0, nvic_base + NVIC_IPR + i);
 
+       set_handle_irq(nvic_handle_irq);
        return 0;
 }
 IRQCHIP_DECLARE(armv7m_nvic, "arm,armv7m-nvic", nvic_of_init);