单片机要如何寻址?
中可能并不这样称呼),二者很容易理解,也很容易区分。当然,二者也是各有优劣:绝对寻址简化了执行电路,因为他无需进行PC和偏移量的加法运算;而相对寻址则可精简编码长度,从而节省程序存储器消耗,当然,还有一个更加重要的好处,那就是可以利用这个特性编写"可搬移"的代码。因为使用相对地址,那么把程序整段搬移到其他的地址空间去,程序也能够正确的执行而不致出差。
对于同时提供了绝对寻址和相对寻址的CPU,在其汇编语法层面就需要给出区别两种寻址方式的语法,由于不同汇编给出的解决方法不同,这里仅以MSP430编程手册中给出的汇编语法为例进行介绍,以方便理解:
相对寻址:MOV ADDR,R4
绝对寻址:MOV &ADDR,R4
可见,这里是通过一个"&"符合进行绝对寻址和相对寻址的区分的。
另外,还有一个不大不小的问题需要注意,很多时候,使用内存直接寻址的汇编中并不直接给出地址数值,而是给出"标号,即label",汇编器自己把这个标号用实际的地址值进行替代,所以就免除了地址的手工计算的麻烦。
6、内存间接寻址,参考寄存器直接寻址与寄存器间接寻址的异同,我们可以通过上面讲到内存直接寻址来推测出内存间接寻址的内容和概念。但是,鉴于在嵌入式处理器和单片机中一般都不使用内存间接寻址方式,所以,这里也就不再展开谈了。
另外,应该清楚,寻址方式并不是处理器设计者想怎么设计就怎么设计的,它很大程度上是由处理器内核结构和存储结构所决定的。一般来说,立即寻址和无址寻址在所有的处理器或单片机中都是存在的;而RISC构架的处理器中一般大量使用寄存器直接寻址,而寄存器间接寻址和内存直接寻址一般只用于加载(LDR)、存储(STR)指令之中,内存间接寻址则在RISC中基本不使用;而对于CISC架构的处理器,不仅大量使用寄存器直接寻址,而且大量使用灵活多变的寄存器间接寻址和内存直接寻址,甚至于会提供强大的内存间接寻址。所以,CISC构架处理器的指令一般功能更丰富、更强大,可以用比RISC技术更少的指令完成相同的功能,但代价是必须增加更多的地址解析译码电路,增加了芯片体积和功耗。
当然,我学单片机时间也不长,水平一般,也没有了解过太多的单片机,只是就自己了解过的ARM、51、AVR、PIC和MSP430做一个小小总结,希望能帮助初学者更快的学习和理解单片机指令。但是能力和见识有限,未免以偏概全,所以也希望功力深厚、见识广博的老前辈能够指正错误,或添加其他未提到的寻址方式。当然,若是那位有更好的寻址方式归纳总结方法分享,那将是更好了。
- 基于自适应技术的CPU供电电路系统(10-27)
- 嵌入式CPU卡在医用便携式监护仪中的应用及设计(09-23)
- 四核Vs八核移动处理器 性能差异并不大(03-10)
- 可编程逻辑控制器(PLC)基本操作及功能简介(03-07)
- 评测:采用AMD APU平台的联想启天M5800——均衡+全能(02-17)
- 智能手机省电秘诀:看如何从设计源头来降低功耗(02-14)
