On Fri, Feb 6, 2015 at 1:13 PM, Konstantin Khlebnikov <koct9i@xxxxxxxxx> wrote: > > Currently that works fine only because kernel retries 0-order allocations > endlessly. But pagefault_out_of_memory() is never called for non-user PF. > For kernel PF all oom-kills are triggered by buddy-allocator. This makes no sense. You're trying to fix what you perceive as a problem in the page fault handling in some totally different place. If *that* is what you are worried about, then damnit, just fix the page fault handler for the kernel case to send a signal or something for VM_FAULT_ENOMEM. Or, better yet, make it just trigger oom at return to user space - we could add a _TIF_OOM flag, for example, and make it part of the user-return logic (do_notify_resume), kind of how _TIF_SIGPENDING triggers a signal. Don't try to make horrible code in insane places that have nothing to do with the fundamental problem. Why did you pick this particular get/put user anyway? There are tons others that we don't test, why did you happen pick these and then make it have that horrible and senseless error handling? Because at *NO* point was it obvious that that patch had anything at all to do with "out of memory". Not in the code, not in your commit messages, *nowhere*. There is no way in hell I will take that kind of changes when you didn't even articulate why you wanted to do them in the commit messages, and the patches didn't look like they had anything to do with oom either. Linus -- To unsubscribe from this list: send the line "unsubscribe linux-api" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html