I.MX6ULL启动详解:Boot配置、Bootable image启动头的组成
本篇文章来了解一下I.MX6ULL的启动方式,实际上之前我介绍了NXP的跨界MCU RT1170的启动方式:I.MX RT1170启动详解:Boot配置、Bootable image头的组成,两个芯片虽然一个是Cortex-M,一个是Cortex-A,但是都是来源于NXP,所以有类似的BootROM代码,在启动的引导方式上是类似的,下面就来详细介绍一下。
文章目录
- 1 基础知识
- 2 Boot配置
- 2.1 BOOT_MODE
- 2.2 BOOT_CFG配置
- 3 Bootable image启动头
- 3.1 组成
- 3.2 实例
- 3.2.1 程序结构
- 3.2.2 程序镜像内容分析
1 基础知识
1、BootROM
在上电后,会执行一段固定的BootROM程序,这段程序是由NXP官方写好的,主要是用来根据用户提供的信息对镜像进行引导。比如说用户希望将代码从Nand/EMMC/SD拷贝到SDRAM执行、用户希望上电时能初始化好SDRAM…这都可以交给BootROM完成。
2、image头
那BootROM要怎么知道用户希望做哪些初始化呢?我们就需要在编译出来的.bin文件的开头添加一些头信息,以提供给BootROM,让它知道如何引导程序启动。
3、eFuse
eFuse顾名思义就是熔丝,它的状态只能由0转为1,这是不可逆的。比如说对于不同的启动方式来说,我们可以将手册中指定的硬件上的几个启动引脚拉高或拉低,从而表示设备会从哪里启动。对于这些,在硬件上我们飞个线或者去掉一个电阻就能更改这些启动方式了,那有什么办法可以固定这个启动方式而不被更改呢?
在eFuse中就有和几个启动引脚相对应的位,然后我们只要烧写eFuse中的BT_FUSE_SEL位,就表示以后上电就是从eFuse中对应的配置读取启动配置,而不会从硬件中读取。
2 Boot配置
2.1 BOOT_MODE

- Boot From Fuses:通过熔丝的配置来Boot。如果是这种启动方式,就会根据刚刚所说的
BT_FUSE_SEL来判断要不要使用eFuse的配置进行启动引导,如果想根据eFuse的配置进行启动,则需要烧写BT_FUSE_SEL位。默认BT_FUSE_SEL为0,在该模式下,会进入Serial Downloader模式。 - Serial Downlaoder:我们可以通过串口或USB与BootROM进行通信,我们就可以根据此功能烧写一段代码到内置的RAM里然后运行,这段代码可以完成Flash的擦写、eFuse的烧写等操作。
- Internal Boot:与Boot From Fuses模式类似,也会根据
BT_FUSE_SEL位来读取配置,只是BT_FUSE_SEL为0时候的定义和Boot From Fuses不同,如果为0,则使用GPIO的配置进行引导。
2.2 BOOT_CFG配置
前面有了启动方式后,BootROM还需要知道从哪里读取代码启动,如果是从NOR Flash启动的话,那就直接在NOR Flash运行,如果是从EMMC、SD等存储设备启动,则还需要拷贝代码到SRAM/SDRAM等RAM中运行。这些都是根据BOOT_CFG来配置的。在I.MX6ULL中支持以下几种存储设备启动:
- NOR Flash
- NAND Flash
- OneNAND Flash
- SD/MMC
- Serial (SPI) NOR Flash and EEPROM
- QuadSPI (QSPI) Flash
BOOT_CFG引脚包括BOOT_CFGx[0]-BOOT_CFGx[7](x=1,2,3),共24个引脚。

对于不同的启动设备来说,BOOT_CFG1[7:4]配置如下:

至于其它的24个引脚的配置,我们不用对每个引脚都进行配置,因为在不同的启动设备下,仅需要配置个别的配置引脚,大家可以根据自己的启动设备,参考8.5 Boot Device(Internal Boot)章节中的配置。比如使用NOR Flash启动,我们只需要再配置表格中的这些引脚即可:

- 同样的,
BOOT_CFG引脚在eFuse中也有对应的位来表示
3 Bootable image启动头
3.1 组成
既然BootROM需要引导程序,它并不知道程序中断向量表所在的位置,如果程序需要从存储设备拷贝到RAM中,那是从哪个地址拷贝到哪个地址呢?另外,前面我们有提到BootROM还可以对SDRAM等外设进行初始化,那不同的SDRAM参数不同,应该如何让BootROM知道呢?我们就可以在启动头中添加这些信息,这个启动头称为IVT(Image Vector Table)。
对于不同的启动设备来说,启动头存放的位置也不同,如下图所示:

