Skip to content

Commit fd1fead

Browse files
chleroympe
authored andcommitted
powerpc/vdso: Merge vdso64 and vdso32 into a single directory
merge vdso64 into vdso32 and rename it vdso. Reported-by: kernel test robot <[email protected]> Signed-off-by: Christophe Leroy <[email protected]> Signed-off-by: Michael Ellerman <[email protected]> Link: https://lore.kernel.org/r/4dbe05cc130f6a0858d09ac72e436c373cb08b70.1642782130.git.christophe.leroy@csgroup.eu
1 parent d88378d commit fd1fead

26 files changed

+44
-321
lines changed

arch/powerpc/Makefile

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -421,9 +421,9 @@ ifeq ($(KBUILD_EXTMOD),)
421421
prepare: vdso_prepare
422422
vdso_prepare: prepare0
423423
$(if $(CONFIG_VDSO32),$(Q)$(MAKE) \
424-
$(build)=arch/powerpc/kernel/vdso32 include/generated/vdso32-offsets.h)
424+
$(build)=arch/powerpc/kernel/vdso include/generated/vdso32-offsets.h)
425425
$(if $(CONFIG_PPC64),$(Q)$(MAKE) \
426-
$(build)=arch/powerpc/kernel/vdso64 include/generated/vdso64-offsets.h)
426+
$(build)=arch/powerpc/kernel/vdso include/generated/vdso64-offsets.h)
427427
endif
428428

429429
archprepare: checkbin

arch/powerpc/kernel/Makefile

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -194,8 +194,8 @@ targets += prom_init_check
194194
clean-files := vmlinux.lds
195195

196196
# Force dependency (incbin is bad)
197-
$(obj)/vdso32_wrapper.o : $(obj)/vdso32/vdso32.so.dbg
198-
$(obj)/vdso64_wrapper.o : $(obj)/vdso64/vdso64.so.dbg
197+
$(obj)/vdso32_wrapper.o : $(obj)/vdso/vdso32.so.dbg
198+
$(obj)/vdso64_wrapper.o : $(obj)/vdso/vdso64.so.dbg
199199

200200
# for cleaning
201-
subdir- += vdso32 vdso64
201+
subdir- += vdso
Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,5 @@
11
# SPDX-License-Identifier: GPL-2.0-only
22
vdso32.lds
33
vdso32.so.dbg
4+
vdso64.lds
5+
vdso64.so.dbg

arch/powerpc/kernel/vdso32/Makefile renamed to arch/powerpc/kernel/vdso/Makefile

Lines changed: 35 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -6,6 +6,7 @@ ARCH_REL_TYPE_ABS := R_PPC_JUMP_SLOT|R_PPC_GLOB_DAT|R_PPC_ADDR32|R_PPC_ADDR24|R_
66
include $(srctree)/lib/vdso/Makefile
77

88
obj-vdso32 = sigtramp32-32.o gettimeofday-32.o datapage-32.o cacheflush-32.o note-32.o getcpu-32.o
9+
obj-vdso64 = sigtramp64-64.o gettimeofday-64.o datapage-64.o cacheflush-64.o note-64.o getcpu-64.o
910

1011
ifneq ($(c-gettimeofday-y),)
1112
CFLAGS_vgettimeofday-32.o += -include $(c-gettimeofday-y)
@@ -15,6 +16,17 @@ ifneq ($(c-gettimeofday-y),)
1516
CFLAGS_vgettimeofday-32.o += -ffreestanding -fasynchronous-unwind-tables
1617
CFLAGS_REMOVE_vgettimeofday-32.o = $(CC_FLAGS_FTRACE)
1718
CFLAGS_REMOVE_vgettimeofday-32.o += -mcmodel=medium -mabi=elfv1 -mabi=elfv2 -mcall-aixdesc
19+
CFLAGS_vgettimeofday-64.o += -include $(c-gettimeofday-y)
20+
CFLAGS_vgettimeofday-64.o += $(DISABLE_LATENT_ENTROPY_PLUGIN)
21+
CFLAGS_vgettimeofday-64.o += $(call cc-option, -fno-stack-protector)
22+
CFLAGS_vgettimeofday-64.o += -DDISABLE_BRANCH_PROFILING
23+
CFLAGS_vgettimeofday-64.o += -ffreestanding -fasynchronous-unwind-tables
24+
CFLAGS_REMOVE_vgettimeofday-64.o = $(CC_FLAGS_FTRACE)
25+
# Go prior to 1.16.x assumes r30 is not clobbered by any VDSO code. That used to be true
26+
# by accident when the VDSO was hand-written asm code, but may not be now that the VDSO is
27+
# compiler generated. To avoid breaking Go tell GCC not to use r30. Impact on code
28+
# generation is minimal, it will just use r29 instead.
29+
CFLAGS_vgettimeofday-64.o += $(call cc-option, -ffixed-r30)
1830
endif
1931

