[PATCH 9/9] lib: sbi_irqchip: Set the IRQ handler when registering a chip

Anup Patel anup at brainfault.org
Wed Nov 27 22:23:03 PST 2024


On Tue, Nov 5, 2024 at 9:40 AM Samuel Holland <samuel.holland at sifive.com> wrote:
>
> In addition to saving some code size, this moves the decision about
> setting the top-level external interrupt handler to the irqchip core,
> not the specific driver, which would be needed to support chained
> interrupt handlers.
>
> Signed-off-by: Samuel Holland <samuel.holland at sifive.com>

LGTM.

Reviewed-by: Anup Patel <anup at brainfault.org>

Regards,
Anup

> ---
>
>  include/sbi/sbi_irqchip.h | 13 +++----------
>  lib/sbi/sbi_irqchip.c     |  9 +++------
>  lib/utils/irqchip/imsic.c |  4 +---
>  3 files changed, 7 insertions(+), 19 deletions(-)
>
> diff --git a/include/sbi/sbi_irqchip.h b/include/sbi/sbi_irqchip.h
> index 9d26067f..e0ae12f5 100644
> --- a/include/sbi/sbi_irqchip.h
> +++ b/include/sbi/sbi_irqchip.h
> @@ -22,17 +22,10 @@ struct sbi_irqchip_device {
>
>         /** Initialize per-hart state for the current hart */
>         int (*warm_init)(struct sbi_irqchip_device *dev);
> -};
>
> -/**
> - * Set external interrupt handling function
> - *
> - * This function is called by OpenSBI platform code to set a handler for
> - * external interrupts
> - *
> - * @param fn function pointer for handling external irqs
> - */
> -void sbi_irqchip_set_irqfn(int (*fn)(void));
> +       /** Handle an IRQ from this irqchip */
> +       int (*irq_handle)(void);
> +};
>
>  /**
>   * Process external interrupts
> diff --git a/lib/sbi/sbi_irqchip.c b/lib/sbi/sbi_irqchip.c
> index ab487d16..0594e05a 100644
> --- a/lib/sbi/sbi_irqchip.c
> +++ b/lib/sbi/sbi_irqchip.c
> @@ -20,12 +20,6 @@ static int default_irqfn(void)
>
>  static int (*ext_irqfn)(void) = default_irqfn;
>
> -void sbi_irqchip_set_irqfn(int (*fn)(void))
> -{
> -       if (fn)
> -               ext_irqfn = fn;
> -}
> -
>  int sbi_irqchip_process(void)
>  {
>         return ext_irqfn();
> @@ -34,6 +28,9 @@ int sbi_irqchip_process(void)
>  void sbi_irqchip_add_device(struct sbi_irqchip_device *dev)
>  {
>         sbi_list_add_tail(&dev->node, &irqchip_list);
> +
> +       if (dev->irq_handle)
> +               ext_irqfn = dev->irq_handle;
>  }
>
>  int sbi_irqchip_init(struct sbi_scratch *scratch, bool cold_boot)
> diff --git a/lib/utils/irqchip/imsic.c b/lib/utils/irqchip/imsic.c
> index b5198b43..057b9fa7 100644
> --- a/lib/utils/irqchip/imsic.c
> +++ b/lib/utils/irqchip/imsic.c
> @@ -347,6 +347,7 @@ int imsic_data_check(struct imsic_data *imsic)
>
>  static struct sbi_irqchip_device imsic_device = {
>         .warm_init      = imsic_warm_irqchip_init,
> +       .irq_handle     = imsic_external_irqfn,
>  };
>
>  int imsic_cold_irqchip_init(struct imsic_data *imsic)
> @@ -376,9 +377,6 @@ int imsic_cold_irqchip_init(struct imsic_data *imsic)
>                         return SBI_ENOMEM;
>         }
>
> -       /* Setup external interrupt function for IMSIC */
> -       sbi_irqchip_set_irqfn(imsic_external_irqfn);
> -
>         /* Add IMSIC regions to the root domain */
>         for (i = 0; i < IMSIC_MAX_REGS && imsic->regs[i].size; i++) {
>                 rc = sbi_domain_root_add_memrange(imsic->regs[i].addr,
> --
> 2.45.1
>
>
> --
> opensbi mailing list
> opensbi at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/opensbi



More information about the opensbi mailing list