Make sure that all references to up_prioritize_irq() are conditioned on CONFIG_ARCH_IRQPRIO. Noted by Make Smith
This commit is contained in:
parent
d2e1d8f6ee
commit
bac1ab9a34
@ -1465,12 +1465,14 @@ int kinetis_netinitialize(int intf)
|
|||||||
kinetis_pinconfig(PIN_RMII0_TXEN);
|
kinetis_pinconfig(PIN_RMII0_TXEN);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_IRQPRIO
|
||||||
/* Set interrupt priority levels */
|
/* Set interrupt priority levels */
|
||||||
|
|
||||||
up_prioritize_irq(KINETIS_IRQ_EMACTMR, CONFIG_KINETIS_EMACTMR_PRIO);
|
up_prioritize_irq(KINETIS_IRQ_EMACTMR, CONFIG_KINETIS_EMACTMR_PRIO);
|
||||||
up_prioritize_irq(KINETIS_IRQ_EMACTX, CONFIG_KINETIS_EMACTX_PRIO);
|
up_prioritize_irq(KINETIS_IRQ_EMACTX, CONFIG_KINETIS_EMACTX_PRIO);
|
||||||
up_prioritize_irq(KINETIS_IRQ_EMACRX, CONFIG_KINETIS_EMACRX_PRIO);
|
up_prioritize_irq(KINETIS_IRQ_EMACRX, CONFIG_KINETIS_EMACRX_PRIO);
|
||||||
up_prioritize_irq(KINETIS_IRQ_EMACMISC, CONFIG_KINETIS_EMACMISC_PRIO);
|
up_prioritize_irq(KINETIS_IRQ_EMACMISC, CONFIG_KINETIS_EMACMISC_PRIO);
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Attach the Ethernet MAC IEEE 1588 timer interrupt handler */
|
/* Attach the Ethernet MAC IEEE 1588 timer interrupt handler */
|
||||||
|
|
||||||
|
@ -1688,9 +1688,11 @@ static int kinetis_attach(FAR struct sdio_dev_s *dev)
|
|||||||
putreg32(0, KINETIS_SDHC_IRQSIGEN);
|
putreg32(0, KINETIS_SDHC_IRQSIGEN);
|
||||||
putreg32(SDHC_INT_ALL, KINETIS_SDHC_IRQSTAT);
|
putreg32(SDHC_INT_ALL, KINETIS_SDHC_IRQSTAT);
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_IRQPRIO
|
||||||
/* Set the interrupt priority */
|
/* Set the interrupt priority */
|
||||||
|
|
||||||
up_prioritize_irq(KINETIS_IRQ_SDHC, CONFIG_KINETIS_SDHC_PRIO);
|
up_prioritize_irq(KINETIS_IRQ_SDHC, CONFIG_KINETIS_SDHC_PRIO);
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Enable SDIO interrupts at the NVIC. They can now be enabled at
|
/* Enable SDIO interrupts at the NVIC. They can now be enabled at
|
||||||
* the SDIO controller as needed.
|
* the SDIO controller as needed.
|
||||||
|
@ -623,12 +623,15 @@ static int up_setup(struct uart_dev_s *dev)
|
|||||||
|
|
||||||
up_restoreuartint(priv, 0);
|
up_restoreuartint(priv, 0);
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_IRQPRIO
|
||||||
/* Set up the interrupt priority */
|
/* Set up the interrupt priority */
|
||||||
|
|
||||||
up_prioritize_irq(priv->irqs, priv->irqprio);
|
up_prioritize_irq(priv->irqs, priv->irqprio);
|
||||||
#ifdef CONFIG_DEBUG
|
#ifdef CONFIG_DEBUG
|
||||||
up_prioritize_irq(priv->irqe, priv->irqprio);
|
up_prioritize_irq(priv->irqe, priv->irqprio);
|
||||||
#endif
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
return OK;
|
return OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -68,13 +68,17 @@ CMN_CSRCS += up_dumpnvic.c
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
CHIP_ASRCS =
|
CHIP_ASRCS =
|
||||||
CHIP_CSRCS = kl_clockconfig.c kl_gpio.c kl_idle.c kl_irq.c kl_irqprio.c kl_lowgetc.c
|
CHIP_CSRCS = kl_clockconfig.c kl_gpio.c kl_idle.c kl_irq.c kl_lowgetc.c
|
||||||
CHIP_CSRCS += kl_lowputc.c kl_serial.c kl_start.c kl_timerisr.c kl_cfmconfig.c
|
CHIP_CSRCS += kl_lowputc.c kl_serial.c kl_start.c kl_timerisr.c kl_cfmconfig.c
|
||||||
|
|
||||||
ifeq ($(CONFIG_NUTTX_KERNEL),y)
|
ifeq ($(CONFIG_NUTTX_KERNEL),y)
|
||||||
CHIP_CSRCS += kl_userspace.c
|
CHIP_CSRCS += kl_userspace.c
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_ARCH_IRQPRIO),y)
|
||||||
|
CHIP_CSRCS += kl_irqprio.c
|
||||||
|
endif
|
||||||
|
|
||||||
ifeq ($(CONFIG_KL_SPI0),y)
|
ifeq ($(CONFIG_KL_SPI0),y)
|
||||||
CHIP_CSRCS += kl_spi.c
|
CHIP_CSRCS += kl_spi.c
|
||||||
else
|
else
|
||||||
|
@ -76,10 +76,10 @@ ifeq ($(CONFIG_NUTTX_KERNEL),y)
|
|||||||
CHIP_CSRCS += sam_userspace.c
|
CHIP_CSRCS += sam_userspace.c
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(CONFIG_SAMD_HAVE_SPI),y)
|
|
||||||
CHIP_CSRCS += sam_spi.c
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(CONFIG_ARCH_IRQPRIO),y)
|
ifeq ($(CONFIG_ARCH_IRQPRIO),y)
|
||||||
CHIP_CSRCS += sam_irqprio.c
|
CHIP_CSRCS += sam_irqprio.c
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_SAMD_HAVE_SPI),y)
|
||||||
|
CHIP_CSRCS += sam_spi.c
|
||||||
|
endif
|
||||||
|
@ -398,6 +398,7 @@ static int stm32_tim_setisr(FAR struct stm32_tim_dev_s *dev,
|
|||||||
|
|
||||||
up_prioritize_irq(vectorno, NVIC_SYSH_PRIORITY_DEFAULT);
|
up_prioritize_irq(vectorno, NVIC_SYSH_PRIORITY_DEFAULT);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return OK;
|
return OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -208,6 +208,7 @@ void up_maskack_irq(int irq)
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_IRQPRIO
|
||||||
int up_prioritize_irq(int irq, int priority)
|
int up_prioritize_irq(int irq, int priority)
|
||||||
{
|
{
|
||||||
uint32_t addr;
|
uint32_t addr;
|
||||||
@ -229,4 +230,5 @@ int up_prioritize_irq(int irq, int priority)
|
|||||||
|
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -628,10 +628,13 @@ static int up_attach(struct uart_dev_s *dev)
|
|||||||
|
|
||||||
up_enable_irq(priv->irq);
|
up_enable_irq(priv->irq);
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_IRQPRIO
|
||||||
/* Set the uart interrupt priority (the default value is one) */
|
/* Set the uart interrupt priority (the default value is one) */
|
||||||
|
|
||||||
up_prioritize_irq(priv->irq, CONFIG_UART_PRI);
|
up_prioritize_irq(priv->irq, CONFIG_UART_PRI);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -198,9 +198,11 @@ void up_timerinit(void)
|
|||||||
putreg16(OCAR_VALUE, STR71X_TIMER0_OCAR);
|
putreg16(OCAR_VALUE, STR71X_TIMER0_OCAR);
|
||||||
putreg16(0xfffc, STR71X_TIMER0_CNTR);
|
putreg16(0xfffc, STR71X_TIMER0_CNTR);
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_IRQPRIO
|
||||||
/* Set the timer interrupt priority */
|
/* Set the timer interrupt priority */
|
||||||
|
|
||||||
up_prioritize_irq(STR71X_IRQ_SYSTIMER, CONFIG_TIM_PRI);
|
up_prioritize_irq(STR71X_IRQ_SYSTIMER, CONFIG_TIM_PRI);
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Attach the timer interrupt vector */
|
/* Attach the timer interrupt vector */
|
||||||
|
|
||||||
|
@ -80,6 +80,10 @@ volatile uint32_t *current_regs;
|
|||||||
* Private Functions
|
* Private Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifndef CONFIG_ARCH_IRQPRIO
|
||||||
|
static int up_prioritize_irq(int irq, int priority);
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Functions
|
* Public Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -436,7 +440,9 @@ void up_clrpend_irq(int irq)
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifdef CONFIG_ARCH_IRQPRIO
|
#ifndef CONFIG_ARCH_IRQPRIO
|
||||||
|
static
|
||||||
|
#endif
|
||||||
int up_prioritize_irq(int irq, int priority)
|
int up_prioritize_irq(int irq, int priority)
|
||||||
{
|
{
|
||||||
int regndx;
|
int regndx;
|
||||||
@ -467,4 +473,3 @@ int up_prioritize_irq(int irq, int priority)
|
|||||||
|
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
@ -362,9 +362,12 @@ static int up_setup(struct uart_dev_s *dev)
|
|||||||
priv->bits, priv->stopbits2);
|
priv->bits, priv->stopbits2);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_IRQPRIO
|
||||||
/* Set up the interrupt priority */
|
/* Set up the interrupt priority */
|
||||||
|
|
||||||
up_prioritize_irq(priv->irq, priv->irqprio);
|
up_prioritize_irq(priv->irq, priv->irqprio);
|
||||||
|
#endif
|
||||||
|
|
||||||
return OK;
|
return OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1007,6 +1007,7 @@ FAR struct spi_dev_s *up_spiinitialize(int port)
|
|||||||
up_enable_irq(priv->txirq);
|
up_enable_irq(priv->txirq);
|
||||||
up_enable_irq(priv->rxirq);
|
up_enable_irq(priv->rxirq);
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_IRQPRIO
|
||||||
/* Set the SPI interrupt priority */
|
/* Set the SPI interrupt priority */
|
||||||
|
|
||||||
ret = up_prioritize_irq(priv->vector, CONFIG_PIC32MX_SPI_PRIORITY)
|
ret = up_prioritize_irq(priv->vector, CONFIG_PIC32MX_SPI_PRIORITY)
|
||||||
@ -1015,6 +1016,7 @@ FAR struct spi_dev_s *up_spiinitialize(int port)
|
|||||||
spidbg("up_prioritize_irq failed: %d\n", ret);
|
spidbg("up_prioritize_irq failed: %d\n", ret);
|
||||||
goto errout;
|
goto errout;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Enable interrupts at the interrupt controller */
|
/* Enable interrupts at the interrupt controller */
|
||||||
|
@ -181,7 +181,9 @@ void up_timerinit(void)
|
|||||||
/* Configure the timer interrupt */
|
/* Configure the timer interrupt */
|
||||||
|
|
||||||
up_clrpend_irq(PIC32MX_IRQSRC_T1);
|
up_clrpend_irq(PIC32MX_IRQSRC_T1);
|
||||||
|
#ifdef CONFIG_ARCH_IRQPRIO
|
||||||
(void)up_prioritize_irq(PIC32MX_IRQ_T1, CONFIG_PIC32MX_T1PRIO);
|
(void)up_prioritize_irq(PIC32MX_IRQ_T1, CONFIG_PIC32MX_T1PRIO);
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Attach the timer interrupt vector */
|
/* Attach the timer interrupt vector */
|
||||||
|
|
||||||
|
@ -96,6 +96,7 @@ void up_irqinitialize(void)
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_IRQPRIO
|
||||||
void up_prioritize_irq(int irq, int priority)
|
void up_prioritize_irq(int irq, int priority)
|
||||||
{
|
{
|
||||||
uint16_t mask;
|
uint16_t mask;
|
||||||
@ -282,4 +283,4 @@ void up_prioritize_irq(int irq, int priority)
|
|||||||
reg16 |= (priority << shift);
|
reg16 |= (priority << shift);
|
||||||
putreg16(reg16, reg);
|
putreg16(reg16, reg);
|
||||||
}
|
}
|
||||||
|
#endif /* CONFIG_ARCH_IRQPRIO */
|
||||||
|
@ -499,10 +499,11 @@ static int up_attach(struct uart_dev_s *dev)
|
|||||||
ret = irq_attach(priv->irq + SH1_TXI_IRQ_OFFSET, up_interrupt);
|
ret = irq_attach(priv->irq + SH1_TXI_IRQ_OFFSET, up_interrupt);
|
||||||
if (ret == OK)
|
if (ret == OK)
|
||||||
{
|
{
|
||||||
|
#ifdef CONFIG_ARCH_IRQPRIO
|
||||||
/* All SCI0 interrupts share the same prioritization */
|
/* All SCI0 interrupts share the same prioritization */
|
||||||
|
|
||||||
up_prioritize_irq(priv->irq, 7); /* Set SCI priority midway */
|
up_prioritize_irq(priv->irq, 7); /* Set SCI priority midway */
|
||||||
|
#endif
|
||||||
/* Return OK on success */
|
/* Return OK on success */
|
||||||
|
|
||||||
return OK;
|
return OK;
|
||||||
@ -545,11 +546,13 @@ static void up_detach(struct uart_dev_s *dev)
|
|||||||
(void)irq_detach(priv->irq + SH1_ERI_IRQ_OFFSET);
|
(void)irq_detach(priv->irq + SH1_ERI_IRQ_OFFSET);
|
||||||
(void)irq_detach(priv->irq + SH1_RXI_IRQ_OFFSET);
|
(void)irq_detach(priv->irq + SH1_RXI_IRQ_OFFSET);
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_IRQPRIO
|
||||||
/* Set the interrupt priority to zero (masking all SCI interrupts). NOTE
|
/* Set the interrupt priority to zero (masking all SCI interrupts). NOTE
|
||||||
* that all SCI0 interrupts share the same prioritization.
|
* that all SCI0 interrupts share the same prioritization.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
up_prioritize_irq(priv->irq, 0);
|
up_prioritize_irq(priv->irq, 0);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
|
@ -193,9 +193,11 @@ void up_timerinit(void)
|
|||||||
|
|
||||||
putreg8(SH1_ITUTIER_IMIEA, SH1_ITU0_TIER);
|
putreg8(SH1_ITUTIER_IMIEA, SH1_ITU0_TIER);
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_IRQPRIO
|
||||||
/* Set the interrupt priority */
|
/* Set the interrupt priority */
|
||||||
|
|
||||||
up_prioritize_irq(SH1_SYSTIMER_IRQ, 7); /* Set ITU priority midway */
|
up_prioritize_irq(SH1_SYSTIMER_IRQ, 7); /* Set ITU priority midway */
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Start the timer */
|
/* Start the timer */
|
||||||
|
|
||||||
|
@ -209,10 +209,11 @@ void up_maskack_irq(int irq)
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_IRQPRIO
|
||||||
int up_prioritize_irq(int irq, int priority)
|
int up_prioritize_irq(int irq, int priority)
|
||||||
{
|
{
|
||||||
/* To be provided */
|
/* To be provided */
|
||||||
|
|
||||||
return -ENOSYS;
|
return -ENOSYS;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user