从0移植uboot (一) _配置分析

来源:Linux社区  作者:xiaojiang1025  :http://www.linuxidc.com/Linux/2017-02/141018.htm

和绝大多数源码编译安装一样,uboot的编译流程也类似于"make config->make->make install"**三步,只是由于uboot本身是针对多种平台的bootloader,软件的复杂性和通用型决定了编译uboot需要自行填补很多坑。本文主要讨论的就是移植uboot-2013.01的第一个坑——uboot分析。

配置编译环境

既然要编译uboot,首先就要有相应的编译器,我的目标板是三星的exynos4412,就是一个ARM核的SoC,这意味着两件事,第一,我编译的时候必须写明"export ARCH=arm"来表明我要编译的目标平台。第二,必须选择合适的开发工具,由于各种uboot各种linux都是对编译器比较敏感的,所以强烈建议使用tar来安装交叉编译器而不是apt,这样可以防止多个编译工具的冲突,这里,uboot作为裸板程序,我用的是arm-none-linux-guneabi-xxx的编译器,所以用来编译的脚本加了下面两句:

export ARCH=arm
export CROSS_COMPILE=/opt/arm-cross-compile/arm-none-linux-gnueabi-2014-05/bin/arm-none-linux-gnueabi-
...

config的流程

uboot的顶层配置主要依靠下面的这棵树

.
├── Makefile
├── mkconfig
├── include
│    ├── config.mk
│  └── config.h
└── boards.cfg

uboot的配置就是通过键入相应的命令将相应的Makfile变量赋值,通过你的配置,Makefile相应的变量就知道编译哪个平台下的哪个cpu的哪个版本的开发板。注意:不同版本的uboot的配置命令可能是不同的,拿到源码包看README是个很好的习惯,比如uboot-2013-01的配置命令是下面这个样子的,但uboot-2016.10的配置命令就不是这个,感兴趣的可以查一下。:

在uboot-2013-01中,顶层目录下的boards.cfs文件中查看它支持的开发板和相应的信息,这个文件就像一个全局的"字典",后续的编译过程需要根据配置名检索到相应的信息,所以不要随意修改。下面这个就是字典的样子

了解了这些,手痒的话就可以先执行下面的脚本试一下,但是并不会生成真正适配我们板子的uboot,只是适配参考板

#!/bin/bash

export ARCH=arm
export CROSS_COMPILE=/opt/arm-cross-compile/arm-none-linux-gnueabi-2014-05/bin/arm-none-linux-gnueabi-
make origen_config
make all

config的分析

首先,当我们"make origen_config"的时候,显然是打算创建makefile里面的一个叫origen_config的目标。根据Makefile的语法,我们就可以找到下面这一段(然而并不是想象中的origen_config:)

Makefile
--770-->unconfig目标的作用是删除所有由于配置产生的文件
--775-->%是Makefile中的通配符,表示任意字符串,所以我们的origen_config就会与之相匹配,这个目标的依赖于unconfig,即每次config之前都会删除之前的配置。如果你键入两次"make xxx_config",那么它最终只会形成一个相应的配置文件,这种写法值得借鉴
--776-->"MKCONFIG"就是顶层目录下的mkconfig脚本,而"$(@:_config=)"就是去除目标中的"_config"串,所以实际上就是去到顶层目录下执行"$mkconfig -A origen"

我们去到这个mkconfig看看它都做了什么

mkconfig
--22-->我们传入的参数会导致脚本执行这个if里面的内容
--23-31-->用扩展正则表达式去顶层目录下的boads.cfg文件中提取含有origen相应的行到line变量中,并把line设置为新的参数列表。取得了这个参数字符串,mkconfig就可以把相应的头文件,链接和全局变量准备好。

我们来稍微看点细节,首先,line里应该有的内容是我们在Boards.cfg中搜到的这个:

根据boards.cfg,这几个参数分别是:TARGET,ARCH,CPU,Board name,Vendor,SoC,Options(origen只有6个,加上之前的$1一共7个参数),So执行的代码是:

从中可以看出,这段代码就是把之前line的内容分段并赋值给开头的arch、cpu、board等变量,显然,这些变量对于我们找到相应的目录,相应的文件进行编译至关重要。这些信息,会在mkconfig的之后写入到相应的文件中:

此外,还要建立一些硬链接:

至此,我们需要的"include/config.mk"就配置完成了,这个文件是长成这个样子的:

除了生成"include/config.mk"mkconfig还负责生成"include/config.h"文件,不过有了之前准备好的变量,这部分只不过是将上面的变量和相应的文件夹进行了初步的定位,代码就是下面这部分:

它生成的"include/config.h"最终是长成这个样子的:

有了这两个文件,当我们再执行"$make"的时候就可以找到相应的文件了。

原文地址:https://www.cnblogs.com/icefree/p/8491268.html

时间: 2024-10-18 01:26:52

从0移植uboot (一) _配置分析的相关文章

