Makefile.clean 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. # ==========================================================================
  2. # Cleaning up
  3. # ==========================================================================
  4. src := $(obj)
  5. PHONY := __clean
  6. __clean:
  7. # Shorthand for $(Q)$(MAKE) scripts/Makefile.clean obj=dir
  8. # Usage:
  9. # $(Q)$(MAKE) $(clean)=dir
  10. clean := -f $(srctree)/scripts/Makefile.clean obj
  11. # The filename Kbuild has precedence over Makefile
  12. kbuild-dir := $(if $(filter /%,$(src)),$(src),$(srctree)/$(src))
  13. include $(if $(wildcard $(kbuild-dir)/Kbuild), $(kbuild-dir)/Kbuild, $(kbuild-dir)/Makefile)
  14. # Figure out what we need to build from the various variables
  15. # ==========================================================================
  16. __subdir-y := $(patsubst %/,%,$(filter %/, $(obj-y)))
  17. subdir-y += $(__subdir-y)
  18. __subdir-m := $(patsubst %/,%,$(filter %/, $(obj-m)))
  19. subdir-m += $(__subdir-m)
  20. __subdir- := $(patsubst %/,%,$(filter %/, $(obj-)))
  21. subdir- += $(__subdir-)
  22. # Subdirectories we need to descend into
  23. subdir-ym := $(sort $(subdir-y) $(subdir-m))
  24. subdir-ymn := $(sort $(subdir-ym) $(subdir-))
  25. # Add subdir path
  26. subdir-ymn := $(addprefix $(obj)/,$(subdir-ymn))
  27. # build a list of files to remove, usually relative to the current
  28. # directory
  29. __clean-files := $(extra-y) $(extra-m) $(extra-) \
  30. $(always) $(targets) $(clean-files) \
  31. $(host-progs) \
  32. $(hostprogs-y) $(hostprogs-m) $(hostprogs-)
  33. __clean-files := $(filter-out $(no-clean-files), $(__clean-files))
  34. # as clean-files is given relative to the current directory, this adds
  35. # a $(obj) prefix, except for absolute paths
  36. __clean-files := $(wildcard \
  37. $(addprefix $(obj)/, $(filter-out /%, $(__clean-files))) \
  38. $(filter /%, $(__clean-files)))
  39. # as clean-dirs is given relative to the current directory, this adds
  40. # a $(obj) prefix, except for absolute paths
  41. __clean-dirs := $(wildcard \
  42. $(addprefix $(obj)/, $(filter-out /%, $(clean-dirs))) \
  43. $(filter /%, $(clean-dirs)))
  44. # ==========================================================================
  45. quiet_cmd_clean = CLEAN $(obj)
  46. cmd_clean = rm -f $(__clean-files)
  47. quiet_cmd_cleandir = CLEAN $(__clean-dirs)
  48. cmd_cleandir = rm -rf $(__clean-dirs)
  49. __clean: $(subdir-ymn)
  50. ifneq ($(strip $(__clean-files)),)
  51. +$(call cmd,clean)
  52. endif
  53. ifneq ($(strip $(__clean-dirs)),)
  54. +$(call cmd,cleandir)
  55. endif
  56. ifneq ($(strip $(clean-rule)),)
  57. +$(clean-rule)
  58. endif
  59. @:
  60. # ===========================================================================
  61. # Generic stuff
  62. # ===========================================================================
  63. # Descending
  64. # ---------------------------------------------------------------------------
  65. PHONY += $(subdir-ymn)
  66. $(subdir-ymn):
  67. $(Q)$(MAKE) $(clean)=$@
  68. # If quiet is set, only print short version of command
  69. cmd = @$(if $($(quiet)cmd_$(1)),echo ' $($(quiet)cmd_$(1))' &&) $(cmd_$(1))
  70. # Declare the contents of the .PHONY variable as phony. We keep that
  71. # information in a variable se we can use it in if_changed and friends.
  72. .PHONY: $(PHONY)