嵌入式系统的bootloader Bootloader 代码是芯片复位后进入操作系统之前执行的一段代码,主要用于完成由硬件启动到操作系统启动的过渡,从而为操作系统提供基本的运行环境,如初始化CPU、 堆栈、存储器系统等。Bootloader 代码与CPU 芯片的内核结构、具体型号、应用系统的配置及使用的操作系统等因素有关,其功能类似于PC机的BIOS程序.

Slides:



Advertisements
Similar presentations
课前回顾.
Advertisements

最新計算機概論 第3章 計算機組織.
基于ARM和linux的开发 华中科技大学 武汉创维特 2017/3/20.
嵌入式操作系统 陈天洲、陈文智.
UClinux在3000平台上的移植.
项目四 组建跨地区网络 授课教师:肖颖.
Oracle数据库 Oracle 子程序.
在PHP和MYSQL中实现完美的中文显示
陈香兰 助教:陈博、李春华 Spring 2009 嵌入式操作系统 陈香兰 助教:陈博、李春华 Spring 2009.
第一章 嵌入式系统开发基础 本章介绍了嵌入式系统开发的基础知识,从嵌入式计算机的历史由来、嵌入式系统的定义、嵌入式系统的基本特点、嵌入式系统的分类及应用、嵌入式系统软硬件各部分组成、嵌入式系统的开发流程、嵌入式技术的发展趋势等方面进行了介绍,涉及到嵌入式系统开发的基本内容,使读者系统地建立起的嵌入式系统整体概念。
Windows CE.Net 移植与开发 Dhp
Kvm异步缺页中断 浙江大学计算机体系结构实验室 徐浩.
陈香兰 助教:陈博、李春华 Spring 2009 嵌入式操作系统 陈香兰 助教:陈博、李春华 Spring 2009.
陈香兰 助教:陈博、李春华 Spring 2009 嵌入式操作系统 陈香兰 助教:陈博、李春华 Spring 2009.
電腦基礎設定與故障排除 主辦單位:教務處 主講人:呂健聰.
1-1 微電腦系統單元 1-2 微電腦系統架構 1-3 微控制器(單晶片微電腦) 1-4 類比與數位訊號介面
Bootloader技术分析.
嵌入式系统课程简介 宋健建 南京大学软件学院 2004/02/10.
2018/11/ /11/23 TRAINING-LZW.
嵌入式系统教案 武汉创维特信息技术有限公司 2018/11/24.
讲议: PXE 介绍及实现 Jarvis
路由器的组成 路由器的前面板除了LED灯外没有其它东西,LED灯主要是指示电源是否开启。
第14章 Bootloader基本概念與燒錄.
第三章 系统的启动和初始化 (include lab1)
陈香兰 助教:陈博、李春华 Spring 2009 嵌入式操作系统 陈香兰 助教:陈博、李春华 Spring 2009.
存储系统.
大学计算机基础 典型案例之一 构建FPT服务器.
模块五: 数控系统参数的备份与恢复 本章学习内容.
SVN服务器的搭建(Windows) 柳峰
第2章 電腦硬體的架構及功能.
单片机应用技术 项目一 循环彩灯装置 第2讲 51单片机的结构与引脚 《单片机应用技术》精品课程组 湖北职业技术学院机电工程系.
在專用的嵌入式板子運行 GNU/Linux 系統已經變得越來越流行。一個嵌入式 Linux 系統從軟體的角度看通常可以分為四個層次:
第11章:一些著名开源软件介绍 第12章:服务安装和配置 本章教学目标: 了解当前一些应用最广泛的开源软件项目 搭建一个网站服务器
DM81X 视频采集处理 ——简单采集显示例程讲解 广州创龙电子科技有限公司
SPI驱动 广州创龙电子科技有限公司 Guangzhou Tronlong Electronic Technology Co., Ltd.
第一单元 初识C程序与C程序开发平台搭建 ---观其大略
操作系统实验 lab1-系统引导
嵌入式系统的Boot Loader技术 陈文智 浙江大学计算机学院 2009年5月.
第8章 构建嵌入式Linux系统.
第2章 ARM微处理器硬件结构 计算机体系结构分类 ARM版本及系列 ARM处理器结构 存储系统机制.
逆向工程-汇编语言
CPU结构和功能.
内核移植基础.
(第2版).
凌宁 系统工程师 亚洲区嵌入式系统事业群 微软(中国)有限公司
中国科学技术大学计算机系 陈香兰(0551- ) Spring 2009
Windows 7 的系统设置.
Instructions: Language of the Machine
Linux Debugging ls,ps,top,etc. printk() /proc i386提供的调试机制(断点,信号,单步执行)
Author:BobZhang Copy Right 2007
Unit 11.Operating System 11.1 What’s OS 11.2 Related Courses
第13章 计算机的保养.
u-boot 启动流程 广州创龙电子科技有限公司
(第2版).
作業系統 第三章 作業系統結構.
内容摘要 ■ 课程概述 ■ 教学安排 ■ 什么是操作系统? ■ 为什么学习操作系统? ■ 如何学习操作系统? ■ 操作系统实例
C语言程序设计 主讲教师:陆幼利.
微机系统的组成.
开发环境的建立 陈文智 浙江大学计算机学院 2005年3月.
第四章 团队音乐会序幕: 团队协作平台的快速创建
嵌入式Linux开发流程 成都研究所操作系统团队.
VisComposer 2019/4/17.
Platform Builder使用介绍 WINCE系统应用开发流程说明 ACTION RDC 杨 涛 2005.Dec.3th
JSP实用教程 清华大学出版社 第2章 JSP运行环境和开发环境 教学目标 教学重点 教学过程 2019年5月7日.
ARM简介及BootLoader介绍 黄大荣
本节内容 Windows线程切换_时钟中断切换 视频提供:昆山滴水信息技术有限公司 官网地址: 论坛地址: QQ交流 :
C++语言程序设计 C++语言程序设计 第一章 C++语言概述 第十一组 C++语言程序设计.
24 or 1024? PWN Jawbone Up24 手环.
DSP技术与应用 电子与信息技术系.
一个实时嵌入式操作系统移植问题研究 报告人:荣峰华.
Presentation transcript:

