makefile中的@ $ :

mac2023-06-09  28

MKCONFIG := $(SRCTREE)/mkconfig smdk2410_config : unconfig @$(MKCONFIG) $(@:_config=) arm arm920t smdk2410 NULL s3c24x0

@$(MKCONFIG)   @表示在执行命令时不输出命令本身(不回显),只输出命令执行的结果                                 $(MKCONFIG)表示(MKCONFIG) 这个变量的值mkconfig $(@:_config=)   这里用到了makefile的变量替换规则,$(VAR:A=B)表示替换变量$(VAR)中的A为B,                                 即把$@中的_config替换为空变成smdk2410,$@ 目标文件名称(这里就是smdk241_config),$^ 所有的依赖文件,$< 第一个依赖文件。

:= ,=,?=的区别 :=不递归赋值 = 递归赋值 ?=默认值    “:=” 的意思是,它右边赋得值如果是变量,只能使用在这条语句之前定义好的,而不能使用本条语句之后定义的变量; 于此对应的是“=”,当它的右边赋值是变量时,这个变量的定义在本条语句之前或之后都可以; 而“?=”是指,该符号左边的变量,如果在本条语句之前没有定义过,则执行本语句,如果已经定义,那么本语句什么都不做

$0 $1 $2 ……$n 表示命令行的参数,$0是命令本身,$1是第一个参数,$n是第n个参数  

最新回复(0)