47 lines
1.1 KiB
C
Raw Normal View History

/*
* Copyright (c) 2021 hpmicro
*
* SPDX-License-Identifier: BSD-3-Clause
*
*/
#include "hpm_common.h"
#include "hpm_soc.h"
#include "hpm_l1c_drv.h"
void enable_plic_feature(void)
{
uint32_t plic_feature = 0;
#ifndef USE_NONVECTOR_MODE
/* enabled vector mode and preemptive priority interrupt */
plic_feature |= HPM_PLIC_FEATURE_VECTORED_MODE;
#endif
#ifndef DISABLE_IRQ_PREEMPTIVE
/* enabled preemptive priority interrupt */
plic_feature |= HPM_PLIC_FEATURE_PREEMPTIVE_PRIORITY_IRQ;
#endif
__plic_set_feature(HPM_PLIC_BASE, plic_feature);
}
__attribute__((weak)) void system_init(void)
{
disable_global_irq(CSR_MSTATUS_MIE_MASK);
disable_irq_from_intc();
enable_plic_feature();
enable_irq_from_intc();
enable_global_irq(CSR_MSTATUS_MIE_MASK);
#ifndef CONFIG_NOT_ENALBE_ACCESS_TO_CYCLE_CSR
uint32_t mcounteren = read_csr(CSR_MCOUNTEREN);
write_csr(CSR_MCOUNTEREN, mcounteren | 1); /* Enable MCYCLE */
#endif
#ifndef CONFIG_NOT_ENABLE_ICACHE
l1c_ic_enable();
#endif
#ifndef CONFIG_NOT_ENABLE_DCACHE
l1c_dc_enable();
l1c_dc_invalidate_all();
#endif
}