如下所示,包括IVT的字段,BootROM就通过这些字段将程序从Boot Device拷贝到Dest Memory。

各个字段的含义如下:
| Field | Description |
|---|---|
| header | 执行镜像中第一条指令的绝对地址 |
| reserved1 | 保留字段,应设为0 |
| dcd | 镜像DCD的绝对地址。DCD是可选的,如果不需要,则此字段可以设置为0。 |
| boot data | 启动数据的绝对地址 |
| self | IVT 的绝对地址。ROM内部使用 |
| csf | 用于加密启动,不用的话设置为0 |
| reserved2 | 保留字段,应设为0 |
- 这里的
CSF用于HAB认证,可以参考我写的这一篇文章RT1170加密启动详解(2):HAB认证原理
实际上这些字段和RT1170中的IVT启动头一模一样,这里就不做详细介绍了,可以参考I.MX RT1170启动详解:Boot配置、Bootable image头的组成。下面直接举一个实际的例子,来看看这些字段是如何配置的。
3.2 实例
3.2.1 程序结构
这里我们假设Boot Device为SD,我们希望将代码拷贝到DDR中运行。根据前面这张图,我们知道从SD启动的话整个头的大小为4KB,其中IVT的偏移为0x400。

由下图可知,DDR的起始地址为0x80000000。

另外I.MX6ULL属于ARMv7内核,来看一下CP15协处理器中的向量表字段:

也就是说在ARMv7中,向量表地址的低5位有别的作用,实际上就是可以指定上电后进入的异常(默认为Reset异常)。如果低5位用不了的话,也就代表着我们的向量表地址要32位对齐。
所以我们可以这样设计镜像格式:

最终DDR的0x80000000开始的内存内容就是以上的格式。由于我们设置了从SD启动,所以我们只需要把这整个固件放在SD中就行了,上电后BootROM会帮我们拷贝到0x80000000处,然后去运行0x80100000处的代码。
- 由于程序放在
0x80100000,所以我们在编译的时候,需要修改链接脚本的链接地址,将程序链接到0x80100000处 - 这里仅是举一个极端的情况,让大家可以更好地理解这个启动头的作用。我们完全可以把向量表放在
0x80100000-0x1000的位置。否则这样的话,如果一次烧写整个镜像到SD卡,那至少要烧写0x100000的大小。同样地,BootROM拷贝也会非常慢。
3.2.2 程序镜像内容分析
(1)0~0x400:暂时没有用到,填0

2、IVT(Image Vector Table):偏移0x400

其中TAG为d1,IVT Length为0x20(这个字段大端表示),version为0x40,entrypoint Address(程序的链接地址或程序reset_handler的地址)为0x80100000,DCD的绝对地址为0x8000042C,Boot Data链接地址为0x80000420,IVT链接地址为0x80000400。
3、BD(Boot Data):偏移0x420

其中镜像的绝对起始地址为0x80000000,程序镜像的大小为0x200000(2M,可以根据DDR最大的大小填写)。
4、DCD:偏移0x42C

从0x42C开始都是DCD的配置了,实际上就是使用指定的格式来配置寄存器,比如可以配置SDRAM的寄存器,这样BootROM就能帮我们初始化好SDRAM。
- 具体格式参考手册:
8.7.2 Device Configuration Data
5、程序镜像:偏移0x100000

