当前位置: 首页 > article >正文

Linux学习笔记——零基础详解:什么是Bootloader?U-Boot启动流程全解析!

零基础详解:什么是Bootloader?U-Boot启动流程全解析!

    • 一、什么是Bootloader?
      • 📌 举个例子:
    • 二、U-Boot 是什么?
    • 三、U-Boot启动过程:分为两个阶段
      • 🔹 第一阶段(汇编阶段)
      • 🔹 第二阶段(C语言阶段)
    • 四、U-Boot是怎么启动Linux内核的?
    • 五、U-Boot与Linux之间的参数传递机制
      • 💡 什么是 tag(启动参数)?
    • 六、为什么U-Boot要关闭 Cache 和 MMU?
    • 七.为什么要给内核传递参数?
      • 为什么要传递这些参数?
    • 八、系统启动完整流程回顾
    • 九、总结一句话
    • 📌 小贴士:常见面试题汇总

一、什么是Bootloader?

Bootloader(引导加载程序),是一段特殊的“小程序”,它运行在 系统刚上电时,主要目的是:

  • 初始化硬件环境(如:内存、时钟、中断、串口等)
  • 然后将 Linux内核从 flash(NAND, NOR FLASH,SD,MMC等)拷贝到SDRAM中,最后启动Linux内核

通俗一点讲,Bootloader 就像电脑中的 BIOS —— 当你按下电源开关,它最先启动,完成最基础的硬件检测后,才将控制权交给操作系统(比如 Windows 或 Linux)。

📌 举个例子:

项目PC系统嵌入式Linux系统
初始程序BIOSBootloader
操作系统WindowsLinux
存储介质硬盘Flash / SD卡等

二、U-Boot 是什么?

U-Boot(全称为 Universal Bootloader)是一种 开源、通用的Bootloader,支持多种架构(ARM、MIPS、x86等),被广泛应用于嵌入式Linux开发中。

它的主要任务:

  • 初始化硬件资源(如内存、串口、存储器等)
  • 加载Linux内核到内存中
  • 传递启动参数给内核
  • 启动Linux内核

三、U-Boot启动过程:分为两个阶段

🔹 第一阶段(汇编阶段)

此阶段主要用 汇编代码编写,功能包括:

  1. 初始化时钟系统
  2. 关闭看门狗(防止系统误复位)
  3. 关闭中断
  4. 启动指令Cache(ICache)
  5. 关闭数据Cache与TLB
  6. 关闭MMU
  7. 初始化SDRAM(用于加载后续程序)
  8. 初始化NAND Flash
  9. 代码重定位(将U-Boot代码搬运至SDRAM中运行)

💡 注意:这部分代码位置受限(通常在片内RAM或FLASH运行),所以通常要写得很精炼。


🔹 第二阶段(C语言阶段)

这部分用 C语言编写,主要功能是:

  1. 初始化串口(便于调试)
  2. 打印启动信息
  3. 检测内存映射情况
  4. 从存储介质读取Linux内核镜像和根文件系统(initrd)将内核映象和根文件系统映象从 Flash上读到SDRAM空间中
  5. 设置内核启动参数
  6. 跳转到Linux内核执行入口

四、U-Boot是怎么启动Linux内核的?

当U-Boot完成自身工作后,就会把控制权交给Linux内核。那么,怎么跳转呢?

👉 本质就是:修改PC寄存器的值为内核所在地址

这样CPU下一条执行指令就来自Linux内核,开始正式启动!


五、U-Boot与Linux之间的参数传递机制

这部分是面试常考,请务必掌握!

在跳转到内核之前,U-Boot 会设置好三个寄存器:

寄存器含义示例说明
R0保持为0固定写0即可
R1机器ID(开发板型号)如友善之臂开发板是199,见mach-types.h
R2参数的地址(tag结构体)tag链表,里面保存了内存大小、命令行、根文件系统等

