mirror of
https://github.com/riscv-software-src/opensbi.git
synced 2026-02-27 18:01:45 +00:00
platform: generic: mips p8700: fix powering up other cluster
While powering up cluster, only indication is bit in cluster power control. It used to wait for CORE0 in that cluster reach U5 state (non-coherent execution), this won't happen when only CM powered up without booting any core Signed-off-by: Vladimir Kondratiev <vladimir.kondratiev@mobileye.com> Reviewed-by: Anup Patel <anup@brainfault.org> Link: https://lore.kernel.org/r/20260223-for-upstream-eyeq7h-v3-5-621d004d1a21@mobileye.com Signed-off-by: Anup Patel <anup@brainfault.org>
This commit is contained in:
committed by
Anup Patel
parent
698ea046e2
commit
6545b78bcd
@@ -12,6 +12,7 @@
|
|||||||
#include <sbi/sbi_error.h>
|
#include <sbi/sbi_error.h>
|
||||||
#include <sbi/sbi_hsm.h>
|
#include <sbi/sbi_hsm.h>
|
||||||
#include <sbi/sbi_timer.h>
|
#include <sbi/sbi_timer.h>
|
||||||
|
#include <sbi/riscv_barrier.h>
|
||||||
#include <sbi_utils/fdt/fdt_helper.h>
|
#include <sbi_utils/fdt/fdt_helper.h>
|
||||||
#include <mips/p8700.h>
|
#include <mips/p8700.h>
|
||||||
#include <mips/mips-cm.h>
|
#include <mips/mips-cm.h>
|
||||||
@@ -42,32 +43,22 @@ static void mips_p8700_pmp_set(unsigned int n, unsigned long flags,
|
|||||||
|
|
||||||
static void power_up_other_cluster(u32 hartid)
|
static void power_up_other_cluster(u32 hartid)
|
||||||
{
|
{
|
||||||
unsigned int stat;
|
unsigned int cl = cpu_cluster(hartid);
|
||||||
unsigned int timeout;
|
bool local_p = (cpu_cluster(current_hartid()) == cl);
|
||||||
bool local_p = (cpu_cluster(current_hartid()) == cpu_cluster(hartid));
|
|
||||||
|
|
||||||
/* Power up cluster cl core 0 hart 0 */
|
/* Power up CM in cluster */
|
||||||
write_cpc_pwrup_ctl(hartid, 1, local_p);
|
write_cpc_pwrup_ctl(hartid, 1, local_p);
|
||||||
|
|
||||||
/* Wait for the CM to start up */
|
/* Wait for the CM to start up */
|
||||||
timeout = 100;
|
for (int i = 100; i > 0; i--) {
|
||||||
while (true) {
|
u32 stat = read_cpc_cm_stat_conf(hartid, local_p);
|
||||||
stat = read_cpc_cm_stat_conf(hartid, local_p);
|
|
||||||
stat = EXT(stat, CPC_Cx_STAT_CONF_SEQ_STATE);
|
stat = EXT(stat, CPC_Cx_STAT_CONF_SEQ_STATE);
|
||||||
if (stat == CPC_Cx_STAT_CONF_SEQ_STATE_U5)
|
if (stat == CPC_Cx_STAT_CONF_SEQ_STATE_U5)
|
||||||
break;
|
return;
|
||||||
|
cpu_relax();
|
||||||
/* Delay a little while before we start warning */
|
|
||||||
if (timeout) {
|
|
||||||
sbi_dprintf("Delay a little while before we start warning\n");
|
|
||||||
timeout--;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
sbi_printf("Waiting for cluster %u CM to power up... STAT_CONF=0x%x\n",
|
|
||||||
cpu_cluster(hartid), stat);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
sbi_printf("ERROR: Fail to power up cluster %u\n", cl);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int mips_hart_start(u32 hartid, ulong saddr)
|
static int mips_hart_start(u32 hartid, ulong saddr)
|
||||||
|
|||||||
Reference in New Issue
Block a user