From: Pavel Machek <pavel@suse.cz>
To: Andrew Morton <akpm@linux-foundation.org>
Cc: linux-kernel@vger.kernel.org, eric.piel@tremplin-utc.net
Subject: Re: hp_accel: do not call ACPI from invalid context
Date: Tue, 13 Jan 2009 23:40:13 +0100 [thread overview]
Message-ID: <20090113224013.GC7770@elf.ucw.cz> (raw)
In-Reply-To: <20090113141721.ccd90351.akpm@linux-foundation.org>
On Tue 2009-01-13 14:17:21, Andrew Morton wrote:
> On Mon, 12 Jan 2009 11:31:55 +0100
> Pavel Machek <pavel@suse.cz> wrote:
>
> >
> > LED on HP notebooks is connected through ACPI. That unfortunately
> > means that it needs to be delayed by using schedule_work() to avoid
> > calling ACPI interpretter in invalid context. This patch fixes that.
> >
> > ...
> >
> > +/* Delayed LEDs infrastructure ------------------------------------ */
> > +
> > +/* Special LED class that can defer work */
> > +struct delayed_led_classdev {
> > + struct led_classdev led_classdev;
> > + struct work_struct work;
> > + enum led_brightness new_brightness;
> > +
> > + unsigned int led; /* For driver */
> > + void (*set_brightness)(struct delayed_led_classdev *data, enum led_brightness value);
> > +};
> > +
> > +static inline void delayed_set_status_worker(struct work_struct *work)
> > +{
> > + struct delayed_led_classdev *data =
> > + container_of(work, struct delayed_led_classdev, work);
> > +
> > + data->set_brightness(data, data->new_brightness);
> > +}
> > +
> > +static inline void delayed_sysfs_set(struct led_classdev *led_cdev,
> > + enum led_brightness brightness)
> > +{
> > + struct delayed_led_classdev *data = container_of(led_cdev,
> > + struct delayed_led_classdev, led_classdev);
> > + data->new_brightness = brightness;
> > + schedule_work(&data->work);
> > +}
>
> Is this the only LED driver int he current and future history of the
> world which uses ACPI?
>
> coz otherwise, this code might better live in LEDs core somewhere, so
> those other drivers can use it?
There are 2 other drivers (thinkpad_acpi and asus-something IIRC) that
want the same infrastructure. So I put that code in
include/linux/delayed-leds.h in my tree, but then I realized I'd need
to coordinate too many maintainers and just inlined it for the
merge. (We do not want to schedule from atomic, right?)
I already have a patch for thinkpad_acpi, but it needs a bit more
testing and perhaps some tweaks by maintainer. So yes, eventually
putting that into shared place is a plan.
> > if (ret) {
> > - led_classdev_unregister(&hpled_led);
> > + while (work_pending(&hpled_led.work))
> > + schedule();
>
> We have flush_work() for this?
I did not realize flush_work() exists/does what I need... sorry.
Pavel
--
(english) http://www.livejournal.com/~pavelmachek
(cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
prev parent reply other threads:[~2009-01-13 22:40 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-01-12 10:31 hp_accel: do not call ACPI from invalid context Pavel Machek
2009-01-13 22:11 ` Andrew Morton
2009-01-13 22:33 ` Pavel Machek
2009-01-13 22:17 ` Andrew Morton
2009-01-13 22:40 ` Pavel Machek [this message]
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=20090113224013.GC7770@elf.ucw.cz \
--to=pavel@suse.cz \
--cc=akpm@linux-foundation.org \
--cc=eric.piel@tremplin-utc.net \
--cc=linux-kernel@vger.kernel.org \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox