diff options
author | Anup Patel <apatel@ventanamicro.com> | 2022-05-13 06:56:27 +0300 |
---|---|---|
committer | Anup Patel <anup@brainfault.org> | 2022-05-13 06:56:27 +0300 |
commit | 3a69d12fc3af4dbcfd4975086985bbe903e8580f (patch) | |
tree | 6dd7be5ca0bbeb0c2ba81e601945b6b6c26323f9 /lib/utils/irqchip/fdt_irqchip.c | |
parent | bfeb305e0f8da3f8bdff97a21a6628c3156fbfff (diff) | |
download | opensbi-3a69d12fc3af4dbcfd4975086985bbe903e8580f.tar.xz |
lib: utils/irqchip: Generate FDT irqchip driver list at compile-time
Instead of having FDT irqchip driver list hard-coded in the C source,
we generate it using carray.sh at compile-time.
Signed-off-by: Anup Patel <apatel@ventanamicro.com>
Reviewed-by: Atish Patra <atishp@rivosinc.com>
Diffstat (limited to 'lib/utils/irqchip/fdt_irqchip.c')
-rw-r--r-- | lib/utils/irqchip/fdt_irqchip.c | 16 |
1 files changed, 5 insertions, 11 deletions
diff --git a/lib/utils/irqchip/fdt_irqchip.c b/lib/utils/irqchip/fdt_irqchip.c index 6007755..1b6b674 100644 --- a/lib/utils/irqchip/fdt_irqchip.c +++ b/lib/utils/irqchip/fdt_irqchip.c @@ -12,15 +12,9 @@ #include <sbi_utils/fdt/fdt_helper.h> #include <sbi_utils/irqchip/fdt_irqchip.h> -extern struct fdt_irqchip fdt_irqchip_aplic; -extern struct fdt_irqchip fdt_irqchip_imsic; -extern struct fdt_irqchip fdt_irqchip_plic; - -static struct fdt_irqchip *irqchip_drivers[] = { - &fdt_irqchip_aplic, - &fdt_irqchip_imsic, - &fdt_irqchip_plic -}; +/* List of FDT irqchip drivers generated at compile time */ +extern struct fdt_irqchip *fdt_irqchip_drivers[]; +extern unsigned long fdt_irqchip_drivers_size; #define FDT_IRQCHIP_MAX_DRIVERS 8 @@ -61,8 +55,8 @@ static int fdt_irqchip_cold_init(void) const struct fdt_match *match; void *fdt = fdt_get_address(); - for (pos = 0; pos < array_size(irqchip_drivers); pos++) { - drv = irqchip_drivers[pos]; + for (pos = 0; pos < fdt_irqchip_drivers_size; pos++) { + drv = fdt_irqchip_drivers[pos]; noff = -1; drv_added = false; |