PowerPc 架构 及 汇编指令 之二 PowerPC 汇编语言

本文介绍了PowerPC架构中的条件寄存器CR,详细讲解了比较指令如cmpw、cmpd及其对CR的影响,以及无条件和条件跳转指令如b、bl、blt、ble等的使用。通过示例展示了如何利用条件寄存器进行复杂条件判断,提升程序的控制逻辑灵活性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

PowerPC 汇编语言

 

1  条件寄存器,比较指令 转移指令 条件转移指令

 

CR(Condition Register) 一共32位,从低位到高位被分成 CR0-CR7八段,每段四位。每个四位的CRn从低到高分别是:LT(小于标志)、GT(大于)、EQ(等于)和SO(溢出)比较指令或条件跳转指令均 可指明具体操作哪个 CRn,由此可以同时判断多个条件。整数计算默认更改CR0,浮点数计算默认更改CR1

 

比较指令 :

 

cmpw rA, rB (比较有符号)cmpwl rA, rB(无符号)cmpwi rA, IMM(立即数比较)

 

cmpw rA, rB 比较 rA, rB的低32位结果存cr0

cmpd rA, rB 比较 rA, rB的全64位结果存cr0

cmpw cr3, rA, rB 比较 rA, rB的低32位结果存cr3

 

转移指令 :

 

b(branch) 是绝对地址无条件跳转,ba 是相对地址无条件跳转,bl 是跳转前将下一条指令的地址记录到register LR 可以用blr跳转到LR所指地址) ,BLA 是相对地址跳转,并将下条指令地址记录地址到LR。

 

 

 

条件跳转指令 :

 

blt addr (小于跳转),ble(小于等于)

bgt addr(大于跳转),bge(大于等于)

beq addr(等于跳转),bne(不等)

 

 

Tips :可以在比较和跳转命令第一个参数指明所使用的条件寄存器,不写则默认CR0。由此我们可以用更多条件寄存器同时判断若干条件

 

cmpw cr4, r3, r4

beq cr4, _branch_1

 


 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值