Hi Stephen, On Fri, Jul 15, 2011 at 09:58 -0400, Stephen Smalley wrote: > Does this have implications for Android's zygote model? There you have > a long running uid 0 / all caps process (the zygote), which forks itself > upon receiving a request to spawn an app and then calls > setgroups(); > setrlimit(); setgid(); setuid(); Is RLIMIT_NPROC forced in your model and setuid() is expected to fail because of NPROC exceeding? If no, then it is not touched at all. > Also, can't setuid() fail under other conditions, e.g. ENOMEM upon > prepare_creds() allocation failure? Is it ever reasonable for a program > to not check setuid() for failure? Certainly there are plenty of > examples of programs not doing that, but it isn't clear that this is a > bug in the kernel. This thing is better to discuss separately, after the patch is applied. Shorter, in current implementation it is not possible as mm layer tries to alloc small structures (less than 8 pages) indefinitely. cred and user_struct are less than 64kb, so ENOMEM is impossible. Thanks, -- Vasiliy Kulikov http://www.openwall.com - bringing security into open computing environments -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html