On Wed, 4 Apr 2018 16:10:52 +0200 Michal Hocko <mhocko@xxxxxxxxxx> wrote: > On Wed 04-04-18 08:59:01, Steven Rostedt wrote: > [...] > > + /* > > + * Check if the available memory is there first. > > + * Note, si_mem_available() only gives us a rough estimate of available > > + * memory. It may not be accurate. But we don't care, we just want > > + * to prevent doing any allocation when it is obvious that it is > > + * not going to succeed. > > + */ > > + i = si_mem_available(); > > + if (i < nr_pages) > > + return -ENOMEM; > > + > > > > Better? > > I must be really missing something here. How can that work at all for > e.g. the zone_{highmem/movable}. You will get false on the above tests > even when you will have hard time to allocate anything from your > destination zones. You mean we will get true on the above tests? Again, the current method is to just say screw it and try to allocate. I originally just used NORETRY which would only allocate memory that is currently available and not try to reclaim anything. But people like Joel at Google that required increasing the buffer when memory was mostly taken up by page cache changed it from NORETRY to RETRY_MAYFAIL. But this now causes the issue that a large allocation can take up all memory even when the allocation requested is guaranteed to fail, because there is not enough memory to pull this off. We just want a way to say "hey, is there enough memory in the system to allocate all these pages before we try? We don't need specifics, we just want to make sure we are not allocating way too much". The answer I want is "yes there may be enough (but you may not be able to use it)" or "no, there is definitely not enough for that". Currently si_mem_available() is the closest thing we have to answering that question. I'm fine if the answer is "Yes" even if I can't allocate that memory. I'm looking for something where "yes" means "there may be enough, but there may not be, buyer beware", and "no" means "forget it, don't even start, because you just asked for more than possible". -- Steve