嵌入式微处理器-arm指令集-课件.ppt
《嵌入式微处理器-arm指令集-课件.ppt》由会员分享,可在线阅读,更多相关《嵌入式微处理器-arm指令集-课件.ppt(75页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、1第五讲第五讲 ARM ARM指令集与编程指令集与编程2ARM 指令集的特点l向后兼容:新版本增加指令,并保持指令向后兼容;向后兼容:新版本增加指令,并保持指令向后兼容;lLoad-store Load-store 结构结构*uload/store load/store 从存储器中读某个值从存储器中读某个值,操作完后再将其放回存储操作完后再将其放回存储器中器中u只对存放在寄存器的数据进行处理;只对存放在寄存器的数据进行处理;u对于存储器中的数据,只能使用对于存储器中的数据,只能使用load/storeload/store指令进行存取指令进行存取3指令格式l指令格式指令格式u3 3 地址指令格式
2、地址指令格式 在在ARMARM状态中使用状态中使用u例例指令语法指令语法目标寄存器(目标寄存器(Rd)源寄存器源寄存器1(Rn)源寄存器源寄存器2(Rm)ADD r3,r1,r2r3r1r24ARM指令编码格式l说明说明lCondl指令执行的条件编码指令执行的条件编码lOpcodel指令操作符编码指令操作符编码lSl决定指令的操作是否影响决定指令的操作是否影响CPSR的值的值lRdl操作目标寄存器编码操作目标寄存器编码lRnl包含第一操作数的寄存器编码包含第一操作数的寄存器编码lShifter_operandl表示第二操作数表示第二操作数cond001opcodesRnRdShifter_op
3、erand 31 28 27 25 24 21 20 19 16 15 12 11 8 7 056ARM 指令分类l数据处理指令数据处理指令 使用和改变寄存器的值使用和改变寄存器的值l数据传送指令数据传送指令 把存储器的值拷贝到寄存器中把存储器的值拷贝到寄存器中 (load)or(load)or 把寄存器中的值拷贝到存储器中把寄存器中的值拷贝到存储器中(store)(store)l控制流指令控制流指令 分支分支分支和链接分支和链接,保存返回的地址保存返回的地址,以恢复最先的次序以恢复最先的次序l软件中断指令软件中断指令l程序状态寄存器指令程序状态寄存器指令l协处理器指令协处理器指令7数据处理指
4、令-1l数据处理指令的类别数据处理指令的类别u算术操作算术操作u按位逻辑操作按位逻辑操作u寄存器移位操作寄存器移位操作u比较操作比较操作l操作数操作数:32-bits:32-bits 宽宽;有有3 3种指定操作数的方式种指定操作数的方式u来自寄存器来自寄存器u第二操作数可以是常数第二操作数可以是常数(立即数立即数)u移位寄存器操作数移位寄存器操作数8数据处理指令-2ADD r0,r1,r2r0:=r1+r2ADC r0,r1,r2r0:=r1+r2+CSUB r0,r1,r2r0:=r1-r2SBC r0,r1,r2r0:=r1-r2+C-1RSB r0,r1,r2r0:=r2 r1RSC r
5、0,r1,r2r0:=r2 r1+C-1算术操作算术操作按位逻辑操作按位逻辑操作AND r0,r1,r2r0:=r1 and r2ORR r0,r1,r2r0:=r1 or r2EOR r0,r1,r2r0:=r1 xor r2BIC r0,r1,r2r0:=r1 and(not)r2寄存器移位寄存器移位MOV r0,r2r0:=r2MVN r0,r2r0:=not r2比较操作比较操作CMP r1,r2set cc on r1-r2CMN r1,r2set cc on r1+r2TST r1,r2set cc on r1 and r2TEQ r1,r2set cc on r1 xor r29
6、10桶形移位器的使用lPRE r0=8,r2=5lMOV r0,r2,LSL#2(逻辑左移两位:(逻辑左移两位:r20)x=1;CMP r0,#0MOVEQ r1,#0MOVGT r1,#1l使用条件比较指令使用条件比较指令if(a=4|a=10)x=0;CMP r0,#4CMPNE r0,#10MOVEQ r1,#019条件执行l所有的所有的ARM指令都可以指令都可以条条件件执行行l指令的指令的执行行与与否取否取决决于于CPSR寄存器的寄存器的N,Z,C and V标标志位志位lCondition Field in instructionl0000=EQ-Z set(equal)l0001=
7、NE-Z clear(not equal)l0010=CS-C set(unsigned higher or same)l0011=CC-C clear(unsigned lower)l0100=MI-N set(negative)l0101=PL-N clear(positive or zero)l0110=VS-V set(overflow)l0111=VC-V clear(no overflow)l1000=HI-C set and Z clear(unsigned higher)l1001=LS-C clear or Z set(unsigned lower or same)l1010
8、=GE-N set and V set,or N clear and V clear(greater or equal)l1011=LT-N set and V clear,or N clear and V set(less than)l1100=GT-Z clear,and either N set and V set,or N clear and V clear(greater than)l1101=LE-Z set,or N set and V clear,or N clear and V set(less than or equal)l1110=AL-alwaysl1111=NV-ne
9、ver20数据传送指令-1l单指令传送单指令传送 (LDR,STR)(LDR,STR)u单字单字(32bit),(32bit),半字半字(1(16 bit)6 bit)以及字节以及字节(8 bit)(8 bit)传送传送u寻址寻址u寄存器偏移寄存器偏移u地址地址 =基址基址 寄存器偏移寄存器偏移u立即数偏移立即数偏移u地址地址=基址基址 立即数常数立即数常数u后变址后变址Post-indexingPost-indexing:modify address after use:modify address after useu前变址前变址Pre-indexing:modify address be
10、fore usePre-indexing:modify address before useu回写回写u如果可能如果可能,更新基址寄存器更新基址寄存器21单寄存器传送指令LDR把一个字装入一个寄存器把一个字装入一个寄存器Rdmem32addressSTR从一个寄存器保存一个字或者一个字节从一个寄存器保存一个字或者一个字节Rdmem32addressLDRB把一个字节装入一个寄存器把一个字节装入一个寄存器Rdmem8addressSTRB从一个寄存器保存一个字节从一个寄存器保存一个字节Rdmem8addressLDRH把一个半字节装入一个寄存器把一个半字节装入一个寄存器Rdmem16addres
11、sSTRH从一个寄存器保存一个半字从一个寄存器保存一个半字Rdmem16addressLDRSB把一个有符号字节装入寄存器把一个有符号字节装入寄存器RdsignExtent(mem8address)STRSH把一个有符号半字装入寄存器把一个有符号半字装入寄存器RdsignExtent(mem16address)22寻址方式变址模式变址模式数据数据基址寄存器基址寄存器示例示例回写前变址回写前变址membase+offset基址寄存器加上偏基址寄存器加上偏移移LDR r0,r1,#4!前变址前变址membase+offset不变不变LDR r0,r1,#4后变址后变址membase基址寄存器加上偏
12、基址寄存器加上偏移移LDR r0,r1,#42324数据传送指令-2COPY:ADR r1,TABLE1;r1 points to TABLE1ADR r2,TABLE2;r2 points to TABLE2LOOP:LDR r0,r1STR r0,r2ADD r1,r1,#4ADD r2,r2,#4.TABLE1:.TABLE2:.COPY:ADR r1,TABLE1;r1 points to TABLE1ADR r2,TABLE2;r2 points to TABLE2LOOP:LDR r0,r1,#4STR r0,r2,#4.TABLE1:.TABLE2:.25多寄存器数据传送指令-L
13、DMl多数据传送指令多数据传送指令 (LDM,STM)(LDM,STM)uload(LDM)load(LDM)或或 store(STM)store(STM)当前可访问寄存器的任意子集当前可访问寄存器的任意子集u 使用使用u堆栈堆栈:maintaining full or empty stacks which can:maintaining full or empty stacks which can grow up or down memorygrow up or down memoryu上下文切换上下文切换:保存或重新存储工作寄存器保存或重新存储工作寄存器u块拷贝块拷贝:在主存储器中移动大数
14、据块在主存储器中移动大数据块26多寄存器数据传送指令的要点l多寄存器多寄存器Load/Store指令会增加中断的延迟,因为指令会增加中断的延迟,因为ARM不会打断不会打断正在执行的指令去响应中断,而必须等到指令执行完成;正在执行的指令去响应中断,而必须等到指令执行完成;l一般编译器将提供一个选项以控制一般编译器将提供一个选项以控制Load/Store指令可以传送的最指令可以传送的最大寄存器数目,以限制最大中断延迟。大寄存器数目,以限制最大中断延迟。2728例子要求:保存要求:保存r1r3到内存地址到内存地址0 x90000 x900c,并且更新基,并且更新基址寄存器址寄存器r4PRE:r1=0
15、 x00000001,r2=0 x00000002,r3=0 x00000003,r4=0 x9000执行操作:执行操作:STMIA r4!,r1,r2,r3(执行后增加执行后增加)POST:mem320 x9000=0 x00000001 mem320 x9004=0 x00000002 mem320 x9008=0 x00000003 r4=0 x900c29多寄存器传送寻址模式r5r1r9r0r9STMIA r9!,r0,r1,r5100016100c16101816r1r5r9STMDA r9!,r0,r1,r5r0r9100016100c16101816r5r9STMDB r9!,r
16、0,r1,r5r1r0r9100016100c16101816r5r1r0r9r9STMIB r9!,r0,r1,r5100016100c161018163031例2:完成一个存储器数据块拷贝l注:注:r9存放源数据的起始地址存放源数据的起始地址 r10存放目标起始地址存放目标起始地址 r11存放源结束地址存放源结束地址 loop LDMIA r9!,r0-r7 ;装载装载32字节并更新字节并更新r9指针指针 STMIA r10!,r0-r7 ;存储存储32字节并更新字节并更新r10指针指针 CMP r9,r11 ;是否到达结束地址是否到达结束地址 BNE loop ;不相等跳转不相等跳转目的
17、目的源源高地址低地址拷贝存储地址r9r11r1032堆栈操作lARM使用多寄存器使用多寄存器Load/Store指令来完成堆栈操作;指令来完成堆栈操作;l使用堆栈时,需要确定堆栈在存储空间中是向上生长使用堆栈时,需要确定堆栈在存储空间中是向上生长(递增的(递增的“A”)还是向下生长(递减的)还是向下生长(递减的“D”););l满堆栈(满堆栈(“F”)是指堆栈指针指向堆栈的最后一个已)是指堆栈指针指向堆栈的最后一个已使用的地址或满位置;相反,空堆栈(使用的地址或满位置;相反,空堆栈(“E”)是指)是指SP指向堆栈的第一个没有使用的地址或空位置;指向堆栈的第一个没有使用的地址或空位置;33堆栈操作
18、寻址方式寻址方式寻址方式说明说明pop=LDMpush=STMFA递增满递增满LDMFALDMDASTMFASTMIBFD递减满递减满LDMFDLDMIASTMFDSTMDBEA递增空递增空LDMEALDMDBSTMEASTMIAED递减空递减空LDMEDLDMIBSTMEDSTMDA34LDMFD sp!,r4-r7,pcSP100FF1234AOBE80341010123484209753r41r5 14544r60r712lr9048pc9020r4100100FFr5FF1234r61234A0BEr7A0BE8034pc8034堆栈r4100r5FFr61234r7A0BElr803
19、4ABCD8765102E16FFFF1010123484209753存储器顶存储器顶SPSP100FF1234A0BE8034SPOld SP100FF1234A0BE8034lARM堆栈操作通过块传送指令来完成堆栈操作通过块传送指令来完成:STMFD(Push)块存储块存储-Full Descending stack STMDBLDMFD(Pop)块装载块装载-Full Descending stack LDMIASTMFD sp!,r4-r7,lr35例:把寄存器内容放入堆栈,更新sp0 x800180 x000000010 x800140 x000000020 x80010Empty0
20、 x8000cEmpty0 x800180 x000000010 x800140 x000000020 x800100 x000000030 x8000c0 x00000002PRE 地址 数据POST 地址 数据SPSPPRE:r1=0 x00000002,r4=0 x00000003,sp=0 x00080014执行指令:执行指令:STMFD sp!,r1,r4POST:r1=0 x00000002,r4=0 x00000003,sp=0 x0008000c36单数据交换指令-SWAPl单数据交换单数据交换 (SWAP)(SWAP)u在寄存器和外部存储器之间交换字节或字在寄存器和外部存储器
21、之间交换字节或字u读存储器和写存储器是是放在一起的读存储器和写存储器是是放在一起的u原子指令原子指令u执行时不能中断执行时不能中断37l在寄存器和存储器之间,由一次存储器读和一次存储器写组成的原子操作。完成在寄存器和存储器之间,由一次存储器读和一次存储器写组成的原子操作。完成一个字节或字的交换。一个字节或字的交换。l语法:语法:l SWPB Rd,Rm,Rnl可用作信号量可用作信号量l不能由不能由armcc编译产生,必须使用汇编器。编译产生,必须使用汇编器。RmRd321temp存储器存储器RnSWP38SWAP指令的用法lPRE mem320 x9000=0 x12345678,r0=0 x
22、00000000,r1=0 x11112222,r2=0 x00009000执行操作:执行操作:SWP r0,r1,r2lPOST:mem320 x9000=0 x11112222,r0=0 x12345678,r1=0 x11112222,r2=0 x00009000l交换指令多用于实现操作系统中的信号量和互斥操作,该指令有交换指令多用于实现操作系统中的信号量和互斥操作,该指令有修饰符修饰符B,即有字交换和字节交换两种形式;,即有字交换和字节交换两种形式;39程序状态寄存器访问指令l程序状态寄存器访问指令程序状态寄存器访问指令(MRS,MSR)(MRS,MSR)lMRS MRS 程序状态寄存
23、器到通用寄存器的数据传送指令程序状态寄存器到通用寄存器的数据传送指令lMSR MSR 通用寄存器到程序状态寄存器的数据传送指令通用寄存器到程序状态寄存器的数据传送指令40常量的装载lARM指令不用于将一个指令不用于将一个32位的常量装入寄存器,因为位的常量装入寄存器,因为ARM本身是本身是32位的,所以指令中不可能再定义一个普通的位的,所以指令中不可能再定义一个普通的32位常量;位常量;lARM增加了增加了2条伪指令,把条伪指令,把32位常量送入寄存器:位常量送入寄存器:l例:例:LDR Rd,=constant ;LDR常量装载伪指令常量装载伪指令 ADR Rd,Label ;ADR地址装载
24、伪指令地址装载伪指令41l为允许装载大常数,汇编器提供了一条伪指令为允许装载大常数,汇编器提供了一条伪指令:lLDR rd,=constl它可能汇编成下列指令:它可能汇编成下列指令:lMOV or MVN。或或lLDR 指令,从数据池(指令,从数据池(Literal pools)读取常数。)读取常数。lFor examplelLDR r0,=0 xFF=MOV r0,#0 xFFlLDR r0,=0 x55555555=LDR r0,PC,#Imm12DCD 0 x55555555l推荐使用这种方法把常数装入寄存器推荐使用这种方法把常数装入寄存器。装载32 bit常数42015310ADDS
25、r2,r2,#1ADD r2,#132-bit ARM 指令16-bit Thumb 指令关于Thumb指令集lThumb 是是16-bit 指令集指令集l代码密度优化代码密度优化(总代码大小约为(总代码大小约为ARM指令的指令的65%)l使用窄总线存储器时可以大大提高性能。使用窄总线存储器时可以大大提高性能。l是是 ARM 指令集的一个子集。指令集的一个子集。l核存在一个执行状态核存在一个执行状态 Thumb状态状态lARM和和Thumb之间切换使用之间切换使用BX 指令指令43ARM汇编程序设计汇编程序设计44符号定义伪指令数据定义伪指令汇编控制伪指令信息报告伪指令宏指令以及其他伪指令。伪
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 嵌入式 微处理器 arm 指令 课件
限制150内