ARM启动解析

参考文章
起始地址
在分析启动流程之前我们首先要清楚不论是arm的何种处理器,其都是从0x0000 0000地址处开始执行程序的。
以2440为例:

1. 启动方式
S3C2440支持两种启动模式:NAND和非NAND(这里是Nor Flash),具体采用的方式取决于OM0、OM1两个引脚的状态。
需要检测硬件启动方式,启动方式是由硬件OM0管脚决定的,软件无法检测硬件电平状态,但可以根据CPU的启动特性来检测。
在这里插入图片描述
2. 地址布局

在这里插入图片描述
从上图我们可以清楚的看到左边的是从Nor Flash启动的地址布局,右边是从NAND启动的地址布局。
Nor Flash内可以运行程序,所以我们在放bootloader的时候放在0地址处即可。
3. 启动流程
1、NAND启动:

如果配置为NAND FLASH启动(启动模式选择开关拔到nand端,此时OM0管脚拉低)S3C2440的NAND控制器会自动把NAND FLASH中的前4K代码数据搬到内部SRAM中(地址为0x40000000),同时还把这块SRAM地址映射到了0x00000000地址。CPU从0x00000000位置开始运行程序。 【从NAND FLASH启动CPU时,CPU会通过内部的硬件将NAND FLASH开始的4KB数据复制到称为“Steppingstone”的4KB的内部RAM中(起始地址为0),然后跳到地址0开始执行】

2、NOR启动:

如果配置为NOR FLASH启动(启动模式选择开关拔到nor端,此时OM0管脚拉高),0x00000000就是NOR FLASH实际的起始地址,NOR FLASH中的程序就从这里开始运行,不涉及到数据拷贝和地址映射。

总结:

NAND启动时,地址0x00000000为内部SRAM映射的地址;

NOR启动时,地址0x00000000为NOR FLASH的实际起始地址。

向NOR FLASH中写数据需要特定的命令时序,而向内存中写数据可以直接向内存地址赋值。
注意:
sp决定栈从哪开始分配;
pc决定下一条命令。

为什么NOR启动要将sp设置为0x40000000+4096:

在这里插入图片描述
1、用NOR启动时,片内的存储控制器的BANK0-BANK7这8个BANK都对应了其他用途,所以设计者在BANK7结束的地址0x40000000的地方作为NOR FLASH的启动地址,而NAND FLASH启动的地址则是0x00000000。

2、 因为对于启动文件.S来说,4K的空间是足够存放,代码段、BSS…和堆栈段了,因为堆栈的SP是从高地址往低地址移动的,所以要将堆栈的起始地址放在堆栈段的高地址;

你也可以不用设置成4096,但要保证堆栈的长度不能和下面其他段重叠,若重叠,就会出BUG,保险值是4096,因为SRAM就是4K设计的

在这里插入图片描述

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
S32K144是一款基于ARM Cortex-M4的32位微控制器,启动文件是该微控制器系统启动时运行的一段代码。对于S32K144启动文件的解析,需要从以下几个方面进行分析。 首先,S32K144启动文件包含有关芯片系统时钟的配置,包括时钟源的选择、时钟分频器的设置等。这些内容是在系统启动前配置的,它们的正确性直接影响了整个系统运行的稳定性和速度。 其次,启动文件也包含有关中断向量表的定义和初始化。中断向量表是存储中断服务程序地址的数组,当中断发生时,由中断控制器根据中断编号在向量表中查找对应的中断服务程序地址执行。中断向量表是系统中断处理的关键数据结构,因此在启动文件中对其的定义和初始化非常重要。 此外,启动文件还包含了对片上Flash和RAM的初始化代码。这些初始化代码设置了Flash和RAM的起始地址、大小、读写属性等,为后续程序的正常运行提供了必要的基础环境。 最后,启动文件中还会有一些基本的程序运行环境初始化,如堆栈空间的设置、全局变量的初始化等。这些内容是为程序的正常运行所必需的,是启动文件中必不可少的部分。 总的来说,S32K144启动文件是一段非常关键的代码,在系统启动时扮演着重要的角色。对于S32K144启动文件的解析,需要深入了解芯片的硬件架构和系统设计理念,才能编写出正确、高效的启动代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值