public inbox for linux-xfs@vger.kernel.org
 help / color / mirror / Atom feed
From: Michal Hocko <mhocko@suse.cz>
To: Tetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp>
Cc: dchinner@redhat.com, oleg@redhat.com, xfs@oss.sgi.com,
	hannes@cmpxchg.org, linux-mm@kvack.org, mgorman@suse.de,
	rientjes@google.com, linux-fsdevel@vger.kernel.org,
	akpm@linux-foundation.org, fernando_b1@lab.ntt.co.jp,
	torvalds@linux-foundation.org
Subject: Re: How to handle TIF_MEMDIE stalls?
Date: Fri, 20 Feb 2015 10:10:01 +0100	[thread overview]
Message-ID: <20150220091001.GC21248@dhcp22.suse.cz> (raw)
In-Reply-To: <201502192229.FCJ73987.MFQLOHSJFFtOOV@I-love.SAKURA.ne.jp>

On Thu 19-02-15 22:29:37, Tetsuo Handa wrote:
> Michal Hocko wrote:
> > On Thu 19-02-15 06:01:24, Johannes Weiner wrote:
> > [...]
> > > Preferrably, we'd get rid of all nofail allocations and replace them
> > > with preallocated reserves.  But this is not going to happen anytime
> > > soon, so what other option do we have than resolving this on the OOM
> > > killer side?
> > 
> > As I've mentioned in other email, we might give GFP_NOFAIL allocator
> > access to memory reserves (by giving it __GFP_HIGH). This is still not a
> > 100% solution because reserves could get depleted but this risk is there
> > even with multiple oom victims. I would still argue that this would be a
> > better approach because selecting more victims might hit pathological
> > case more easily (other victims might be blocked on the very same lock
> > e.g.).
> > 
> Does "multiple OOM victims" mean "select next if first does not die"?
> Then, I think my timeout patch http://marc.info/?l=linux-mm&m=142002495532320&w=2
> does not deplete memory reserves. ;-)

It doesn't because
--- a/mm/page_alloc.c
+++ b/mm/page_alloc.c
@@ -2603,9 +2603,7 @@ gfp_to_alloc_flags(gfp_t gfp_mask)
 			alloc_flags |= ALLOC_NO_WATERMARKS;
 		else if (in_serving_softirq() && (current->flags & PF_MEMALLOC))
 			alloc_flags |= ALLOC_NO_WATERMARKS;
-		else if (!in_interrupt() &&
-				((current->flags & PF_MEMALLOC) ||
-				 unlikely(test_thread_flag(TIF_MEMDIE))))
+		else if (!in_interrupt() && (current->flags & PF_MEMALLOC))
 			alloc_flags |= ALLOC_NO_WATERMARKS;

you disabled the TIF_MEMDIE heuristic and use it only for OOM exclusion
and break out from the allocator. Exiting task might need a memory to do
so and you make all those allocations fail basically. How do you know
this is not going to blow up?

> If we change to permit invocation of the OOM killer for GFP_NOFS / GFP_NOIO,
> those who do not want to fail (e.g. journal transaction) will start passing
> __GFP_NOFAIL?
> 
> --
> To unsubscribe, send a message with 'unsubscribe linux-mm' in
> the body to majordomo@kvack.org.  For more info on Linux MM,
> see: http://www.linux-mm.org/ .
> Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a>

-- 
Michal Hocko
SUSE Labs

_______________________________________________
xfs mailing list
xfs@oss.sgi.com
http://oss.sgi.com/mailman/listinfo/xfs

  reply	other threads:[~2015-02-20  9:10 UTC|newest]

Thread overview: 83+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <20141230112158.GA15546@dhcp22.suse.cz>
     [not found] ` <201502092044.JDG39081.LVFOOtFHQFOMSJ@I-love.SAKURA.ne.jp>
     [not found]   ` <201502102258.IFE09888.OVQFJOMSFtOLFH@I-love.SAKURA.ne.jp>
     [not found]     ` <20150210151934.GA11212@phnom.home.cmpxchg.org>
     [not found]       ` <201502111123.ICD65197.FMLOHSQJFVOtFO@I-love.SAKURA.ne.jp>
     [not found]         ` <201502172123.JIE35470.QOLMVOFJSHOFFt@I-love.SAKURA.ne.jp>
     [not found]           ` <20150217125315.GA14287@phnom.home.cmpxchg.org>
