Add sys_trace_idle_exit to RISCV cpu_idle functions and allow enabling CPU_LOAD module for RISCV and disable it for SMP. Signed-off-by: Krzysztof Chruściński <krzysztof.chruscinski@nordicsemi.no>
28 lines
537 B
C
28 lines
537 B
C
/*
|
|
* Copyright (c) 2016 Jean-Paul Etienne <fractalclone@gmail.com>
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
#include <zephyr/irq.h>
|
|
#include <zephyr/tracing/tracing.h>
|
|
|
|
#ifndef CONFIG_ARCH_HAS_CUSTOM_CPU_IDLE
|
|
void arch_cpu_idle(void)
|
|
{
|
|
sys_trace_idle();
|
|
__asm__ volatile("wfi");
|
|
sys_trace_idle_exit();
|
|
irq_unlock(MSTATUS_IEN);
|
|
}
|
|
#endif
|
|
|
|
#ifndef CONFIG_ARCH_HAS_CUSTOM_CPU_ATOMIC_IDLE
|
|
void arch_cpu_atomic_idle(unsigned int key)
|
|
{
|
|
sys_trace_idle();
|
|
__asm__ volatile("wfi");
|
|
sys_trace_idle_exit();
|
|
irq_unlock(key);
|
|
}
|
|
#endif
|