现在来分析$(SRCTREE)/mkconfig文件的内容。在分析内容之前,为了方便,我把传入到此脚本中的参数都列出来,方便后面备查:smdk2410 arm arm920t smdk2410 NULL s3c24x0
#!/bin/sh -e
这是第一行的内容,表示这个shell脚本的解释器是/bin/sh,给的解释器的参数为-e,这个参数的意思就是,当shell返回值为非零值的时候,shell马上退出执行。
说个题外话,在shell脚本里也可以没有这一行,这一行不是必须的,如果没有这一行的话,那么shell脚本就会用当前运行环境下的默认的shell来执行。
_________________________________________________
APPEND=no # Default: Create new config file
BOARD_NAME="" # Name to print in make output
while [ $# -gt 0 ] ; do
case "$1" in
--) shift ; break ;;
-a) shift ; APPEND=yes ;;
-n) shift ; BOARD_NAME="${1%%_config}" ; shift ;;
*) break ;;
esac
done
_________________________________________________
首先是把APPEND变量与BOARD_NAME变量都设置了默认值,如果后面对变量值有修改就以后面的为准,没有就是默认值了。这里的 APPEND的参数的意义,实际上就是用来标识是否产生一个新的配置文件,还是直接把生成的配置信息写到旧文件后面。
$#代表的是传入脚本的参数的个数,-gt表示是如果左边参数比右边参数大,则返回true,否则为false。$1代表的是传入的第一个参数的内容,$2表示传入的第二个参数的内容,以此类推。shift表示参数都左移一位,原来的$3变为$2,$2为$1,$1的内容则被丢弃。
这样就可以看出来,这个地方,实际上是处理了一些附加的参数的问题,如果是--,则仅丢弃不做其它处理;如果是-a,则把APPEND的值置为 yes;如果是-n,则表示后面跟的是板子的名字。${a%%pattern}是shell中的一个替换语法,表示把变量a中的内容,从右至左,最大程度上把符合pattern样式的字符串删掉。这里可以看出,如果-n后面跟的是类似于咱们之前的那个smdk2410_config的参数的话,则最后会变成smdk2410;如果是其它的值,则退出循环,不执行了。咱们在Makefile中的动作,其实并不会触发这里的处理逻辑,我估计这里是作者为了调试方便,需要单独运行此脚本的时候,加的一些对参数的处理。
_________________________________________________
[ "${BOARD_NAME}" ] || BOARD_NAME="$1"
[ $# -lt 4 ] && exit 1
[ $# -gt 6 ] && exit 1
echo "Configuring for ${BOARD_NAME} board..."
__________________________________________________
第一行的语法之前已经交待过,如果BOARD_NAME没有被设置过,则把它置为变量1的值。
然后进行参数个数的判断,-lt表示less than则返回true,也就是如果参数少于4个或是参数大于6个,则退出,不执行。
如果没有退出执行的话,则输出Configuring for ${BOARD_NAME} board...这句话,其中${BOARD_NAME}会被替换成用户输入的板子的名字。
___________________________________________________
if [ "$SRCTREE" != "$OBJTREE" ] ; then
mkdir -p ${OBJTREE}/include
mkdir -p ${OBJTREE}/include2
cd ${OBJTREE}/include2
rm -f asm
ln -s ${SRCTREE}/include/asm-$2 asm
LNPREFIX="../../include2/asm/"
cd ../include
rm -rf asm-$2
rm -f asm
mkdir asm-$2
ln -s asm-$2 asm
else
cd ./include
rm -f asm
ln -s asm-$2 asm
fi
rm -f asm-$2/arch
____________________________________________________
咱们先来看看当用户指定的$OBJTREE与$SRCTREE不一致的时候会做一些什么事情。
1.在$OBJTREE下建立 include文件夹
2.在$OBJTREE下建立include2文件夹
3.进入到include2文件夹,其实就是$OBJTREE文件夹下的include2
4.删除asm,其实往后看就知道了,这是一个文件夹,是以link的方式建立的
5. 然后建立一个asm的文件夹,这个文件夹是指向${SRCTREE}/include/asm-$2的,其实就是指向${SRCTREE} /include/asm-arm的
6.给变量LNPREFIX赋值。这个变量在以后的执行会用到,所以这里给的asm的位置,是相对于后来执行的时候,当前工作目录与asm之间的关系来定的。
7.进入到$OBJTREE中的include文件夹(之前是在include2里)。
8. 删除掉asm-$2文件夹,其实就是asm-arm文件夹。
9.删除掉asm文件夹
10.建立一个新的asm-$2文件夹,其实就是 asm-arm文件夹
11.建立一个名为asm的link,这个link指向新建立的asm-arm文件夹。
现在看一下整个目录大概的结构:
${OBJTREE}
include
asm-arm
asm -> ./asm-arm
include2
asm -> ${SRCTREE}/include/asm-arm
可以看到,目前在include下的asm-arm与asm其实是同一个文件夹,并且内容为空,include2文件夹下的asm是指向了源码树中的${SRCTREE}/include/asm-arm文件夹。
如果"$SRCTREE"与"$OBJTREE"是同一个文件(大多数情况下,咱们都是这种方式来编译的),那么就是仅仅在include 文件夹下,建立一个名为asm的link,直接指向asm-$2,即asm-arm。
最后删除asm-arm/arch文件夹。
______________________________________________________
if [ -z "$6" -o "$6" = "NULL" ] ; then
ln -s ${LNPREFIX}arch-$3 asm-$2/arch
else
ln -s ${LNPREFIX}arch-$6 asm-$2/arch
fi
if [ "$2" = "arm" ] ; then
rm -f asm-$2/proc
ln -s ${LNPREFIX}proc-armv asm-$2/proc
fi
______________________________________________________
第一句中连接两个判断的-o,相当于or的意思,这个我在文档里没有查到,但是经过实验,就是表示的“或”。意思就是如果第6个参数为空或是为 NULL,则执行
ln -s ${LNPREFIX}arch-$3 asm-$2/arch
这条语句是在include 下建立一个asm-$2/arch的link,也即asm-arm/arch,指向${LNPREFIX}arch-$3,即arch-arm920t
否则就执行
ln -s ${LNPREFIX}arch-$6 asm-$2/arch
这条语句是在include下建立一个asm-$2/arch的link,也即asm-arm/arch,指向${LNPREFIX}arch-$6,即arch-s3c24x0
________________________________________________________
if [ "$2" = "arm" ] ; then
rm -f asm-$2/proc
ln -s ${LNPREFIX}proc-armv asm-$2/proc
fi
________________________________________________________
这段的意思就是,如果第二个参数是arm的话,则执行
1.删除include/asm-$2/proc文件,实际上就是include /asm-arm/proc文件夹
2.建立一个新的link,在include/asm-$2/proc处,也即include/asm- arm/proc,指向${LNPREFIX}proc-armv文件夹
________________________________________________________
echo "ARCH = $2" > config.mk
echo "CPU = $3" >> config.mk
echo "BOARD = $4" >> config.mk
[ "$5" ] && [ "$5" != "NULL" ] && echo "VENDOR = $5" >> config.mk
[ "$6" ] && [ "$6" != "NULL" ] && echo "SOC = $6" >> config.mk
#
# 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
echo "#include <configs/$1.h>" >>config.h
exit 0
__________________________________________________________
第一行,输出ARCH = $2,即ARCH = arm到config.mk,也即include/config.mk,注意这里用了一个>,它表示重新生成一个config.mk文件,如果有旧的,则覆盖
第二行,同理,输出CPU = arm920t到config.mk中
第三行,同理,输出BOARD = smdk2410到config.mk
第四行,判断,如果$5不为空,且$5的值不为NULL,则把VENDOR = $5的值输出到config.mk中,但是这里,VENDOR是为NULL,所以不作输出
第五行,同理,把SOC = s3c24x0输出到config.mk中
后面的一组判断,就是判断,如果APPEND的值为yes,则写入一空行到已经存在的config.h中,也即include/config.h 中,如果不是,则生成一个新的config.h,如果旧的文件存在,则覆盖。
后面几个语句就很简单了,直接输出内容到config.h里了,然后退出,返回值为0,表示正常执行了本脚本。