I.MX6ULL裸机开发笔记2:镜像文件
创始人
2024-05-14 12:40:04
0

目录

一、boot ROM程序

二、镜像文件五要素

三、芯片手册  

四、芯片手册数据解读       

1、空偏移 

2、IVT表

3、DCD表

一、boot ROM程序

选择内部启动方式,启动boot ROM程序

  • 初始化时钟,外部DDR3
  • 从外部存储介质加载代码

boot ROM程序是芯片厂商将芯片制作出来的时候就固化到里面的程序,不可更改;

其主要可以解决2个问题:

  • DDR3有很多不同的厂商,其内部规格不同,boot ROM固件程序如何获得正确的属性参数来设置寄存器
  • boot ROM代码如何获取外部介质代码,如何加载地址

解决方式:通过设置镜像文件的格式

二、镜像文件五要素

        1、空偏移

                芯片厂商设定;镜像文件并不是放在外部存储介质中的起始位置;数据手册可查询;

        2、Image vector table,简称VT

                记录关键数据的位置:主要是Boot data的位置和Decice configuration data的位置

        4、Boot data,启动数据

                镜像加载地址,大小

        5、Device configuration data,渐层DCD

                关键外设的寄存器配置信息(时钟、DDR3相关)

        6、bin文件

                真正的程序文件

三、芯片手册  

    8.7.1 Image Vector Table and Boot Data(芯片手册目录)

        可以看出,1是空偏移部分,如果空偏移存在,那么就会从外部介质的起始地址开始加载,否则不能;2是Vector Table部分,记录着各个重要数据的地址,可以看出通过箭头指向了各个数据;3是Boot Data;4是DCD;

四、芯片手册数据解读       

1、空偏移 

        8.7.1 Image Vector Table and Boot Data 

  • Boot Device Type:不同的启动介质
  • Image Vector Table Offset:镜像有效数据偏移位置
  • Initial Load Region Size:boot ROM读取程序大小

2、IVT表

        8.7.1.1  Image vector table structure 

 这个IVT表在代码中展现的就是一个结构体;

  • header:IVT的长度、大小
  • entry:程序运行地址
  • dcd:内存中boot data地址
  • self:内存中IVT自己所在地址

Boot data:

记录“镜像”在内存中的加载地址和大小

8.7.1.2 Boot data structure

  • statrt:镜像在内存中的加载地址,包括空偏移
  • length:镜像长度,包括空偏移
  • plugin:插件,扩展驱动的     

       

3、DCD表

外设寄存器配置信息,初始化关键外设

        8.7.2 Device Configuration Data(DCD)

     Header:记录DCD大小,版本

CMD:寄存器初始化列表

Table 8-28.Write data commond format

  • Tag:DCD命令,一般写为寄存器
  • Length:表示命令的大小
  • Parameter:设置写寄存器方式(写值/清位/设置位)
  • Address:寄存器地址,主要是始终,DDR3相关外设地址
  • Value:具体设置值

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...