TMS320C55xDSP教材习题答案_第1页
TMS320C55xDSP教材习题答案_第2页
TMS320C55xDSP教材习题答案_第3页
TMS320C55xDSP教材习题答案_第4页
TMS320C55xDSP教材习题答案_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

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

文档简介

1、第一章1 简述典型实时数字信号处理系统组成部分。答: 包括: 抗混叠滤波器(Anti-aliasing filter) 、 模数转换器AD(C Analog-to-DigitalConverter ) 、数字信号处理、数模转换器DAC( Digital-to-Analog Converter )和抗镜像滤波器 (Anti-image filter) 。2.简述X86处理器完成实时数字信号处理的优缺点。答:利用X86处理器完成实时数字信号处理。特点是处理器选择范围宽,主板及外设资源丰富,有多种操作系统可供选择,开发、调试较为方便;缺点是数字信号处理能力不强,硬件组成较为复杂,系统体积、重量较大,

2、功耗较高,抗环境影响能力较弱。3简述数字信号处理器的主要特点。答: ( 1 )存储器采用哈佛或者改进的哈佛结构;( 2)内部采用了多级流水;( 3)具有硬件乘法累加单元;( 4)可以实现零开销循环;( 5)采用了特殊的寻址方式;( 6)高效的特殊指令; ( 7)具有丰富的片内外设。4给出存储器的两种主要结构,并分析其区别。答:存储器结构分为两大类:冯诺依曼结构和哈佛结构。冯诺依曼结构的特点是只有一个存储器空间、一套地址总线和一套数据总线;指令、 数据都存放在这个存储器空间中,统一分配地址,所以处理器必须分时访问程序和数据空间。哈佛结构程序存储器空间和数据存储器空间分开,具有多套地址、数据总线,

3、哈佛结构是并行体系结构,程序和数据存于不同的存储器空间,每个存储器空间独立编址、独立访问。5简述选择数字信号处理器所需要考虑的因素。答:应考虑运算速度、算法格式和数据宽度、存储器类型、功耗和开发工具。6给出数字信号处理器的运算速度指标,并给出其具体含义。答:常见的运算速度指标有如下几种:(1) 1)指令周期:执行一条指令所需的最短时间,数值等于主频的倒数;指令周期通常以ns (纳秒)为单位。例如,运行在200MHz的TMS320VC5510勺指令周期为5ns。(2) MIPS:每秒百万条指令数。(3) MOPS每秒百万次操作数。(4) MFLOPS每秒百万次浮点操作数。(5) BOPS每秒十亿

4、次操作数。(6) MAC时间:一次乘法累加操作花费的时间。大部分DSP芯片可在一个指令周期内完成MACt作;(7) FFT执行时间:完成N点FFT所需的时间。FFT运算是数字信号处理中的典型算法而且应用很广,因此该指标常用于衡量DSP芯片的运算能力。第二章1. TMS320C55x DSP有哪些特征和优点(表 2-2) 答:一个32 位 x 16 位指令缓冲队列:缓冲变长指令并完成有效的块重复操作;两个 17 位 x17 位的乘法累加器:在一个单周期执行双乘法累加操作;一个40位算术逻辑单元(ALU):实现高精度算术和逻辑操作;一个 40 位桶形移位寄存器:能够将一个40 位的计算结果最高向左

5、移31 位或向右移 32 位; 一个16位算术逻辑单元(ALU):对主ALU并行完成简单的算术操作; 4 个 40 位的累加器:保留计算结果,减少对存储单元的访问; 12条独立总线,其中包括3 条读数据总线、2 条写数据总线、5 条数据地址总线、1 条读程序总线、1 条程序地址总线:为各种计算单元并行地提供将要处理的指令和操作数一一利用 C55x的并行机制的优点; 用户可配置IDLE 域:改进了低功耗电源管理的灵活性。2. TMS320C55x DSP的内部结构由哪几部分组成(图 2-1 )答:C55x有一条32位的程序数据总线(PB), 5条16位数据总线(BB CB DB EB、 FB)和

6、1条24位的程序地址总线及 5条23位的数据地址总线,这些总线分别与 CPUffi连。 总线通过存储器接口单元( M)与外部程序总线和数据总线相连,实现CPU寸外部存储器的访问;指令缓冲单元(I)、程序流程单元(P)、地址流程单元(A)和数据计算单元(D); 以及存储器接口单元(M) 。3. 简述指令缓冲单元(I )、程序流程单元(P)、地址流程单元(A)和数据计算单元(D) 的组成和功能答:C55x的指令缓冲单元由指令缓冲队列旧Q (Instruction Buffer Queue)和指令译码器组成。在每个 CPU周期内,I单元将从读程序数据总线接收的4B程序代码放入指令缓冲队列,指令译码器

