vdso: Improve cmd_vdso_check to check all dynamic relocations
The actual intention is that no dynamic relocation exists in the VDSO. For this the VDSO build validates that the resulting .so file does not have any relocations which are specified via $(ARCH_REL_TYPE_ABS) per architecture, which is fragile as e.g. ARM64 lacks an entry for R_AARCH64_RELATIVE. Aside of that ARCH_REL_TYPE_ABS is a misnomer as it checks for relative relocations too. However, some GNU ld ports produce unneeded R_*_NONE relocation entries. If a port fails to determine the exact .rel[a].dyn size, the trailing zeros become R_*_NONE relocations. E.g. ld's powerpc port recently fixed https://sourceware.org/bugzilla/show_bug.cgi?id=29540). R_*_NONE are generally a no-op in the dynamic loaders. So just ignore them. Remove the ARCH_REL_TYPE_ABS defines and just validate that the resulting .so file does not contain any R_* relocation entries except R_*_NONE. Signed-off-by: Fangrui Song <maskray@google.com> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Tested-by: Vincenzo Frascino <vincenzo.frascino@arm.com> # for aarch64 Reviewed-by: Christophe Leroy <christophe.leroy@csgroup.eu> Reviewed-by: Vincenzo Frascino <vincenzo.frascino@arm.com> # for vDSO, aarch64 Acked-by: Michael Ellerman <mpe@ellerman.id.au> (powerpc) Link: https://lore.kernel.org/r/20230310190750.3323802-1-maskray@google.com
This commit is contained in:
parent
e8d018dd02
commit
aff69273af
@ -1,8 +1,6 @@
|
|||||||
# SPDX-License-Identifier: GPL-2.0
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
# Absolute relocation type $(ARCH_REL_TYPE_ABS) needs to be defined before
|
# Include the generic Makefile to check the built vdso.
|
||||||
# the inclusion of generic Makefile.
|
|
||||||
ARCH_REL_TYPE_ABS := R_ARM_JUMP_SLOT|R_ARM_GLOB_DAT|R_ARM_ABS32
|
|
||||||
include $(srctree)/lib/vdso/Makefile
|
include $(srctree)/lib/vdso/Makefile
|
||||||
|
|
||||||
hostprogs := vdsomunge
|
hostprogs := vdsomunge
|
||||||
|
@ -6,9 +6,7 @@
|
|||||||
# Heavily based on the vDSO Makefiles for other archs.
|
# Heavily based on the vDSO Makefiles for other archs.
|
||||||
#
|
#
|
||||||
|
|
||||||
# Absolute relocation type $(ARCH_REL_TYPE_ABS) needs to be defined before
|
# Include the generic Makefile to check the built vdso.
|
||||||
# the inclusion of generic Makefile.
|
|
||||||
ARCH_REL_TYPE_ABS := R_AARCH64_JUMP_SLOT|R_AARCH64_GLOB_DAT|R_AARCH64_ABS64
|
|
||||||
include $(srctree)/lib/vdso/Makefile
|
include $(srctree)/lib/vdso/Makefile
|
||||||
|
|
||||||
obj-vdso := vgettimeofday.o note.o sigreturn.o
|
obj-vdso := vgettimeofday.o note.o sigreturn.o
|
||||||
|
@ -3,9 +3,6 @@
|
|||||||
# Makefile for vdso32
|
# Makefile for vdso32
|
||||||
#
|
#
|
||||||
|
|
||||||
# Absolute relocation type $(ARCH_REL_TYPE_ABS) needs to be defined before
|
|
||||||
# the inclusion of generic Makefile.
|
|
||||||
ARCH_REL_TYPE_ABS := R_ARM_JUMP_SLOT|R_ARM_GLOB_DAT|R_ARM_ABS32
|
|
||||||
include $(srctree)/lib/vdso/Makefile
|
include $(srctree)/lib/vdso/Makefile
|
||||||
|
|
||||||
# Same as cc-*option, but using CC_COMPAT instead of CC
|
# Same as cc-*option, but using CC_COMPAT instead of CC
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
# SPDX-License-Identifier: GPL-2.0-only
|
# SPDX-License-Identifier: GPL-2.0-only
|
||||||
|
|
||||||
# Absolute relocation type $(ARCH_REL_TYPE_ABS) needs to be defined before
|
# Include the generic Makefile to check the built vdso.
|
||||||
# the inclusion of generic Makefile.
|
|
||||||
ARCH_REL_TYPE_ABS := R_CKCORE_ADDR32|R_CKCORE_JUMP_SLOT
|
|
||||||
include $(srctree)/lib/vdso/Makefile
|
include $(srctree)/lib/vdso/Makefile
|
||||||
|
|
||||||
# Symbols present in the vdso
|
# Symbols present in the vdso
|
||||||
|
@ -1,9 +1,7 @@
|
|||||||
# SPDX-License-Identifier: GPL-2.0
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
# Objects to go into the VDSO.
|
# Objects to go into the VDSO.
|
||||||
|
|
||||||
# Absolute relocation type $(ARCH_REL_TYPE_ABS) needs to be defined before
|
# Include the generic Makefile to check the built vdso.
|
||||||
# the inclusion of generic Makefile.
|
|
||||||
ARCH_REL_TYPE_ABS := R_LARCH_32|R_LARCH_64|R_LARCH_MARK_LA|R_LARCH_JUMP_SLOT
|
|
||||||
include $(srctree)/lib/vdso/Makefile
|
include $(srctree)/lib/vdso/Makefile
|
||||||
|
|
||||||
obj-vdso-y := elf.o vgetcpu.o vgettimeofday.o sigreturn.o
|
obj-vdso-y := elf.o vgetcpu.o vgettimeofday.o sigreturn.o
|
||||||
|
@ -4,9 +4,7 @@
|
|||||||
# Sanitizer runtimes are unavailable and cannot be linked here.
|
# Sanitizer runtimes are unavailable and cannot be linked here.
|
||||||
KCSAN_SANITIZE := n
|
KCSAN_SANITIZE := n
|
||||||
|
|
||||||
# Absolute relocation type $(ARCH_REL_TYPE_ABS) needs to be defined before
|
# Include the generic Makefile to check the built vdso.
|
||||||
# the inclusion of generic Makefile.
|
|
||||||
ARCH_REL_TYPE_ABS := R_MIPS_JUMP_SLOT|R_MIPS_GLOB_DAT
|
|
||||||
include $(srctree)/lib/vdso/Makefile
|
include $(srctree)/lib/vdso/Makefile
|
||||||
|
|
||||||
obj-vdso-y := elf.o vgettimeofday.o sigreturn.o
|
obj-vdso-y := elf.o vgettimeofday.o sigreturn.o
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
# List of files in the vdso, has to be asm only for now
|
# List of files in the vdso, has to be asm only for now
|
||||||
|
|
||||||
ARCH_REL_TYPE_ABS := R_PPC_JUMP_SLOT|R_PPC_GLOB_DAT|R_PPC_ADDR32|R_PPC_ADDR24|R_PPC_ADDR16|R_PPC_ADDR16_LO|R_PPC_ADDR16_HI|R_PPC_ADDR16_HA|R_PPC_ADDR14|R_PPC_ADDR14_BRTAKEN|R_PPC_ADDR14_BRNTAKEN|R_PPC_REL24
|
# Include the generic Makefile to check the built vdso.
|
||||||
include $(srctree)/lib/vdso/Makefile
|
include $(srctree)/lib/vdso/Makefile
|
||||||
|
|
||||||
obj-vdso32 = sigtramp32-32.o gettimeofday-32.o datapage-32.o cacheflush-32.o note-32.o getcpu-32.o
|
obj-vdso32 = sigtramp32-32.o gettimeofday-32.o datapage-32.o cacheflush-32.o note-32.o getcpu-32.o
|
||||||
|
@ -1,9 +1,7 @@
|
|||||||
# SPDX-License-Identifier: GPL-2.0-only
|
# SPDX-License-Identifier: GPL-2.0-only
|
||||||
# Copied from arch/tile/kernel/vdso/Makefile
|
# Copied from arch/tile/kernel/vdso/Makefile
|
||||||
|
|
||||||
# Absolute relocation type $(ARCH_REL_TYPE_ABS) needs to be defined before
|
# Include the generic Makefile to check the built vdso.
|
||||||
# the inclusion of generic Makefile.
|
|
||||||
ARCH_REL_TYPE_ABS := R_RISCV_32|R_RISCV_64|R_RISCV_JUMP_SLOT
|
|
||||||
include $(srctree)/lib/vdso/Makefile
|
include $(srctree)/lib/vdso/Makefile
|
||||||
# Symbols present in the vdso
|
# Symbols present in the vdso
|
||||||
vdso-syms = rt_sigreturn
|
vdso-syms = rt_sigreturn
|
||||||
|
@ -2,9 +2,8 @@
|
|||||||
# List of files in the vdso
|
# List of files in the vdso
|
||||||
|
|
||||||
KCOV_INSTRUMENT := n
|
KCOV_INSTRUMENT := n
|
||||||
ARCH_REL_TYPE_ABS := R_390_COPY|R_390_GLOB_DAT|R_390_JMP_SLOT|R_390_RELATIVE
|
|
||||||
ARCH_REL_TYPE_ABS += R_390_GOT|R_390_PLT
|
|
||||||
|
|
||||||
|
# Include the generic Makefile to check the built vdso.
|
||||||
include $(srctree)/lib/vdso/Makefile
|
include $(srctree)/lib/vdso/Makefile
|
||||||
obj-vdso32 = vdso_user_wrapper-32.o note-32.o
|
obj-vdso32 = vdso_user_wrapper-32.o note-32.o
|
||||||
|
|
||||||
|
@ -2,9 +2,8 @@
|
|||||||
# List of files in the vdso
|
# List of files in the vdso
|
||||||
|
|
||||||
KCOV_INSTRUMENT := n
|
KCOV_INSTRUMENT := n
|
||||||
ARCH_REL_TYPE_ABS := R_390_COPY|R_390_GLOB_DAT|R_390_JMP_SLOT|R_390_RELATIVE
|
|
||||||
ARCH_REL_TYPE_ABS += R_390_GOT|R_390_PLT
|
|
||||||
|
|
||||||
|
# Include the generic Makefile to check the built vdso.
|
||||||
include $(srctree)/lib/vdso/Makefile
|
include $(srctree)/lib/vdso/Makefile
|
||||||
obj-vdso64 = vdso_user_wrapper.o note.o
|
obj-vdso64 = vdso_user_wrapper.o note.o
|
||||||
obj-cvdso64 = vdso64_generic.o getcpu.o
|
obj-cvdso64 = vdso64_generic.o getcpu.o
|
||||||
|
@ -3,10 +3,7 @@
|
|||||||
# Building vDSO images for x86.
|
# Building vDSO images for x86.
|
||||||
#
|
#
|
||||||
|
|
||||||
# Absolute relocation type $(ARCH_REL_TYPE_ABS) needs to be defined before
|
# Include the generic Makefile to check the built vdso.
|
||||||
# the inclusion of generic Makefile.
|
|
||||||
ARCH_REL_TYPE_ABS := R_X86_64_JUMP_SLOT|R_X86_64_GLOB_DAT|R_X86_64_RELATIVE|
|
|
||||||
ARCH_REL_TYPE_ABS += R_386_GLOB_DAT|R_386_JMP_SLOT|R_386_RELATIVE
|
|
||||||
include $(srctree)/lib/vdso/Makefile
|
include $(srctree)/lib/vdso/Makefile
|
||||||
|
|
||||||
# Sanitizer runtimes are unavailable and cannot be linked here.
|
# Sanitizer runtimes are unavailable and cannot be linked here.
|
||||||
|
@ -5,18 +5,13 @@ GENERIC_VDSO_DIR := $(dir $(GENERIC_VDSO_MK_PATH))
|
|||||||
|
|
||||||
c-gettimeofday-$(CONFIG_GENERIC_GETTIMEOFDAY) := $(addprefix $(GENERIC_VDSO_DIR), gettimeofday.c)
|
c-gettimeofday-$(CONFIG_GENERIC_GETTIMEOFDAY) := $(addprefix $(GENERIC_VDSO_DIR), gettimeofday.c)
|
||||||
|
|
||||||
# This cmd checks that the vdso library does not contain absolute relocation
|
# This cmd checks that the vdso library does not contain dynamic relocations.
|
||||||
# It has to be called after the linking of the vdso library and requires it
|
# It has to be called after the linking of the vdso library and requires it
|
||||||
# as a parameter.
|
# as a parameter.
|
||||||
#
|
#
|
||||||
# $(ARCH_REL_TYPE_ABS) is defined in the arch specific makefile and corresponds
|
# As a workaround for some GNU ld ports which produce unneeded R_*_NONE
|
||||||
# to the absolute relocation types printed by "objdump -R" and accepted by the
|
# dynamic relocations, ignore R_*_NONE.
|
||||||
# dynamic linker.
|
|
||||||
ifndef ARCH_REL_TYPE_ABS
|
|
||||||
$(error ARCH_REL_TYPE_ABS is not set)
|
|
||||||
endif
|
|
||||||
|
|
||||||
quiet_cmd_vdso_check = VDSOCHK $@
|
quiet_cmd_vdso_check = VDSOCHK $@
|
||||||
cmd_vdso_check = if $(OBJDUMP) -R $@ | grep -E -h "$(ARCH_REL_TYPE_ABS)"; \
|
cmd_vdso_check = if $(READELF) -rW $@ | grep -v _NONE | grep -q " R_\w*_"; \
|
||||||
then (echo >&2 "$@: dynamic relocations are not supported"; \
|
then (echo >&2 "$@: dynamic relocations are not supported"; \
|
||||||
rm -f $@; /bin/false); fi
|
rm -f $@; /bin/false); fi
|
||||||
|
Loading…
Reference in New Issue
Block a user