DSP第三章3_new_第1页
DSP第三章3_new_第2页
DSP第三章3_new_第3页
DSP第三章3_new_第4页
DSP第三章3_new_第5页
已阅读5页,还剩40页未读 继续免费阅读

下载本文档

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

文档简介

1、1DSPDSP技术技术及应用及应用igital ignal rocessor数字信号处理器数字信号处理器刘君刘君2第四节第四节 指令系统概述指令系统概述TMS320C54xTMS320C54x是是TMS320TMS320系列中的一种定点系列中的一种定点数字信号处理器,它的指令系统分助记符形数字信号处理器,它的指令系统分助记符形式和代数式形式两种。式和代数式形式两种。共有指令共有指令129129条,由于操作数的寻址方式条,由于操作数的寻址方式不同,派生至不同,派生至205205条。条。3可同时读入可同时读入2 2或或3 3个操作数;个操作数;支持双精度运算的支持双精度运算的3232位长操作数指令

2、;位长操作数指令;可进行单条指令重复和块指令重复操作;可进行单条指令重复和块指令重复操作;有块存储器传送指令和并行操作(如并行存储和加载有块存储器传送指令和并行操作(如并行存储和加载、并行存储和加、并行存储和加/ /减法、并行存储和乘法、并行加载和减法、并行存储和乘法、并行加载和乘法)指令;乘法)指令;设有条件存储指令及延迟操作指令、有从中断快速返设有条件存储指令及延迟操作指令、有从中断快速返回指令;回指令;有为特殊用途设计的指令(如支持有为特殊用途设计的指令(如支持FIRFIR滤波、最小均方滤波、最小均方算法算法LSMLSM、多项式计算以及浮点运算);、多项式计算以及浮点运算);有为省电安排

3、的空转指令。有为省电安排的空转指令。 TMS320C54xTMS320C54x指令系统的主要特点指令系统的主要特点4TMS320C54x指令系统 指令语句 每一条指令语句在源程序汇编时都要产生可供计算机执行的指令代码(即目标代码),所以这种语句又叫可执行语句。每一条指令语句表示计算机具有的一个基本能力,如数据传送,两数相加或相减,移位等,而这种能力是在目标程序(指令代码的有序集合)运行时完成的,是依赖于汁算机内的中央处理器(CPU)、存储器、IO接口等硬件设备来实现的。 5 伪指令语句 伪指令语句是用于指示汇编程序如何汇编源程序,所以这种语句又叫命令语句。例如源程序中的伪指令语句告诉汇编程序:

4、该源程序如何分段,有哪些逻辑段在程序段中哪些是当前段,它们分别由哪个段寄存器指向;定义了哪些数据,存储单元是如何分配的等等。伪指令语句除定义的具体数据要生成目标代码外,其他均没有对应的目标代码。伪指令语句的这些命令功能是由汇编程序在汇编源程序时,通过执行一段程序来完成的,而不是在运行目标程序时实现的 6SmemSmem:1616位单寻址操作数。位单寻址操作数。XmemXmem:1616位双寻址操作数,从位双寻址操作数,从DBDB数据总线上读出。数据总线上读出。YmemYmem:1616位双寻址操作数,从位双寻址操作数,从CBCB数据总线上读出。数据总线上读出。dmaddmad:1616位立即数

5、,数据存储器地址。位立即数,数据存储器地址。pmadpmad:1616位立即数,程序存储器地址。位立即数,程序存储器地址。PAPA: 1616位立即数,位立即数,I/OI/O口地址。口地址。srcsrc: 源累加器(源累加器(A A或或B B)。)。dstdst: 目的累加器(目的累加器(A A或或B B)。)。lklk: 1616位长立即数。位长立即数。第一节第一节 TMS320C54xTMS320C54x的寻址方式的寻址方式 71 1立即数寻址立即数寻址2绝对地址寻址绝对地址寻址3累加器寻址累加器寻址4直接寻址直接寻址5间接寻址间接寻址6存储器映象寄存器寻址存储器映象寄存器寻址7堆栈寻址堆

