ARM指令集

转载链接:
ARM指令集
http://www.doc88.com/p-9826603848969.html
第3章 ARM寻址方式与指令系统.ppt

ARM指令集

ARM指令的分类
6种类型(53种主要助记符) :
1.数据处理指令(22种主要助记符)
2.跳转指令(4种主要助记符)
3.Load/Store指令(16种主要助记符)
4.程序状态寄存器指令(2种主要助记符)
5.协处理器指令(5种主要助记符)
6.软件中断指令 (2种主要助记符)

ARM指令的格式
经典ARM指令格式如下:
<opcode> {<cond>} {S} <Rd>,<Rn>,<operand2>

  • <> 为必选项,{}为可选项
  • 为操作码,如ADD表示算术加操作指令
  • {} 决定指令执行条件域
  • {S} 决定指令执行是否影响CPSR寄存器的值
  • 为目的寄存器
  • 的第一个操作数为寄存器
  • 为第二个操作数

1.数据处理指令

数据处理指令大致可分为5类:
1.1数据传送指令;
1.2加减指令;
1.3乘法指令
1.4逻辑运算指令
1.5比较指令。
数据处理指令只能对寄存器的内容进行操作,而不能对内存中的数据进行操作。所有ARM数据处理指令均可选择使用S后缀,并影响状态标志。

1.1 数据传输指令

1.1.1 MOV 数据传送指令

格式MOV{<cond>}{S} <Rd>,<op1>;
功能Rd=op1;
op1可以是寄存器、被移位的寄存器或立即数。
例如MOV R0,#5 ;R0=5
MOV R0,R1 ;R0=R1
MOV R0,R1,LSL#5 ;R0=R1左移5位

1.1.2 MVN 数据取反传送指令

格式MVN{<cond>}{S} <Rd>,<op1>;
功能将op1表示的值传送到目的寄存器Rd中,但该值在传送前被按位取反,即Rd=!op1;
op1可以是寄存器、被移位的寄存器或立即数。
例如MVN R0,#0 ;R0=-1

1.2 算术逻辑运算指令

1.2.1 ADD 加法指令

格式ADD{<cond>}{S} <Rd>,<Rn>,<op2>;
功能Rd=Rn+op2
op2可以是寄存器,被移位的寄存器或立即数。
例如ADD R0,R1,#5 ;R0=R1+5
ADD R0,R1,R2 ;R0=R1+R2
ADD R0,R1,R2,LSL#5 ;R0=R1+R2左移5位

1.2.2 ADC 带进位加法指令

格式ADC{<cond>}{S} <Rd>,<Rn>,<op2>;
功能Rd=Rn+op2+carry
op2可以是寄存器、被移位的寄存器或立即数;carry为进位标志值。
该指令用于实现超过32位的数的加法。
例如第一个64位操作数存放在寄存器R2,R3中;第二个64位操作数存放在寄存器R4,R5中;
64位结果存放在R0,R1中。
64位的加法可由以下语句实现:
ADDS R0,R2,R4 ;低32位相加,S表示结果影响条件标志位的值
ADC R1,R3,R5 ;高32位相加

1.2.3 SUB 减法指令

格式SUB{<cond>}{S} <Rd>,<Rn>,<op2>;
功能Rd=Rn-op2
op2可以是寄存器、被移位的寄存器或立即数。
例如SUB R0,R1,#5 ;R0=R1-5
SUB R0,R1,R2 ;R0=R1-R2
SUB R0,R1,R2,LSL#5 ;R0=R1-R2左移5位

1.2.4 RSB 反向减法指令

格式RSB{<cond>}{S} <Rd>,<Rn>,<op2>;
功能同SUB指令,但倒换了两操作数的前后位置,即Rd=op2-Rn。
例如RSB R0,R1,#5 ;R0=5-R1
RSB R0,R1,R2 ;R0=R2-R1
RSB R0,R1,R2,LSL#5 ;R0=R2左移5位-R1

1.2.5 SBC 带借位减法指令

