cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

Makefile (2806B)


      1# SPDX-License-Identifier: GPL-2.0
      2#
      3# Building a vDSO image for AArch64.
      4#
      5# Author: Will Deacon <will.deacon@arm.com>
      6# Heavily based on the vDSO Makefiles for other archs.
      7#
      8
      9# Absolute relocation type $(ARCH_REL_TYPE_ABS) needs to be defined before
     10# the inclusion of generic Makefile.
     11ARCH_REL_TYPE_ABS := R_AARCH64_JUMP_SLOT|R_AARCH64_GLOB_DAT|R_AARCH64_ABS64
     12include $(srctree)/lib/vdso/Makefile
     13
     14obj-vdso := vgettimeofday.o note.o sigreturn.o
     15
     16# Build rules
     17targets := $(obj-vdso) vdso.so vdso.so.dbg
     18obj-vdso := $(addprefix $(obj)/, $(obj-vdso))
     19
     20btildflags-$(CONFIG_ARM64_BTI_KERNEL) += -z force-bti
     21
     22# -Bsymbolic has been added for consistency with arm, the compat vDSO and
     23# potential future proofing if we end up with internal calls to the exported
     24# routines, as x86 does (see 6f121e548f83 ("x86, vdso: Reimplement vdso.so
     25# preparation in build-time C")).
     26ldflags-y := -shared -soname=linux-vdso.so.1 --hash-style=sysv	\
     27	     -Bsymbolic --build-id=sha1 -n $(btildflags-y) -T
     28
     29ccflags-y := -fno-common -fno-builtin -fno-stack-protector -ffixed-x18
     30ccflags-y += -DDISABLE_BRANCH_PROFILING -DBUILD_VDSO
     31
     32# -Wmissing-prototypes and -Wmissing-declarations are removed from
     33# the CFLAGS of vgettimeofday.c to make possible to build the
     34# kernel with CONFIG_WERROR enabled.
     35CFLAGS_REMOVE_vgettimeofday.o = $(CC_FLAGS_FTRACE) -Os $(CC_FLAGS_SCS) \
     36				$(RANDSTRUCT_CFLAGS) $(GCC_PLUGINS_CFLAGS) \
     37				$(CC_FLAGS_LTO) -Wmissing-prototypes -Wmissing-declarations
     38KASAN_SANITIZE			:= n
     39KCSAN_SANITIZE			:= n
     40UBSAN_SANITIZE			:= n
     41OBJECT_FILES_NON_STANDARD	:= y
     42KCOV_INSTRUMENT			:= n
     43
     44CFLAGS_vgettimeofday.o = -O2 -mcmodel=tiny -fasynchronous-unwind-tables
     45
     46ifneq ($(c-gettimeofday-y),)
     47  CFLAGS_vgettimeofday.o += -include $(c-gettimeofday-y)
     48endif
     49
     50# Disable gcov profiling for VDSO code
     51GCOV_PROFILE := n
     52
     53targets += vdso.lds
     54CPPFLAGS_vdso.lds += -P -C -U$(ARCH)
     55
     56# Link rule for the .so file, .lds has to be first
     57$(obj)/vdso.so.dbg: $(obj)/vdso.lds $(obj-vdso) FORCE
     58	$(call if_changed,vdsold_and_vdso_check)
     59
     60# Strip rule for the .so file
     61$(obj)/%.so: OBJCOPYFLAGS := -S
     62$(obj)/%.so: $(obj)/%.so.dbg FORCE
     63	$(call if_changed,objcopy)
     64
     65# Generate VDSO offsets using helper script
     66gen-vdsosym := $(srctree)/$(src)/gen_vdso_offsets.sh
     67quiet_cmd_vdsosym = VDSOSYM $@
     68      cmd_vdsosym = $(NM) $< | $(gen-vdsosym) | LC_ALL=C sort > $@
     69
     70include/generated/vdso-offsets.h: $(obj)/vdso.so.dbg FORCE
     71	$(call if_changed,vdsosym)
     72
     73# Actual build commands
     74quiet_cmd_vdsold_and_vdso_check = LD      $@
     75      cmd_vdsold_and_vdso_check = $(cmd_ld); $(cmd_vdso_check)
     76
     77# Install commands for the unstripped file
     78quiet_cmd_vdso_install = INSTALL $@
     79      cmd_vdso_install = cp $(obj)/$@.dbg $(MODLIB)/vdso/$@
     80
     81vdso.so: $(obj)/vdso.so.dbg
     82	@mkdir -p $(MODLIB)/vdso
     83	$(call cmd,vdso_install)
     84
     85vdso_install: vdso.so