From: "Rafael J. Wysocki" <rjw@sisk.pl>
To: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com>
Cc: linux-pm@lists.linux-foundation.org,
"M. Vefa Bicakci" <bicave@superonline.com>,
Linux Kernel Mailing List <linux-kernel@vger.kernel.org>
Subject: Re: [Bisected Regression in 2.6.35] A full tmpfs filesystem causeshibernation to hang
Date: Thu, 2 Sep 2010 22:24:59 +0200 [thread overview]
Message-ID: <201009022224.59313.rjw@sisk.pl> (raw)
In-Reply-To: <201009022157.18561.rjw@sisk.pl>
On Thursday, September 02, 2010, Rafael J. Wysocki wrote:
> On Thursday, September 02, 2010, KOSAKI Motohiro wrote:
> > > On Wednesday, September 01, 2010, KOSAKI Motohiro wrote:
> > > > > === 8< ===
> > > > > PM: Marking nosave pages: ...0009f000 - ...000100000
> > > > > PM: basic memory bitmaps created
> > > > > PM: Syncing filesystems ... done
> > > > > Freezing user space processes ... (elapsed 0.01 seconds) done.
> > > > > Freezing remaining freezable tasks ... (elapsed 0.01 seconds) done.
> > > > > PM: Preallocating image memory...
> > > > > shrink_all_memory start
> > > > > PM: shrink memory: pass=1, req:310171 reclaimed:15492 free:360936
> > > > > PM: shrink memory: pass=2, req:294679 reclaimed:28864 free:373981
> > > > > PM: shrink memory: pass=3, req:265815 reclaimed:60311 free:405374
> > > > > PM: shrink memory: pass=4, req:205504 reclaimed:97870 free:443024
> > > > > PM: shrink memory: pass=5, req:107634 reclaimed:146948 free:492141
> > > > > shrink_all_memory: req:107634 reclaimed:146948 free:492141
> > > > > PM: preallocate_image_highmem 556658 278329
> > > > > PM: preallocate_image_memory 103139 103139
> > > > > PM: preallocate_highmem_fraction 183908 556658 760831 -> 183908
> > > > > === >8 ===
> > > >
> > > > Rafael, this log mean hibernate_preallocate_memory() has a bug.
> > >
> > > Well, it works as designed ...
> > >
> > > > It allocate memory as following order.
> > > > 1. preallocate_image_highmem() (i.e. __GFP_HIGHMEM)
> > > > 2. preallocate_image_memory() (i.e. GFP_KERNEL)
> > > > 3. preallocate_highmem_fraction (i.e. __GFP_HIGHMEM)
> > > > 4. preallocate_image_memory() (i.e. GFP_KERNEL)
> > > >
> > > > But, please imazine following scenario (as Vefa's scenario).
> > > > - system has 3GB memory. 1GB is normal. 2GB is highmem.
> > > > - all normal memory is free
> > > > - 1.5GB memory of highmem are used for tmpfs. rest 500MB is free.
> > >
> > > Indeed, that's a memory allocation pattern I didn't anticipate.
> > >
> > > > At that time, hibernate_preallocate_memory() works as following.
> > > >
> > > > 1. call preallocate_image_highmem(1GB)
> > > > 2. call preallocate_image_memory(500M) total 1.5GB allocated
> > > > 3. call preallocate_highmem_fraction(660M) total 2.2GB allocated
> > > >
> > > > then, all of normal zone memory was exhaust. next preallocate_image_memory()
> > > > makes OOM, and oom_killer_disabled makes infinite loop.
> > > > (oom_killer_disabled careless is vmscan bug. I'll fix it soon)
> > >
> > > So, it looks like the problem will go away if we check if there are any normal
> > > pages to allocate from before calling the last preallocate_image_memory()?
> > >
> > > Like in the patch below, perhaps?
> >
> > Looks like fine. but I have one question. hibernate_preallocate_memory() call
> > preallocate_image_memory() two times. Why do you only care latter one?
> > former one seems similar risk.
>
> The first one is mandatory, ie. if we can't allocate the requested number of
> pages at this point, we fail the entire hibernation. In that case the
> performance hit doesn't matter.
IOW, your patch at http://lkml.org/lkml/2010/9/2/262 is still necessary to
protect against the infinite loop in that case.
Thanks,
Rafael
next prev parent reply other threads:[~2010-09-02 20:24 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <20100830083704.5231.A69D9226@jp.fujitsu.com>
[not found] ` <4C7BE25B.1020504@superonline.com>
2010-09-01 0:48 ` [Bisected Regression in 2.6.35] A full tmpfs filesystem causeshibernation to hang KOSAKI Motohiro
[not found] ` <20100901093219.9744.A69D9226@jp.fujitsu.com>
2010-09-01 22:02 ` Rafael J. Wysocki
[not found] ` <201009020002.25113.rjw@sisk.pl>
2010-09-02 0:31 ` KOSAKI Motohiro
[not found] ` <20100902091010.D050.A69D9226@jp.fujitsu.com>
2010-09-02 19:57 ` Rafael J. Wysocki
[not found] ` <201009022157.18561.rjw@sisk.pl>
2010-09-02 20:24 ` Rafael J. Wysocki [this message]
2010-09-03 0:13 ` KOSAKI Motohiro
[not found] ` <20100903085756.B657.A69D9226@jp.fujitsu.com>
2010-09-03 1:07 ` Rafael J. Wysocki
2010-09-03 1:53 ` KOSAKI Motohiro
[not found] ` <20100903105216.B65C.A69D9226@jp.fujitsu.com>
2010-09-04 1:44 ` Rafael J. Wysocki
[not found] ` <201009040344.42342.rjw@sisk.pl>
2010-09-06 2:08 ` KOSAKI Motohiro
[not found] ` <20100906090528.C8A9.A69D9226@jp.fujitsu.com>
2010-09-06 11:27 ` Important news regarding the two different patches M. Vefa Bicakci
[not found] ` <4C84D02A.7070508@superonline.com>
2010-09-06 18:43 ` Rafael J. Wysocki
[not found] ` <201009062043.37819.rjw@sisk.pl>
2010-09-07 1:34 ` M. Vefa Bicakci
[not found] ` <4C8596B1.6010005@superonline.com>
2010-09-07 1:58 ` KOSAKI Motohiro
[not found] ` <20100907104218.C8EF.A69D9226@jp.fujitsu.com>
2010-09-07 21:44 ` Rafael J. Wysocki
[not found] ` <201009072344.53905.rjw@sisk.pl>
2010-09-08 12:56 ` M. Vefa Bicakci
[not found] ` <4C878818.1070705@superonline.com>
2010-09-08 21:34 ` [PATCH] PM / Hibernate: Avoid hitting OOM during preallocation of memory (was: Re: Important news ...) Rafael J. Wysocki
[not found] ` <201009082334.01255.rjw@sisk.pl>
2010-09-11 18:12 ` PATCH: PM / Hibernate: Avoid hitting OOM during preallocationof memory M. Vefa Bicakci
[not found] ` <4C8BC68B.8050002@superonline.com>
2010-09-11 19:06 ` Rafael J. Wysocki
[not found] ` <201009112106.07687.rjw@sisk.pl>
2010-09-11 22:27 ` [PATCH] PM / Hibernate: Make default image size depend on total RAM size (was: Re: PATCH: PM / Hibernate: Avoid hitting OOM ...) Rafael J. Wysocki
[not found] ` <201009120027.06470.rjw@sisk.pl>
2010-09-13 15:40 ` [PATCH] PM / Hibernate: Make default image size depend on totalRAM size M. Vefa Bicakci
[not found] ` <4C8E45EB.8030408@superonline.com>
2010-09-13 17:52 ` Rafael J. Wysocki
2010-09-06 18:46 ` [Bisected Regression in 2.6.35] A full tmpfs filesystem causeshibernation to hang Rafael J. Wysocki
[not found] ` <201009062046.43513.rjw@sisk.pl>
2010-09-06 19:54 ` Rafael J. Wysocki
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=201009022224.59313.rjw@sisk.pl \
--to=rjw@sisk.pl \
--cc=bicave@superonline.com \
--cc=kosaki.motohiro@jp.fujitsu.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pm@lists.linux-foundation.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