嵌入式控制系统--2ARM7指系统课件

上传人:cn****1 文档编号:574846414 上传时间:2024-08-17 格式:PPT 页数:36 大小:323KB
返回 下载 相关 举报
嵌入式控制系统--2ARM7指系统课件_第1页
第1页 / 共36页
嵌入式控制系统--2ARM7指系统课件_第2页
第2页 / 共36页
嵌入式控制系统--2ARM7指系统课件_第3页
第3页 / 共36页
嵌入式控制系统--2ARM7指系统课件_第4页
第4页 / 共36页
嵌入式控制系统--2ARM7指系统课件_第5页
第5页 / 共36页
点击查看更多>>
资源描述

《嵌入式控制系统--2ARM7指系统课件》由会员分享,可在线阅读,更多相关《嵌入式控制系统--2ARM7指系统课件(36页珍藏版)》请在金锄头文库上搜索。

1、ARM指令目录1.指令格式2.条件码3.存储器访问指令4.数据处理指令5.乘法指令6.ARM分支指令7.杂项指令8.伪指令1嵌入式控制系统-2ARM7指令系统3.1 指令集介绍nARM指令集乘法指令 ARM7TDMI具有三种乘法指令,分别为:3232位乘法指令;32 32位乘加指令;32 32位结果为64位的乘/乘加指令。2嵌入式控制系统-2ARM7指令系统ARM指令乘法指令乘法指令编码64位有符号乘加指令SMLAL11164位有符号乘法指令SMULL11064位无符号乘加指令UMLAL10164位无符号乘法指令UMULL10032位乘加指令MLA00132位乘法指令MUL000说明指令助记符

2、操作码opcode操作码功能表3嵌入式控制系统-2ARM7指令系统助记符说明操作条件码位置MUL Rd,Rm,Rs32位乘法指令RdRm*Rs (RdRm)MULcondSMLA Rd,Rm,Rs,Rn32位乘加指令RdRm*Rs+Rn (RdRm)MLAcondSUMULL RdLo,RdHi,Rm,Rs64位无符号乘法指令(RdLo,RdHi) Rm*Rs UMULLcondSUMLAL RdLo,RdHi,Rm,Rs64位无符号乘加指令(RdLo,RdHi) Rm*Rs+(RdLo,RdHi)UMLALcondSSMULL RdLo,RdHi,Rm,Rs64位有符号乘法指令(RdLo,R

3、dHi) Rm*RsSMULLcondSSMLAL RdLo,RdHi,Rm,Rs64位有符号乘加指令(RdLo,RdHi) Rm*Rs+(RdLo,RdHi)SMLALcondSARM指令乘法指令4嵌入式控制系统-2ARM7指令系统助记符说明操作条件码位置MUL Rd,Rm,RsMUL Rd,Rm,Rs32位乘法指令RdRm*Rs (RdRm)MULcondSMLA Rd,Rm,Rs,Rn32位乘加指令RdRm*Rs+Rn (RdRm)MLAcondSUMULL RdLo,RdHi,Rm,Rs64位无符号乘法指令(RdLo,RdHi) Rm*Rs UMULLcondSUMLAL RdLo,R

4、dHi,Rm,Rs64位无符号乘加指令(RdLo,RdHi) Rm*Rs+(RdLo,RdHi)UMLALcondSSMULL RdLo,RdHi,Rm,Rs64位有符号乘法指令(RdLo,RdHi) Rm*RsSMULLcondSSMLAL RdLo,RdHi,Rm,Rs64位有符号乘加指令(RdLo,RdHi) Rm*Rs+(RdLo,RdHi)SMLALcondSARM指令乘法指令 32位乘法指令MUL指令将Rm和Rs中的值相乘,结果的低32位保存到Rd中。 Rd,Rm,Rs不能为R15。只影响CPSR中的N位和Z位。指令格式如下:MULcondS Rd,Rm,Rs 应用示例: MUL

