On 2018/07/06 11:49, Linus Torvalds wrote: > On Thu, Jul 5, 2018 at 7:40 PM Tetsuo Handa > <penguin-kernel@xxxxxxxxxxxxxxxxxxx> wrote: >> >>> >>> No, direct reclaim is a way to throttle allocations to the reclaim >>> speed. You would have to achive the same by other means. >> >> No. Direct reclaim is a way to lockup the system to unusable level, by not giving >> enough CPU resources to memory reclaim activities including the owner of oom_lock. > > No. Really. > > Direct reclaim really really does what Michal claims. Yes, it has > other effects too, and it can be problematic, but direct reclaim is > important. I'm saying that even an unprivileged user can make the reclaim speed to "0 pages per minute". [PATCH 1/8] is for reducing possibility of hitting "0 pages per minute" whereas [PATCH 8/8] is for increasing possibility of hitting "0 pages per minute". They are contradicting directions which should not be made in one patch. > > People have tried to remove it many times, but it's always been a > disaster. You need to synchronize with _something_ to make sure that > the thread that is causing a lot of allocations actually pays the > price, and slows down. [PATCH 3/8] is for reducing possibility of hitting "0 pages per minute" by making sure that allocating threads pay some price for reclaiming memory via doing direct OOM reaping. > > You want to have a balance between direct and indirect reclaim. While [PATCH 3/8] currently pays the full price, we can improve [PATCH 3/8] to pay only some price by changing direct OOM reaping to use some threshold. That is the direction towards the balance between "direct reclaim (by direct OOM reap by allocating threads)" and "indirect reclaim (by the OOM reaper kernel thread and exit_mmap())". > > If you think direct reclaim is only a way to lock up the system to > unusable levels, you should stop doing VM development. Locking up the system to unusable levels due to things outside of the page allocator is a different bug. The page allocator chokes themselves by lack of "direct reclaim" when we are waiting for the owner of oom_lock to make progress. This series is for getting rid of the lie /* * Acquire the oom lock. If that fails, somebody else is * making progress for us. */ if (!mutex_trylock(&oom_lock)) { *did_some_progress = 1; schedule_timeout_uninterruptible(1); return NULL; } caused by lack of "direct reclaim". > > Linus > On 2018/07/06 14:56, Michal Hocko wrote: >>> Yes, there is no need to reclaim all pages. OOM is after freeing _some_ >>> memory after all. But that means further complications down the unmap >>> path. I do not really see any reason for that. >> >> "I do not see reason for that" cannot become a reason direct OOM reaping has to >> reclaim all pages at once. > > We are not going to polute deep mm guts for unlikely events like oom. And since Michal is refusing to make changes for having the balance between "direct reclaim by threads waiting for oom_lock" and "indirect reclaim by a thread holding oom_lock", we will keep increasing possibility of hitting "0 pages per minute". Therefore, > If you are afraid of > regression and do not want to have your name on the patch then fine. I > will post the patch myself and also handle any fallouts. PLEASE PLEASE PLEASE DO SO IMMEDIATELY!!!