Prev: Change hex to Math::BigInt->from_hex in markup_oops.pl
Next: [PATCH 3/8] percpu: add __percpu sparse annotations to net
From: Sebastian Ott on 25 Jan 2010 10:10 Hi. On Fri, 22 Jan 2010, Rafael J. Wysocki wrote: > On Friday 22 January 2010, Sebastian Ott wrote: > > > > a possible fix would be to call disable_nonboot_cpus before suspending the > > devices.. > > This is going against the changes attempting to speed-up suspend and resume, > such as the asynchronous suspend/resume patchset, so I don't agree with it. Isn't the main benefit for this scenario that while a driver starts io and waits for interrupts, the callback for the next device can be called? And this can be done with one cpu as well. > > The real solution would be to remove the memory allocations from the > _cpu_down() call path. So you have to also ban allocations from all registered notifiers at the cpu_chain. And since enable_nonboot_cpus is called before the devices are woken up, the same would be true for _cpu_up() which may not be done easily. > > BTW, this is one of the cases I and Ben are talking about where it's not > practical to rework the code just to avoid memory allocation problems during > suspend/resume. Ok. All i'm saying is that in hibernation_snapshot/create_image memory allocations are directely triggered after all devices were put to sleep / before woken up - and this looks like a bug. For the driver case - what about using your patch to not modify the gfp mask but print a warning instead so that these drivers can be identified and fixed. Regards, Sebastian -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
From: Sebastian Ott on 1 Feb 2010 09:50
Hi Rafael, since you didn't like the idea of calling the driver callbacks with just one cpu enabled, we gave your patch: "MM / PM: Force GFP_NOIO during suspend/hibernation and resume" a try and i can confirm that this fixes the issue on s390. Will this go in 2.6.33/stable? greetings, Sebastian -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/ |