MX28: leds/pwm: Using pwm driven led as heartbeat leads to kernel warning
Alexandre Belloni
alexandre.belloni at free-electrons.com
Tue Apr 8 00:59:16 PDT 2014
On 08/04/2014 at 15:34:04 +0800, Shawn Guo wrote :
> On Fri, Apr 04, 2014 at 06:44:47PM +0200, Alexandre Belloni wrote:
> > On 04/04/2014 at 22:26:58 +0800, Shawn Guo wrote :
> > > On Fri, Apr 04, 2014 at 03:54:52PM +0200, Stefan Wahren wrote:
> > > > the problem is still reproducable in Mainline 3.14.0 and gives the same
> > > > warning message.
> > > > Also i add linux-leds in CC.
> > > >
> > > > Are there any advices to narrow down the problem?
> > > >
> > > > Is this problem specific to i.MX28 PWM (i don't have other kind of
> > > > hardware)?
> > >
> > > I don't think it's specific to i.MX28 PWM. Since the .config hook of
> > > pwm_ops will be called from interrupt context in this case, any pwm
> > > drivers that do sleeping calls in the hook will have this problem, e.g.
> > > the clk APIs that hold mutex like clk_prepare() and clk_get_rate() etc.
> > >
> >
> > Yeah, I'm wondering whether we should set pwm->chip->can_sleep then.
>
> Right, per kerneldoc of struct pwm_chip, we should set can_sleep.
>
> /**
> * struct pwm_chip - abstract a PWM controller
> * ...
> * @can_sleep: must be true if the .config(), .enable() or .disable()
> * operations may sleep
> */
>
> But how does setting the flag make a difference there? I see pwm core
> does nothing about the flag, or am I missing something?
>
The driver using the PWM should test the flag, have a look at:
http://lxr.free-electrons.com/source/drivers/leds/leds-pwm.c#L183
--
Alexandre Belloni, Free Electrons
Embedded Linux, Kernel and Android engineering
http://free-electrons.com
More information about the linux-arm-kernel
mailing list