📄 rules.make
字号:
## This file contains rules which are shared between multiple Makefiles.### False targets.#.PHONY: dummy## Special variables which should not be exported#unexport EXTRA_AFLAGSunexport EXTRA_CFLAGSunexport EXTRA_LDFLAGSunexport EXTRA_ARFLAGSunexport SUBDIRSunexport SUB_DIRSunexport ALL_SUB_DIRSunexport O_TARGETunexport obj-yunexport obj-nunexport obj-unexport export-objsunexport subdir-yunexport subdir-munexport subdir-nunexport subdir-## Get things started.#first_rule: sub_dirs $(MAKE) all_targetsboth-m := $(filter $(mod-subdirs), $(subdir-y))SUB_DIRS := $(subdir-y)ALL_SUB_DIRS := $(sort $(subdir-y) $(subdir-m) $(subdir-n) $(subdir-))## Common rules#%.s: %.c $(CC) $(CFLAGS) $(EXTRA_CFLAGS) $(CFLAGS_$@) -S $< -o $@%.i: %.c $(CPP) $(CFLAGS) $(EXTRA_CFLAGS) $(CFLAGS_$@) $< > $@%.o: %.c $(CC) $(CFLAGS) $(EXTRA_CFLAGS) $(CFLAGS_$@) -c -o $@ $< @ ( \ echo 'ifeq ($(strip $(subst $(comma),:,$(CFLAGS) $(EXTRA_CFLAGS) $(CFLAGS_$@))),$$(strip $$(subst $$(comma),:,$$(CFLAGS) $$(EXTRA_CFLAGS) $$(CFLAGS_$@))))' ; \ echo 'FILES_FLAGS_UP_TO_DATE += $@' ; \ echo 'endif' \ ) > $(dir $@)/.$(notdir $@).flags%.o: %.s $(AS) $(AFLAGS) $(EXTRA_CFLAGS) -o $@ $<%.s: %.S $(CPP) $(AFLAGS) $(EXTRA_AFLAGS) $(AFLAGS_$@) $< > $@%.o: %.S $(CC) $(AFLAGS) $(EXTRA_AFLAGS) $(AFLAGS_$@) -c -o $@ $<%.lst: %.c $(CC) $(CFLAGS) $(EXTRA_CFLAGS) $(CFLAGS_$@) -g -c -o $*.o $< $(TOPDIR)/scripts/makelst $* $(TOPDIR) $(OBJDUMP)###all_targets: $(O_TARGET) $(L_TARGET)## Rule to compile a set of .o files into one .o file#ifdef O_TARGET$(O_TARGET): $(obj-y) rm -f $@ ifneq "$(strip $(obj-y))" "" $(LD) $(EXTRA_LDFLAGS) -r -o $@ $(filter $(obj-y), $^) else $(AR) rcs $@ endif @ ( \ echo 'ifeq ($(strip $(subst $(comma),:,$(EXTRA_LDFLAGS) $(obj-y))),$$(strip $$(subst $$(comma),:,$$(EXTRA_LDFLAGS) $$(obj-y))))' ; \ echo 'FILES_FLAGS_UP_TO_DATE += $@' ; \ echo 'endif' \ ) > $(dir $@)/.$(notdir $@).flagsendif # O_TARGET## Rule to compile a set of .o files into one .a file#ifdef L_TARGET$(L_TARGET): $(obj-y) rm -f $@ $(AR) $(EXTRA_ARFLAGS) rcs $@ $(obj-y) @ ( \ echo 'ifeq ($(strip $(subst $(comma),:,$(EXTRA_ARFLAGS) $(obj-y))),$$(strip $$(subst $$(comma),:,$$(EXTRA_ARFLAGS) $$(obj-y))))' ; \ echo 'FILES_FLAGS_UP_TO_DATE += $@' ; \ echo 'endif' \ ) > $(dir $@)/.$(notdir $@).flagsendif## This make dependencies quickly#fastdep: dummy $(TOPDIR)/scripts/mkdep $(CFLAGS) $(EXTRA_CFLAGS) -- $(wildcard *.[chS]) > .dependifdef ALL_SUB_DIRS $(MAKE) $(patsubst %,_sfdep_%,$(ALL_SUB_DIRS)) _FASTDEP_ALL_SUB_DIRS="$(ALL_SUB_DIRS)"endififdef _FASTDEP_ALL_SUB_DIRS$(patsubst %,_sfdep_%,$(_FASTDEP_ALL_SUB_DIRS)): $(MAKE) -C $(patsubst _sfdep_%,%,$@) fastdependif ## A rule to make subdirectories#subdir-list = $(sort $(patsubst %,_subdir_%,$(SUB_DIRS)))sub_dirs: dummy $(subdir-list)ifdef SUB_DIRS$(subdir-list) : dummy $(MAKE) -C $(patsubst _subdir_%,%,$@)endif## A rule to do nothing#dummy:## This is useful for testing#script: $(SCRIPT)## include dependency files if they exist#ifneq ($(wildcard .depend),)include .dependendififneq ($(wildcard $(TOPDIR)/.hdepend),)include $(TOPDIR)/.hdependendif## Find files whose flags have changed and force recompilation.# For safety, this works in the converse direction:# every file is forced, except those whose flags are positively up-to-date.#FILES_FLAGS_UP_TO_DATE :=# For use in expunging commas from flags, which mung our checking.comma = ,FILES_FLAGS_EXIST := $(wildcard .*.flags)ifneq ($(FILES_FLAGS_EXIST),)include $(FILES_FLAGS_EXIST)endifFILES_FLAGS_CHANGED := $(strip \ $(filter-out $(FILES_FLAGS_UP_TO_DATE), \ $(O_TARGET) $(L_TARGET) $(active-objs) \ ))# A kludge: .S files don't get flag dependencies (yet),# because that will involve changing a lot of Makefiles. Also# suppress object files explicitly listed in $(IGNORE_FLAGS_OBJS).# This allows handling of assembly files that get translated into# multiple object files (see arch/ia64/lib/idiv.S, for example).FILES_FLAGS_CHANGED := $(strip \ $(filter-out $(patsubst %.S, %.o, $(wildcard *.S) $(IGNORE_FLAGS_OBJS)), \ $(FILES_FLAGS_CHANGED)))ifneq ($(FILES_FLAGS_CHANGED),)$(FILES_FLAGS_CHANGED): dummyendif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -