第一范文网 - 专业文章范例文档资料分享平台

U-BOOT的启动流程及移植

来源:用户分享 时间:2025/9/25 10:16:36 本文由loading 分享 下载这篇文档手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:xxxxxxx或QQ:xxxxxx 处理(尽可能给您提供完整文档),感谢您的支持与谅解。

11U-BOOT的启动流程及移植

摘要:嵌入式系统一般没有通用的bootloader,u-boot是功能强大的bootloader开发软件,但相对也比较复杂。文中对u-boot的启动流程作了介绍,详细给出了u-boot在S3C44B0开发板上的移植方法和步骤。

1 Bootloader及u-boot简介

Bootloader 代码是芯片复位后进入操作系统之前执行的一段代码,主要用于完成由硬件启动到操作系统启动的过渡,从而为操作系统提供基本的运行环境,如初始化CPU、 堆栈、存储器系统等。Bootloader 代码与CPU 芯片的内核结构、具体型号、应用系统的配置及使用的操作系统等因素有关,其功能类似于PC机的BIOS程序。由于bootloader和CPU及电路板的配置情况有关,因此不可能有通用的bootloader ,开发时需要用户根据具体情况进行移植。嵌入式Linux系统中常用的bootloader有armboot、redboot、blob、u-boot等,其中u-boot是当前比较流行,功能比较强大的bootloader,可以支持多种体系结构,但相对也比较复杂。bootloader的实现依赖于CPU的体系结构,大多数bootloader都分为stage 1和stage 2两大部分。Bootloader的基本原理见参考文献。

u-boot是sourceforge网站上的一个开放源代码的项目。它可对 PowerPCMPC5xx、MPC8xx、MPC82xx、 MPC7xx、MPC74xx、ARM(ARM7、ARM9、StrongARM、Xscale)、MIPS(4kc、5kc)、X86等处理器提供支持,支持的嵌入式操作系统有Linux、Vx-Works、NetBSD、QNX、RTEMS、ARTOS、LynxOS等,主要用来开发嵌入式系统初始化代码bootloader。软件的主站点是http//sourceforge.net/projects/ u-boot。u-boot 最初是由denxwww.denx.de的PPC-boot发展而来的,它对PowerPC系列处理器的支持最完善,对Linux 操作系统的支持最好。源代码开放的u-boot软件项目经常更新,是学习硬件底层代码开发的很好样例。

2 u-boot系统启动流程

大多数bootloader都分为stage1和stage2两大部分,u-boot也不例外。依赖于CPU体系结构的代码(如设备初始化代码等)通常都放在stage1且可以用汇编语言来实现,而stage2则通常用C语言来实现,这样可以实现复杂的功能,而且有更好的可读性和移植性。

2.1 stage1 (start.s代码结构)

u-boot的stage1代码通常放在start.s文件中,它用汇编语言写成,其主要代码部分如下:

(1) 定义入口 。由于一个可执行的Image必须有一个入口点,并且只能有一个全局入口,通常这个入口放在ROM(Flash)的0x0地址,因此,必须通知编译器以使其知道这个入口,该工作可通过修改连接器脚本来完成。

(2)设置异常向量(Exception Vector)。 (3)设置CPU的速度、时钟频率及中断控制寄存器。 (4)初始化内存控制器 。

(5)将ROM中的程序复制到RAM中。 (6)初始化堆栈 。

(7)转到RAM中执行,该工作可使用指令ldr pc来完成。 2.2 stage2C语言代码部分 lib arm/board.c中的start armboot是C语言开始的函数,也是整个启动代码中C语言的主函数,同时还是整个u-boot(armboot)的主函数,该函数主要完成如下操作: (1)调用一系列的初始化函数。 (2)初始化Flash设备。 (3)初始化系统内存分配函数。

(4)如果目标系统拥有NAND设备,则初始化NAND设备。 (5)如果目标系统有显示设备,则初始化该类设备。 (6)初始化相关网络设备,填写IP、MAC地址等。 (7)进入命令循环(即整个boot的工作循环),接受用户从串口输入的命令,然后进行相应的工作。

3 移植实例

本系统开发板主要由S3C44B0X嵌入式微处理器、2MB的Flash (SST39VF160)、8MB的SDRAM(HY57V641620)、4个LED以及ARM JTAG接口组成。该开发板上与S3C44B0X相关部分的功能框图如图1所示。 3.1 u-boot文件下载

u-boot文件的下载有两种方法,第一种是在Linux环境下通过CVS下载最新的文件,方法是: $cvs-dpserveranonymous@cvs.sourceforge. net/cvsroot/u-boot login 当要求输入匿名登录的密码时,可直接按回车键 $cvs-z6-dpserveranonymous@cvs.source forge.net/cvsroot/u-boot\co.P modulename 第二种是通过ftp//ftp.denx.de/pub/u-boot/ 下载正式发布的压缩文件。