嵌入式系统的bootloader Bootloader 代码是芯片复位后进入操作系统之前执行的一段代码,主要用于完成由硬件启动到操作系统启动的过渡,从而为操作系统提供基本的运行环境,如初始化CPU、 堆栈、存储器系统等。Bootloader 代码与CPU 芯片的内核结构、具体型号、应用系统的配置及使用的操作系统等因素有关,其功能类似于PC机的BIOS程序

Boot Loader 所支持的 CPU 和嵌入式板 每种不同的 CPU 体系结构都有不同的 Boot Loader。有些 Boot Loader 也支持多种体系 结构的 CPU,比如 U-Boot 就同时支持 ARM 体系结构和MIPS 体系结构。除了依赖于 CPU 的体系结构外,Boot Loader 实际上也依赖于具体的嵌入式板级设备的配置。这也就是说 ,对于两块不同的嵌入式板而言,即使它们是基于同一种 CPU 而构建的,要想让运行在一 块板子上的 Boot Loader 程序也能运行在另一块板子上,通常也都需要修改 Boot Loade r 的源程序。

嵌入式 Linux 系统 的四个层次 1. 引导加载程序。包括固化在固件(firmware)中的 boot 代码(可选),和 Boot Loader 两大部分。 2. Linux 内核。特定于嵌入式板子的定制内核以及内核的启动参数。 3. 文件系统。包括根文件系统和建立于 Flash 内存设备之上文件系统。通常用 ram dis k 来作为 root fs。

