All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Uwe Kleine-König" <u.kleine-koenig@pengutronix.de>
To: Thierry Reding <thierry.reding@gmail.com>
Cc: linux-pwm@vger.kernel.org,
	Boris Brezillon <boris.brezillon@bootlin.com>,
	kernel@pengutronix.de,
	Ariel D'Alessandro <ariel@vanguardiasur.com.ar>
Subject: Re: is pwm_put supposed to stop a PWM?
Date: Thu, 15 Nov 2018 21:46:15 +0100	[thread overview]
Message-ID: <20181115204615.mo5ea6uzxkb73kdf@pengutronix.de> (raw)
In-Reply-To: <20181115154345.GB8611@ulmo>

Hello Thierry,

On Thu, Nov 15, 2018 at 04:43:45PM +0100, Thierry Reding wrote:
> On Thu, Nov 15, 2018 at 09:42:31AM +0100, Uwe Kleine-König wrote:
> > On Wed, Nov 14, 2018 at 12:50:25PM +0100, Thierry Reding wrote:
> > > On Wed, Nov 14, 2018 at 10:30:07AM +0100, Uwe Kleine-König wrote:
> > > > On Sat, Nov 03, 2018 at 03:49:20PM +0100, Uwe Kleine-König wrote:
> > > > > On Mon, Oct 29, 2018 at 12:48:35PM +0100, Thierry Reding wrote:
> > > > > > On Thu, Oct 25, 2018 at 09:45:24PM +0200, Uwe Kleine-König wrote:
> > > > > > > while digging around in the pwm drivers I found
> > > > > > > drivers/pwm/pwm-lpc18xx-sct.c which in its .free callback calls
> > > > > > > pwm_disable() and pwm_set_duty_cycle(pwm, 0).
> > > > > > > 
> > > > > > > I think calling pwm_disable is wrong for two reasons:
> > > > > > > 
> > > > > > >  a) pwm_disable is for PWM users, not for drivers
> > > > > > 
> > > > > > PWM controller drivers can still call pwm_disable(), though they should
> > > > > > do so very carefully and not behind consumers' backs.
> > > > > 
> > > > > I'd say this is a bad idea because the driver knows in which callback
> > > > > this results and so there is complexity for no real benefit. When the
> > > > > core implemented some locking this could easily deadlock.
> > > > 
> > > > I think it would be beneficial to get rid of these calls. Would you
> > > > agree to document calling pwm-API calls as forbidden as a first step and
> > > > then work on fixing these?
> > > 
> > > I'm not a big fan of documenting anything as being forbidden. People can
> > > do whatever they want when nobody's checking and we don't have a way of
> > > enforcing anything either because they could just as well remove those
> > > enforcement measures. Remember, they have access to all the code, so the
> > > best we can do is discourage people from doing potentially stupid things
> > > by documenting expectations, requirements and limitations.
> > 
> > In my eyes the purpose of the PWM framework (and similar all other
> > frameworks, too) is to abstract a common set of functions for a certain
> > type of hardware. As such it is beneficial to all affected parties if
> > the hardware drivers have a tight policy what is expected. This makes
> > implementing stuff in the hardware driver easier, because people know
> > what should be done and what not in a given callback. It makes pwm
> > consumers' work easier, because they know what to expect from calling a
> > certain API function and so increases the chances that a backlight
> > driver that was only tested with say a rockchip PWM also works the same
> > way when another machine makes use of the same backlight driver with an
> > imx PWM.
> > This increases overall code quality.
> > 
> > Sure we cannot protect people from doing stupid things by patching
> > stuff. But we can improve the situation for people who have to patch to
> > actually fix broken stuff by documenting for them in the above scenario
> > where the backlight driver doesn't work with the imx pwm if it's the
> > backlight driver or the pwm driver that needs adaption to converge to a
> > state where all pwm consumers work with all pwm backends.
> 
> I agree with the above. But I don't see how it is relevant to this
> particular discussion.

I also think this is irrelevant to the discussion. It was you who
brought up this argument.

> I'm merely pointing out that we can't prevent people from using
> pwm_disable() in drivers if they choose to do so.  Yes, we should
> avoid doing that in the upstream kernel if we consider it to be bad
> practice, and we can enforce it during review or reject patches that
> do so. If this is currently not clear, then by all means let's
> document it.

Of course such a rule only applies to the vanilla kernel. And it is
totally irrelevant if the rule states that something is forbidden or if
it states that something must be done.

