Re: LED devices & poll() for brightness attribute

From: Pali RohÃr
Date: Wed Feb 22 2017 - 16:16:48 EST


On Wednesday 22 February 2017 21:54:08 Pavel Machek wrote:
> On Wed 2017-02-22 13:39:29, Pali RohÃr wrote:
> > On Wednesday 22 February 2017 13:25:57 Pavel Machek wrote:
> > > Hi!
> > >
> > > > But this support is useful just for one single central
> > > > userspace application which will control all leds in system
> > > > other application which will change state by /sys/class/leds/
> > > > will de-synchronize that one central application.
>
> Actually this is wrong.
>
> > > Yes. Does it matter for some real use case?
> >
> > Yes. E.g. systemd has already some support for changing leds. And I
> > do not want to be forced to use systemd (or any other specific
> > application) just because it already controls leds.
>
> So... you don't want to use systemd, so don't use systemd. What is
> the problem? :-)
>
> > And my own application for controlling leds should know current
> > state of them if it is possible.
>
> If you have at most one application controlling each LED, you are
> fine. That's quite common situation, serial port can also be opened
> at most once. Do you actually have two applications accessing one
> led? If so, what applications?

First application which controls leds is integrated into desktop
environment. In basic/default settings it do nothing automatically, just
show GUI bar to user and allow user to adjust LED level.

Second one is basic shell script executed at specific situation (e.g.
power adapter was unplugged) which changes LED level.

Now you have two independent applications which both could change LED
level and at least one of them needs to know if another one changed
level so can adjust GUI bar correctly.

I think this starts to be real situation for lot of users as more
desktops (gnome, kde, ...) have already GUI bars for setting keyboard
backlight and more users writes own scripts which at specific
time/condition call echo > brightness.

Yes, if somebody uses GUI bar for manual keyboard backlight probably
does not use led trigger or blinking feature. Probably that GUI desktop
application could turn off them (do not know if kde/gnome application
really turn off them).

> > > > So I think new ABI is not sufficient and I would propose to add
> > > > poll() support also for changes done by userspace, write() to
> > > > attribute /sys/class/leds/.../brightness.
> > >
> > > Not easily possible, as we have triggers, and this was discussed
> > > in great great lengths before. Please go through that
> > > discussion.
> >
> > Without triggers and blinking it should be possible.
> >
> > Just notify only when some application do echo > brightness.
>
> Yes, we _could_ do that. Would be slightly confusing
> w.r.t. triggers. But is it good idea?

Above situation for setting manual level of led is normal. And in this
situation setting trigger or blink support does not make sense.
Specially when user want to manually set led level.

I think it is good idea to provide some poll-able sysfs for this change.
And if brightness is used for writing, then I would expect that
brightness also provide poll() state.

Yes, it could be little confusing due to triggers/blinking support, but
I think it is better as providing new sysfs file and it does not make
this interface worse...

> Userspace could easily keep /var/run/led/XXX/brightness, and inotify
> works over regular files..

That would need to force all application to decide on this specific
path. And looks bad as kernel already provides brightness attribute, why
it should not also notify for changes on it?

> And yes, with three color LEDs, userspace daemon managing LED state
> will be pretty much mandatory...

Why it should be running daemon? Script which you start when you want
change is also enough... no need to have permanently running process.

--
Pali RohÃr
pali.rohar@xxxxxxxxx

Attachment: signature.asc
Description: This is a digitally signed message part.