2015-02-17 22:54             ` How to handle TIF_MEMDIE stalls? Dave Chinner
2015-02-17 23:32               ` Dave Chinner
2015-02-18  8:25               ` Michal Hocko
2015-02-18 10:48                 ` Dave Chinner
2015-02-18 12:16                   ` Michal Hocko
2015-02-18 21:31                     ` Dave Chinner
2015-02-19  9:40                       ` Michal Hocko
2015-02-19 22:03                         ` Dave Chinner
2015-02-20  9:27                           ` Michal Hocko
2015-02-19 11:01                     ` Johannes Weiner
2015-02-19 12:29                       ` Michal Hocko
2015-02-19 12:58                         ` Michal Hocko
2015-02-19 15:29                           ` Tetsuo Handa
2015-02-19 21:53                             ` Tetsuo Handa
2015-02-20  9:13                             ` Michal Hocko
2015-02-20 13:37                               ` Stefan Ring
2015-02-19 13:29                         ` Tetsuo Handa
2015-02-20  9:10                           ` Michal Hocko [this message]
2015-02-20 12:20                             ` Tetsuo Handa
2015-02-20 12:38                               ` Michal Hocko
2015-02-19 21:43                         ` Dave Chinner
2015-02-20 12:48                           ` Michal Hocko
2015-02-20 23:09                             ` Dave Chinner
2015-02-19 10:24               ` Johannes Weiner
2015-02-19 22:52                 ` Dave Chinner
2015-02-20 10:36                   ` Tetsuo Handa
2015-02-20 23:15                     ` Dave Chinner
2015-02-21  3:20                       ` Theodore Ts'o
2015-02-21  9:19                         ` Andrew Morton
2015-02-21 13:48                           ` Tetsuo Handa
2015-02-21 21:38                           ` Dave Chinner
2015-02-22  0:20                           ` Johannes Weiner
2015-02-23 10:48                             ` Michal Hocko
2015-02-23 11:23                               ` Tetsuo Handa
2015-02-23 21:33                             ` David Rientjes
2015-02-21 12:00                         ` Tetsuo Handa
2015-02-23 10:26                         ` Michal Hocko
2015-02-21 11:12                       ` Tetsuo Handa
2015-02-21 21:48                         ` Dave Chinner
2015-02-21 23:52                   ` Johannes Weiner
2015-02-23  0:45                     ` Dave Chinner
2015-02-23  1:29                       ` Andrew Morton
2015-02-23  7:32                         ` Dave Chinner
2015-02-27 18:24                           ` Vlastimil Babka
2015-02-28  0:03                             ` Dave Chinner
2015-02-28 15:17                               ` Theodore Ts'o
2015-03-02  9:39                           ` Vlastimil Babka
2015-03-02 22:31                             ` Dave Chinner
2015-03-03  9:13                               ` Vlastimil Babka
2015-03-04  1:33                                 ` Dave Chinner
2015-03-04  8:50                                   ` Vlastimil Babka
2015-03-04 11:03                                     ` Dave Chinner
2015-03-07  0:20                               ` Johannes Weiner
2015-03-07  3:43                                 ` Dave Chinner
2015-03-07 15:08                                   ` Johannes Weiner
2015-03-02 20:22                           ` Johannes Weiner
2015-03-02 23:12                             ` Dave Chinner
2015-03-03  2:50                               ` Johannes Weiner
2015-03-04  6:52                                 ` Dave Chinner
2015-03-04 15:04                                   ` Johannes Weiner
2015-03-04 17:38                                     ` Theodore Ts'o
2015-03-04 23:17                                       ` Dave Chinner
2015-02-28 16:29                       ` Johannes Weiner
2015-02-28 16:41                         ` Theodore Ts'o
2015-02-28 22:15                           ` Johannes Weiner
2015-03-01 11:17                             ` Tetsuo Handa
2015-03-06 11:53                               ` Tetsuo Handa
2015-03-01 13:43                             ` Theodore Ts'o
2015-03-01 16:15                               ` Johannes Weiner
2015-03-01 19:36                                 ` Theodore Ts'o
2015-03-01 20:44                                   ` Johannes Weiner
2015-03-01 20:17                               ` Johannes Weiner
2015-03-01 21:48                             ` Dave Chinner
2015-03-02  0:17                               ` Dave Chinner
2015-03-02 12:46                                 ` Brian Foster
2015-02-28 18:36                       ` Vlastimil Babka
2015-03-02 15:18                       ` Michal Hocko
2015-03-02 16:05                         ` Johannes Weiner
2015-03-02 17:10                           ` Michal Hocko
2015-03-02 17:27                             ` Johannes Weiner
2015-03-02 16:39                         ` Theodore Ts'o
2015-03-02 16:58                           ` Michal Hocko
2015-03-04 12:52                             ` Dave Chinner

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=20150220091001.GC21248@dhcp22.suse.cz \
    --to=mhocko@suse.cz \
    --cc=akpm@linux-foundation.org \
    --cc=dchinner@redhat.com \
    --cc=fernando_b1@lab.ntt.co.jp \
    --cc=hannes@cmpxchg.org \
    --cc=linux-fsdevel@vger.kernel.org \
    --cc=linux-mm@kvack.org \
    --cc=mgorman@suse.de \
    --cc=oleg@redhat.com \
    --cc=penguin-kernel@I-love.SAKURA.ne.jp \
    --cc=rientjes@google.com \
    --cc=torvalds@linux-foundation.org \
    --cc=xfs@oss.sgi.com \
    /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