格 式SBC{<cond>}{S} <Rd>,<Rn>,<op2>;
功能Rd=Rn-op2-!carry
op2可以是寄存器、被移位的寄存器或立即数。
SUB和SBC生成进位标志的方式不同于常规,如果需要借位则清除进位标志,所以指令要对进位标志进行一个非操作。
例如第一个64位操作数存放在寄存器R2,R3中; 第二个64位操作数存放在寄存器R4,R5中;
64位结果存放在R0,R1中。
64位的减法(第一个操作数减去第二个操作数)可由以下语句实现:
SUBS R0,R2,R4; 低32位相减,S表示结果影响条件标志位的值
SBC R1,R3,R5; 高32位相减

1.2.6 RSC 带借位的反向减法指令

格式RSC{<cond>}{S} <Rd>,<Rn>,<op2>;
功能同SBC指令,但倒换了两操作数的前后位置,即Rd=op2-Rn-!carry。
例如前提条件与SBC例子相同,操作数1-操作数2的实现语句需改为:
SUBS R0,R2,R4; 低32位相减,S表示结果影响寄存器CPSR的值
RSC R1,R5,R3; 高32位相减

1.3 乘法指令

ARM7TDMI具有三种乘法指令,分别为:
32× 32位乘法指令;
32× 32位乘加指令;
32× 32位结果为64位的乘/乘加指令。

1.3.1 MUL 32位乘法指令

格式MUL{<cond>}{S} <Rd>,<Rn>,<op2>;
功能Rd=Rn×op2
该指令根据S标志,决定操作是否影响CPSR的值;其中op2必须为寄存器。
Rn和op2的值为32位的有符号数或无符号数。
例如MULS R0,R1,R2 ;R0=R1×R2,结果影响寄存器CPSR的值

1.3.2 MLA 32位乘加指令

格式MLA{<cond>}{S} <Rd>,<Rn>,<op2>,<op3>;
功能Rd=Rn×op2+op3
op2和op3必须为寄存器。Rn、op2和op3的值为32位的有符号数或无符号数。
例如MLA R0,R1,R2,R3 ;R0=R1×R2+R3

1.3.4 SMULL 64位有符号数乘法指令

格式SMULL{<cond>}{S} <Rdl>,<Rdh>,<Rn>,<op2>;
功能Rdh Rdl=Rn×op2
Rdh、Rdl和op2均为寄存器。Rn和op2的值为32位的有符号数。
例如SMULL R0,R1,R2,R3
;R0=R2×R3的低32位 ;R1=R2×R3的高32位

1.3.5 SMLAL 64位有符号数乘加指令

格式SMLAL{<cond>}{S} <Rdl>,<Rdh>,<Rn>,<op2>;
功能Rdh Rdl=Rn×op2+Rdh Rdl
Rdh、Rdl和op2均为寄存器。Rn和op2的值为32位的有符号数,Rdh Rdl的值为64位的加数。
例如SMLAL R0,R1,R2,R3
;R0=R2×R3的低32位+R0
;R1=R2×R3的高32位+R1

1.3.6 UMULL 64位无符号数乘法指令

格式UMULL{<cond>}{S} <Rdl>,<Rdh>,<Rn>,<op2>;
功能同SMULL指令,但指令中Rn和op2的值为32位的无符号数。
例如UMULL R0,R1,R2,R3
;R0=R2×R3的低32位
;R1=R2×R3的高32位 其中R2,R3的值为无符号数

1.3.7 UMLAL 64位无符号数乘加指令

格式UMLAL {}{S} ,,,;
功能同SMLAL指令,但指令中Rn,op2的值为32位的无符号数,Rdh Rdl的值为64位无符号数。
例如UMLAL R0,R1,R2,R3
;R0=R2×R3的低32位+R0
;R1=R2×R3的高32位+R1 ;其中R2,R3的值为32位无符号数 ;R1,R0的值为64位无符号数

1.4 逻辑运算指令

1.4.1 AND 逻辑与指令

格式AND{<cond>}{S} <Rd>,<Rn>,<op2>;
功能Rd=Rn AND op2
op2可以是寄存器,被移位的寄存器或立即数。一般用于清除Rn的特定几位。
例如AND R0,R0,#5
;保持R0的第0位和第2位,其余位清0

1.4.2 ORR 逻辑或指令

格式ORR{<cond>}{S} <Rd>,<Rn>,<op2>;
功能Rd=Rn OR op2
op2可以是寄存器、被移位的寄存器或立即数。一般用于设置Rn的特定几位。
例如ORR R0,R0,#5
;R0的第0位和第2位设置为1,其余位不变

