当前位置:首页 > 芯闻号 > 充电吧
[导读]U-Boot,全称 Universal Boot Loader,是遵循GPL条款的开放源码项目。U-Boot的作用是系统引导。U-Boot从FADSROM、8xxROM、PPCBOOT逐步发展演化而来

U-Boot,全称 Universal Boot Loader,是遵循GPL条款的开放源码项目。U-Boot的作用是系统引导。

U-Boot从FADSROM、8xxROM、PPCBOOT逐步发展演化而来。其源码目录、编译形式与Linux内核很相似,事实上,不少U-Boot源码就是根据相应的Linux内核源程序进行简化而形成的,尤其是一些设备的驱动程序,这从U-Boot源码的注释中能体现这一点。

一、uboot的最终目的 在说uboot之前,先看一下PC机是怎么启动的? pc上电,bios(引导操作系统)、识别C盘、运行应用程序。 同样的在嵌入系统里面,启动过程:一上电的时候,uboot(引导Linux内核)、挂接根文件系统、运行应用程序。
小结:uboot的最终的目的->启动内核 二、怎么让嵌入式系统使用uboot ① 先来介绍一下补丁: 什么是补丁? 所谓的补丁就是我们在原码包上做了什么修改,我们将这些修改单独列出来放到一个文件,然后发布的时候,把补丁文件给别人家即可。 怎么打补丁?

 tar xjf u-boot-1.1.6.tar.bz2
 cd u-boot-1.1.6/
 patch -p1 < ../u-boot-1.1.6_jz2440.patch

-p1 是忽略配置文件中的第一个参数,即,u-boot-1.1.6/和u-boot-1.1.6_jz2440/

补丁文件中的 ---表示原来的代码,+++表示修改后的代码;比如:  
② 打完补丁之后,要想uboot支持哪些单板,需要配置。通过make 100ask24x0_config 来配置我们此款JZ2440V3单板,然后再make编译uboot。 总结一下:

tar xjf u-boot-1.1.6.tar.bz2 //解压缩
patch -p1 < ../u-boot-1.1.6_jz2440.patch //打补丁
make 100ask24x0_config //配置
make //编译

③ 编译完成以后,会生成一个u-boot.bin的文件,如图:

然后通过dnw或者eop将这个bin文件烧写到开发板上面,烧写完成以后在串口上可以看到它的启动信息;

三、uboot命令使用

在嵌入式操作系统中,bootloader有很多种,我们这里使用的是uboot;

① 输入help或?可以查看uboot有哪些命令; 如果想查看具体哪个命令的用法,可以输入“? 命令名”即可。
如何查看uboot有哪些环境变量? 使用print 命令

② 怎么设置环境变量? 使用set 命令

总结一下:

?/help + 命令 //查询命令的用法
print        //查看当前环境变量
set          //修改环境变量
save         //保存环境变量
reset        //重启uboot
boot         //引导内核

四、uboot功能介绍 ① 对于PC机来说windows操作系统存在于硬盘上面,BIOS从硬盘上读出windows操作系统,然后放到DDR(SDRAM的一种 DDR SDRAM); ② 而对于嵌入linux来说,一般从flash中读取出内核,然后放到SDRAM中去。 可以看出,uboot要具备的基本功能:能够读取flash、写入SDRAM之前要初始化SDRAM、启动内核。 在开发阶段,我们想让它增加更多的功能,比如说加入写flash的功能,因为在开发中(为了开发方便),内核也是通过uboot利用网络或USB下载把内核烧写到开发板中去的。

总结一下uboot的功能:

