]> git.baikalelectronics.ru Git - kernel.git/commit
RISC-V: Fix the VDSO symbol generaton for binutils-2.35+
authorPalmer Dabbelt <palmerdabbelt@google.com>
Sat, 24 Oct 2020 04:50:47 +0000 (21:50 -0700)
committerPalmer Dabbelt <palmerdabbelt@google.com>
Fri, 6 Nov 2020 08:03:48 +0000 (00:03 -0800)
commit78ebd5208ff095c03eb7bdfcd5e729644371e412
tree5251b4b631c953597711d4bcd04147a255621c1f
parent5715109da8eb4a91402d7447de4e5aa415005fd5
RISC-V: Fix the VDSO symbol generaton for binutils-2.35+

We were relying on GNU ld's ability to re-link executable files in order
to extract our VDSO symbols.  This behavior was deemed a bug as of
binutils-2.35 (specifically the binutils-gdb commit a87e1817a4 ("Have
the linker fail if any attempt to link in an executable is made."), but
as that has been backported to at least Debian's binutils-2.34 in may
manifest in other places.

The previous version of this was a bit of a mess: we were linking a
static executable version of the VDSO, containing only a subset of the
input symbols, which we then linked into the kernel.  This worked, but
certainly wasn't a supported path through the toolchain.  Instead this
new version parses the textual output of nm to produce a symbol table.
Both rely on near-zero addresses being linkable, but as we rely on weak
undefined symbols being linkable elsewhere I don't view this as a major
issue.

Fixes: 84df39b7f5b8 ("RISC-V: User-facing API")
Signed-off-by: Palmer Dabbelt <palmerdabbelt@google.com>
arch/riscv/kernel/vdso/.gitignore
arch/riscv/kernel/vdso/Makefile
arch/riscv/kernel/vdso/so2s.sh [new file with mode: 0755]