程序从片内地址0开始,但为什么链接地址又设0x30000000,那不就从0x30000000开始了,反汇编可以看到不是从0开始的
2013-03-13 17:45
399 查看
from:http://blog.csdn.net/ouyang_linux007/article/details/7448505
程序从片内地址0开始,但为什么链接地址又设0x30000000,那不就从0x30000000开始了,反汇编可以看到不是从0开始的
分类: 嵌入式硬件--裸机2012-04-11
10:37 583人阅读 评论(0) 收藏 举报
汇编存储flash
谢谢韦老大和独孤君
韦老大回答:
1. 裸板程序烧在FLASH上
一上电,肯定从0地址运行
2. 但是,0地址要么对应NOR FLASH,要么对应只有4K的片内内存
3. 程序要读写数据,或是程序大于4K,怎么办?
4. 程序就要复制到SDRAM里去执行
5. SDRAM那么大,复制到哪个地址去?能随便选择地址吗
6. 不能,要复制到它的链接地址去
7. 为什么一定要复制到它的链接地址去?
8. 因为这个链接地址是程序运行时“应该位于的地方”,比如要访问某个全局变量时,就是访问这个全局变量的链接地址
9. 既然链接地址是SDRAM的地址,那为什么一开始程序可以从0地址运行
10. 因为一开始的程序是“位置无关码”
独孤君回答:
以下是我自己总结的,看对你有帮助不
加载时域与运行时域:可以这么理解,加载时域涉及到存储地址;运行时域涉及到连接地址(连接地址开始作用的时间是在使用伪指令ldr(adr、adrl)pc,=某符号或是某立即数时 )。可执行程序在被下载到相应存储器件里时,它的存储地址可以通过oflash来选择;而当运行该程序时,一开始时PC寄存器的值是指向存储空间的起始地址(起始地址由oflash决定)的,但在遇到伪指令ldr(adr、adrl)pc,=某符号或是某立即数(位置无关相对跳转指令B与BL不影响运行地址)后,程序运行时的绝对地址(即PC寄存器的值)就发生了改变,它是以连接地址(由arm-linux-ld之-T选项设定)为基址,指令所在位置为相对地址共同组成的。总之:运行地址=-T指定的连接地址+相对偏移地址;存储地址=由oflash指定某存储器件的起始地址+由链接文件中AT指定的加载地址。
程序从片内地址0开始,但为什么链接地址又设0x30000000,那不就从0x30000000开始了,反汇编可以看到不是从0开始的
分类: 嵌入式硬件--裸机2012-04-11
10:37 583人阅读 评论(0) 收藏 举报
汇编存储flash
谢谢韦老大和独孤君
韦老大回答:
1. 裸板程序烧在FLASH上
一上电,肯定从0地址运行
2. 但是,0地址要么对应NOR FLASH,要么对应只有4K的片内内存
3. 程序要读写数据,或是程序大于4K,怎么办?
4. 程序就要复制到SDRAM里去执行
5. SDRAM那么大,复制到哪个地址去?能随便选择地址吗
6. 不能,要复制到它的链接地址去
7. 为什么一定要复制到它的链接地址去?
8. 因为这个链接地址是程序运行时“应该位于的地方”,比如要访问某个全局变量时,就是访问这个全局变量的链接地址
9. 既然链接地址是SDRAM的地址,那为什么一开始程序可以从0地址运行
10. 因为一开始的程序是“位置无关码”
独孤君回答:
以下是我自己总结的,看对你有帮助不
加载时域与运行时域:可以这么理解,加载时域涉及到存储地址;运行时域涉及到连接地址(连接地址开始作用的时间是在使用伪指令ldr(adr、adrl)pc,=某符号或是某立即数时 )。可执行程序在被下载到相应存储器件里时,它的存储地址可以通过oflash来选择;而当运行该程序时,一开始时PC寄存器的值是指向存储空间的起始地址(起始地址由oflash决定)的,但在遇到伪指令ldr(adr、adrl)pc,=某符号或是某立即数(位置无关相对跳转指令B与BL不影响运行地址)后,程序运行时的绝对地址(即PC寄存器的值)就发生了改变,它是以连接地址(由arm-linux-ld之-T选项设定)为基址,指令所在位置为相对地址共同组成的。总之:运行地址=-T指定的连接地址+相对偏移地址;存储地址=由oflash指定某存储器件的起始地址+由链接文件中AT指定的加载地址。
相关文章推荐
- 程序从片内地址0开始,但为什么链接地址又设0x30000000,那不就从0x30000000开始了,反汇编可以看到不是从0开始的
- 程序从片内地址0开始,但为什么链接地址又设0x30000000,那不就从0x30000000开始了,反汇编可以看到不是从0开始的
- 程序从片内地址0开始,但为什么链接地址又设0x30000000,那不就从0x30000000开始了,反汇编可以看到不是从0开始的
- 【总结】RAM-Like芯片地址线为什么不是从0开始
- GCC 预处理 编译 汇编 链接全过程及其含义 程序的开始不是main函数
- 为什么x86 Linux程序起始地址是从0x08048000开始的?
- 今天在看程序,看到了break ,C还不是很好,就查了一下。再次记录一下。以后可以随时查看。
- C/C++ 指向字符的指针为什么可以用字符串来初始化,而不是字符地址。
- 无需提交就可以改变页面内的链接地址
- 程序设计的理念是从写测试程序开始,然后编写可以通过测试的程序
- Java邮件发送程序(可以同时发给多个地址、可以带附件)
- 为什么写程序的时候可以坚持很久,但是学习数学就很难保持注意力?
- VC++2005运行Win32控制台程序时,为什么弹不出控制台窗口(无法看到运行结果)?
- ASP.NET通过第三方网站Bitly实现短链接地址程序
- Java邮件发送程序(可以同时发给多个地址、可以带附件)
- 为什么数组可以不加“&”取它的地址,而普通变量必须要加“& ”才可以呢?
- C#Winform窗体中添加WebService引用,并提供动态链接地址给程序
- 读“为什么c程序要从main函数开始执行”
- Fork and Join: Java也可以轻松地编写并发程序 原文地址 作者:Julien Ponge 译者:iDestiny 资源下载: Java SE 7 Sample Code(Zi
- 裸机程序常识1 _start程序入口标号 -Ttext链接地址作用,如何使用uboot中的函数