新闻中心

EEPW首页 > 汽车电子 > 学习方法与实践 > DSP入门导读(4)

DSP入门导读(4)

——
作者:时间:2007-10-29来源:嵌入式技术网收藏
什么是boot loader? 

的速度快,EPROM或flash的速度较慢,而片内的RAM很快,片外的RAM也较快。为了使充分发挥它的能力,必须将程序代码放在RAM中运行。为了方便的将代码从ROM中搬到RAM中,在不带flash的DSP中,TI在出厂时固化了一段程序,在上电后完成从ROM或外设将代码搬到用户指定的RAM中。此段程序称为“boot loader”。   



TMS320C3x如何boot? 

在MC/MP管脚为高时,C3x进入boot状态。C3x的boot loader在reset时,判断外部中断管脚的电平。根据中断配置决定boot的方式为存储器加载还是串口加载,其中ROM的地址可以为三个中的一个,ROM可以为8位。   



Boot有问题如何解决? 
1)仔细检查boot的控制字是否正确。 
2)仔细检查外部管脚设置是否正确。 
3)仔细检查hex文件是否转换正确。 
4)用仿真器跟踪boot过程,分析错误原因。   



DSP为什么要初始化? 

DSP在RESET后,许多的寄存器的初值一般同用户的要求不一致,例如:等待寄存器,SP,中断定位寄存器等,需要通过初始化程序设置为用户要求的数值。 初始化程序的主要作用: 
1)设置寄存器初值。 
2)建立中断向量表。 
3)外围部件初始化。   



DSP有哪些数学库及其它应用软件? 

TI公司为了方便客户开发DSP,在它的网站上提供了许多程序的示例和应用程序,如MATH库,FFT,FIR/IIR等,可以在TI的网页免费下载。   



如何获得DSP专用算法? 

TI有许多的Third Party可以通过DSP上的多种算法软件。可以通过TI的网页搜索你所需的算法,找到通过算法的公司,同相应的公司联系。注意这些算法都是要付费的。   



eXpressDSP是什么? 

eXpressDSP是一种实时DSP软件技术,它是一种DSP编程的标准,利用它可以加快你开发DSP软件的速度。以往DSP软件的开发没有任何标准,不同的人写的程序一般无法连接在一起。DSP软件的调试工具也非常不方便。使得DSP软件的开发往往滞后于硬件的开发。 eXpressDSP集成了CCS(Code Composer Studio)开发平台,DSP BIOS实时软件平台,DSP算法标准和第三方支持四部分。利用该技术,可以使你的软件调试,软件进程管理,软件的互通及算法的获得,都便的容易。这样就可以加快你的软件开发进程。 
1)CCS是eXpressDSP的基础,因此你必须首先拥有CCS软件。 
2)DSP BIOS是eXpressDSP的基本平台,你必须学会所有DSP BIOS。 
3)DSP算法标准可以保证你的程序可以方便的同其它利用eXpressDSP技术的程序连接在一起。同时也保证你的程序的延续性。   



为什么要用DSP? 

3G技术和internate的发展,要求处理器的速度越来越高,体积越来越小,DSP的发展正好能满足这一发展的要求。因为,传统的其它处理器都有不同的缺陷。MCU的速度较慢;CPU体积较大,功耗较高;嵌入CPU的成本较高。 DSP的发展,使得在许多速度要求较高,算法较复杂的场合,取代MCU或其它处理器,而成本有可能更低。   



如何选择DSP? 

