其他分享
首页 > 其他分享> > I.MX启动方式和头部

I.MX启动方式和头部

作者:互联网

1. 启动方式

image
image

2. 头部信息

编译好的bin文件烧写到SD卡中,需要加一些头部文件,才可以执行。

链接起始地址为0x87800000,IVT+Boot Data+DCD的大小大约是3KB,所以load.imx文件起始地址就是0x87800000-0x3072 = 0x877FF004

2.1 IVT和BootData

load.imx 最前面的就是 IVT 和 Boot Data,IVT 包含了镜像程序的入口点指向 DCD 的指针和一些用作其它用途的指针。内部 Boot ROM 要求 IVT 应该放到指定的位置,不同的启动设备位置不同,而 IVT 在整个 load.imx 的最前面,其实就相当于要求 load.imx 在烧写的时候应该烧写到存储设备的指定位置去。整个位置都是相对于存储设备的起始地址的偏移。

烧写到SD卡时,要从第三个扇区开始烧写,前两个扇区是SD卡配置的, 加起来大概占用1kB。因此在bin文件其实是从第四个字节开始的,但是,当我们打开load.imx文件时发现bin文件是从0x0C(第三个字节)开始的,那是因为我们还没把load.imx放到SD卡或者ddr中,当然就是4-1 = 3KB了。

IVT

image-20211117150733720

因为是大端模式,32字节

bootData

2.2 DCD

复位以后,I.MX6U 片内的所有寄存器都会复位为默认值,但是这些默认值往往不是我们想要的值,而且有些外设我们必须在使用之前初始化它。为此 I.MX6U 提出了一个 DCD(Device Config Data)的概念,和 IVT、Boot Data 一样,DCD 也是添加到 load.imx 里面的,紧跟在 IVT和 Boot Data 后面,IVT 里面也指定了 DCD 的位置。DCD 其实就是 I.MX6U 寄存器地址和对应的配置信息集合,Boot ROM 会使用这些寄存器地址和配置集合来初始化相应的寄存器,比如开启某些外设的时钟、初始化 DDR 等等。DCD 区域不能超过 1768Byte。

DCD 里面的初始化配置主要包括三方面:

①、设置 CCGR0~CCGR6 这 7 个外设时钟使能寄存器,默认打开所有的外设时钟。

②、配置 DDR3 所用的所有 IO。

③、配置 MMDC 控制器,初始化 DDR3。

标签:load,启动,DCD,Boot,IVT,地址,头部,imx,MX
来源: https://www.cnblogs.com/yoshinb/p/15568508.html