On Friday 19 February 2010, Alan Jenkins wrote:
On 2/18/10, Rafael J. Wysocki <rjw@xxxxxxx> wrote:
On Thursday 18 February 2010, Alan Jenkins wrote:EeePC 701. 32 bit. 512Mb RAM. 350Mb swap file, on a "first-gen" SSD.
On 2/17/10, Rafael J. Wysocki <rjw@xxxxxxx> wrote:Hmm. I guess I asked that before, but is this a 32-bit or 64-bit system and
On Wednesday 17 February 2010, Alan Jenkins wrote:It still hangs if I try to hibernate a couple of times with too many
On 2/16/10, Rafael J. Wysocki <rjw@xxxxxxx> wrote:In that case you can try to reduce the number of preallocated pages even
On Tuesday 16 February 2010, Alan Jenkins wrote:I did test with both patches applied together -
On 2/16/10, Alan Jenkins <sourcejedi.lkml@xxxxxxxxxxxxxx> wrote:Have you tested it alone or on top of the previous one? If you've
On 2/15/10, Rafael J. Wysocki <rjw@xxxxxxx> wrote:To be clear: It doesn't stop the hang when I hibernate with too many
On Tuesday 09 February 2010, Alan Jenkins wrote:It doesn't seem to help.
Perhaps I spoke too soon. I see the same hang if I run too manyWell, I have an idea.
applications. The first hibernation fails with "not enough
swap"
as
expected, but the second or third attempt hangs (with the same
backtrace
as before).
The patch definitely helps though. Without the patch, I see a
hang
the
first time I try to hibernate with too many applications
running.
Can you try to apply the appended patch in addition and see if
that
helps?
Rafael
applications.
It does stop the same hang in a different case though.
1. boot with init=/bin/bash
2. run s2disk
3. cancel the s2disk
4. repeat steps 2&3
With the patch, I can run 10s of iterations, with no hang.
Without the patch, it soon hangs, (in disable_nonboot_cpus(), as
always).
That's what happens on 2.6.33-rc7. On 2.6.30, there is no problem.
On 2.6.31 and 2.6.32 I don't get a hang, but dmesg shows an
allocation
failure after a couple of iterations ("kthreadd: page allocation
failure. order:1, mode:0xd0"). It looks like it might be the same
stop_machine thread allocation failure that causes the hang.
tested it
alone, please apply the appended one in addition to it and retest.
Rafael
1. [Update] MM / PM: Force GFP_NOIO during suspend/hibernation and
resume
2. "reducing the number of pages that we're going to keep preallocated
by
20%"
more,
ie. change "/ 5" to "/ 2" (for example) in the second patch.
applications.
how much RAM is there in the box?
Rafael
Hmm. I'd try to make free_unnecessary_pages() free all of the preallocated
pages and see what happens.