版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、1DSPDSP技术及应用技术及应用igital ignal rocessor数字信号处理器数字信号处理器第三章第三章 DSP指令系统与特点指令系统与特点 第一节第一节 寻址方式寻址方式第二节第二节 程序地址的生成程序地址的生成第三节第三节 流水线操作技术流水线操作技术(了解了解)第四节第四节 指令系统概述指令系统概述SmemSmem:1616位单寻址操作数。位单寻址操作数。XmemXmem:1616位双寻址操作数,从位双寻址操作数,从DBDB数据总线上读出。数据总线上读出。YmemYmem:1616位双寻址操作数,从位双寻址操作数,从CBCB数据总线上读出。数据总线上读出。dmaddmad:1
2、616位立即数,数据存储器地址。位立即数,数据存储器地址。pmadpmad:1616位立即数,程序存储器地址。位立即数,程序存储器地址。PAPA: 1616位立即数,位立即数,I/OI/O口地址。口地址。srcsrc: 源累加器(源累加器(A A或或B B)。)。dstdst: 目的累加器(目的累加器(A A或或B B)。)。lklk: 1616位长立即数。位长立即数。第一节第一节 TMS320C54xTMS320C54x的寻址方式的寻址方式 1 1立即数寻址立即数寻址2绝对地址寻址绝对地址寻址3累加器寻址累加器寻址4直接寻址直接寻址5间接寻址间接寻址6存储器映象寄存器寻址存储器映象寄存器寻址
3、7堆栈寻址堆栈寻址寻址寻址分类分类 1 1立即数寻址立即数寻址 在操作数前面需要加字号来说明该操作数在操作数前面需要加字号来说明该操作数为立即数。否则会把该操作数误认为是一个地为立即数。否则会把该操作数误认为是一个地址,从而把立即数寻址变成绝对地址寻址。址,从而把立即数寻址变成绝对地址寻址。 特特点点指令中包含有执行指令所需要的操作数。指令中包含有执行指令所需要的操作数。立即数分为立即数分为3 3、5 5、8 8或或9 9位的短立即数和位的短立即数和1616位位的长立即数两种。的长立即数两种。短立即数可包含在单字或双字指令中,长立短立即数可包含在单字或双字指令中,长立即数在双字指令中。即数在双
4、字指令中。 注注意意LD #93hLD #93h,A A LD 93hLD 93h,A A 举例举例 2绝对地址寻址绝对地址寻址特特点点在指令中包含有所要寻址的存储单元的在指令中包含有所要寻址的存储单元的1616位位地址。这个地址。这个1616位的地址可以用其所在单元的地位的地址可以用其所在单元的地址标号或者址标号或者1616位符号常数来表示。位符号常数来表示。 (1 1)数据存储器地址()数据存储器地址(damddamd)寻寻址址 用一个符号或一用一个符号或一个数来确定数据个数来确定数据空间的一个地址。空间的一个地址。 方法方法MVKD SAMPLEMVKD SAMPLE,* *AR3AR3
5、 举例举例用一个符号或一用一个符号或一个具体的数来确个具体的数来确定程序存储器中定程序存储器中的一个地址的一个地址 (2 2)程序存储器地址()程序存储器地址(pmadpmad)寻寻址址 方法方法MVPD TABLEMVPD TABLE,* *AR4AR4 举例举例用一个符用一个符号或一个号或一个常数来确常数来确定外部定外部I/OI/O口地口地址址 (3 3)PAPA寻址寻址 端口(端口(PAPA) 方法方法PORTR FIFOPORTR FIFO,* *AR5 AR5 举例举例用一个符号用一个符号或一个常数或一个常数来确定数据来确定数据存储器中的存储器中的一个地址一个地址 (4 4)* *(
6、lklk)寻址寻址 方法方法LD LD * *(BUFFERBUFFER),),A A 举例举例特点特点允许所有使允许所有使用用SmemSmem寻址寻址的指令去访的指令去访问数据空间问数据空间的任意单元的任意单元而不改变数而不改变数据页指针据页指针(DPDP)的值,的值,也不用对也不用对ARxARx进行初始化进行初始化 用累加用累加器中的器中的数值作数值作为地址为地址来读写来读写程序存程序存储器。储器。 方法方法READA READA SmemSmem WRITA WRITA SmemSmem 举例举例特点特点可用来可用来完成完成程序存储器程序存储器单元的数据单元的数据与与数据存储数据存储器单
7、元的数器单元的数据据进行交换进行交换 3累加器寻址累加器寻址可以在不改可以在不改变变DPDP或或SPSP的的情况下,随情况下,随机地寻址机地寻址128128个存储单元个存储单元中的任何一中的任何一个单元。个单元。 用一个符号或用一个符号或一个常数来确一个常数来确定定7 7位偏移值位偏移值,与与DPDP或或SPSP共同共同形成形成1616位的数位的数据存储器实际据存储器实际地址。地址。4直接寻址直接寻址 方法方法LD #xLD #x,DPDPLD uLD u,A A ADD vADD v,A A =SSBX CPLSSBX CPL LD X1 LD X1,A A ADD Y2 ADD Y2,A
8、A 举例举例特点特点CPL=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范围从范围从0127,每页有,每页有128128个可访问的单元。个可访问的单元。 5间接寻址间接寻址 方法方法
9、特点特点(AR0AR0AR7AR7)ARAU0/ARAU1 ARAU0/ARAU1 1616位无符号算术运位无符号算术运算算寻址范围为寻址范围为64K 64K 能在一个指令中访问能在一个指令中访问两个数据存储器单元两个数据存储器单元两个独立的存储器单元读数据两个独立的存储器单元读数据读一个读一个、写另一个存储器单元写另一个存储器单元读写两个连续的存储器单元读写两个连续的存储器单元 5间接寻址间接寻址 (1 1)单操作数寻址)单操作数寻址 定义间接寻定义间接寻址的类型址的类型定义寻址所使用定义寻址所使用的辅助寄存器的辅助寄存器 ST1ST1CMPT=0 CMPT=0 标准方式标准方式ARFARF
10、确定辅助寄存器确定辅助寄存器,ST0ST0中中ARPARP0 0 CMPT=1 CMPT=1 兼容方式兼容方式如如ARF=0ARF=0,用,用ARPARP选择辅助寄存器,选择辅助寄存器,否则,用否则,用ARFARF来确定辅助寄存器。来确定辅助寄存器。ARFARF的值装入的值装入ARPARP。LD LD * *AR1,BAR1,B单操作数间接寻址的硬件框图MOD域域操作码语法操作码语法功功 能能说说 明明0000*ARxaddr=ARxARx包含了数据存储器地址包含了数据存储器地址0001*ARx-addr=ARxARx=ARx-1访问后,访问后,ARx中的地址减中的地址减10010*ARx+a
11、ddr=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=ARxARx=ARx+AR0访问后,把访问后,把AR0加到加到ARx中去中去0111*ARx+0Baddr=ARxAR
12、x=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中的地址以循环寻址的方式加中的地址以循环寻址的方式加11011*ARx+0%addr=ARxARx=circ(ARx+
13、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的值作为数据存储器的地址的值作为数据存储器的地址1110*+ARx(lk)%addr=circ(ARx+lk)ARx=circ(
14、ARx+lk)在寻址前,把一个带符号的在寻址前,把一个带符号的16位的长偏移以循环寻址的位的长偏移以循环寻址的方式加到方式加到ARx中,然后再用新的中,然后再用新的ARx的值作为数据存储器的值作为数据存储器的地址的地址1111*(lk)addr=lk一个无符号的一个无符号的16位的长偏移(位的长偏移(lk)用来作为数据存储器的用来作为数据存储器的绝对地址。(也属绝对寻址)绝对地址。(也属绝对寻址)单数据存储器操作数间接寻址类型单数据存储器操作数间接寻址类型 1) 1) 循环寻址循环寻址 循环缓冲区的长度值存放在循环缓冲循环缓冲区的长度值存放在循环缓冲区长度寄存器区长度寄存器BKBK中,中,BK
15、BK中的数值由指令设定。长度为中的数值由指令设定。长度为R R的循环缓冲器必须从一个的循环缓冲器必须从一个N N位地址的边界开始,即循环位地址的边界开始,即循环缓冲器基地址的最低缓冲器基地址的最低N N位必须为位必须为0 0。N N是满足是满足2 2N NR R的最的最小整数。小整数。R R的值必须装入的值必须装入BKBK。例如,含有例如,含有3131个字的循环缓冲器必须从最低个字的循环缓冲器必须从最低5 5位为位为0 0的的地址开始,即地址开始,即xxxxxxxx xxxxxxxx xxx0 0000 xxx0 00002 2,N=5N=5,2 2N N=2=25 5R=31R=31,且且3
16、131必须装入必须装入BKBK。如:如:STM #1kSTM #1k,BKBK如果如果R=32R=32,则最小的则最小的N N值为值为6 6,循环缓冲区的起始地址,循环缓冲区的起始地址必须有必须有6 6个最低有效位为个最低有效位为0 0,即,即 00 000000 00002 2。2) 2) 位倒序寻址位倒序寻址 在这种寻址方式中,用在这种寻址方式中,用AR0AR0存放存放FFTFFT点数的一半整数点数的一半整数N N,用另一辅助寄存器指向一数据用另一辅助寄存器指向一数据存放的物理单元。当使用位倒序寻址把存放的物理单元。当使用位倒序寻址把AR0AR0加到辅助寄加到辅助寄存器中时,地址以位倒序的
17、方式产生,即进位是从左存器中时,地址以位倒序的方式产生,即进位是从左向右,而不是从右向左进位。向右,而不是从右向左进位。 例如:例如: 0110 10000110 1000 + 0000 1000 + 0000 1000 0110 01000110 0100以以8 8位辅助寄存器为例,位辅助寄存器为例,AR1AR1表示了在存储器中数表示了在存储器中数据的基地址(据的基地址(0110 00000110 0000)2 2,AR0AR0的值为(的值为(0000 10000000 1000)2 2。利用以下两条语句可以向外设口(口地址为。利用以下两条语句可以向外设口(口地址为PAPA)输出整序后的输出
18、整序后的FFTFFT变换结果:变换结果:RPT #15 RPT #15 重复执行下条指令重复执行下条指令15+115+1次次PORTW PORTW * *AR1+0BAR1+0B,PA PA 向外设口向外设口PAPA输出整结果输出整结果AR1修改修改循环值循环值存储单存储单元地址元地址整序前整序前FFT 变换结果变换结果位倒序位倒序AR1更新的地址值更新的地址值AR0=0000 10002整序后整序后PA输出的输出的FFT变换结果变换结果00000X(0)00000110 0000X(0)10001X(8)10000110 1000X(1)20010X(4)01000110 0100X(2)3
19、0011X(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)11010110 1101X(11)121100X(3)00110110 0011X(12)131101X(11)10110110 1011X(13)14
20、1110X(7)01110110 0111X(14)151111X(15)11110110 1111X(15)位倒序对位倒序对FFTFFT变换结果的序号调整变换结果的序号调整 5间接寻址间接寻址 (2 2)双操作数寻址方式)双操作数寻址方式 确定确定包含包含XmemXmem地址地址的辅的辅助寄助寄存器存器 确定确定包含包含YmemYmem地址地址的辅的辅助寄助寄存存器器定义用于定义用于访问访问YmemYmem操作数的操作数的间接寻址间接寻址方式的类方式的类型型 定义用于定义用于访问访问XmemXmem操操作数的间作数的间接寻址方接寻址方式的类型式的类型 MPY MPY * *AR2,AR2,*
21、 *AR3,AAR3,AXar或或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中的地址加中的地址加111*ARx+0%addr=ARxARx=circ(ARx+AR0)访问后,访问后,AR0以循环寻址的以循环寻址的方式加到方式加到ARx中中0 0页寻址
22、。页寻址。不影响不影响当前当前DPDP或或SPSP值值 。用于直用于直接寻址接寻址和间接和间接寻址寻址用来修用来修改存储改存储器映象器映象寄存器寄存器 6存储器映象寄存器寻址存储器映象寄存器寻址功能功能LDM PRD,ALDM PRD,A举例举例特点特点方法方法高高9 9位数据位数据存储器地址存储器地址被置被置0 0,利,利用指令中的用指令中的低位地址低位地址访问访问MMRMMR。7堆栈寻址堆栈寻址 从高地址向低地址方向生长,从高地址向低地址方向生长,SPSP)来管理堆栈,来管理堆栈,SPSP始终指始终指向堆栈中所存放的最后一个向堆栈中所存放的最后一个数据,即数据,即SPSP指针始终指向栈指针
23、始终指向栈顶。在压入操作时,先减小顶。在压入操作时,先减小SPSP的值,再将数据压入堆栈;的值,再将数据压入堆栈;在弹出操作时,先从堆栈弹在弹出操作时,先从堆栈弹出数据,再增加出数据,再增加SPSP的值。的值。用来在中断用来在中断和子程序调和子程序调用时自动保用时自动保存程序计数存程序计数器(器(PCPC)中中的数值的数值,也也能用来保护能用来保护现场或传送现场或传送参数参数 功能功能特点特点PSHD PSHD * *AR2AR2 POPD POPD * *AR3AR3第二节第二节 程序地址的生成程序地址的生成程序地址程序地址生成器生成器(PAGENPAGEN)构成构成程序计数器(程序计数器(
24、PCPC)重复计数器(重复计数器(RCRC)块重复计数器(块重复计数器(BRCBRC)块重复起始地址寄存器(块重复起始地址寄存器(RSARSA)块重复结束地址寄存器(块重复结束地址寄存器(REAREA)核心核心1616位程序计数器(位程序计数器(PCPC)内中保存某个内部或外内中保存某个内部或外部程序存储器的地址部程序存储器的地址。地址地址内容为:内容为:即将取指的某条指令即将取指的某条指令;某个某个1616位立即操作数位立即操作数;系数表系数表。在程序存储器中的地址在程序存储器中的地址操作操作加载到加载到PC的地址的地址复位复位PC=FF80h。顺序执行指令顺序执行指令PC=PC+1。分支转
25、移分支转移用紧跟在分支转移指令后面的用紧跟在分支转移指令后面的16位立即数加载位立即数加载PC。由累加器分支转移由累加器分支转移用累加器用累加器A或或B的低的低16位立即数加载位立即数加载PC。块重复循环块重复循环假如假如ST1中的块重复有效位中的块重复有效位BRAF=1,当,当PC+1等于块重复等于块重复结束地址(结束地址(REA)+1,将块重复起始地址(将块重复起始地址(RSA)加载加载PC。子程序调用子程序调用将将PC+2压入堆栈,并用紧跟在调用指令后面的压入堆栈,并用紧跟在调用指令后面的16位立即数位立即数加载加载PC。返回指令将栈顶弹出至返回指令将栈顶弹出至PC,回到原先的程序处回到
26、原先的程序处继续执行。继续执行。从累加器调用子程从累加器调用子程序序将将PC+1压入椎栈,用累加器压入椎栈,用累加器A或或B的低的低16位加载位加载PC。返回返回指令将栈顶弹出至指令将栈顶弹出至PC,回到原先的程序处继续执行。回到原先的程序处继续执行。硬件中断或软件中硬件中断或软件中断断将将PC压入堆栈,用适当的中断向量地址加载压入堆栈,用适当的中断向量地址加载PC。中断返中断返回时,将栈顶弹出至回时,将栈顶弹出至PC,继续执行被中断了的子程序。继续执行被中断了的子程序。将程序存储器地址加载到程序计数器的途径将程序存储器地址加载到程序计数器的途径1分支转移操作分支转移操作 通过分支转移指令改写
27、通过分支转移指令改写PCPC,可可以改变程序的流向。而子程序以改变程序的流向。而子程序调用指令则通过将一个返回地调用指令则通过将一个返回地址压入堆栈,执行返回时恢复址压入堆栈,执行返回时恢复原地址。原地址。可执行可执行: :分支转移分支转移循环控制循环控制子程序操子程序操作作 功能功能方法方法条件条件分支转移分支转移无条件分支转移无条件分支转移 BDBD用指令用指令中所给出的中所给出的地址加载地址加载PCPCBACCDBACCD用用所指定的累所指定的累加器的低加器的低1616位作为地址位作为地址加载加载PCPC。 带延迟带延迟不带延迟不带延迟操作操作转移种类转移种类BCDBCD如果指令如果指令
28、中所规定的条中所规定的条件得到满足,件得到满足,就用指令中所就用指令中所给出的地址加给出的地址加载载PCPC;BANZDBANZD如果当如果当前辅助寄存器前辅助寄存器不等于不等于0 0,就用,就用指令中所规定指令中所规定的地址加载的地址加载PCPC。 BC newBC new,AOVAOV BANZ loop,BANZ loop,* *AR2-AR2-B nextB nextBACC ABACC A2调用和返回调用和返回 转移前,原程序的转移前,原程序的下条指令的地址被下条指令的地址被压入堆栈,而在返压入堆栈,而在返回时则将这个地址回时则将这个地址弹出至弹出至PCPC,使被中使被中断了的原程序
29、能继断了的原程序能继续执行。续执行。 当采用调用指令进当采用调用指令进行子程序或函数调行子程序或函数调用时,用时,DSPDSP中断当前中断当前运行的程序,转移运行的程序,转移到程序存储器的其到程序存储器的其它地它地址址继续运行。继续运行。功能功能方法方法无条件调用与返回无条件调用与返回有条件调用与返回有条件调用与返回带延迟带延迟不带延迟不带延迟CALLd lopCALLd lopRET mainRET main3条件指令中的条件判断条件指令中的条件判断多重条件判断多重条件判断 第第1组组第第2组组A 类类B 类类A 类类B 类类C 类类EQOVTCCBIONEQNOVNTCNCNBIOLT L
30、EQ GT GEQ 第第1 1组组 例如例如 可以从可以从A A类中选一个条件,同类中选一个条件,同时可以从时可以从B B类中选择一个条件。类中选择一个条件。但是不能从同一类中选择两但是不能从同一类中选择两个条件。个条件。另外,两种条件测试的累加另外,两种条件测试的累加器必须是同一个。器必须是同一个。可以同时测试可以同时测试AGTAGT和和AOVAOV,但但不能同时测试不能同时测试AGTAGT和和BGTBGT。 第第2 2组组 例如例如 可以在可以在A A、B B、C C三类中各三类中各选择一个条件,但不能从选择一个条件,但不能从同一类中选择两个条件同一类中选择两个条件 可以在可以在A A、B
31、 B、C C三类中各选三类中各选择一个条件,但不能从同择一个条件,但不能从同一类中选择两个条件一类中选择两个条件 特特例例如果条件分支转移出去的地方只有如果条件分支转移出去的地方只有1 12 2字的字的程序段,则可以用一条单周期条件执行指令程序段,则可以用一条单周期条件执行指令(XCXC)来代替分支转移指令:来代替分支转移指令:XC nXC n,condcond ,condcond ,condcond当当n=1n=1,且条件得到满足,就执行紧随此且条件得到满足,就执行紧随此条件指令后的个字指令。条件指令后的个字指令。当当n=2n=2,且条件得到满足,就执行紧随此且条件得到满足,就执行紧随此指
32、令 后 的指 令 后 的 1 1 个 双 字 指 令 或 者个 双 字 指 令 或 者 2 2 条 单条 单字指令。字指令。当条件不满足,就依当条件不满足,就依n n的值执行的值执行1 1条或条或2 2条条NOPNOP指令。指令。例例3-3 编写计算编写计算 的主要程序部分。的主要程序部分。 . .bssbss x,4 x,4 ;为;为X X建立建立4 4个单元,个单元, ;放置放置X1X1、X2X2、X3X3、X4X4 . .bssbss y,1 y,1 ;为;为Y Y建立建立1 1个单元,放置个单元,放置Y Y STM #xSTM #x,AR1 AR1 ;将;将X1X1的地址传给的地址传给
33、AR1AR1 STM #3STM #3,AR2 AR2 ;将循环次数将循环次数3 3传给传给AR2AR2 LD #0LD #0,A A ;对;对A A清零清零loop: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中中特点特点2 2特点特点1 14单条指令的重复操作单条指令的重复操作 重复执行(重复执行(RCRC)+1+
34、1次。次。RCRC内容不能编程设置,内容不能编程设置,只能由重复指令(只能由重复指令(RPTRPT和和RPTZRPTZ)中的操作数加载。中的操作数加载。操作数操作数n n的最大值为的最大值为65 65 535535,最大重复执行次数,最大重复执行次数为为65 535+165 535+1。 一旦重复指令被取一旦重复指令被取指、译码,直到重指、译码,直到重复循环完成以前,复循环完成以前,对所有的中断(包对所有的中断(包括括 ,但不包,但不包括括 )均不响应。)均不响应。 功能功能重复执行下一条指令重复执行下一条指令 NMIRS重复过程重复过程当当RPTRPT指令执行时指令执行时:首先把循环的次数装
35、入循环计数器(首先把循环的次数装入循环计数器(RCRC),),其循环次数其循环次数n n由一个由一个1616位单数据存储器操作数位单数据存储器操作数 SmemSmem或一个或一个8 8位或位或1616位常数位常数k k或或lklk给定。这样,给定。这样, 紧接着的下一条指令会循环执行紧接着的下一条指令会循环执行n+1n+1次。次。循环循环,RCRC在执行减在执行减1 1操作时不能被访问。操作时不能被访问。注意:注意:该循环内不能套用循环。该循环内不能套用循环。 当当RPTZRPTZ指令执行时指令执行时:对目的累加器对目的累加器dstdst清清0 0, 循环执行下一条指令循环执行下一条指令n+1
36、n+1次。次。 例例3-5 利用单条指令的重复操作对数组利用单条指令的重复操作对数组x5=0 x5=0,0 0,0 0,0 0,00进行初始化。进行初始化。. .bssbss 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各单元清零各单元清零或者或者. .bssbss x,5 x,5S
37、TM #x,AR1STM #x,AR1RPTZ A,#4RPTZ A,#4;对;对A A清零并设置重复执行下条指令清零并设置重复执行下条指令5 5次次STL A,STL A,* *AR1+AR1+特点特点5块重复操作块重复操作 利用利用C54xC54x内部的块重复计数器(内部的块重复计数器(BRCBRC,加载值加载值可为可为0 065 53565 535)、块重复起始地址寄存器)、块重复起始地址寄存器(RSARSA)、)、块重复结束地址寄存器(块重复结束地址寄存器(REAREA)与程与程序块重复指令序块重复指令RPTBRPTB,可对紧随可对紧随RPTBRPTB、由若干条由若干条指令构成的程序块
38、进行重复操作。指令构成的程序块进行重复操作。功能功能将重复操作的范围扩大到任意长度的循环回路将重复操作的范围扩大到任意长度的循环回路 注意注意1.1.RPTRPT指令一旦执行,不会停止操作,指令一旦执行,不会停止操作,即使有中断请求也不响应;即使有中断请求也不响应;2.RPTB2.RPTB指令可以响应中断;指令可以响应中断;例例3-6 对数据组对数据组x5x5中的每个元素加中的每个元素加1 1。. .bssbss x,5 x,5 ;为数组为数组x x分配分配5 5个存储单元个存储单元begin: LD #1,16,B begin: LD #1,16,B ;将将1 1左移左移1616位放入位放入
39、B B的的 ;高端字的最低位高端字的最低位STM #4,BRC STM #4,BRC ; 4BRC4BRC,(PCPC)+2 +2 RSARSA STM #x,AR4STM #x,AR4;将;将x x的首地址赋给的首地址赋给AR4 AR4 RPTB next-1RPTB next-1;将将NEXT-1 NEXT-1 REAREA ADD ADD * *AR4,16,B,A AR4,16,B,A ;x x地址的内容左移地址的内容左移1616位加位加 ; B B的高端字,结果放的高端字,结果放A ASTH A,STH A,* *AR4+ AR4+ ;将;将A A的高端字存入的高端字存入x x单元,
40、单元, ;完成加完成加1 1操作操作next: LD #0,B next: LD #0,B ;对;对B B清零清零 ;必必需需next-1next-1作为结束地址作为结束地址对寄存器的占用对寄存器的占用6循环的嵌套循环的嵌套 执行执行RPTRPT指令时指令时占用占用RPTCRPTC寄存器(重复计数器);寄存器(重复计数器);执行执行RPTBRPTB指令时要用到指令时要用到BRCBRC、RSARSA和和RSERSE寄存器。只有寄存器。只有一套块重复寄存器,一套块重复寄存器,故故块重复操作不能嵌套。块重复操作不能嵌套。 由于由于RPTRPT与与RPTBRPTB两者用了不同的寄存器,因此两者用了不同
41、的寄存器,因此RPTRPT指指令可以嵌套在令可以嵌套在RPTBRPTB指令中,实现循环的嵌套。指令中,实现循环的嵌套。执行执行BANZBANZ指令指令只占用辅助寄存器只占用辅助寄存器ARxARx。不会与不会与RPT RPT RPTBRPTB指令指令相冲突。相冲突。嵌套原则嵌套原则参与嵌套循环的寄存器不能重复使用参与嵌套循环的寄存器不能重复使用 图3-3 一个三重循环嵌套结构第三节第三节 流水线操作技术流水线操作技术 流水线流水线操作操作在执行多条指令时,将每条指令的在执行多条指令时,将每条指令的预取指、取指、译码、寻址、读取预取指、取指、译码、寻址、读取操作数、执行等阶段,操作数、执行等阶段,
42、相差一个阶相差一个阶段段地地重叠重叠地执行。地执行。流水流水线操线操作作的的优点优点一条一条k k段流水能在段流水能在k k+ +(n n-1-1)个周期内处理个周期内处理n n条指令。其前条指令。其前k k个周期用于完成第一条指令个周期用于完成第一条指令,其余,其余n n-1-1条指令的执行需要条指令的执行需要n n-1-1个周期。而个周期。而非流水处理器上执行非流水处理器上执行n n条指令则需要条指令则需要nknk 个周个周期。当指令条数期。当指令条数n n较大时,可认为每个周期较大时,可认为每个周期内执行的最大指令个数为内执行的最大指令个数为k k。 预取指预取指P取指取指F译码译码D寻
43、址寻址A读取操作数读取操作数R执行执行X流水线操作流水线操作 在第一个机在第一个机器周期用器周期用PCPC中的内容加中的内容加载载PABPAB 在第二个机器周在第二个机器周期用读取到的指期用读取到的指令字加载令字加载PBPB。 第三个周期用第三个周期用PBPB的内容加载指令寄存器的内容加载指令寄存器IRIR,对,对IRIR内的指令进行译码,产生执行内的指令进行译码,产生执行指令所需要的一系列控制信号。指令所需要的一系列控制信号。 预取指预取指P取指取指F译码译码D寻址寻址A读取操作数读取操作数R执行执行X流水线操作流水线操作 用数据用数据1 1读地址加载读地址加载DABDAB,或用数据读地或用
44、数据读地址加载址加载CABCAB,修正辅助修正辅助寄存器和堆栈指针。寄存器和堆栈指针。读数据读数据1 1加载加载DBDB,或读数或读数据据2 2加载加载CBCB;用数据用数据3 3写写地址加载到地址加载到EABEAB,以便在以便在流水线的最后一级将数流水线的最后一级将数据送到数据存储空间。据送到数据存储空间。 执行指令,或用执行指令,或用写数据加载写数据加载EBEB。 空转浪费周期空转浪费周期1延迟分支转移的流水线图延迟分支转移的流水线图 无延迟流水线分支转移的问题无延迟流水线分支转移的问题地址地址 指令指令a1a1,a2 a2 B b1 B b1 这是一个四周期、二字分支指令这是一个四周期、
45、二字分支指令a3 a3 i3 i3 这是任意的一周期、一字指令这是任意的一周期、一字指令a4 a4 i4 i4 这是任意的一周期、一字指令这是任意的一周期、一字指令. . .b1 j1b1 j1例例3-73-7分支转移指令流水线图分支转移指令流水线图用分支转移用分支转移指令的地址指令的地址a1a1加载加载PABPAB。 取得双字分取得双字分支转移指令支转移指令取得双字分取得双字分支转移指令支转移指令分支转移指令流水线图分支转移指令流水线图i3i3和和i4i4指令取指令取指。由于这两指。由于这两条指令处在分条指令处在分支转移指令的支转移指令的后面,虽然已后面,虽然已经取指,但不经取指,但不能进入
46、译码级,能进入译码级,且最终被丢弃。且最终被丢弃。 分支转移指令分支转移指令进入译码级进入译码级用新的值用新的值b1b1加载加载PABPAB分支转移指令流水线图分支转移指令流水线图j1j1指令取指指令取指 双字分支转移双字分支转移指令进入流水指令进入流水线的执行级线的执行级 执行执行j1j1指令指令 双字分支转移双字分支转移指令进入流水指令进入流水线的执行级线的执行级 由于由于i3i3和和i4i4指指令是不允许执令是不允许执行的,所以这行的,所以这两个周期均花两个周期均花在分支转移指在分支转移指令的执行上。令的执行上。允许跟在延迟分支允许跟在延迟分支转移指令之后的两转移指令之后的两条单字条单字
47、或一条双字或一条双字指令可以被执行指令可以被执行 延迟分支转移延迟分支转移注意注意1.1.延迟操作指令后面只有两个字的空延迟操作指令后面只有两个字的空 隙,因此不能在此空隙中安排任何隙,因此不能在此空隙中安排任何 一类分支转移指令或重复指令;一类分支转移指令或重复指令;2.2.在在CALLDCALLD或或RETDRETD的空隙中还不能安的空隙中还不能安 排排PUSHPUSH和和POPPOP指令。指令。3 3. .延迟操作指令比它们的非延迟型延迟操作指令比它们的非延迟型 指令要快,在调试延迟型指令时,指令要快,在调试延迟型指令时, 直观性稍差一些,因此希望在大多直观性稍差一些,因此希望在大多 数
48、情况下还是采用非延迟型指令。数情况下还是采用非延迟型指令。 例例3-8 在完成在完成R=R=(x+yx+y)* *z z操作后转至操作后转至nextnext。可以分别编出如下两段程序:可以分别编出如下两段程序:利用普通分支转移指令利用普通分支转移指令B B 利用延迟分支转移指令利用延迟分支转移指令BDBDLD xLD x,A LD xA LD x,A AADD yADD y,A ADD yA ADD y,A ASTL ASTL A, s STL As STL A, ssLD sLD s,T LD sT LD s,T TMPY zMPY z,A BD next A BD next STL AST
49、L A, r MPY zr MPY z,A A B next STL AB next STL A, rr(共共8 8个字,个字,1010个个T T) (共共8 8个字,个字,8 8个个T T)在空闲的随后两周期中执行下两条指令在空闲的随后两周期中执行下两条指令 XC nXC n,cndcnd ,cndcnd ,cndcnd 如果条件满足,则执如果条件满足,则执行下面行下面n n(n=1n=1或或2 2)条指令,)条指令,否则下面否则下面n n条指令改为执行条指令改为执行n n条条NOPNOP指令。指令。 2条件执行指令的流水线图条件执行指令的流水线图 条件执行指令条件执行指令XC 有下列程序:
50、有下列程序:地址地址 指令指令a1 i1a1 i1a2 i2a2 i2a3 i3a3 i3a4 XC 2a4 XC 2, condconda5 i5a5 i5a6 i6 a6 i6 条件执行指令流水线图条件执行指令流水线图XCXC指令的地址指令的地址a4a4加载到加载到PAB PAB 取取 X CX C 指 令指 令的操作码的操作码 求解求解XCXC指令所规定的条件。如果条件满指令所规定的条件。如果条件满足,则后面指令足,则后面指令i5i5和和i6i6进入译码级并执进入译码级并执行;否则不对行;否则不对i5i5和和i6i6指令译码。指令译码。1. 1. XCXC是一条单字单周期指令,与条件跳是
51、一条单字单周期指令,与条件跳 转指令相比,具有快速选择其后转指令相比,具有快速选择其后1 1或或2 2 条指令是否执行的优点条指令是否执行的优点 ;2. XC2. XC指令在执行前指令在执行前2 2个周期就已经求出个周期就已经求出 条件,如果在这之后到执行前改变条条件,如果在这之后到执行前改变条 件(如发生中断),将会造成无期望件(如发生中断),将会造成无期望 的结果的结果 。3 3. . 要尽力避免在要尽力避免在XCXC指令执行前指令执行前2 2个周期个周期 改变所规定的条件改变所规定的条件 。 4 4. . 并没有规定并没有规定XCXC指令指令后的一条或两条指后的一条或两条指 令必须是单周
52、期指令。令必须是单周期指令。注注意意CPUCPU在单个周期内两次在单个周期内两次访问双寻址存储器访问双寻址存储器3双寻址存储器的流水线冲突双寻址存储器的流水线冲突 流水线冲突原因流水线冲突原因不会产生流水线冲突的情况不会产生流水线冲突的情况(1 1)在单周期内允许同时访问)在单周期内允许同时访问DARAMDARAM的不同块。的不同块。(2 2)当流水线中的一条指令访问某一存储器块时,)当流水线中的一条指令访问某一存储器块时, 允许流水线中处于同一级的另一条指令访问允许流水线中处于同一级的另一条指令访问 另一个存储器块。另一个存储器块。(3 3)允许处于流水线不同级上的两条指令同时访)允许处于流水线不同级上的两条指令同时访 问同一个存储器块。问同一个存储器块。 是利用一次访问中对是利用一次访问中对前、后半个周期分时前、后半个周期分时进行访问的缘故。进
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 湖南师大附中思沁中学2025-2026学年高二生物第一学期期末教学质量检测试题含解析
- 2026届河南省郑州市四校高二上生物期末联考试题含解析
- 青岛远洋船员职业学院《基础曲式》2024-2025学年第一学期期末试卷
- 云南省彝良县民族中2025-2026学年物理高二上期末统考试题含解析
- 河南省周口市西华县2026届化学高二第一学期期末监测模拟试题含解析
- 海南省八校联盟2025年高二上数学期末达标检测试题含解析
- 2024年兴安盟辅警协警招聘考试备考题库及1套参考答案详解
- 生物选修3试卷含答案(3篇)
- 保定幼儿师范高等专科学校《文本数据挖掘》2024-2025学年第一学期期末试卷
- 营口职业技术学院《植物认知》2024-2025学年第一学期期末试卷
- 四川省绵阳市2024-2025学年高二上学期期末教学质量测试数学试题(解析版)
- 齐齐哈尔市辅警考试题库2025(附答案)
- 医疗器械委托研发协议
- 人民代表大会制度知识竞赛试题(附参考答案)
- 幼儿园园长培训心得体会范文
- 2025年慢病管理行业当前发展趋势与投资机遇洞察报告
- 2025年贵州省综合评标专家库评标专家考试历年参考题库含答案详解(5套)
- DG-TJ08-2144-2025 公路养护工程质量检验评定标准
- 心肌梗死患者的护理诊断与护理措施
- 统编教材初中语文单元人文主题和语文要素梳理
- 初中女生生理健康讲座
评论
0/150
提交评论