Add argument to capture irq callback
This commit is contained in:
parent
5987db47e5
commit
27c3c2605c
@ -702,7 +702,7 @@ static int stm32_cap_setclock(FAR struct stm32_cap_dev_s *dev, stm32_cap_clk_t c
|
|||||||
return prescaler;
|
return prescaler;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int stm32_cap_setisr(FAR struct stm32_cap_dev_s *dev, xcpt_t handler)
|
static int stm32_cap_setisr(FAR struct stm32_cap_dev_s *dev, xcpt_t handler, void *arg)
|
||||||
{
|
{
|
||||||
const struct stm32_cap_priv_s *priv = (const struct stm32_cap_priv_s *)dev;
|
const struct stm32_cap_priv_s *priv = (const struct stm32_cap_priv_s *)dev;
|
||||||
int irq;
|
int irq;
|
||||||
@ -736,13 +736,13 @@ static int stm32_cap_setisr(FAR struct stm32_cap_dev_s *dev, xcpt_t handler)
|
|||||||
|
|
||||||
/* Otherwise set callback and enable interrupt */
|
/* Otherwise set callback and enable interrupt */
|
||||||
|
|
||||||
irq_attach(irq, handler, NULL);
|
irq_attach(irq, handler, arg);
|
||||||
up_enable_irq(irq);
|
up_enable_irq(irq);
|
||||||
|
|
||||||
#ifdef USE_ADVENCED_TIM
|
#ifdef USE_ADVENCED_TIM
|
||||||
if (priv->irq_of)
|
if (priv->irq_of)
|
||||||
{
|
{
|
||||||
irq_attach(priv->irq_of, handler, NULL);
|
irq_attach(priv->irq_of, handler, arg);
|
||||||
up_enable_irq(priv->irq_of);
|
up_enable_irq(priv->irq_of);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -54,7 +54,7 @@
|
|||||||
#define STM32_CAP_SETCLOCK(d,clk_src,psc,max) ((d)->ops->setclock(d,clk_src,psc,max))
|
#define STM32_CAP_SETCLOCK(d,clk_src,psc,max) ((d)->ops->setclock(d,clk_src,psc,max))
|
||||||
#define STM32_CAP_SETCHANNEL(d,ch,cfg) ((d)->ops->setchannel(d,ch,cfg))
|
#define STM32_CAP_SETCHANNEL(d,ch,cfg) ((d)->ops->setchannel(d,ch,cfg))
|
||||||
#define STM32_CAP_GETCAPTURE(d,ch) ((d)->ops->getcapture(d,ch))
|
#define STM32_CAP_GETCAPTURE(d,ch) ((d)->ops->getcapture(d,ch))
|
||||||
#define STM32_CAP_SETISR(d,hnd) ((d)->ops->setisr(d,hnd))
|
#define STM32_CAP_SETISR(d,hnd,arg) ((d)->ops->setisr(d,hnd,arg))
|
||||||
#define STM32_CAP_ENABLEINT(d,s,on) ((d)->ops->enableint(d,s,on))
|
#define STM32_CAP_ENABLEINT(d,s,on) ((d)->ops->enableint(d,s,on))
|
||||||
#define STM32_CAP_ACKFLAGS(d,f) ((d)->ops->ackflags(d,f))
|
#define STM32_CAP_ACKFLAGS(d,f) ((d)->ops->ackflags(d,f))
|
||||||
#define STM32_CAP_GETFLAGS(d) ((d)->ops->getflags(d))
|
#define STM32_CAP_GETFLAGS(d) ((d)->ops->getflags(d))
|
||||||
@ -178,7 +178,7 @@ struct stm32_cap_ops_s
|
|||||||
int (*setclock)( FAR struct stm32_cap_dev_s *dev, stm32_cap_clk_t clk, uint32_t prescaler, uint32_t max);
|
int (*setclock)( FAR struct stm32_cap_dev_s *dev, stm32_cap_clk_t clk, uint32_t prescaler, uint32_t max);
|
||||||
int (*setchannel)(FAR struct stm32_cap_dev_s *dev, uint8_t channel, stm32_cap_ch_cfg_t cfg);
|
int (*setchannel)(FAR struct stm32_cap_dev_s *dev, uint8_t channel, stm32_cap_ch_cfg_t cfg);
|
||||||
uint32_t (*getcapture)(FAR struct stm32_cap_dev_s *dev, uint8_t channel);
|
uint32_t (*getcapture)(FAR struct stm32_cap_dev_s *dev, uint8_t channel);
|
||||||
int (*setisr)( FAR struct stm32_cap_dev_s *dev, xcpt_t handler);
|
int (*setisr)(FAR struct stm32_cap_dev_s *dev, xcpt_t handler, void *arg);
|
||||||
void (*enableint)( FAR struct stm32_cap_dev_s *dev, stm32_cap_flags_t src, bool on );
|
void (*enableint)( FAR struct stm32_cap_dev_s *dev, stm32_cap_flags_t src, bool on );
|
||||||
void (*ackflags)( FAR struct stm32_cap_dev_s *dev, int flags);
|
void (*ackflags)( FAR struct stm32_cap_dev_s *dev, int flags);
|
||||||
stm32_cap_flags_t (*getflags)(FAR struct stm32_cap_dev_s *dev);
|
stm32_cap_flags_t (*getflags)(FAR struct stm32_cap_dev_s *dev);
|
||||||
|
Loading…
Reference in New Issue
Block a user