资料介绍
6.13 ORR逻辑或指令
1.指令的编码格式
ORR(Logical OR)为逻辑或操作指令,将第二个源操作数《shifter_operand》的值与寄存器Rn的值按位做逻辑或操作,结果保存到Rd中。
指令的编码格式如图6.14所示。
图6.14 ORR指令编码格式
2.指令的语法格式
ORR{《cond》}{S} 《Rn》,《Rn》,《shifter_operand》
① 《cond》
为指令编码中的条件域。它指示指令在什么条件下执行。当《cond》忽略时,指令为无条件执行(cond=AL(Alway))。
② 《S》
S位(bit[20])决定指令的操作是否影响CPSR中条件标志位的值。当S=1时指令更新CPSR中条件标志位的值;当S=0时指令不更新CPSR中条件标志位的值。当S=1时,有下面两种情况。
· 如果《Rd》不是R15,则CPSR中的N位和Z位根据指令的执行结果设置。C位则根据指令操作是否产生一个进位(即一个无符号溢出)来设置;V位则根据是否有带符号的溢出来设置。CPSR中的其他位不受影响。
· 如果《Rd》是程序计数器R15,则当前程序状态的SPSR拷贝到CPSR。如果处理器处于用户模式或系统模式,则指令的执行结果不可预知。因为这两种模式没有自己的私有SPSR寄存器。
③ 《Rd》
指定目标寄存器。
④ 《Rn》
指定第一个源操作数寄存器。
⑤ 《shifter_operand》
使用ARM的通用寻址模式确定第二个源操作数。它影响指令编码格式中的I(bit[25])位和shifter_operand(bits[11∶0])位。
3.指令操作的伪代码
指令操作的伪代码如下面程序段所示。
If ConditionPassed{cond} then
Rd=Rn OR shifter_operand
If S==1 and Rd==r15 then
CPSR=SPSR
Else if S==1 then
N flag=Rd[31]
Z flag=if Rd==0 then 1 else 0
C flag=shifter_Carry_out
V flag=unaffected
4.指令举例
【例6.13】ORR指令举例。
(1)设置R0中位0和1
ORR R0, R0, #3
(2)将R0的低4位置1
ORR R0,R0,#0x0F;
(3)使用ORR指令将R2的高8位数据移入到R3的低8位中
MOV R1,R2,LSR #4;
ORR R3,R1,R3,LSL #8;
1.指令的编码格式
ORR(Logical OR)为逻辑或操作指令,将第二个源操作数《shifter_operand》的值与寄存器Rn的值按位做逻辑或操作,结果保存到Rd中。
指令的编码格式如图6.14所示。
图6.14 ORR指令编码格式
2.指令的语法格式
ORR{《cond》}{S} 《Rn》,《Rn》,《shifter_operand》
① 《cond》
为指令编码中的条件域。它指示指令在什么条件下执行。当《cond》忽略时,指令为无条件执行(cond=AL(Alway))。
② 《S》
S位(bit[20])决定指令的操作是否影响CPSR中条件标志位的值。当S=1时指令更新CPSR中条件标志位的值;当S=0时指令不更新CPSR中条件标志位的值。当S=1时,有下面两种情况。
· 如果《Rd》不是R15,则CPSR中的N位和Z位根据指令的执行结果设置。C位则根据指令操作是否产生一个进位(即一个无符号溢出)来设置;V位则根据是否有带符号的溢出来设置。CPSR中的其他位不受影响。
· 如果《Rd》是程序计数器R15,则当前程序状态的SPSR拷贝到CPSR。如果处理器处于用户模式或系统模式,则指令的执行结果不可预知。因为这两种模式没有自己的私有SPSR寄存器。
③ 《Rd》
指定目标寄存器。
④ 《Rn》
指定第一个源操作数寄存器。
⑤ 《shifter_operand》
使用ARM的通用寻址模式确定第二个源操作数。它影响指令编码格式中的I(bit[25])位和shifter_operand(bits[11∶0])位。
3.指令操作的伪代码
指令操作的伪代码如下面程序段所示。
If ConditionPassed{cond} then
Rd=Rn OR shifter_operand
If S==1 and Rd==r15 then
CPSR=SPSR
Else if S==1 then
N flag=Rd[31]
Z flag=if Rd==0 then 1 else 0
C flag=shifter_Carry_out
V flag=unaffected
4.指令举例
【例6.13】ORR指令举例。
(1)设置R0中位0和1
ORR R0, R0, #3
(2)将R0的低4位置1
ORR R0,R0,#0x0F;
(3)使用ORR指令将R2的高8位数据移入到R3的低8位中
MOV R1,R2,LSR #4;
ORR R3,R1,R3,LSL #8;
下载该资料的人也在下载
下载该资料的人还在阅读
更多 >
- Thumb数据处理指令 0次下载
- 数据处理指令之 BIC位清零指令解析 1次下载
- 数据处理指令之TST测试指令分析 1次下载
- 数据处理指令之TEQ测试相等指令分析 1次下载
- 数据处理指令之SUB减操作指令分析 1次下载
- 数据处理指令之SBC带进位的减法指令分析 2次下载
- 数据处理指令之RSC带进位的翻转减指令分析 2次下载
- 数据处理指令之RSB减翻转指令分析 2次下载
- 数据处理指令的寻址方式解析 2次下载
- 数据处理指令CMN之负数比较指令分析 1次下载
- EOR逻辑异或指令分析 1次下载
- 数据处理指令之ADD加操作指令 1次下载
- SIMATIC逻辑堆栈指令
- WinPEsoft指令手册
- arm汇编指令集
- 三菱PLC数据传送指令介绍 1553次阅读
- PLC逻辑运算指令 2025次阅读
- 电路块ANB指令与ORB指令操作 4916次阅读
- 什么是位逻辑指令? 6821次阅读
- 什么是位逻辑指令?plc位逻辑指令有哪些?plc位逻辑指令应用方法图解 1.5w次阅读
- PLC编程中容易混淆的AND指令和OR指令 1.2w次阅读
- 单片机位处理指令的使用方法 2502次阅读
- 以三菱FX系列基本逻辑指令为例聊聊PLC常用基本逻辑指令 5091次阅读
- 三菱PLC有哪些常用指令三菱PLC指令详细汇总 5.5w次阅读
- 指令和伪指令分得清吗? 6727次阅读
- 西门子PLC编程指令大全包括:位逻辑指令,比较指令,转换指令等14个 3.3w次阅读
- PLC编程常用指令 2.7w次阅读
- 协处理器的三大类数据传送指令 2107次阅读
- thumb指令集是什么_thumb指令集与arm指令集的区别 1.8w次阅读
- ARM微处理器的指令的分类与格式 1361次阅读
下载排行
本周
- 1电子电路原理第七版PDF电子教材免费下载
- 0.00 MB | 1490次下载 | 免费
- 2单片机典型实例介绍
- 18.19 MB | 92次下载 | 1 积分
- 3S7-200PLC编程实例详细资料
- 1.17 MB | 27次下载 | 1 积分
- 4笔记本电脑主板的元件识别和讲解说明
- 4.28 MB | 18次下载 | 4 积分
- 5开关电源原理及各功能电路详解
- 0.38 MB | 10次下载 | 免费
- 6基于AT89C2051/4051单片机编程器的实验
- 0.11 MB | 4次下载 | 免费
- 7蓝牙设备在嵌入式领域的广泛应用
- 0.63 MB | 3次下载 | 免费
- 89天练会电子电路识图
- 5.91 MB | 3次下载 | 免费
本月
- 1OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234313次下载 | 免费
- 2PADS 9.0 2009最新版 -下载
- 0.00 MB | 66304次下载 | 免费
- 3protel99下载protel99软件下载(中文版)
- 0.00 MB | 51209次下载 | 免费
- 4LabView 8.0 专业版下载 (3CD完整版)
- 0.00 MB | 51043次下载 | 免费
- 5555集成电路应用800例(新编版)
- 0.00 MB | 33562次下载 | 免费
- 6接口电路图大全
- 未知 | 30320次下载 | 免费
- 7Multisim 10下载Multisim 10 中文版
- 0.00 MB | 28588次下载 | 免费
- 8开关电源设计实例指南
- 未知 | 21539次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935053次下载 | 免费
- 2protel99se软件下载(可英文版转中文版)
- 78.1 MB | 537791次下载 | 免费
- 3MATLAB 7.1 下载 (含软件介绍)
- 未知 | 420026次下载 | 免费
- 4OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234313次下载 | 免费
- 5Altium DXP2002下载入口
- 未知 | 233045次下载 | 免费
- 6电路仿真软件multisim 10.0免费下载
- 340992 | 191183次下载 | 免费
- 7十天学会AVR单片机与C语言视频教程 下载
- 158M | 183277次下载 | 免费
- 8proe5.0野火版下载(中文版免费下载)
- 未知 | 138039次下载 | 免费
评论
查看更多