Re: [PATCH 1/3] PM: Disable OOM killer during system-wide power transitions
From: Rafael J. Wysocki
Date: Sat May 02 2009 - 07:35:45 EST
On Saturday 02 May 2009, Andrew Morton wrote:
> On Sat, 2 May 2009 00:27:30 +0200
> "Rafael J. Wysocki" <rjw@xxxxxxx> wrote:
>
> > From: Rafael J. Wysocki <rjw@xxxxxxx>
> >
> > The OOM killer is not particularly useful during system-wide power
> > transitions, so do not use it if such a transition is in progress.
> >
>
> so... I think what you've done here is to arrange for the page
> allocator to return NULL if we're hibernating rather than oom-killing,
> yes?
Yes.
> Does the same apply to suspending? If so, why?
Because I think it doesn't work anyway. User space processes are frozen and
effectively in TASK_UNINTERRUPTIBLE, so they won't be killed.
> I think this is an OK change, as long as the only thing which is
> allocating memory is hibernation itself. If random processes are still
> doing random memory allocations at this time then their failed memory
> allocation could be just as fatal as an oom-killing. Moreso if they're
> s/bin/init or whatever.
At this point all of the user space tasks are frozen.
> So is it the case that pm_transition_in_progress() is only true during
> the highly-constrained hibernation process? After everything is frozen?
Yes.
> If so, there are alternatives - the calling process could set
> PF_DONT_KILL_ANYONE_FOR_ME, or could pass __GFP_DONT_KILL_ANYONE_FOR_ME.
> Those might be worse alternatives, dunno - I'm just asking probing
> questions ;)
Well, the __GFP_DONT_KILL_ANYONE_FOR_ME would be easier to implement.
I don't really think that the freezing of processes plays very well with the
OOM killer, so disabling it altogether after the processes have been frozen
seems reasonable to me. Still, if you prefer to use
__GFP_DONT_KILL_ANYONE_FOR_ME, it's fine by me.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/