嵌入式系统4+(ARM指令详细介绍)_第1页
嵌入式系统4+(ARM指令详细介绍)_第2页
嵌入式系统4+(ARM指令详细介绍)_第3页
嵌入式系统4+(ARM指令详细介绍)_第4页
嵌入式系统4+(ARM指令详细介绍)_第5页
已阅读5页,还剩56页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

嵌入式系统第四讲ARM指令详细介绍西安电子科技大学计算机学院2ARM指令集编码西安电子科技大学计算机学院3指令分类数据处理指令load/store指令跳转指令CPSR处理指令异常产生指令协处理器指令西安电子科技大学计算机学院41数据处理指令数据传送指令(2条)算术运算指令(6条)逻辑运算指令(4条)比较指令(2条)测试指令(2条)乘法指令(6条)西安电子科技大学计算机学院51.1数据传送指令MOV指令

MOV指令的格式为:

MOV{条件}{S}目的寄存器,源操作数MOV指令可完成从另一个寄存器、被移位的寄存器或将一个立即数加载到目的寄存器。其中S选项决定指令的操作是否影响CPSR中条件标志位的值,当没有S时指令不更新CPSR中条件标志位的值。指令示例: MOV R1,R0 MOV R1,R0,LSL#3西安电子科技大学计算机学院61.1数据传送指令MVN指令MVN指令的格式为:

MVN{条件}{S}目的寄存器,源操作数MVN指令可完成从另一个寄存器、被移位的寄存器、或将一个立即数加载到目的寄存器。与MOV指令不同之处是在传送之前按位被取反了,即把一个被取反的值传送到目的寄存器中。其中S决定指令的操作是否影响CPSR中条件标志位的值,当没有S时指令不更新CPSR中条件标志位的值。指令示例: MVN R0,#0 西安电子科技大学计算机学院71.2算术运算指令ADD指令

ADD指令的格式为:

ADD{条件}{S}目的寄存器,操作数1,操作数2ADD指令用于把两个操作数相加,并将结果存放到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。指令示例: ADD R0,R1,R2 ADD R0,R1,#256 ADD R0,R2,R3,LSL#1西安电子科技大学计算机学院81.2算术运算指令ADC指令

ADC指令的格式为:

ADC{条件}{S}目的寄存器,操作数1,操作数2ADC指令用于把两个操作数相加,再加上CPSR中的C条件标志位的值,并将结果存放到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。以下指令序列完成两个128位数的加法,第一个数存放在寄存器R7~R4,第二个数存放在寄存器R11~R8,运算结果存放在寄存器R3~R0: ADDS R0,R4,R8;加低端的字 ADCS R1,R5,R9;加第二个字,带进位 ADCS R2,R6,R10;加第三个字,带进位 ADC R3,R7,R11;加第四个字,带进位

西安电子科技大学计算机学院91.2算术运算指令SUB指令

SUB指令的格式为:

SUB{条件}{S}目的寄存器,操作数1,操作数2SUB指令用于把操作数1减去操作数2,并将结果存放到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。该指令可用于有符号数或无符号数的减法运算。指令示例:SUB R0,R1,R2;R0=R1-R2SUB R0,R1,#256;R0=R1-256SUB R0,R2,R3,LSL#1;R0=R2-(R3<<1)西安电子科技大学计算机学院101.2算术运算指令SBC指令

SBC指令的格式为:

SBC{条件}{S}目的寄存器,操作数1,操作数2SBC指令用于把操作数1减去操作数2,再减去CPSR中的C条件标志位的非,并将结果存放到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。以下指令序列实现64减法(R1,R0)-(R3,R2) SUBS R0,R0,R2 SBC R1,R1,R3西安电子科技大学计算机学院111.2算术运算指令RSB指令

RSB指令的格式为:

RSB{条件}{S}目的寄存器,操作数1,操作数2RSB指令称为逆向减法指令,用于把操作数2减去操作数1,并将结果存放到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。指令示例: RSB R0,R1,R2 RSB R0,R1,#256 RSB R0,R2,R3,LSL#1西安电子科技大学计算机学院121.2算术运算指令RSC指令

RSC指令的格式为:

