mirror of
https://github.com/zephyrproject-rtos/zephyr
synced 2025-09-16 18:47:39 +00:00
Convert code to use u{8,16,32,64}_t and s{8,16,32,64}_t instead of C99 integer types. There are few places we dont convert over to the new types because of compatiability with ext/HALs or for ease of transition at this point. Fixup a few of the PRI formatters so we build with newlib. Jira: ZEP-2051 Change-Id: I7d2d3697cad04f20aaa8f6e77228f502cd9c8286 Signed-off-by: Kumar Gala <kumar.gala@linaro.org>
45 lines
832 B
C
45 lines
832 B
C
/*
|
|
* Copyright (c) 2016 Jean-Paul Etienne <fractalclone@gmail.com>
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
/**
|
|
* @file
|
|
* @brief Kernel event logger support for RISCV32
|
|
*/
|
|
|
|
#ifndef __KERNEL_EVENT_LOGGER_ARCH_H__
|
|
#define __KERNEL_EVENT_LOGGER_ARCH_H__
|
|
|
|
#include <arch/cpu.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief Get the identification of the current interrupt.
|
|
*
|
|
* This routine obtain the key of the interrupt that is currently processed
|
|
* if it is called from an IRQ context.
|
|
*
|
|
* @return The key of the interrupt that is currently being processed.
|
|
*/
|
|
static inline int _sys_current_irq_key_get(void)
|
|
{
|
|
u32_t mcause;
|
|
|
|
__asm__ volatile("csrr %0, mcause" : "=r" (mcause));
|
|
|
|
mcause &= SOC_MCAUSE_EXP_MASK;
|
|
|
|
return mcause;
|
|
}
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* __KERNEL_EVENT_LOGGER_ARCH_H__ */
|