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区的所有存取指令都不会被移动位置(特别是存取指令之间的相对位置)。这一点对访问内存映射设备的寄存器非常重要。因为对于外围设备而言,读写的次序十分重要。另外对读状态寄存器也非常重要。因为想得到的状态都是最新的。举例来说&

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值