ARM Cortex-M3/M4启动分析
序:
之前在进行嵌入式开发的时候,并没有太过于关注ARM芯片的启动逻辑,现在IMXRT1052的学习过程中,发现了还真的老老实实的回去学习一下关于Cortex-M的启动逻辑和原理,才能惬意的玩转IMXRT芯片!此处做个随笔,主要是方便自己回顾,温故而知新嘛!
关键:
要分析cortex-m的启动原理需要从两个方面入手
1、芯片的memory map
2、链接文件
Memory Map:
我们用STM32F4XX来分析!The chip memory map has been provided in the following tables.
Figuer 1. Memory map
重要的区域:
Size AddrArea
Block 0 512M 0x0000 0000 ~ 0x1FFF FFFF
内部Flash:存储程序指令,内核上电后会从0x0800 0000地址取指令运行
注意:大家不都程序要在RAM中运行吗?为啥在这里从Flash里就可以运行了?这里涉及到XIP的概念,支持XIP的Flash,CPU是可以直接在上面取指,译码,执行的,一般的Norflash就有XIP的特性。
你可以吧STM32内部的Flash理解为一个Norflash,上电后内核就可以从0x0800 0000取指,执行。但是数据段必须还是要拷贝到RAM中的运行,应为数据段需要频繁的读写,所以放在RAM里效率会更高。
一般来说,一个系统起码要搭配一个具有xip功能的芯片,系统从xip芯里只完成SDRAM初始化,然后拷贝Flash中的代码到SDRAM中,然后内核再跳转到SDRAM里取运行。在S3C2410中,内核上电后,
会自动读取NANDFLASH前4K的数据进行初始化然后拷贝代码到SDRAM,也是同样的道理!
Block 1 512M 0x2000 0000 ~ 0x3FFF FFFF
内部SRAM:内核的数据区,程序的DATA段在运行的时候需要从Flash拷贝到SRAM运行