um: Fix overlapping ELF segments when statically linked
authorDavid Gow <davidgow@google.com>
Thu, 5 Mar 2020 18:39:39 +0000 (10:39 -0800)
committerRichard Weinberger <richard@nod.at>
Sun, 29 Mar 2020 21:21:29 +0000 (23:21 +0200)
commit598f5630361397c542a0ba2bec0ac5c0e1723d5c
tree3ded48a12c36cb047ff59d8f21ea27e6532aca53
parent73343392aae8bdd939ca58e855889d1b015b0ef4
um: Fix overlapping ELF segments when statically linked

When statically linked, the .text section in UML kernels is not page
aligned, causing it to share a page with the executable headers. As
.text and the executable headers have different permissions, this causes
the kernel to wish to map the same page twice (once as headers with r--
permissions, once as .text with r-x permissions), causing a segfault,
and a nasty message printed to the host kernel's dmesg:

"Uhuuh, elf segment at 0000000060000000 requested but the memory is
mapped already"

By aligning the .text to a page boundary (as in the dynamically linked
version in dyn.lds.S), there is no such overlap, and the kernel runs
correctly.

Signed-off-by: David Gow <davidgow@google.com>
Reviewed-by: Brendan Higgins <brendanhiggins@google.com>
Signed-off-by: Richard Weinberger <richard@nod.at>
arch/um/kernel/uml.lds.S