最后就是我们编译出来的原始bin文件了。
相关文章:
I.MX6ULL启动详解:Boot配置、Bootable image启动头的组成
本篇文章来了解一下I.MX6ULL的启动方式,实际上之前我介绍了NXP的跨界MCU RT1170的启动方式:I.MX RT1170启动详解:Boot配置、Bootable image头的组成,两个芯片虽然一个是Cortex-M,一个是Cortex-A,但是都是来…...
隐藏通信隧道技术——防御SSH隧道攻击的思路
隐藏通信隧道技术——防御SSH隧道攻击的思路 在内网中建立一个稳定、可靠的数据通道,对渗透测试工作来说具有重要的意义。应用层的隧道通信技术主要利用应用软件提供的端口来发送数据。常用的隧道协议有SSH、HTTP/HTTPS和DNS。 SSH协议 在一般情况下ÿ…...
UE-近战战斗系统学习笔记一
文章目录 一、介绍1)选择paragon资产下载2)用UE 5.0版本创建额外项目迁移到5.1版本的项目3)由于后面要装备武器和盾牌,所以引入一个空手人物模型 二、创建目标系统1)用导入的角色资产代替UE默认的人物第三人称角色资产…...
使用 Layui 的 template 模块来动态加载select选项
可以使用 Layui 的 template 模块来动态加载选项,如下所示: <!DOCTYPE html> <html> <head><meta charset"utf-8"><title>Layui 动态模板示例</title><link rel"stylesheet" href"pat…...
《数据分析-JiMuReport》积木报表详细入门教程
积木报表详细入门教程 一、JimuReport部署入门介绍 积木报表可以通过源码部署、SpringBoot集成、Docker部署以及各种成熟框架部署,具体可查看积木官方文档 当前采用源码部署,首先下载Jimureport-example-1.5.6 1 jimureport-example目录查看 使用ID…...
React面试题:React.Component和React.PureComponent的区别?
回答思路:什么是PureComponent-->Component更新过程-->PureComponent更新过程-->PureComponent的优点 什么是PureComponent:pure:纯净的,即为纯组件,可以用来优化React程序,减少render函数执行的…...
力扣:203. 移除链表元素(Python3)
题目: 给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val val 的节点,并返回 新的头节点 。 来源:力扣(LeetCode) 链接:力扣(LeetCode)官网 …...
微信小程序-选择和分割打开地图选择位置的信息
一、 前言 废话不多说,单刀直入。 本文要实现的功能是微信小程序中打开地图选择位置,以及将返回的位置信息分割。 例如返回的位置信息是:广东省深圳市龙岗区xxxxx小区 分割后变成: {province: "广东省",city: "深…...
Flink Table API 与 SQL 编程整理
Flink API总共分为4层这里主要整理Table API的使用 Table API是流处理和批处理通用的关系型API,Table API可以基于流输入或者批输入来运行而不需要进行任何修改。Table API是SQL语言的超集并专门为Apache Flink设计的,Table API是Scala和Java语言集成式…...
华为OS与麒麟OS:华为自研操作系统的对决
导言 在移动操作系统领域,华为OS和麒麟OS代表了华为在自主研发方面的努力。本文将深入探讨这两个操作系统的特点、竞争关系以及它们在用户体验、生态系统建设等方面的差异。 1. 背景与起源 华为OS的诞生: 华为OS是华为公司为应对外部环境而自主…...
Java解决比特维位计数
Java解决比特维位计数 01 题目 给你一个整数 n ,对于 0 < i < n 中的每个 i ,计算其二进制表示中 1 的个数 ,返回一个长度为 n 1 的数组 ans 作为答案。 示例 1: 输入:n 2 输出:[0,1,1] 解释&a…...
【深度学习目标检测】九、基于yolov5的路标识别(python,目标检测)
YOLOv5是目标检测领域一种非常优秀的模型,其具有以下几个优势: 1. 高精度:YOLOv5相比于其前身YOLOv4,在目标检测精度上有了显著的提升。YOLOv5使用了一系列的改进,如更深的网络结构、更多的特征层和更高分辨率的输入图…...
PyCharm添加自动函数文档注释
目录 1、背景2、开启PyCharm自动函数文档注释 1、背景 规范的函数文档注释有助于他人理解代码,便于团队协作、提高效率。但如果我们自己手写函数文档注释将非常耗时耗力。PyCharm安装后默认没有开启自动化函数文档注释,需要我们开启 2、开启PyCharm自动…...
数字图像处理 基于Numpy、PyTorch在频率空间中建模运动模糊
一、简述 运动模糊在图像中很常见,它会降低图像的价值,因为它会破坏图像中包含的数据。在计算机视觉中,通常通过使用许多不同的模糊增强来训练神经网络以适应这种模糊。建模模糊或图像退化的概念来自图像恢复,这是逆转退化影响的过程,以便人类或算法可以辨别原始捕获的数据…...
海康威视对讲广播系统 RCE漏洞复现(CVE-2023-6895)
0x01 产品简介 Hikvision Intercom Broadcasting System是中国海康威视(Hikvision)公司的一个对讲广播系统。 0x02 漏洞概述 Hikvision Intercom Broadcasting System 3.0.3_20201113_RELEASE(HIK)版本存在操作系统命令注入漏洞,该漏洞源于文件/php/ping.php的参数jsonda…...
【优化】Springboot 修改 tomcat连接池
【优化】Springboot 修改 tomcat连接池 factory.setTomcatProtocolHandlerCustomizers(tomcatProtocolHandlerCustomizers); 可以更换为 虚拟线程连接池 package org.config.init;import org.apache.catalina.Context; import org.apache.catalina.core.AprLifecycleListener…...
百度侯震宇:AI原生与大模型将从三个层面重构云计算
12月20日,2023百度云智大会智算大会在北京举办,大会以「大模型重构云计算,Cloud for AI」为主题,深度聚焦大模型引发的云计算变革。 百度智能云表示,为满足大模型落地需求,正在基于「云智一体」战略重构…...
【SpringBoot快速入门】(2)SpringBoot的配置文件与配置方式详细讲解
之前我们已经学习的Spring、SpringMVC、Mabatis、Maven,详细讲解了Spring、SpringMVC、Mabatis整合SSM的方案和案例,上一节我们学习了SpringBoot的开发步骤、工程构建方法以及工程的快速启动,从这一节开始,我们开始学习SpringBoot…...
麒麟V10 ARM 离线生成RabbitMQ docker镜像并上传Harbor私有仓库
第一步在外网主机执行: docker pull arm64v8/rabbitmq:3.8.9-management 将下载的镜像打包给离线主机集群使用 在指定目录下执行打包命令: 执行: docker save -o rabbitmq_arm3.8.9.tar arm64v8/rabbitmq:3.8.9-management 如果懒得打包…...
AI创作系统ChatGPT商业运营网站系统源码,支持AI绘画,GPT语音对话+DALL-E3文生图
一、前言 SparkAi创作系统是基于ChatGPT进行开发的Ai智能问答系统和Midjourney绘画系统,支持OpenAI-GPT全模型国内AI全模型。本期针对源码系统整体测试下来非常完美,可以说SparkAi是目前国内一款的ChatGPT对接OpenAI软件系统。那么如何搭建部署AI创作Ch…...
Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以?
Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以? 在 Golang 的面试中,map 类型的使用是一个常见的考点,其中对 key 类型的合法性 是一道常被提及的基础却很容易被忽视的问题。本文将带你深入理解 Golang 中…...
Zustand 状态管理库:极简而强大的解决方案
Zustand 是一个轻量级、快速和可扩展的状态管理库,特别适合 React 应用。它以简洁的 API 和高效的性能解决了 Redux 等状态管理方案中的繁琐问题。 核心优势对比 基本使用指南 1. 创建 Store // store.js import create from zustandconst useStore create((set)…...
Unity3D中Gfx.WaitForPresent优化方案
前言 在Unity中,Gfx.WaitForPresent占用CPU过高通常表示主线程在等待GPU完成渲染(即CPU被阻塞),这表明存在GPU瓶颈或垂直同步/帧率设置问题。以下是系统的优化方案: 对惹,这里有一个游戏开发交流小组&…...
CMake基础:构建流程详解
目录 1.CMake构建过程的基本流程 2.CMake构建的具体步骤 2.1.创建构建目录 2.2.使用 CMake 生成构建文件 2.3.编译和构建 2.4.清理构建文件 2.5.重新配置和构建 3.跨平台构建示例 4.工具链与交叉编译 5.CMake构建后的项目结构解析 5.1.CMake构建后的目录结构 5.2.构…...
AtCoder 第409场初级竞赛 A~E题解
A Conflict 【题目链接】 原题链接:A - Conflict 【考点】 枚举 【题目大意】 找到是否有两人都想要的物品。 【解析】 遍历两端字符串,只有在同时为 o 时输出 Yes 并结束程序,否则输出 No。 【难度】 GESP三级 【代码参考】 #i…...
全球首个30米分辨率湿地数据集(2000—2022)
数据简介 今天我们分享的数据是全球30米分辨率湿地数据集,包含8种湿地亚类,该数据以0.5X0.5的瓦片存储,我们整理了所有属于中国的瓦片名称与其对应省份,方便大家研究使用。 该数据集作为全球首个30米分辨率、覆盖2000–2022年时间…...
c++ 面试题(1)-----深度优先搜索(DFS)实现
操作系统:ubuntu22.04 IDE:Visual Studio Code 编程语言:C11 题目描述 地上有一个 m 行 n 列的方格,从坐标 [0,0] 起始。一个机器人可以从某一格移动到上下左右四个格子,但不能进入行坐标和列坐标的数位之和大于 k 的格子。 例…...
解决本地部署 SmolVLM2 大语言模型运行 flash-attn 报错
出现的问题 安装 flash-attn 会一直卡在 build 那一步或者运行报错 解决办法 是因为你安装的 flash-attn 版本没有对应上,所以报错,到 https://github.com/Dao-AILab/flash-attention/releases 下载对应版本,cu、torch、cp 的版本一定要对…...
零基础设计模式——行为型模式 - 责任链模式
第四部分:行为型模式 - 责任链模式 (Chain of Responsibility Pattern) 欢迎来到行为型模式的学习!行为型模式关注对象之间的职责分配、算法封装和对象间的交互。我们将学习的第一个行为型模式是责任链模式。 核心思想:使多个对象都有机会处…...
九天毕昇深度学习平台 | 如何安装库?
pip install 库名 -i https://pypi.tuna.tsinghua.edu.cn/simple --user 举个例子: 报错 ModuleNotFoundError: No module named torch 那么我需要安装 torch pip install torch -i https://pypi.tuna.tsinghua.edu.cn/simple --user pip install 库名&#x…...
