全部指令集.docx
- 文档编号:12573246
- 上传时间:2023-04-20
- 格式:DOCX
- 页数:16
- 大小:20.78KB
全部指令集.docx
《全部指令集.docx》由会员分享,可在线阅读,更多相关《全部指令集.docx(16页珍藏版)》请在冰豆网上搜索。
全部指令集
加減法指令及例程
ADD{
加法指令 Rd=op1
ADC{
带进位的加法指令 Rd=!
op1
SUB{
减法指令 Rd=Rn+op2
RSB{
反向减法指令 Rd=Rn+op2+carry
SBC{
带借位减法指令 Rd=Rn-op2
RSC{
带借位的反向减法指令Rd=op2-Rn
AREAEXAMPLE3,CODE,READONLY;/*声明一段名为EXAMPLE3的CODE*/
ENTRY;/*指定函数的入口*/
START
MOVR0,#0xFF;/*把#0xFF传送到R0*/
MOVR1,#0xEF000000;/*把#0XEF000000传送到R1*/
MOVR2,#0x2F000000;/*把#0x2F000000传送到R2*/
MVNR3,#0Xff;/*把#0xFF取反后传送到R3*/
ADDR4,R2,R1;/*把R2加R1的值传送到R4*/
ADDSR5,R2,R1;/*把R2加R1的值传送到R5,s表示会影响cpsr*/
ADCSR6,R2,R1;/*把R2加R1的值,再加上carry的值后传送到R6.
;s表示值会影响cpsr*/
SUBR4,R2,R1;/R2减R1的值传送到R4*/
SUBSR4,R2,R1;/*R2减R1的值传送到R4,s表示值会影响cpsr*/
RSBR5,R2,R1;/*R1减R2的值传送到R5*/
RSBSR5,R2,R1;/*R1减R2的值后传送到R5,s表示会影响cpsr*/
SBCR6,R1,R2;/*R1减R2的值再减去!
CARRY后传送到R6*/
RSCR7,R1,R2;/*R2减R1的值再减去!
CARRY后传送到R7*/
stop
BLstop
END;/*endoftheprogram*/
乘法指令及例程
MUL{
32位乘法指令Rd=Rn×op2
MLA{
32位乘加指令Rd=Rn×op2+op3
SMULL{
64位有符号数乘法指令RdhRd1=Rn×op2
SMLAL{
64位有符号数乘加指令RdhRd1=Rn×op2+RdhRd1
UMULL{
64位无符号数乘法指令
同SMULL指令,但指令中的Rn,op2的值为32位的无符号数
UMLAL{
64位无符号数乘加指令
同SMLAL指令,但指令中的Rn,op2的值为32位的无符号数
AREAEXAMPLE3,CODE,READONLY;/*声明一段名为EXAMPLE3的代码*/
ENTRY
START
MOVR0,#0XFF000000;/*对R0赋值#0XFF000000*/
MOVR1,#-0X10;/*对R1赋值#-0X10*/
MOVR2,#0X1000000;/*对R2赋值#0X1000000*/
MOVR3,#0;/*对R3赋值#0*/
MULSR4,R0,R1;/*R4=R0*R1,结果影响寄存器CPSR的值*/
SMULLSR6,R5,R1,R0;/*R6=R1*R0的低32位,R5=R1*R0的高32位,
;结果影响寄存器CPAR的值*/
UMULLSR8,R7,R1,R0;/*R8=R1*R0的低32位,R7=R1*R0的高32位,
;结果影响寄存器CPSR的值*/
MLAR3,R0,R1,R2;/*R3=R0*R1+R2*/
SMLALR6,R0,R1,R2;/*R6=R1*R2的低32位+R6,
;R0=R1*R2的高32位+R0*/
UMLALR8,R0,R1,R2;/*R8=R1*R2的低32位+R8,
;R0=R1*R2的高32位+R0,
;其中R1,R2的值为32位无符号数,
;R8,R0的值为64位无符号数*/
STOP
BLSTOP;/*死循环*/
END
数据传送指令
MOV指令
语法格式MOV{
MOV指令是最简单的ARM指令,执行的结果就是把一个数N送到目标寄存器Rd,其中N可以是寄存器,也可以是立即数。
指令举例
MOVR0,R0;R0=R0…..NOP指令
MOVR0,R0,LSL#3;R0=R0*8
MVN指令
语法格式MVN{
MVN指令多用于向寄存器传送一个负数或生成位掩码。
指令举例
MVNR0,#4;R0=-5
MVNR0,#0;R0=-1
逻辑运算指令
逻辑与指令AND
语法格式AND{
逻辑与指令Rd=RnANDop2
逻辑或指令ORR
语法格式ORR{
逻辑或指令Rd=RnORop2
逻辑异或指令EOR
语法格式EOR{
逻辑异或指令Rd=RnEORop2
位清除指令BIC
语法格式BIC{
位清除指令Rd=RnAND(!
op2)
比较运算指令
CMP指令
CMP指令使用寄存器Rn的值减去operand2的值
语法格式CMP{
举例CMPR1,#10
CMPR1,R2
CMN指令
CMN指令使用寄存器Rn的值减去operand2的负数值
语法格式CMN{
举例CMPRn,#0
CMPRn,#0
分支跳转指令
B{
跳转指令,一旦遇到B指令,ARM指令将立即跳转到给定的addr标号位置,然后从那里继续执行。
BL{
带返回的跳转指令,同B指令,但BL指令执行跳转指令的同时,还将PC的值保存到LR寄存器中。
BLX
带返回和状态切换的跳转指令,处理器跳转到目标地址处,从那里继续执行,并将PC的值保存到LR寄存器中。
BX
带状态切换的跳转指令,处理器跳转到目标地址处,从那里继续执行,目标地址为寄存器Rn的值和0xFFFFFFFE作与操作的结果。
程序举例
AREAEXAMPLE3,CODE,READONLY
ENTRY
START
Ba;跳转至a
MOVR1,#10;这条语句将不会被执行
a
MOVR2,#11;r2=11
BLb;跳转至b
BLXt16;跳转至t16
Bends;跳转到ends
ends
MOVPC,LR;PC=LR,PC指向(Bends),死循环,
;程序到这里结束
b
MOVR3,#2;r3=2
MOVPC,LR;PC=LR,PC指向(BLb)的下一行,
;返回
t16
MOVPC,LR;PC=LR,PC指向(BLXt16)的
;下一行,返回
END
存储器访问指令:
寄存器寻址
MOVR1,R2;R2->R1
SUBR0,R1,R2;R1-R2->R0
寄存器偏移寻址
MOVR0,R2,LSL#3
R2的值左移3位,结果放入R0,即R0=R2*8
ANDSR1,R1,R2,LSLR3
R2的值左移R3位,然后和R1相与操作,结果放入R1
寄存器间接寻址
LDRR1,[R2];R1←[R2]
ADDR1,R1,[R2];R1←R1+[R2]
多寄存器寻址
LDMIAR1,{R2,R12}
R2←[R1],R12←[R2+4]
多寄存器的Load/Store内存访问指令
LDM装载多个寄存器{Rd}*N←mem32[startaddress+4*N]
STM保存多个寄存器{Rd}*N→mem32[startaddress+4*N]
协处理指令
ARM协处理器指令可以分为以下3类:
(1)协处理器数据操作
(2)协处理器数据传送指令
(3)协处理器寄存传送指令
协处理器指令b
CDP协处理器数据操作
LDC转载协处理器寄存器
MCR从ARM寄存器传数据到协处理器寄存器
MRC从协处理器寄存器传数据到ARM寄存器
STC存器协处理器寄存器
杂项指令(状态操作指令)
MRS把程序状态寄存器的值传送到一个通用寄存器Rd=SPR
MSR把通用寄存器的值送到程序状态寄存器或把一个立即数送到程序状态字
PSR[field]=Rm或PSR[field]=immediate
符号定义伪指令及例程
1、全局变量定义:
(1)GBLA定义全局数字变量并初始化为0。
格式如下:
GBLA变量名
GBLATest1;定义一个全局数值变量,变量名为Test1
Test1SETA0xaa;将该变量赋值为0xaa
(2)GBLS 定义全局字符串变量并初始化为空串。
格式如下:
GBLS变量名
GBLLTest2;定义一个全局的逻辑变量,变量名为Test2
Test2SETL{TRUE};将该变量赋值为真
(3)GBLL 定义全局逻辑变量并初始化为FALSE。
格式如下:
GBLL变量名
GBLSTest3;定义一个全局的字符串变量,变量名为Test3
Test3SETS“Testing”;将该变量赋值为“Testing”
2、变量赋值伪操作:
(1)SETA 给数字变量赋值。
格式如下:
变量名SETA数值
varSETA0x11;var付值为0x11
(2)SETS 给字符串变量赋值。
格式如下:
变量名SETS字符串;
LogicSETL{FALSE};Logic付值为FALSE,
(3)SETL 给逻辑变量赋值。
格式如下:
变量名SETL逻辑{TRUE/FALSE}
StringSETS"nottest";String1付值为"nottest"
3、局部变量伪操作:
(1)LCLA 定义一个局部数字变量,并初始化为0。
格式如下:
LCLA变量名
LCLATest4;声明一个局部的数字变量,命名为Test4
Test3SETA0xaa;将改变量赋值为0xaa
(2)LCLS 定义一个局部字符串变量,并初始化为空串。
格式如下:
LCLS变量名
LCLLTest5;声明一个局部的逻辑变量,命名为Test5
Test4SETL{TRUE};将该变量赋值为真
(3)LCLL 定义一个局部逻辑变量,并初始化为FALSE。
格式如下:
LCLL变量名
LCLSTest6;声明一个局部的字符串变量,命名为Test6
Test6SETS“Testing”;将该变量赋值为“Testing”
(4)定义一个宏显示局部变量的作用范围:
MACRO;声明一个宏
$labelmessage$a;宏原型
LCLSerr;声明局部变量字符串
$label
INFO0,”err”:
CC:
:
STA:
$a
MEND;宏结束,局部变量不再起作用4、通用寄存器列表定义:
(1)RLIST为通用寄存器列表定义名称。
格式如下:
寄存器列表的名称RLIST{通用寄存器的列表}
RegListRLIST{R0-R5,R8,R10}
将寄存器列表名定义为RegList,
*列表中的寄存器用逗号隔开,如果是编号连续的通用寄存器可以用“-”指定寄存器范围。
数据定义伪操作:
(1)DCB用于分配一片连续的字节存储单元并用指定的数据初始化,。
格式如下:
{程序标号}DCBexpr{,expr}
*expr可以是128~255的数字,也可以是字符串
StrDCB“Thisisatest!
”
(2)DCW(DCWU)用于分配一片连续的半字节存储单元并用指定的数据初始化。
格式如下:
{程序标号}DCW{U}expr{,expr}
DateTestDCW1,2,3
(3)DCD用于指定一片连续的子存储单元并用指定的数据初始化。
格式如下:
{程序标号}DCDexpr{,expr}
分配一片连续的字存储单元并初始化:
DateTestDCD4,5,6
(4)DCFS/DCFSU 为单精度浮点数分配连续的字储存单元并使用指定数据初始化。
格式如下:
标号DCFS/DCFSU表达式
DCFS/DCFSU1.0,-0.1,3.1
(5)DCFD/DCFDU 为双精度浮点数分配连续的字储存单元并使用指定数据初始化。
格式如下:
标号DCFD/DCFDU表达式
DCFD/DCFDU1.0,-0.1,3.1
(6)SPACE 分配一块连续的存储单元。
格式如下:
SPACE表达式
DateSpaceSAPCE100;分配连续的100字节的存储单元并初始化为0
(7)FIELD 分配一块连续的存储单元。
格式如下:
FIELD字节数
(8)MAP 定义一个结构化的内存表的首地址。
格式如下:
MAP表达式[,基址寄存器]
MAP0x100,R0;定义结构化内存表首地址的值为0x100+R0
(9)DCQ用于分配一片以8字节为单位的连续的存储单元并用指定的数据初始化
标号DCQ表达式
分配一片连续的存储单元并初始化为指定的值
DateTestDCQ100
控制伪指令及例程:
(1)IF、ELSE和ENDIF 条件编译指令。
格式如下:
IF逻辑表达式
指令序列1
ELSE
指令序列2
ENDIF
(2)WHILE、WEND 指令格式如下:
WHILE逻辑表达式
指令序列
WEND
WHILE、WEND伪指令能根据条件的成立与否决定是否循环执行某个指令序列。
使用示例如下:
(3)MACRO、MEND 指令格式如下:
$标号宏名$参数1,$参数2,……
指令序列
MEND
MACRO、MEND伪指令可以将一段代码定义为一个整体,称为宏指令,然后就可以在程序中通过宏指令多次调用该段代码。
地址加载伪指令及例程:
(1)ADR 小范围的地址读取伪指令。
格式如下:
ADR{cond}register,expr
指令功能为:
通常,编译器用一条ADD指令或SUB指令来实现该ADR伪指令的功能。
(2)ADRL 中等范围的地址读取伪指令。
格式如下:
ADRL{cond}register,expr
指令功能为:
ADRL伪指令被编译器替换成两条合适的指令,即使一条指令可以完成该伪指令的功能,编译器也将用两条指令来替换该ADRL伪指令。
(3)LDR 大范围的地址读取伪指令。
格式如下:
LDR{cond}register,=[expr|label-expr]
指令功能为:
当需要读取到寄存器中的数据超过了MOV及MVN指令可以操作的范围时,可以使用LDR伪指令将该数据读取到寄存器中。
(4)NOP 空操作伪指令。
格式如下:
NOP
指令功能为:
NOP伪指令不影响CPSR中的条件标志为。
声明引用伪指令:
(1)EQU 指令格式如下:
名称EQU表达式{,类型}
EQU伪指令用于为程序中的常量、标号等定义一个等效的字符名称,类似于C语言中的#define。
其中EQU可用“*”代替。
(2)EXPORT(或GLOBAL) 指令格式如下:
EXPORT标号{[WEAK]}
EXPORT伪指令用于在程序中声明一个全局的标号,该标号可在其他的文件中引用。
EXPORT可用GLOBAL代替。
(3)IMPORT 指令格式如下:
IMPORT标号{[WEAK]}
IMPORT伪指令用于通知编译器要使用的标号在其他的源文件中定义,但要在当前源文件中引用,而且无论当前源文件是否引用该标号,该标号均会被加入到当前源文件的符号表中。
(4)EXTERN 指令格式如下:
EXTERN标号{[WEAK]}
EXTERN伪指令用于通知编译器要使用的标号在其他的源文件中定义,但要在当前源文件中引用,如果当前源文件实际并未引用该标号,该标号就不会被加入到当前源文件的符号表中。
(5)GET(或INCLUDE) 指令格式如下:
GET文件名
GET伪指令用于将一个源文件包含到当前的源文件中,并将被包含的源文件在当前位置进行汇编处理。
(6)INCBIN 指令格式如下:
INCBIN文件名
INCBIN伪指令用于将一个目标文件或数据文件包含到当前的源文件中,被包含的文件不作任何变动的存放在当前文件中,编译器从其后开始继续处理。
(7)RN 指令格式如下:
名称RN表达式
RN伪指令用于给一个寄存器定义一个别名。
(8)ROUT 指令格式如下:
{名称}ROUT
ROUT伪指令用于给一个局部变量定义作用范围。
段域伪指令及例程:
(1)FILED和MAP 结构化内存表中的数据域指令。
指令格式如下:
标号FIELD表达式
FIELD伪指令用于定义一个结构化内存表中的数据域。
(2)AREA 指令格式如下:
AREA段名属性1,属性2,……
AREA伪指令用于定义一个代码段或数据段。
其中,段名若以数字开头,则该段名需用“|”括起来,如|1_test|。
属性字段表示该代码段(或数据段)的相关属性,多个属性用逗号分隔。
常用的属性如下:
CODE属性:
用于定义代码段,默认为READONLY。
DATA属性:
用于定义数据段,默认为READWRITE。
READONLY属性:
指定本段为只读,代码段默认为READONLY。
READWRITE属性:
指定本段为可读可写,数据段的默认属性为READWRITE。
ALIGN属性:
使用方式为ALIGN表达式。
在默认时,ELF(可执行连接文件)的代码段和数据段是按字对齐的,表达式的取值范围为0~31,相应的对齐方式为2表达式次方。
COMMON属性:
该属性定义一个通用的段,不包含任何的用户代码和数据。
各源文件中同名的COMMON段共享同一段存储单元。
(3)ALIGN 指令格式如下:
ALIGN{表达式{,偏移量}}
ALIGN伪指令可通过添加填充字节的方式,使当前位置满足一定的对其方式。
(4)CODE16和CODE32 指令格式如下:
CODE16(或CODE32)
CODE16伪指令通知编译器,其后的指令序列为16位的Thumb指令。
CODE32伪指令通知编译器,其后的指令序列为32位的ARM指令。
(5)ENTRY 指令格式如下:
ENTRY
ENTRY伪指令用于指定汇编程序的入口点。
(6)END 指令格式如下:
END
END伪指令用于通知编译器已经到了源程序的结尾。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 全部 指令