4. 用户应用程序。特定于用户的应用程序。有时在用户应用程序和内核层之间可能还会包 括一个嵌入式图形用户界面。常用的嵌入式 GUI 有:MicroWindows 和 MiniGUI 懂。

系统的典型构建

Boot Loader 的操作模式 (Operation Mode) 大多数 Boot Loader 都包含两种不同的操作模式:"启动加载"模式和"下载"模式,这种区 别仅对于开发人员才有意义。但从最终用户的角度看,Boot Loader 的作用就是用来加载 操作系统,而并不存在所谓的启动加载模式与下载工作模式的区别。

启动加载(Boot loading)模式:这种模式也称为"自主"(Autonomous)模式。也即 Boo t Loader 从目标机上的某个固态存储设备上将操作系统加载到 RAM 中运行,整个过程并 没有用户的介入。这种模式是 Boot Loader 的正常工作模式,因此在嵌入式产品发布的时 侯,Boot Loader 显然必须工作在这种模式下。

下载(Downloading)模式:在这种模式下,目标机上的 Boot Loader 将通过串口连接或 网络连接等通信手段从主机(Host)下载文件,比如:下载内核映像和根文件系统映像等 。从主机下载的文件通常首先被 Boot Loader 保存到目标机的 RAM 中,然后再被 Boot Loader 写到目标机上的FLASH 类固态存储设备中。Boot Loader 的这种模式通常在第一次 安装内核与根文件系统时被使用;此外,以后的系统更新也会使用 Boot Loader 的这种工 作模式。工作于这种模式下的 Boot Loader 通常都会向它的终端用户提供一个简单的命令 行接口

Boot Loader 的主要任务与典型结构框架 假定内核映像与根文件系统映像 都被加载到 RAM 中运行。之所以提出这样一个假设前提是因为,在嵌入式系统中内核映像 与根文件系统映像也可以直接在 ROM 或 Flash 这样的固态存储设备中直接运行。但这种 做法无疑是以运行速度的牺牲为代价的。从操作系统的角度看,Boot Loader 的总目标就 是正确地调用内核来执行。

由于 Boot Loader 的实现依赖于 CPU 的体系结构,因此大多数 Boot Loader 都分 为 stage1 和 stage2 两大部分。依赖于 CPU 体系结构的代码,比如设备初始化代码等, 通常都放在 stage1 中,而且通常都用汇编语言来实现,以达到短小精悍的目的。而 sta ge2 则通常用C语言来实现,这样可以实现给复杂的功能,而且代码会具有更好的可读性和 可移植性。

Boot Loader 的 stage1 通常包括以下步骤(以执行的先后顺序): ·硬件设备初始化。 ·为加载 Boot Loader 的 stage2 准备 RAM 空间。 ·拷贝 Boot Loader 的 stage2 到 RAM 空间中。 ·设置好堆栈。 ·跳转到 stage2 的 C 入口点。 Boot Loader 的 stage2 通常包括以下步骤(以执行的先后顺序): ·初始化本阶段要使用到的硬件设备。 ·检测系统内存映射(memory map)。 ·将 kernel 映像和根文件系统映像从 flash 上读到 RAM 空间中。 ·为内核设置启动参数。 ·调用内核。

Boot Loader 的 stage1 这是 Boot Loader 一开始就执行的操作,其目的是为 stage2 的执行以及随后的 kernel 的执行准备好一些基本的硬件环境。它通常包括以下步骤(以执行的先后顺序): 1.屏蔽所有的中断。为中断提供服务通常是 OS 设备驱动程序的责任,因此在 Boot Loa der 的执行全过程中可以不必响应任何中断。中断屏蔽可以通过写 CPU 的中断屏蔽寄存器 或状态寄存器(比如 ARM 的 CPSR 寄存器)来完成。 2.设置 CPU 的速度和时钟频率。

