关于LPC1768的存储地址、运行地址、向量地址

时间:2018-11-30

  对于编写程序而言,程序的运行地址很重要。默认情况下都是直接按照软件的模块进行设置即可,此前并没有太过于关心,近在研究iap的时候需要做到这个方面的改进。

  以NXP提供的IAR例程为例,IAR既可以做flash的调试还支持SRAM的调试,那这是如何做到的呢?在程序中,有以下的一段切换代码:

      在FLASH模式下:

     在RAM模式下:

 

  翻译以后,可以得到以下内容:

  当FLASH调试时,设置向量地址为:0x00000000;当RAM   调试时, 设置向量地址为:0x10000000;LPC1768的为512K的flash和32K的sram,其地址如下图所示:

  因此答案很清除,当要在flash调试时,将向量地址指向flash,当要在ram中调试时,将向量地址指向ram。

  以上是程序内容的变化,然后还有链接文件的变化,分别对应以下两个文件:

  通过ultra-edit打开,发现两份链接文件的区别主要是向量地址,ROM地址,RAM地址发生了变化。由于链接文件是给程序编译、链接用的,因此一旦链接文件确定,程序就必须按照链接文件中规定的地址存储。这里的链接地址也认为是存储地址。

  由于bin文件格式本身是不带程序运行地址信息的,因此在用J-LINK烧写时,必须指定BIN文件的烧写地址。如程序从0x00000000运行,则从0x00000000开始烧写,如从0x00001000运行,则从0x00001000开始烧写。

  程序运行,MCU上电后,总是从0x00000000地址开始运行程序。

上一篇:基于S3C6410的ARM11学习(五) 初始化之关闭看门狗
下一篇:关于KEIL MDK调试ARM程序不能仿真的问题

免责声明: 凡注明来源本网的所有作品,均为本网合法拥有版权或有权使用的作品,欢迎转载,注明出处。非本网作品均来自互联网,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。

相关技术资料