本文主要是介绍mips汇编时常用的宏指令,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
MIPS公司最初设计的汇编器是一个宏伟的计划,它能完成智能宏的扩展,延迟槽填充,窥孔优化以及尽可能减少流水线堵塞而对复杂指令序列进行指令重组。不过其他的汇编器简单多了,因为高级语言的先进编译器技术已经可以完成这些优化工作。为了保持汇编代码的兼容性,同时为了让汇编程序员轻松一点,所有的MIPS汇编器至少实现下列功能:
(1)进行宏展开
(2)为了让分支和加载指令的延迟槽对程序员透明,能够在需要的地方自动插入nop指令
(3)能够避免流水线在执行普通指令时出错。
1,set noreord/reorder
默认汇编器处在reorder的模式下。该模式允许汇编器对指令进行重新排序,以避免流水线阻塞并获得更好的性能,在这种模式下,是不允许在代码中插入nop指令的。反之,在noreorder模式下,指令的顺序不会被更改也不会对代码进行任何优化。这样做的优点是程序员可以完全控制代码的顺序执行,缺点是必须手工对指令进行排序,并在分支和加载指令的延迟槽中填上有用的指令或nop指令如:
.set noreorder
lw t0,0(a0)
nop #加载延迟槽
sub t0,1
bne t0,zero,loop
nop #分支延迟槽
.set reorder
2,set volatile/ novolatile
处在volatile区的所有存取指令都不会被移动位置(特别是存取指令之间的相对位置)。这一点对访问内存映射设备的寄存器非常重要。因为对于外围设备而言,读写的次序十分重要。另外对读状态寄存器也非常重要。因为想得到的状态都是最新的。举例来说&
这篇关于mips汇编时常用的宏指令的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!