7、从队列中取6B程序代码,根据指令的长度可对8位、16位、24位、32位和48位的变长指令进行译码,然后把译码数据送入P单元、A单元和D单元去执行。程序流程单元由程序地址产生电路和寄存器组构成。程序流程单元产生所有程序空间的地址,并控制指令的读取顺序。地址流程单元包括数据地址产生电路、算术逻辑电路和寄存器组构成。数据地址产生电路(DAGEN能够接收来自I单元的立即数和来自 A单元的寄存器产生读取数据空间的地址。 对于使用间接寻址模式的指令,由 P单元向DAGE觥明采用的寻址模式。数据计算单元由移位器、算术逻辑电路、乘法累加器和寄存器组构成。D 单元包含了CPU的主要运算部件。D单元移位器能够接收

8、来自 I单元的立即数,能够与存储器、 I/O空 间、A单元寄存器、D单元寄存器和P单元寄存器进行双向通信,此外,还可以向D单元的ALU和A单元的ALU提供移位后的数据。4. TMS320C55x DSP的流水线操作包括多少个阶段每一阶段完成什么操作答: 两个。 第一阶段是取流水线,即从内存中取出32 位的指令包,放入指令缓冲队( IBQ)中,然后为流水线的第二阶段提供48 位的指令包。第二阶段是指执行流水线,这部分的功能是对指令进行解码,完成数据的存取和计算。5. TMS320C55x DSPf哪些片上外设答:两个20 位的定时器。一个看门狗定时器。6 通道直接存储器存取控制器(DMA) 。外

9、部存储器接口 (EMIF)。三个串口支持最多三个多通道缓冲串口( McBSP或最多两个多媒 体/安全数字卡接口。增强型主机接口 (EHPI)是一个16位的并行接口。可编程锁相环(DPLD 时钟发生器。USB全速(12Mbps)从端口。 I2C主从接口。一个实时时钟。6. TMS320C55X的寻址空间是多少当 CPUB问程序空间和数据空间时,使用的地址是多少位 的答:C55x的寻址空间为16MB当CPU从程序空间读取程序代码时,使用24位地址,当访问数据空间时,使用 23位的地址。但是在访问数据空间时,将23位地址左移一位,并将地址总线上的最低有效位(LSB)置0,使得在对数据空间或程序空间寻

10、址时,地址总线都 传送24位地址。7. 符合标准的测试/仿真接口的引脚有哪几个答:TCK弓I脚、TDI 弓|脚、TDI 弓|脚、TMS TRST EMU0 EMU1/OFF-第三章1 . C55x DSP支持哪三种寻址模式答:C55x DSP支持三种寻址模式,绝对寻址模式;直接寻址模式;间接寻址模式。2 .简述k16绝对寻址和k23绝对寻址不同点和相同点。答:不同k16绝对寻址的指令其操作数为 *abs16(#k16),其中k16是一个16位的无符 号常数。寻址方法是将 7位的寄存器DPH(扩展数据页指针 XDP的高位部分)和k16级联形 成一个23位的地址,用于对数据空间的访问。该模式可以访

11、问一个存储单元和一个存储映 射寄存器。和k23绝对寻址的指令其操作数为 *(#k23),其中k23是一个23位的无符号常数。 使用 这种寻址方法的指令将常数编码为3字节(去掉最高位)。相同点:k16绝对寻址和k23绝对寻址的指令不能与其他指令并行执行。3 .简述C55x DSP并行指令遵守的规则。答:在并行指令中,必须遵守三条基本规则: 两条指令的总长度不能超过6个字节。在指令的执行过程中不存在操作器、地址产生单元、总线等资源冲突。 其中一条指令必须有并行使能位或两条指令符合软-双并行条件。4 . 已知 AC1=0200FC00H AR3=0200H (200) =340014 MOV *AR

12、3+ << #16, AC1执行上面指令后,AC1和AR3的值分别是多少答:BeforeAfterAC1 00 0200 FC00 AC1 00 3400 0000AR3 0200AR3 0201200 340020034005 .已知 AC0=EC000000HAC1=00000000H AR1=0200H (200) =3300H, TC2=1。ADDSUBCC AR1, AC0, TC2, AC1执行上面指令后,AC1 AR1和AC0的值分别是多少答:BeforeAfterAC0 00 EC00 0000AC1 00 0000 0000AR1 0200 200 3300TC2

13、 1SXMD 0M40 0ACOV1 0CARRY 0AC0 00 EC00 0000AC1 01 1F00 0000AR1 0200200 3300TC2 1SXMD 0M40 0ACOV1 1CARRY 16 .已知 AC0=H AC1=00230000H AR1=EF00H AR2=0201HCDP=A067H执行下面指令后,AMAR *AR2+ :MAC uns(*AR1), uns(*CDP), AC0 >> #16答:BeforeAC0 00 6900 0000AC1 00 0023 0000*AR1 EF00AR2 0201*CDP A067ACOV0 0ACOV1

14、0CARRY 0M40 0FRCT 0SATD 07,已知 PC=004042HAfterAC0 00 95C0 9200AC1 00 0023 0000*AR1 EF00AR2 0202*CDP A067ACOV01ACOV1 0CARRY 0M40 0FRCT 0SATD 0H根据下表的情况AC0=0000000001ACOARt AR2和AC1的值分另是多少B branch执行上面指令后,PC和AC0分别是多少答:BeforeAfterPC 004042PC 006047AC0 00 0000 0001 AC0 00 0000 0000第四章1.根据任务调度的方式不同,C55x处理器程序

15、可以分为哪两类并简述其优缺点。答:一类是由程序自己完成任务调度,另一类是由嵌入式操作系统完成任务调度。由程序自身完成任务调度程序运行效率高,对硬件中断响应快,程序运行稳定,适合于任务较为单一,实时性较强的应用;嵌入式操作系统完成任务调度,可以将应用分解为多个任务,简化了应用系统软件设计,更为重要的是良好的多任务设计有助于提高系统的稳定性和可靠性。2请利用指针将IO 空间中地址从0x100 到 0x107 中的值放置到数据空间*ptr 指针当中。答: ioport int *a;Int *ptrvoid foo (void)i = 0x100;a = &i;for(int j=0;j&l

16、t;=7;j+) ptr j=aj;3在o3 级优化情况下,利用中断读取0x100000 地址,并将值存放到变量in_flag 中。答:变量in_flag 定义volatile unsigned int in_flag;中断服务程序interrupt void int_handler()In_flag= (unsigned int *)0x100000;4.在C语言编写的程序中,分别给出利用 C语言和嵌套汇编语言打开全局中断的程序代码。 答:C语言打开全局中断IRQ_globalEnable();嵌套汇编语言打开全局中断asm ( “ BCLR ST1_INTM” ) ;5给出函数int fn

17、(long l1, long l2, long l3, int *p4, int *p5, int *p6, int *p7,int *p8, int i9, int i10)中传送参数所使用的寄存器。答:输入参数通过 AC0 ACI AC2、AR0 AR1 AR2、AR3 AR4 T0、T1传递,输出参数 通过T0传送参数。6.在.sine数据段中定义一个16点的正弦表,其数值采用Q15T式存放。(Q1出M、数点在第 15位)答:.sina.word 0,12539,23170,30273.word32767, 30273,23170,12539.word0,-12539,-23170,-3

18、0273.word-32767,-30273,-23170,-125397在.mydata 段中为 a,b,c 分别预留10、 20、 5个字的空间。答:.def _a.def _b.def _c.sect mydata_a:.space 10*16_b:.space 20*16;_c: .space 5*16;8.请给出调用图像和视频处理库所需要的.h文件和.lib 文件。答:调用图像和视频处理库需要需要包含文件,如过采用小模式编程需要,而采用大模式编程需要库。第五章1 . C55x的片内外设可以分为哪几类这些片上外设可以通过什么工具完成片上外设的操作答:可以分为时钟与定时器类、 外部设备连

19、接接口、 信号采集和通信接口类以及其他外 设。用户可以通过片上外设支持库完成外设的操作,片上外设支持库为用户提供了控制片上外设的函数、宏等工具,用户可以通过程序或者DSP/BIOS完成这些函数和宏的调用。2 .片上外设支持库具有什么特点答:1)采用标准协议对外设进行编程。片上外设支持库采用标准协议实现片上外设的 编程,这些协议包括数据类型、定义外设配置的宏定义,以及实现各种外设操作的函数等;2)基本资源管理。可以通过程序实现多通道外设的资源管理;3)设备的符号描述。片上外设支持库通过对外设寄存器和寄存器域的符号定义,使得 程序在不同DSP之间的移植变得容易,而当DSP的版本发生升级时,可以最大

20、程度减少程序 的修改。3 .如何测试时钟发生器是否正常工作答:(1)检查DSP的时钟输入引脚 CLKIN、时钟输出引脚 CLKOU下口时钟模式引脚 CLKMD连接是否正确,正常情况下CLKIN应接时钟源,而 CLKM而拉高或拉低,CLKOUTZ是信号输出引脚;(2)系统加电后测量 CLKIN引脚时钟输入是否正常,信号的高低电平及占空比是否满足需要;(3)在没有进行软件设置的情况下,DSP在复位后CLKOUT勺输出直接受CLKM的制,当CLKM时高,CLKOUT勺输出频率将等于 CLKIN的频率,CLKMD低贝U CLKOUT俞出将 等于CLKIN的频率的1/2;(4)如果以上步骤运行正常, 则

21、利用软件设置 CLKMD?存器,使时钟产生器工作于 PLL 锁相环模式下,此时再检测 CLKOUTt号,查看锁相环是否正常工作。4 .设数字信号处理器定时器输入时钟频率为100MHz如果要求定时器发送中断信号或同步事件信号的频率为1000次每秒,需要如何对定时器进行设置答:根据公式TINT频率 一输入时钟频率(TDDR 1) (PRD 1)输入时钟频率为 100MHz由于TDDM 4位,这里我们把 TDDR为9,则PRD为 9999。5 .为了完成McBS珅口的测试,需要其在回环模式下工作,试画出回环模式工作框图。答:DR6 .系统需要通过 EHPI接口完成引导,在该引导模式下需要如何对通用引

22、脚进行设置答:在EHPI引导模式下,BOOTM3:0的值为1101B,下面给出通过 GPIO设置DSP上电 方式示意图。7 .如何对通用输入输出引脚进行测试答:(1)输入口测试输入口测试步骤如下:1)通过I/O方向寄存器IODIR设置某一个引脚为输入方向;2)在已设置为输入方向的引脚上外加LVTTL信号;3) DSP访问I/O数据寄存器IODATA查看引脚上的逻辑电平,与外加 LVTTL电平比较来 测试输入口是否工作正常。(2)输出口测试输入口测试步骤如下:1)通过I/O方向寄存器IODIR设置某一个引脚为输出方向;2)在I/O数据寄存器IODATA上设置这个引脚的逻辑电平;3)测量引脚的电平

