LiteX: driver for MMCM
[linux/fpc-iii.git] / scripts / Makefile.clean
blobd9e0ceace6a64f35cdfe2819a591b6149edd3d38
1 # SPDX-License-Identifier: GPL-2.0
2 # ==========================================================================
3 # Cleaning up
4 # ==========================================================================
6 src := $(obj)
8 PHONY := __clean
9 __clean:
11 include scripts/Kbuild.include
13 # The filename Kbuild has precedence over Makefile
14 kbuild-dir := $(if $(filter /%,$(src)),$(src),$(srctree)/$(src))
15 include $(if $(wildcard $(kbuild-dir)/Kbuild), $(kbuild-dir)/Kbuild, $(kbuild-dir)/Makefile)
17 # Figure out what we need to build from the various variables
18 # ==========================================================================
20 subdir-ymn := $(sort $(subdir-y) $(subdir-m) $(subdir-) \
21 $(patsubst %/,%, $(filter %/, $(obj-y) $(obj-m) $(obj-))))
23 # Add subdir path
25 subdir-ymn := $(addprefix $(obj)/,$(subdir-ymn))
27 # build a list of files to remove, usually relative to the current
28 # directory
30 __clean-files := \
31 $(clean-files) $(targets) $(hostprogs) $(userprogs) \
32 $(extra-y) $(extra-m) $(extra-) \
33 $(always-y) $(always-m) $(always-) \
34 $(hostprogs-always-y) $(hostprogs-always-m) $(hostprogs-always-) \
35 $(userprogs-always-y) $(userprogs-always-m) $(userprogs-always-)
37 # deprecated
38 __clean-files += $(always) $(hostprogs-y) $(hostprogs-m) $(hostprogs-)
40 __clean-files := $(filter-out $(no-clean-files), $(__clean-files))
42 # clean-files is given relative to the current directory, unless it
43 # starts with $(objtree)/ (which means "./", so do not add "./" unless
44 # you want to delete a file from the toplevel object directory).
46 __clean-files := $(wildcard \
47 $(addprefix $(obj)/, $(filter-out $(objtree)/%, $(__clean-files))) \
48 $(filter $(objtree)/%, $(__clean-files)))
50 # ==========================================================================
52 quiet_cmd_clean = CLEAN $(obj)
53 cmd_clean = rm -rf $(__clean-files)
55 __clean: $(subdir-ymn)
56 ifneq ($(strip $(__clean-files)),)
57 $(call cmd,clean)
58 endif
62 # ===========================================================================
63 # Generic stuff
64 # ===========================================================================
66 # Descending
67 # ---------------------------------------------------------------------------
69 PHONY += $(subdir-ymn)
70 $(subdir-ymn):
71 $(Q)$(MAKE) $(clean)=$@
73 .PHONY: $(PHONY)