五、uboot的源码结构:board  开发板相关  对应不同配置的(即使CPU相同),smdk2410、sbc2410x  cpu  平台相关  对应不同的CPU,arm920t、arm925t、i386等;在它们的子目录下仍可以细分,比如arm920t就有at91rm9200、s3c24x0  lib_i386 类似  平台相关  某一架构下通用的文件  include  通用的函数  头文件和开发板配置文件,开发板的配置文件都放在include/configs目录下,U-boot没有make menuconfig类似的菜单来进行可视化配置,需要手动地修改配置文件中的宏定义  lib_generic  通用的函数  通用的库函数,比如printf等  common  通用的函数  通用的函数,多是对下一层驱动程序的进一步封装  disk  通用的设备驱动程序  硬盘接口程序  drivers  通用的设备驱动程序  各类具体设备的驱动程序,基本上可以通用,它们通过宏从外面引入平台/开发板相关的函数  dtt  通用的设备驱动程序  数字温度测量器或者传感器的驱动  fs  通用的设备驱动程序  文件系统  nand_spl  通用的设备驱动程序  U-Boot一半从ROM、NOR Flash等设备启动,现在开始支持从NAND Flash启动,但是支持的CPU种类还不多  net  通用的设备驱动程序  各种网络协议  post  通用的设备驱动程序  上电自检程序  rtc  通用的设备驱动程序  实时时钟的驱动  doc  文档  开发、使用文档  examples  示例程序  一些测试程序,可以使用U-Boot下载后运行  tools  工具  制作S-Record、U-Boot格式映象的工具,比如mkimage U-boot中各目录间也是有层次结构的,虽然这种分法不是绝对的,但是在移植过程中可以提供一些指导意义

这些源码是怎么组织起来构成一个uboot的,最简单的方法就是分析它的makefile文件。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

关注星标公众号,不错过精彩内容来源|综合来自网络内容嵌入式软件工程师听说过u-boot和bootloader,但很多工程师依然不知道他们到底是啥。今天就来简单讲讲 u-boot 和 bootloader的内容以及区别。B...

关键字: u-boot

当我们在控制台的时候,输入boot可以启动Linux内核,那么我们以boot为例子来解析一下uboot命令的执行过程,为下一步分析uboot怎样启动Linux来做准备。 一、我们搜索boot命令

关键字: u-boot u-boot添加命令

/*  *  armboot - Startup Code for S5PC110/ARM-Cortex CPU-core  *  *  Copyright (c) 2009 Samsung Elec

关键字: tq210 u-boot

作者:华清远见讲师Bootloader:简单地说,Bootloader 就是在操作系统内核运行之前运行的一段小程序。通过这段小程序,我们可以初始化硬件设备、建立内存空间的映射图,从而将系统的软硬件环境

关键字: kernel u-boot 缓存

1 开发环境    友善之臂mini2440-W35    win7+SecureCRT    VirtualBox+Ubuntu    Jlink V82 VirtualBox设置    Sett

关键字: nfs u-boot

移植环境1,主机环境:VMare下CentOS 5.5 ,1G内存。2,集成开发环境:Elipse IDE3,编译编译环境:arm-linux-gcc v4.4.3,arm-none-eabi-gcc v4.5.1。4,...

关键字: mini2440 u-boot 移植 dm9000驱动

移植环境1,主机环境:VMare下CentOS 5.5 ,1G内存。2,集成开发环境:Elipse IDE3,编译编译环境:arm-linux-gcc v4.4.3,arm-none-eabi-gcc v4.5.1。4,...

关键字: eeprom i2c mini2440 u-boot 移植

一、U-BOOT命令详解 1.1 帮助命令 # help 尽管UBOOT提供了丰富的命令集,但不同的开发板所支持的命令却不一样(可配置),help 命令可用于察看当前单板所支持的命令。 1.2 查看环

关键字: u-boot u-boot命令

移植环境1,主机环境:VMare下CentOS 5.5 ,1G内存。2,集成开发环境:Elipse IDE3,编译编译环境:arm-linux-gcc v4.4.3,arm-none-eabi-gcc v4.5.1。4,...

关键字: mini2440 u-boot 移植 引导内核

嵌入式Linux之我行,主要讲述和总结了本人在学习嵌入式linux中的每个步骤。一为总结经验,二希望能给想入门嵌入式Linux的朋友提供方便。如有错误之处,谢请指正。共享资源,欢迎转载:http://hbhuanggan...

关键字: 2440 u-boot 移植详解
关闭
关闭