5、R1,R2,R3 ;R1=R2R3 MULS R0,R3,R7 ;R0=R3R7,影响CPSR中的N位和Z位 5嵌入式控制系统-2ARM7指令系统助记符说明操作条件码位置MUL Rd,Rm,Rs32位乘法指令RdRm*Rs (RdRm)MULcondSMLA Rd,Rm,Rs,RnMLA Rd,Rm,Rs,Rn32位乘加指令RdRm*Rs+Rn (RdRm)MLAcondSUMULL RdLo,RdHi,Rm,Rs64位无符号乘法指令(RdLo,RdHi) Rm*Rs UMULLcondSUMLAL RdLo,RdHi,Rm,Rs64位无符号乘加指令(RdLo,RdHi) Rm*Rs+(RdL

6、o,RdHi)UMLALcondSSMULL RdLo,RdHi,Rm,Rs64位有符号乘法指令(RdLo,RdHi) Rm*RsSMULLcondSSMLAL RdLo,RdHi,Rm,Rs64位有符号乘加指令(RdLo,RdHi) Rm*Rs+(RdLo,RdHi)SMLALcondSARM指令乘法指令 32位乘加指令MLA指令将Rm和Rs中的值相乘,再将乘积加上第3个操作数,结果的低32位保存到Rd中。 Rd,Rm,Rs,Rn不能为R15。只影响CPSR中的N位和Z位。指令格式如下: MLAcondS Rd,Rm,Rs,Rn 应用示例: MLA R1,R2,R3,R0; R1=R2R3+

7、R06嵌入式控制系统-2ARM7指令系统助记符说明操作条件码位置MUL Rd,Rm,Rs32位乘法指令RdRm*Rs (RdRm)MULcondSMLA Rd,Rm,Rs,Rn32位乘加指令RdRm*Rs+Rn (RdRm)MLAcondSUMULL RdLo,RdHi,Rm,RsUMULL RdLo,RdHi,Rm,Rs64位无符号乘法指令(RdLo,RdHi) Rm*Rs UMULLcondSUMLAL RdLo,RdHi,Rm,Rs64位无符号乘加指令(RdLo,RdHi) Rm*Rs+(RdLo,RdHi)UMLALcondSSMULL RdLo,RdHi,Rm,Rs64位有符号乘法指

8、令(RdLo,RdHi) Rm*RsSMULLcondSSMLAL RdLo,RdHi,Rm,Rs64位有符号乘加指令(RdLo,RdHi) Rm*Rs+(RdLo,RdHi)SMLALcondSARM指令乘法指令 64位无符号乘法指令UMULL指令将Rm和Rs中的值作无符号数相乘,结果的低32位保存到RdLo中,而高32位保存到RdHi中。 RdLo/Hi,Rm,Rs不能为R15。 RdLo/Hi,Rm必须是不同的寄存器。只影响CPSR中的N位和Z位。指令格式如下: UMULLcondS RdLo,RdHi,Rm,Rs 应用示例: UMULL R0,R1,R5,R8; (R1、R0)=R5R

9、8 7嵌入式控制系统-2ARM7指令系统助记符说明操作条件码位置MUL Rd,Rm,Rs32位乘法指令RdRm*Rs (RdRm)MULcondSMLA Rd,Rm,Rs,Rn32位乘加指令RdRm*Rs+Rn (RdRm)MLAcondSUMULL RdLo,RdHi,Rm,Rs64位无符号乘法指令(RdLo,RdHi) Rm*Rs UMULLcondSUMLAL RdLo,RdHi,Rm,RsUMLAL RdLo,RdHi,Rm,Rs64位无符号乘加指令(RdLo,RdHi) Rm*Rs+(RdLo,RdHi)UMLALcondSSMULL RdLo,RdHi,Rm,Rs64位有符号乘法指

10、令(RdLo,RdHi) Rm*RsSMULLcondSSMLAL RdLo,RdHi,Rm,Rs64位有符号乘加指令(RdLo,RdHi) Rm*Rs+(RdLo,RdHi)SMLALcondSARM指令乘法指令 64位无符号乘加指令UMLAL指令将Rm和Rs中的值作无符号数相乘,64位乘积与RdHi、RdLo相加,结果的低32位保存到RdLo中,而高32位保存到RdHi中。 RdLo/Hi,Rm,Rs不能为R15。 RdLo/Hi,Rm必须是不同的寄存器。只影响CPSR中的N位和Z位。指令格式如下: UMLALcondS RdLo,RdHi,Rm,Rs 应用示例: UMLAL R0,R1,

