3、嵌入式系统的启动过程(BoodLoader)

news2024/12/23 18:44:37

1、系统启动过程

在这里插入图片描述
通电 - > 执行BootLoader - > 加载内核 - > 挂在根文件系统 - > 执行应用程序

Windows的启动过程:
通电 - > 执行BIOS - > 加载WinNT内核 - > 挂在文件系统 - > 执行应用程序

二、嵌入式系统的结构

在这里插入图片描述

BootLoader

1、BootLoader的概念

硬件平台通电后不会直接运行操作系统。通电之后到执行操作系统需要一个引导的过程,而这个过程需要依赖启动引导程序,所以启动引导程序被称为Boot Loader。需要注意的是,Boot Loader是统称,Boot Loader的种类很多。比如X86平台使用BIOS,arm平台使用U-Boot等都属于Boot Loader。

2、Boot Loader的作用

启动引导程序起始就是硬件平台通电后运行的一段程序,这段程序可以初始化硬件,比如建立内存的映射表。其实际目的就是为了Linux内核的正常运行做准备,就是为了建立一个合适的运行平台

3、Boot Loader的说明

Boot Loader是通用的启动引导程序,可以在不同的硬件平台上运行,如ARM、X86、PowerPC、MIPS等多种架构,但是不完全通用。也就是不能把一个Boot Loader源码在不经过修改的前提下使用在硬件平台

Boot Loader不光依赖于处理器的架构,而且还依赖硬件平台的板级硬件,就必须要对启动引导程序进行修改。比如:现在购买2块不同公司的开发板,这2块开发板的处理器用的是同一种,能不能把A公司的BootLoader直接移植到B公司的开发板使用?答案是不可以的,必须要根据B公司的开发板来修BootLoader。

4、Boot Loader的启动

在硬件通电后,CPU会去某个地址下进行取址,这个地址是由处理器决定的。一般ARM处理器都会从0x00000000这个地址取第一条指令,所以就必须把Flash的地址映射在0x00000000地址下,或者就直接把Boot Loader存储在Flash的首地址,这样CPU才可以正常操作

三、U-Boot

1、U-Boot的概念

U-Boot的全称是Universal BoodLoader,是一种通用的引导程序,属于BoodLoader的一种

Boot:初始化硬件平台,提供一个合适的环境
Loader:加载Linux内核

通用的地方

  • 多种处理器架构:U-Boot可以运行在:X86、ARM、MIPS、PowerPC等架构
  • 多种操作系统:U-Boot可以运行在:Linux、WinCE、安卓、等系统
  • 多种开发板:U-Boot可以运行在:Cortex A8、Cortex A53、Cortex A72等平台

Boot Loader的运行阶段:

(1)CPU的初始化:采用汇编语言,这部分是没有压缩过的,初始化CPU,eMMC、看门狗、Cache等,然后会解压第二部分的image(映像),然后拷贝到内存中

(2)板级的初始化:采用C语言设计,这部分代码是经过压缩的,初始化开发板的串口、LCD、网口等,然后回加载Linux内核

注意

  • 在整个Boot Loader期间,MMU(内存管理单元)都是没有被初始化的,所以CPU都是访问的物理地址

2、U-Boot的资源

U-Boot是开源的,可以在官网下载不同版本的源码,然后根据自己的硬件平台进行修改,并移植到硬件平台上
U-Boot官网:U-Boot官网

3、U-Boot的作用

(1)CPU的初始化:用汇编语言初始化Cache、时钟、看门狗、中断…

(2)板级的初始化:用C语言初始化串口、网卡、LCD…

(3)提供一些工具:进入U-Boot的控制台、提供U-Boot的命令…

(4)加载Linux内核

4、U-Boot的输出

在这里插入图片描述

5、U-Boot的命令

Uboot提供了一个控制台,在硬件平台通电后,Uboot会延时等待几秒钟(一般是3s),用户可以利用Uboot提供的命令操作。比如:烧写系统(fast boot、SD卡…)、设置环境变量。

这些操作都必须由Uboot提供的shell命令实现,shell指的是用户操作接口,shell的原理就是一个不断进行信息接收、解析、执行死循环

Uboot的控制台和Linux系统提供的终端都是采用行缓冲模式进行shell命令接收,也就是以回车键作为命令的结束但是不可以把Linux系统提供的shell命令在Uboot的控制台使用

