lib: Simplify sbi_platform timer_init() hooks

Instead of having separate timer_init() hooks for cold and
warm boot, this patch updates struct sbi_platform to have just
one timer_init() hook. The type of boot (cold or warm) is now
a boolean flag parameter for the updated timer_init() hook.

Signed-off-by: Anup Patel <anup.patel@wdc.com>
This commit is contained in:
Anup Patel
2018-12-26 18:44:54 +05:30
committed by Anup Patel
parent c1b6200653
commit 52ed1d1709
8 changed files with 61 additions and 48 deletions

View File

@@ -106,10 +106,18 @@ static int virt_ipi_init(u32 hartid, bool cold_boot)
return clint_warm_ipi_init(hartid);
}
static int virt_cold_timer_init(void)
static int virt_timer_init(u32 hartid, bool cold_boot)
{
return clint_cold_timer_init(VIRT_CLINT_ADDR,
VIRT_HART_COUNT);
int rc;
if (cold_boot) {
rc = clint_cold_timer_init(VIRT_CLINT_ADDR,
VIRT_HART_COUNT);
if (rc)
return rc;
}
return clint_warm_timer_init(hartid);
}
static int virt_system_down(u32 type)
@@ -138,8 +146,7 @@ struct sbi_platform platform = {
.timer_value = clint_timer_value,
.timer_event_stop = clint_timer_event_stop,
.timer_event_start = clint_timer_event_start,
.warm_timer_init = clint_warm_timer_init,
.cold_timer_init = virt_cold_timer_init,
.timer_init = virt_timer_init,
.system_reboot = virt_system_down,
.system_shutdown = virt_system_down
};