11、R5,R8;(R1、R0)=R5R8+(R1、R0) 8嵌入式控制系统-2ARM7指令系统助记符说明操作条件码位置MUL Rd,Rm,Rs32位乘法指令RdRm*Rs (RdRm)MULcondSMLA Rd,Rm,Rs,Rn32位乘加指令RdRm*Rs+Rn (RdRm)MLAcondSUMULL RdLo,RdHi,Rm,Rs64位无符号乘法指令(RdLo,RdHi) Rm*Rs UMULLcondSUMLAL RdLo,RdHi,Rm,Rs64位无符号乘加指令(RdLo,RdHi) Rm*Rs+(RdLo,RdHi)UMLALcondSSMULL RdLo,RdHi,Rm,RsSMULL

12、 RdLo,RdHi,Rm,Rs64位有符号乘法指令(RdLo,RdHi) Rm*RsSMULLcondSSMLAL RdLo,RdHi,Rm,Rs64位有符号乘加指令(RdLo,RdHi) Rm*Rs+(RdLo,RdHi)SMLALcondSARM指令乘法指令 64位有符号乘法指令SMULL指令将Rm和Rs中的值作有符号数相乘,结果的低32位保存到RdLo中,而高32位保存到RdHi中。 RdLo/Hi,Rm,Rs不能为R15。 RdLo/Hi,Rm必须是不同的寄存器。只影响CPSR中的N位和Z位。指令格式如下: SMULLcondS RdLo,RdHi,Rm,Rs 应用示例: SMULL

13、R2,R3,R7,R6; (R3、R2)=R7R6 9嵌入式控制系统-2ARM7指令系统助记符说明操作条件码位置MUL Rd,Rm,Rs32位乘法指令RdRm*Rs (RdRm)MULcondSMLA Rd,Rm,Rs,Rn32位乘加指令RdRm*Rs+Rn (RdRm)MLAcondSUMULL RdLo,RdHi,Rm,Rs64位无符号乘法指令(RdLo,RdHi) Rm*Rs UMULLcondSUMLAL RdLo,RdHi,Rm,Rs64位无符号乘加指令(RdLo,RdHi) Rm*Rs+(RdLo,RdHi)UMLALcondSSMULL RdLo,RdHi,Rm,Rs64位有符号

14、乘法指令(RdLo,RdHi) Rm*RsSMULLcondSSMLAL RdLo,RdHi,Rm,RsSMLAL RdLo,RdHi,Rm,Rs64位有符号乘加指令(RdLo,RdHi) Rm*Rs+(RdLo,RdHi)SMLALcondSARM指令乘法指令 64位有符号乘加指令SMLAL指令将Rm和Rs中的值作有符号数相乘,64位乘积与RdHi、RdLo相加,结果的低32位保存到RdLo中,而高32位保存到RdHi中。 RdLo/Hi,Rm,Rs不能为R15。 RdLo/Hi,Rm必须是不同的寄存器。只影响CPSR中的N位和Z位。指令格式如下: SMLALcondS RdLo,RdHi,

15、Rm,Rs 应用示例: SMLALR2,R3,R7,R6; (R3、R2)=R7R6+(R3、R2) 10嵌入式控制系统-2ARM7指令系统ARM指令目录1.指令格式2.条件码3.存储器访问指令4.数据处理指令5.乘法指令6.ARM分支指令7. 杂项指令8.伪指令11嵌入式控制系统-2ARM7指令系统3.1 指令集介绍nARM指令集分支指令 在ARM中有两种方式可以实现程序的跳转,一种是使用分支指令直接跳转,另一种则是直接向PC寄存器赋值实现跳转。 分支指令有以下三种:分支指令B;带链接的分支指令BL;带状态切换的分支指令BX。12嵌入式控制系统-2ARM7指令系统助记符说明操作条件码位置B