23、,与设置的逻辑电平相比较来检测输出口是否正常工作。8. DMAGCR存器中的EHPIEXCLB设置为0或1时有何区别答:当 EHPIEXCL=0 HPI 和 DMA!道共享 DARAM SARA附口 EMIF;当 EHPIEXCL=1 HPI 独占DARAM口 SARAMI DMA!道只能访问 EMIF和外设。第六章1 . CCS集成开发环境有哪些功能答:CCS的功能十分强大,它集成了代码的编辑、编译、链接和调试等功能,而且支持 C和汇编混合编程,其主要功能如下。集成可视化代码编辑界面 :可直接编写C、汇编、C和汇编混合、.H文件、.cmd文件等; 集成代码生成工具:包括汇编器、优化 C编译器

24、、链接器等,将代码的编辑、编译、链接和 调试等功能集成到一个开发环境中;基本调试工具:可以装入执行代码(.out文件),查看寄存器窗口、存储器窗口、反汇编窗口和变量窗口,并且支持C源代码级调试;断点工具:能在调试程序的过程中,设置软件断点、硬件断点、数据空间读/写断点、条件断点(使用GEL编写表达式)等; 探针调试工具(probe points ):可用于算法仿真,数据监视等;性能分析工具(pro巾le points):可用于评估代码执行的时钟数;实时分析和数据可视化工具:例如:数据的图形显示工具,可绘制时域 /频域波形、眼图、星座图、图像等,并具有 自动刷新功能(使用 Animate命令运行

25、);GEL工具:用户利用 GEL扩展语言可以编写自己 的控制面板/菜单,设置GEL菜单选项,可方便直观地修改变量,配置参数等;支持实时数据交换RTDX(Real Time Data Exchange)技术:该技术可在不中断目标系统运行的情况下, 实现DSP与其他应用程序(OLE)的数据交换;提供DSP/BIOS工具:增强对代码的实时分析能力,如分析代码执行的效率、调度程序执行的优先级、方便管理或使用系统资源(代码/数据占用空间,中断服务程序的调用,定时器使用等),从而减少了开发人员对硬件资源熟悉程度的依赖性;支持多DSP的调试。2 .在CCSt成开发环境中可以使用的仿真设备包括哪些答:仿真设备

