uboot之—make smdk2410_config命令详细解析

uboot之—make smdk2410_config命令详细解析

大家好,又见面了,我是全栈君。

先进入顶层Makefile。有很多相对不同板子的配置,如:

gec2440_config:unconfig

  @$(MKCONFIG) $(@:_config=) arm arm920t gec2440 samsung s3c24x0

 

1.配置编译uboot第一步都是make *****_config。既然是make就得执行Makefile。makefile就包括很多上面的语句,make *****_config,首先执行的就是上面的配置信息。 @$(MKCONFIG)啥意思,其实在Makefile前面就有定义 @$(MKCONFIG) := $(SRCTREE)/mkconfig,也就是根目录的mkconfig文件。$(@:_config=)的意思就是吧make *****_config的_config给去到。所以gec2440_config执行./mkconfig  gec2440  arm arm920t gec2440 samsung s3c24x0。而unconfig的作用在于去除原先的配置信息,即make ***_config与make unconfig互逆关系。

 

2.OK,现在执行make gec2440_config,那么就会出现:

   Configuring for gec2440 board…

     现在看看有发生那些变化。由于上面的命令相当于执行./mkconfig  arm arm920t gec2440 samsung s3c24x0。所以先进去根目录的mkconfig文件看看。

首先,要明确一点:./mkconfig  gec2440  arm arm920t gec2440 samsung s3c24x0使得$0=./mkconfig,$1=arm,$2=arm920t,$3=gec2440, $4=samsung, $5=s3c24x0

下面是mkconfig的内容:

APPEND=no # 这里记得APPEND初值为no
BOARD_NAME=””
TARGETS=””

#下面一段代码不执行(while—done),由于./mkconfig  arm arm920t gec2440 samsung s3c24x0没有–、-a、-n、-t

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

[ “${BOARD_NAME}” ] || BOARD_NAME=”$1″  //BOARD_NAME=gec2440

