If mip.SEIP bit is not cleared then on HiFive Unmatched board it causes
spurious external interrupts. This breaks the boot up of HiFive Unmatched
board. Hence it is required to bring the mip CSR to a known state during
hart init and avoid spurious interrupts.
Fixes: d9e7368 ("firmware: Not to clear all the MIP")
Signed-off-by: Mayuresh Chitale <mchitale@ventanamicro.com>
Reviewed-by: Anup Patel <anup@brainfault.org>
/* Disable all interrupts */
csrw CSR_MIE, zero
- /*
- * Only clear the MIP_SSIP and MIP_STIP. For the platform like QEMU,
- * If we clear other interrupts like MIP_SEIP and the pendings of
- * PLIC still exist, the QEMU may not set it back immediately.
- */
- li t0, (MIP_SSIP | MIP_STIP)
- csrc CSR_MIP, t0
/* Find HART count and HART stack size */
lla a4, platform
{
int rc;
+ /*
+ * Clear mip CSR before proceeding with init to avoid any spurious
+ * external interrupts in S-mode.
+ */
+ csr_write(CSR_MIP, 0);
+
if (cold_boot) {
if (misa_extension('H'))
sbi_hart_expected_trap = &__sbi_expected_trap_hext;