Several fixes related to Cortex-M RAM vectors
This commit is contained in:
parent
88faa55ac1
commit
22e208dbf9
@ -442,7 +442,6 @@
|
||||
#define NVIC_INTCTRL_VECTACTIVE_MASK (0x1ff << NVIC_INTCTRL_VECTACTIVE_SHIFT)
|
||||
|
||||
/* System control register (SYSCON) */
|
||||
|
||||
/* Bit 0: Reserved */
|
||||
#define NVIC_SYSCON_SLEEPONEXIT (1 << 1) /* Bit 1: Sleep-on-exit (returning from Handler to Thread mode) */
|
||||
#define NVIC_SYSCON_SLEEPDEEP (1 << 2) /* Bit 2: Use deep sleep in low power mode */
|
||||
@ -484,11 +483,11 @@
|
||||
#define NVIC_SYSH_PRIORITY_PR15_MASK (0xff << NVIC_SYSH_PRIORITY_PR15_SHIFT)
|
||||
|
||||
/* Vector Table Offset Register (VECTAB). This mask seems to vary among
|
||||
* ARMv7-M implementations. It may be be redefined in the architecture-
|
||||
* specific chip.h header file.
|
||||
* ARMv7-M implementations. It may need to be redefined in some
|
||||
* architecture-specific header file.
|
||||
*/
|
||||
|
||||
#define NVIC_VECTAB_TBLOFF_MASK (0xffffffc0)
|
||||
#define NVIC_VECTAB_TBLOFF_MASK (0xffffff80)
|
||||
|
||||
/* Application Interrupt and Reset Control Register (AIRCR) */
|
||||
|
||||
|
@ -64,8 +64,8 @@
|
||||
#endif
|
||||
|
||||
/* This, then is the size of the vector table (in 4-byte entries). This size
|
||||
* includes the IDLE stack pointer which lies at the beginning of
|
||||
* the table.
|
||||
* includes the (1) the device interrupts, (2) space for 15 Cortex-M excpetions, and
|
||||
* (3) IDLE stack pointer which lies at the beginning of the table.
|
||||
*/
|
||||
|
||||
#define ARMV7M_VECTAB_SIZE (ARMV7M_PERIPHERAL_INTERRUPTS + 16)
|
||||
@ -84,7 +84,7 @@
|
||||
*/
|
||||
|
||||
extern up_vector_t g_ram_vectors[ARMV7M_VECTAB_SIZE]
|
||||
__attribute__ ((section (".ram_vectors"), aligned (64)));
|
||||
__attribute__ ((section (".ram_vectors"), aligned (128)));
|
||||
|
||||
/************************************************************************************
|
||||
* Public Function Prototypes
|
||||
|
@ -39,6 +39,7 @@
|
||||
|
||||
#include <nuttx/config.h>
|
||||
|
||||
#include <errno.h>
|
||||
#include <debug.h>
|
||||
|
||||
#include <nuttx/irq.h>
|
||||
@ -94,17 +95,17 @@ void exception_common(void);
|
||||
*
|
||||
* Description:
|
||||
* Configure the ram vector table so that IRQ number 'irq' will be
|
||||
* dipatched by hardware to 'vector'
|
||||
* dispatched by hardware to 'vector'
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
int up_ramvec_attach(int irq, up_vector_t vector)
|
||||
{
|
||||
int ret = ERROR;
|
||||
int ret = -EINVAL;
|
||||
|
||||
intvdbg("%s IRQ%d\n", vector ? "Attaching" : "Detaching", irq);
|
||||
|
||||
if ((unsigned)irq < ARMV7M_PERIPHERAL_INTERRUPTS)
|
||||
if ((unsigned)irq < (STM32_IRQ_INTERRUPTS + ARMV7M_PERIPHERAL_INTERRUPTS))
|
||||
{
|
||||
irqstate_t flags;
|
||||
|
||||
@ -129,7 +130,7 @@ int up_ramvec_attach(int irq, up_vector_t vector)
|
||||
vector = exception_common;
|
||||
}
|
||||
|
||||
/* Save the new vector in the vector table. */
|
||||
/* Save the new vector in the vector table */
|
||||
|
||||
g_ram_vectors[irq] = vector;
|
||||
irqrestore(flags);
|
||||
|
@ -88,7 +88,7 @@
|
||||
*/
|
||||
|
||||
up_vector_t g_ram_vectors[ARMV7M_VECTAB_SIZE]
|
||||
__attribute__ ((section (".ram_vectors"), aligned (64)));
|
||||
__attribute__ ((section (".ram_vectors"), aligned (128)));
|
||||
|
||||
/****************************************************************************
|
||||
* Private Variables
|
||||
@ -139,7 +139,14 @@ void up_ramvec_initialize(void)
|
||||
/* Now configure the NVIC to use the new vector table. */
|
||||
|
||||
putreg32((uint32_t)g_ram_vectors, NVIC_VECTAB);
|
||||
|
||||
/* The number bits required to align the RAM vector table seem to vary
|
||||
* from part-to-part. The following assertion will catch the case where
|
||||
* the table alignment is insufficient.
|
||||
*/
|
||||
|
||||
intvdbg("NVIC_VECTAB=%08x\n", getreg32(NVIC_VECTAB));
|
||||
DEBUGASSERT(getreg32(NVIC_VECTAB) == (uint32_t)g_ram_vectors);
|
||||
}
|
||||
|
||||
#endif /* !CONFIG_ARCH_RAMVECTORS */
|
||||
|
Loading…
Reference in New Issue
Block a user