从0移植uboot (二) _启动流程分析

来源:Linux社区  作者:xiaojiang1025  : http://www.linuxidc.com/Linux/2017-02/141019.htm 经过了上一篇的配置,我们已经执行make就可以编译出一个uboot.bin,但这还不够,首先,此时的uboot并不符合三星芯片对bootloader的格式要求,其次,此时的uboot.bin也没有结合我们的开发板进行配置,还无法使用.而要进行这样的个性化配置,前提条件就是对uboot开机流程和编译系统有所了解,本文主要讨论前者.uboo

从0移植uboot(三) _编译最小可用uboot

来源:Linux社区  作者:xiaojiang1025  :http://www.linuxidc.com/Linux/2017-02/141020.htm 前两篇介绍了uboot-2013.01的配置原理以及大体的运行流程,本文将讨论如何对uboot源码进行配置,将一个可用的uboot烧录到SD卡中. 定制自己的core board 市面上能买到的开发板的核心板基本都是基于官方参考板制作的,所以虽然标准操作是"定制"自己的core board,但鉴于我的板子的核心板是基于三星的参考

uboot移植——uboot源码目录分析

uboot移植(一)--uboot源码目录分析 本文分析的uboot是九鼎官方提供的,是对应s5pv210开发板x210bv3的uboot 一:uboot的概念及移植的原理. uboot就是在内核运行前的一段小程序,用来初始化硬件设备,建立内存空间映射图.从而将系统的软硬件带到合适的状态,主要功能就是为了启动内核,它将内核从flash中拷贝到ddr中,然后跳转到内核入口中,交由内核控制权,uboot严重依赖硬件,因此一个通用的uboot不太可能. 移植原理:uboot中有很多平行代码,各自属于各

linux移植u-boot(一)——U-Boot详解+自定义命令实战

linux移植u-boot(一)--U-Boot详解+自定义命令实战 2015-02-07 一.Bootloader ????简单地说:Bootloader主要功能就是 在系统上电时开始执行,初始化硬件和设备,准备好软件环境,最后调用操作系统. ????具体的包含:关闭你看门狗WATCHDOG,改变系统时钟,初始化存储控制器 ,将操作系统内核代码复制到内存中去运行. ????为了开发方便,可以增加网络功能,从PC上通过串口或者网络下载文件,烧写文件,将flash上的内核代码解压后运行等. Boo

移植 U-Boot(一)

1.Bootloader作用: 在系统上电时,初始化硬件设备.准备好软件环境.最后调用操作系统内核,将系统内核复制到内存中运行. 2.Bootloader的起始地址:     ARM架构的CPU从地址0x0000000开始取第一条指令,该地址也是Bootloader的起始地址. 3.Bootloader的启动方式: 启动加载模式:上电后,Bootloader从板子的某个固态存储设备上将操作系统加载到RAM中运行,整个过程不需要用户的介入,用于产品发布. 下载模式:开发人员各种命令,通过串口连接或

at91sam9260ek的移植 — U-boot(V1.3.4)

at91sam9260ek的移植 - U-boot(V1.3.4) 关于移植在U-boot文档中这样介绍: README If the system board that you have is not listed, then you will need to port U-Boot to your hardware platform. To do this, follow these steps: 1. Add a new configuration option for your boar

uboot源码简要分析

uboot源码简要分析 一.uboot源码整体框架 源码解压以后,我们可以看到以下的文件和文件夹: cpu 与处理器相关的文件.每个子目录中都包括cpu.c和interrupt.c.start.S.u-boot.lds. cpu.c:初始化CPU.设置指令Cache和数据Cache等 interrupt.c:设置系统的各种中断和异常 start.S:是U-boot启动时执行的第一个文件,它主要做最早期的系统初始化,代码重定向和设置系统堆栈,为进入U-boot第二阶段的C程序奠定基础. u-boo

U-BOOT第一阶段程序分析(1)

分析移植之前先介绍下我的软硬件环境: 开发板:JZ2440v2板 CPU   :ARM920T SOC   :S3C2440 晶振freq:12MHz NorFlash:2MB => Am29LV160DB NandFlash:256MB => K9F2G08U0A SDRAM:32MB X 2pieces => K4S561632H-T(U)C(16M X 16bit) U-BOOT版本:u-boot-1.1.6.tar.bz2 我移植的uboot是基于nand启动的,所以代码的分析过

Linux主机上使用交叉编译移植u-boot到树莓派

0环境 Linux主机OS:Ubuntu14.04 64位,运行在wmware workstation 10虚拟机 树莓派版本:raspberry pi 2 B型. 树莓派OS: Debian Jessie Raspbian Jessie 1树莓派的启动过程 树莓派1,2,3的启动过程大致相同,主要分为3个阶段:ROM上的GPU bootloader启动GPU,GPU启动CPU,CPU直接启动内核或通过u-boot启动内核. 由于树莓派涉及到GPU的东西不开源,移植u-boot到树莓派并不是真正