arch: arm: cortex_r: Support nested exception detection
Cortex-A/R does not have hardware supported nested interrupts, but it is easily emulatable using the nesting level stored in the kernel structure. Signed-off-by: Bradley Bolen <bbolen@lexmark.com>
This commit is contained in:
parent
1e153b5091
commit
046f93627c
|
@ -29,6 +29,7 @@ config CPU_CORTEX_R
|
|||
bool
|
||||
select CPU_CORTEX
|
||||
select HAS_CMSIS_CORE
|
||||
select ARCH_HAS_NESTED_EXCEPTION_DETECTION
|
||||
select HAS_FLASH_LOAD_OFFSET
|
||||
select ARCH_HAS_USERSPACE if ARM_MPU
|
||||
select ARCH_HAS_EXTRA_EXCEPTION_INFO
|
||||
|
|
|
@ -38,6 +38,11 @@ static ALWAYS_INLINE bool arch_is_in_isr(void)
|
|||
return (_kernel.cpus[0].nested != 0U);
|
||||
}
|
||||
|
||||
static ALWAYS_INLINE bool arch_is_in_nested_exception(const z_arch_esf_t *esf)
|
||||
{
|
||||
return (_kernel.cpus[0].nested > 1U) ? (true) : (false);
|
||||
}
|
||||
|
||||
#if defined(CONFIG_USERSPACE)
|
||||
/*
|
||||
* This function is used by privileged code to determine if the thread
|
||||
|
|
Loading…
Reference in a new issue