Bootloader启动过程

1、作用

嵌入式系统的引导加载程序,系统上电后运行的第一段程序。在完成对系统的初始化任务后,它会将非易失性存储器(通常是FLASH)中的Linux内核拷贝到RAM中,然后跳转到内核的第一条指令处继续执行,从而启动Linux内核。

2、功能

实际应用中的Bootloader根据所需功能的不同可以设计的很复杂,除完成基本的初始化系统和调用Linux内核等基本任务外,还可以执行很多用户输入的命令,比如设置Linux启动参数,给Flash分区等;为了能达到启动Linux内核的目的,所有的Bootloader都具备以下功能:

(1)初始化RAM

因为Linux内核一般都会在RAM中运行,所有在调用Linux内核之前bootloader必须设置和初始化RAM,为调用Linux内核做准备。初始化RAM的任务包括设置CPU的控制寄存器参数,以便能正常使用RAM以及检测RAM大小等。

(2)初始化串口

在执行过程中初始化一个串口做为调试端口

(3)检测处理器类型

在调用Linux内核前必须检测系统的处理器类型,并将其保存到某个常量中提供给Linux内核。Linux内核在启动过程中会根据该处理器类型调用相应的初始化程序。

(4)设置Linux启动参数

目前传递启动参数主要采用两种方式:即通过struct param_struct 和struct tag(标记列表,tagged list)两种结构传递。struct param_struct是一种比较老的参数传递方式,在2.4版本以前的内核中使用较多,从2.4版本以后Linux内核基本上采用标记列表的方式。但为了保持和以前版本的兼容性,它仍支持struct param_struct参数传递方式,只不过在内核启动过程中它将被转换成标记列表方式。标记列表方式是比较新的参数传递方式,需要以ATAG_CORE开始,并以ATAG_NONE结尾。中间根据需要加入其它列表。Linux内核在启动过程中会根据该启动参数进行相应的初始化工作。

(5)调用Linux内核映像

Bootloader完成的最后一项工作便是调用Linux内核。在跳到Linux内核执行之前CPU的寄存器必须满足以下条件:r0=0,r1=处理器类型,r2=标记列表在RAM中的地址。

时间: 2024-10-07 16:18:31

Bootloader启动过程的相关文章

bootloader和kernel配合启动过程/编译bootloader/编译kernel

bootloader和kernel配合启动过程 -------------------------------------------- ARM9的板子有norflash芯片,存储基本的bootlader代码,此处为cpu执行代码的0地址.cpu内部的4kRam空间充当此时的栈和数据段存储.因为是三星公司自己做的芯片,故硬件上面可以实现将nandflash前4K的代码自动拷贝到iRam中(实现方式没有公开,只要能够理解工作方式即可).只需要将bootloader的后续代码放到内存sdram中即可

Linux内核分析 实验三:跟踪分析Linux内核的启动过程

贺邦 + 原创作品转载请注明出处 + <Linux内核分析>MOOC课程 http://mooc.study.163.com/course/USTC-1000029000 一. 实验过程 1.打开shell,输入启动指令,内核启动完成后进入menu程序,支持三个命令help.version和quit. 2.然后使用gdb跟踪调试内核,输入命令qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -s -S 3.按住

Android 启动过程的底层实现

转载请标明出处: http://blog.csdn.net/yujun411522/article/details/46367787 本文出自:[yujun411522的博客] 3.1 android正常模式启动流程 主要流程例如以下: 1.系统加电.运行bootloader,bootloader会将内核载入到内存中. 2.内核载入到内存之后首先进入内核引导阶段,最后调用start_kernel进入内核启动.start_kernel终于会启动init程序 3.init程序负责解析init.rc文

【转载】简述Linux的启动过程

原文:简述Linux的启动过程 本文将简单介绍一下Linux的启动过程,希望对那些安装Linux的过程中遇到了问题的朋友有些帮助 声明:本人没用过UEFI模式和GPT分区格式,所有关于这两部分的内容都是网络上找的资料,仅供参考. 典型启动顺序 计算机通电后,CPU开始从一个固定的地址加载代码并开始执行,这个地址就是BIOS的驱动程序所在的位置,于是BIOS的驱动开始执行. BIOS驱动首先进行一些自检工作,然后根据配置的启动顺序,依次尝试加载启动程序.比如配置的启动顺序是CD->网卡01->U

20135239 益西拉姆 linux内核分析 跟踪分析Linux内核的启动过程

回顾 1.中断上下文的切换——保存现场&恢复现场 本节主要课程内容 Linux内核源代码简介 1.打开内核源代码页面 arch/目录:支持不同CPU的源代码:其中的X86是重点 init/目录:内核启动相关的代码基本都在该目录中(比如main.c等) start_kernel函数就相当于普通C程序的main函数 kernel/目录:Linux内核核心代码在kernel目录中 README 介绍了什么是Linux,Linux能够在哪些硬件上运行,如何安装内核源代码等 构造一个简单的linux系统m

linux内核学习之三 跟踪分析内核的启动过程

一   前期准备工作       1 搭建环境 1.1下载内核源代码并编译内核 创建目录,并进入该目录: 下载源码: 解压缩,并进入该目录:xz -d linux-3.18.6.tar.xz tar -xvf linux-3.18.6 cd  linux-3.18.6 选定x86架构的相关文件编译: 编译: 1.2 制作根文件系统 在工作目录下新建一个文件夹: mkdir rootfs 下载老师提供的资料:git clone https://github.com/mengning/menu.gi

Linux系统--Linux的启动过程

Linux系统--Linux启动过程 CentOS 启动流程: POST --> Boot Sequence(BIOS) --> Boot Loader (MBR) --> Kernel(ramdisk) --> rootfs --> switchroot --> /sbin/init -->(/etc/inittab, /etc/init/*.conf) --> 设定默认运行级别 --> 系统初始化脚本 --> 关闭或启动对应级别下的服务 --

信庭嵌入式工作室-Linux系统Bootloader启动调试技术

嵌入式系统搭建过程中,对于系统平台搭建工程师最初的一步通常是移植Bootloader ,当然移植有几个级别,通常最常见的是参考的EVM 的硬件有了修改(如更改了FLASH ,更改了SDRAM .DDR SDRAM 等),并且是初次调试硬件,更大的困难是公司为节省成本不打算买上万的EVM 开发板,或者EVM 开发板需要license 才能购买,这时移植Bootloader 是比较难做的,不过也不是没有方法,最有效的有两个--点灯和串口打印 .(作者通过这种方法调试成功过IXP2400(Xscale

TMS320F2812启动过程

TMS320F2812从内部Flash启动的详细流程说明: 1>程序硬件复位或者软件复位; 2>判断XMP/MC信号状态;若该信号为高电平时是微处理器模式,此时外部接口Zone7有效,Zone7被映射到存储空间的高位,这样向量表指向外部,系统从Zone7启动.若该信号为低电平时是微计算机模式,此时Zone7被禁止,向量表指向Boot ROM,这样系统既可以从内部存储空间启动,也可以从外部存储空间启动. 3>到Boot ROM的0x3FFC00处取出复位向量,跳到Boot函数;(TMS32