STM32 F7 SDMMC: Use new interrupt argument facility.
This commit is contained in:
parent
8c3d2769f9
commit
810fe33c3c
@ -347,13 +347,11 @@ struct stm32_dev_s
|
||||
/* STM32-specific extensions */
|
||||
uint32_t base;
|
||||
int nirq;
|
||||
xcpt_t handler;
|
||||
#ifdef CONFIG_ARCH_IRQPRIO
|
||||
int irqprio;
|
||||
#endif
|
||||
#ifdef CONFIG_MMCSD_SDIOWAIT_WRCOMPLETE
|
||||
uint32_t d0_gpio;
|
||||
xcpt_t wrchandler;
|
||||
#endif
|
||||
#ifdef CONFIG_STM32F7_SDMMC_DMA
|
||||
uint32_t dmapri;
|
||||
@ -470,22 +468,9 @@ static void stm32_endtransfer(struct stm32_dev_s *priv, sdio_eventset_t wkupeven
|
||||
|
||||
/* Interrupt Handling *******************************************************/
|
||||
|
||||
static int stm32_sdmmc_interrupt(struct stm32_dev_s *sdmmc_dev);
|
||||
|
||||
#ifdef CONFIG_STM32F7_SDMMC1
|
||||
static int stm32_sdmmc1_interrupt(int irq, void *context, void *arg);
|
||||
#endif
|
||||
#ifdef CONFIG_STM32F7_SDMMC2
|
||||
static int stm32_sdmmc2_interrupt(int irq, void *context, void *arg);
|
||||
#endif
|
||||
|
||||
static int stm32_sdmmc_interrupt(int irq, void *context, void *arg);
|
||||
#ifdef CONFIG_MMCSD_SDIOWAIT_WRCOMPLETE
|
||||
#ifdef CONFIG_STM32F7_SDMMC1
|
||||
static int stm32_sdmmc1_rdyinterrupt(int irq, void *context, void *arg);
|
||||
#endif
|
||||
#ifdef CONFIG_STM32F7_SDMMC2
|
||||
static int stm32_sdmmc2_rdyinterrupt(int irq, void *context, void *arg);
|
||||
#endif
|
||||
static int stm32_sdmmc_rdyinterrupt(int irq, void *context, void *arg);
|
||||
#endif
|
||||
|
||||
/* SDIO interface methods ***************************************************/
|
||||
@ -609,13 +594,11 @@ struct stm32_dev_s g_sdmmcdev1 =
|
||||
},
|
||||
.base = STM32_SDMMC1_BASE,
|
||||
.nirq = STM32_IRQ_SDMMC1,
|
||||
.handler = stm32_sdmmc1_interrupt,
|
||||
#ifdef CONFIG_SDMMC1_PRI
|
||||
.irqprio = CONFIG_SDMMC1_PRI,
|
||||
#endif
|
||||
#ifdef CONFIG_MMCSD_SDIOWAIT_WRCOMPLETE
|
||||
.d0_gpio = GPIO_SDMMC1_D0,
|
||||
.wrchandler = stm32_sdmmc1_rdyinterrupt,
|
||||
#endif
|
||||
#ifdef CONFIG_STM32F7_SDMMC1_DMAPRIO
|
||||
.dmapri = CONFIG_STM32F7_SDMMC1_DMAPRIO,
|
||||
@ -665,13 +648,11 @@ struct stm32_dev_s g_sdmmcdev2 =
|
||||
},
|
||||
.base = STM32_SDMMC2_BASE,
|
||||
.nirq = STM32_IRQ_SDMMC2,
|
||||
.handler = stm32_sdmmc2_interrupt,
|
||||
#ifdef CONFIG_SDMMC2_PRI
|
||||
.irqprio = CONFIG_SDMMC2_PRI,
|
||||
#endif
|
||||
#ifdef CONFIG_MMCSD_SDIOWAIT_WRCOMPLETE
|
||||
.d0_gpio = GPIO_SDMMC2_D0,
|
||||
.wrchandler = stm32_sdmmc2_rdyinterrupt,
|
||||
#endif
|
||||
#ifdef CONFIG_STM32F7_SDMMC2_DMAPRIO
|
||||
.dmapri = CONFIG_STM32F7_SDMMC2_DMAPRIO,
|
||||
@ -847,7 +828,7 @@ static void stm32_configwaitints(struct stm32_dev_s *priv, uint32_t waitmask,
|
||||
/* Arm the SDMMC_D Ready and install Isr */
|
||||
|
||||
(void)stm32_gpiosetevent(pinset, true, false, false,
|
||||
priv->wrchandler, priv);
|
||||
stm32_sdmmc_rdyinterrupt, priv);
|
||||
}
|
||||
|
||||
/* Disarm SDMMC_D ready */
|
||||
@ -1507,8 +1488,7 @@ static void stm32_endtransfer(struct stm32_dev_s *priv,
|
||||
****************************************************************************/
|
||||
|
||||
#ifdef CONFIG_MMCSD_SDIOWAIT_WRCOMPLETE
|
||||
# if defined(CONFIG_STM32F7_SDMMC1)
|
||||
static int stm32_sdmmc1_rdyinterrupt(int irq, void *context, void *arg)
|
||||
static int stm32_sdmmc_rdyinterrupt(int irq, void *context, void *arg)
|
||||
{
|
||||
struct stm32_dev_s *priv = (struct stm32_dev_s *)arg;
|
||||
stm32_endwait(priv, SDIOWAIT_WRCOMPLETE);
|
||||
@ -1516,21 +1496,11 @@ static int stm32_sdmmc1_rdyinterrupt(int irq, void *context, void *arg)
|
||||
}
|
||||
#endif
|
||||
|
||||
# if defined(CONFIG_STM32F7_SDMMC2)
|
||||
static int stm32_sdmmc2_rdyinterrupt(int irq, void *context, void *arg)
|
||||
{
|
||||
struct stm32_dev_s *priv = (struct stm32_dev_s *)arg;
|
||||
stm32_endwait(priv, SDIOWAIT_WRCOMPLETE);
|
||||
return OK;
|
||||
}
|
||||
# endif
|
||||
#endif
|
||||
|
||||
/****************************************************************************
|
||||
* Name: stm32_sdmmc_interrupt
|
||||
*
|
||||
* Description:
|
||||
* SDMMC common interrupt handler
|
||||
* SDMMC interrupt handler
|
||||
*
|
||||
* Input Parameters:
|
||||
* priv - Instance of the SDMMC private state structure.
|
||||
@ -1540,11 +1510,14 @@ static int stm32_sdmmc2_rdyinterrupt(int irq, void *context, void *arg)
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
static int stm32_sdmmc_interrupt(struct stm32_dev_s *priv)
|
||||
static int stm32_sdmmc_interrupt(int irq, void *context, void *arg);
|
||||
{
|
||||
struct stm32_dev_s *priv =(struct stm32_dev_s *)arg;
|
||||
uint32_t enabled;
|
||||
uint32_t pending;
|
||||
|
||||
DEBUGASSERT(priv != NULL);
|
||||
|
||||
/* Loop while there are pending interrupts. Check the SDIO status
|
||||
* register. Mask out all bits that don't correspond to enabled
|
||||
* interrupts. (This depends on the fact that bits are ordered
|
||||
@ -1728,49 +1701,6 @@ static int stm32_sdmmc_interrupt(struct stm32_dev_s *priv)
|
||||
return OK;
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: stm32_sdmmc1_interrupt
|
||||
*
|
||||
* Description:
|
||||
* SDMMC 1 interrupt handler wrapper
|
||||
*
|
||||
* Input Parameters:
|
||||
* irq - not used
|
||||
* context - not used
|
||||
*
|
||||
* Returned Value:
|
||||
* None
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
#ifdef CONFIG_STM32F7_SDMMC1
|
||||
static int stm32_sdmmc1_interrupt(int irq, void *context, void *arg)
|
||||
{
|
||||
return stm32_sdmmc_interrupt(&g_sdmmcdev1);
|
||||
}
|
||||
#endif
|
||||
|
||||
/****************************************************************************
|
||||
* Name: stm32_sdmmc2_interrupt
|
||||
*
|
||||
* Description:
|
||||
* SDMMC 2 interrupt handler wrapper
|
||||
*
|
||||
* Input Parameters:
|
||||
* irq - not used
|
||||
* context - not used
|
||||
*
|
||||
*
|
||||
* Returned Value:
|
||||
* None
|
||||
*
|
||||
****************************************************************************/
|
||||
#ifdef CONFIG_STM32F7_SDMMC2
|
||||
static int stm32_sdmmc2_interrupt(int irq, void *context, void *arg)
|
||||
{
|
||||
return stm32_sdmmc_interrupt(&g_sdmmcdev2);
|
||||
}
|
||||
#endif
|
||||
/****************************************************************************
|
||||
* SDIO Interface Methods
|
||||
****************************************************************************/
|
||||
@ -2023,8 +1953,7 @@ static int stm32_attach(FAR struct sdio_dev_s *dev)
|
||||
|
||||
/* Attach the SDIO interrupt handler */
|
||||
|
||||
ret = irq_attach(priv->nirq, priv->handler, NULL);
|
||||
|
||||
ret = irq_attach(priv->nirq, stm32_sdmmc_interrupt, priv);
|
||||
if (ret == OK)
|
||||
{
|
||||
|
||||
@ -3066,6 +2995,7 @@ static int stm32_dmasendsetup(FAR struct sdio_dev_s *dev,
|
||||
/****************************************************************************
|
||||
* Initialization/uninitialization/reset
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: stm32_callback
|
||||
*
|
||||
|
Loading…
Reference in New Issue
Block a user