6、栈寻址寻址寻址分类分类8 1 1立即数寻址立即数寻址 在操作数前面需要加字号来说明该操作数在操作数前面需要加字号来说明该操作数为立即数。否则会把该操作数误认为是一个地为立即数。否则会把该操作数误认为是一个地址,从而把立即数寻址变成绝对地址寻址。址,从而把立即数寻址变成绝对地址寻址。 特特点点指令中包含有执行指令所需要的操作数。指令中包含有执行指令所需要的操作数。立即数分为立即数分为3 3、5 5、8 8或或9 9位的短立即数和位的短立即数和1616位位的长立即数两种。的长立即数两种。短立即数可包含在单字或双字指令中,长立短立即数可包含在单字或双字指令中,长立即数在双字指令中。即数在双字指令中。

7、 注注意意LD #93hLD #93h,A A LD 93hLD 93h,A A 举例举例9 2绝对地址寻址绝对地址寻址特特点点在指令中包含有所要寻址的存储单元的在指令中包含有所要寻址的存储单元的1616位位地址。这个地址。这个1616位的地址可以用其所在单元的地位的地址可以用其所在单元的地址标号或者址标号或者1616位符号常数来表示。位符号常数来表示。 (1 1)数据存储器地址()数据存储器地址(damddamd)寻)寻址址 用一个符号或一用一个符号或一个数来确定数据个数来确定数据空间的一个地址。空间的一个地址。 方法方法MVKD SAMPLEMVKD SAMPLE,* *AR3AR3 举例

8、举例10用一个符号或一用一个符号或一个具体的数来确个具体的数来确定程序存储器中定程序存储器中的一个地址的一个地址 2绝对地址寻址绝对地址寻址(2 2)程序存储器地址()程序存储器地址(pmadpmad)寻)寻址址 方法方法MVPD TABLEMVPD TABLE,* *AR4AR4 举例举例11用一个符用一个符号或一个号或一个常数来确常数来确定外部定外部I/OI/O口地口地址址 2绝对地址寻址绝对地址寻址(3 3)PAPA寻址寻址 端口(端口(PAPA) 方法方法PORTR FIFOPORTR FIFO,* *AR5 AR5 举例举例12用一个符号用一个符号或一个常数或一个常数来确定数据来确定

9、数据存储器中的存储器中的一个地址一个地址 2绝对地址寻址绝对地址寻址(4 4)* *(lklk)寻址)寻址 方法方法LD LD * *(BUFFERBUFFER),),A A 举例举例特点特点允许所有使允许所有使用用SmemSmem寻址寻址的指令去访的指令去访问数据空间问数据空间的任意单元的任意单元而不改变数而不改变数据页指针据页指针(DPDP)的值,)的值,也不用对也不用对ARxARx进行初始化进行初始化 13用累加用累加器中的器中的数值作数值作为地址为地址来读写来读写程序存程序存储器。储器。 方法方法READA SmemREADA Smem WRITA SmemWRITA Smem 举例举

10、例特点特点可用来可用来完成完成程序存储器程序存储器单元的数据单元的数据与与数据存储数据存储器单元的数器单元的数据据进行交换进行交换 3累加器寻址累加器寻址14可以在不改可以在不改变变DPDP或或SPSP的的情况下,随情况下,随机地寻址机地寻址128128个存储单元个存储单元中的任何一中的任何一个单元。个单元。 用一个符号或用一个符号或一个常数来确一个常数来确定定7 7位偏移值位偏移值,与与DPDP或或SPSP共同共同形成形成1616位的数位的数据存储器实际据存储器实际地址。地址。4直接寻址直接寻址 方法方法LD #xLD #x,DPDPLD uLD u,A A ADD vADD v,A A =

11、SSBX CPLSSBX CPL LD X1 LD X1,A A ADD Y2 ADD Y2,A A 举例举例特点特点15CPL=0 7CPL=0 7位位dmadma域与域与9bit9bit的的DPDP相结合相结合形成形成1616位的数据存储器地址。位的数据存储器地址。CPL=1 7CPL=1 7位位dmadma域加上(正偏移)域加上(正偏移)SPSP的值形成的值形成1616位的数据存储器地址。位的数据存储器地址。 DPDP值是从值是从0511(2 29 9-1-1),以),以DPDP为基准的直接寻址把存储器分为基准的直接寻址把存储器分成成512512页,页,7 7位的位的dmadma范围从范

