2019-11-19 18:32:32 +08:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2016 Cadence Design Systems, Inc.
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <zephyr/types.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <arch/xtensa/xtensa_api.h>
|
|
|
|
#include <kernel_arch_data.h>
|
|
|
|
#include <sys/__assert.h>
|
|
|
|
/*
|
|
|
|
* @internal
|
|
|
|
*
|
|
|
|
* @brief Set an interrupt's priority
|
|
|
|
*
|
|
|
|
* The priority is verified if ASSERT_ON is enabled.
|
|
|
|
*
|
|
|
|
* The priority is verified if ASSERT_ON is enabled. The maximum number of
|
|
|
|
* priority levels is a little complex, as there are some hardware priority
|
|
|
|
* levels which are reserved: three for various types of exceptions, and
|
|
|
|
* possibly one additional to support zero latency interrupts.
|
|
|
|
*
|
|
|
|
* Valid values are from 1 to 6. Interrupts of priority 1 are not masked when
|
|
|
|
* interrupts are locked system-wide, so care must be taken when using them.
|
|
|
|
* ISR installed with priority 0 interrupts cannot make kernel calls.
|
|
|
|
*
|
|
|
|
* @return N/A
|
|
|
|
*/
|
|
|
|
|
2020-05-28 00:26:57 +08:00
|
|
|
void z_irq_priority_set(unsigned int irq, unsigned int prio, uint32_t flags)
|
2019-11-19 18:32:32 +08:00
|
|
|
{
|
|
|
|
__ASSERT(prio < XCHAL_EXCM_LEVEL + 1,
|
|
|
|
"invalid priority %d! values must be less than %d\n",
|
|
|
|
prio, XCHAL_EXCM_LEVEL + 1);
|
|
|
|
/* TODO: Write code to set priority if this is ever possible on
|
|
|
|
* Xtensa
|
|
|
|
*/
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef CONFIG_DYNAMIC_INTERRUPTS
|
|
|
|
#ifndef CONFIG_MULTI_LEVEL_INTERRUPTS
|
|
|
|
int z_arch_irq_connect_dynamic(unsigned int irq, unsigned int priority,
|
|
|
|
void (*routine)(void *parameter),
|
2020-05-28 00:26:57 +08:00
|
|
|
void *parameter, uint32_t flags)
|
2019-11-19 18:32:32 +08:00
|
|
|
{
|
|
|
|
ARG_UNUSED(flags);
|
|
|
|
ARG_UNUSED(priority);
|
|
|
|
|
|
|
|
z_isr_install(irq, routine, parameter);
|
|
|
|
return irq;
|
|
|
|
}
|
|
|
|
#else /* !CONFIG_MULTI_LEVEL_INTERRUPTS */
|
|
|
|
int z_arch_irq_connect_dynamic(unsigned int irq, unsigned int priority,
|
|
|
|
void (*routine)(void *parameter),
|
2020-05-28 00:26:57 +08:00
|
|
|
void *parameter, uint32_t flags)
|
2019-11-19 18:32:32 +08:00
|
|
|
{
|
|
|
|
return z_soc_irq_connect_dynamic(irq, priority, routine, parameter,
|
|
|
|
flags);
|
|
|
|
}
|
|
|
|
#endif /* !CONFIG_MULTI_LEVEL_INTERRUPTS */
|
|
|
|
#endif /* CONFIG_DYNAMIC_INTERRUPTS */
|