x86/vdso: Ensure vdso32_enabled gets set to valid values only
authorMathias Krause <minipli@googlemail.com>
Mon, 10 Apr 2017 15:14:27 +0000 (17:14 +0200)
committerThomas Gleixner <tglx@linutronix.de>
Mon, 10 Apr 2017 16:31:41 +0000 (18:31 +0200)
commitc06989da39cdb10604d572c8c7ea8c8c97f3c483
tree832904412f9e1d1b57195624443a0d00c07decee
parentcfac6dfa42bddfa9711b20d486e521d1a41ab09f
x86/vdso: Ensure vdso32_enabled gets set to valid values only

vdso_enabled can be set to arbitrary integer values via the kernel command
line 'vdso32=' parameter or via 'sysctl abi.vsyscall32'.

load_vdso32() only maps VDSO if vdso_enabled == 1, but ARCH_DLINFO_IA32
merily checks for vdso_enabled != 0. As a consequence the AT_SYSINFO_EHDR
auxiliary vector for the VDSO_ENTRY is emitted with a NULL pointer which
causes a segfault when the application tries to use the VDSO.

Restrict the valid arguments on the command line and the sysctl to 0 and 1.

Fixes: b0b49f2673f0 ("x86, vdso: Remove compat vdso support")
Signed-off-by: Mathias Krause <minipli@googlemail.com>
Acked-by: Andy Lutomirski <luto@amacapital.net>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: stable@vger.kernel.org
Cc: Roland McGrath <roland@redhat.com>
Link: http://lkml.kernel.org/r/1491424561-7187-1-git-send-email-minipli@googlemail.com
Link: http://lkml.kernel.org/r/20170410151723.518412863@linutronix.de
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
arch/x86/entry/vdso/vdso32-setup.c