public inbox for linux-acpi@vger.kernel.org
 help / color / mirror / Atom feed
From: Pavel Machek <pavel-AlSwsSmVLrQ@public.gmane.org>
To: Adam Belay <ambx1-IBH0VoN/3vPQT0dZR+AlfA@public.gmane.org>
Cc: Matthew Garrett <mjg59-1xO5oi07KQx4cg9Nei1l7Q@public.gmane.org>,
	acpi-devel-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@public.gmane.org
Subject: Re: Shutting down PCI devices on suspend
Date: Mon, 13 Dec 2004 12:09:56 +0100	[thread overview]
Message-ID: <20041213110956.GO6272@elf.ucw.cz> (raw)
In-Reply-To: <20041213001125.GD2661-IBH0VoN/3vPQT0dZR+AlfA@public.gmane.org>

Hi!

> > > | driver (*suspend) - tell class to stop logical device (often large amounts
> > > |		      of duplicate code between drivers)
> > 
> > Well, then feel free to move that duplicate code into helper
> > functions. I do think that I'd notice that large amounts of duplicate
> > code, but feel free to prove me wrong.

You did not show me that duplicated code...

> > > |		    - totally ignore ACPI firmware Dx states (how could we
> > > |		      handle them, we don't know enough about the layers below
> > > |		      us.  ACPI may not be compiled into the kernel, the device
> > > |		      may not have ACPI extensions etc.)
> > 
> > Helpers can do that, right?
> 
> Maybe, something really needs to be done about it in the short run.
> 
> 
> Why must the driver be in complete control?  We can't ensure every driver will
> behave consistently.  Why have a driver model at all if we can't break tasks
> into layers of responsibility?

Driver model is neccessary for suspending devices in right order. 

> Yes, layering has small losses in flexability, but the advantage of ensuring
> uniform behavior and capabilities is very important.  With layering, code
> repitition is minimal and everything in the kernel is all around more
> simplistic and easy to maintain.  I think we can have a higher average quality
> of functionality and stability with this approach.  Also less work
> will be

Maybe you'll have higher average quality, but I'm afraid that it will
also mean that few important drivers will no longer work that well
(see the loss of flexibility above).

Plus your solution is more complex and harder to understand.

> required when developing new drivers or adding new functionality.  For
> example, a developer could update class level code without breaking or needing
> to change driver and bus level code.

If you update class level without at least testing the drivers, you
are likely to cause problems. I'd rather have people test their
changes, and the way to do that is to leave the control at the driver
level.

> > Well, if you want your network card to do wake-on-lan, you need to
> > keep it powered on... And the driver is the piece of code that knows
> > if you want to do wake-on-lan, right?
> 
> Firmware like ACPI will tell us what wake-on-lan capabilities we have.  The
> bus layer also handles much of the physical aspects.  The user will say that
> he or she wants the logical device "eth1", as an example, to wake up the
> computer if any traffic is incoming.  So really all of the layers play some
> role in wake-on-lan, right?  Is a device useful for wake-on-lan without a
> corresponding logical ethernet device?

I do not think mapping between eth1, PCI device and ACPI device is
readily available in kernel somewhere. 
									Pavel
-- 
People were complaining that M$ turns users into beta-testers...
...jr ghea gurz vagb qrirybcref, naq gurl frrz gb yvxr vg gung jnl!


-------------------------------------------------------
SF email is sponsored by - The IT Product Guide
Read honest & candid reviews on hundreds of IT Products from real users.
Discover which products truly live up to the hype. Start reading now. 
http://productguide.itmanagersjournal.com/

  parent reply	other threads:[~2004-12-13 11:09 UTC|newest]

Thread overview: 19+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2004-12-11 15:37 Shutting down PCI devices on suspend Matthew Garrett
2004-12-11 19:50 ` Nate Lawson
     [not found]   ` <41BB4F70.9060606-Y6VGUYTwhu0@public.gmane.org>
2004-12-11 22:41     ` Matthew Garrett
2004-12-11 23:20       ` Nate Lawson
     [not found]         ` <41BB80C6.1020404-Y6VGUYTwhu0@public.gmane.org>
2004-12-12  1:44           ` Arjen Verweij
2004-12-11 21:31 ` Arjen Verweij
2004-12-12 16:44 ` Pavel Machek
     [not found]   ` <20041212164422.GD6286-I/5MKhXcvmPrBKCeMvbIDA@public.gmane.org>
2004-12-12 17:01     ` Matthew Garrett
2004-12-12 17:15       ` Pavel Machek
     [not found]         ` <20041212171521.GC6272-I/5MKhXcvmPrBKCeMvbIDA@public.gmane.org>
2004-12-12 19:29           ` Adam Belay
     [not found]             ` <20041212192913.GB2661-IBH0VoN/3vPQT0dZR+AlfA@public.gmane.org>
2004-12-12 20:18               ` Pavel Machek
     [not found]                 ` <20041212201810.GE6272-I/5MKhXcvmPrBKCeMvbIDA@public.gmane.org>
2004-12-12 22:36                   ` Adam Belay
     [not found]                     ` <20041212223655.GC2661-IBH0VoN/3vPQT0dZR+AlfA@public.gmane.org>
2004-12-12 23:01                       ` Pavel Machek
     [not found]                         ` <20041212230157.GH6272-I/5MKhXcvmPrBKCeMvbIDA@public.gmane.org>
2004-12-13  0:11                           ` Adam Belay
     [not found]                             ` <20041213001125.GD2661-IBH0VoN/3vPQT0dZR+AlfA@public.gmane.org>
2004-12-13 11:09                               ` Pavel Machek [this message]
2004-12-12 23:23           ` Matthew Garrett
2004-12-13 10:52             ` Pavel Machek
  -- strict thread matches above, loose matches on Subject: below --
2004-12-13  1:59 Li, Shaohua
     [not found] ` <16A54BF5D6E14E4D916CE26C9AD30575C12271-4yWAQGcml66iAffOGbnezLfspsVTdybXVpNB7YpNyf8@public.gmane.org>
2004-12-13 11:11   ` Pavel Machek

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=20041213110956.GO6272@elf.ucw.cz \
    --to=pavel-alswssmvlrq@public.gmane.org \
    --cc=acpi-devel-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@public.gmane.org \
    --cc=ambx1-IBH0VoN/3vPQT0dZR+AlfA@public.gmane.org \
    --cc=mjg59-1xO5oi07KQx4cg9Nei1l7Q@public.gmane.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