16、label分支指令PClabelBcondBL label带链接的分支指令LRPC,PClabelBLcondBX Rm带状态切换的分支指令PCRm,切换处理器状态BXcondARM指令分支指令13嵌入式控制系统-2ARM7指令系统助记符说明操作条件码位置B labelB label分支指令PClabelBcondBL label带链接的分支指令LRPC,PClabelBLcondBX Rm带状态切换的分支指令PCRm,切换处理器状态BXcondARM指令分支指令 分支指令B指令,该指令跳转范围限制在当前指令的32M字节地址内(ARM指令为字对齐,最低2位地址固定为0)。指令格式如下:Bcon

17、d Label 应用示例: B WAITA; 跳转到WAITA标号处 B0x1234; 跳转到绝对地址0x1234处 14嵌入式控制系统-2ARM7指令系统BL LabelxxxxxxLabelxxxMOV PC,LRAddr1Addr2xxxxxxLRPC助记符说明操作条件码位置B label分支指令PClabelBcondBL labelBL label带链接的分支指令LRPC,PClabelBLcondBX Rm带状态切换的分支指令PCRm,切换处理器状态BXcondARM指令分支指令 带链接的分支指令BL指令适用于子程序调用,使用该指令后,下一条指令的地址被拷贝到R14(即LR) 连接

18、寄存器中,然后跳转到指定地址运行程序。跳转范围限制在当前指令的32M字节地址内。指令格式如下:BLcond LabelAddr1LabelAddr2Addr21.当程序执行到BL跳转指令时,硬件将下一条指令的地址Addr2装入LR寄存器,并把跳转地址装入程序计数器(PC)2. 程序跳转到目标地址Label继续执行,当子程序执行结束后,将LR寄存器内容存入PC,返回调用函数继续执行 应用示例(调用子程序): BL Label15嵌入式控制系统-2ARM7指令系统助记符说明操作条件码位置B label分支指令PClabelBcondBL label带链接的分支指令LRPC,PClabelBLcon

19、dBX RmBX Rm带状态切换的分支指令PCRm,切换处理器状态BXcondARM指令分支指令 带状态切换的分支指令BX指令,该指令可以根据跳转地址(Rm)的最低位来切换处理器状态。其跳转范围限制在当前指令的32M字节地址内。指令格式如下:BXcond Rm跳转地址Rm0跳转后CPSR标志T位处理器状态00ARM11Thumb16嵌入式控制系统-2ARM7指令系统助记符说明操作条件码位置B label分支指令PClabelBcondBL label带链接的分支指令LRPC-4,PClabelBLcondBX RmBX Rm带状态切换的分支指令PCRm,切换处理器状态BXcondARM指令分支

20、指令 Rm的位0不用作地址的一部分。若Rm的位0为1,则指令将CPSR中的标志T置位,且将目标地址的代码解释为Thumb代码。 应用示例: ADRL R0,ThumbFun+1 ;将Thumb程序的入口地址加1存入R0 BX R0 ; 跳转到R0指定的地址, ;并根据R0的最低位来切换处理器状态17嵌入式控制系统-2ARM7指令系统ARM指令目录1.指令格式2.条件码3.存储器访问指令4.数据处理指令5.乘法指令6.ARM分支指令7. 杂项指令8.伪指令18嵌入式控制系统-2ARM7指令系统3.1 指令集介绍nARM指令集杂项指令 ARM指令集中有三条指令作为杂项指令,在实际应用中这三条指令非

21、常重要。它们如下所示:助记符说明操作条件码位置SWI immed_24软中断指令产生软中断,处理器进入管理模式SWIcondMRS Rd,psr读状态寄存器指令Rdpsr,psr为CPSR或SPSRMRScondMSR psr_fields,Rd/#immed_8r写状态寄存器指令psr_fieldsRd/#immed_8r,psr为CPSR或SPSRMSRcond19嵌入式控制系统-2ARM7指令系统ARM杂项指令软中断指令 SWI指令用于产生SWI异常,使得CPU模式变换到管理模式,并且将CPSR保存到管理模式的SPSR中,然后程序跳转到SWI异常入口。不影响条件码标志。 该指令主要用于用