1.4.3 EOR 逻辑异或指令

格式EOR{<cond>}{S} <Rd>,<Rn>,<op2>;
功能Rd=Rn EOR op2
op2可以是寄存器、被移位的寄存器或立即数。一般用于将Rn的特定几位取反。
例如EOR R0,R0,#5
;R0的第0位和第2位取反,其余位不变

1.4.4 BIC 位清除指令

格式BIC{<cond>}{S} <Rd>,<Rn>,<op2>;
功能Rd=Rn AND (!op2)
用于清除寄存器Rn中的某些位,并把结果存放到目的寄存器Rd中.
操作数op2是一个32位掩码(mask),如果在掩码中设置了某一位,则清除Rn中的这一位;
未设置的掩码位指示Rn中此位保持不变。其中,op2可以是寄存器、被移位的寄存器或立即数。
例如BIC R0,R0,#5
;R0中第0位和第2位清0,其余位不变

1.5 比较指令

1.5.1 CMP 比较指令

格式CMP{<cond>} <Rn>,<op1>;
功能Rn-op1
该指令进行一次减法运算,但不存储结果,根据结果更新CPSR中条件标志位的值。
该指令不需要显式地指定S后缀来更改状态标志。其中,操作数op1为寄存器或立即数。
例如CMP R0, #5; 计算R0-5,根据结果设置条件标志位
ADDGT R0, R0, #5; 如果R0>5,则执行ADDGT指令

1.5.2 CMN 反值比较指令

格式CMN{<cond>} <Rn>,<op1>;
功能同CMP指令,但寄存器Rn的值是和op1取负的值进行比较。
例如CMN R0,#5 ;把R0与-5进行比较

1.5.3 TST 位测试指令

格式TST{<cond>} <Rn>,<op1>;
功能Rn AND op1
根据结果更新CPSR中条件标志位的值,但不存储结果。
用于检查寄存器Rn是否设置了op1中相应的位。
例如TST R0,#5
;测试R0中第0位和第2位是否为1

1.5.4 TEQ 相等测试指令

格式TEQ{<cond>} <Rn>,<op1>;
功能Rn EOR op1
将寄存器Rn的值和操作数op1所表示的值按位作逻辑异或操作,
根据结果更新CPSR中条件标志位的值,但不存储结果。
用于检查寄存器Rn的值是否和op1所表示的值相等。
例如TEQ R0,#5 ;判断R0的值是否和5相等

2. 跳转指令

跳转指令用于实现程序的跳转和程序状态的切换。
ARM程序设计中,实现程序跳转有两种方式:
(1)跳转指令
(2)直接向程序寄存器PC(R15)中写入目标地址值。
通过向程序计数器PC写入跳转地址值,可以实现在4GB的地址空间中的任意跳转。
使用跳转指令,其跳转空间受到限制。

2.1 B 跳转指令

格式B{<cond>} <addr>;
功能PC= PC+ addr左移两位
addr的值是相对当前PC(即寄存器R15)的值的一个偏移量,而不是一个绝对地址,它是24位有符号数。
实际地址的值由汇编器来计算.
addr的值有符号扩展为32位后,左移两位,然后与PC值相加,即得到跳转的目的地址。
跳转的范围为-32MB~+32MB。
例如B exit; 程序跳转到标号exit处

exit

2.2 BL 带返回的跳转指令

格式BL{<cond>} <addr>;
功能同B指令,但BL指令执行跳转操作的同时,还将PC(寄存器R15)的值保存到LR寄存器(寄存器R14)中。
该指令用于实现子程序调用,程序的返回可通过把LR寄存器的值复制到PC寄存器中来实现。
例如BL func; 调用子程序func

func

MOV R15,R14; 子程序返回

由于返回地址保存在寄存器里,在保存R14之前不应再调用下一级的嵌套子程序;否则,新的返回地址将覆盖原来的返回地址,就无法返回到原来的调用位置。这时一般是把R14压入存储器中的堆栈。由于子程序经常还需要一些工作寄存器,所以可使用多寄存器存储指令同时把这些寄存器中原有的数据一起存储。

例如BL SUB1

SUB1
STMFD R13!,{R0-R2,R14};保存工作和链接寄存器
BL SUB2

SUB2

对于不调用其他子程序的子程序(叶子程序),不需要保存R14,因为它不会被覆盖。

