1*4882a593Smuzhiyun# SPDX-License-Identifier: GPL-2.0 2*4882a593Smuzhiyun# Objects to go into the VDSO. 3*4882a593Smuzhiyun 4*4882a593Smuzhiyun# Absolute relocation type $(ARCH_REL_TYPE_ABS) needs to be defined before 5*4882a593Smuzhiyun# the inclusion of generic Makefile. 6*4882a593SmuzhiyunARCH_REL_TYPE_ABS := R_MIPS_JUMP_SLOT|R_MIPS_GLOB_DAT 7*4882a593Smuzhiyuninclude $(srctree)/lib/vdso/Makefile 8*4882a593Smuzhiyun 9*4882a593Smuzhiyunobj-vdso-y := elf.o vgettimeofday.o sigreturn.o 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun# Common compiler flags between ABIs. 12*4882a593Smuzhiyunccflags-vdso := \ 13*4882a593Smuzhiyun $(filter -I%,$(KBUILD_CFLAGS)) \ 14*4882a593Smuzhiyun $(filter -E%,$(KBUILD_CFLAGS)) \ 15*4882a593Smuzhiyun $(filter -mmicromips,$(KBUILD_CFLAGS)) \ 16*4882a593Smuzhiyun $(filter -march=%,$(KBUILD_CFLAGS)) \ 17*4882a593Smuzhiyun $(filter -m%-float,$(KBUILD_CFLAGS)) \ 18*4882a593Smuzhiyun $(filter -mno-loongson-%,$(KBUILD_CFLAGS)) \ 19*4882a593Smuzhiyun $(CLANG_FLAGS) \ 20*4882a593Smuzhiyun -D__VDSO__ 21*4882a593Smuzhiyun 22*4882a593Smuzhiyunifndef CONFIG_64BIT 23*4882a593Smuzhiyunccflags-vdso += -DBUILD_VDSO32 24*4882a593Smuzhiyunendif 25*4882a593Smuzhiyun 26*4882a593Smuzhiyun# 27*4882a593Smuzhiyun# The -fno-jump-tables flag only prevents the compiler from generating 28*4882a593Smuzhiyun# jump tables but does not prevent the compiler from emitting absolute 29*4882a593Smuzhiyun# offsets. 30*4882a593Smuzhiyuncflags-vdso := $(ccflags-vdso) \ 31*4882a593Smuzhiyun $(filter -W%,$(filter-out -Wa$(comma)%,$(KBUILD_CFLAGS))) \ 32*4882a593Smuzhiyun -O3 -g -fPIC -fno-strict-aliasing -fno-common -fno-builtin -G 0 \ 33*4882a593Smuzhiyun -mrelax-pic-calls $(call cc-option, -mexplicit-relocs) \ 34*4882a593Smuzhiyun -fno-stack-protector -fno-jump-tables -DDISABLE_BRANCH_PROFILING \ 35*4882a593Smuzhiyun $(call cc-option, -fno-asynchronous-unwind-tables) 36*4882a593Smuzhiyunaflags-vdso := $(ccflags-vdso) \ 37*4882a593Smuzhiyun -D__ASSEMBLY__ -Wa,-gdwarf-2 38*4882a593Smuzhiyun 39*4882a593Smuzhiyunifneq ($(c-gettimeofday-y),) 40*4882a593SmuzhiyunCFLAGS_vgettimeofday.o = -include $(c-gettimeofday-y) 41*4882a593Smuzhiyun 42*4882a593Smuzhiyun# config-n32-o32-env.c prepares the environment to build a 32bit vDSO 43*4882a593Smuzhiyun# library on a 64bit kernel. 44*4882a593Smuzhiyun# Note: Needs to be included before than the generic library. 45*4882a593SmuzhiyunCFLAGS_vgettimeofday-o32.o = -include $(srctree)/$(src)/config-n32-o32-env.c -include $(c-gettimeofday-y) 46*4882a593SmuzhiyunCFLAGS_vgettimeofday-n32.o = -include $(srctree)/$(src)/config-n32-o32-env.c -include $(c-gettimeofday-y) 47*4882a593Smuzhiyunendif 48*4882a593Smuzhiyun 49*4882a593SmuzhiyunCFLAGS_REMOVE_vgettimeofday.o = -pg 50*4882a593Smuzhiyun 51*4882a593Smuzhiyunifdef CONFIG_MIPS_DISABLE_VDSO 52*4882a593Smuzhiyun ifndef CONFIG_MIPS_LD_CAN_LINK_VDSO 53*4882a593Smuzhiyun $(warning MIPS VDSO requires binutils >= 2.25) 54*4882a593Smuzhiyun endif 55*4882a593Smuzhiyun obj-vdso-y := $(filter-out vgettimeofday.o, $(obj-vdso-y)) 56*4882a593Smuzhiyunendif 57*4882a593Smuzhiyun 58*4882a593Smuzhiyun# VDSO linker flags. 59*4882a593Smuzhiyunldflags-y := -Bsymbolic --no-undefined -soname=linux-vdso.so.1 \ 60*4882a593Smuzhiyun $(filter -E%,$(KBUILD_CFLAGS)) -nostdlib -shared \ 61*4882a593Smuzhiyun -G 0 --eh-frame-hdr --hash-style=sysv --build-id=sha1 -T 62*4882a593Smuzhiyun 63*4882a593SmuzhiyunCFLAGS_REMOVE_vdso.o = -pg 64*4882a593Smuzhiyun 65*4882a593SmuzhiyunGCOV_PROFILE := n 66*4882a593SmuzhiyunUBSAN_SANITIZE := n 67*4882a593SmuzhiyunKCOV_INSTRUMENT := n 68*4882a593Smuzhiyun 69*4882a593Smuzhiyun# Check that we don't have PIC 'jalr t9' calls left 70*4882a593Smuzhiyunquiet_cmd_vdso_mips_check = VDSOCHK $@ 71*4882a593Smuzhiyun cmd_vdso_mips_check = if $(OBJDUMP) --disassemble $@ | egrep -h "jalr.*t9" > /dev/null; \ 72*4882a593Smuzhiyun then (echo >&2 "$@: PIC 'jalr t9' calls are not supported"; \ 73*4882a593Smuzhiyun rm -f $@; /bin/false); fi 74*4882a593Smuzhiyun 75*4882a593Smuzhiyun# 76*4882a593Smuzhiyun# Shared build commands. 77*4882a593Smuzhiyun# 78*4882a593Smuzhiyun 79*4882a593Smuzhiyunquiet_cmd_vdsold_and_vdso_check = LD $@ 80*4882a593Smuzhiyun cmd_vdsold_and_vdso_check = $(cmd_ld); $(cmd_vdso_check); $(cmd_vdso_mips_check) 81*4882a593Smuzhiyun 82*4882a593Smuzhiyunquiet_cmd_vdsoas_o_S = AS $@ 83*4882a593Smuzhiyun cmd_vdsoas_o_S = $(CC) $(a_flags) -c -o $@ $< 84*4882a593Smuzhiyun 85*4882a593Smuzhiyun# Strip rule for the raw .so files 86*4882a593Smuzhiyun$(obj)/%.so.raw: OBJCOPYFLAGS := -S 87*4882a593Smuzhiyun$(obj)/%.so.raw: $(obj)/%.so.dbg.raw FORCE 88*4882a593Smuzhiyun $(call if_changed,objcopy) 89*4882a593Smuzhiyun 90*4882a593Smuzhiyunhostprogs := genvdso 91*4882a593Smuzhiyun 92*4882a593Smuzhiyunquiet_cmd_genvdso = GENVDSO $@ 93*4882a593Smuzhiyundefine cmd_genvdso 94*4882a593Smuzhiyun $(foreach file,$(filter %.raw,$^),cp $(file) $(file:%.raw=%) &&) \ 95*4882a593Smuzhiyun $(obj)/genvdso $(<:%.raw=%) $(<:%.dbg.raw=%) $@ $(VDSO_NAME) 96*4882a593Smuzhiyunendef 97*4882a593Smuzhiyun 98*4882a593Smuzhiyun# 99*4882a593Smuzhiyun# Build native VDSO. 100*4882a593Smuzhiyun# 101*4882a593Smuzhiyun 102*4882a593Smuzhiyunnative-abi := $(filter -mabi=%,$(KBUILD_CFLAGS)) 103*4882a593Smuzhiyun 104*4882a593Smuzhiyuntargets += $(obj-vdso-y) 105*4882a593Smuzhiyuntargets += vdso.lds 106*4882a593Smuzhiyuntargets += vdso.so.dbg.raw vdso.so.raw 107*4882a593Smuzhiyuntargets += vdso.so.dbg vdso.so 108*4882a593Smuzhiyuntargets += vdso-image.c 109*4882a593Smuzhiyun 110*4882a593Smuzhiyunobj-vdso := $(obj-vdso-y:%.o=$(obj)/%.o) 111*4882a593Smuzhiyun 112*4882a593Smuzhiyun$(obj-vdso): KBUILD_CFLAGS := $(cflags-vdso) $(native-abi) 113*4882a593Smuzhiyun$(obj-vdso): KBUILD_AFLAGS := $(aflags-vdso) $(native-abi) 114*4882a593Smuzhiyun 115*4882a593Smuzhiyun$(obj)/vdso.lds: KBUILD_CPPFLAGS := $(ccflags-vdso) $(native-abi) 116*4882a593Smuzhiyun 117*4882a593Smuzhiyun$(obj)/vdso.so.dbg.raw: $(obj)/vdso.lds $(obj-vdso) FORCE 118*4882a593Smuzhiyun $(call if_changed,vdsold_and_vdso_check) 119*4882a593Smuzhiyun 120*4882a593Smuzhiyun$(obj)/vdso-image.c: $(obj)/vdso.so.dbg.raw $(obj)/vdso.so.raw \ 121*4882a593Smuzhiyun $(obj)/genvdso FORCE 122*4882a593Smuzhiyun $(call if_changed,genvdso) 123*4882a593Smuzhiyun 124*4882a593Smuzhiyunobj-y += vdso-image.o 125*4882a593Smuzhiyun 126*4882a593Smuzhiyun# 127*4882a593Smuzhiyun# Build O32 VDSO. 128*4882a593Smuzhiyun# 129*4882a593Smuzhiyun 130*4882a593Smuzhiyun# Define these outside the ifdef to ensure they are picked up by clean. 131*4882a593Smuzhiyuntargets += $(obj-vdso-y:%.o=%-o32.o) 132*4882a593Smuzhiyuntargets += vdso-o32.lds 133*4882a593Smuzhiyuntargets += vdso-o32.so.dbg.raw vdso-o32.so.raw 134*4882a593Smuzhiyuntargets += vdso-o32.so.dbg vdso-o32.so 135*4882a593Smuzhiyuntargets += vdso-o32-image.c 136*4882a593Smuzhiyun 137*4882a593Smuzhiyunifdef CONFIG_MIPS32_O32 138*4882a593Smuzhiyun 139*4882a593Smuzhiyunobj-vdso-o32 := $(obj-vdso-y:%.o=$(obj)/%-o32.o) 140*4882a593Smuzhiyun 141*4882a593Smuzhiyun$(obj-vdso-o32): KBUILD_CFLAGS := $(cflags-vdso) -mabi=32 142*4882a593Smuzhiyun$(obj-vdso-o32): KBUILD_AFLAGS := $(aflags-vdso) -mabi=32 143*4882a593Smuzhiyun 144*4882a593Smuzhiyun$(obj)/%-o32.o: $(src)/%.S FORCE 145*4882a593Smuzhiyun $(call if_changed_dep,vdsoas_o_S) 146*4882a593Smuzhiyun 147*4882a593Smuzhiyun$(obj)/%-o32.o: $(src)/%.c FORCE 148*4882a593Smuzhiyun $(call cmd,force_checksrc) 149*4882a593Smuzhiyun $(call if_changed_rule,cc_o_c) 150*4882a593Smuzhiyun 151*4882a593Smuzhiyun$(obj)/vdso-o32.lds: KBUILD_CPPFLAGS := $(ccflags-vdso) -mabi=32 152*4882a593Smuzhiyun$(obj)/vdso-o32.lds: $(src)/vdso.lds.S FORCE 153*4882a593Smuzhiyun $(call if_changed_dep,cpp_lds_S) 154*4882a593Smuzhiyun 155*4882a593Smuzhiyun$(obj)/vdso-o32.so.dbg.raw: $(obj)/vdso-o32.lds $(obj-vdso-o32) FORCE 156*4882a593Smuzhiyun $(call if_changed,vdsold_and_vdso_check) 157*4882a593Smuzhiyun 158*4882a593Smuzhiyun$(obj)/vdso-o32-image.c: VDSO_NAME := o32 159*4882a593Smuzhiyun$(obj)/vdso-o32-image.c: $(obj)/vdso-o32.so.dbg.raw $(obj)/vdso-o32.so.raw \ 160*4882a593Smuzhiyun $(obj)/genvdso FORCE 161*4882a593Smuzhiyun $(call if_changed,genvdso) 162*4882a593Smuzhiyun 163*4882a593Smuzhiyunobj-y += vdso-o32-image.o 164*4882a593Smuzhiyun 165*4882a593Smuzhiyunendif 166*4882a593Smuzhiyun 167*4882a593Smuzhiyun# 168*4882a593Smuzhiyun# Build N32 VDSO. 169*4882a593Smuzhiyun# 170*4882a593Smuzhiyun 171*4882a593Smuzhiyuntargets += $(obj-vdso-y:%.o=%-n32.o) 172*4882a593Smuzhiyuntargets += vdso-n32.lds 173*4882a593Smuzhiyuntargets += vdso-n32.so.dbg.raw vdso-n32.so.raw 174*4882a593Smuzhiyuntargets += vdso-n32.so.dbg vdso-n32.so 175*4882a593Smuzhiyuntargets += vdso-n32-image.c 176*4882a593Smuzhiyun 177*4882a593Smuzhiyunifdef CONFIG_MIPS32_N32 178*4882a593Smuzhiyun 179*4882a593Smuzhiyunobj-vdso-n32 := $(obj-vdso-y:%.o=$(obj)/%-n32.o) 180*4882a593Smuzhiyun 181*4882a593Smuzhiyun$(obj-vdso-n32): KBUILD_CFLAGS := $(cflags-vdso) -mabi=n32 182*4882a593Smuzhiyun$(obj-vdso-n32): KBUILD_AFLAGS := $(aflags-vdso) -mabi=n32 183*4882a593Smuzhiyun 184*4882a593Smuzhiyun$(obj)/%-n32.o: $(src)/%.S FORCE 185*4882a593Smuzhiyun $(call if_changed_dep,vdsoas_o_S) 186*4882a593Smuzhiyun 187*4882a593Smuzhiyun$(obj)/%-n32.o: $(src)/%.c FORCE 188*4882a593Smuzhiyun $(call cmd,force_checksrc) 189*4882a593Smuzhiyun $(call if_changed_rule,cc_o_c) 190*4882a593Smuzhiyun 191*4882a593Smuzhiyun$(obj)/vdso-n32.lds: KBUILD_CPPFLAGS := $(ccflags-vdso) -mabi=n32 192*4882a593Smuzhiyun$(obj)/vdso-n32.lds: $(src)/vdso.lds.S FORCE 193*4882a593Smuzhiyun $(call if_changed_dep,cpp_lds_S) 194*4882a593Smuzhiyun 195*4882a593Smuzhiyun$(obj)/vdso-n32.so.dbg.raw: $(obj)/vdso-n32.lds $(obj-vdso-n32) FORCE 196*4882a593Smuzhiyun $(call if_changed,vdsold_and_vdso_check) 197*4882a593Smuzhiyun 198*4882a593Smuzhiyun$(obj)/vdso-n32-image.c: VDSO_NAME := n32 199*4882a593Smuzhiyun$(obj)/vdso-n32-image.c: $(obj)/vdso-n32.so.dbg.raw $(obj)/vdso-n32.so.raw \ 200*4882a593Smuzhiyun $(obj)/genvdso FORCE 201*4882a593Smuzhiyun $(call if_changed,genvdso) 202*4882a593Smuzhiyun 203*4882a593Smuzhiyunobj-y += vdso-n32-image.o 204*4882a593Smuzhiyun 205*4882a593Smuzhiyunendif 206*4882a593Smuzhiyun 207*4882a593Smuzhiyun# FIXME: Need install rule for debug. 208*4882a593Smuzhiyun# Needs to deal with dependency for generation of dbg by cmd_genvdso... 209