22、户程序调用操作系统的系统服务,操作系统在SWI异常处理程序中进行相应的系统服务。20嵌入式控制系统-2ARM7指令系统ARM杂项指令软中断指令 根据SWI指令传递的参数SWI异常处理程序可以做出相应的处理。,指令中的24位立即数指定了用户请求的服务类型,参数通过通用寄存器传递。 MOV R0,#34;设置子功能号为34 SWI 12;调用12号软中断 21嵌入式控制系统-2ARM7指令系统ARM杂项指令状态寄存器读指令 在ARM处理器中,只有MRS指令可以对状态寄存器CPSR和SPSR进行读操作。通过读CPSR可以了解当前处理器的工作状态。读SPSR寄存器可以了解到进入异常前的处理器状态。该指

23、令不影响条件码。22嵌入式控制系统-2ARM7指令系统ARM杂项指令状态寄存器读指令 在ARM处理器中,只有MRS指令可以对状态寄存器CPSR和SPSR进行读操作。通过读CPSR可以了解当前处理器的工作状态。读SPSR寄存器可以了解到进入异常前的处理器状态。MRScond Rd,psrMRS指令格式 应用示例: MRS R1,CPSR; 将CPSR状态寄存器读取,保存到R1中 MRS R2,SPSR; 将SPSR状态寄存器读取,保存到R2中23嵌入式控制系统-2ARM7指令系统ARM杂项指令状态寄存器写指令 在ARM处理器中,只有MSR指令与MRS配合使用,可以实现对CPSR或SPSR寄存器的

24、读-修改-写操作,可以切换处理器模式、或者允许/禁止IRQ/FIQ中断等。MSRcond psr_fields,#immed_8rMSR指令格式1MSRcond psr_fields,RmMSR指令格式2指令执行的条件码CPSR或SPSR指定传送的区域,可以为以下字母(必须小写)的一个或者组合:c 控制域屏蔽字节(psr7.0)x 扩展域屏蔽字节(psr15.8)s 状态域屏蔽字节(psr23.16)f 标志域屏蔽字节(psr31.24)保存要传送到状态寄存器指定域数据的源寄存器要传送到状态寄存器指定域的立即数24嵌入式控制系统-2ARM7指令系统(1)(2)(3)(4)ARM杂项指令状态寄存

25、器写指令 在ARM处理器中,只有MSR指令可以对状态寄存器CPSR和SPSR进行写操作。与MRS配合使用,可以实现对CPSR或SPSR寄存器的读-修改-写操作,可以切换处理器模式、或者允许/禁止IRQ/FIQ中断等。 应用示例1:;子程序:使能IRQ中断ENABLE_IRQ MRS R0, CPSR BIC R0, R0,#0x80 MSR CPSR_c,R0 MOV PC,LR 应用示例2:;子程序:禁能IRQ中断DISABLE_IRQ MRS R0, CPSR ORR R0, R0,#0x80 MSR CPSR_c,R0 MOV PC,LR 1.将CPSR寄存器内容读出到R0;2.修改对应

26、于CPSR中的I控制位;3.将修改后的值写回 CPSR寄存器的对应控制域;4.返回上一层函数;25嵌入式控制系统-2ARM7指令系统ARM指令目录1.指令格式2.条件码3.存储器访问指令4.数据处理指令5.乘法指令6.ARM分支指令7. 杂项指令8.伪指令26嵌入式控制系统-2ARM7指令系统3.1 指令集介绍nARM伪指令 ARM伪指令不属于ARM指令集中的指令,是为了编程方便而定义的。伪指令可以像其它ARM指令一样使用,但在编译时这些指令将被等效的一条或多条ARM指令所代替。ARM伪指令有四条,分别为ADR伪指令、ADRL伪指令、LDR伪指令、NOP伪指令。 27嵌入式控制系统-2ARM7

27、指令系统ARM伪指令小范围的地址读取 ADR伪指令将基于PC相对偏移的地址值或基于寄存器相对偏移的地址值读取到寄存器中。在汇编编译器编译源程序时,ADR伪指令被编译器替换成一条合适的指令。通常,编译器用一条ADD指令或SUB指令来实现该ADR伪指令的功能。ADRcond register,exprADR伪指令格式指令执行的条件码加载的目标寄存器地址表达式 地址表达式expr的取指范围:当地址值是字对齐时,其取指范围为-255255;当地址值是字节对齐时,其取指范围为-10201020;28嵌入式控制系统-2ARM7指令系统ARM伪指令小范围的地址读取 . ADRL R0,Delay .Dela