选择DSP可以根据以下几方面决定: 
1)速度: DSP速度一般用MIPS或FLOPS表示,即百万次/秒钟。根据您对处理速度的要求选择适合的器件。一般选择处理速度不要过高,速度高的DSP,系统实现也较困难。 
2)精度: DSP芯片分为定点、浮点处理器,对于运算精度要求很高的处理,可选择浮点处理器。定点处理器也可完成浮点运算,但精度和速度会有影响。 
3)寻址空间: 不同系列DSP程序、数据、I/O空间大小不一,与普通MCU不同,DSP在一个指令周期内能完成多个操作,所以DSP的指令效率很高,程序空间一般不会有问题,关键是数据空间是否满足。数据空间的大小可以通过DMA的帮助,借助程序空间扩大。 
4)成本: 一般定点DSP的成本会比浮点DSP的要低,速度也较快。要获得低成本的DSP系统,尽量用定点算法,用定点DSP。 
5)实现方便: 浮点DSP的结构实现DSP系统较容易,不用考虑寻址空间的问题,指令对C语言支持的效率也较高。 
6)内部部件:根据应用要求,选择具有特殊部件的DSP。如:C2000适合于电机控制;OMAP适合于多媒体等。 
要了解DSP芯片的性能,本网中的"DSP及相关器件"中有介绍。   



DSP同MCU相比的特点? 

1)DSP的速度比MCU快,主频较高。 
2)DSP适合于数据处理,数据处理的指令效率较高。 
3)DSP均为16位以上的处理器,不适合于低档的场合。 
4)DSP可以同时处理的事件较多,系统级成本有可能较低。 
5)DSP的灵活性较好,大多数算法都可以软件实现。 
6)DSP的集成度较高,可靠性较好。   



DSP同嵌入CPU相比的特点? 

1) DSP是单片机,构成系统简单。 
2)DSP的速度快。 
3)DSP的成本较低。 
4)DSP的性能高,可以处理较多的任务。   



如何编写C2000片内Flash? 

DSP中的Flash的编写方法有三中: 
1.通过仿真器编写:在我们的网页上有相关的软件,在销售仿真器时我们也提供相关软件。其中 LF240x的编写可以在CCS中加入一个插件,F24x的编写需要在windows98下的DOS窗中进行。具体步骤见软件中的readme。有几点需要注意: a.必须为MC方式; b.F206的工作频率必须为20MHz; c.F240需要根据PLL修改C240_CFG.I文件。建议外部时钟为20MHz。 d.LF240x也需要根据PLL修改文件。 d.如果编写有问题,可以用BFLWx.BAT修复。 
2.提供串口编写:TI的网页上有相关软件。注意只能编写一次,因为编写程序会破坏串口通信程序。 
3.在你的程序中编写:TI的网页上有相关资料。   


如何编写DSP外部的Flash? 

DSP的外部Flash编写方法: 
1.通过编程器编写:将OUT文件通过HEX转换程序转换为编程器可以接受的格式,再由编程器编写。 
2.通过DSP软件编写:您需要根据Flash的说明,编写Flash的编写程序,将应用程序和编写Flash的程序分别load到RAM中,运行编写程序编写。   


对于C5000,大于48K的程序如何BOOT? 

对于C5000,片内的BOOT程序在上电后将数据区的内容,搬移到程序区的RAM中,因此FLASH必须在RESET后放在数据区。由于C5000,数据区的空间有限,一次BOOT的程序不能对于48K。解决的方法如下: 
1.在RESET后,将FLASH译码在数据区,RAM放在程序区,片内BOOT程序将程序BOOT到RAM中。 
2.用户初试化程序发出一个I/O命令(如XF),将FLASH译码到程序区的高地址。开放数据区用于其它的RAM。 
3.用户初试化程序中包括第二次BOOT程序(此程序必须用户自己编写),将FLASH中没有BOOT的其它代码搬移到RAM中。 
4.开始运行用户处理程序。   



DSP外接存储器的控制方式?

对于一般的存储器具有RD、WR和CS等控制信号,许多DSP(C3x、C5000)都没有控制信号直接连接存储器,一般采用的方式如下: 
1.CS有地址线和PS、DS或STRB译码产生; 
2./RD=/STRB+/R/W; 
3./WR=/STRB+R/W。   



GEL文件的功能? 

GEL文件的功能同emuinit.cmd的功能基本相同,用于初始化DSP。但它的功能比emuinit的功能有所增强,GEL在CCS下有一个菜单,可以根据DSP的对象不同,设置不同的初始化程序。以TMS320LF2407为例: 
#define SCSR1 0x7018 ;定义scsr1寄存器 
#define SCSR2 0X7019 ;定义scsr2寄存器 
#define WDKEY 0x7025 ;定义wdkey寄存器 
#define WDNTR 0x7029 ;定义wdntr寄存器 
StartUp() ; 开始函数 

