mirror of
https://github.com/riscv-software-src/opensbi.git
synced 2025-10-10 02:21:43 +01:00
lib: sbi: Introduce IPI device rating
A platform can have multiple IPI devices (such as ACLINT MSWI, AIA IMSIC, etc). Currently, OpenSBI rely on platform calling the sbi_ipi_set_device() function in correct order and prefer the first avaiable IPI device which is fragile. Instead of the above, introduce IPI device rating and prefer the highest rated IPI device. This further allows extending the sbi_ipi_raw_clear() to clear all available IPI devices. Signed-off-by: Anup Patel <apatel@ventanamicro.com> Tested-by: Nick Hu <nick.hu@sifive.com> Link: https://lore.kernel.org/r/20250904052410.546818-2-apatel@ventanamicro.com Signed-off-by: Anup Patel <anup@brainfault.org>
This commit is contained in:
@@ -61,6 +61,7 @@ static void plicsw_ipi_clear(void)
|
||||
|
||||
static struct sbi_ipi_device plicsw_ipi = {
|
||||
.name = "andes_plicsw",
|
||||
.rating = 200,
|
||||
.ipi_send = plicsw_ipi_send,
|
||||
.ipi_clear = plicsw_ipi_clear
|
||||
};
|
||||
@@ -99,7 +100,7 @@ int plicsw_cold_ipi_init(struct plicsw_data *plicsw)
|
||||
if (rc)
|
||||
return rc;
|
||||
|
||||
sbi_ipi_set_device(&plicsw_ipi);
|
||||
sbi_ipi_add_device(&plicsw_ipi);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
Reference in New Issue
Block a user