On Fri, 30 Mar 2018 19:18:57 -0700 Matthew Wilcox <willy@xxxxxxxxxxxxx> wrote: > Again though, this is the same pattern as vmalloc. There are any number > of places where userspace can cause an arbitrarily large vmalloc to be > attempted (grep for kvmalloc_array for a list of promising candidates). > I'm pretty sure that just changing your GFP flags to GFP_KERNEL | > __GFP_NOWARN will give you the exact behaviour that you want with no > need to grub around in the VM to find out if your huge allocation is > likely to succeed. Not sure how this helps. Note, I don't care about consecutive pages, so this is not an array. It's a link list of thousands of pages. How do you suggest allocating them? The ring buffer is a link list of pages. What I currently do is to see how many more pages I need. Allocate them one at a time and put them in a temporary list, if it succeeds I add them to the ring buffer, if not, I free the entire list (it's an all or nothing operation). The allocation I'm making doesn't warn. The problem is the GFP_RETRY_MAYFAIL, which will try to allocate any possible memory in the system. When it succeeds, the ring buffer allocation logic will then try to allocate another page. If we add too many pages, we will allocate all possible pages and then try to allocate more. This allocation will fail without causing an OOM. That's not the problem. The problem is if the system is active during this time, and something else tries to do any allocation, after all memory has been consumed, that allocation will fail. Then it will trigger an OOM. I showed this in my Call Trace, that the allocation that failed during my test was something completely unrelated, and that failure caused an OOM. What this last patch does is see if there's space available before it even starts the process. Maybe I'm missing something, but I don't see how NOWARN can help. My allocations are not what is giving the warning. -- Steve