ARM Cortex-M3/M4 启动分析

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运行

 

 

 

 

 

 

 

 

 

 

  

posted @ 2019-07-10 10:07  古幕流西  阅读(1361)  评论(0编辑  收藏  举报