嵌入式系统的 boot loader 技术

35
1 嵌嵌嵌嵌 Boot Loader 嵌嵌

Upload: chavez

Post on 19-Jan-2016

143 views

Category:

Documents


0 download

DESCRIPTION

嵌入式系统的 Boot Loader 技术. 内容提要. 1. Boot Loader 程序的基本概念 2. Boot Loader 的典型结构框架 3. Boot Loader 实验 实验一 Boot Loader 应用实验 实验二 U-BOOT 的分析和移植. 1. Boot Loader 程序的基本概念. Boot Loader 就是在操作系统内核运行之前运行的一段小程序 初始化硬件设备和建立内存空间的映射图 将系统的软硬件环境带到一个合适的状态,以便为最终调用操作系统内核准备好正确的环境 - PowerPoint PPT Presentation

TRANSCRIPT

Page 1: 嵌入式系统的 Boot Loader 技术

1

嵌入式系统的 Boot Loader 技术

Page 2: 嵌入式系统的 Boot Loader 技术

2

内容提要

1. Boot Loader 程序的基本概念 2. Boot Loader 的典型结构框架 3. Boot Loader 实验

实验一 Boot Loader 应用实验实验二 U-BOOT 的分析和移植

Page 3: 嵌入式系统的 Boot Loader 技术

3

1. Boot Loader 程序的基本概念

Boot Loader 就是在操作系统内核运行之前运行的一段小程序 初始化硬件设备和建立内存空间的映射图 将系统的软硬件环境带到一个合适的状态,以便为

最终调用操作系统内核准备好正确的环境 系统的 Boot Loader 程序通常安排在地址 0x00

000000 处

Page 4: 嵌入式系统的 Boot Loader 技术

4

Boot Loader 所支持的硬件环境 每种不同的 CPU 体系结构都有不同的 Boot Loader

Boot Loader 的安装地址 系统加电或复位后,所有的 CPU 通常都从某个由 C

PU 制造商预先安排的地址上取指令。 基于 XScale 内核的 CPU 在复位时通常都从地址 0x

00000000 处取它的第一条指令。 基于这种 CPU 构建的嵌入式系统通常都有某种类型

的固态存储设备 ( 如 ROM 、 EEPROM 或 FLASH等 ) 被映射到这个预先安排的地址上。因此在系统加电后, CPU 将首先执行 Boot Loader 程序。

Page 5: 嵌入式系统的 Boot Loader 技术

5

Boot Loader 相关的设备和机制 主机和目标机之间一般通过串口建立连接

Boot Loader 的启动过程 通常多阶段的 Boot Loader 能提供更为复杂的功能,

以及更好的可移植性。 从固态存储设备上启动的 Boot Loader 大多都是 st

age2 的启动过程,也即启动过程可以分为 stage1

和 stage2 两部分。

Page 6: 嵌入式系统的 Boot Loader 技术

6

Boot Loader 的操作模式 启动加载模式 下载模式

Boot Loader 与主机之间的通信设备及协议 目标机上的 Boot Loader 通常是通过串口与主机之

间进行文件传输,传输协议通常是 xmodem / ymodem / zmodem 协议中的一种。但是,串口传输的速度是有限的,因此通过以太网连接并借助 TFTP 协议来下载文件是个更好的选择。

主机平台所用的软件也需要考虑。比如,在通过以太网连接和 TFTP 协议来下载文件时,主机平台必须有一个软件用来提供 TFTP 服务。

Page 7: 嵌入式系统的 Boot Loader 技术

7

2. Boot Loader 的典型结构框架

操作系统的角度看, Boot Loader 的总目标就是正确地调用内核来执行

大多数 Boot Loader 都分为 stage1 和 stage2两大部分 stage1 实现依赖于 CPU 体系结构的代码 ,比如设备

初始化代码等,通常都放在 stage1 中,而且通常都用汇编语言来实现,以达到短小精悍的目的。

