关于LPC1768的存储地址、运行地址、向量地址
出处:eefocus 发布于:2018-11-30 11:52:55
对于编写程序而言,程序的运行地址很重要。默认情况下都是直接按照软件的模块进行设置即可,此前并没有太过于关心,近在研究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地址开始运行程序。
版权与免责声明
凡本网注明“出处:维库电子市场网”的所有作品,版权均属于维库电子市场网,转载请必须注明维库电子市场网,https://www.dzsc.com,违反者本网将追究相关法律责任。
本网转载并注明自其它出处的作品,目的在于传递更多信息,并不代表本网赞同其观点或证实其内容的真实性,不承担此类作品侵权行为的直接责任及连带责任。其他媒体、网站或个人从本网转载时,必须保留本网注明的作品出处,并自负版权等法律责任。
如涉及作品内容、版权等问题,请在作品发表之日起一周内与本网联系,否则视为放弃相关权利。
- 英特尔数据存储如何操作和实现2024/4/26 17:40:38
- TI - 电池储能系统需要克服的三大设计挑战2024/4/24 15:46:55
- ram与rom的主要区分2024/4/12 17:48:19
- 什么是储能电池2024/4/3 17:34:46
- 一文解析HBM技术原理及优势2024/3/29 17:53:22
- 英特尔数据存储如何操作和实现
- 什么是微动开关_微动开关有什么用_微动开关使用方法
- VCC,VDD,VEE,VSS在电源原理图中有什么区别?
- 低压配电系统设计规范_低压配电系统设计注意事项
- xEV 主逆变器电源模块中第四代 SiC MOSFET 的短路测试
- 光耦详细应用教程
- 定义绝缘耐久性评估的电压脉冲测试要求
- 采用沟槽MOS结构,使存在权衡关系的VF和IR相比以往产品得到显著改善 ROHM推出实现业界超快trr的100V耐压SBD“YQ系列”
- NOVOSENSE - 纳芯微推出车规级温湿度传感器NSHT30-Q1,助力汽车智能化发展
- Keysight - EV 电池设计创新:扩大续航里程、延长电池寿命