Makefile 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. # SPDX-License-Identifier: GPL-2.0
  2. # List of files in the vdso, has to be asm only for now
  3. 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
  4. include $(srctree)/lib/vdso/Makefile
  5. obj-vdso32 = sigtramp32-32.o gettimeofday-32.o datapage-32.o cacheflush-32.o note-32.o getcpu-32.o
  6. obj-vdso64 = sigtramp64-64.o gettimeofday-64.o datapage-64.o cacheflush-64.o note-64.o getcpu-64.o
  7. ifneq ($(c-gettimeofday-y),)
  8. CFLAGS_vgettimeofday-32.o += -include $(c-gettimeofday-y)
  9. CFLAGS_vgettimeofday-32.o += $(DISABLE_LATENT_ENTROPY_PLUGIN)
  10. CFLAGS_vgettimeofday-32.o += $(call cc-option, -fno-stack-protector)
  11. CFLAGS_vgettimeofday-32.o += -DDISABLE_BRANCH_PROFILING
  12. CFLAGS_vgettimeofday-32.o += -ffreestanding -fasynchronous-unwind-tables
  13. CFLAGS_REMOVE_vgettimeofday-32.o = $(CC_FLAGS_FTRACE)
  14. CFLAGS_REMOVE_vgettimeofday-32.o += -mcmodel=medium -mabi=elfv1 -mabi=elfv2 -mcall-aixdesc
  15. CFLAGS_vgettimeofday-64.o += -include $(c-gettimeofday-y)
  16. CFLAGS_vgettimeofday-64.o += $(DISABLE_LATENT_ENTROPY_PLUGIN)
  17. CFLAGS_vgettimeofday-64.o += $(call cc-option, -fno-stack-protector)
  18. CFLAGS_vgettimeofday-64.o += -DDISABLE_BRANCH_PROFILING
  19. CFLAGS_vgettimeofday-64.o += -ffreestanding -fasynchronous-unwind-tables
  20. CFLAGS_REMOVE_vgettimeofday-64.o = $(CC_FLAGS_FTRACE)
  21. # Go prior to 1.16.x assumes r30 is not clobbered by any VDSO code. That used to be true
  22. # by accident when the VDSO was hand-written asm code, but may not be now that the VDSO is
  23. # compiler generated. To avoid breaking Go tell GCC not to use r30. Impact on code
  24. # generation is minimal, it will just use r29 instead.
  25. CFLAGS_vgettimeofday-64.o += $(call cc-option, -ffixed-r30)
  26. endif
  27. # Build rules
  28. ifdef CROSS32_COMPILE
  29. VDSOCC := $(CROSS32_COMPILE)gcc
  30. else
  31. VDSOCC := $(CC)
  32. endif
  33. targets := $(obj-vdso32) vdso32.so.dbg vgettimeofday-32.o
  34. obj-vdso32 := $(addprefix $(obj)/, $(obj-vdso32))
  35. targets += $(obj-vdso64) vdso64.so.dbg vgettimeofday-64.o
  36. obj-vdso64 := $(addprefix $(obj)/, $(obj-vdso64))
  37. GCOV_PROFILE := n
  38. KCOV_INSTRUMENT := n
  39. UBSAN_SANITIZE := n
  40. KASAN_SANITIZE := n
  41. ccflags-y := -shared -fno-common -fno-builtin -nostdlib -Wl,--hash-style=both
  42. ccflags-$(CONFIG_LD_IS_LLD) += $(call cc-option,--ld-path=$(LD),-fuse-ld=lld)
  43. CC32FLAGS := -Wl,-soname=linux-vdso32.so.1 -m32
  44. AS32FLAGS := -D__VDSO32__ -s
  45. CC64FLAGS := -Wl,-soname=linux-vdso64.so.1
  46. AS64FLAGS := -D__VDSO64__ -s
  47. targets += vdso32.lds
  48. CPPFLAGS_vdso32.lds += -P -C -Upowerpc
  49. targets += vdso64.lds
  50. CPPFLAGS_vdso64.lds += -P -C -U$(ARCH)
  51. # link rule for the .so file, .lds has to be first
  52. $(obj)/vdso32.so.dbg: $(src)/vdso32.lds $(obj-vdso32) $(obj)/vgettimeofday-32.o FORCE
  53. $(call if_changed,vdso32ld_and_check)
  54. $(obj)/vdso64.so.dbg: $(src)/vdso64.lds $(obj-vdso64) $(obj)/vgettimeofday-64.o FORCE
  55. $(call if_changed,vdso64ld_and_check)
  56. # assembly rules for the .S files
  57. $(obj-vdso32): %-32.o: %.S FORCE
  58. $(call if_changed_dep,vdso32as)
  59. $(obj)/vgettimeofday-32.o: %-32.o: %.c FORCE
  60. $(call if_changed_dep,vdso32cc)
  61. $(obj-vdso64): %-64.o: %.S FORCE
  62. $(call if_changed_dep,vdso64as)
  63. $(obj)/vgettimeofday-64.o: %-64.o: %.c FORCE
  64. $(call if_changed_dep,cc_o_c)
  65. # Generate VDSO offsets using helper script
  66. gen-vdso32sym := $(srctree)/$(src)/gen_vdso32_offsets.sh
  67. quiet_cmd_vdso32sym = VDSO32SYM $@
  68. cmd_vdso32sym = $(NM) $< | $(gen-vdso32sym) | LC_ALL=C sort > $@
  69. gen-vdso64sym := $(srctree)/$(src)/gen_vdso64_offsets.sh
  70. quiet_cmd_vdso64sym = VDSO64SYM $@
  71. cmd_vdso64sym = $(NM) $< | $(gen-vdso64sym) | LC_ALL=C sort > $@
  72. include/generated/vdso32-offsets.h: $(obj)/vdso32.so.dbg FORCE
  73. $(call if_changed,vdso32sym)
  74. include/generated/vdso64-offsets.h: $(obj)/vdso64.so.dbg FORCE
  75. $(call if_changed,vdso64sym)
  76. # actual build commands
  77. quiet_cmd_vdso32ld_and_check = VDSO32L $@
  78. cmd_vdso32ld_and_check = $(VDSOCC) $(c_flags) $(CC32FLAGS) -o $@ -Wl,-T$(filter %.lds,$^) $(filter %.o,$^) -z noexecstack ; $(cmd_vdso_check)
  79. quiet_cmd_vdso32as = VDSO32A $@
  80. cmd_vdso32as = $(VDSOCC) $(a_flags) $(CC32FLAGS) $(AS32FLAGS) -c -o $@ $<
  81. quiet_cmd_vdso32cc = VDSO32C $@
  82. cmd_vdso32cc = $(VDSOCC) $(c_flags) $(CC32FLAGS) -c -o $@ $<
  83. quiet_cmd_vdso64ld_and_check = VDSO64L $@
  84. cmd_vdso64ld_and_check = $(VDSOCC) $(c_flags) $(CC64FLAGS) -o $@ -Wl,-T$(filter %.lds,$^) $(filter %.o,$^) -z noexecstack ; $(cmd_vdso_check)
  85. quiet_cmd_vdso64as = VDSO64A $@
  86. cmd_vdso64as = $(VDSOCC) $(a_flags) $(CC64FLAGS) $(AS64FLAGS) -c -o $@ $<