[PATCH] error path in setup_arg_pages() misses vm_unacct_memory()
authorHugh Dickins <hugh@veritas.com>
Wed, 14 Sep 2005 05:13:02 +0000 (06:13 +0100)
committerLinus Torvalds <torvalds@g5.osdl.org>
Wed, 14 Sep 2005 18:18:13 +0000 (11:18 -0700)
commit2fd4ef85e0db9ed75c98e13953257a967ea55e03
tree119dfe9f88a832f3db6ff66e631112626f268f18
parentfb085cf1d4294824571815d487daccc0609543f0
[PATCH] error path in setup_arg_pages() misses vm_unacct_memory()

Pavel Emelianov and Kirill Korotaev observe that fs and arch users of
security_vm_enough_memory tend to forget to vm_unacct_memory when a
failure occurs further down (typically in setup_arg_pages variants).

These are all users of insert_vm_struct, and that reservation will only
be unaccounted on exit if the vma is marked VM_ACCOUNT: which in some
cases it is (hidden inside VM_STACK_FLAGS) and in some cases it isn't.

So x86_64 32-bit and ppc64 vDSO ELFs have been leaking memory into
Committed_AS each time they're run.  But don't add VM_ACCOUNT to them,
it's inappropriate to reserve against the very unlikely case that gdb
be used to COW a vDSO page - we ought to do something about that in
do_wp_page, but there are yet other inconsistencies to be resolved.

The safe and economical way to fix this is to let insert_vm_struct do
the security_vm_enough_memory check when it finds VM_ACCOUNT is set.

And the MIPS irix_brk has been calling security_vm_enough_memory before
calling do_brk which repeats it, doubly accounting and so also leaking.
Remove that, and all the fs and arch calls to security_vm_enough_memory:
give it a less misleading name later on.

Signed-off-by: Hugh Dickins <hugh@veritas.com>
Signed-Off-By: Kirill Korotaev <dev@sw.ru>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
arch/ia64/ia32/binfmt_elf32.c
arch/mips/kernel/sysirix.c
arch/ppc64/kernel/vdso.c
arch/x86_64/ia32/ia32_binfmt.c
arch/x86_64/ia32/syscall32.c
fs/exec.c
mm/mmap.c