stage2 通常用 C 语言来实现,这样可以实现一些复杂的功能,而且代码会具有更好的可读性和可移植性。

Page 8: 嵌入式系统的 Boot Loader 技术

8

2.1 Boot Loader 阶段 1 介绍

Boot Loader 的 stage1 通常包括以下步骤: 1 )硬件设备初始化。

屏蔽所有的中断 设置 CPU 的速度和时钟频率 RAM 初始化 初始化 LED

关闭 CPU 内部指令/数据 Cache

Page 9: 嵌入式系统的 Boot Loader 技术

9

2 )为加载 stage2 准备 RAM 空间 必须为加载 Boot Loader 的 stage2 准备好一段可

用的 RAM 空间范围 除了 stage2 可执行映象的大小外,还必须把堆栈空

间也考虑进来 必须确保所安排的地址范围的的确是可读写的 RAM

空间

Page 10: 嵌入式系统的 Boot Loader 技术

10

3 )复制 stage2 到 RAM 中 拷贝时要确定两点: (1)stage2 的可执行映象在固态存储设备的存放起始

地址和终止地址; (2) RAM 空间的起始地址。

4 )设置堆栈指针 sp 通常我们可以把 sp 的值设置为 (stage2_end-4) ,

也即所安排的那个 1MB 的 RAM 空间的最顶端 ( 堆栈向下生长 ) 。

Page 11: 嵌入式系统的 Boot Loader 技术

11

5 )跳转到 stage

2 的 C 入口点 Boot Loader 的 阶段 2 可执行映象刚被拷贝到 RAM 空间时的系统内存布局,如右图:

Page 12: 嵌入式系统的 Boot Loader 技术

12

2.2 Boot Loader 阶段 2 介绍

1 )初始化本阶段要使用到的硬件设备 初始化至少一个串口,以便和终端用户进行 I/O 输出

信息 初始化计时器等

Page 13: 嵌入式系统的 Boot Loader 技术

13

2 )检测系统的内存映射 内存映射的描述 可以用如下数据结构来描述 RAM 地址空间中的一段

连续的地址范围:

内存映射的检测

typedef struct memory_area_struct {u32 start; /* 内存空间的基址 */u32 size; /* 内存空间的大小 */int used;

} memory_area_t;

Page 14: 嵌入式系统的 Boot Loader 技术

14

3 )加载内核映像和根文件系统映像 规划内存占用的布局

内核映像所占用的内存范围 根文件系统所占用的内存范围

从 Flash 上拷贝

Page 15: 嵌入式系统的 Boot Loader 技术

15

4 )设置内核的启动参数 标记列表 (tagged list) 的形式来传递启动参数,启

动参数标记列表以标记 ATAG_CORE开始,以标记ATAG_NONE 结束

嵌入式 Linux 系统中,通常需要由 Boot Loader 设置的常见启动参数有: ATAG_CORE 、 ATAG_ME

M 、 ATAG_CMDLINE 、 ATAG_RAMDISK 、 AT

AG_INITRD

Page 16: 嵌入式系统的 Boot Loader 技术

16

例:设置 ATAG_CORE 的代码如下:

params = (struct tag *)BOOT_PARAMS;params->hdr.tag = ATAG_CORE;params->hdr.size = tag_size(tag_core);params->u.core.flags = 0;params->u.core.pagesize = 0;params->u.core.rootdev = 0;params = tag_next(params);

BOOT_PARAMS 表示内核启动参数在内存中的起始基地址,指针 params 是一个 struct tag 类型的指针。宏 tag_next() 将以指向当前标记的指针为参数,计算出当前标记的下一个标记的起始地址

Page 17: 嵌入式系统的 Boot Loader 技术

17

5 )调用内核 CPU寄存器的设置:

R0= 0; R1=机器类型 ID;关于机器类型号,可以参见: linux/arch/arm/tools/mach-types 。 R2=启动参数标记列表在 RAM 中起始基地址;

