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

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。

在这里插入图片描述

各个字段的含义如下:

FieldDescription
header执行镜像中第一条指令的绝对地址
reserved1保留字段,应设为0
dcd镜像DCD的绝对地址。DCD是可选的,如果不需要,则此字段可以设置为0。
boot data启动数据的绝对地址
selfIVT 的绝对地址。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协议 在一般情况下&#xff…...

UE-近战战斗系统学习笔记一

文章目录 一、介绍1)选择paragon资产下载2)用UE 5.0版本创建额外项目迁移到5.1版本的项目3)由于后面要装备武器和盾牌,所以引入一个空手人物模型 二、创建目标系统1)用导入的角色资产代替UE默认的人物第三人称角色资产…...

使用 Layui 的 template 模块来动态加载select选项

可以使用 Layui 的 template 模块来动态加载选项&#xff0c;如下所示&#xff1a; <!DOCTYPE html> <html> <head><meta charset"utf-8"><title>Layui 动态模板示例</title><link rel"stylesheet" href"pat…...

《数据分析-JiMuReport》积木报表详细入门教程

积木报表详细入门教程 一、JimuReport部署入门介绍 积木报表可以通过源码部署、SpringBoot集成、Docker部署以及各种成熟框架部署&#xff0c;具体可查看积木官方文档 当前采用源码部署&#xff0c;首先下载Jimureport-example-1.5.6 1 jimureport-example目录查看 使用ID…...

React面试题:React.Component和React.PureComponent的区别?

回答思路&#xff1a;什么是PureComponent-->Component更新过程-->PureComponent更新过程-->PureComponent的优点 什么是PureComponent&#xff1a;pure&#xff1a;纯净的&#xff0c;即为纯组件&#xff0c;可以用来优化React程序&#xff0c;减少render函数执行的…...

力扣:203. 移除链表元素(Python3)

题目&#xff1a; 给你一个链表的头节点 head 和一个整数 val &#xff0c;请你删除链表中所有满足 Node.val val 的节点&#xff0c;并返回 新的头节点 。 来源&#xff1a;力扣&#xff08;LeetCode&#xff09; 链接&#xff1a;力扣&#xff08;LeetCode&#xff09;官网 …...

微信小程序-选择和分割打开地图选择位置的信息

一、 前言 废话不多说&#xff0c;单刀直入。 本文要实现的功能是微信小程序中打开地图选择位置&#xff0c;以及将返回的位置信息分割。 例如返回的位置信息是&#xff1a;广东省深圳市龙岗区xxxxx小区 分割后变成&#xff1a; {province: "广东省",city: "深…...

Flink Table API 与 SQL 编程整理

Flink API总共分为4层这里主要整理Table API的使用 Table API是流处理和批处理通用的关系型API&#xff0c;Table API可以基于流输入或者批输入来运行而不需要进行任何修改。Table API是SQL语言的超集并专门为Apache Flink设计的&#xff0c;Table API是Scala和Java语言集成式…...

华为OS与麒麟OS:华为自研操作系统的对决

导言 在移动操作系统领域&#xff0c;华为OS和麒麟OS代表了华为在自主研发方面的努力。本文将深入探讨这两个操作系统的特点、竞争关系以及它们在用户体验、生态系统建设等方面的差异。 1. 背景与起源 华为OS的诞生&#xff1a; 华为OS是华为公司为应对外部环境而自主…...

Java解决比特维位计数

Java解决比特维位计数 01 题目 给你一个整数 n &#xff0c;对于 0 < i < n 中的每个 i &#xff0c;计算其二进制表示中 1 的个数 &#xff0c;返回一个长度为 n 1 的数组 ans 作为答案。 示例 1&#xff1a; 输入&#xff1a;n 2 输出&#xff1a;[0,1,1] 解释&a…...

【深度学习目标检测】九、基于yolov5的路标识别(python,目标检测)

YOLOv5是目标检测领域一种非常优秀的模型&#xff0c;其具有以下几个优势&#xff1a; 1. 高精度&#xff1a;YOLOv5相比于其前身YOLOv4&#xff0c;在目标检测精度上有了显著的提升。YOLOv5使用了一系列的改进&#xff0c;如更深的网络结构、更多的特征层和更高分辨率的输入图…...

PyCharm添加自动函数文档注释

目录 1、背景2、开启PyCharm自动函数文档注释 1、背景 规范的函数文档注释有助于他人理解代码&#xff0c;便于团队协作、提高效率。但如果我们自己手写函数文档注释将非常耗时耗力。PyCharm安装后默认没有开启自动化函数文档注释&#xff0c;需要我们开启 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日&#xff0c;2023百度云智大会智算大会在北京举办&#xff0c;大会以「大模型重构云计算&#xff0c;Cloud for AI」为主题&#xff0c;深度聚焦大模型引发的云计算变革。 百度智能云表示&#xff0c;为满足大模型落地需求&#xff0c;正在基于「云智一体」战略重构…...

【SpringBoot快速入门】(2)SpringBoot的配置文件与配置方式详细讲解

之前我们已经学习的Spring、SpringMVC、Mabatis、Maven&#xff0c;详细讲解了Spring、SpringMVC、Mabatis整合SSM的方案和案例&#xff0c;上一节我们学习了SpringBoot的开发步骤、工程构建方法以及工程的快速启动&#xff0c;从这一节开始&#xff0c;我们开始学习SpringBoot…...