> However, we have no means of controlling what people do when they work
> outside of upstream and we also have no way of prosecuting people, so
> "forbidding" something is pointless.
> 
> > > > > > So perhaps a good compromise would be to document that users are
> > > > > > supposed to disable the PWM before they release it and then drivers (or
> > > > > > the core) could go and check that they're really disabled when the chip
> > > > > > is being removed and WARN() if not. That way we can flag all consumers
> > > > > > that don't behave and fix them.
> > > > > 
> > > > > Yeah, I'd say documenting is a good idea, too. And then check in the
> > > > > core (and WARN there) and remove the code from hardware drivers.
> > > > 
> > > > Thinking about this, I'd not require that a consumer disables a pwm
> > > > before calling pwm_put. Eventually it might have good reasons to keep
> > > > the PWM running (e.g. to keep a led in its state). So I'd restrict the
> > > > documentation to the undisputed part that the hw driver should only
> > > > touch the configuration in .apply (respectively .config, .set_polarity,
> > > > .enable, .disable for legacy drivers).
> > > 
> > > What would you consider good reasons for keeping a PWM running when the
> > > consumer no longer needs it? I can't come up with any sane reason why we
> > > would want to allow that. It's normal to turn things off when you no
> > > longer need them. I do that with a computer, an oven and a shower, too.
> > > Why would a PWM be different?
> > 
> > I'm not sure I have a good use case. But I'm not certain enough that
> > there is none and so I'd just say---keeping legacy drivers out of the
> > discussion for simplicity:
> > 
> > 	A hardware driver should only modify the behaviour of the output
> > 	pin in the .apply callback.
> > 
> > instead of:
> > 
> > 	The PWM consumer must disable the PWM before calling pwm_put.
> > 	The backend driver can assume the PWM to be off when its .free
> > 	callback is entered.
> 
> I don't get it. On one hand you're arguing that we should put stricter
> rules into place so that consumers know what to expect and then you walk
> that back and say we shouldn't have stricter rules.

I think the rules for hardware drivers should be strict. And I think
that the PWM framework should be as cooperative as possible to its
consumers. That's according to the motto "Be conservative in what you
do, be liberal in what you accept from others."

> To reiterate my point: there's no reason to keep anything enabled after
> you're done using it. If you need to keep it enabled it means that you
> still use it. In terms of drivers this means that as long as a device is
> actively being used (backlight, fan, motor, ...), the consumer of the
> PWM should stay around. You don't unload a backlight driver if you want
> to keep using the backlight, right? The same is true for fans and any
> number of things. Once you no longer use the device the natural action
> is to turn it off. Consequently when you unload the PWM consumer driver
> the PWM should be disabled.
> 
> So I do think we should require consumers to disable a PWM before they
> release the PWM using pwm_put() and warn about it on pwmchip_remove().

I wouldn't enforce this, but I won't argue here.

Best regards
Uwe

-- 
Pengutronix e.K.                           | Uwe Kleine-König            |
Industrial Linux Solutions                 | http://www.pengutronix.de/  |

  reply	other threads:[~2018-11-15 20:46 UTC|newest]

Thread overview: 26+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-10-25 19:45 is pwm_put supposed to stop a PWM? Uwe Kleine-König
2018-10-29 11:48 ` Thierry Reding
2018-11-03 14:49   ` Uwe Kleine-König
2018-11-14  9:30     ` Uwe Kleine-König
2018-11-14 11:50       ` Thierry Reding
2018-11-15  8:42         ` Uwe Kleine-König
2018-11-15 15:43           ` Thierry Reding
2018-11-15 20:46             ` Uwe Kleine-König [this message]
2018-11-16  6:52         ` [PATCH] pwm: lpc18xx-sct: don't reconfigure PWM in .request and .free Uwe Kleine-König
2018-11-16  6:52           ` Uwe Kleine-König
2018-11-16  7:02           ` Uwe Kleine-König
2018-11-16  7:02             ` Uwe Kleine-König
2018-11-16  9:22           ` Vladimir Zapolskiy
2018-11-16  9:22             ` Vladimir Zapolskiy
2018-11-16  9:48             ` Uwe Kleine-König
2018-11-16  9:48               ` Uwe Kleine-König
2018-11-16 10:01             ` Thierry Reding
2018-11-16 10:01               ` Thierry Reding
2018-11-16 10:45               ` Uwe Kleine-König
2018-11-16 10:45                 ` Uwe Kleine-König
2018-11-16 10:05           ` Thierry Reding
2018-11-16 10:05             ` Thierry Reding
2018-11-19 19:55             ` Uwe Kleine-König
2018-11-19 19:55               ` Uwe Kleine-König
2018-11-20 15:42               ` Thierry Reding
2018-11-20 15:42                 ` Thierry Reding

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20181115204615.mo5ea6uzxkb73kdf@pengutronix.de \
    --to=u.kleine-koenig@pengutronix.de \
    --cc=ariel@vanguardiasur.com.ar \
    --cc=boris.brezillon@bootlin.com \
    --cc=kernel@pengutronix.de \
    --cc=linux-pwm@vger.kernel.org \
    --cc=thierry.reding@gmail.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.