欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    嵌入式系统开发与应用教程.pptx

    • 资源ID:80034229       资源大小:2.59MB        全文页数:121页
    • 资源格式: PPTX        下载积分:20金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要20金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    嵌入式系统开发与应用教程.pptx

    会计学1嵌入式系统开发与应用教程嵌入式系统开发与应用教程1.1.ARM指令集概述;2.2.ARM寻址方式;3.3.数据处理指令、Load/Store指令;4.4.寄存器传送指令、转移指令、异常中断产生指令;5.5.ARM系统初始化6.6.Embest IDE集成开发环境、实验系统介绍;7.7.基于ARM的嵌入式软件开发基础:ARM汇编指令实验及C语言程序实验。第1页/共121页指令长度指令长度n n指令集可以是以下任一种n n32 bits 32 bits 长长 (ARM(ARM状态状态)n n16 bits 16 bits 长长 (Thumb(Thumb 状态状态)n nARM7TDMI 支持3种数据类型n n字节字节 (8-bit)(8-bit)n n半字半字 (16-bit)16-bit)n n字字 (32-bit)(32-bit)n n字必须被排成4个字节边界对齐,半字必须被排列成2个字节边界对齐 第2页/共121页一、一、ARM指令集概述指令集概述n nARMARM指指令令集集是是3232位位的的,ARMARM汇汇编编程程序序的的启启动动都都是是从从ARMARM指指令令集集开开始始。所所有有的的ARMARM指指令令集集都都可可以以是是有有条条件件执执行行的的。本本节节从以下三个方面介绍:从以下三个方面介绍:指令分类及指令格式 指令集编码 条件执行第3页/共121页指令分类及指令格式指令分类及指令格式FF ARM指令集可以分为六大类,分别为数据处理指令、Load/Store指令、跳转指令、程序状态寄存器处理指令、协处理器指令和异常产生指令。FF ARM指令使用的基本格式如下:opcodeopcode condcond S S RdRd,RnRn,operand2operand2 第4页/共121页ARM指令集指令集编码编码FFARMARM指指令令集集是是以以3232位位二二进进制制编编码码的的方方式式给给出出的的,大大部部分分的的指指令令编编码码中中定定义义了了第第一一操操作作数数、第第二二操操作作数数、目目的的操操作作数数、条条件件标标志志影影响响位位以以及及每每条条指指令令所所对对应应的的不同功能实现的二进制位。不同功能实现的二进制位。FF每每条条3232位位ARMARM指指令令都都具具有有不不同同的的二二进进制制编码方式,和不同的指令功能相对应编码方式,和不同的指令功能相对应 。FF编码表如下编码表如下:第5页/共121页指令集编码表指令集编码表第6页/共121页条件执行条件执行FFARMARM指指令令根根据据CPSRCPSR中中的的条条件件位位自自动动判判断断是是否否执执行行指指令令,在在条条件件满满足足时时,指令执行,否则指令被忽略。指令执行,否则指令被忽略。FF在在ARMARM的的指指令令编编码码表表中中,统统一一占占用用编编码码的的最最高高四四位位3131:2828来来表表示示“条条件件码码”(即(即“condcond”)。)。(P100页)第7页/共121页条件域表条件域表1条件码后缀标 志含 义0000EQZ置位相等0001NEZ清零不相等0010CSC置位无符号数大于或等于0011CCC清零无符号数小于0100MIN置位负数0101PLN清零正数或零0110VSV置位溢出0111VCV清零未溢出 1000 HIC置位Z清零无符号数高于第8页/共121页条件域表条件域表2条件码后缀标 志含 义1001LSC清零Z置位无符号数小于或等于1010GEN等于V带符号数大于或等于1011LTN不等于V带符号数小于1100GTZ清零且(N等于V)带符号数大于1101LEZ置位或(N不等于V)带符号数小于或等于1110AL总是无条件执行第9页/共121页 二、二、ARMARM寻址方式寻址方式ARMARM指令系统支持如下几种常见的指令系统支持如下几种常见的寻址方式:寻址方式:FF立即寻址立即寻址FF寄存器寻址寄存器寻址FF寄存器间接寻址寄存器间接寻址FF基址加偏址寻址基址加偏址寻址 FF堆栈寻址堆栈寻址 FF块拷贝寻址块拷贝寻址 FF相对寻址相对寻址 第10页/共121页立即寻址立即寻址F立立即即寻寻址址也也叫叫立立即即数数寻寻址址,这这是是一一种种特特殊殊的的寻寻址址方方式式,操操作作数数本本身身就就在在指指令令中中给给出出,只只要要取取出出指指令令也也就就取取到到了了操操作作数数,这这个个操操作作数数被被称称为为立立即即数数,对对应应的的寻寻址址方方式也就叫做立即寻址。例如以下指令:式也就叫做立即寻址。例如以下指令:ADDADDR0R0,R0R0,1 1/*R0R0/*R0R01*/1*/AND ANDR0R0,R0R0,0 x3f0 x3f /*R0R0/*R0R0 AND 0 x3f*/AND 0 x3f*/F 在在以以上上两两条条指指令令中中,第第二二个个源源操操作作数数即即为为立立即即数数,要要求求以以“”为为前前缀缀,对对于于以以十十六六进进制制表表示示的的立立即即数数,还要求在还要求在“”后加上后加上“0 x0 x”。第11页/共121页注:注:注:注:有效立即数问题有效立即数问题有效立即数问题有效立即数问题 在在3232位指令编码中存放位指令编码中存放3232位立即数的方法是:位立即数的方法是:在在ARMARM数据处理指令中,当参与操作的第二操作数为立数据处理指令中,当参与操作的第二操作数为立即数型时,每个立即数都是采用一个即数型时,每个立即数都是采用一个8 8位的常数循环右移位的常数循环右移偶数位而间接得到。其中循环右移的位数由一个偶数位而间接得到。其中循环右移的位数由一个4 4位二进位二进制的两倍表示,制的两倍表示,如果立即数记作如果立即数记作,8 8位常数位常数记作记作immed_8immed_8,4 4位的循环右移值记作位的循环右移值记作rotate_immrotate_imm,有效,有效的立即数是由一个的立即数是由一个8 8位的立即数循环右移偶数位得到。位的立即数循环右移偶数位得到。因此有效立即数因此有效立即数immediateimmediateimmediateimmediate可以表示成:可以表示成:=immed_8=immed_8=immed_8=immed_8循环右移(循环右移(循环右移(循环右移(2rotate_imm2rotate_imm2rotate_imm2rotate_imm)第12页/共121页例:例:MOV R0,#0 x0000F200MOV R0,#0 x00012800MOV R0,#0 x00041400MOV R0,#0 x00041800MOV R0,#0 xF000000F第13页/共121页寄存器寻址寄存器寻址就是利用寄存器中的数值作为操作数,这寄存器寻址就是利用寄存器中的数值作为操作数,这寄存器寻址就是利用寄存器中的数值作为操作数,这寄存器寻址就是利用寄存器中的数值作为操作数,这种寻址方式是各类微处理器经常采用的一种方式,也种寻址方式是各类微处理器经常采用的一种方式,也种寻址方式是各类微处理器经常采用的一种方式,也种寻址方式是各类微处理器经常采用的一种方式,也是一种执行效率较高的寻址方式。以下指令:是一种执行效率较高的寻址方式。以下指令:是一种执行效率较高的寻址方式。以下指令:是一种执行效率较高的寻址方式。以下指令:ADDADD R0R0,R1R1,R2R2/*R0R1/*R0R1R2*/R2*/该指令的执行效果是将寄存器该指令的执行效果是将寄存器该指令的执行效果是将寄存器该指令的执行效果是将寄存器R1R1R1R1和和和和R2R2R2R2的内容相加,其的内容相加,其的内容相加,其的内容相加,其结果存放在寄存器结果存放在寄存器结果存放在寄存器结果存放在寄存器R0R0R0R0中中中中。第14页/共121页寄存器寻址FF第二操作数为寄存器型的移位操作第二操作数为寄存器型的移位操作第二操作数为寄存器型的移位操作第二操作数为寄存器型的移位操作 在在ARMARM指令的数据处理指令中参与操作的第二操作数指令的数据处理指令中参与操作的第二操作数为寄存器型时,在执行寄存器寻址操作时,可以选择是为寄存器型时,在执行寄存器寻址操作时,可以选择是否对第二操作数进行移位,即否对第二操作数进行移位,即RmRm,其中,其中RmRm称称为第二操作数寄存器,为第二操作数寄存器,用来指定移位类型(用来指定移位类型(LSLLSL,LSRLSR,ASLASL,ASRASR,RORROR或或RRXRRX)和移位位数。移位位数可)和移位位数。移位位数可以是以是5 5位立即数(位立即数(#)或寄存器()或寄存器(RsRs)。在指令)。在指令执行时将移位后的内容作为第二操作数参与运算。例如执行时将移位后的内容作为第二操作数参与运算。例如指令:指令:n nADD R3ADD R3,R2R2,R1R1,LSR#2 LSR#2 ;R3R3R2+R14R2+R14第15页/共121页寄存器寻址寄存器寻址FF第二操作数移位方式第二操作数移位方式 LSLLSL:逻辑左移,空出的最低有效位用:逻辑左移,空出的最低有效位用0 0填充。填充。LSRLSR:逻辑右移,空出的最高有效位用:逻辑右移,空出的最高有效位用0 0填充。填充。ASLASL:算术左移,由于左移空出的有效位用:算术左移,由于左移空出的有效位用0 0填充,因此填充,因此 它与它与LSLLSL同义。同义。ASRASR:算术右移,算术移位的对象是带符号数,移位过程中必须保:算术右移,算术移位的对象是带符号数,移位过程中必须保持操作数的符号不变。如果源操作数是正数,空出的最持操作数的符号不变。如果源操作数是正数,空出的最高有效位用高有效位用0 0填充,如果是负数用填充,如果是负数用1 1填充。填充。RORROR:循环右移,移出的字的最低有效位依次填入空出的最高有效:循环右移,移出的字的最低有效位依次填入空出的最高有效位。位。RRXRRX:带扩展的循环右移。将寄存器的内容循环右移:带扩展的循环右移。将寄存器的内容循环右移1 1位,空位用位,空位用原来原来C C标志位填充。标志位填充。第16页/共121页寄存器寻址寄存器寻址第17页/共121页寄存器寻址寄存器寻址FF第二操作数的移位位数第二操作数的移位位数第二操作数的移位位数第二操作数的移位位数 移位位数可以用立即数方式或者寄存器方式给出移位位数可以用立即数方式或者寄存器方式给出,如下如下所示:所示:n nADD R3ADD R3,R2R2,R1R1,LSR#2LSR#2;R3 R3 R2+R14R2+R14n nADD R3ADD R3,R2R2,R1R1,LSR R4LSR R4;R3 R3 R2+R12R2+R12R4R4寄存器寄存器R1R1的内容分别逻辑右移的内容分别逻辑右移2 2位、位、R4R4位(亦即位(亦即R14R14、R12R12R4R4),再与寄存器),再与寄存器R2R2的内容相加,结果放入的内容相加,结果放入R3R3中。中。第18页/共121页寄存器间接寻址寄存器间接寻址FF 寄存器间接寻址就是以寄存器中的值作为操作寄存器间接寻址就是以寄存器中的值作为操作数的地址,而操作数本身存放在存储器中。例如以数的地址,而操作数本身存放在存储器中。例如以下指令:下指令:n n LDRLDRR0R0,R1R1/*R0R1*/*R0R1*/n n STR STRR0R0,R1R1/*R1R0*/*R1R0*/第第一一条条指指令令将将以以R1R1的的值值为为地地址址的的存存储储器器中中的的数数据据传传送送到到R0R0中中。第第二二条条指指令令将将R0R0的的值值传传送送到到以以R1R1的的值为地址的存储器中。值为地址的存储器中。第19页/共121页基址加偏址寻址基址加偏址寻址 基址变址寻址就是将寄存器(该寄存器一般称作基址变址寻址就是将寄存器(该寄存器一般称作基址寄存器)的内容与指令中给出的地址偏移量相加,基址寄存器)的内容与指令中给出的地址偏移量相加,从而得到一个操作数的有效地址。变址寻址方式常用从而得到一个操作数的有效地址。变址寻址方式常用于访问某基地址附近的地址单元。采用变址寻址方式于访问某基地址附近的地址单元。采用变址寻址方式的指令又可以分为以下几种形式:的指令又可以分为以下几种形式:前变址模式前变址模式前变址模式前变址模式:n nLDR R0LDR R0,R1R1,44;R0R1R0R144自动变址模式自动变址模式自动变址模式自动变址模式:n nLDR R0LDR R0,R1R1,44!;R0R1R0R144、R1R1R1R14 4后变址模式后变址模式后变址模式后变址模式:n nLDR R0LDR R0,R1 R1,4 4;R0R1R0R1、R1R1R1R14 4第20页/共121页基址加偏址寻址基址加偏址寻址基基址址寄寄存存器器的的地地址址偏偏移移可可以以是是一一个个立立即即数数,也也可可以以是是另另一一个个寄寄存存器器,并且在加到基址寄存器前还可以经过移位操作,如下所示:并且在加到基址寄存器前还可以经过移位操作,如下所示:n nLDRLDR r0 r0,r1r1,r2r2;r0r0memmem3232r1+r2r1+r2n nLDR r0LDR r0,r1r1,r2r2,LSL#2LSL#2;r0r0r1+r2*4r1+r2*4n n但但常常用用的的是是立立即即数数偏偏移移的的形形式式,地地址址偏偏移移为为寄寄存存器器形形式式的的指指令令很很少少使用。使用。第21页/共121页堆栈寻址堆栈寻址FF堆堆栈栈是是一一种种数数据据结结构构,按按先先进进后后出出(First First In In Last Last OutOut,FILOFILO)的的方方式式工工作作,使使用用一一个个称称作作堆堆栈栈指指针针的的专专用用寄寄存存器器指指示示当当前前的的操操作作位位置置,堆堆栈栈指针总是指向栈顶。指针总是指向栈顶。FF当堆栈指针指向最后压入堆栈的数据时,称为满当堆栈指针指向最后压入堆栈的数据时,称为满堆栈(堆栈(Full StackFull Stack),而当堆栈指针指向下一个),而当堆栈指针指向下一个将要放入数据的空位置时,称为空堆栈(将要放入数据的空位置时,称为空堆栈(Empty Empty StackStack)。)。FF即访问存储器时,存储器的地址向高地址方向生即访问存储器时,存储器的地址向高地址方向生长,称为递增堆栈(长,称为递增堆栈(ascending stackascending stack)。)。存储存储器的地址向低地址方向生长,称为递减堆栈器的地址向低地址方向生长,称为递减堆栈(descending stackdescending stack)。)。第22页/共121页堆栈寻址堆栈寻址四种类型的堆栈工作方式四种类型的堆栈工作方式 FF满满递递增增堆堆栈栈:堆堆栈栈指指针针指指向向最最后后压压入入的的数数据据,且且由由低低地地址址向向高高地地址址生生成。成。FF满满递递减减堆堆栈栈:堆堆栈栈指指针针指指向向最最后后压压入入的的数数据据,且且由由高高地地址址向向低低地地址址生生成。成。FF空空递递增增堆堆栈栈:堆堆栈栈指指针针指指向向下下一一个个将将要要放放入入数数据据的的空空位位置置,且且由由低低地地址向高地址生成。址向高地址生成。FF空空递递减减堆堆栈栈:堆堆栈栈指指针针指指向向下下一一个个将将要要放放入入数数据据的的空空位位置置,且且由由高高地地址向低地址生成址向低地址生成n n STMFD SP!,R1-R7,LR 满递减满递减n nLDMFD SP!,R1-R7,LR 第23页/共121页块拷贝寻址块拷贝寻址FF块块拷拷贝贝寻寻址址是是多多寄寄存存器器传传送送指指令令LDM/STMLDM/STM的的寻寻址址方方式式。LDM/STMLDM/STM指指令令可可以以把把存存储储器器中中的的一一个个数数据据块块加加载载到到多多个个寄寄存存器器中中,也也可可以以把把多多个个寄寄存存器器中中的的内内容容保保存存到到存存储储器器中中。寻寻址址操操作作中中的的寄寄存存器器可可以以是是R0-R15R0-R15这这1616个个寄寄存存器器的的子子集集或或是是所所有有寄存器。寄存器。FFLDM/STMLDM/STM指指令令依依据据其其后后缀缀名名的的不不同同其其寻寻址址的的方方式式也有很大不同,见下表。也有很大不同,见下表。第24页/共121页第25页/共121页例:例:STMIA R0!,R2-R9STMDB R1!,R2-R9LDMIB R0,R2-R9第26页/共121页相对寻址相对寻址 FF 与与基基址址变变址址寻寻址址方方式式相相类类似似,相相对对寻寻址址以以程程序序计计数数器器PCPC的的当当前前值值为为基基地地址址,指指令令中中的的地地址址标标号号作作为为偏偏移移量量,将将两两者者相相加加之之后后得得到到操操作作数数的的有有效效地地址址。以以下下程程序序段段完完成成子子程程序序的的调调用用和和返返回回,跳跳转转指指令令BLBL采采用用了了相对寻址方式:相对寻址方式:n nBLBLNEXTNEXT;跳转到子程序;跳转到子程序n n ;NEXTNEXT处执行处执行n nn nNEXTNEXT:n nn nMOVMOVPCPC,LRLR;从子程序返回;从子程序返回 第27页/共121页三、三、ARMARM指令详细介绍指令详细介绍 ARMARM指令集总体分为以下指令集总体分为以下6 6类:类:FF 数据处理指令;FF Load/Store指令;FF转移指令;FF程序状态寄存器与通用寄存器之间的传送指令;FF异常中断指令;FF 协处理器指令。第28页/共121页、数据处理指令、数据处理指令FF ARMARM的数据处理指令主要完成寄存器中数据的的数据处理指令主要完成寄存器中数据的算术和逻辑运算操作。算术和逻辑运算操作。n n本节按以下内容组织:本节按以下内容组织:数据处理指令分类数据处理指令分类 数据处理指令二进制编码数据处理指令二进制编码 数据处理指令表数据处理指令表第29页/共121页数据处理指令数据处理指令分类分类分类分类FF 数据处理指令根据指令实现处理功能可分为数据处理指令根据指令实现处理功能可分为以下六类:以下六类:数据传送指令;数据传送指令;算术运算指令算术运算指令;逻辑运算指令;逻辑运算指令;比较指令;比较指令;测试指令;测试指令;乘法指令。乘法指令。第30页/共121页数据处理指令数据处理指令FFARMARM数据处理指令的基本原则为数据处理指令的基本原则为 :所有的操作数都是所有的操作数都是3232位宽,或来自寄存器,或位宽,或来自寄存器,或是在指令中定义的立即数(符号或是在指令中定义的立即数(符号或0 0扩展);扩展);如果数据操作有结果,则结果为如果数据操作有结果,则结果为3232位宽,放在位宽,放在一个寄存器中。(有一个例外:长乘指令产生一个寄存器中。(有一个例外:长乘指令产生6464位的结果);位的结果);ARMARM指令中使用指令中使用“3 3地址模式地址模式”,即每一个操作,即每一个操作数寄存器和结果寄存器在指令中分别指定。数寄存器和结果寄存器在指令中分别指定。第31页/共121页数据处理指令数据处理指令汇编格式汇编格式汇编格式汇编格式FFARMARM数据处理指令使用两个源操作数和一个目的数据处理指令使用两个源操作数和一个目的寄存器(寄存器(RdRd)的)的“3 3地址模式地址模式”,一个源操作数,一个源操作数(RnRn)总是寄存器,第二个被称为)总是寄存器,第二个被称为“灵活的第二灵活的第二操作数操作数operand2operand2”,它可以是寄存器、移位后的寄,它可以是寄存器、移位后的寄存器或立即数。如果第二操作数是寄存器存器或立即数。如果第二操作数是寄存器RmRm,它,它的移位类型可以是的移位类型可以是LSLLSL,LSRLSR,ASLASL,ASRASR,RORROR或或RRXRRX中的任意一种中的任意一种 ;移位的位数可以是立;移位的位数可以是立即数,也可以是寄存器的内容。即数,也可以是寄存器的内容。FF汇编格式汇编格式汇编格式汇编格式 n n S Rd S Rd,RnRn,#32#n n S Rd S Rd,RnRn,RmRm,第32页/共121页数据处理指令数据处理指令指令表指令表指令表指令表n n数据处理指令的详细列表如下:数据处理指令的详细列表如下:操作码24:21助记符意义效果0000AND逻辑位与Rd=Rn AND Op20001EOR逻辑位异或Rd=Rn EOR Op20010SUB减Rd=Rn-Op20011RSB反向减Rd=Op2 Rn0100ADD加Rd=Rn+Op20101ADC带进位加Rd=Rn+Op2+C0110SBC带进位减Rd=Rn-Op2+C-10111RSC反向带进位减Rd=Op2-Rn+C-11000TST测试根据Rn AND Op2设置条件码1001TEQ测试相等根据Rn EOR Op2设置条件1010CMP比较根据Rn-Op2设置条件码1011CMN负数比较根据Rn+Op2设置条件码1100ORR逻辑位或Rd=Rn OR Op21101MOV传送Rd=Op21110BIC位清零Rd=Rn AND NOT Op21111MVN求反Rd=NOT Op2第33页/共121页算术运算指令:算术运算指令:n nADDn nADCn nSUBn nSBCn nRSBn nRSC第34页/共121页加法:Rd=Rn+Op2ADDR0,R1,R2ADDR0,R1,#256ADDR0,R2,R3,LSL#1ADDSR4,R1,R2ADC指令在形式上和功能上都有与ADD类似,只是相加时还要包括进位标志C的内容:Rd=Rn+Op2+CADC R5,R1,R3第35页/共121页减法:减法:Rd=Rn-Op2Rd=Rn-Op2SUBSUBR0,R1,R2R0,R1,R2SUBSUBR0,R1,#256R0,R1,#256SUBSUBR0,R1,R2,LSL#1R0,R1,R2,LSL#1SUBSSUBS R3,R6,R9R3,R6,R9带借位减:带借位减:Rd=Rn-Op2+C-1Rd=Rn-Op2+C-1SBCSSBCS R4,R7,R10R4,R7,R10SBCSBCR5,R8,R11R5,R8,R11第36页/共121页反减:反减:Rd=Op2-RnRSBR0,R1,R2RSBR0,R1,#256RSBR0,R2,R3,LSL#1反向带借位减:Rd=Op2-Rn+C-1RSCR0,R1,R2第37页/共121页例:ADDR2,R1,R3SUBSR8,R6,#240RSBR4,R4,#0 x1280ADCHIR11,R0,R3RSCLESR0,R5,R0,LSL R4第38页/共121页逻辑运算指令:逻辑运算指令:ANDORREORBIC:Rd=Rn AND NOT Op2第39页/共121页例:例:ANDR9,R2,#0 xFF00ORREQR2,R0,R5EORR0,R0,R3,ROR R6BICNESR0,R5,R0,LSL R4第40页/共121页数据传送指令:数据传送指令:MOV:Rd=Op2MVN:Rd=NOT Op2MOVR9,R2MVNNE R0,#0 xFF00MOVSR0,R0,ROR R6第41页/共121页比较指令:比较指令:CMP:根据Rn-Op2设置条件码CMN:根据Rn+Op2设置条件码CMPGTR3,R7,LSL#2CMNR0,#0 x6400第42页/共121页测试指令:测试指令:TST:根据Rn AND Op2设置条件码TEQ:根据Rn EOR Op2设置条件码TSTR0,#0 x3F8TEQEQR10,R9TSTNER1,R5,ASR R1第43页/共121页注:注:FFRSBRSB是反减,即用第二操作数减去源操作数。由是反减,即用第二操作数减去源操作数。由于第二操作数可选的范围宽,所以这条指令很有于第二操作数可选的范围宽,所以这条指令很有用。用。FFRSCRSC是带进位标志的反减。若进位标志为零,则是带进位标志的反减。若进位标志为零,则结果减结果减1 1。FFBICBIC用于将源操作数的各位与第二操作数中相应用于将源操作数的各位与第二操作数中相应位的反码进行位的反码进行“与与”操作。操作。BICBIC可用于将寄存器可用于将寄存器中某些位的值设置为中某些位的值设置为0 0。FFMVNMVN是是“取反传送取反传送”,它是把第二操作数的每一,它是把第二操作数的每一位取反,将得到的值置入结果寄存器。位取反,将得到的值置入结果寄存器。FFCMNCMN表示表示“取反比较取反比较”,将目的操作数和源操作,将目的操作数和源操作数相加,根据结果更新条件码标志。数相加,根据结果更新条件码标志。第44页/共121页数据处理指令数据处理指令二进制编码二进制编码二进制编码二进制编码n n数据处理指令的二进制编码如下:数据处理指令的二进制编码如下:第二操作数为立即数以寄存器表示移位位数以立即数表示移位位数第45页/共121页*乘法指令 ARMARM乘乘法法指指令令完完成成两两个个寄寄存存器器中中数数据据的的乘乘法法。按按产产生生结结果果的的位位宽宽一一般般分分为为两两类类:一一类类是是两两个个3232位位二二进进制制数数相相乘乘的的结结果果是是6464位位,另另一一类类是是两两个个3232位位二二进进制制数数相相乘乘,仅仅保保留留最最低低有有效效3232位位。这这两两种种类类型型都都有有“乘法累加乘法累加”的变的变形形,如下表所示:,如下表所示:操作码23:21助记符意义效果000MUL乘(32位结果)Rd(RmRs)31:0001MLA乘累加(32位结果)Rd(RmRs+Rn)31:0100UMULL无符号数长乘RdHi:RdLoRmRs101UMLAL无符号长乘累加RdHi:RdLo+=RmRs110SMULL有符号数长乘RdHi:RdLoRmRs111SMLAL有符号数长乘累加RdHi:RdLo+=RmRs第46页/共121页乘法乘法指令指令二进制编码二进制编码二进制编码二进制编码FF二进制编码二进制编码二进制编码二进制编码 FF说明说明说明说明对于对于3232位乘积结果指令,位乘积结果指令,RdRd为结果寄存器,为结果寄存器,RmRm、RsRs、RnRn为操作数寄存器。为操作数寄存器。对于对于6464位乘积结果指令,位乘积结果指令,RdLoRdLo、RdHiRdHi为结果寄存器,为结果寄存器,“RdHi:RdLoRdHi:RdLo”是由是由RdHiRdHi(最高有效(最高有效3232位)和位)和RdLoRdLo(最低(最低有效有效3232位)连接形成位)连接形成6464位乘积结果,位乘积结果,RmRm、RsRs为操作数寄为操作数寄存器。存器。第47页/共121页乘法指令乘法指令汇编格式汇编格式汇编格式汇编格式FF产生最低有效产生最低有效产生最低有效产生最低有效32323232位乘积的指令:位乘积的指令:位乘积的指令:位乘积的指令:n nMULS RdMULS Rd,RmRm,RsRsn nMULAS RdMULAS Rd,RmRm,RsRs,RnRnFF产生产生产生产生64646464位乘积的指令位乘积的指令位乘积的指令位乘积的指令:S RdHiS RdHi,RdLoRdLo,RmRm,RsRsn n在此在此是是6464位乘法类型(位乘法类型(UMULLUMULL、UMLALUMLAL、SMULLSMULL、SMLALSMLAL)。)。第48页/共121页、Load/StoreLoad/Store指令指令 FFARMARM处处理理器器是是Load/storeLoad/store型型的的,即即它它对对数数据据的的操操作作是是通通过过将将数数据据从从存存储储器器加加载载到到片片内内寄寄存存器器中中进进行行处处理理,处处理理完完成成后后的的结结果果经经过过寄寄存存器器存存回回到到存存储储器器中中,以加快对片外存储器进行数据处理的执行速度。以加快对片外存储器进行数据处理的执行速度。FFARMARM的的数数据据存存取取指指令令Load/StoreLoad/Store是是唯唯一一用用于于寄寄存存器和存储器之间进行数据传送的指令。器和存储器之间进行数据传送的指令。FFARMARM指令集中有三种基本的数据存取指令:指令集中有三种基本的数据存取指令:单寄存器的存取指令(单寄存器的存取指令(LDRLDR,STRSTR)多寄存器存取指令(多寄存器存取指令(LDMLDM,STMSTM)单寄存器交换指令(单寄存器交换指令(SWPSWP)第49页/共121页单寄存器的存取指令单寄存器的存取指令 单个寄存器存取指令又可以针对以下几类数据:单个寄存器存取指令又可以针对以下几类数据:单字单字 无符号半字、有符号半字无符号半字、有符号半字 无符号字节、有符号字节无符号字节、有符号字节第50页/共121页 单字:单字:n nLDR从内存中取32位字数据放入寄存器,STR将寄存器中的32位字数据保存到内存中。第51页/共121页字节:字节:n nLDR从内存中取8位字节数据放入寄存器,STR将寄存器中的8位字节数据保存到内存中。无符号字节:用“0”将8位的操作数扩展到32位有符号字节:用符号位将8位的操作数扩展到32位第52页/共121页半字:半字:n nLDR从内存中取半字数据放入寄存器,STR将寄存器中的半字数据保存到内存中。无符号半字:用“0”将16位的操作数扩展到32位有符号半字:用符号位将16位的操作数扩展到32位第53页/共121页汇编格式汇编格式汇编格式汇编格式n n这一类数据传送指令的汇编格式如下 前变址格式LDR|STR B|SB|H|SH RdLDR|STR B|SB|H|SH RdLDR|STR B|SB|H|SH RdLDR|STR B|SB|H|SH Rd,RnRnRnRn,!后变址格式LDR|STR B|SB|H|SH T RdLDR|STR B|SB|H|SH T RdLDR|STR B|SB|H|SH T RdLDR|STR B|SB|H|SH T Rd,RnRnRnRn,相对PC的形式LDR|STR B RdLDR|STR B RdLDR|STR B RdLDR|STR B Rd,LABEL LABEL LABEL LABEL 式中式中是是#8#或或#Rm#Rm;第54页/共121页例:例:LDRR8,R10LDRNER1,R5,#0 x960!STRR2,R9,#4STRBR0,R3,-R8,ASR#2LDRR1,localdataLDRR0,R1,R2,LSL#2LDRBR0,R2,#3LDRR1,R0,-R2,LSL#2STRR0,R7,#-8第55页/共121页例:例:LDREQSHR11,R6LDRHR1,R0,#20STRHR4,R3,R2!LDRSBR0,constfLDRHR6,R2,#2LDRSHR1,R9STRHR0,R1,R2,LSL#2STRNEHR0,R2,#960!第56页/共121页例如COPY:COPY:ADR r1,TABLE1ADR r1,TABLE1;r1 points;r1 points to TABLE1to TABLE1ADR r2,TABLE2ADR r2,TABLE2;r2 points;r2 points to TABLE2to TABLE2LOOP:LOOP:LDR r0,r1LDR r0,r1STR r0,r2STR r0,r2ADD r1,r1,#4ADD r1,r1,#4ADD r2,r2,#4ADD r2,r2,#4.TABLE1:TABLE1:.TABLE2:.TABLE2:.COPY:COPY:ADR r1,TABLE1ADR r1,TABLE1;r1 points;r1 points to TABLE1to TABLE1ADR r2,TABLE2ADR r2,TABLE2;r2 points;r2 points to TABLE2to TABLE2LOOP:LOOP:LDR r0,r1,#4LDR r0,r1,#4STR r0,r2,#4STR r0,r2,#4.TABLE1:TABLE1:.TABLE2:.TABLE2:.第57页/共121页二进制编码格式二进制编码格式二进制编码格式二进制编码格式n n这一类数据传送格式的二进制编码如下:这一类数据传送格式的二进制编码如下:第58页/共121页多寄存器存取指令多寄存器存取指令n n多多寄寄存存器器传传送送指指令令可可以以用用一一条条指指令令将将1616个个可可见见寄寄存存器器(R0-R15R0-R15)的的任任意意子子集集合合(或或全全部部)存存储储到到存存储储器器或或从从存存储储器器中中读读取取数数据据到到该该寄寄存存器器集集合合中中。与与单单寄寄存存器器存存取取指指令令相相比比,多多寄寄存存器器数数据据存存取取可可用用的的寻址模式更加有限。寻址模式更加有限。第59页/共121页汇编格式汇编格式汇编格式汇编格式n n多寄存器存取指令的汇编格式如下:多寄存器存取指令的汇编格式如下:n nLDM/STM Rn!LDM/STM Rn!LDM/STM Rn!LDM/STM Rn!,LDMDBR1!,R0,R2,R5STMIAR1!,R3-R6,R11,R12LDMIAR10!,R0-R7,LR第60页/共121页多寄存器传送寻址模式r5r1r9r0r9STMIA r9!,r0,r1,r5100016100c16101816r1r5r9STMDA r9!,r0,r1,r5r0r9100016100c16101816r5r9STMDB r9!,r0,r1,r5r1r0r9100016100c16101816r5r1r0r9r9STMIB r9!,r0,r1,r5100016100c16101816第61页/共121页n n块块拷拷贝贝n n数数据被存据被存贮贮在基本寄存器在基本寄存器的上面地址或下面地址的上面地址或下面地址 n n地址增加或地址增加或减减少是在存少是在存贮贮第一第一个个值值之前或之后之前或之后开开始始的的LDMIA r1,r0,r2,LDMIA r1,r0,r2,r5r5r0:=memr0:=mem3232r1r1r2:=memr2:=mem3232r1+r1+44r5:=memr5:=mem3232r1+r1+88Note:寄存器的部分或全部都可以用单指令传送Note:在表中的寄存器顺序并不重要Note:在表中包括 r15 i将造成控制流的改变多寄存器多寄存器数数据据传送送 Increment After第62页/共121页习题习题假设R0中内容为0 x8000,R1和R2中内容分别为0 x01和0 x10,存储器内容为空,执行下述指令后,寄存器和存储器内容如何变化?STMIBR0!,R1,R2LDMIAR0!,R1,R2第63页/共121页单寄存器交换指令(单寄存器交换指令(SWPSWP)n n交换指令把字或无符号字节的读取和存入组合在一条指令中。通常都把这两种传送结合成为一个不能被外部存储器的访问(例如来自DMA控制器的访问)分隔开的基本的存储器操作,因此本指令一般用于处理器之间或处理器与DMA控制器之间共享的信号量、数据结构进行互斥的访问。第64页/共121页二进制编码及汇编格式二进制编码及汇编格式二进制编码及汇编格式二进制编码及汇编格式FF其二进制编码格式如下:其二进制编码格式如下:FF其汇编格式如下:其汇编格式如下:n nSWP B RdSWP B Rd,RmRm,RnRn 第65页/共121页SWPBR1,R1,R0SWPR1,R2,R3第66页/共121页3 3、转移指令、转移指令FF 跳跳转转指指令令用用于于实实现现程程序序流流程程的的跳跳转转,在在ARMARM程程序序中有两种方法可以实现程序流程的跳转:中有两种方法可以实现程序流程的跳转:使用专门的跳转指令。使用专门的跳转指令。直接向程序计数器直接向程序计数器PCPC写入跳转地址值。写入跳转地址值。FF ARMARM的的

    注意事项

    本文(嵌入式系统开发与应用教程.pptx)为本站会员(莉***)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开