麒麟V10 ARM 离线生成RabbitMQ docker镜像并上传Harbor私有仓库

第一步在外网主机执行&#xff1a; docker pull arm64v8/rabbitmq:3.8.9-management 将下载的镜像打包给离线主机集群使用 在指定目录下执行打包命令&#xff1a; 执行&#xff1a; docker save -o rabbitmq_arm3.8.9.tar arm64v8/rabbitmq:3.8.9-management 如果懒得打包…...

AI创作系统ChatGPT商业运营网站系统源码,支持AI绘画,GPT语音对话+DALL-E3文生图

一、前言 SparkAi创作系统是基于ChatGPT进行开发的Ai智能问答系统和Midjourney绘画系统&#xff0c;支持OpenAI-GPT全模型国内AI全模型。本期针对源码系统整体测试下来非常完美&#xff0c;可以说SparkAi是目前国内一款的ChatGPT对接OpenAI软件系统。那么如何搭建部署AI创作Ch…...

SkyWalking 10.2.0 SWCK 配置过程

SkyWalking 10.2.0 & SWCK 配置过程 skywalking oap-server & ui 使用Docker安装在K8S集群以外&#xff0c;K8S集群中的微服务使用initContainer按命名空间将skywalking-java-agent注入到业务容器中。 SWCK有整套的解决方案&#xff0c;全安装在K8S群集中。 具体可参…...

Flask RESTful 示例

目录 1. 环境准备2. 安装依赖3. 修改main.py4. 运行应用5. API使用示例获取所有任务获取单个任务创建新任务更新任务删除任务 中文乱码问题&#xff1a; 下面创建一个简单的Flask RESTful API示例。首先&#xff0c;我们需要创建环境&#xff0c;安装必要的依赖&#xff0c;然后…...

应用升级/灾备测试时使用guarantee 闪回点迅速回退

1.场景 应用要升级,当升级失败时,数据库回退到升级前. 要测试系统,测试完成后,数据库要回退到测试前。 相对于RMAN恢复需要很长时间&#xff0c; 数据库闪回只需要几分钟。 2.技术实现 数据库设置 2个db_recovery参数 创建guarantee闪回点&#xff0c;不需要开启数据库闪回。…...

React Native 导航系统实战(React Navigation)

导航系统实战&#xff08;React Navigation&#xff09; React Navigation 是 React Native 应用中最常用的导航库之一&#xff0c;它提供了多种导航模式&#xff0c;如堆栈导航&#xff08;Stack Navigator&#xff09;、标签导航&#xff08;Tab Navigator&#xff09;和抽屉…...

UDP(Echoserver)

网络命令 Ping 命令 检测网络是否连通 使用方法: ping -c 次数 网址ping -c 3 www.baidu.comnetstat 命令 netstat 是一个用来查看网络状态的重要工具. 语法&#xff1a;netstat [选项] 功能&#xff1a;查看网络状态 常用选项&#xff1a; n 拒绝显示别名&#…...

多模态商品数据接口:融合图像、语音与文字的下一代商品详情体验

一、多模态商品数据接口的技术架构 &#xff08;一&#xff09;多模态数据融合引擎 跨模态语义对齐 通过Transformer架构实现图像、语音、文字的语义关联。例如&#xff0c;当用户上传一张“蓝色连衣裙”的图片时&#xff0c;接口可自动提取图像中的颜色&#xff08;RGB值&…...

今日科技热点速览

&#x1f525; 今日科技热点速览 &#x1f3ae; 任天堂Switch 2 正式发售 任天堂新一代游戏主机 Switch 2 今日正式上线发售&#xff0c;主打更强图形性能与沉浸式体验&#xff0c;支持多模态交互&#xff0c;受到全球玩家热捧 。 &#x1f916; 人工智能持续突破 DeepSeek-R1&…...

Web 架构之 CDN 加速原理与落地实践

文章目录 一、思维导图二、正文内容&#xff08;一&#xff09;CDN 基础概念1. 定义2. 组成部分 &#xff08;二&#xff09;CDN 加速原理1. 请求路由2. 内容缓存3. 内容更新 &#xff08;三&#xff09;CDN 落地实践1. 选择 CDN 服务商2. 配置 CDN3. 集成到 Web 架构 &#xf…...

C/C++ 中附加包含目录、附加库目录与附加依赖项详解

在 C/C 编程的编译和链接过程中&#xff0c;附加包含目录、附加库目录和附加依赖项是三个至关重要的设置&#xff0c;它们相互配合&#xff0c;确保程序能够正确引用外部资源并顺利构建。虽然在学习过程中&#xff0c;这些概念容易让人混淆&#xff0c;但深入理解它们的作用和联…...

【LeetCode】3309. 连接二进制表示可形成的最大数值(递归|回溯|位运算)

LeetCode 3309. 连接二进制表示可形成的最大数值&#xff08;中等&#xff09; 题目描述解题思路Java代码 题目描述 题目链接&#xff1a;LeetCode 3309. 连接二进制表示可形成的最大数值&#xff08;中等&#xff09; 给你一个长度为 3 的整数数组 nums。 现以某种顺序 连接…...