关于Makfile中PHONY的理解问题
时行居正 2015-11-20 10:12:31 1 背景
最近分析linux内核中的Makefile以及Makefile.build文件,在网上搜了一篇makefile.build,说是根据内核的改编,但是有关PHONY的理解不清楚。
2 问题描述
Makefile中通过如下代码转换到makefile.build文件
-----------------------------------------------------------------------------------
all :
make -C ./ -f $(TOPDIR)/Makefile.build
$(CC) $(LDFLAGS) -o $(TARGET) built-in.o
-----------------------------------------------------------------------------------
makefile.build代码部分截取如下
-----------------------------------------------------------------------------------
PHONY := __build
__build:
PHONY += $(subdir-y)
__build : $(subdir-y) built-in.o
$(subdir-y):
make -C $@ -f $(TOPDIR)/Makefile.build
built-in.o : $(cur_objs) $(subdir_objs)
$(LD) -r -o $@ $^
%.o : %.c
$(CC) $(CFLAGS) -Wp,-MD,$(dep_file) -c -o $@ $<
.PHONY : $(PHONY)
----------------------------------------------------------------------------------------
subdir-y 变量声明为PHONY可以理解,是想让它每次编译时必定执行,访问下级目录 。
可是__build为什么也要声明为PHONY,它是.build文件中第一个目标,应该肯定会被执行的啊。
我自己的理解会不会是因为Makfile中已经存在目标了all的原因,
如果是这样,make -C ./ -f $(TOPDIR)/Makefile.build 这句到底怎么理解 ?