Makefile.rules 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. # ===========================================================================
  2. # arch/um: Generic definitions
  3. # ===========================================================================
  4. USER_SINGLE_OBJS := \
  5. $(foreach f,$(patsubst %.o,%,$(obj-y) $(obj-m)),$($(f)-objs))
  6. USER_OBJS += $(filter %_user.o,$(obj-y) $(obj-m) $(USER_SINGLE_OBJS))
  7. USER_OBJS := $(foreach file,$(USER_OBJS),$(obj)/$(file))
  8. $(USER_OBJS) $(USER_OBJS:.o=.i) $(USER_OBJS:.o=.s) $(USER_OBJS:.o=.lst): \
  9. c_flags = -Wp,-MD,$(depfile) $(USER_CFLAGS) $(CFLAGS_$(notdir $@))
  10. $(USER_OBJS): cmd_checksrc =
  11. $(USER_OBJS): quiet_cmd_checksrc =
  12. $(USER_OBJS): cmd_force_checksrc =
  13. $(USER_OBJS): quiet_cmd_force_checksrc =
  14. # The stubs and unmap.o can't try to call mcount or update basic block data
  15. define unprofile
  16. $(patsubst -pg,,$(patsubst -fprofile-arcs -ftest-coverage,,$(1)))
  17. endef
  18. # The stubs and unmap.o can't try to call mcount or update basic block data
  19. define unprofile
  20. $(patsubst -pg,,$(patsubst -fprofile-arcs -ftest-coverage,,$(1)))
  21. endef
  22. quiet_cmd_make_link = SYMLINK $@
  23. cmd_make_link = ln -sf $(srctree)/arch/$(SUBARCH)/$($(notdir $@)-dir)/$(notdir $@) $@
  24. # this needs to be before the foreach, because targets does not accept
  25. # complete paths like $(obj)/$(f). To make sure this works, use a := assignment
  26. # or we will get $(obj)/$(f) in the "targets" value.
  27. # Also, this forces you to use the := syntax when assigning to targets.
  28. # Otherwise the line below will cause an infinite loop (if you don't know why,
  29. # just do it).
  30. targets := $(targets) $(SYMLINKS)
  31. SYMLINKS := $(foreach f,$(SYMLINKS),$(obj)/$(f))
  32. $(SYMLINKS): FORCE
  33. $(call if_changed,make_link)