12、围从0127,每页有,每页有128128个可访问的单元。个可访问的单元。 165间接寻址间接寻址 方法方法特点特点(AR0AR0AR7AR7)ARAU0/ARAU1 ARAU0/ARAU1 1616位无符号算术运位无符号算术运算算寻址范围为寻址范围为64K 64K 能在一个指令中访问能在一个指令中访问两个数据存储器单元两个数据存储器单元两个独立的存储器单元读数据两个独立的存储器单元读数据读一个读一个、写另一个存储器单元写另一个存储器单元读写两个连续的存储器单元读写两个连续的存储器单元 175间接寻址间接寻址 (1 1)单操作数寻址)单操作数寻址 定义间接寻定义间接寻址的类型址的类型定义寻址所使

13、用定义寻址所使用的辅助寄存器的辅助寄存器 ST1ST1CMPT=0 CMPT=0 标准方式标准方式ARFARF确定辅助寄存器确定辅助寄存器,ST0ST0中中ARPARP0 0 CMPT=1 CMPT=1 兼容方式兼容方式如如ARF=0ARF=0,用,用ARPARP选择辅助寄存器,选择辅助寄存器,否则,用否则,用ARFARF来确定辅助寄存器。来确定辅助寄存器。ARFARF的值装入的值装入ARPARP。LD LD * *AR1,BAR1,B18单操作数间接寻址的硬件框图19MOD域域操作码语法操作码语法功功 能能说说 明明0000*ARxaddr=ARxARx包含了数据存储器地址包含了数据存储器地

14、址0001*ARx-addr=ARxARx=ARx-1访问后,访问后,ARx中的地址减中的地址减10010*ARx+addr=ARxARx=ARx+1访问后,访问后,ARx中的地址加中的地址加10011*+ARxaddr=ARx+1ARx=ARx+1在寻址前,在寻址前,ARx中的地址加中的地址加1,然后再寻址,然后再寻址0100*ARx-0Baddr=ARxARx=B(ARx-AR0)访问后,从访问后,从ARx中以位倒序进位的方式减去中以位倒序进位的方式减去AR00101*ARx-0addr=ARxARx=ARx-AR0访问后,从访问后,从ARx中减去中减去AR00110*ARx+0addr=

15、ARxARx=ARx+AR0访问后,把访问后,把AR0加到加到ARx中去中去0111*ARx+0Baddr=ARxARx=B(ARx+AR0)访问后,把访问后,把AR0以位倒序进位的方式加到以位倒序进位的方式加到ARx中中1000*ARx-%addr=ARxARx=circ(ARx-1)访问后,访问后,ARx中的地址以循环寻址的方式减中的地址以循环寻址的方式减11001*ARx-0%addr=ARxARx=circ(ARx-AR0)访问后,从访问后,从ARx中以循环寻址的方式减去中以循环寻址的方式减去AR01010*ARx+%addr=ARxARx=circ(ARx+1)访问后,访问后,ARx

16、中的地址以循环寻址的方式加中的地址以循环寻址的方式加11011*ARx+0%addr=ARxARx=circ(ARx+AR0)访问后,把访问后,把AR0以循环寻址的方式加到以循环寻址的方式加到ARx中中1100*ARx(lk)addr=ARx+lkARx=ARxARx和和16位的长偏移(位的长偏移(lk)的和用来作为数据存储器地)的和用来作为数据存储器地址。址。ARx本身不被修改本身不被修改1101*+ARx(lk)addr=ARx+lkARx=ARx+lk在寻址前,把一个带符号的在寻址前,把一个带符号的16位的长偏移(位的长偏移(lk)加到)加到ARx中,然后用新的中,然后用新的ARx的值作

17、为数据存储器的地址的值作为数据存储器的地址1110*+ARx(lk)%addr=circ(ARx+lk)ARx=circ(ARx+lk)在寻址前,把一个带符号的在寻址前,把一个带符号的16位的长偏移以循环寻址位的长偏移以循环寻址的方式加到的方式加到ARx中,然后再用新的中,然后再用新的ARx的值作为数据的值作为数据存储器的地址存储器的地址1111*(lk)addr=lk一个无符号的一个无符号的16位的长偏移(位的长偏移(lk)用来作为数据存储)用来作为数据存储器的绝对地址。(也属绝对寻址)器的绝对地址。(也属绝对寻址)单数据存储器操作数间接寻址类型单数据存储器操作数间接寻址类型 201) 1)

