public inbox for linux-pm@vger.kernel.org
 help / color / mirror / Atom feed
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

  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