2.3 BLX 带返回和状态切换的跳转指令

格式BLX <addr>;或BLX <Rn>;
功能处理器跳转到目标地址处,并将PC(寄存器R15)的值保存到LR寄存器(R14)中。
若为第二种格式,寄存器Rn的值是转移目标,Rn的第0位拷贝到CPSR中的T位(决定是继续执行还是切换到Thumb指令),[31:0]位移入PC;
如果Rn[0]是1,则处理器切换执行Thumb指令,并在Rn中的地址开始执行,但是需将最低为清零;如果Rn[0]是0,则处理器继续执行ARM指令,并在Rn中的地址处开始执行,但需将Rn[1]清零。
该指令用于子程序调用和程序状态的切换。
例如BLX T16; 跳转到标号T16处执行,T16后面的指令为Thumb指令

CODE16 T16 后面指令为Thumb指令

2.4 BX 带状态切换的跳转指令

格式BX <Rn>;
功能处理器跳转到目标地址处,从那里继续执行;
目标地址为寄存器Rn的值和0xFFFFFFFE作与操作的结果。
目标地址处的指令可以是ARM指令,也可以是Thumb 指令。
例如ADR R0,exit ;标号exit处的地址装入R0中
BX R0 ;跳转到exit处

3. Load/Store指令

Load/Store指令用于寄存器和内存间数据的传送。
Load 用于把内存中的数据装载到寄存器中。
Store用于把寄存器中的数据存入内存。
该集合的指令使用频繁,在指令集中最为重要,因为其他指令只能操作寄存器,当数据存放在内存中时,必须先把数据从内存装载到寄存器,执行完后再把寄存器中的数据存储到内存中。
Load/Store指令分为3类:
(1)单一数据传送指令(LDR和STR等)
(2)多数据传送指令(LDM和STM)
(3)数据交换指令(SWP和SWPB)

条件执行的举例
将流程图对应GCD算法转换成
(1) 普通汇编代码 .
(2)ARM 汇编代码.
只使用 CMP, B 及 SUB指令

条件执行的举例
普通汇编代码
gcd cmp r0, r1 ;reached the end?
beq stop
blt less ;if r0 > r1
sub r0, r0, r1 ;subtract r1 from r0
bal gcd
less sub r1, r1, r0 ;subtract r0 from r1
bal gcd
stop
ARM 代码
gcd cmp r0, r1 ;if r0 > r1
subgt r0, r0, r1 ;subtract r1 from r0
sublt r1, r1, r0 ;else subtract r0 from r1
bne gcd ;

3.1 LDR 字数据加载指令

格式LDR{<cond>} <Rd>,<addr>;
功能把addr所表示的内存地址中的字数据装载到目标寄存器Rd中,同时还可以把合成的有效地址写回到基址寄存器。地址addr可以是一个简单的值、一个偏移量,或者是一个被移位的偏移量。
寻址方式Rn:基址寄存器。
Rm:变址寄存器。

Index : 偏移量,12位的无符号数。

