[linux-pm] [PATCH 2/2] Fix console handling during suspend/resume

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi!

> > > > Why? We are saving state to memory, we should not need any other
> > > > devices to do that.
> > > 
> > > Hell no, we're not.
> > 
> > ?
> 
> We're clearly saving state to _user_ space etc in some cases. That's not 
> "memory", that is "pageable data and processes that can - and do - depend 
> on other devices in ways that the kernel is not necessarily even aware 
> of".
> 
> Just as the most obvious example, it's entirely possible that when you ask 
> the graphics system to save its state, it might actually tell clients 
> across a network that their window got occluded or something.

That's okay, kernel tells X to switch consoles. When X gives console
control back to kernel, kernel owns the graphics hardware, and we are
okay.

> The same is true of various virtual devices that the kernel may not even 
> know about. Network devices done as tunnels in user space etc. They may 
> _look_ like system devices at the root of the device tree to the kernel, 
> but that's just because the kernel has not a f*cking clue about what they 
> are actually connected to.

I admit we have problems with various virtual devices...

> So we're _not_ just saving data to memory. We're allocating memory (which 
> means that we want to access every single device that may do write-back), 
> and we're calling out to user space (which means that we _really_ don't 
> know what a device may need).

That memory should be either allocated statically, or allocated during
boot up or something. Usually, device just adds few bytes to
per-device structures.. this problem is real but not too bad.

> > For fbcon, etc, no, we do not any other devices, so it actually works
> > okay.
> 
> Yeah, Linux suspend is generally felt to "work ok".
> 
> Not.

Yeah, we have few drivers to fix :-). Yes, we could add one more pass
before freezing (in s2disk) and before suspending (s2ram). Would it
magically solve all the suspend problems? No I don't think so.

[Your separate pass may save some memory at runtime, you are right,
but it will not fix the buggy drivers.]

> > > In fact, done right, if you know the machine powers off, the final suspend 
> > > should literally not be needed. "Remove power globally" is actually a very 
> > > good suspend/shutdown mechanism that doesn't even need any driver support ;)
> > 
> > Actually, that's bad idea; some machines are unable to power down with
> > devices still running.
> 
> Can you read my sentence again? "If you know the machine powers off"?
> 
> Trust me, if you remove power from the devices, that machine _will_ power 
> down. It's that simple. It's not "maybe", or "if" or "unable to". It's 
> basic physics.

Except that powerdown is done with ACPI, and that means ... guess
what... BIOS call. And that BIOS fails if you leave APIC enabled, or
something like that. So yes, if you could cut off power with devices
enabled, it is okay to do that. But you can't, because BIOSen are
broken.

									Pavel
-- 
(english) http://www.livejournal.com/~pavelmachek
(cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html


[Index of Archives]     [Linux ACPI]     [Netdev]     [Ethernet Bridging]     [Linux Wireless]     [CPU Freq]     [Kernel Newbies]     [Fedora Kernel]     [Security]     [Linux for Hams]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux Admin]     [Samba]

  Powered by Linux