18、 循环寻址循环寻址 循环缓冲区的长度值存放在循环缓冲循环缓冲区的长度值存放在循环缓冲区长度寄存器区长度寄存器BKBK中,中,BKBK中的数值由指令设定。长度为中的数值由指令设定。长度为R R的循环缓冲器必须从一个的循环缓冲器必须从一个N N位地址的边界开始,即循环位地址的边界开始,即循环缓冲器基地址的最低缓冲器基地址的最低N N位必须为位必须为0 0。N N是满足是满足2 2N NR R的最的最小整数。小整数。R R的值必须装入的值必须装入BKBK。例如,含有例如,含有3131个字的循环缓冲器必须从最低个字的循环缓冲器必须从最低5 5位为位为0 0的的地址开始,即地址开始,即xxxx xxxx

19、xxxx xxxx xxx0 0000 xxx0 00002 2,N=5N=5,2 2N N=2=25 5R=31R=31,且,且3131必须装入必须装入BKBK。如:。如:STM #1kSTM #1k,BKBK如果如果R=32R=32,则最小的,则最小的N N值为值为6 6,循环缓冲区的起始地址,循环缓冲区的起始地址必须有必须有6 6个最低有效位为个最低有效位为0 0,即,即 00 000000 00002 2。212) 2) 位倒序寻址位倒序寻址 在这种寻址方式中,用在这种寻址方式中,用AR0AR0存放存放FFTFFT点数的一半整数点数的一半整数N N,用另一辅助寄存器指向一数据,用另一辅

20、助寄存器指向一数据存放的物理单元。当使用位倒序寻址把存放的物理单元。当使用位倒序寻址把AR0AR0加到辅助寄加到辅助寄存器中时,地址以位倒序的方式产生,即进位是从左存器中时,地址以位倒序的方式产生,即进位是从左向右,而不是从右向左进位。向右,而不是从右向左进位。 例如:例如: 0110 10000110 1000 + 0000 1000 + 0000 1000 0110 01000110 0100以以8 8位辅助寄存器为例,位辅助寄存器为例,AR1AR1表示了在存储器中数表示了在存储器中数据的基地址(据的基地址(0110 00000110 0000)2 2,AR0AR0的值为(的值为(0000

21、 10000000 1000)2 2。利用以下两条语句可以向外设口(口地址为。利用以下两条语句可以向外设口(口地址为PAPA)输出整序后的输出整序后的FFTFFT变换结果:变换结果:RPT #15 RPT #15 重复执行下条指令重复执行下条指令15+115+1次次PORTW PORTW * *AR1+0BAR1+0B,PA PA 向外设口向外设口PAPA输出整结果输出整结果22AR1修改修改循环值循环值存储单存储单元地址元地址整序前整序前FFT 变换结果变换结果位倒序位倒序AR1更新的地址值更新的地址值AR0=0000 10002整序后整序后PA输出的输出的FFT变换结果变换结果00000X

22、(0)00000110 0000X(0)10001X(8)10000110 1000X(1)20010X(4)01000110 0100X(2)30011X(12)11000110 1100X(3)40100X(2)00100110 0010X(4)50101X(10)10100110 1010X(5)60110X(6)01100110 0110X(6)70111X(14)11100110 1110X(7)81000X(1)00010110 0001X(8)91001X(9)10010110 1001X(9)101010X(5)01010110 0101X(10)111011X(13)1101

23、0110 1101X(11)121100X(3)00110110 0011X(12)131101X(11)10110110 1011X(13)141110X(7)01110110 0111X(14)151111X(15)11110110 1111X(15)位倒序对位倒序对FFTFFT变换结果的序号调整变换结果的序号调整 235间接寻址间接寻址 (2 2)双操作数寻址方式)双操作数寻址方式 确定确定包含包含XmemXmem地址地址的辅的辅助寄助寄存器存器 确定确定包含包含YmemYmem地址地址的辅的辅助寄助寄存存器器定义用于定义用于访问访问YmemYmem操作数的操作数的间接寻址间接寻址方式的

24、类方式的类型型 定义用于定义用于访问访问XmemXmem操操作数的间作数的间接寻址方接寻址方式的类型式的类型 MPY MPY * *AR2,AR2,* *AR3,AAR3,A24Xar或或Yar 辅助寄存器辅助寄存器00 AR201 AR310 AR411 AR5辅助辅助寄存器寄存器选择选择Xmod或或Ymod操作码语操作码语法法功功 能能说说 明明00*ARxaddr=ARxARx是数据存储器地址是数据存储器地址01*ARx-addr=ARxARx=ARx-1访问后,访问后,ARx中的地址减中的地址减110*ARx+addr=ARxARx=ARx+1访问后,访问后,ARx中的地址加中的地址加

25、111*ARx+0%addr=ARxARx=circ(ARx+AR0)访问后,访问后,AR0以循环寻址的以循环寻址的方式加到方式加到ARx中中250 0页寻址。页寻址。不影响不影响当前当前DPDP或或SPSP值值 。用于直用于直接寻址接寻址和间接和间接寻址寻址用来修用来修改存储改存储器映象器映象寄存器寄存器 6存储器映象寄存器寻址存储器映象寄存器寻址功能功能LDM PRD,ALDM PRD,A举例举例特点特点方法方法高高9 9位数据位数据存储器地址存储器地址被置被置0 0,利,利用指令中的用指令中的低位地址低位地址访问访问MMRMMR。267堆栈寻址堆栈寻址 从高地址向低地址方向生长,从高地址

26、向低地址方向生长,SPSP)来管理堆栈,)来管理堆栈,SPSP始终指始终指向堆栈中所存放的最后一个向堆栈中所存放的最后一个数据,即数据,即SPSP指针始终指向栈指针始终指向栈顶。在压入操作时,先减小顶。在压入操作时,先减小SPSP的值,再将数据压入堆栈;的值,再将数据压入堆栈;在弹出操作时,先从堆栈弹在弹出操作时,先从堆栈弹出数据,再增加出数据,再增加SPSP的值。的值。用来在中断用来在中断和子程序调和子程序调用时自动保用时自动保存程序计数存程序计数器(器(PCPC)中)中的数值的数值,也也能用来保护能用来保护现场或传送现场或传送参数参数 功能功能特点特点PSHD PSHD * *AR2AR2

