Re: [PATCH 1/3 for 2.6.38] oom: oom_kill_process: don't setTIF_MEMDIE if !p->mm
From: Oleg Nesterov
Date: Tue Mar 15 2011 - 15:21:52 EST
On 03/14, David Rientjes wrote:
>
> On Mon, 14 Mar 2011, Linus Torvalds wrote:
>
> > The combination of testing PF_EXITING and p->mm just doesn't seem to
> > make any sense.
> >
>
> Right, it doesn't (and I recently removed testing the combination from
> select_bad_process() in -mm). The check for PF_EXITING in the oom killer
> is purely to avoid needlessly killing tasks when something is already
> exiting
Maybe 0/3 wasn't clear enough. This patches does not try to fix things,
it only tries to close the hole in 2.6.38. But it was already released
today.
> and will (hopefully) be freeing its memory soon.
This is not clear to me.
When I did this change I looked at 81236810226f71bd9ff77321c8e8276dae7efc61
and the changelog says:
__oom_kill_task() is called to elevate the task's timeslice and give it
access to memory reserves so that it may quickly exit.
This privilege is unnecessary, however, if the task has already detached
its mm.
Now you are saing this is pointless.
OK. I already said I do not understand this special case. Perhaps I'll ask
the questions later.
> If an eligible
> thread is found to be PF_EXITING,
The problem is, we can't trust per-thread PF_EXITING checks. But I guess
we will discuss this more anyway.
Oleg.
--
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/