Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | # SPDX-License-Identifier: GPL-2.0 |
Will Deacon | 9031fef | 2012-03-05 11:49:31 +0000 | [diff] [blame] | 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 | |
Vincenzo Frascino | 28b1a82 | 2019-06-21 10:52:31 +0100 | [diff] [blame] | 9 | # Absolute relocation type $(ARCH_REL_TYPE_ABS) needs to be defined before |
| 10 | # the inclusion of generic Makefile. |
| 11 | ARCH_REL_TYPE_ABS := R_AARCH64_JUMP_SLOT|R_AARCH64_GLOB_DAT|R_AARCH64_ABS64 |
| 12 | include $(srctree)/lib/vdso/Makefile |
| 13 | |
| 14 | obj-vdso := vgettimeofday.o note.o sigreturn.o |
Will Deacon | 9031fef | 2012-03-05 11:49:31 +0000 | [diff] [blame] | 15 | |
| 16 | # Build rules |
| 17 | targets := $(obj-vdso) vdso.so vdso.so.dbg |
| 18 | obj-vdso := $(addprefix $(obj)/, $(obj-vdso)) |
| 19 | |
Mark Brown | 5e02a18 | 2020-05-06 20:51:37 +0100 | [diff] [blame] | 20 | btildflags-$(CONFIG_ARM64_BTI_KERNEL) += -z force-bti |
| 21 | |
Vincenzo Frascino | 86b8783 | 2020-04-28 16:08:54 +0100 | [diff] [blame] | 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")). |
Will Deacon | 49a3b0e | 2020-06-24 13:23:10 +0100 | [diff] [blame] | 26 | ldflags-y := -shared -nostdlib -soname=linux-vdso.so.1 --hash-style=sysv \ |
| 27 | -Bsymbolic $(call ld-option, --no-eh-frame-hdr) --build-id -n \ |
| 28 | $(btildflags-y) -T |
Will Deacon | 9031fef | 2012-03-05 11:49:31 +0000 | [diff] [blame] | 29 | |
Peter Collingbourne | 98cd3c3 | 2019-06-21 10:52:32 +0100 | [diff] [blame] | 30 | ccflags-y := -fno-common -fno-builtin -fno-stack-protector -ffixed-x18 |
Vincenzo Frascino | 28b1a82 | 2019-06-21 10:52:31 +0100 | [diff] [blame] | 31 | ccflags-y += -DDISABLE_BRANCH_PROFILING |
| 32 | |
Alexander Popov | e56404e | 2020-06-24 15:33:28 +0300 | [diff] [blame] | 33 | CFLAGS_REMOVE_vgettimeofday.o = $(CC_FLAGS_FTRACE) -Os $(CC_FLAGS_SCS) $(GCC_PLUGINS_CFLAGS) |
Vincenzo Frascino | 28b1a82 | 2019-06-21 10:52:31 +0100 | [diff] [blame] | 34 | KBUILD_CFLAGS += $(DISABLE_LTO) |
| 35 | KASAN_SANITIZE := n |
| 36 | UBSAN_SANITIZE := n |
| 37 | OBJECT_FILES_NON_STANDARD := y |
| 38 | KCOV_INSTRUMENT := n |
| 39 | |
Vincenzo Frascino | 1578e5d | 2020-04-29 16:10:50 +0100 | [diff] [blame] | 40 | CFLAGS_vgettimeofday.o = -O2 -mcmodel=tiny -fasynchronous-unwind-tables |
Vincenzo Frascino | a88754b | 2019-07-19 11:10:18 +0100 | [diff] [blame] | 41 | |
| 42 | ifneq ($(c-gettimeofday-y),) |
| 43 | CFLAGS_vgettimeofday.o += -include $(c-gettimeofday-y) |
Vincenzo Frascino | 28b1a82 | 2019-06-21 10:52:31 +0100 | [diff] [blame] | 44 | endif |
| 45 | |
Vincenzo Frascino | 3acf4be | 2019-06-26 12:36:32 +0100 | [diff] [blame] | 46 | # Clang versions less than 8 do not support -mcmodel=tiny |
| 47 | ifeq ($(CONFIG_CC_IS_CLANG), y) |
| 48 | ifeq ($(shell test $(CONFIG_CLANG_VERSION) -lt 80000; echo $$?),0) |
| 49 | CFLAGS_REMOVE_vgettimeofday.o += -mcmodel=tiny |
| 50 | endif |
| 51 | endif |
| 52 | |
Arnd Bergmann | 5430978 | 2015-11-12 15:37:12 +0100 | [diff] [blame] | 53 | # Disable gcov profiling for VDSO code |
| 54 | GCOV_PROFILE := n |
| 55 | |
Will Deacon | 9031fef | 2012-03-05 11:49:31 +0000 | [diff] [blame] | 56 | obj-y += vdso.o |
Masahiro Yamada | 887af6d | 2020-09-01 03:22:39 +0900 | [diff] [blame^] | 57 | targets += vdso.lds |
Will Deacon | 9031fef | 2012-03-05 11:49:31 +0000 | [diff] [blame] | 58 | CPPFLAGS_vdso.lds += -P -C -U$(ARCH) |
| 59 | |
| 60 | # Force dependency (incbin is bad) |
| 61 | $(obj)/vdso.o : $(obj)/vdso.so |
| 62 | |
| 63 | # Link rule for the .so file, .lds has to be first |
Masahiro Yamada | 697e96e | 2019-04-03 17:48:22 +0900 | [diff] [blame] | 64 | $(obj)/vdso.so.dbg: $(obj)/vdso.lds $(obj-vdso) FORCE |
Naohiro Aota | 2e2f3c9 | 2019-07-12 19:15:56 +0900 | [diff] [blame] | 65 | $(call if_changed,vdsold_and_vdso_check) |
Will Deacon | 9031fef | 2012-03-05 11:49:31 +0000 | [diff] [blame] | 66 | |
| 67 | # Strip rule for the .so file |
| 68 | $(obj)/%.so: OBJCOPYFLAGS := -S |
| 69 | $(obj)/%.so: $(obj)/%.so.dbg FORCE |
| 70 | $(call if_changed,objcopy) |
| 71 | |
| 72 | # Generate VDSO offsets using helper script |
| 73 | gen-vdsosym := $(srctree)/$(src)/gen_vdso_offsets.sh |
| 74 | quiet_cmd_vdsosym = VDSOSYM $@ |
Masahiro Yamada | 697e96e | 2019-04-03 17:48:22 +0900 | [diff] [blame] | 75 | cmd_vdsosym = $(NM) $< | $(gen-vdsosym) | LC_ALL=C sort > $@ |
Will Deacon | 9031fef | 2012-03-05 11:49:31 +0000 | [diff] [blame] | 76 | |
Kevin Brodsky | a66649d | 2016-05-12 17:39:15 +0100 | [diff] [blame] | 77 | include/generated/vdso-offsets.h: $(obj)/vdso.so.dbg FORCE |
Will Deacon | 9031fef | 2012-03-05 11:49:31 +0000 | [diff] [blame] | 78 | $(call if_changed,vdsosym) |
| 79 | |
Will Deacon | 9031fef | 2012-03-05 11:49:31 +0000 | [diff] [blame] | 80 | # Actual build commands |
Naohiro Aota | 2e2f3c9 | 2019-07-12 19:15:56 +0900 | [diff] [blame] | 81 | quiet_cmd_vdsold_and_vdso_check = LD $@ |
| 82 | cmd_vdsold_and_vdso_check = $(cmd_ld); $(cmd_vdso_check) |
| 83 | |
Will Deacon | 9031fef | 2012-03-05 11:49:31 +0000 | [diff] [blame] | 84 | # Install commands for the unstripped file |
| 85 | quiet_cmd_vdso_install = INSTALL $@ |
| 86 | cmd_vdso_install = cp $(obj)/$@.dbg $(MODLIB)/vdso/$@ |
| 87 | |
| 88 | vdso.so: $(obj)/vdso.so.dbg |
| 89 | @mkdir -p $(MODLIB)/vdso |
| 90 | $(call cmd,vdso_install) |
| 91 | |
| 92 | vdso_install: vdso.so |