2032
# Build rules
@@ -27,6 +39,8 @@ endif
2739

2840
targets := $(obj-vdso32) vdso32.so.dbg vgettimeofday-32.o
2941
obj-vdso32 := $(addprefix $(obj)/, $(obj-vdso32))
42+
targets += $(obj-vdso64) vdso64.so.dbg vgettimeofday-64.o
43+
obj-vdso64 := $(addprefix $(obj)/, $(obj-vdso64))
3044

3145
GCOV_PROFILE := n
3246
KCOV_INSTRUMENT := n
@@ -38,26 +52,42 @@ ccflags-y := -shared -fno-common -fno-builtin -nostdlib -Wl,--hash-style=both
3852
CC32FLAGS := -Wl,-soname=linux-vdso32.so.1 -m32
3953
AS32FLAGS := -D__VDSO32__ -s
4054

55+
CC64FLAGS := -Wl,-soname=linux-vdso64.so.1
56+
AS64FLAGS := -D__VDSO64__ -s
57+
4158
targets += vdso32.lds
4259
CPPFLAGS_vdso32.lds += -P -C -Upowerpc
60+
targets += vdso64.lds
61+
CPPFLAGS_vdso64.lds += -P -C -U$(ARCH)
4362

4463
# link rule for the .so file, .lds has to be first
4564
$(obj)/vdso32.so.dbg: $(src)/vdso32.lds $(obj-vdso32) $(obj)/vgettimeofday-32.o FORCE
4665
$(call if_changed,vdso32ld_and_check)
66+
$(obj)/vdso64.so.dbg: $(src)/vdso64.lds $(obj-vdso64) $(obj)/vgettimeofday-64.o FORCE
67+
$(call if_changed,vdso64ld_and_check)
4768

4869
# assembly rules for the .S files
4970
$(obj-vdso32): %-32.o: %.S FORCE
5071
$(call if_changed_dep,vdso32as)
5172
$(obj)/vgettimeofday-32.o: %-32.o: %.c FORCE
5273
$(call if_changed_dep,vdso32cc)
74+
$(obj-vdso64): %-64.o: %.S FORCE
75+
$(call if_changed_dep,vdso64as)
76+
$(obj)/vgettimeofday-64.o: %-64.o: %.c FORCE
77+
$(call if_changed_dep,cc_o_c)
5378

5479
# Generate VDSO offsets using helper script
5580
gen-vdso32sym := $(srctree)/$(src)/gen_vdso32_offsets.sh
5681
quiet_cmd_vdso32sym = VDSO32SYM $@
5782
cmd_vdso32sym = $(NM) $< | $(gen-vdso32sym) | LC_ALL=C sort > $@
83+
gen-vdso64sym := $(srctree)/$(src)/gen_vdso64_offsets.sh
84+
quiet_cmd_vdso64sym = VDSO64SYM $@
85+
cmd_vdso64sym = $(NM) $< | $(gen-vdso64sym) | LC_ALL=C sort > $@
5886

5987
include/generated/vdso32-offsets.h: $(obj)/vdso32.so.dbg FORCE
6088
$(call if_changed,vdso32sym)
89+
include/generated/vdso64-offsets.h: $(obj)/vdso64.so.dbg FORCE
90+
$(call if_changed,vdso64sym)
6191

6292
# actual build commands
6393
quiet_cmd_vdso32ld_and_check = VDSO32L $@
@@ -66,3 +96,8 @@ quiet_cmd_vdso32as = VDSO32A $@
6696
cmd_vdso32as = $(VDSOCC) $(a_flags) $(CC32FLAGS) $(AS32FLAGS) -c -o $@ $<
6797
quiet_cmd_vdso32cc = VDSO32C $@
6898
cmd_vdso32cc = $(VDSOCC) $(c_flags) $(CC32FLAGS) -c -o $@ $<
99+
100+
quiet_cmd_vdso64ld_and_check = VDSO64L $@
101+
cmd_vdso64ld_and_check = $(VDSOCC) $(c_flags) $(CC64FLAGS) -o $@ -Wl,-T$(filter %.lds,$^) $(filter %.o,$^) ; $(cmd_vdso_check)
102+
quiet_cmd_vdso64as = VDSO64A $@
103+
cmd_vdso64as = $(VDSOCC) $(a_flags) $(CC64FLAGS) $(AS64FLAGS) -c -o $@ $<
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.

0 commit comments

Comments
 (0)