28、y MOV R0,r14 .应用示例(源程序): .0x20 ADD r0,pc,#0x3c . .0x64 MOV r0,r14 .编译后的反汇编代码:使用伪指令将程序标号Delay的地址存入R0ADR伪指令被汇编成一条指令29嵌入式控制系统-2ARM7指令系统ARM伪指令小范围的地址读取 应用示例2(查表): ADR R0,DISP_TAB; 加载转换表地址 LDRB R1,R0,R2; 使用R2作为参数,进行查表 DISP_TAB DCB 0xC0,0xF9,0xA4,0xB0,0x99, 0x92,0x82,0xF830嵌入式控制系统-2ARM7指令系统ARM伪指令中等范围的地址读取

29、ADRL伪指令将基于PC相对偏移的地址值或基于寄存器相对偏移的地址值读取到寄存器中,比ADR伪指令可以读取更大范围的地址 。在汇编编译器编译源程序时,ADRL伪指令被编译器替换成两条合适的指令。若不能用两条指令实现,则产生错误,编译失败。ADRLcond register,exprADRL伪指令格式指令执行的条件码加载的目标寄存器地址表达式 地址表达式expr的取指范围:当地址值是字节对齐时,其取指范围为-64K64K;当地址值是字对齐时,其取指范围为-256K256K;31嵌入式控制系统-2ARM7指令系统ARM伪指令中等范围的地址读取 . ADRL R0,Delay .Delay MOV

30、R0,r14 .应用示例(源程序): . 0x20 ADD r0,pc,#400x24 ADD r0,r0,#FF00 .0xFF68 MOV r0,r14 .编译后的反汇编代码:使用伪指令将程序标号Delay的地址存入R0ADRL伪指令被汇编成两条指令32嵌入式控制系统-2ARM7指令系统ARM伪指令大范围的地址读取 LDR伪指令用于加载32位的立即数或一个地址值到指定寄存器。在汇编编译源程序时,LDR伪指令被编译器替换成一条合适的指令。若加载的常数未超出MOV或MVN的范围,则使用MOV或MVN指令代替该LDR伪指令,否则使用一条程序相对偏移的LDR指令读出常量。LDRcond regis

31、ter,=expr | label_exprLDR伪指令格式指令执行的条件码加载的目标寄存器基于PC的地址表达式或外部表达式注意:1. 指令位置的偏移量必须小于4KB;2.与ARM指令的LDR相比,伪指令的LDR的参数有“=”号。33嵌入式控制系统-2ARM7指令系统ARM伪指令大范围的地址读取应用示例(加载地址):编译后的反汇编代码: . LDR R1,=InitStack .InitStack MOV R0, LR . .0x60 LDR R1,0xb4 .0x64 MOV R0, LR .0xb4 DCD 0x64使用伪指令将程序标号InitStack的地址存入R1LDR伪指令被汇编成一

32、条LDR指令,并 定 义 了 一 个 常 量 , 该 常 量 为InitStack标号的地址34嵌入式控制系统-2ARM7指令系统ARM伪指令空操作伪指令 NOP伪指令在汇编时将会被代替成ARM中的空操作,比如可能是“MOV R0,R0”指令等。NOP可用于延时操作。NOPNOP伪指令格式应用示例(延时子程序): mov R1,#0x1234Delay NOP;空操作 NOP NOP SUBS R1,R1,#1;循环次数减一 BNE Delay;如果循环没有结束,跳转Delay继续 MOV PC,LR;子程序返回35嵌入式控制系统-2ARM7指令系统编程编程 1.用ARM汇编指令实现的C赋值语句:x=(a+b)-c,在进行运算之前,代码必须先把a、b、c的值装入到寄存器,运算结束后,还要把x的值存回存储器中。 2用ARM汇编指令实现的C语句:z=(a2)|(b&15)。3在ARM汇编指令中实现下面条件转移语句: if(ab) x=5; y=c+d; else x=c-d;36嵌入式控制系统-2ARM7指令系统

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 教学/培训

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号