Re: [PATCH] Re: NAK new drivers without proper power management?

From: Nigel Cunningham
Date: Sat Feb 10 2007 - 05:02:24 EST


Gidday.

On Sat, 2007-02-10 at 10:34 +0100, Rafael J. Wysocki wrote:
> On Saturday, 10 February 2007 04:02, Nigel Cunningham wrote:
> > On Fri, 2007-02-09 at 19:50 -0600, Robert Hancock wrote:
> > > It also kind of bothers me that if a driver has no suspend/resume
> > > functions, and you suspend and resume the system, we don't complain
> > > about it even though there's a very good chance that device is not going
> > > to function properly. How about something in dmesg like:
> > >
> > > Warning: driver for device XXXX has no suspend or resume support.
> > > Device may not function properly after resume.
> > >
> > > so that users know who to complain to. Maybe there are some devices that
> > > truly don't need any handling for suspend, but if so I suspect the
> > > number of those is small enough that adding empty functions would be a
> > > good-enough solution.
> >
> > Here's my current version of a patch to do this, if anyone wants to try
> > it out. It dumps stack with the warning to make it easier to see what
> > the source of the message is:
>
> I have an alternative idea.
>
> There is a test mode of swsusp that's triggered with
> "echo test > /sys/power/disk" and "echo disk > /sys/power/state". We can make
> it set a switch that will be used to trigger the warnings in the core.
>
> This way the warnings will only appear in the user's dmesg in the test mode
> and not always.
>
> Would that be acceptable?

Well, the original desire was to stop new drivers getting in without
proper power management. For this to help achieve that aim, one or more
of the following would need to happen:

* developers of new drivers would have to remember to run the test
after/during writing their driver. Of course if they remember to do
this, they've already remembered that they need to implement power
management;
* you, I or someone else would need to test all these trees before
Andrew and Linus merge them and report problems to the developers before
they get their new drivers merged;
* Andrew or Linus would run it prior to or after merging a whole lot of
stuff.

I'm afraid I don't like the chances of any of those things happening, so
I'm not sure that it is an acceptable alternative from my perspective.

Sticking a printk in dmesg doesn't exactly put the problem in flashing
red 36 point characters before the developer either, but I think they're
slightly more likely to see it there if only because they might stick
printks in that they want to read (eg perhaps while debugging the
driver) and therefore see the message when checking output from the
driver being loaded/initialised.

Maybe another alternative would be to make the warnings compile time
warnings - if that's possible?

Regards,

Nigel

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/