GEL_MapReset(); ; 存储空间复位 GEL_MapAdd(0x0000,0,0x7fff,1,1); 定义程序空间从0000-7fff 可读写 
GEL_MapAdd(0x8000,0,0x7000,1,1); 定义程序空间从8000-f000 可读写 
GEL_MapAdd(0x0000,1,0x10000,1,1); 定义数据空间从0000-10000可读写 
GEL_MapAdd(0xffff,2,1,1,1); 定义i/o 空间0xffff可读写 
GEL_MapOn(); 存储空间打开 
GEL_MemoryFill(0xffff,2,1,0x40); 在i/o空间添入数值40h 
*(int *)SCSR1=0x0200; 给scsr1寄存器赋值 
*(int *)SCSR2=0x000C; 给scsr2寄存器赋值,在这里可以进行mp/mc方式的转换 
*(int *)WDNTR=0x006f; 给wdntr寄存器赋值 
*(int *)WDKEY=0x055; 给wdkey寄存器赋值 
*(int *)WDKEY=0x0AA; 给wdkey寄存器赋值 
}   



使用TI公司模拟器件与DSP结合使用的好处。 

1)在使用TI公司的DSP的同时,使用TI公司的模拟可以和DSP进行无缝连接。器件与器件之间不需要任何的连接或转接器件。这样即减少了板卡的尺寸,也降低了开发难度。 
2)同为TI公司的产品,很多器件可以固定搭配使用。少了器件选型的烦恼 
3)TI在CCS中提供插件,可以用于DSP和模拟器件的开发,非常方便。   



C语言中可以嵌套汇编语言? 

可以。在ANSI C标准中的标准用法就是用C语言编写主程序,用汇编语言编写子程序,中断服务程序,一些算法,然后用C语言调用这些汇编程序,这样效率会相对比较高。



在定点DSP系统中可否实现浮点运算?

当然可以,因为DSP都可以用C,只要是可以使用c语言的场合都可以实现浮点运算。   



JTAG头的使用会遇到哪些情况? 

1)DSP的CLKOUT没有输出,工作不正常。 
2)Emu0,Emu1需要上拉。 
3)TCK的频率应该为10M。 
4)在3.3V DSP中,PD脚为3.3V 供电,但是仿真器上需要5V电压供电,所以PP仿真器盒上需要单独供电。 
5)仿真多片DSP。在使用菊花链的时候,第一片DSP的TDO接到第二片DSP的TDI即可。注意当串联DSP比较多的时候,信号线要适当的增加驱动。



include头文件(.h)的主要作用?

头文件,一般用于定义程序中的函数、参数、变量和一些宏单元,同库函数配合使用。因此,在使用库时,必须用相应的头文件说明。   



DSP中断向量的位置?

1)2000系列dsp的中断向量只能从0000H处开始。所以在我们调试程序的时候,要把DSP选择为MP(微处理器方式),把片内的Flash屏蔽掉,免去每次更改程序都要重新烧写Flash工作。 
2)3x系列dsp的中断向量也只能在固定的地址。 
3)5000,6000系列dsp的中断向量可以重新定位。但是它只能被重新定位到Page0范围内的任何空间。   


有源晶振与晶体的区别,应用范围及用法?

1)晶体需要用DSP片内的振荡器,在datasheet上有建议的连接方法。晶体没有电压的问题,可以适应于任何DSP,建议用晶体。 
2)有源晶振不需要DSP的内部振荡器,信号比较稳定。有源晶振用法:一脚悬空,二脚接地,三脚接输出,四脚接电压。   


程序经常跑飞的原因?

1)程序没有结尾或不是循环的程序。 
2)nmi管脚没有上拉。 
3)在看门狗动作的时候程序会经常跑飞。 
4)程序编制不当也会引起程序跑飞。 
5)硬件系统有问题。   
linux操作系统文章专题:linux操作系统详解(linux不再难懂)


关键词: DSP 嵌入式

评论


相关推荐

技术专区

关闭