CPU 模式: 必须禁止中断( IRQs 和 FIQs ); CPU 必须 SVC 模式;

Cache 和 MMU 的设置: MMU 必须关闭; 指令 Cache 可以打开也可以关闭; 数据 Cache 必须关闭;

Page 18: 嵌入式系统的 Boot Loader 技术

18

2.3 关于串口终端

向串口终端打印信息也是一个非常重要而又有效的调试手段

如果碰到串口终端显示乱码或根本没有显示的问题,可能是因为: Boot Loader 对串口的初始化设置不正确 运行在 host 端的终端仿真程序对串口的设置不正确

Page 19: 嵌入式系统的 Boot Loader 技术

19

Boot Loader 启动内核后却无法看到内核的启动输出信息: 确认内核在编译时是否配置了对串口终端的支持,

并配置了正确的串口驱动程序 Boot Loader 对串口的初始化设置是否和内核对串

口的初始化设置一致 还要确认 Boot Loader 所用的内核基地址必须和内

核映像在编译时所用的运行基地址一致

Page 20: 嵌入式系统的 Boot Loader 技术

20

3. Boot Loader 实验

实验一 Boot Loader 应用实验实验二 U-BOOT 的分析和移植

Page 21: 嵌入式系统的 Boot Loader 技术

21

实验一 Boot Loader 应用实验( 1 )

烧写 XSBase255 的 BootLoader 编译生成 XSBase255专用的 JTAG 程序

Jflash-XSBase255编译生成 XSBase 的 Boot Loader x-boot2

55 正确连线利用 JTAG烧写 BootLoader [root@XSBase JTAG]# ./Jflash-XSBase255 x-boot255

Page 22: 嵌入式系统的 Boot Loader 技术

22

实验一 Boot Loader 应用实验( 2 )

熟悉使用 Bootloader 指令,执行各个指令后将其结果与下表的 description 进行比较

Usage help

Description 对各个指令的简单的说明。

Arguments None

Example XSBase255> Help

Page 23: 嵌入式系统的 Boot Loader 技术

23

Usage reload [kernel/ramdisk]

Description 将 Flash中纪录的 image复制到 SDRAM 为了复制 kernel image 到 SDRAM , Autoboot时

自动执行

Arguments 将 Kernel – flash 的 kernel image 复制到 SDRAM 0xa0008000将 Ramdisk – flash 的 ramdisk 复制到 SDRAM 0xa0800000

Example XSBase255> reload kernel

Page 24: 嵌入式系统的 Boot Loader 技术

24

Usage tftp [file] [loader/kernel/root/ramdisk]tftp [file] [addr]

Description 通过 Ethernet 将 Host的映像文件下载到 SDRAM中

Arguments Loader–将接收到的文件储存到 loader的 SDRAM 0xa0000000Kernel–将接收到的文件储存到 kernel 的 SDRAM 0xa0008000Root – 将接收到的文件储存到 0xa0000000Ramdisk – 将接收到的文件储存到 0xA0800000。Addr – SDRAM上纪录接收到的文件的地址

Example XSBase255> tftp zImage kernelXSBase255> tftp zImage 0xa0000000

Page 25: 嵌入式系统的 Boot Loader 技术

25

Usage flash [loader/kernel/root/ramdisk]flash [dest] [src] [len]

Description 将 SDRAM上的数据储存到 flash的相应地址Arguments Loader-将 SDRAM的 loader 0xa00000000储存到 flash

的 0x0地址Kernel-将 SDRAM的 Kernel 0xa00080000储存到 flash的 0xc0000 地址Root-将 SDRAM的 root 0xa0000000储存到 flash的 0x1c0000地址Ramdisk-将 SDRAM的 ramdisk 0xA0800000储存到 Flash的 0x1c00 00地址Dest-储存到 flash上的地址Src-原来的数据所在地址Len-复制的长度

Example XSBase255> flash kernelXSBase255> flash 0xc0000 0xa0000000 0x100000