RSC{条件}{S}目的寄存器,操作数1,操作数2RSC指令用于把操作数2减去操作数1,再减去CPSR中的C条件标志位,并将结果存放到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。该指令使用进位标志来表示借位,这样就可以做大于32位的减法。下列指令实现64位数据的负数 RSBSR2,R0,#0 RSCR3,R1,#0西安电子科技大学计算机学院131.3逻辑运算指令AND指令AND指令的格式为:

AND{条件}{S}目的寄存器,操作数1,操作数2AND指令用于在两个操作数上进行逻辑与运算,并把结果放置到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。该指令常用于屏蔽操作数1的某些位。例如: AND R0,R0,#3;将高位屏蔽(取出低位)西安电子科技大学计算机学院141.3逻辑运算指令ORR指令ORR指令的格式为:

ORR{条件}{S}目的寄存器,操作数1,操作数2ORR指令用于在两个操作数上进行逻辑或运算,并把结果放置到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。该指令常用于设置操作数1的某些位。例如: ORR R0,R0,#3;将低位置位西安电子科技大学计算机学院151.3逻辑运算指令EOR指令EOR指令的格式为:EOR{条件}{S}目的寄存器,操作数1,操作数2EOR指令用于在两个操作数上进行逻辑异或运算,并把结果放置到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。该指令常用于反转操作数1的某些位。例如: EOR R0,R0,#3西安电子科技大学计算机学院161.3逻辑运算指令BIC指令BIC指令的格式为:

BIC{条件}{S}目的寄存器,操作数1,操作数2BIC指令用于清除操作数1的某些位,并把结果放置到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。操作数2为32位的掩码,如果在掩码中设置了某一位,则清除这一位。未设置的掩码位保持不变。例如:

BIC R0,R0,#3;清除低两位西安电子科技大学计算机学院171.4比较指令CMP指令CMP指令的格式为:

CMP{条件}操作数1,操作数2CMP指令用于把一个寄存器的内容和另一个寄存器的内容或立即数进行比较,同时无条件更新CPSR中条件标志位的值。该指令进行一次减法运算,但不存储结果,只更改条件标志位。标志位表示的是操作数1与操作数2的关系(大、小、相等),例如,当操作数1大于操作操作数2,则此后的有GT后缀的指令将可以执行。例如: CMPR1,R0 CMPR1,#100西安电子科技大学计算机学院181.4比较指令CMN指令

CMN指令的格式为:

CMN{条件}操作数1,操作数2CMN指令用于把一个寄存器的内容和另一个寄存器的内容或立即数取补后进行比较,同时无条件更新CPSR中条件标志位的值。该指令实际完成操作数1和操作数2相加,并根据结果更改条件标志位。例如: CMN R1,R0 CMN R1,#100西安电子科技大学计算机学院191.5测试指令TST指令

TST指令的格式为:

TST{条件}操作数1,操作数2TST指令用于把一个寄存器的内容和另一个寄存器的内容或立即数进行按位的与运算,并根据运算结果无条件更新CPSR中条件标志位的值。操作数1是要测试的数据,而操作数2是一个位掩码,该指令一般用来检测是否设置了特定的位。 TST R1,#1 TST R1,#0xffe 西安电子科技大学计算机学院201.5测试指令TEQ指令

TEQ指令的格式为:

TEQ{条件}操作数1,操作数2TEQ指令用于把一个寄存器的内容和另一个寄存器的内容或立即数进行按位的异或运算,并根据运算结果无条件更新CPSR中条件标志位的值。该指令通常用于比较操作数1和操作数2是否相等。例如: TEQ R1,R2西安电子科技大学计算机学院211.6乘法指令MUL 32位乘法指令MLA 32位乘加指令SMULL 64位有符号数乘法指令SMLAL 64位有符号数乘加指令UMULL 64位无符号数乘法指令UMLAL 64位无符号数乘加指令西安电子科技大学计算机学院221.6乘法指令MUL指令

MUL指令的格式为:

MUL{条件}{S}目的寄存器,操作数1,操作数2MUL指令完成将操作数1与操作数2的乘法运算,并把结果的低32位放置到目的寄存器中,同时可以根据运算结果设置CPSR中相应的条件标志位。其中,操作数1和操作数2均为32位的有符号数或无符号数。例如: MUL R0,R1,R2 MULS R0,R1,R2 西安电子科技大学计算机学院231.6乘法指令MLA指令MLA指令的格式为:

MLA{条件}{S}目的寄存器,操作数1,操作数2,操作数3MLA指令完成将操作数1与操作数2的乘法运算,再将乘积加上操作数3,并把结果的低32位放置到目的寄存器中,同时可以根据运算结果设置CPSR中相应的条件标志位。其中,操作数1和操作数2均为32位的有符号数或无符号数。例如: MLA R0,R1,R2,R3 MLAS R0,R1,R2,R3西安电子科技大学计算机学院241.6乘法指令SMULL指令SMULL指令格式为:

SMULL{条件}{S} 目的寄存器Low,目的寄存器High,操作数1,操作数2

SMULL指令完成将操作数1与操作数2的乘法运算,并把结果的低32位放置到目的寄存器Low中,结果的高32位放置到目的寄存器High中,同时可以根据运算结果设置CPSR中相应的条件标志位。其中,操作数1和操作数2均为32位的有符号数。例如:SMULLR0,R1,R2,R3;R0(Low32)←(R2×R3)Low32

;R1(High32)←(R2×R3)High32西安电子科技大学计算机学院251.6乘法指令SMLAL指令SMLAL指令的格式为:

SMLAL{条件}{S} 目的寄存器Low,目的寄存器High,操作数1,操作数2SMLAL指令完成将操作数1与操作数2的乘法运算,并把结果的低32位同目的寄存器Low中的值相加后又放置到目的寄存器Low中,结果的高32位同目的寄存器High中的值相加后又放置到目的寄存器High中,同时可以根据运算结果设置CPSR中相应的条件标志位。其中,操作数1和操作数2均为32位的有符号数。对于目的寄存器Low,在指令执行前存放64位加数的低32位,指令执行后存放结果的低32位。对于目的寄存器High,在指令执行前存放64位加数的高32位,指令执行后存放结果的高32位。西安电子科技大学计算机学院261.6乘法指令UMULL指令UMULL指令的格式为:

UMULL{条件}{S} 目的寄存器Low,目的寄存器High,操作数1,操作数2

UMULL指令完成将操作数1与操作数2的乘法运算,并把结果的低32位放置到目的寄存器Low中,结果的高32位放置到目的寄存器High中,同时可以根据运算结果设置CPSR中相应的条件标志位。其中,操作数1和操作数2均为32位的无符号数。例如:UMULLR0,R1,R2,R3;R0(Low32)←(R2×R3)Low32 ;R1(High32)←(R2×R3)High32西安电子科技大学计算机学院271.6乘法指令UMLAL指令UMLAL指令的格式为:

UMLAL{条件}{S} 目的寄存器Low,目的寄存器High,操作数1,操作数2

UMLAL指令完成将操作数1与操作数2的乘法运算,并把结果的低32位同目的寄存器Low中的值相加后又放置到目的寄存器Low中,结果的高32位同目的寄存器High中的值相加后又放置到目的寄存器High中,同时可以根据运算结果设置CPSR中相应的条件标志位。其中,操作数1和操作数2均为32位的无符号数。对于目的寄存器Low,在指令执行前存放64位加数的低32位,指令执行后存放结果的低32位。对于目的寄存器High,在指令执行前存放64位加数的高32位,指令执行后存放结果的高32位。西安电子科技大学计算机学院282load/store指令ARM微处理器支持加载(Load)/存储(Store)指令用于在寄存器和存储器之间传送数据。单寄存器存取指令LDR 字数据加载指令LDRB 字节数据加载指令LDRH 半字数据加载指令STR 字数据存储指令STRB 字节数据存储指令STRH 半字数据存储指令多寄存器存取指令LDM 批量数据加载指令STM 批量数据存储指令存储器和寄存器交换指令SWP/SWPB西安电子科技大学计算机学院292.1字数据加载指令LDR指令LDR指令的格式为:

LDR{条件}目的寄存器,<存储器地址>

