mirror of
https://github.com/torvalds/linux.git
synced 2026-06-14 10:03:05 +02:00
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> |
||
|---|---|---|
| .. | ||
| asm-offsets.c | ||
| binfmt_elfn32.c | ||
| binfmt_elfo32.c | ||
| branch.c | ||
| cpu-bugs64.c | ||
| cpu-probe.c | ||
| entry.S | ||
| gdb-low.S | ||
| gdb-stub.c | ||
| genex.S | ||
| genrtc.c | ||
| head.S | ||
| i8259.c | ||
| init_task.c | ||
| ioctl32.c | ||
| irix5sys.S | ||
| irixelf.c | ||
| irixinv.c | ||
| irixioctl.c | ||
| irixsig.c | ||
| irq_cpu.c | ||
| irq-msc01.c | ||
| irq-mv6434x.c | ||
| irq-rm7000.c | ||
| irq-rm9000.c | ||
| irq.c | ||
| linux32.c | ||
| Makefile | ||
| mips_ksyms.c | ||
| module-elf32.c | ||
| module-elf64.c | ||
| module.c | ||
| proc.c | ||
| process.c | ||
| ptrace.c | ||
| ptrace32.c | ||
| r4k_fpu.S | ||
| r4k_switch.S | ||
| r2300_fpu.S | ||
| r2300_switch.S | ||
| r6000_fpu.S | ||
| reset.c | ||
| scall32-o32.S | ||
| scall64-64.S | ||
| scall64-n32.S | ||
| scall64-o32.S | ||
| semaphore.c | ||
| setup.c | ||
| signal_n32.c | ||
| signal-common.h | ||
| signal.c | ||
| signal32.c | ||
| smp.c | ||
| syscall.c | ||
| sysirix.c | ||
| time.c | ||
| traps.c | ||
| unaligned.c | ||
| vmlinux.lds.S | ||