📌 这些参数是内核“启动时所需的环境信息”,如果不给内核传递参数,它无法知道设备的具体配置!

  1. R0寄存器:设置为0,通常用于标识内核启动时的参数。
  2. R1寄存器:传递给内核一个“机器ID”。这是一个唯一标识当前硬件平台的ID,每个开发板或CPU都会有一个唯一的ID。内核会根据该ID来判断是否支持当前硬件平台。
  3. R2寄存器:存储一个指向参数列表的指针,该列表包含了内核启动时需要的所有环境信息(例如内存大小、内存地址、文件系统等)。

💡 什么是 tag(启动参数)?

tag 是一组结构体,存放了启动参数,形式如下:

struct tag {struct tag_header {uint32_t size;   // tag大小(单位:4字节)uint32_t tag;    // tag类型(如ATAG_MEM、ATAG_CMDLINE等)} hdr;union {struct tag_mem32 mem;struct tag_cmdline cmdline;// 其他类型参数...} u;
};

📌 常见的tag有:

  • ATAG_CORE:表示起始
  • ATAG_MEM:内存起始地址与大小
  • ATAG_CMDLINE:命令行参数(如根文件系统路径)
  • ATAG_NONE:表示结束

六、为什么U-Boot要关闭 Cache 和 MMU?

  • 上电后RAM未初始化前,Cache 不能正常工作。
  • 如果数据 Cache 开启了,会导致从未初始化的Cache中读取错误数据,程序可能崩溃!
  • 所以:必须关闭MMU和Data Cache,指令Cache可以开也可以不开。

七.为什么要给内核传递参数?

在启动Linux内核之前,U-Boot完成了对硬件的基本初始化。此时,U-Boot已经“适应”了当前的开发板,但Linux内核并不一定能直接支持所有开发板。因为每个开发板的硬件配置都可能有所不同,例如不同的CPU型号、内存配置、外设接口等。而内核本身并不是为每个具体的开发板都做了硬件适配的,因此,内核在启动时需要了解当前开发板的硬件环境。为此,U-Boot需要将这些硬件信息传递给内核,以帮助内核做相应的配置和适配。

为什么要传递这些参数?