3.RAM 初始化。包括正确地设置系统的内存控制器的功能寄存器以及各内存库控制寄存器 等。 4.初始化 LED。典型地,通过 GPIO 来驱动 LED,其目的是表明系统的状态是 OK 还是 Error。如果板子上没有 LED,那么也可以通过初始化 UART 向串口打印 Boot Loader 的 Logo 字符信息来完成这一点。 5. 关闭 CPU 内部指令/数据 cache。

第二的boot loader,可以更加形象得被称为内核加载程序。这个阶段的任务就是加载linux内核,以及可选的初始化内存盘。 首先修改makefile里的交叉编译器 设定交叉编译器的路径,对于arm的bootloader选用arm-linux-gcc,运行环境是在linux下

主要修改的文件有 include/configs/2410.h ---- 配置文件,大部分参数是这里配置的. board/wx/wx20/lowlevel_init.S -- 内存参数配置 cpu/s3c44b0/serial.c -- 串口配置 cpu/s3c44b0/start.S -- 程序入口 lib_arm /armlinux

比如2410.h里的(摘录;部分) #define CFG_LONGHELP /* undef to save memory */ #define CFG_PROMPT "ARMSYS2410-B # " /* Monitor Command Prompt */ #define CFG_CBSIZE 256 /* Console I/O Buffer Size */ #define CFG_MEMTEST_START 0x30000000 /* memtest works on */ #define CFG_MEMTEST_END 0x33F00000 /* 63 MB in DRAM */

#define CFG_LOAD_ADDR 0x33000000 /* default load address */ #define PHYS_FLASH_SIZE 0x00100000 /* 1MB */ #define CFG_MAX_FLASH_SECT (19) /* max number of sectors on one chip */ #define CFG_ENV_ADDR (CFG_FLASH_BASE + 0x0F0000) /* addr of environment */

/. #define CONFIG_BOOTARGS /* #define CONFIG_BOOTARGS "root=ramfs devfs=mount console=ttySAC0,115200" */ #define CONFIG_BOOTARGS "noinitrd root=/dev/bon/2 init=/linuxrc console=ttyS0" #define CONFIG_ETHADDR 08:00:3e:26:0a:5b #define CONFIG_NETMASK 255.255.255.0 #define CONFIG_IPADDR 192.168.1.15 #define CONFIG_SERVERIP 192.168.1.128 /*#define CONFIG_BOOTFILE "elinos-lart" */ #define CONFIG_BOOTCOMMAND "tftp 30007fc0 z; bootm 30007fc0"

修改后重新编译会生成u-boot.bin二进制文件 一个成功移植后的启动代码: U-Boot 1.1.4 (Jan 14 2006 - 02:09:02) U-Boot code: 33F80000 -> 33F9985C  BSS: -> 33F9D970 RAM Configuration: Bank #0: 30000000 64 MB Flash:  1 MB In:    serial Out:   serial Err:   serial Hit any key to stop autoboot:  0

smdk2410=> tftp TFTP from server 192. 168. 1 smdk2410=> tftp TFTP from server 192.168.1.15; our IP address is 192.168.1.128 Filename 'zImage'. Load address: 0x 33000000 Booting image at 33000000...    Image Name:    linux-2.6.10    Created:      2006-01-12  20:31:21 UTC    Image Type:   ARM Linux Kernel Image (uncompressed)    Data Size:    900588 Bytes = 879.5 kB    Load Address: 33000000    Entry Point:  30008000

Verifying Checksum. OK XIP Kernel Image Verifying Checksum ... OK    XIP Kernel Image ... OK ## Transferring control to Linux (at address 30008000) ... Kernel command line is console=ttyS0 root=/dev/nfs nfsroot=192.168.0.101:/armsys2410/root ip=192.168.0.111:192.168.0.1:192.168.0.1:2 55.255.255.0:armsys.hzlitai.com:eth0:off Starting kernel ...

参考文献: Arm9嵌入式linux系统的构建与应用 Bootloader技术内幕