x86/vdso: Plug race between mapping and ELF header setup
authorThomas Gleixner <tglx@linutronix.de>
Mon, 10 Apr 2017 15:14:28 +0000 (17:14 +0200)
committerJiri Slaby <jslaby@suse.cz>
Fri, 28 Apr 2017 17:30:42 +0000 (19:30 +0200)
commit3ebb1b606820857986b4310e5012f78352478774
treec9a8a977fb4514a3d6bdaf5c14c1c1185a91e32f
parent7ac6fcfad1212f888d425ba8ac83a7826d6f5a43
x86/vdso: Plug race between mapping and ELF header setup

commit 6fdc6dd90272ce7e75d744f71535cfbd8d77da81 upstream.

The vsyscall32 sysctl can racy against a concurrent fork when it switches
from disabled to enabled:

    arch_setup_additional_pages()
if (vdso32_enabled)
           --> No mapping
                                        sysctl.vsysscall32()
                                          --> vdso32_enabled = true
    create_elf_tables()
      ARCH_DLINFO_IA32
        if (vdso32_enabled) {
           --> Add VDSO entry with NULL pointer

Make ARCH_DLINFO_IA32 check whether the VDSO mapping has been set up for
the newly forked process or not.

Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Acked-by: Andy Lutomirski <luto@amacapital.net>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Mathias Krause <minipli@googlemail.com>
Link: http://lkml.kernel.org/r/20170410151723.602367196@linutronix.de
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Jiri Slaby <jslaby@suse.cz>
arch/x86/include/asm/elf.h