虽然都是shell命令,但是Uboot和Linux系统采用的shell命令集是不同的,而且是不兼容的

  • 输出板级信息(bdi
    在这里插入图片描述

  • 输出环境变量(pri

  • 设置环境变量(set

  • 保存环境变量(save

  • 删除环境变量(set 变量名

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1043627.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

GoLang 百行代码实现小项目《家庭收支软件》

界面显示 实现思路 GoLang 百行代码实现的小项目《家庭收支软件》是一个简单的家庭收支记账软件,可以通过命令行界面记录和显示收支明细。 在代码中,定义了两个结构体类型:record(代表一条收支记录)和software&#…

直线模组的品牌有哪些?

中国工业制造业快速发展,工业自动化领域也进入了飞速发展的阶段,直线模组作为工业自动化领域不可缺少的机器人之一,有着重要的不可或缺的作用,在行业内做得好的直线模组品牌有哪些呢? 1、NSK:日本精工株式会…

关于MATLAB R2022b中MATLAB function没有edit data选项的解决办法

问题描述 在MATLAB 2022b的simulink中双击MATLAB function,出来的是这个界面,而不是跳转到MATLAB的编辑窗口。因此就找不到edit data选项,没法完成新建data store memory 全局变量。 解决办法: 点击 编辑数据 按钮 在弹出的窗…

SQL sever中的约束

目录 一、约束定义 二、约束分类 三、定义约束 四、约束相关语法格式 4.1主键约束(Primary Key Constraint): 4.2外键约束(Foreign Key Constraint): 4.3唯一约束(Unique Constraint&…

常用的文本对比工具或网站

以下是一些常用的文本对比工具的下载地址或网站访问地址: DiffNow: https://www.diffnow.com/ WinMerge: https://winmerge.org/ Beyond Compare: https://www.scootersoftware.com/ Meld: https://meldmerge.org/ diff:文本对比/字符串差异比较 - 在线工具 请…

解决仪器掉线备忘

网络管控越来越严格,老的Mac模式连接的仪器经常断开,要么是网络没活动被断开TCP了,要么是网络波动无法保持TCP。每次重启仪器控制很麻烦,基于之前用M写http服务的基础上改进仪器接口连接。 参照之前实现http服务的逻辑 最终逻辑 …

用CNC网关推动工业自动化革命

在当今的工业自动化领域,机床(CNC,计算机数值控制)已成为制造业的重要支柱。然而,这些复杂的设备在数据收集、通信和集成方面通常面临诸多挑战。其中,CNC转Modbus网关为解决这些问题提供了有效的解决方案。…

Vue+ElementUI实现动态树和表格数据的查询

目录 前言 一、动态树的实现 1.数据表 2.编写后端controller层 3.定义前端发送请求路径 4.前端左侧动态树的编写 4.1.发送请求获取数据 4.2.遍历左侧菜单 5.实现左侧菜单点击展示右边内容 5.1.定义组件 5.2.定义组件与路由的对应关系 5.3.渲染组件内容 5.4.通过动态…

Linux0.11——操作系统怎么把自己从硬盘搬到内存

这里先直接给出答案:中断 此时,操作系统用短短几行代码,将数据段寄存器ds和代码段寄存器cs设置为了0x9000,方便之后的程序访问代码和数据,并且将栈顶地ss:sp设置在了远离代码的位置0x9000足够遥远的0x9FF00&#xff0c…

Lesson08---string

lesson11: 一、 1.string大概有多少个接口函数?(3:2:25) 2.string在C库的reference的XX(3:3:47) a.我们平时用的string是下面的哪一个?(3&…

2、Linux中静态IP与动态IP的修改

修改为静态IP 打开文件 sudo vim /etc/network/interfaces修改如下 # interfaces(5) file used by ifup(8) and ifdown(8) auto lo iface lo inet loopbackauto ens33#配置网络为DHCP模式 #iface ens33 inet dhcp#配置网络 ens33为静态IP模式 iface ens33 inet static #设置…

什么才是物联网领域最好的开发语言?

什么才是物联网领域最好的开发语言? 最好!运行最快?开发最高效?最容易学习? 各有特点! 采用C/C语言,运行最快,一般采用厂家提供的底层驱动支持包BSP,所有MCU都支持。如…

DKD蒸馏复现

知识蒸馏主要分两类: 1:基于logits 2:基于feature logits蒸馏主要是在早期,后期效果逐步被基于feature蒸馏超越。 cvpr2022的DKD基于传统的KD进行改进,重铸logits蒸馏的荣光。目前很多蒸馏都采用DKD方案&#xff0…

通俗易懂经典的黑客入门教程

第一节、黑客的种类和行为 以我的理解,“黑客”大体上应该分为“正”、“邪”两类,正派黑客依靠自己掌握的知识帮助系统管理员找出系统中的漏洞并加以完善,而邪派黑客则是通过各种黑客技能对系统进行攻击、入侵或者做其他一些有害于网络的事…

一维卷积神经网络

假设输入数据维度为8,filter维度为5; 不加padding时,输出维度为4,如果filter的数量为16,那么输出数据的shape就是4*16. 一维卷积不代表卷积核只有一维,也不代表被卷积的feature也是一维。一维的意思是说卷…

Pytorch CUDA11.4版本匹配

1.查看CUDA,并查找对应的torch的版本 首先判断自己是否适合使用GPU版本的torch,打开自己的cmd输入 NVIDIA-smi CUDA11.4版本比较特殊的版本,可以用CUDA11.3版本 2.下载orch、torchvision、torchaudio(三者版本要相关) 知道pytorch可以下载…

Day57:组件库封装-1

封装element组件 参考对象 折叠面板 按钮 npm create vue3 npm i 使用vue3建库如果报错可以尝试禁用vs的 vetur 插件,这是vue2插件,会给vue3项目报错(禁用了之后需要重新加载 src新建components文件夹 下面新建Button文件夹,新建vue&…

9月19-21日上课内容 zabbix监控系统与部署Zabbix5.0监控

本章结构 前言 监控软件的作用 作为一个运维,需要会使用监控系统查看服务器状态以及网站流量指标,利用监控系统的数据去了解上线发布的结果和网站的健康状态 利用一个优秀的监控软件,我们可以: ●通过一个友好的界面进行浏览整…

什么是单片机最小系统?

大家好,我是山羊君Goat。 对于单片机来说,它是一种电子编程器件,可以实现很多多样的功能,常见的单品机有51,STM32等等。 单片机(single-chip Microcomputer),是一种集成电路芯片&am…

云服务器 CentOS7 操作系统上安装Jpress (Tomcat 部署项目)

1、xShell 和 xftp 下载安装(略) https://www.xshell.com/zh/free-for-home-school/2、xftp 连接云服务器 xftp 新建连接 3、JDK 压缩包下载 下载 jdk1.8 注:此处 CentOS7 是64位,所以下载的是:Linux x64&#xf…