On Tue 05-01-16 17:22:46, Michal Hocko wrote: > On Wed 30-12-15 15:33:47, Tetsuo Handa wrote: [...] > > I wish for a kernel thread that does OOM-kill operation. > > Maybe we can change the OOM reaper kernel thread to do it. > > What do you think? > > I do no think a separate kernel thread would help much if the > allocations have to keep looping in the allocator. oom_reaper is a > separate kernel thread only due to locking required for the exit_mmap > path. Let me clarify what I've meant here. What you actually want is to do select_bad_process and oom_kill_process (including oom_reap_vmas) in the kernel thread context, right? That should be doable because we do not depend on the allocation context there. That would certainly save 1 kernel thread for the sysrq+f part but it would make the regular case more complicated AFAICS. We would have to handle queuing of the oom requests because multiple oom killers might be active in different allocation domains (cpusets, memcgs) so I am not so sure this would be a great win in the end. But I haven't tried to do it so I might be wrong and it will turn up being much more easier than I expect. -- Michal Hocko SUSE Labs -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>