抛弃 Sass / Less ,迎接原子化 CSS 时代
|
我们可以看到是从pc值+4位置取出对应的内存的值,pc值+4是28,该位置对应22行, 即将4000802c写入到r3,然后20行会将r2中值写入到0x4000802c这个地址, 而此时该地址并不是全局变量aaaa, 所以此指令是无法找到bss段的aaaa变量的内存。 四、总结 1. 位置无关码:CPU取指时用相对地址取指令(比如pc +4),只要其相对地址没有变,都能够取指并运行。即该段代码无论放在内存的哪个地址,都能正确运行。究其原因,是因为代码里没有使用绝对地址,都是相对地址。 2. 位置相关码:利用绝对地址取指并运行,这就需要你存放程序(链接过程中)需要按照连接脚本的要求那样执行(Makefile里面有 -Ttext xxx指定或连接脚本)。即它的地址与代码处于的位置相关,是绝对地址,如:mov PC ,#0xff;ldr pc,=0xffff等。 3. 位置无关码的应用:1). 程序在运行期间动态加载到内存; 2). 程序在不同场合与不同程序组合后加载到内存(共享的动态链接库); 3). 在运行期间不同地址相互之间的映射(如bootloader) 4. 结论
拷贝到0地址运行后,**内存中指令(机器码)**的内容还和以前一样, pc的值会根据实际运行地址重新修正。 1.首先看bl func
对应的汇编代码是 第9行;该指令的机器码是0xeb000001, 我们在《4. 从0开始学ARM-ARM指令,移位、数据处理、BL、机器码》讲过该机器码格式 是从pc的位置向前偏移1条指令 因为三级流水线,所以应该往下偏移3条指令,即func的位置, 所以bl仍然可以正确找到func这个函数。 如上图所示:
如果我们将生成的bin文件拷贝到内存0x40008000位置运行必然没有问题, bl func 和 ldr pc,=func 都能跳转到func函数,而19行代码,也能访问到全局变量aaaa。 如果我们将该程序拷贝到其他地址是否能正常运行呢? 假定我们拷贝到0地址运行,那么程序的执行地址需要从0开始重新编排,即_start对应0地址,main对应0x18。
拷贝到0地址后内存布局: (编辑:济宁站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
