makefile中的@ $ :

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个参数
 

你可能感兴趣的:(makefile知识)