Page 26: 嵌入式系统的 Boot Loader 技术

26

Usage bootboot [opt1] [opt2]boot [addr] [opt1] [opt2]

Description 驱动 SDRAM 上的 kernel 通过相应 arguments 驱动或者驱动相应地指的 ker

nel。Arguments opt1 – kernel option(Only 0)

opt2 – machine type( X-Hyer255 : 200)addr – kernel image address

Example XSBase255> bootXSBase255> boot 0 200XSBase255> boot 0xa0008000 0 200

Page 27: 嵌入式系统的 Boot Loader 技术

27

实验二 U-BOOT 的分析和移植( 1 )

U-BOOT简介 U-BOOT 是由德国的工程师Wolfgang Denk

从 8XXROM 代码发展而来的,它支持很多处理器,比如 PowerPC 、 ARM 、 MIPS 和 x86 。目前, U-BOOT源代码在 sourceforge 网站的社区服务器中, Internet 上有一群自由开发人员对其进行维护和开发。 U-BOOT 的最新版本源代码可以在 web 地址 http://sourceforge.net 下载到。

Page 28: 嵌入式系统的 Boot Loader 技术

28

U-BOOT 的特点 在线读写 Flash 、 DOC 、 IDE 、 IIC 、 EE

ROM 、 RTC 支持串行口 kermit 和 S-record 下载代码识别二进制、 ELF32 、 uImage格式的 Ima

ge ,对 Linux引导有特别的支持单任务软件运行环境

Page 29: 嵌入式系统的 Boot Loader 技术

29

脚本语言支持 ( 类似 BASH脚本 ) 支持 WatchDog 、 LCD logo 和状态指示功

能等 支持 MTD 和文件系统 支持中断 详细的开发文档

Page 30: 嵌入式系统的 Boot Loader 技术

30

实验二 U-BOOT 的分析和移植( 2 )

U-BOOT源代码结构 \board :和一些已有开发板相关的文件 \common :与体系结构无关的文件,实现各

种命令的 C 文件 \cpu : CPU 相关文件 \disk : disk驱动的分区处理代码doc :文档 drivers :通用设备驱动程序

Page 31: 嵌入式系统的 Boot Loader 技术

31

fs: 支持文件系统的文件 net :与网络有关的代码 lib_arm :与 ARM 体系结构相关的代码 tools :创建 S-Record格式文件 和 U-BOO

T images 的工具

Page 32: 嵌入式系统的 Boot Loader 技术

32

实验二 U-BOOT 的分析和移植( 3 )

对 U-BOOT 的移植建立自己开发板的目录和相关文件

在 include/configs 目录中添加头文件 xsbase.h 在 board/ 目录下新建 xsbase 目录,创建如下文

件: flash.c 、 memsetup.S 、 xsbase.c 、 Makefile 和 u-boot.lds

添加网口设备控制程序, cs8900 网口设备的控制程序 cs8900.c 和 cs8900.h

Page 33: 嵌入式系统的 Boot Loader 技术

33

实验二 U-BOOT 的分析和移植( 4 )

修改Makefile 在 u-boot-1.1.2/Makefile 中加入:xsbase_config : unconfig@./mkconfig $(@:_config=) arm pxa xsbase

Page 34: 嵌入式系统的 Boot Loader 技术

34

实验二 U-BOOT 的分析和移植( 5 )

生成目标文件先运行 make clean 然后运行 make xsbase_config 再运行 make all生成三个文件:

u-boot——ELF格式的文件,可以被大多数 Debug 程序识别。

u-boot.bin—— 二进制 bin 文件,这个文件一般用于烧录到用户开发板中。

u-boot.srec——Motorola S-Record格式,可以通过串行口下载到开发板中

Page 35: 嵌入式系统的 Boot Loader 技术

35

实验二 U-BOOT 的分析和移植( 6 )

通过 JTAG 口将 u-boot.bin烧写到 Flash 的零地址,复位后执行 u-boot

输入 help得到所有命令列表