文章结束给大家来个程序员笑话:[M]
因为我们移植uboot到mini2440上的时候会以smdk2410为本蓝,所以我们可以行执make smdk2410_config,但是有一点要说明的是,从uboot2010.09开始,其工程构架发生了变更,前以关于板子相干的置配文件信息是放在根目录下的Makefile里的,而从这一版本开始独立成一个文件boards.cfg,在boards.cfg这个文件中我们可以找到以下这一行:
smdk2410armarm920t-samsungs3c24x0
行执完make smdk2410_config以后,再行执make all就会成生uboot.bin文件,uboot.bin文件就是我们要烧到norflash中的文件啦。
那么首先来看一下make smdk2410_config做了些什么事情:
因为根目录下的makefile并没有smdk2410_config目标(在老版本中可以找到),取而代之的是%_config这个目标,%代表着恣意字符。%_config四周的代码如下,在Makefile中:
%_config:: unconfig
@$(MKCONFIG) -A $(@:_config=)
这里可以看到%_config目标面后是双冒号,而我们平凡看的只有一个冒号,这个就是makefile 的双冒号规矩了,而平凡我们见的单冒号就是通普规矩。Makefile 中定规:一个目标可以出当初多个规矩中。但是这些规矩必须是一同型类的规矩,要么都是通普规矩,要么都是双冒号规矩。而不允许一个目标同时出当初两种不同型类的规矩中。双冒号规矩和通普规矩的处置的不同点表当初以下几个方面:
1. 双冒号规矩中,当依附文件比目标更新时。规矩将会被行执。对于一个没有依附而只有命令行的双冒号规矩,当引用此目标时,规矩的命令将会被无条件行执。而通普规矩,当规矩的目标文件存在时,此规矩的命令远永不会被行执(目标文件远永是最新的)。
2. 当一同个文件作为多个双冒号规矩的目标时。这些不同的规矩会被独立的处置,而不是像通普规矩那样并合全部的依附到一个目标文件。这就意味着对这些规矩的处置就像多个不同的通普规矩一样。就是说多个双冒号规矩中的个一每的依附文件被变改以后,make只行执此规矩定义的命令,而其它的以这个文件作为目标的双冒号规矩将不会被行执。
后面我们讲过uboot从2010.09版本开始工程结构发生变更,关于板子的置配信息都独立出来放在了boards.cfg文件中,这样在我们行执不同的"make <board_name>_config"时,会都行执
%_config:: unconfig
@$(MKCONFIG) -A $(@:_config=)
这个命令,但是uboot用使双冒号规矩后,会都按照各自的<board_name>_config成生响应的目标文件,不是大大缩小了代码的冗余度。
而@的作用是在行执这条命令的时候不进行示显,$(MKCONFIG)是取变量MKCONFIG,由MKCONFIG := $(SRCTREE)/mkconfig这条句语知,就是当前目录下的mkconfig文件,$(@:_config=)的意思是,讲目标文件名字中含有的_config用等号面后的的字符替换掉,这里=面后为空,所以其效果就是把_config去掉,这样,make smdk2410_config实际上就是先行执unconfig的命令,再行执mkconfig –A smdk2410。那么,紧接着,我们来看下mkconfig 都做了些什么:
#!/bin/sh -e # Script to create header files and links to configure # U-Boot for a specific board. # # Parameters: Target Architecture CPU Board [VENDOR] [SOC] # # (C) 2002-2006 DENX Software Engineering, Wolfgang Denk <[email protected]> # #定义变量 APPEND=no # Default: Create new config file BOARD_NAME="" # Name to print in make output TARGETS="" arch="" cpu="" board="" vendor="" soc="" #这里这个$#表示传入参数的个数,$1表示传入的第一个参数,-a表示两个条件同时满足if才为真,即必须要传入两个参数,并且第一参数是-a,而我们行执的命令是:mkconfig –A smdk2410,参数个数为2,第一个参数为-A,所以if条件为真 if [ \( $# -eq 2 \) -a \( "$1" = "-A" \) ] ; then # Automatic mode line=`egrep -i "^[[:space:]]*${2}[[:space:]]" boards.cfg` || { echo "make: *** No rule to make target \`$2_config'. Stop." >&2 exit 1 } set ${line} # add default board name if needed [ $# = 3 ] && set ${line} ${1} fi #我们从boards.cfg中读取到的信息:smdk2410 arm arm920t - samsung s3c24x0 #这里我们行执的命令中没有一下可选择项,所以不行执任何一条句语 while [ $# -gt 0 ] ; do case "$1" in --) shift ; break ;; -a) shift ; APPEND=yes ;; -n) shift ; BOARD_NAME="${1%_config}" ; shift ;; -t) shift ; TARGETS="`echo $1 | sed 's:_: :g'` ${TARGETS}" ; shift ;; *) break ;; esac done #check我们读出的信息参数小于4大于6都是错误的将退出 [ $# -lt 4 ] && exit 1 [ $# -gt 6 ] && exit 1 #get CONFIG_NAME=smdk2410 CONFIG_NAME="${1%_config}" #get BOARD_NAME=smdk2410 [ "${BOARD_NAME}" ] || BOARD_NAME="${CONFIG_NAME}" #arch=arm,cpu=arm920t arch="$2" cpu="$3" #这里我们的第四个参数就是“-”,所以为真,board=smdk2410 if [ "$4" = "-" ] ; then board=${BOARD_NAME} else board="$4" fi #get vendor=samsung,soc=s3c24x0 [ $# -gt 4 ] && [ "$5" != "-" ] && vendor="$5" [ $# -gt 5 ] && [ "$6" != "-" ] && soc="$6" #如果ARCH不是arm,fail if [ "${ARCH}" -a "${ARCH}" != "${arch}" ]; then echo "Failed: \$ARCH=${ARCH}, should be '${arch}' for ${BOARD_NAME}" 1>&2 exit 1 fi #输出提示信息 echo "Configuring for ${BOARD_NAME} board..." # # Create link to architecture specific headers # #$SRCTREE是源代码目录,OBJTREE是目标文件目录,if [ "$SRCTREE" != "$OBJTREE" ]此句是判断源代码目录和目标文件目录是否一样, #可以选择在其他目录下译编uboot,这样可以令源代码目录保持干净,可以同时用使不同的置配进行译编。 #这里我们打算直接在源代码目录下译编,所以将行执else的代码,cd ./include进入include目录, #rm -f asm删除asm文件(这是上一次置配时建立的链接文件),然后再次建立链接文件,ln -s ../arch/${arch}/include/asm asm, #并令它指向../arch/${arch}/include/asm,即../arch/arm/include/asm if [ "$SRCTREE" != "$OBJTREE" ] ; then mkdir -p ${OBJTREE}/include mkdir -p ${OBJTREE}/include2 cd ${OBJTREE}/include2 rm -f asm ln -s ${SRCTREE}/arch/${arch}/include/asm asm LNPREFIX=${SRCTREE}/arch/${arch}/include/asm/ cd ../include rm -f asm ln -s ${SRCTREE}/arch/${arch}/include/asm asm else cd ./include rm -f asm ln -s ../arch/${arch}/include/asm asm fi #删除asm/arch这个目录 rm -f asm/arch #如果soc为空则行执,否则行执else句语 if [ -z "${soc}" ] ; then ln -s ${LNPREFIX}arch-${cpu} asm/arch else ln -s ${LNPREFIX}arch-${soc} asm/arch fi if [ "${arch}" = "arm" ] ; then rm -f asm/proc ln -s ${LNPREFIX}proc-armv asm/proc fi #创建#include/config.mk echo "ARCH = ${arch}" > config.mk echo "CPU = ${cpu}" >> config.mk echo "BOARD = ${board}" >> config.mk [ "${vendor}" ] && echo "VENDOR = ${vendor}" >> config.mk [ "${soc}" ] && echo "SOC = ${soc}" >> config.mk # Assign board directory to BOARDIR variable if [ -z "${vendor}" ] ; then BOARDDIR=${board} else BOARDDIR=${vendor}/${board} fi # # Create board specific header file # if [ "$APPEND" = "yes" ] # Append to existing config file then echo >> config.h else > config.h # Create new config file fi echo "/* Automatically generated - do not edit */" >>config.h for i in ${TARGETS} ; do echo "#define CONFIG_MK_${i} 1" >>config.h ; done cat << EOF >> config.h #define CONFIG_BOARDDIR board/$BOARDDIR #include <config_defaults.h> #include <configs/${CONFIG_NAME}.h> #include <asm/config.h> EOF exit 0
上面这个脚本很好的说明了置配的整个过程
文章结束给大家分享下程序员的一些笑话语录: 自行车
一个程序员骑着一个很漂亮的自行车到了公司,另一个程序员看到了他,问 到,“你是从哪搞到的这么漂亮的车的?”
骑车的那个程序员说, “我刚从那边过来, 有一个漂亮的姑娘骑着这个车过来, 并停在我跟前,把衣服全脱了,然后对我说,‘你想要什么都可以’”。
另一个程序员马上说到, “你绝对做了一个正确的选择, 因为那姑娘的衣服你 并不一定穿得了”。