  1. 硬件适配:Linux内核需要了解当前硬件平台的配置(例如内存大小、CPU架构、设备树等)才能正确配置和初始化硬件资源。如果没有这些信息,内核就无法正确识别或初始化硬件设备。
  2. 启动过程的灵活性:开发板通常会有不同的硬件平台,U-Boot的作用就是提供一个通用的引导机制,而通过参数传递,U-Boot使得内核在加载后可以根据传递的参数调整自身的行为和配置。
  3. 内核启动时的配置:内核需要根据不同的硬件环境来调整内存、CPU等硬件的使用模式。例如,在某些开发板上可能需要配置特定的硬件接口,或者根据内存的大小调整内核的行为。通过参数传递,内核能够灵活地进行这些调整。

八、系统启动完整流程回顾

下面是系统上电到进入Linux系统的完整流程图:

[ 上电/复位 ]↓
[ ROM代码执行 ]↓
[ 初始化外设 & SDRAM ]↓
[ 加载并执行U-Boot ]↓
[ U-Boot初始化硬件 ]↓
[ 加载Linux内核 + initrd ]↓
[ 设置启动参数(R0, R1, R2)]↓
[ 跳转到内核入口 ]↓
[ Linux内核初始化 ]↓
[ 挂载根文件系统 ]↓
[ 启动用户空间进程 ]

九、总结一句话

Bootloader 就是操作系统的“搬运工 + 启动器”,而 U-Boot 就是最流行的 Bootloader,它让 Linux 成为可能!


📌 小贴士:常见面试题汇总

面试问题回答要点
什么是Bootloader?启动时执行的第一段程序,初始化硬件,加载并启动内核
U-Boot做了哪些事?两阶段:汇编(初始化)、C语言(加载内核+参数设置+跳转)
U-Boot如何跳转到Linux内核?设置PC寄存器为内核地址
参数是如何传递给内核的?用R0=0, R1=机器ID, R2=tag结构体地址传递
为什么要关闭Data Cache?避免RAM未初始化时Cache取错误数据导致程序异常
什么是tag结构?如何组织?struct tag,含header+联合体,ATAG_CORE起始、ATAG_NONE结束

相关文章:

Linux学习笔记——零基础详解:什么是Bootloader?U-Boot启动流程全解析!

零基础详解:什么是Bootloader?U-Boot启动流程全解析! 一、什么是Bootloader?📌 举个例子: 二、U-Boot 是什么?三、U-Boot启动过程:分为两个阶段🔹 第一阶段(汇…...

Windows环境下开发pyspark程序

Windows环境下开发pyspark程序 一、环境准备 1.1. Anaconda/Miniconda(Python环境) 如果不怕包的版本管理混乱,可以直接使用已有的Python环境。 需要安装anaconda/miniconda(python3.8版本以上):Anaconda…...

thinkphp8.0上传图片到阿里云对象存储(oss)

1、开通oss,并获取accessKeyId、accessKeySecret <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, initial-scale1.0" /><tit…...

SSM婚纱摄影网的设计

&#x1f345;点赞收藏关注 → 添加文档最下方联系方式咨询本源代码、数据库&#x1f345; 本人在Java毕业设计领域有多年的经验&#xff0c;陆续会更新更多优质的Java实战项目希望你能有所收获&#xff0c;少走一些弯路。&#x1f345;关注我不迷路&#x1f345; 项目视频 SS…...

1110+款专业网站应用程序UI界面设计矢量图标figma格式素材 Icon System | 1,100+ Icons Easily Customize

1110款专业网站应用程序UI界面设计矢量图标figma格式素材 Icon System | 1,100 Icons Easily Customize 产品特点 — 24 x 24 px 网格大小 — 2px 线条描边 — 所有形状都是基于矢量的 — 平滑和圆角 — 易于更改颜色 类别 &#x1f6a8; 警报和反馈 ⬆️ 箭头 &…...

nacos的地址应该配置在项目的哪个文件中

在 Spring Boot 和 Spring Cloud 的上下文中&#xff0c;​Nacos 的地址既可以配置在 bootstrap.yml 中&#xff0c;也可以配置在 application.yml 中&#xff0c;但具体取决于使用场景和需求。以下是两者的区别和最佳实践&#xff1a; ​1. bootstrap.yml vs application.yml …...

Llama 4 家族:原生多模态 AI 创新的新时代开启

0 要点总结 Meta发布 Llama 4 系列的首批模型&#xff0c;帮用户打造更个性化多模态体验Llama 4 Scout 是有 170 亿激活参数、16 个专家模块的模型&#xff0c;同类中全球最强多模态模型&#xff0c;性能超越以往所有 Llama 系列模型&#xff0c;能在一张 NVIDIA H100 GPU 上运…...

OpenCV 在树莓派上进行实时人脸检测

这段 Python 代码借助 OpenCV 库实现了在树莓派上进行实时人脸检测的功能。它会开启摄像头捕获视频帧&#xff0c;在每一帧里检测人脸并以矩形框标记出来&#xff0c;同时在画面上显示帧率&#xff08;FPS&#xff09;。 依赖库 cv2&#xff1a;OpenCV 库&#xff0c;用于计算…...

SMT加工贴片核心工艺解析

内容概要 表面贴装技术&#xff08;SMT&#xff09;作为现代电子制造的核心工艺&#xff0c;其加工流程的精细度直接影响产品性能和良率。本文系统性梳理SMT贴片生产的全链条技术节点&#xff0c;以焊膏印刷、元件贴装、回流焊接三大核心工序为轴线&#xff0c;剖析各环节的工…...

嵌入式Linux驱动开发基础知识(三)

Linux系统与驱动开发&#xff1a;从字符设备到I2C传感器驱动实战 本文将系统梳理Linux驱动开发的核心知识与实战流程&#xff0c;从基础概念到项目实践&#xff0c;带你完整掌握Linux驱动开发的关键技术。我们将从字符设备驱动框架讲起&#xff0c;深入设备树配置原理&#xf…...

正则表达式(Regular Expression,简称 Regex)

一、5w2h&#xff08;七问法&#xff09;分析正则表达式 是的&#xff0c;5W2H 完全可以应用于研究 正则表达式&#xff08;Regular Expressions&#xff09;。通过回答 5W2H 的七个问题&#xff0c;我们可以全面理解正则表达式的定义、用途、使用方法、适用场景等&#xff0c…...

Superset 问题

和nginx结合使用&#xff0c;如果不是配置到根路径&#xff0c;会比较麻烦&#xff0c;我试了很多种方法&#xff0c;也就 这个 靠谱点&#xff0c;不过&#xff0c;我最后还是选择的部署在根路径&#xff0c;先探索一番再说默认不能选择mysql数据库&#xff0c;需要安装mysql客…...

JMeter脚本录制(火狐)

录制前准备&#xff1a; 电脑&#xff1a; 1、将JMeter证书导入&#xff0c;&#xff08;bin目录下有一个证书&#xff0c;需要安装这个证书到电脑中&#xff09; 2、按winr&#xff0c;输入certmgr.msc&#xff0c;打开证书&#xff0c;点击下一步&#xff0c;输入JMeter证书…...

基于SpringBoot的“高校社团管理系统”的设计与实现(源码+数据库+文档+PPT)

基于SpringBoot的“高校社团管理系统”的设计与实现&#xff08;源码数据库文档PPT) 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SpringBoot 工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 系统展示 总体功能结构图 局部E-R图 系统首页页面 用户…...

Maven/Gradle的讲解

一、为什么需要构建工具? 在理解 Maven/Gradle 之前,先明确它们解决的问题: ​​依赖管理​​:项目中可能需要引入第三方库(如 Spring、JUnit 等),手动下载和管理这些库的版本非常麻烦。​​标准化构建流程​​:编译代码、运行测试、打包成 JAR/WAR 文件等步骤需要自动…...

C# Winform 入门(3)之尺寸同比例缩放

放大前 放大后 1.定义当前窗体的宽度和高度 private float x;//定义当前窗体的宽度private float y;//定义当前窗台的高度 2.接收当前窗体的尺寸大小 x this.Width;//存储原始宽度ythis.Height;//存储原始高度setTag(this);//为控件设置 Tag 属性 3.声明方法&#xff0c;获…...

infinityfree最新免费建站详细教程_无需备案_5G空间_无限流量_免费域名_免费SSL

一、明确目标—是否要使用 1.为什么选择InfinityFree&#xff1f; 对于初学者、学生或只是想尝试网站搭建的个人用户来说&#xff0c;InfinityFree提供了一个绝佳的免费解决方案。这个国外免费的虚拟主机服务提供&#xff1a; 5GB存储空间 - 足以存放个人博客、作品集或小型…...

打造高效英文单词记忆系统:基于Python的实现与分析

在当今全球化的世界中,掌握一门外语已成为必不可少的技能。对于许多学习者来说,记忆大量的英文单词是一个漫长而艰难的过程。为了提高学习效率,我们开发了一个基于Python的英文单词记忆系统。这个系统结合了数据管理、复习计划、学习统计和测试练习等多个模块,旨在为用户提…...

node_modules\deasync: Command failed.

运行&#xff1a;“yarn install” 时报错 PS D:\WebPro\hainan-mini-program> yarn install yarn install v1.22.19 [1/4] Resolving packages... [2/4] Fetching packages... [3/4] Linking dependencies... warning " > babel-loader8.2.2" has un…...

session临时文件包含

使用情况 if(isset($_GET[file])){$file $_GET[file];$file str_replace("php", "???", $file);$file str_replace("data", "???", $file);$file str_replace(":", "???", $file);$file str_repla…...

【新能源汽车研发测试数据深度分析:从传感器到智能决策的硬核方法论】

摘要&#xff1a; 本文系统性解构新能源汽车&#xff08;NEV&#xff09;研发测试中的数据采集、处理及分析全链条&#xff0c;覆盖传感器融合、大数据清洗、AI算法优化等核心技术&#xff0c;并引入行业顶级案例&#xff08;如特斯拉Autopilot验证、宁德时代BMS算法迭代&#…...

游戏引擎学习第206天

回顾并为当天的工作定下目标 接着回顾了前一天的进展。之前我们做了一些调试功能&#xff0c;并且已经完成了一些基础的工作&#xff0c;但是还有一些功能需要继续完善。其中一个目标是能够展示实体数据&#xff0c;以便在开发游戏逻辑系统时&#xff0c;可以清晰地查看和检查…...

Zapier MCP:重塑跨应用自动化协作的技术实践

引言&#xff1a;数字化协作的痛点与突破 在当今多工具协同的工作环境中&#xff0c;开发者与办公人员常常面临数据孤岛、重复操作等效率瓶颈。Zapier推出的MCP&#xff08;Model Context Protocol&#xff09;协议通过标准化数据交互框架&#xff0c;为跨应用自动化提供了新的…...

ubuntu部署ollama+deepseek+open-webui

ubuntu部署ollamadeepseekopen-webui 全文-ubuntu部署ollamadeepseekopen-webui 大纲 Ollama部署 安装Ollama&#xff1a;使用命令apt install curl和curl -fsSL https://ollama.com/install.sh | sh ollama-v网络访问配置&#xff1a;设置环境变量OLLAMA_HOST0.0.0.0:11434&…...

蓝桥云客--破译密码

5.破译密码【算法赛】 - 蓝桥云课 问题描述 在近期举办的蓝桥杯竞赛中&#xff0c;诞生了一场激动人心的双人破译挑战。比赛的主办方准备了N块神秘的密码芯片&#xff0c;参赛队伍需要在这场智力竞赛中展示团队合作的默契与效率。每个队伍需选出一位破译者与一位传输者&#…...

量子计算与经典计算的拉锯战:一场关于计算未来的辩论

在计算科学领域&#xff0c;一场关于未来的激烈辩论正在上演。2025年3月&#xff0c;D-Wave量子公司的研究人员在《Science》杂志上发表了一项突破性成果&#xff0c;声称他们的量子退火处理器在几分钟内解决了一个经典超级计算机需要数百万年才能完成的复杂现实问题。这一声明…...

Java面试黄金宝典30

1. 请详细列举 30 条常用 SQL 优化方法 定义 SQL 优化是指通过对 SQL 语句、数据库表结构、索引等进行调整和改进&#xff0c;以提高 SQL 查询的执行效率&#xff0c;减少系统资源消耗&#xff0c;提升数据库整体性能的一系列操作。 要点 从索引运用、查询语句结构优化、数据…...

React-Diffing算法和key的作用

1.验证Diffing算法 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title> </he…...

【NLP 54、大模型训练相关知识】

目录 引言&#xff1a;大模型训练两大问题 一、并行训练 1.方式一&#xff1a;数据并行 DP ① 复制模型到多个GPU ② 各自计算梯度后累加&#xff0c;再反传更新 ③ 需要单卡就能训练整个模型&#xff08;显存够大&#xff09; 2.方式二&#xff1a;模型并行 PP ① 将模型的不同…...

cursor机器码重置

1、下载vscode插件 cursor-fake-machine-0.0.2 2、将插件拖入拓展 3、彻底将cursor账号退出 setting -> Manage -> 退出账号 4、打开cursor&#xff0c;ctrlshiftp &#xff0c;输入fake,点击确定...