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