Linux系统移植之Uboot启动流程
Linux系统移植之Uboot启动流程
- 一,Uboot启动流程
- 1.Uboot的两阶段
- 1.1.第一阶段
- 1.11.硬件初始化
- 1.12.复制 U-Boot 到 RAM
- 1.13.跳转到第二阶段
- 1.2.第二阶段
- 1.21.C 语言环境初始化
- 1.22. 硬件设备初始化
- 1.23. 加载环境变量
- 1.24. 显示启动信息
- 1.25. 等待用户输入(可选)
- 1.26. 加载内核并启动
- 二,相关文件
- 1.u-boot.lds
- 2.BSS段
一,Uboot启动流程
1.Uboot的两阶段
第一阶段初始化硬件,采用的汇编语言。
第二阶段更为复杂的初始化和内核加载,采用C语言。
1.1.第一阶段
uboot启动,先找到入口(第一行程序),通过链接脚本u-boot.lds找到程序的入口地址,即文件中的_start,如下:


1.11.硬件初始化
- 关中断:在启动过程中,为了避免中断干扰初始化流程,首先会关闭所有中断。例如,在 ARM 架构中,通过设置 CPSR(当前程序状态寄存器)的相应位来禁止 IRQ(外部中断请求)和 FIQ(快速中断请求)。比如在_start的54行,跳转到reset函数中,reset函数会设置CPU处于SVC2模式,并且关闭FIQ和IRQ中断,用的是汇编语言。
- 初始化时钟:配置系统时钟,确保各个硬件模块能够以正确的频率运行。这可能涉及到设置 PLL(锁相环)等时钟源,以提供稳定的时钟信号。
- 初始化存储控制器:对内存控制器、Flash 控制器等进行初始化,以便后续能够正确访问内存和存储设备。例如,设置内存的时序参数、片选信号等。
- 初始化栈指针:为后续执行 C 代码准备栈空间,设置栈指针(SP)指向合适的内存地址。
1.12.复制 U-Boot 到 RAM
由于 Flash 等存储设备的读写速度较慢,为了提高程序的执行效率,通常会将 U-Boot 的第二阶段代码从 Flash 复制到 RAM 中执行。复制的起始地址和长度需要根据具体的硬件和 U-Boot 配置来确定。
1.13.跳转到第二阶段
在完成硬件初始化和代码复制后,程序会跳转到 U-Boot 第二阶段的入口点,开始执行 C 代码。
1.2.第二阶段
1.21.C 语言环境初始化
- 初始化全局变量:对 C 语言中的全局变量进行初始化,确保它们具有正确的初始值。
- 初始化堆:为动态内存分配(如
malloc函数)初始化堆空间。
1.22. 硬件设备初始化
- 初始化串口:配置串口通信参数,以便在启动过程中可以通过串口输出调试信息,方便开发人员进行调试和监控。
- 初始化网络设备:如果系统支持网络功能,会对网络设备进行初始化,包括设置 MAC 地址、配置网络接口等。
- 初始化其他设备:根据具体的硬件平台和应用需求,还可能对其他设备进行初始化,如 USB 设备、LCD 显示屏等。
1.23. 加载环境变量
U-Boot 支持环境变量的功能,这些环境变量可以用于配置 U-Boot 的行为和内核的启动参数。在启动过程中,U-Boot 会从存储设备(如 Flash)中加载预先保存的环境变量。
1.24. 显示启动信息
通过串口或其他输出设备,显示 U-Boot 的版本信息、硬件平台信息等启动信息,让用户了解系统的基本情况。
1.25. 等待用户输入(可选)
在某些情况下,U-Boot 会在启动过程中等待用户输入。例如,用户可以按下特定的按键进入 U-Boot 的命令行界面,进行一些手动配置和操作。
1.26. 加载内核并启动
根据环境变量中配置的内核加载地址和方式,U-Boot 会从存储设备(如 SD 卡、NAND Flash 等)或网络中加载操作系统内核到内存中。
U-Boot 会将一些必要的参数(如内核命令行参数、设备树等)传递给内核,并跳转到内核的入口点,将控制权交给内核,从而启动操作系统。bootz命令执行do_bootz函数,设置linux系统在DRAM中的存储位置0x80800000,设备树在DRAM中的存储地址0x83000000,最终由do_bootm_linux启动linux内核参数,起始地址保存linux内核第一行代码(汇编),就是函数kernel_entry(内核入口点),这个函数有三个参数,zero,arch,params,第一个参数zero为0,第二个参数为机器ID,第三个用于传递设备树。