26、包才软仿真器(Simulator )、各种硬仿真器(Emulator )、TI或第三方公 司提供的DSPJ学者套件(DSK和DS印估板(EVM等。3 . CCS的所有窗口都含有一个关联菜单,如何打开一个窗口的关联菜单答:只要在该窗口中单击右键,就可以打开关联菜单。4 . CCS为用户提供了哪几种常用的工具条答:常用工具条包括:标准工具条、编辑工具条、项目工具条和调试工具条。5 .怎样创建一个新的工程项目答:工程项目的创建过程包括:(1)在主菜单“ Project ”中选择“ NeW'选项,弹出下图所示的对话框。(2)在“Project Name ”域中输入要创建的项目名,在"

27、 Location ”域输入或选择将 要创建的工程项目所处的目录,对于每个新建的工程项目,最好建立不同的目录。(3)从“ Project ”下拉列表中选择要创建的工程项目的配置(可执行程序.out或目标库函数.lib )。(4)在“ Target ”下拉列表中选择将要创建的工程项目所对应的目标器件系列 (TMS320C54xx TMS320C55xx TMS320C62xx§)。(5)单击“ Finish ”按钮就完成了一个工程项目的创建。6 .如果工程文件是基于 C语言编写的,怎样向工程项目中添加运行时支持库答:在主菜单中选择"Project "中的"

28、Add Files to Project ”选项,或在工程项目 浏览窗口单击项目名,在弹出的对话框中选择“ Add Files ”选项。在弹出的对话框中选择 要添加文件的目录,在CCS勺安装目录“c5500cgtoolslib ”下,在添加文件对话框的“文 件类型”下拉列表中要选择" Object and Library Files (*.o*,*.l*)”,向工程里添加“”或文件。7 .在调试程序时,经常使用断点,它的作用是什么怎样设置和删除断点答:程序运行过程中如果遇到断点,就会暂时停止运行,回到调试状态。用户可以通过查看变量、图形等方式,发现程序中的错误。断点可以设置在源代码行

29、上,也设置在反汇编窗口中的指令行上。有三种方法可以快 速地设置断点。 在反汇编窗口或含有C/C+的源代码窗口中,将光标移动到需要设置断点的指令行上,单击右键,在弹出的菜单中选择" Toggle breakpoint ”命令,在本行左边会出现红 色标记,表示此处有断点。 在反汇编窗口,双击要设置断点的指令行,在源代码窗口,双击指令行左边的页边,即可完成断点的设置。 可以单击工具条上的按钮来添加断点。可以以下使用任何一种方法删除断点。在反汇编窗口或含有 C/C+的源代码窗口中,将光标移动到需要已经设有断点的指 令行上,单击右键,在弹出的菜单中选择" Toggle breakpo

30、int ”命令来取消断点。 在反汇编窗口,双击已经设有断点的指令行,在源代码窗口,双击设有断点的指 令行左边的页边,即可取消断点。可以单击工具条上的按钮来删除断点。选择"Debug"菜单中"Breakpoints ”命令,出现如图 6-38所示的“Break/Probe Points ”对话框,在断点列表中选择要删除的断点,单击“ Delete ”按钮,单击 “OK按钮即可。8 .什么是探针点它的作用是什么怎样设置和删除探针点答:探针点(Probe Point )是CCS中比较有特色的工具,程序运行到探针点会执行特 定的操作,如刷新图形、文件输入/输出等。有两种方

31、法可以很方便地设置探针点:将光标移动到需要设置探针点的位置,单击右键,在弹出的菜单中选择"Toggle Probe Point ”命令,该行最左边将出现一个蓝色菱形探针点 标志;或单击项目工具条上的按钮完成探针点的设置。探针点的删除:在反汇编窗口或含有C/C+的源文件中,将光标移动到已设置探针点的位置,单击右键,在弹出的菜单中选择“ Toggle Probe Point ”命令即可删除探针点;或单 击项目工具条上的按钮删除探针点。单击项目工具条上的按钮可以删除所有探针点。第七章R1、R2的电阻阻值1 .如果电源芯片 TPS54110的输出电压为,应如何设置答:根据公式R1R2 0.891Vout0.891如果R2为,将值带入公式,最后得到R1为KQO2 .请给出TMS320VC5510勺上电力

温馨提示

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

评论

0/150

提交评论