LDR指令用于从存储器中将一个32位的字数据传送到目的寄存器中。该指令通常用于从存储器中读取32位的字数据到通用寄存器,然后对数据进行处理。例如:LDRR0,[R1];将内存单元[R1]中的字读取到R0寄存器中LDRR0,[R1,R2];将内存单元[R1+R2]中的字读取到 R0寄存器中LDRR0,[R1,#8];将内存单元[R1+8]中的字读取到R0 寄存器中LDRR0,[R1,R2]!;将内存单元[R1+R2]中的字读取到R0 寄存器中,同时R1←R1+R2西安电子科技大学计算机学院302.2字节数据加载指令LDRB指令LDRB指令的格式为:

LDR{条件}B目的寄存器,<存储器地址>LDRB指令用于从存储器中将一个8位的字节数据传送到目的寄存器中,同时将寄存器的高24位清零。该指令通常用于从存储器中读取8位的字节数据到通用寄存器,然后对数据进行处理。LDRBR0,[R1];将内存单元[R1]中的字节读取到R0 寄存器中,R0中高24位设置为0LDRBR0,[R1,#8];将内存单元[R1+8]中的字节 读取到R0寄存器中,R0中高24位设置为0西安电子科技大学计算机学院312.3半字数据加载指令LDRH指令LDRH指令的格式为:

LDR{条件}H目的寄存器,<存储器地址>LDRH指令用于从存储器中将一个16位的半字数据传送到目的寄存器中,同时将寄存器的高16位清零。该指令通常用于从存储器中读取16位的半字数据到通用寄存器,然后对数据进行处理。LDRHR0,[R1];将内存单元[R1]中的半字(16位)数据读 取到R0寄存器中,R0中高16位设置为0LDRHR0,[R1,#8];将内存单元[R1+8]中的半字(16位) 数据读取到R0寄存器中,R0中高16位设置为0LDRHR0,[R1,R2];将内存单元[R1+R2]中的半字(16位) 数据读取到R0寄存器中,R0中高16位设置为0

西安电子科技大学计算机学院322.4字数据存储指令STR指令STR指令的格式为:

STR{条件}源寄存器,<存储器地址>STR指令用于从源寄存器中将一个32位的字数据传送到存储器中。该指令在程序设计中比较常用,且寻址方式灵活多样,使用方式可参考指令LDR。STR R0,[R1],#8;将R0的字数据保存到内存单元 [R1]中,同时R1←R1+8(后变)STR R0,[R1,#8];将R0的字数据保存到内存单元 [R1+8]中(前变)西安电子科技大学计算机学院332.5字节数据存储指令STRB指令STRB指令的格式为:

STR{条件}B源寄存器,<存储器地址>STRB指令用于从源寄存器中将一个8位的字节数据传送到存储器中。该字节数据为源寄存器中的低8位。STRB R0,[R1];将R0的低8位数据保存到 内存单元[R1]中STRB R0,[R1,#8];将R0的低8位数据保存到 内存单元[R1]中西安电子科技大学计算机学院342.6半字数据存储指令STRH指令STRH指令的格式为:

STR{条件}H源寄存器,<存储器地址>STRH指令用于从源寄存器中将一个16位的半字数据传送到存储器中。该半字数据为源寄存器中的低16位。STRH R0,[R1];将R0中的16位的半字数据 保存到内存单元[R1]中STRH R0,[R1,#8];将R0中的16位的半字数据 保存到内存单元[R1+8]中

西安电子科技大学计算机学院35LDR/STR指令的寻址方式基址寻址变址寻址变址寻址灵活多变,需要认真掌握西安电子科技大学计算机学院36批量数据加载(LDM)/存储(STM)内存访问指令ARM微处理器所支持批量数据加载/存储指令可以一次在一片连续的存储器单元和多个寄存器之间传送数据。批量数据加载指令(LDM)用于将一片连续的存储器中的数据传送到多个寄存器,批量数据存储指令(STR)则完成相反的操作。IA、IB、DA、DBFD、ED、FA、EA西安电子科技大学计算机学院372.7批量数据存储指令STM指令STM指令的格式为:

STM{条件}{类型}基址寄存器{!},寄存器列表{^}STM指令用于将寄存器列表所指示的多个寄存器数据送到由基址寄存器所指示的一片连续存储器,该指令的常见用途是将多个寄存器的内容入栈。例如:STMFDR0!,{r0-r4};将寄存器列表中的寄存器 (R1~R4)内容按照满递减的方式 存入到[R0]指示的4个连续存储器单元中西安电子科技大学计算机学院382.8批量数据加载指令LDM指令LDM指令的格式为:

LDM{条件}{类型}基址寄存器{!},寄存器列表{^}LDM指令用于从由基址寄存器所指示的一片连续存储器送字数据到寄存器列表所指示的多个寄存器中,该指令的常见用途是将多个寄存器出栈。例如:

LDMFDR0!,{r1-r4};将[R0]指示的4个连续存储器 单元的内容按照满递减的方式送到 寄存器列表中的寄存器(R1~R4)中西安电子科技大学计算机学院39可选后缀{!}回写使能标志为可选后缀,若选用该后缀,则当数据传送完毕之后,将最后的地址写入基址寄存器,否则基址寄存器的内容不改变。{^}为可选后缀,当指令为LDM,且寄存器列表中包含R15,选用该后缀时表示:除了正常的数据传送之外,还将SPSR复制到CPSR。西安电子科技大学计算机学院402.9存储器和寄存器交换指令ARM微处理器所支持数据交换指令能在存储器和寄存器之间交换数据。数据交换指令主要用于实现信号量操作,信号量用于进程间的同步与互斥。西安电子科技大学计算机学院412.9存储器和寄存器交换指令SWP指令SWP指令的格式为:

SWP{条件}目的寄存器,源寄存器1,[源寄存器2]SWP指令用于将源寄存器2所指向的存储器中的字数据传送到目的寄存器中,同时将源寄存器1中的字数据传送到源寄存器2所指向的存储器中。显然,当源寄存器1和目的寄存器为同一个寄存器时,指令交换该寄存器和存储器的内容。SWPR0,R1,[R2];R0←[R2],[R2]←R1SWPR0,R0,[R2];R0(目的)←[R2],[R2]←R0(源) 即实现了寄存器R0的内容与存 储器地址[R2]的内容的交换

西安电子科技大学计算机学院42信号量操作举例SEM EQU 0x40003000 …SEM_WAIT MOV R1,#0 LDR R0,=SEM SWP R1,R1,[R0];取出信号量, 并设置其为0 CMP R1,#0;判断是否有信号 BEQ SEM_WAIT;若没有,则等待西安电子科技大学计算机学院433跳转指令ARM中实现程序跳转直接向PC寄存器写入目标地址值跳转指令实现向PC寄存器写入目标地址值可实现4GB地址空间的任意跳转跳转指令可以完成从当前指令向前或向后的32MB的地址空间的跳转,包括:B 跳转指令BL 带返回的跳转指令BX 带状态切换的跳转指令BLX 带返回和状态切换的跳转指令西安电子科技大学计算机学院443.1跳转指令B指令B指令的格式为:

B{条件} 目标地址B指令是最简单的跳转指令。一旦遇到一个B指令,ARM处理器将立即跳转到给定的目标地址,从那里继续执行。注意存储在跳转指令中的实际值是相对当前PC值的一个偏移量,而不是一个绝对地址,它的值由汇编器来计算。它是24位有符号数,左移两位后有符号扩展为32位,表示的有效偏移为26位(前后32MB的地址空间)。如:BLabel/*程序无条件跳转到标号Label处执行*/西安电子科技大学计算机学院453.2带返回的跳转指令BL指令BL指令的格式为:

BL{条件} 目标地址BL是另一个跳转指令,但跳转之前,会在寄存器R14中保存PC的当前内容,因此,可以通过将R14的内容重新加载到PC中,来返回到跳转指令之后的那个指令处执行。该指令是实现子程序调用的一个基本但常用的手段。例如:BL Label /*当程序无条件跳转到标号Label处执 行时,同时将当前的PC值保存到R14中*/西安电子科技大学计算机学院463.3带状态切换的跳转指令BX指令BX指令的格式为:

BX{条件}目标地址BX指令跳转到指令中所指定的目标地址,目标地址处的指令既可以是ARM指令,也可以是Thumb指令。因此,当前处理器工作状态使用Thumb指令集时,通过BX指令可使当前处理器工作状态切换到ARM指令集运行状态,反之亦然。具体状态有目标寄存器最低位决定。例如:ADRL R0,ThumbFun+1BX R0 ;跳转到R0指定的地址,并根 据R0最低位来切换处理器状态西安电子科技大学计算机学院473.4带返回和状态切换的跳转BLX指令BLX指令的格式为:

BLX目标地址BLX指令从ARM指令集跳转到指令中所指定的目标地址,并将处理器的工作状态由ARM状态切换到Thumb状态,该指令同时将PC的当前内容保存到寄存器R14中。因此,当子程序使用Thumb指令集,而调用者使用ARM指令集时,可以通过BLX指令实现子程序的调用和处理器工作状态的切换。同时,子程序的返回可以通过将寄存器R14值复制到PC中来完成。西安电子科技大学计算机学院484程序状态寄存器访问指令

ARM微处理器支持程序状态寄存器(PSR)访问指令,用于在程序状态寄存器(CPSR/SPSR)和通用寄存器之间传送数据,程序状态寄存器访问指令包括以下两条:MRS状态寄存器的内容读取到通用寄存器(Rn←CPSR/SPSR)MSR立即数或通用寄存器内容写到状态寄存器的指定区域(CPSR/SPSR←Rn)西安电子科技大学计算机学院494.1MRS指令MRS指令的格式为:MRS{条件}通用寄存器,程序状态寄存器(CPSR或SPSR)MRS指令用于将程序状态寄存器的内容传送到通用寄存器中。例如:MRS R0,CPSR ;R0←CPSRMRS R0,SPSR ;R0←SPSR该指令一般用在以下几种情况:当需要改变程序状态寄存器的内容时,可用MRS将程序状态寄存器的内容读入通用寄存器,修改后再写回程序状态寄存器。当在异常处理或进程切换时,需要保存程序状态寄存器的值,可先用该指令读出程序状态寄存器的值,然后保存。西安电子科技大学计算机学院504.2MSR指令MSR指令的格式为:

MSR{条件} 程序状态寄存器(CPSR或SPSR)_<域>,操作数MSR指令用于将操作数的内容传送到程序状态寄存器的特定域中。其中,操作数可以为通用寄存器或立即数。MSR指令的形式如下:

MSR{cond}<PSR>_<fields>,#immed_8r MSR{cond}<PSR>_<fields>,Rm西安电子科技大学计算机学院514.2MSR指令其中:<域>用于设置程序状态寄存器中需要操作的位(4个域)c位[7:0]为控制位域,用c表示;x位[15:8]为扩展位域,用x表示;s位[23:16]为状态位域,用s表示;

f位[31:24]为条件标志位域,用f表示;例如:MSR CPSR,R0 ;CPSR←R0MSR CPSR_c,R0 ;CPSR_c←R0,仅改变CPSR的控 制域即位[7:0]西安电子科技大学计算机学院525异常产生指令ARM微处理器所支持的异常指令有如下两条:SWI 软件中断指令BKPT 断点中断指令(ARMv5以上)西安电子科技大学计算机学院535.1软件中断指令SWI指令SWI指令的格式为:

SWI{条件}24位的立即数SWI指令用于产生软件中断,以便用户程序能调用操作系统的系统例程。操作系统在SWI的异常处理程序中提供相应的系统服务,指令中24位的立即数指定用户程序调用系统例程的类型,相关参数通过通用寄存器传递,当指令中24位的立即数被忽略时,用户程序调用系统例程的类型由通用寄存器R0的内容决定,同时,参数通过其他通用寄存器传递。例如:SWI 0x02;西安电子科技大学计算机学院545.2断点中断指令BKPT指令BKPT指令的格式为:

BKPT 16位的立即数BKPT指令产生软件断点中断,可用于程序的调试。西安电子科技大学计算机学院556协处理器指令数据操作指令数据存取指令(内存-协处理器寄存器)数据传送指令(ARM寄存器-协处理器寄存器)西安电子科技大学计算机学院566.1数据操作指

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论