[ $# -lt 4 ] && exit 1
[ $# -gt 6 ] && exit 1

if [ “${ARCH}” -a “${ARCH}” != “$2” ]; then
echo “Failed: \$ARCH=${ARCH}, should be ‘$2’ for ${BOARD_NAME}” 1>&2
exit 1
fi

//在终端打印Config  for gec2440  board….
echo “Configuring for ${BOARD_NAME} board…”

#
# 产生链接文件
#
if [ “$SRCTREE” != “$OBJTREE” ] ; then   //是否在源代码目录下编译Uboot,不是就执行下面,else就是表示是在源代码目录编译
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    //进入include
rm -f asm
ln -s asm-$2 asm    //ln -s  include/asm-arm   asm
fi

rm -f asm-$2/arch            //删除include/asm-arm/arch

if [ -z “$6” -o “$6” = “NULL” ] ; then   //由于$6=s3c24x0,执行而else下面
ln -s ${LNPREFIX}arch-$3 asm-$2/arch   
else
ln -s ${LNPREFIX}arch-$6 asm-$2/arch  //ln -s include/arch-s3c24x0  include/asm-arm/arch
fi

if [ “$2” = “arm” ] ; then
rm -f asm-$2/proc  //删除include/asm-arm/proc
ln -s ${LNPREFIX}proc-armv asm-$2/proc  //ln -s include/proc-arm asm-arm/pro
fi

#
# Create include file for Make
#
echo “ARCH   = $2” >  config.mk   //ARCH=arm,放入include/config.mk
echo “CPU    = $3” >> config.mk  //CPU=arm920t,放入includde/config.mk
echo “BOARD  = $4” >> config.mk //BOARD=gec2440,放入include/config.mk

[ “$5” ] && [ “$5” != “NULL” ] && echo “VENDOR = $5” >> config.mk
//VERDOR=samaung,放入include/config.mk
[ “$6” ] && [ “$6” != “NULL” ] && echo “SOC    = $6” >> config.mk
//SOC=s3c24x0,放入include/config.mk
#
# Create board specific header file
#
if [ “$APPEND” = “yes” ] # 有第一行知道,APPEND=no
then
echo >> config.h
else
> config.h  #产生config.h文件,位于include目录下
echo “/* Automatically generated – do not edit */” >>config.h

for i in ${TARGETS} ; do
echo “#define CONFIG_MK_${i} 1” >>config.h ;
//将”#define CONFIG_MK_${i} 1加入上面产生的config.h文件
done

echo “#include <configs/$1.h>” >>config.h  //config.h文件包含头文件”#include <configs/gec2440.h>
echo “#include <asm/config.h>” >>config.h //config.h文件包含头文件”#include <asm/config.h>

exit 0

 

3.上面红色部分就是改变部分。到现实中的源代码看看,

大家执行完make gec2440_config之后,到源代码看看。

第一就是ARCH、CPU、BOARD、VERDOR、SOC被赋值,

并加入include/config.mk文件中,

我的config.mk文件内容如下:

ARCH   = arm
  CPU    = arm920t
  BOARD  = gec2440
  VENDOR = samsung
  SOC    = s3c24x0

第二就是看一下链接文件,我的情况如下:

进入include目录下:

#ll

lrwxrwxrwx  1 root root      7 04-01 21:36 asm -> asm-arm

进入include/asm-arm目录下:

lrwxrwxrwx 1 root root     12 04-01 21:36 arch -> arch-s3c24x0

…………

lrwxrwxrwx 1 root root      9 04-01 21:36 proc -> proc-armv

第三就是在include目录下产生新文件:config.h.里面包含几个头文件,我的是:   /* Automatically generated – do not edit */
  #include <configs/gec2440.h>
  #include <asm/config.h>           

转载于:https://www.cnblogs.com/wlzy/p/6039434.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/108799.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • TortoiseSVN 设置中文语言包

    TortoiseSVN 设置中文语言包

    2021年11月7日
    40
  • 6种常见的测试用例设计方法及应用_测试用例设计的方法

    6种常见的测试用例设计方法及应用_测试用例设计的方法测试前准备作为一个测试人员,软件测试的流程首先是要非常熟悉的,何时何地都能脱口而出,避免一切翻车的可能。需要注意的是流程没有唯一答案,具体由项目决定。所以给出的只是一个还算通用的参考流程。  我们要熟知的测试流程:  总结一下:在测试流程中,有6个部分,其中3个部分涉及到了用例,可见写好用例的重要性。  所以,结合这些年吃过的亏,我来给大家缕缕,如何快速的get到测试用例的设计方法。  5种常见的测试用例设计方法  一、等价类划分  1)概念  某个输入域的集合,在这个集合中每个输入条件都是

    2022年10月9日
    0
  • jax-ws使用教程_JAX-WS教程

    jax-ws使用教程_JAX-WS教程jax-ws使用教程WelcometoJAX-WSTutorial.WebServicesworkonclient-servermodelwheretheycommunicateoverthenetwork.ServersidecomponentprovidestheendpointURLwhereserviceislocatedandcli…

    2022年7月15日
    16
  • 设计模式——六大原则[通俗易懂]

    设计模式——六大原则[通俗易懂]设计模式——六大原则

    2022年4月24日
    34
  • 线程join方法用处「建议收藏」

    线程join方法用处「建议收藏」参考博客:https://www.cnblogs.com/lcplcpjava/p/6896904.html第一种情况(不使用join):ThreadJoinTestt1=newThreadJoinTest(“小明”);ThreadJoinTestt2=newThreadJoinTest(“小东”);t1.start();

    2022年5月24日
    35
  • c语言中system函数怎么用_system函数的返回值

    c语言中system函数怎么用_system函数的返回值C语言中如何使用system函数一.system函数c语言中的system()函数主要用于发出一个DOS命令,该函数已经收录在标准c库中,可以直接调用。使用时包含头文件<stdlib.h>补充:DOS:DOS是DiskOperatingSystem的缩写,即磁盘操作系统。它是一个基于磁盘管理的操作系统。DOS命令:是指DOS操作系统的命令,是一种面向磁盘的操作命令,主要包括目录操作类命令、磁盘操作类命令、文件操作类命令和其它命令。(学习DOS命令是控制微机的基础)提供用户使用的

    2022年9月15日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号