二,相关文件
1.u-boot.lds
u-boot.lds即链接脚本:指导链接器如何进行内存分配和符号解析的文件。在uboot程序编译和链接时,编译器将代码源文件编译成.o的目标文件,这些文件包含了代码和数据,但是其地址是相对的,链接器就是将多个目标文件合并成一个可执行文件,为代码段,数据段和bss段分配实际的内存地址,链接脚本就是对其进行指导。
2.BSS段
程序内用于存放未初始化的全局变量和静态变量的一段区域。在编译器编译和链接过程中,将程序的不同部分分到不同段中,对于BSS段部分的内容,执行前会初始化为0(数据)活着空指针,好处就是节省执行文件的空间。具体生成这个BSS段:编译器在编译源文件时,会识别未初始化的全局变量和静态变量,将其标记为BSS类型,编译多个文件,会将所有BSS类型的变量合并到一个BSS段中,记录该段的起始地址和大小。
相关文章:
Linux系统移植之Uboot启动流程
Linux系统移植之Uboot启动流程 一,Uboot启动流程1.Uboot的两阶段1.1.第一阶段1.11.硬件初始化1.12.复制 U-Boot 到 RAM1.13.跳转到第二阶段 1.2.第二阶段1.21.C 语言环境初始化1.22. 硬件设备初始化1.23. 加载环境变量1.24. 显示启动信息1.25. 等待用户输入…...
【Open X-Embodiment】简单数据下载与预处理
文章目录 1. RLDS Dataset2. 处理成numpy格式3. 存储桶 1. RLDS Dataset 从 Octo 里面找到数据下载的代码 rlds_dataset_mod github 按照官网代码配置环境后,修改 prepare_open_x.sh,相当于只用 gsutil 下载数据: DOWNLOAD_DIR/mnt/data…...
【第四节】C++设计模式(创建型模式)-Builder(建造者)模式
目录 引言 一、Builder 模式概述 二、Builder 模式举例 三、Builder 模式的结构 四、Builder 模式的实现 五、Builder 模式的优缺点 六、总结 引言 Builder 模式是一种创建型设计模式,旨在将复杂对象的构建过程与其表示分离。通过一步步构建对象,…...
排查JVM的一些命令
查看JVM相关信息的方法 环境: Win10, jdk17 查看端口的Pid netstat -ano | findstr <端口号>列出当前运行的JVM进程 ## 用于输出JVM中运行的进程状态信息。通过jps,可以快速获取Java进程的PID(进程标识符), …...
uni-app(位置1)
文章目录 一、获取当前的地理位置、速度 uni.getLocation(OBJECT)二、打开地图选择位置 uni.chooseLocation(OBJECT)三、使用应用内置地图查看位置。uni.openLocation(OBJECT) 一、获取当前的地理位置、速度 uni.getLocation(OBJECT) App平台 manifest中配置好自己的地图厂商k…...
某手sig3-ios算法 Chomper黑盒调用
Chomper-iOS界的Unidbg 最近在学习中发现一个Chomper框架,Chomper 是一个模拟执行iOS可执行文件的框架,类似于安卓端大名鼎鼎的Unidbg。 这篇文章使用Chomper模拟执行某手的sig3算法,初步熟悉该框架。这里只熟悉模拟执行步骤以及一些常见的…...
登录-05.JWT令牌-介绍
一.JWT令牌 JWT令牌是一种简洁的、自包含的格式,用于在通讯双方之间以json数据格式安全的传输数据。说白了,JWT令牌就是将json格式的数据进行封装,从而实现安全传输。 所谓简洁,就是指JWT令牌就是一个简单的字符串。 所谓自包含…...
Mac下Python版本管理,适用于pyenv不起作用的情况
前言 声明:之前也在网上看到过可以使用pyenv来管理python版本,但由于作者的python安装路径实在是繁杂不堪,因此安装完成pyenv体验下来没有任何用处,但偶然发现vscode似乎可以看到各个python版本,因此写下这篇博客记录…...
Ubuntu 服务器Llama Factory 搭建DeepSeek-R1微调训练环境
1.首先了解一下什么是LLM微调 LLM 微调指的是在已经预训练好的大型语言模型基础上,使用特定的任务数据或领域数据,通过进一步的训练来调整模型的参数,使其在特定任务或领域上能够表现得更好。简单来说,就是对一个已经具备了丰富语…...
【redis】redis内存管理,过期策略与淘汰策略
一:Redis 的过期删除策略及处理流程如下: 1. 过期删除策略 Redis 通过以下两种策略删除过期键: 1.1 惰性删除 触发时机:当客户端访问某个键时,Redis 会检查该键是否过期。执行流程: 客户端请求访问键。…...
RabbitMQ学习—day6—死信队列与延迟队列
目录 死信队列 1. 死信的概念 2. 死信的来源 实战演练 1. 消息TTL过期 2. 队列达到最大长度 3. 消息被拒绝 延迟队列 概念 使用场景 TTL的两种设置 死信队列 1. 死信的概念 1.1 先从概念解释上搞清楚这个定义,死信,顾名思义就是无法被消费的…...
seacmsv9联合注入数据以及绕过 ORDERBY
seacmsv9联合注入数据 php源码 <?php session_start(); require_once("../../include/common.php"); $id (isset($gid) && is_numeric($gid)) ? $gid : 0; $page (isset($page) && is_numeric($page)) ? $page : 1; $type (isset($type) …...
day58 第十一章:图论part08
拓扑排序精讲 关键: 先找到入度为0的节点,把这些节点加入队列/结果,然后依次循环再找。 #include <iostream> #include <vector> #include <queue> #include <unordered_map> using namespace std; int main() {int …...
网络安全-openssl工具
OpenSSl是一个开源项目,包括密码库和SSL/TLS工具集。它已是在安全领域的事实标准,并且拥有比较长的历史,现在几乎所有的服务器软件和很多客户端都在使用openssl,其中基于命令行的工具是进行加密、证书管理以及测试最常用到的软件。…...
Java面试第六山!《MySQL基础知识点》
一、引言 MySQL 作为一款广泛使用的开源关系型数据库管理系统,在软件开发领域占据着重要地位。无论是小型项目还是大型企业级应用,都能看到 MySQL 的身影。今天就来和大家分享 MySQL 的相关知识,帮助大家更好地应对日常开发和面试。 二、My…...
云计算中的API网关是什么?为什么它很重要?
在云计算架构中,API网关(API Gateway)是一个重要的组件,主要用于管理、保护和优化不同服务之间的接口(API)通信。简单来说,API网关就像是一个中介,它充当客户端和后端服务之间的“桥…...
【WebGL】fbo双pass案例
双pass渲染案例(离线渲染一个三角面,然后渲染到一个占满屏幕的矩阵上) 离线渲染如何需要开启深度测试的话,需要额外操作,这里不展开 <!DOCTYPE html> <html lang"en"><head><meta ch…...
Unity面板介绍_层级面板(23.1.1)
一、Inspector(检视面板) 显示当前选定游戏对象附加的组件及其属性信息。为重要游戏物体选择图标 二、面板详情...
详解Nginx 配置
一、Nginx 介绍 Nginx 是一款轻量级的 Web 服务器 / 反向代理服务器及电子邮件(IMAP/POP3)代理服务器。它由俄罗斯的程序设计师 Igor Sysoev 所开发,自 2004 年发布以来,凭借其高性能、低内存消耗、高并发处理能力等特点…...
数据库系统概念
1. 绪论 数据库的基本概念: 数据(data): 数据库中存储的基本对象, 可以是文字, 声音, 图片, 视频等。 数据库(DB): 概括来说就是永久存储, 有组织, 可共享的大量数据的集合。 数据库管理系统(DBMS): 和操作系统一样是计算机基础软件, 主要有数据定义语言(DDL, 对数据对象的组…...
浏览器访问 AWS ECS 上部署的 Docker 容器(监听 80 端口)
✅ 一、ECS 服务配置 Dockerfile 确保监听 80 端口 EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]或 EXPOSE 80 CMD ["python3", "-m", "http.server", "80"]任务定义(Task Definition&…...
linux之kylin系统nginx的安装
一、nginx的作用 1.可做高性能的web服务器 直接处理静态资源(HTML/CSS/图片等),响应速度远超传统服务器类似apache支持高并发连接 2.反向代理服务器 隐藏后端服务器IP地址,提高安全性 3.负载均衡服务器 支持多种策略分发流量…...
从零实现富文本编辑器#5-编辑器选区模型的状态结构表达
先前我们总结了浏览器选区模型的交互策略,并且实现了基本的选区操作,还调研了自绘选区的实现。那么相对的,我们还需要设计编辑器的选区表达,也可以称为模型选区。编辑器中应用变更时的操作范围,就是以模型选区为基准来…...
dedecms 织梦自定义表单留言增加ajax验证码功能
增加ajax功能模块,用户不点击提交按钮,只要输入框失去焦点,就会提前提示验证码是否正确。 一,模板上增加验证码 <input name"vdcode"id"vdcode" placeholder"请输入验证码" type"text&quo…...
《通信之道——从微积分到 5G》读书总结
第1章 绪 论 1.1 这是一本什么样的书 通信技术,说到底就是数学。 那些最基础、最本质的部分。 1.2 什么是通信 通信 发送方 接收方 承载信息的信号 解调出其中承载的信息 信息在发送方那里被加工成信号(调制) 把信息从信号中抽取出来&am…...
linux 错误码总结
1,错误码的概念与作用 在Linux系统中,错误码是系统调用或库函数在执行失败时返回的特定数值,用于指示具体的错误类型。这些错误码通过全局变量errno来存储和传递,errno由操作系统维护,保存最近一次发生的错误信息。值得注意的是,errno的值在每次系统调用或函数调用失败时…...
微服务商城-商品微服务
数据表 CREATE TABLE product (id bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 商品id,cateid smallint(6) UNSIGNED NOT NULL DEFAULT 0 COMMENT 类别Id,name varchar(100) NOT NULL DEFAULT COMMENT 商品名称,subtitle varchar(200) NOT NULL DEFAULT COMMENT 商…...
04-初识css
一、css样式引入 1.1.内部样式 <div style"width: 100px;"></div>1.2.外部样式 1.2.1.外部样式1 <style>.aa {width: 100px;} </style> <div class"aa"></div>1.2.2.外部样式2 <!-- rel内表面引入的是style样…...
前端开发面试题总结-JavaScript篇(一)
文章目录 JavaScript高频问答一、作用域与闭包1.什么是闭包(Closure)?闭包有什么应用场景和潜在问题?2.解释 JavaScript 的作用域链(Scope Chain) 二、原型与继承3.原型链是什么?如何实现继承&a…...
vue3+vite项目中使用.env文件环境变量方法
vue3vite项目中使用.env文件环境变量方法 .env文件作用命名规则常用的配置项示例使用方法注意事项在vite.config.js文件中读取环境变量方法 .env文件作用 .env 文件用于定义环境变量,这些变量可以在项目中通过 import.meta.env 进行访问。Vite 会自动加载这些环境变…...