代码注释
LDR Rd,[Rn];把内存中地址为Rn的字数据装入寄存器Rd中
LDR Rd,[Rn,Rm];将内存中地址为Rn+Rm的字数据装入寄存器Rd中
LDR Rd,[Rn,#index];将内存中地址为Rn+index的字数据装入Rd中
LDR Rd,[Rn,Rm,LSL#5];将内存中地址为Rn+Rm×32的字数据装入Rd
LDR Rd,[Rn,Rm] !;将内存中地址为Rn+Rm的字数据装入Rd,并将新地址Rn+Rm写入Rn
LDR Rd,[Rn,#index] !;将内存中地址为Rn+index的字数据装入Rd,并将新地址Rn+index写入Rn
LDR Rd,[Rn,Rm,LSL#5]!;将内存中地址为Rn+Rm×32的字数据装入Rd,并将新地址Rn+Rm×32写入Rn
LDR Rd,[Rn],Rm;将内存中地址为Rn的字数据装入寄存器Rd,并将新地址Rn+Rm写入Rn
LDR Rd,[Rn],#index;将内存中地址为Rn的字数据装入寄存器Rd,并将新地址Rn+index写入Rn
LDR Rd,[Rn],Rm,LSL#5;将内存中地址为Rn的字数据装入寄存器Rd,并将新地址Rn+Rm×32写入Rn
LDR R0,[R1,R2,LSL#5]!; 将内存中地址为R1+R2×32的字数据装入寄存器R0,并将新地址R1+R2×32写入R1

3.2 LDRB 字节数据加载指令

格式LDR{<cond>}B <Rd>,<addr>;
功能同LDR指令,但该指令只是从内存读取一个8位的字节数据而不是一个32位的字数据,并将Rd的高24位清0。
例如LDRB R0,[R1] ;将内存中起始地址为R1的一个字节数据装入R0中

3.3 LDRBT 用户模式的字节数据加载指令

格式LDR{<cond>}BT <Rd>,<addr>;
功能同LDRB指令,但无论处理器处于何种模式,都将该指令当作一般用户模式下的内存操作。

3.4 LDRH 半字数据加载指令

格式LDR{<cond>}H <Rd>,<addr>;
功能同LDR指令,但该指令只是从内存读取一个16位的半字数据而不是一个32位的字数据,并将Rd的高16位清0。
例如LDRH R0,[R1] ;将内存中起始地址为R1的一个半字数据装入R0中

3.5 LDRSB 有符号的字节数据加载指令

格式LDR{<cond>}SB <Rd>,<addr>;
功能同LDRB指令,但该指令将寄存器Rd的高24位设置成所装载的字节数据符号位的值。
例如LDRSB R0,[R1] ;将内存中起始地址为R1的一个字节数据装入R0中,R0的高24位设置成该字节数据的符号位

3.6 LDRSH 有符号的半字数据加载指令

格式LDR{<cond>}SH <Rd>,<addr>;
功能同LDRH指令,但该指令将寄存器Rd的高16位设置成所装载的半字数据符号位的值。
例如LDRSH R0,[R1] ;将内存中起始地址为R1的一个16位半字数据装入R0中,R0的高16位设置成该半字数据的符号位

3.7 LDRT 用户模式的字数据加载指令

格式LDR{<cond>}T <Rd>,<addr>;
功能同LDR指令,但无论处理器处于何种模式,都将该指令当作一般用户模式下的内存操作。
addr所表示的有效地址必须是字对齐的,否则从内存中读出的数值需进行循环右移操作。

3. 8 STR 字数据存储指令

格式STR{<cond>} <Rd>,<addr>;
功能把寄存器Rd中的字数据(32位)保存到addr所表示的内存地址中,同时还可以把合成的有效地址写回到基址寄存器。 地址addr可以是一个简单的值、一个偏移量,或者是一个被移位的偏移量。 寻址方式同LDR指令。
例如STR R0,[R1,#5]!
;把R0中的字数据保存到以R1+5为地址的内存中,然后R1=R1+5

3.9 STRB 字节数据存储指令

格式STR{<cond>}B <Rd>,<addr>;
功能把寄存器Rd中的低8位字节数据保存到addr所表示的内存地址中。 其他用法同STR指令。
例如STRB R0,[R1] ;将寄存器R0中的低8位数据存入R1表示的内存地址中

3.10STRBT 用户模式的字节数据存储指令

格式STR{<cond>}BT <Rd>,<addr>;
功能同STRB指令,但无论处理器处于何种模式,该指令都将被当作一般用户模式下的内存操作。

3.11 STRH 半字数据存储指令

格式STR{<cond>}H <Rd>,<addr>;
功能把寄存器Rd中的低16位半字数据保存到addr所表示的内存地址中,而且addr所表示的地址必须是半字对齐的。 其他用法同STR指令。
例如STRH R0,[R1]
;将寄存器R0中的低16位数据存入R1表示的内存地址中

3.12 STRT 用户模式的字数据存储指令

格式STR{<cond>}T <Rd>,<addr>;
功能同STR指令,但无论处理器处于何种模式,该指令都将被当作一般用户模式下的内存操作。

3.13 LDM 批量数据加载指令

格式LDM{<cond>}{<type>} <Rn>{!},<regs>{^};
功能从一片连续的内存单元读取数据到各个寄存器中,内存单元的起始地址为基址寄存器Rn的值,各个寄存器由寄存器列表regs表示。 该指令一般用于多个寄存器数据的出栈。
type字段种类IA:每次传送后地址加1。
IB:每次传送前地址加1。
DA:每次传送后地址减1。
DB:每次传送前地址减1。
FD:满递减堆栈。
ED:空递减堆栈。
FA:满递增堆栈。
EA:空递增堆栈。

注意:有一个约定,编号低的寄存器在存储数据或者加载数据时对应于存储器的低地址。

例如 LDMIA/IB/DA/DB R13!,{R0-R1,R3};
各指令执行完后,结果如图所示。
在这里插入图片描述
FD、ED、FA和EA指定是满栈还是空栈,是升序栈还是降序栈,用于堆栈寻址。
一个满栈的栈指针指向上次写的最后一个数据单元.
空栈的栈指针指向第一个空闲单元。
一个降序栈是在内存中反向增长而升序栈在内存中正向增长。
在这里插入图片描述
格式: LDM{<cond>}{<type>} <Rn>{!},<regs>{^};

  • {!}:若选用了此后缀,则当指令执行完毕后,将最后的地址写入基址寄存器。
  • {^}:当regs中不包含PC时,该后缀用于指示指令所用的寄存器为用户模式下的寄存器,否则指示指令执行时,将寄存器SPSR的值复制到CPSR中。

3.14 STM 批量数据存储指令

格式STM{<cond>}{<type>} <Rn>{!},<regs>{^};
功能将各个寄存器的值存入一片连续的内存单元中,内存单元的起始地址为基址寄存器Rn的值,各个寄存器由寄存器列表regs表示。
该指令一般用于多个寄存器数据的入栈。
{^}:指示指令所用的寄存器为用户模式下的寄存器。
其他参数用法同LDM指令。
例如STMEA R13!,{R0-R12,PC} ;将寄存器R0~R12以及程序计数器PC的值保存到R13指示的堆栈中

3.15 SWP 字数据交换指令

格式SWP{<cond>} <Rd>,<op1>,[<op2>];
功能Rd=[op2],[op2]=op1
从op2所表示的内存装载一个字并把这个字放置到目的寄存器Rd中,然后把寄存器op1的内容存储到同一内存地址中。op1,op2均为寄存器。
例如SWP R0,R1,[R2]
;将R2所表示的内存单元中的字数据装载到R0,然后将R1中的字数据保存到R2所表示的内存单元中

3.16 SWPB 字节数据交换指令

格式SWP{<cond>}B <Rd>,<op1>,[<op2>];
功能从op2所表示的内存装载一个字节并把这个字节放置到目的寄存器Rd的低8位中,Rd的高24位设置为0;然后将寄存器op1的低8位数据存储到同一内存地址中。
例如SWPB R0,R1,[R2]
;将R2所表示的内存单元中的一个字节数据装载到R0的低8位,然后将R1中的低8位字节数据保存到R2所表示的内存单元中

4 程序状态寄存器指令

用于状态寄存器和通用寄存器间传送数据。
总共有两条指令:MRS和MSR。
两者结合可用来修改程序状态寄存器的值。

4.1 MRS 程序状态寄存器到通用寄存器的数据传送指令

格式MRS{<cond>} <Rd>,CPSR/SPSR;
功能用于将程序状态寄存器的内容传送到目标寄存器Rd中。
当进入中断服务程序或进程切换时,该指令可用来保存当前状态寄存器的值。
例如MRS R0,CPSR ;状态寄存器CPSR的值存入寄存器R0中

4.2 MSR 通用寄存器到程序状态寄存器的数据传送指令

格式MSR{<cond>} CPSR/SPSR_<field>,<op1>;
功能用于将寄存器Rd的值传送到程序状态寄存器中。
当退出中断服务程序或进程切换时,该指令可用来恢复状态寄存器的值。
操作数op1可以是通用寄存器或立即数。
<field>用来设置状态寄存器中需要操作的位。
32位的状态寄存器可以分为4个域:
位[31:24]为条件标志位域,用f表示。
位[23:16]为状态位域,用s表示。
位[15:8]为扩展位域,用x表示。
位[7:0]为控制位域,用c表示。
例如MSR CPSR_f,R0 ;用R0的值修改CPSR的条件标志域
MSR CPSR_fsxc,#5; CPSR的值修改为5

5 协处理器指令

ARM处理器最多可支持16个协处理器,用于辅助ARM完成各种协处理操作。
在程序执行过程中,各协处理器只执行自身的协处理指令,而忽略属于ARM处理器和其他协处理器的指令。
ARM协处理器指令可分为3类:
(1)ARM处理器用于初始化协处理器的数据操作指令(CDP)。
(2)协处理器寄存器和内存单元之间的数据传送指令(LDC,STC)。
(3)ARM处理器寄存器和协处理器寄存器之间的数据传送指令(MCR,MRC)。

5.1 CDP协处理器操作指令

格式CDP{<cond>}<p>,<opcode1>,<CRd>,<CRm>,<CRn>,<opcode2>;
功能用于传递指令给协处理器p,要求其在寄存器CRn和CRm上,进行操作opcode1,并把结果存放到CRd中,可以使用opcode2提供与操作有关的补充信息。 指令中的所有寄存器均为协处理器的寄存器,操作由协处理器完成。
指令中P为协处理器编号;
CRd为目的寄存器的协处理器寄存器;
CRm和CRn为存放操作数的协处理器寄存器;
Opcode1和opcode2为协处理器即将执行的操作。
例如CDP p5,5,c0,c1,c2,9;
该指令用于通知协处理器p5,在c1和c2上执行操作5和9,并将结果存放到c0中。

5.2 LDC协处理器数据读取指令

格式LDC {<cond>}{L}<p>,<CRd>,<addr>;
功能将addr表示的内存地址中的连续数据传送到目的寄存器CRd中。
L表示指令为长读取操作,比如用于双精度数据的传输;
目的寄存器CRd为协处理器的寄存器;
addr的寻址方式同LDR指令,其寄存器为ARM处理器的寄存器。
例如LDC p5,c1,[R1+5]:该指令用于将R1+5所对应的存储单元中的数据,传送到协处理器p5的寄存器c1中。

5.3 STC协处理器数据存储指令

格式STC{<cond>}{L}<p>,<CRd>,<addr>;
功能将寄存器CRd的值传送到addr表示的内存地址中。指令中各参数用法同LDC。
例如STC p5,c1,[R1+5]; 该指令用于将协处理器p5中寄存器c1的数据传送到R1+5所对应的存储单元中。

5.4 MCR ARM寄存器到协处理器寄存器的数据传送指令

格式MCR{<cond>}<p>,<op1>,<Rd>,<CRn>,<CRm>{,op2};
功能将ARM处理器的寄存器Rd中的数据传送到协处理器p的寄存器CRn,CRm中;op1,op2为协处理器将要执行的操作。
例如MCR p5,5,R1,C1,C2,9;该指令将R1中的数据传送到协处理器p5的寄存器C1,C2中,协处理器执行操作5和9。

5.5 MRC 协处理器寄存器到ARM寄存器的数据传送指令

格式MRC {<cond>}<p>,<op1>,<Rd>,<CRn>,<CRm>{,op2};
功能将协处理器p的寄存器CRn,CRm的数据传送到ARM处理器的寄存器Rd中;op1,op2为协处理器将要执行的操作。
例如MRC p5,5,R1,C1,C2,9;该指令将寄存器C1,C2中的数据传送到R1中,协处理器p5协处理器执行操作5和9。

6. 软件中断指令

6.1 SWI 软件中断指令

格式SWI {<cond>} 24位的立即数;
功能用于产生软件中断,以使用户程序调用操作系统的系统例程。
指令中24位的立即数指定用户程序调用系统例程的类型,其参数通过通用寄存器传递。
当24位的立即数被忽略时,系统例程类型由寄存器R0指定,其参数通过其他通用寄存器传递。
例如SWI 0X05; 调用编号为05的系统例程。

6.2 BKPT 断点中断指令

格式BKPT 16位的立即数;
功能用于产生软件断点中断,以便软件调试时使用。16位的立即数用于保存软件调试中额外的断点信息。

指令操作的伪代码:
if (not overdiden by debug hardware) then
R14_abt = adderss of BKPT instruction + 4
SPSR_abt = CPSR
CPSR[4:0] = 0b10111 /* 中止模式 /
CPSR[5] = 0 /
使程序处于 ARM 状态, T Bit = 0*/
/* CPSR[6] is unchanged, fiq不变*/
CPSR[7] = 1 /* 禁止正常中断,I Bit = 1, 禁止irq */
if high vectors configured then
PC = 0xFFFF000C
else
PC = 0x0000000C

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值