Makefile 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. # SPDX-License-Identifier: GPL-2.0
  2. obj-y += vsyscall.o vsyscall-syscall.o vsyscall-syms.o
  3. $(obj)/vsyscall-syscall.o: \
  4. $(foreach F,trapa,$(obj)/vsyscall-$F.so)
  5. # Teach kbuild about targets
  6. targets += $(foreach F,trapa,vsyscall-$F.o vsyscall-$F.so)
  7. targets += vsyscall-note.o vsyscall.lds vsyscall-dummy.o
  8. # The DSO images are built using a special linker script
  9. quiet_cmd_syscall = SYSCALL $@
  10. cmd_syscall = $(CC) -nostdlib $(SYSCFLAGS_$(@F)) \
  11. -Wl,-T,$(filter-out FORCE,$^) -o $@
  12. export CPPFLAGS_vsyscall.lds += -P -C -Ush
  13. vsyscall-flags = -shared -s -Wl,-soname=linux-gate.so.1 \
  14. $(call cc-ldoption, -Wl$(comma)--hash-style=sysv)
  15. SYSCFLAGS_vsyscall-trapa.so = $(vsyscall-flags)
  16. $(obj)/vsyscall-trapa.so: \
  17. $(obj)/vsyscall-%.so: $(src)/vsyscall.lds $(obj)/vsyscall-%.o FORCE
  18. $(call if_changed,syscall)
  19. # We also create a special relocatable object that should mirror the symbol
  20. # table and layout of the linked DSO. With ld -R we can then refer to
  21. # these symbols in the kernel code rather than hand-coded addresses.
  22. SYSCFLAGS_vsyscall-dummy.o = -r
  23. $(obj)/vsyscall-dummy.o: $(src)/vsyscall.lds \
  24. $(obj)/vsyscall-trapa.o $(obj)/vsyscall-note.o FORCE
  25. $(call if_changed,syscall)
  26. LDFLAGS_vsyscall-syms.o := -r -R
  27. $(obj)/vsyscall-syms.o: $(obj)/vsyscall-dummy.o FORCE
  28. $(call if_changed,ld)