3.2 u-boot文件的结构 初次下载的文件有很多,解压后存放在u-boot文件目录下,具体内容已在readme文件中做了详细的介绍,其中与移植相关的主要文件夹有: (1)CPU它的每个子文件夹里都有如下文件: makefile config.mk

cpu.c 和处理器相关的代码

interrupts.c 中断处理代码 serial.c 串口初始化代码 start.s 全局开始启动代码 (2)BOARD它的每个子文件夹里都有如下文件: makefile config.mk

smdk2410.c 和板子相关的代码(以smdk2410为例) flash.c Flash操作代码

memsetup.s 初始化SDRAM代码 u-boot.lds 对应的连接文件 (3)lib arm体系结构下的相关实现代码,比如memcpy等的汇编语言的优化实现。

3.3 交叉编译环境的建立

要得到下载到目标板的u-boot二进制启动代码,还需要对下载的u-boot1.1.1进行编译。u-boot的编译一般在Linux系统下进行,可用ARM-LIN-UX-GCC进行编译。一步一步建立交叉编译环境通常比较复杂,最简单的方法是使用别人编译好的交叉编译工具,方法如下: (1)在http//handhelds.org/download/toolchain下载 arm-Linux-gcc-3.3.2.tar.bz2

(2)以用户名root登录,将arm-linux-gcc-3.3.2.tar.bz2 解压到 /root目录下

# tar jxvf arm-linux-gcc-3.3.2.tar.bz2

(3)在http//handhelds.org/download/toolchain下载 arm-linux-toolchain-post-2.2.13.tar.gz 只是用了它的头文件而已,主要来自内核/linux-x.x/include下 (4)将arm-linux-toolchain-post-2.2. 13.tar.gz 解压到 /skiff/local/ 下

# tar zxvf arm-linux-toolchain-post-2.2.13.tar.gz

(5)拷贝头文件到/root/usr/3.3.2/arm-linux/ 下然后删除 /skiff

# cp -dR /skiff/local/arm-linux/include /root/usr/3.3.2/arm-linux # rm -fr /skiff

这样就建立了arm linux 交叉编译环境。

(6)增加/root/usr/local/arm/3.3.2/bin到路径环境变量

path=$path:/root/usr/local/arm/3.3.2/bin 可以检查路径变量是否设置正确。# echo $path 3.4 移植的预先编译

移植u-boot到新的开发板上仅需要修改与硬件相关的部分即可。主要包括两个层面的移植,第一层是针对CPU的移植,第二层是针对BOARD的移植。由于u-boot 1.1.1里面已经包含S3C44B0的移植,所以笔者对板子myboard的移植主要是针对BOARD的移植。移植之前需要仔细阅读u-boot目录下的readme文件,其中对如何移植做了简要的介绍。为了减少移植的工作量,可以在include/config目录下选一个和要移植的硬件相似的开发板,笔者选的是b2开发板。具体步骤如下:

(1)u-boot 1.1.1 下的CPU文件夹里已经包括了S3C44B0的目录,其下已经有start.sinterrupts.c以及 cpu.cserial.c几个文件,因而不需要建立与CPU相关的目录。

(2)在board目录下创建myboard目录以及my-board.c、flash.c、memsetup.s和u-boot.lds 等文件。不需要从零开始创建,只需选择一个相似的目录直接复制过来,然后修改文件名及内容即可。笔者在移植u-boot过程中选择的是u-boot 1.1.1/board/dave/B2目录。 (3)在include/configs目录下添加myboard.h,在这里可放入全局的宏定义等也不需要从头创建,可以在include/configs目录下寻找相似的CPU的头文件进行复制,这里笔者用的是B2.h文件来进行相关的修改。 (4) 对u-boot根目录下的makefile文件进行修改,加入 myboard_config : unconfig

@./mkconfig $(@:_config=)arm S3C44B0 myboard

(5) 修改u-boot根目录下的makefile文件,加入对板子的申明。然后在makefile 中加入myboard、LIST ARM7=″B2 ep7312 impa7 myboard″。

(6)运行make clobber,删除错误的depend文件。

搜索更多关于: U-BOOT的启动流程及移植 的文档
U-BOOT的启动流程及移植.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.diyifanwen.net/c2j30k38hzx7l7tx2ascg_1.html(转载请注明文章来源)
热门推荐
Copyright © 2012-2023 第一范文网 版权所有 免责声明 | 联系我们
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:xxxxxx 邮箱:xxxxxx@qq.com
渝ICP备2023013149号
Top