27、 POPD POPD * *AR3AR327第二节第二节 程序地址的生成程序地址的生成程序地址程序地址生成器生成器(PAGENPAGEN)构成构成程序计数器(程序计数器(PCPC)重复计数器(重复计数器(RCRC)块重复计数器(块重复计数器(BRCBRC)块重复起始地址寄存器(块重复起始地址寄存器(RSARSA)块重复结束地址寄存器(块重复结束地址寄存器(REAREA)核心核心1616位程序计数器(位程序计数器(PCPC)内中保存某个内部或外内中保存某个内部或外部程序存储器的地址部程序存储器的地址。地址地址内容为:内容为:即将取指的某条指令即将取指的某条指令;某个某个1616位立即操作数位立即

28、操作数;系数表系数表。在程序存储器中的地址在程序存储器中的地址28操作操作加载到加载到PC的地址的地址复位复位PC=FF80h。顺序执行指令顺序执行指令PC=PC+1。分支转移分支转移用紧跟在分支转移指令后面的用紧跟在分支转移指令后面的16位立即数加载位立即数加载PC。由累加器分支转移由累加器分支转移用累加器用累加器A或或B的低的低16位立即数加载位立即数加载PC。块重复循环块重复循环假如假如ST1中的块重复有效位中的块重复有效位BRAF=1,当,当PC+1等于块重复等于块重复结束地址(结束地址(REA)+1,将块重复起始地址(,将块重复起始地址(RSA)加载)加载PC。子程序调用子程序调用将

29、将PC+2压入堆栈,并用紧跟在调用指令后面的压入堆栈,并用紧跟在调用指令后面的16位立即数位立即数加载加载PC。返回指令将栈顶弹出至。返回指令将栈顶弹出至PC,回到原先的程序处,回到原先的程序处继续执行。继续执行。从累加器调用子程从累加器调用子程序序将将PC+1压入椎栈,用累加器压入椎栈,用累加器A或或B的低的低16位加载位加载PC。返回。返回指令将栈顶弹出至指令将栈顶弹出至PC,回到原先的程序处继续执行。,回到原先的程序处继续执行。硬件中断或软件中硬件中断或软件中断断将将PC压入堆栈,用适当的中断向量地址加载压入堆栈,用适当的中断向量地址加载PC。中断返。中断返回时,将栈顶弹出至回时,将栈顶

30、弹出至PC,继续执行被中断了的子程序。,继续执行被中断了的子程序。将程序存储器地址加载到程序计数器的途径将程序存储器地址加载到程序计数器的途径291分支转移操作分支转移操作 通过分支转移指令改写通过分支转移指令改写PCPC,可,可以改变程序的流向。而子程序以改变程序的流向。而子程序调用指令则通过将一个返回地调用指令则通过将一个返回地址压入堆栈,执行返回时恢复址压入堆栈,执行返回时恢复原地址。原地址。可执行可执行: :分支转移分支转移循环控制循环控制子程序操子程序操作作 功能功能方法方法30条件条件分支转移分支转移无条件分支转移无条件分支转移 BDBD用指令用指令中所给出的中所给出的地址加载地址

31、加载PCPCBACCDBACCD用用所指定的累所指定的累加器的低加器的低1616位作为地址位作为地址加载加载PCPC。 带延迟带延迟不带延迟不带延迟操作操作转移种类转移种类BCDBCD如果指令如果指令中所规定的条中所规定的条件得到满足,件得到满足,就用指令中所就用指令中所给出的地址加给出的地址加载载PCPC;BANZDBANZD如果当如果当前辅助寄存器前辅助寄存器不等于不等于0 0,就用,就用指令中所规定指令中所规定的地址加载的地址加载PCPC。 BC newBC new,AOVAOV BANZ loop,BANZ loop,* *AR2-AR2-B nextB nextBACC ABACC

32、A312调用和返回调用和返回 转移前,原程序的转移前,原程序的下条指令的地址被下条指令的地址被压入堆栈,而在返压入堆栈,而在返回时则将这个地址回时则将这个地址弹出至弹出至PCPC,使被中,使被中断了的原程序能继断了的原程序能继续执行。续执行。 当采用调用指令进当采用调用指令进行子程序或函数调行子程序或函数调用时,用时,DSPDSP中断当前中断当前运行的程序,转移运行的程序,转移到程序存储器的其到程序存储器的其它地它地址址继续运行。继续运行。功能功能方法方法无条件调用与返回无条件调用与返回有条件调用与返回有条件调用与返回带延迟带延迟不带延迟不带延迟CALLd lopCALLd lopRET ma

33、inRET main323条件指令中的条件判断条件指令中的条件判断33多重条件判断多重条件判断 BC pmadBC pmad,condcond,condcond,condcond相与关系相与关系相或关系相或关系BC pmadBC pmad,condcondBC pmadBC pmad,condcond第第1组组第第2组组A 类类B 类类A 类类B 类类C 类类EQOVTCCBIONEQNOVNTCNCNBIOLT LEQ GT GEQ 34第第1 1组组 例如例如 可以从可以从A A类中选一个条件,同类中选一个条件,同时可以从时可以从B B类中选择一个条件。类中选择一个条件。但是不能从同一类中

34、选择两但是不能从同一类中选择两个条件。个条件。另外,两种条件测试的累加另外,两种条件测试的累加器必须是同一个。器必须是同一个。可以同时测试可以同时测试AGTAGT和和AOVAOV,但,但不能同时测试不能同时测试AGTAGT和和BGTBGT。 35第第2 2组组 例如例如 可以在可以在A A、B B、C C三类中各三类中各选择一个条件,但不能从选择一个条件,但不能从同一类中选择两个条件同一类中选择两个条件 可以在可以在A A、B B、C C三类中各选三类中各选择一个条件,但不能从同择一个条件,但不能从同一类中选择两个条件一类中选择两个条件 36特特例例如果条件分支转移出去的地方只有如果条件分支转

35、移出去的地方只有1 12 2字的字的程序段,则可以用一条单周期条件执行指令程序段,则可以用一条单周期条件执行指令(XCXC)来代替分支转移指令:)来代替分支转移指令:XC nXC n,condcond,condcond,condcond当当n=1n=1,且条件得到满足,就执行紧随此,且条件得到满足,就执行紧随此条件指令后的个字指令。条件指令后的个字指令。当当n=2n=2,且条件得到满足,就执行紧随此,且条件得到满足,就执行紧随此指 令 后 的指 令 后 的 1 1 个 双 字 指 令 或 者个 双 字 指 令 或 者 2 2 条 单条 单字指令。字指令。当条件不满足,就依当条件不满足,就依n

36、n的值执行的值执行1 1条或条或2 2条条NOPNOP指令。指令。37例例3-3 编写计算编写计算 的主要程序部分。的主要程序部分。 .bss.bss x,4 x,4 ;为;为X X建立建立4 4个单元,个单元, ;放置;放置X1X1、X2X2、X3X3、X4X4 .bss.bss y,1 y,1 ;为;为Y Y建立建立1 1个单元,放置个单元,放置Y Y STM #xSTM #x,AR1 AR1 ;将;将X1X1的地址传给的地址传给AR1AR1 STM #3STM #3,AR2 AR2 ;将循环次数;将循环次数3 3传给传给AR2AR2 LD #0LD #0,A A ;对;对A A清零清零l

37、oop:ADD loop:ADD * *AR1+AR1+,A A ;对;对X1X1、X2X2、X3X3、X4X4循环循环累累 ;加,结果放;加,结果放A A中中 BANZ loop,BANZ loop,* *AR2- AR2- ;检查循环是否应结束;检查循环是否应结束 STL ASTL A,y y ;将累加结果存入;将累加结果存入Y Y中中41iixy38特点特点2 2特点特点1 14单条指令的重复操作单条指令的重复操作 重复执行(重复执行(RCRC)+1+1次。次。RCRC内容不能编程设置,内容不能编程设置,只能由重复指令(只能由重复指令(RPTRPT和和RPTZRPTZ)中的操作数加载。)

38、中的操作数加载。操作数操作数n n的最大值为的最大值为65 65 535535,最大重复执行次数,最大重复执行次数为为65 535+165 535+1。 一旦重复指令被取一旦重复指令被取指、译码,直到重指、译码,直到重复循环完成以前,复循环完成以前,对所有的中断(包对所有的中断(包括括 ,但不包,但不包括括 )均不响应。)均不响应。 功能功能重复执行下一条指令重复执行下一条指令 NMIRS39重复过程重复过程当当RPTRPT指令执行时指令执行时:首先把循环的次数装入循环计数器(首先把循环的次数装入循环计数器(RCRC),),其循环次数其循环次数n n由一个由一个1616位单数据存储器操作数位单

39、数据存储器操作数 SmemSmem或一个或一个8 8位或位或1616位常数位常数k k或或lklk给定。这样,给定。这样, 紧接着的下一条指令会循环执行紧接着的下一条指令会循环执行n+1n+1次。次。循环,循环,RCRC在执行减在执行减1 1操作时不能被访问。操作时不能被访问。注意:注意:该循环内不能套用循环。该循环内不能套用循环。 当当RPTZRPTZ指令执行时指令执行时:对目的累加器对目的累加器dstdst清清0 0, 循环执行下一条指令循环执行下一条指令n+1n+1次。次。 40例例3-5 利用单条指令的重复操作对数组利用单条指令的重复操作对数组x5=0 x5=0,0 0,0 0,0 0

40、,00进行初始化。进行初始化。.bss.bss x,5 x,5 ;为数组;为数组x x分配分配5 5个存储单元个存储单元STM #x,AR1 STM #x,AR1 ;将;将x x的首地址赋给的首地址赋给AR1AR1LD #0,A LD #0,A ;对;对A A清零清零RPT #4 RPT #4 ;设置重复执行下条指令;设置重复执行下条指令5 5次次STL A,STL A,* *AR1+AR1+;对;对x5x5各单元清零各单元清零或者或者.bss.bss x,5 x,5STM #x,AR1STM #x,AR1RPTZ A,#4RPTZ A,#4;对;对A A清零并设置重复执行下条指令清零并设置重复执行下条指令5

温馨提示

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

评论

0/150

提交评论