资料介绍
6.2 EOR逻辑异或指令
1.指令的编码格式
逻辑异或EOR(Exclusive OR)指令将寄存器《Rn》中的值和《shifter_operand》的值执行按位“异或”操作,并将执行结果存储到目的寄存器《Rd》中,同时根据指令的执行结果更新CPSR中相应的条件标志位。
指令的编码格式如图6.3所示。
图6.3 EOR指令的编码格式
2.指令的语法格式
EOR{《cond》}{S} 《Rn》,《Rn》,《shifter_operand》
① 《cond》
为指令编码中的条件域。它指示指令在什么条件下执行。当《cond》忽略时,指令为无条件执行(cond=AL(Alway))。
② 《S》
S位(bit[20])决定指令的执行是否影响CPSR中的条件域。当S位清0时,指令执行不影响CPSR。当S位置位时(并且不是r15),则有以下规则。
· 如果结果为负,则标志位N置位;否则清0(也就是说N等于结果的第31位)。
· 如果结果为0,则标志位Z置位;否则清0。
· 当操作定义为算术操作(ADD、ADC、SUB、SBC、RSB或RSC)时,标志位C设置为ALU的进位输出;否则设置为移位器的进位输出。如果不需要移位,则保持C。
· 在非算术操作中,标志位V保持原值。在算术操作中,如果有从第30位到第31位的溢出,则置位;如果不发生溢出,则清0。仅当算术操作中操作数被认为是2的补码的有符号数时,这个标志位才有意义,而且指示结果超出范围。
若指令中的目标寄存器《Rd》为r15,则当前处理器模式对应的SPSR的值被复制到CPSR寄存器中。用户模式和系统模式下,由于没有相应的SPSR,指令的执行结果不可预知。
③ 《Rd》
指定目标寄存器。
④ 《Rn》
指定第一个源操作数寄存器。
⑤ 《shifter_operand》
使用ARM的通用寻址模式确定第二个源操作数。它影响指令编码格式中的I(bit[25])位和shifter_operand(bits[11∶0])位。
注意当指令的编码格式中I位等于0,并且移位操作数shifter_operand中bit[7]和bit[4]也都等于1,则指令并非EOR指令。详情请参阅ARM系统结构参考手册。
3.指令操作的伪代码
指令操作的伪代码如下面程序段所示。
If ConditionPassed{cond} then
Rd=Rn EOR 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=unaggected
4.指令举例
【例6.2】EOR指令举例。
(1)EOR的真值表(二者不同则结果为1)如表6.3所示。
表6.3 EOR指令真值表
Op_1Op_2结 果
000
011
101
110
(2)反转R0中的位0和1
EOR R0, R0, #3 ;
(3)将R1的低4位取反
EOR R1,R1,#0x0F;
(4)R2=R1∧R0
EOR R2,R1,R0;
(5)将R5和0x01进行逻辑异或,结果保存到R0,并根据执行结果设置标志位。
EORS R0,R5,#0x01;
1.指令的编码格式
逻辑异或EOR(Exclusive OR)指令将寄存器《Rn》中的值和《shifter_operand》的值执行按位“异或”操作,并将执行结果存储到目的寄存器《Rd》中,同时根据指令的执行结果更新CPSR中相应的条件标志位。
指令的编码格式如图6.3所示。
图6.3 EOR指令的编码格式
2.指令的语法格式
EOR{《cond》}{S} 《Rn》,《Rn》,《shifter_operand》
① 《cond》
为指令编码中的条件域。它指示指令在什么条件下执行。当《cond》忽略时,指令为无条件执行(cond=AL(Alway))。
② 《S》
S位(bit[20])决定指令的执行是否影响CPSR中的条件域。当S位清0时,指令执行不影响CPSR。当S位置位时(并且不是r15),则有以下规则。
· 如果结果为负,则标志位N置位;否则清0(也就是说N等于结果的第31位)。
· 如果结果为0,则标志位Z置位;否则清0。
· 当操作定义为算术操作(ADD、ADC、SUB、SBC、RSB或RSC)时,标志位C设置为ALU的进位输出;否则设置为移位器的进位输出。如果不需要移位,则保持C。
· 在非算术操作中,标志位V保持原值。在算术操作中,如果有从第30位到第31位的溢出,则置位;如果不发生溢出,则清0。仅当算术操作中操作数被认为是2的补码的有符号数时,这个标志位才有意义,而且指示结果超出范围。
若指令中的目标寄存器《Rd》为r15,则当前处理器模式对应的SPSR的值被复制到CPSR寄存器中。用户模式和系统模式下,由于没有相应的SPSR,指令的执行结果不可预知。
③ 《Rd》
指定目标寄存器。
④ 《Rn》
指定第一个源操作数寄存器。
⑤ 《shifter_operand》
使用ARM的通用寻址模式确定第二个源操作数。它影响指令编码格式中的I(bit[25])位和shifter_operand(bits[11∶0])位。
注意当指令的编码格式中I位等于0,并且移位操作数shifter_operand中bit[7]和bit[4]也都等于1,则指令并非EOR指令。详情请参阅ARM系统结构参考手册。
3.指令操作的伪代码
指令操作的伪代码如下面程序段所示。
If ConditionPassed{cond} then
Rd=Rn EOR 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=unaggected
4.指令举例
【例6.2】EOR指令举例。
(1)EOR的真值表(二者不同则结果为1)如表6.3所示。
表6.3 EOR指令真值表
Op_1Op_2结 果
000
011
101
110
(2)反转R0中的位0和1
EOR R0, R0, #3 ;
(3)将R1的低4位取反
EOR R1,R1,#0x0F;
(4)R2=R1∧R0
EOR R2,R1,R0;
(5)将R5和0x01进行逻辑异或,结果保存到R0,并根据执行结果设置标志位。
EORS R0,R5,#0x01;
下载该资料的人也在下载
下载该资料的人还在阅读
更多 >
- 单片机指令系统(2)
- <微机与接口技术>51单片机的指令系统——算术运算和逻辑运算指令
- 51单片机之逻辑运算指令ANL、ORL、XRL等
- 51单片机汇编语言教程之单片机逻辑与或异或指令的详细资料讲解 17次下载
- 逻辑分析仪设计实例 53次下载
- kingst虚拟逻辑分析仪使用详解 52次下载
- 数据处理指令之TST测试指令分析 1次下载
- 数据处理指令之TEQ测试相等指令分析 1次下载
- 数据处理指令之SUB减操作指令分析 1次下载
- 数据处理指令之ORR逻辑或指令 2次下载
- C#教程之异或加密数字 13次下载
- 逻辑运算与移位指令 0次下载
- SIMATIC逻辑堆栈指令
- SIMATIC 逻辑运算指令
- 升级使用16800或16900系列逻辑分析仪的十大理由
- 西门子PLC编程指令详解 三菱FX系列PLC的基本逻辑指令详解 1737次阅读
- 使用CD4007阵列构建CMOS逻辑功能 1620次阅读
- SIMATIC S7-1500多路复用、多路分用指令简述 2294次阅读
- SIMATIC S7-1500 PLC与运算指令(AND)简述 3008次阅读
- CMOS逻辑电路、传输门XOR 3041次阅读
- 什么是位逻辑指令? 6821次阅读
- 什么是位逻辑指令?plc位逻辑指令有哪些?plc位逻辑指令应用方法图解 1.5w次阅读
- 异或门基础知识(逻辑表达式_真值表_符号_应用) 9.9w次阅读
- 西门子PLC编程指令大全包括:位逻辑指令,比较指令,转换指令等14个 3.3w次阅读
- 异或运算有什么用_二进制异或运算法则 4.7w次阅读
- 逻辑异或运算怎么算 10.6w次阅读
- 异或运算规则及其应用详解 4.4w次阅读
- 一文看懂C语言异或运算 4.5w次阅读
- 异或运算法则和异或符号在multisim和word的输入方法 2.7w次阅读
- 什么是异或_异或运算及异或运算的作用 11.7w次阅读
下载排行
本周
- 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次下载 | 免费
评论
查看更多