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 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.