Commit 6f601709 authored by Jeff Dike's avatar Jeff Dike Committed by Greg Kroah-Hartman

UML - host VDSO fix

This fixes a problem seen by a number of people running UML on newer host
kernels.  init would hang with an infinite segfault loop.

It turns out that the host kernel was providing a AT_SYSINFO_EHDR of
0xffffe000, which faked UML into believing that the host VDSO page could be
reused.  However, AT_SYSINFO pointed into the middle of the address space, and
was unmapped as a result.  Because UML was providing AT_SYSINFO_EHDR and
AT_SYSINFO to its own processes, these would branch to nowhere when trying to
use the VDSO.

The fix is to also check the location of AT_SYSINFO when deciding whether to
use the host's VDSO.
Signed-off-by: default avatarJeff Dike <jdike@linux.intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent edfcf73f
...@@ -40,6 +40,9 @@ __init void scan_elf_aux( char **envp) ...@@ -40,6 +40,9 @@ __init void scan_elf_aux( char **envp)
switch ( auxv->a_type ) { switch ( auxv->a_type ) {
case AT_SYSINFO: case AT_SYSINFO:
__kernel_vsyscall = auxv->a_un.a_val; __kernel_vsyscall = auxv->a_un.a_val;
/* See if the page is under TASK_SIZE */
if (__kernel_vsyscall < (unsigned long) envp)
__kernel_vsyscall = 0;
break; break;
case AT_SYSINFO_EHDR: case AT_SYSINFO_EHDR:
vsyscall_ehdr = auxv->a_un.a_val; vsyscall_ehdr = auxv->a_un.a_val;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment