一、填空题:1.DSP芯片的结构特点主要有改进的哈佛结构、低功耗设计、高度并行性、多处理单元、特殊的DSP指令等。2.C54xDSP具有两个40位累加器。累加器A的AG或32-39位是保护位。3.软件中断都是由INTRK、TRAPK和RESET产生。4.TMS320C54X片内有8条16位主总线,它们是1条程序总线、3条数据总线、4条地址总线。5.MEMROY的作用是用于描述系统实际的硬件资源,用来定义用户设计的系统中所包含的各种形式的存储器,以及它们占据的地址范围,SECTIONS的作用是用于描述输入段怎样被组合到输出段内,在可执行程序内定义输出段,规定存储器内何处存放置输出段,允许重命名输出段。6.执行复位操作后,下列寄存器的初始值分别为:ASM=0、DP=0。7.TMS320C54x有三种类型的串行口:标准同步串行口(SPI)、缓冲串行口(BSP)、和时分多路复用串行接口(TDM)。8.桶形移位器能把输入的数据进行0-31位的左移和0-15位的右移。9.即寻址方式中的立即数有两种数值形式,数值的位数为3、5、8、9位时为短立即数;数值的位数为16位时是长立即数。10.DSP片内寄存器在C语言中一般采用指针方式来访问,常常采用的方法是将DSP寄存器地址的列表定义在头文件中(reg.h)。11.所有TMS320C54X芯片内部都包含程序存储器和数据存储器。12.直接寻址就是在指令中包含有数据存储器地址的低7位用作偏移地址,并与基地地址组成16位的数据存储器地址。13.定时器主要由3个寄存器所组成,包括定时寄存器TIM、定时周期寄存器PRD、定时控制寄存器TCR。14.链接器对段的处理主要通过MEMORY和SECTIONS两个命令完成。15.OVLY=0,则片内RAM只安排到数据存储空间。DROM=1,则部分片内ROM安排到数据空间。16.C54X的工作方式状态寄存器PMST提供了三个控制位,包括MP/非MC、OVLY、DROM。17.DSP芯片的结构特点主要有改进的哈佛结构、流水线操作、专用的硬件乘法器、快速的指令周期、特殊的DSP指令等。18.ST1的CPL=1表示选用堆栈指针(SP)的直接寻址方式。19.TMS320C54X有3个16位寄存器作为状态和控制寄存器,它们是状态寄存器ST0、状态寄存器ST1、处理器工作方式状态寄存器PMST。20.ST1的C16=0表示ALU工作在双精度算术运算方式。21.时钟发生器包括一个内部振荡器和一个锁相环(PLL)电路。22.所有的COFF文件都包含三种形式的段,分别是.text文本段、.data数据段、和.bss保留空间段。23.状态寄存器ST1中CPL=0表示使用DP,CPL=1表示选择的是使用SP。24.累加器寻址的两条指令分别是READASmem、WRITASmem二、简答题1.简述TMS320C54x的7种基本的数据寻址方式。答:1、立即寻址2、绝对寻址3、直接寻址4、间接寻址5、累加器寻址6、存储器映射寄存器寻址7、堆栈寻址2.段的作用是什么?COFF目标文件包含哪些段?答:所谓段,是指连续地占有存储空间的一个代码段或数据段,是COFF文件中最重要的概念。一个目标文件中的每一段都是分开的和各不相同的。COFF目标文件文件包含:(1)text段:可执行代码段(2)data段:已初始化数据段(3)bss段:未初始化数据的保留空间段4.什么是COFF和段?COFF目标文件包含哪些段?答:所谓段,是指连续地占有存储空间的一个代码段或数据段,是COFF文件中最重要的概念。一个目标文件中的每一段都是分开的和各不相同的。.text文本段.data数据段.bss保留空间段5.简述McBSP接口的特点。答:(1)全双工通信;(2)拥有两级缓冲发送和三级缓冲接收数据寄存器,允许连续数据流传输;(3)为数据发送和接收提供独立的帧同步脉冲和时钟信号;(4)能够与工业标准的解码器、模拟接口芯片(AICs)和其他串行A/D和D/A设备直接连接;5)支持外部移位时钟或内部频率可编程移位时钟。6)128个通道用于接收传送。(7)支持A-bis(8)接口直接连接工业标准的多媒体数字信号编解码器,A/D、D/A和模拟芯片。6.HPI8接口有几个寄存器?他们的作用是什么?答:(1)HPI存储器:用于TMS320C54X与主机间传送数据。地址从1000H到17FFH,空间容量为2K字(2)HPI地址寄存器:由主机对其直接访问,存放当前寻址HPI存储单元的地址(3)HPI数据锁存器:由主机对其直接访问,存放当前进行读/写的数据(4)HPI控制寄存器:TMS320C54X与主机都能对其直接访问,用于主处理与DSP相互握手,实现相互中断请求(5)HPI控制逻辑:用于处理HPI与主机之间的接口信号7.一个典型的DSP系统通常由哪些部分组成?画出原理框图。答:DSP芯片及DSP基本系统、程序和数据存储器、数/模和模/数转换器、模拟控制与处理电路、各种控制口和通信口、电源处理电路和同步电路等。8.简述C54X芯片的主要特点。答:(1)CPU利用其专用的硬件逻辑和高度并行性提高芯片的处理性能。(2)存储器具有192K字可寻址存储空间(包括64K字程序存储空间、64K字数据存储空间、64K字I/O空间)(3)高度专业化的指令集能够快速地实现算法并用于高级语言编程优化(4)片内外设和专用电路采用模块化的结构设计,可以快速地推出新的系列产品(5)TMS320C54X执行单周期定点指令时间为25/20/15/12.5/10ns,每秒指令数为40/66/100MIPS。(6)TMS320C54XD电源由IDLE1、IDLE2、IDLE3功耗下降指令控制功能,以便DSP工作在节电模式下,使之更适合于手机。(7)在片仿真接口,片上的JTAG接口符合IEEE149.1边界扫描逻辑接口标准,可与主机连接,用于芯片的仿真和测试。9.定时器由哪些寄存器组成,他们是如何工作的?答:定时器主要由3个寄存器所组成,包括定时寄存器TIM、定时周期寄存器PRD、定时控制寄存器TCR。定时寄存器TIM是一个减1计数器,提供定时器目前的计数值;周期定时器PRD用来存取定时时间常数;定时控制寄存器TCR中包含定时器的控制位和状态位,可以使能和屏蔽定时器,决定定时器的工作模式,用来控制定时器的操作。1.什么是定点DSP芯片和浮点DSP芯片?各有什么优缺点?解:按数据的定点格式工作的DSP芯片称为定点DSP;按数据的浮点格式工作的DSP芯片称为浮点DSP;定点DSP的价格便宜,功耗低,但运算精度低;浮点DSP的价格较高,C语言编程调试方便,运算精度高。2.简述流水线操作的基本原理。解:流水线操作是各指令以机器周期为单位相差一个时钟周期,连续并行工作的情况。其本质是DSP多条总线彼此独立地同时工作,使得同一条指令在不同机器周期内占用不同总线资源。同时,不同指令在同一机器周期内占用不同总线资源。3.C54xDSP有哪些重复操作?各有什么优点?解:有单条指令重复执行和程序块重复执行两种重复操作。单条指令重复操作功能,可以使乘法/累加和数据块传送那样的多周期指令在执行一次之后变成单周期指令,大大提高了这些指令的执行速度。利用块重复操作进行循环,是一种零开销循环。4.软件可编程等待状态发生器的功能是什么?解:软件可编程等待状态产生器可以将外部总线周期扩展到7个机器周期(C549、C5402、C5410和C5420为14个机器周期),这样’C54xDSP可以方便地与慢速的片内存储器和I/O器件接口。三、问答题(10分)1.C54xDSP的串行口有哪些类型?各有什么特点?解:有标准同步串口SP、缓冲同步串口BSP、多路缓冲串口McBSP、时分多路同步串口TMD四种。缓冲串口(BSP)是一个增强型的标准串口,它由一个全双工双缓冲串口和一个自动缓冲单元(ABU)组成。由于其中的串行口与标准串口的功能相同,因此在标准模式下,缓冲串口的操作与标准串口的工作方式是一样的。不过无论是标准模式还是自动缓冲模式,BSP都提供了一些增强功能。主要包括了可编程控制的串口时钟、可选择时钟和帧同步信号的正负极性,能够以每帧8位、10位、12位和16位传输数据。通过配置BSP的控制寄存器,BSP还能实现忽略帧同步信号的数据传输。时分复用串行口TDM采用时分复用技术,将多个外部器件复用与’C54x进行串行通信,每一个时隙对应于其中的1路通信。TDM可以和外部的多个应用接口实现方便灵活的数据交换。’C54x最多可以和8个外部器件接口通信。多通道缓冲串口(McBSP)是在缓冲串口的基础上发展起来的增强版。McBSP具有高速、全双工、可与各种总线标准的器件直接接口等特点,它为DSP使用者在不同方面的应用提供了方便,尤其适合在通信领域的应用。二、指令解释1、MAC*AR3+,*AR4+,A,B;B=A-*AR3+*AR4;AR3=AR3+1;AR4=AR4+12、SUB#12345,8,A,B;B=A-1234583、ADD*AR2+,*AR2-,A;A=*(AR2)+*(AR2+1)4、RPT#99NOP;重复NOP100次5、MVDD*AR3+,*AR5+;数据存储器内部传送数据AR3→AR5,且指令结束后AR3与AR5加16、ABDST*AR3+,*AR4+;B=(*AR3-*AR4)167、CALAA;按累加器规定的地址调用子程序8、STT,*AR7-*AR7=T,AR7=AR7-19、DSTB,*AR1+AR1=B,AR1=AR1+110、10、STA,*AR4+||LD*AR4-,AAR4=A,AR4=AR4+1||A=AR4,AR4-111、LD#0032H,4,A;立即数0032H先左移4位后,再加载累加器A12、STM#1000H,*AR2;立即数1000H存储到AR2指向的地址单元13、MAC#345,A,B;立即数345与T寄存器内值相乘后与累加器A相加,结果加载累加器B14、MVDD*AR3-,100H;AR3指向的地址单元的值传送给地址100H,AR3中地址减一15、LDM*AR1,A;AR1指向的地址单元的值加载到累加器A16、LD#80H,A把立即数80H装入累加器17、WRITASMEM把Smem所指定的数据存储单元中的一个数传送到累加器A所指定的成序存储单元18、PORTRFIFO,*AR5把一个数从端口为FIFO的I/O口复制到AR5寄存器所指向的数据存储单元中19、LDMMMR,A;将MMR装入累加器A中20、MVKDSAMPLE,*AR521、ADD*AR3+,14,A;将AR3左移14加上A→AAR3=AR3+122、MPYATEMP2;B=A.Temp2.T=Temp223、STA,*AR4+23、||LD*AR4-,A24、DSTB,*AR1-;B存到长字单元AR1中,且AR减125、MACD*AR2-,COEFFS,A26、26、STLA,@quot;将累加器A的低16位字存放在quot的存储单元中27、ADD#4568H,8,A,B;将4568H左移8位与A相加,赋给B28、LDMAR1,A;存储器映像寄存器寻址方式,将映像寄存器加载累加器AR1→A的低位,其余位置为029、MVDD*AR3+,*AR5+;数据存储器内部传送数据AR3→AR5,且指令结束后AR3与AR5加130、MPYATEMP2;B=A.Temp2.T=Temp2四、编程1.用汇编语言编制计算60iiyx.globalstart.mmregs.dataTable:.word1,1,1,1,1,1.textstart:STM#Table,AR1LD#0,ARPT#5ADDC*AR1+,Aend:bend2.编一程序,首先实现对DATA开始的5个单元赋初值0,1,2,3,4,5,然后再对每个单元内容加1。;chushihuax[5]={0,1,2,3,4}binduimeigedanyuanjia1.titlelian.asm.mmregs.bssx,5stack.use