Linux内核---5.Makefile显示打印信息

来源:互联网 发布:乌克兰 知乎 编辑:程序博客网 时间:2024/05/21 11:02

编译内核make的时候,通常在terminal上打印的信息非常少,隐藏了编译和连接的过程。想显示编译全过程可以简单的加上 "V=1"。

  root@ubuntu:~/kernel/linux-2.6.30.4# make zImage V=1

下面分析一下加V=1与不加V=1的区别:

38 ifdef V 
39   ifeq ("$(origin V)", "command line") 
40     KBUILD_VERBOSE = $(V) 
41   endif 
42 endif 
43 ifndef KBUILD_VERBOSE 
44   KBUILD_VERBOSE = 0 
45 endif

origin关键字不对变量起作用,只是确定变量从何而来。

$(origin variable)的返回值 command line说明,变量V是在命令行中定义的。 KBUILD_VERBOSE = $(V) = 1

290 ifeq ($(KBUILD_VERBOSE),1) 
291   quiet = 
292   Q = 
293 else 
294   quiet=quiet_ 
295   Q = @ 
296 endif

当KBUILD_VERBOSE==1时,Q和quiet都为空

当在命令前有@时,不会打印命令行本身,测试代码如下:

点击(此处)折叠或打开

  1. root@ubuntu:~/test# cat Makefile
  2. all:
  3.     @echo "@echo"
  4. root@ubuntu:~/test# make
  5. @echo

当在命令前没有@时,会打印命令行本身,测试代码如下:

点击(此处)折叠或打开

  1. root@ubuntu:~/test# cat Makefile
  2. all:
  3.     echo "no_@echo"
  4. root@ubuntu:~/test# make
  5. echo "no_@echo"
  6. no_@echo
所以当$(Q)为空时,再出现类似于:$(Q)$(MAKE) -C $(srctree) KBUILD_SRC= $@都会打印信息。

还有一处地方:

127 sub-make: FORCE 
128     $(if $(KBUILD_VERBOSE:1=),@)$(MAKE) -C $(KBUILD_OUTPUT) \

这个是什么东东?有没有用到?现在还不太清楚,研究一下这个再说。

0 0
原创粉丝点击