From: Nathael Pajani Date: Tue, 1 Feb 2022 03:41:36 +0000 (+0100) Subject: Fix NVIC_SetPriority function ! X-Git-Url: http://git.techno-innov.fr/?a=commitdiff_plain;h=5239a262d7b92ade851eb4c4150289e356e2ba6d;p=soft%2Flpc82x%2Fcore Fix NVIC_SetPriority function ! --- diff --git a/include/core/lpc_core.h b/include/core/lpc_core.h index 6439a1e..bbf11ab 100644 --- a/include/core/lpc_core.h +++ b/include/core/lpc_core.h @@ -373,10 +373,11 @@ static inline void NVIC_ClearPendingIRQ(uint32_t IRQ) /* The following MACROS handle generation of the register offset and byte masks */ -#define LPC_NVIC_PRIO_BITS 5 /* Number of Bits used for Priority Levels */ +#define LPC_NVIC_PRIO_BITS 2 /* Number of Bits used for Priority Levels */ #define LPC_IRQ_BIT_SHIFT(IRQ) (((uint32_t)(IRQ) & 0x03) * 8) -#define LPC_IRQ_SHP_IDX(IRQ) ((((int32_t)(IRQ) + 16) >> 2) - 1) #define LPC_IRQ_IP_IDX(IRQ) ((uint32_t)(IRQ) >> 2) +#define LPC_IRQ_SHP_IDX(IRQ) ((((int32_t)(IRQ) + 16) >> 2) - 2) +#define LPC_IRQ_SHP_BIT_SHIFT(IRQ) ((((int32_t)(IRQ) + 16) & 0x03) * 8) /* Set Interrupt Priority This function sets the priority for the specified interrupt. The interrupt @@ -384,15 +385,15 @@ static inline void NVIC_ClearPendingIRQ(uint32_t IRQ) interrupt, or negative to specify an internal (core) interrupt. Note: The priority cannot be set for every core interrupt. IRQ : Number of the interrupt for set priority - priority : Priority to set + priority : Priority to set : (0 to 3 : 0 is highest, 3 is lowest) */ static inline void NVIC_SetPriority(uint32_t IRQ, uint32_t priority) { if ((int32_t)IRQ < 0) { if ((int32_t)IRQ > (-12)) { struct syst_ctrl_block_regs* scb = LPC_SCB; - scb->shp[LPC_IRQ_SHP_IDX(IRQ)] = (scb->shp[LPC_IRQ_SHP_IDX(IRQ)] & ~(0xFF << LPC_IRQ_BIT_SHIFT(IRQ))) | - (((priority << (8 - LPC_NVIC_PRIO_BITS)) & 0xFF) << LPC_IRQ_BIT_SHIFT(IRQ)); + scb->shp[LPC_IRQ_SHP_IDX(IRQ)] = (scb->shp[LPC_IRQ_SHP_IDX(IRQ)] & ~(0xFF << LPC_IRQ_SHP_BIT_SHIFT(IRQ))) | + (((priority << (8 - LPC_NVIC_PRIO_BITS)) & 0xFF) << LPC_IRQ_SHP_BIT_SHIFT(IRQ)); } } else if (LPC_IRQ_IP_IDX(IRQ) < 8) { struct nvic_regs* nvic = LPC_NVIC; @@ -417,7 +418,7 @@ static inline uint32_t NVIC_GetPriority(uint32_t IRQ) if ((int32_t)IRQ > (-12)) { struct syst_ctrl_block_regs* scb = LPC_SCB; /* Get priority for Cortex-M0 system interrupts */ - return ((uint32_t)((scb->shp[LPC_IRQ_SHP_IDX(IRQ)] >> LPC_IRQ_BIT_SHIFT(IRQ) ) >> (8 - LPC_NVIC_PRIO_BITS))); + return ((uint32_t)((scb->shp[LPC_IRQ_SHP_IDX(IRQ)] >> LPC_IRQ_SHP_BIT_SHIFT(IRQ) ) >> (8 - LPC_NVIC_PRIO_BITS))); } } else if (LPC_IRQ_IP_IDX(IRQ) < 8) { struct nvic_regs* nvic = LPC_NVIC;