uboot中mkconfig详细分析-- 转载

来源:互联网 发布:lte网络优化工程师初级 编辑:程序博客网 时间:2024/05/21 05:20

现在来分析$(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,表示正常执行了本脚本。

 

原创粉丝点击