硬汉嵌入式论坛

 找回密码
 立即注册
查看: 14594|回复: 49
收起左侧

[DSP] 做 DSP 最应该懂得157 个问题(问答)

[复制链接]

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
发表于 2014-8-8 10:09:08 | 显示全部楼层 |阅读模式
一. 什么是 DSP?
DSP 芯片,也称数字信号处理器,是一种具有特殊结构的微处理器。DSP 芯片的内部采用程序和数据分开的哈佛结构,具有专门的硬件乘法器,广泛采用流水线操作,提供特殊的DSP  指令,可以用来快速地实现各种数字信号处理算法。根据数字信号处理的要求, DSP 芯片一般具有如下的一些主要特点:
(1)  在一个指令周期内可完成一次乘法和一次加法。
(2)  程序和数据空间分开,可以同时访问指令和数据。
(3)  片内具有快速 RAM,通常可通过独立的数据总线在两块中同时访问。
(4)  具有低开销或无开销循环及跳转的硬件支持。
(5)  快速的中断处理和硬件 I/O 支持。
(6)  具有在单周期内操作的多个硬件地址产生器。
(7)  可以并行执行多个操作。
(8)  支持流水线操作,使取指、译码和执行等操作可以重叠执行。

二.DSP 的 C 语言同主机 C 语言的主要区别?
1)DSP 的 C 语言是标准的 ANSI C,它不包括同外设联系的扩展部分,如屏幕绘图等。但在 CCS中,为了方便调试,可以将数据通过 prinf 命令虚拟输出到主机的屏幕上。
2)DSP 的 C 语言的编译过程为,C 编译为 ASM,再由 ASM 编译为 OBJ。因此 C 和 ASM 的对应关系非常明确,非常便于人工优化。
3)DSP 的代码需要绝对定位;主机的 C 的代码有操作系统定位。
4)DSP 的 C 的效率较高,非常适合于嵌入系统。

三.DSP 发展动态
1.TMS320C2000  TMS320C2000 系列包括 C24x 和 C28x 系列。C24x 系列建议使用 LF24xx 系列替代 C24x 系列, LF24xx 系列的价格比 C24x 便宜,性能高于 C24x,而且 LF24xxA 具有加密功能。  C28x 系列主要用于大存储设备管理,高性能的控制场合。
2.TMS320C3x TMS320C3x 系列包括 C3x 和 VC33,主要推荐使用 VC33。 C3x 系列是 TI 浮点 DSP的基础,不可能停产,但价格不会进一步下调。
3.TMS320C5x TMS320C5x 系列已不推荐使用,建议使用 C24x 或 C5000 系列替代。
4.TMS320C5000  TMS320C5000 系列包括 C54x 和 C55x 系列。其中 VC54xx 还不断有新的器件出现,如:TMS320VC5471(DSP+ARM7)。  C55x 系列是 TI 的第三代 DSP,功耗为 VC54xx的 1/6,性能为 VC54xx 的 5 倍,是一个正在发展的系列。  C5000 系列是目前 TI DSP 的主流DSP,它涵盖了从低档到中高档的应用领域,目前也是用户最多的系列。
5.TMS320C6000  TMS320C6000 系列包括 C62xx、C67xx 和 C64xx。此系列是 TI 的高档 DSP 系列。其中 C62xx 系列是定点的 DSP,系列芯片种类较丰富,是主要的应用系列。  C67xx 系列是浮点的 DSP,用于需要高速浮点处理的领域。  C64xx 系列是新发展,性能是 C62xx 的 10倍。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:15:50 | 显示全部楼层
四.5V/3.3V如何混接?
TI DSP的发展同集成电路的发展一样,新的DSP都是3.3V的,但目前还有许多外围电路是5V的,因此在DSP系统中,经常有5V和3.3V的DSP混接问题。
在这些系统中,应注意:
1)DSP输出给5V的电路(如D/A),无需加任何缓冲电路,可以直接连接。
2)DSP输入5V的信号(如A/D),由于输入信号的电压>4V,超过了DSP的电源电压,DSP的外部信号没有保护电路,需要加缓冲,如74LVC245等,将5V信号变换成3.3V的信号。
3)仿真器的JTAG口的信号也必须为3.3V,否则有可能损坏DSP。

五.为什么要片内RAM大的DSP效率高?
目前DSP发展的片内存储器RAM越来越大,要设计高效的DSP系统,就应该选择片内RAM较大的DSP。
片内RAM同片外存储器相比,有以下优点:
1)片内RAM的速度较快,可以保证DSP无等待运行。
2)对于C2000/C3x/C5000系列,部分片内存储器可以在一个指令周期内访问两次,使得指令可以更加高效。
3)片内RAM运行稳定,不受外部的干扰影响,也不会干扰外部。
4)DSP片内多总线,在访问片内RAM时,不会影响其它总线的访问,效率较高。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:35:09 | 显示全部楼层
六.为什么DSP从5V发展成3.3V?
超大规模集成电路的发展从1um,发展到目前的0.1um,芯片的电源电压也随之降低,功耗也随之降低。DSP也同样从5V发展到目前的3.3V,核心电压发展到1V。
目前主流的DSP的外围均已发展为3.3V,5V的DSP的价格和功耗都价格,以逐渐被3.3V的DSP取代。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:35:42 | 显示全部楼层
七如何选择DSP的电源芯片?
TMS320LF24xx:TPS7333QD,5V变3.3V,最大500mA。
TMS320VC33: TPS73HD318PWP,5V变3.3V和1.8V,最大750mA。
TMS320VC54xx:TPS73HD318PWP,5V变3.3V和1.8V,最大750mA; TPS73HD301PWP,5V变3.3V和可调,最大750mA。
TMS320VC55xx:TPS73HD301PWP,5V变3.3V和可调,最大750mA。
TMS320C6000: PT6931,TPS56000,最大3A。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:36:22 | 显示全部楼层
八.软件等待的如何使用?
DSP的指令周期较快,访问慢速存储器或外设时需加入等待。等待分硬件等待和软件等待,每一个系列的等待不完全相同。
1)对于C2000系列: 硬件等待信号为READY,高电平时不等待。 软件等待由WSGR寄存器决定,可以加入最多7个等待。其中程序存储器和数据存储器及I/O可以分别设置。
2)对于C3x系列: 硬件等待信号为/RDY,低电平是不等待。 软件等待由总线控制寄存器中的SWW和WTCNY决定,可以加入最多7个等待,但等待是不分段的,除了片内之外全空间有效。
3)对于C5000系列: 硬件等待信号为READY,高电平时不等待。 软件等待由SWWCR和SWWSR寄存器决定,可以加入最多14个等待。其中程序存储器、控制程序存储器和数据存储器及I/O可以分别设置。
4)对于C6000系列(只限于非同步存储器或外设): 硬件等待信号为ARDY,高电平时不等待。 软件等待由外部存储器接口控制寄存器决定,总线访问外部存储器或设备的时序可以设置,可以方便的同异步的存储器或外设接口。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:37:09 | 显示全部楼层
九.中断向量为什么要重定位?
为了方便DSP存储器的配置,一般DSP的中断向量可以重新定位,即可以通过设置寄存器放在存储器空间的任何地方。
   注意:C2000的中断向量不能重定位。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:38:14 | 显示全部楼层
十.DSP的最高主频能从芯片型号中获得吗?
TIDSP最高主频可以从芯片的型号中获得但每一个系列不一定相同。


1)TMS320C2000系列:
TMS320F206-最高主频20MHz
TMS320C203/C206-最高主频40MHz
TMS320F24x-最高主频20MHz
TMS320LF24xx-最高主频30MHz
TMS320LF24xxA-最高主频40MHz
TMS320LF28xx-最高主频150MHz


2)TMS320C3x系列:
TMS320C30:最高主频25MHz
TMS320C31PQL80:最高主频40MHz
TMS320C32PCM60:最高主频30MHz
TMS320VC33PGE150:最高主频75MHz


3)TMS320C5000系列:
TMS320VC54xx:最高主频160MHz
TMS320VC55xx:最高主频300MHz


4)TMS320C6000系列:
TMS320C62xx:最高主频300MHz
TMS320C67xx:最高主频230MHz
TMS320C64xx:最高主频720MHz
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:41:04 | 显示全部楼层
十一.DSP可以降频使用吗?
可以DSP的主频均有一定的工作范围因此DSP均可以降频使用。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:42:01 | 显示全部楼层
十二.如何选择外部时钟?
DSP的内部指令周期较高外部晶振的主频不够因此DSP大多数片内均有PLL。但每个系列不尽相同。
1)TMS320C2000系列:
TMS320C20xPLL可以÷2×1×2×4因此外部时钟可以为5MHz40MHz
TMS320F240PLL可以÷2×1×1.5×2×2.5×3×4×4.5×5×9因此外部时钟可以为2.22MHz40MHz
TMS320F241/C242/F243PLL可以×4因此外部时钟为5MHz TMS320LF24xxPLL可以由RC调节因此外部时钟为4MHz20MHz
TMS320LF24xxAPLL可以由RC调节因此外部时钟为4MHz20MHz

2)TMS320C3x系列:
TMS320C3x:没有PLL因此外部主频为工作频率的2倍。
TMS320VC33PLL可以÷2×1×5因此外部主频可以为12MHz100MHz

3)TMS320C5000系列:
TMS320VC54xxPLL可以÷4÷2×1-32因此外部主频可以为0.625MHz50MHz
TMS320VC55xxPLL可以÷4÷2×1-32因此外部主频可以为6.25MHz300MHz

4)TMS320C6000系列:
TMS320C62xxPLL可以×1×4×6×7×8×9×10×11因此外部主频可以为11.8MHz300MHz
TMS320C67xxPLL可以×1×4因此外部主频可以为12.5MHz230MHz
TMS320C64xxPLL可以×1×6×12因此外部主频可以为30MHz720MHz
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:43:44 | 显示全部楼层
十三.如何选择DSP的外部存储器?
DSP的速度较快为了保证DSP的运行速度外部存储器需要具有一定的速度否则DSP访问外部存储器时需要加入等待周期。
1)对于C2000系列 C2000系列只能同异步的存储器直接相接。 C2000系列的DSP目前的最高速度为150MHz
建议可以用的存储器有:
CY7C199-1532K×815ns5V;
CY7C1021-1264K×1615ns5V; CY7C1021V33-1264K×1615ns3.3V

2)对于C3x系列 C3x系列只能同异步的存储器直接相接。 C3x系列的DSP的最高速度5V的为40MHz3.3V的为75MHz为保证DSP无等待运行分别需要外部存储器的速度<25ns<12ns
建议可以用的存储器有:
ROM AM29F400-70256K×1670ns5V加入一个等待;
AM29LV400-55(SST39VF400)256K×1655ns3.3V加入两个等待(目前没有更快的Flash)。
SRAM CY7C199-1532K×815ns5V;
CY7C1021-1564K×1615ns5V;
CY7C1009-15128K×815ns5V;
CY7C1049-15512K×815ns5V;
CY7C1021V33-1564K×1615ns3.3V;
CY7C1009V33-15128K×815ns3.3V;
CY7C1041V33-15256k×1615ns3.3V

3)对于C54x系列 C54x系列只能同异步的存储器直接相接。 C54x系列的DSP的速度为100MHz160MHz为保证DSP无等待运行需要外部存储器的速度<10ns<6ns
建议可以用的存储器有:
ROM AM29LV400-55(SST39VF400)256K×1655ns3.3V加入59个等待(目前没有更快的Flash)。
SRAM CY7C1021V33-1264K×1612ns3.3V加入一个等待;
CY7C1009V33-12128K×812ns3.3V加入一个等待。

4)对于C55xC6000系列 TIDSP中只有C55xC6000可以同同步的存储器相连同步存储器可以保证系统的数据交换效率更高。
ROM AM29LV400-55(SST39VF400)256K×1655ns3.3V
SDRAM HY57V651620BTC-10S64M10ns
SBSRAM CY7C1329-133AC64k×32;
CY7C1339-133AC128k×32
FIFOCY7C42x5V-10ASC32k/64k×18
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:44:12 | 显示全部楼层
十四.DSP芯片有多大的驱动能力?
DSP的驱动能力较强可以不加驱动连接8个以上标准TTL门。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:44:42 | 显示全部楼层
十五.调试TMS320C2000系列的常见问题?
1)单步可以运行连续运行时总回0地址: Watchdog没有关连续运行复位DSP回到0地址。
2)OUT文件不能load到片内flash中: Flash不是RAM不能用简单的写指令写入需要专门的程序写入。CCSC Source Debugger中的load命令不能对flash写入。 OUT文件只能load到片内RAM或片外RAM中。
3)flash中如何加入断点: flash中可以用单步调试也可以用硬件断点的方法在flash中加入断点软件断点是不能加在ROM中的。硬件断点设置存储器的地址当访问该地址时产生中断。
4)中断向量: C2000的中断向量不可重定位因此中断向量必须放在0地址开始的flash内。在调试系统时代码放在RAM中断向量也必须放在flash内。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:45:33 | 显示全部楼层
十六.调试TMS320C3x系列的常见问题?
1)TMS320C32的存储器配置: TMS320C32的程序存储器可以配置为16位或32;数据存储器可以配置为8位、16位或32位。
2)TMS320VC33PLL控制: TMS320VC33PLL控制端只能接1.8V不能接3.3V5V
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:46:32 | 显示全部楼层
十七.如何调试多片DSP?
对于有MPSD仿真口的DSPTMS320C30/C31/C32不能用一套仿真器同时调试每次只能调试其中的一个DSP; 对于有JTAG仿真口的DSP可以将JTAG串接在一起用一套仿真器同时调试多个DSP每个DSP可以用不同的名字在不同的窗口中调试。 注意:如果在JTAGDSP间加入驱动一定要用快速的门电路不能使用如LS的慢速门电路。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:47:02 | 显示全部楼层
十八.在DSP系统中为什么要使用CPLD?
DSP的速度较快要求译码的速度也必须较快。利用小规模逻辑器件译码的方式已不能满足DSP系统的要求。 同时DSP系统中也经常需要外部快速部件的配合这些部件往往是专门的电路有可编程器件实现。 CPLD的时序严格速度较快可编程性好非常适合于实现译码和专门电路。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:47:42 | 显示全部楼层
十九.DSP系统构成的常用芯片有哪些?
1)电源: TPS73HD3xxTPS7333TPS56100PT64xx...
2)Flash AM29F400AM29LV400SST39VF400...
3)SRAM CY7C1021CY7C1009CY7C1049...
4)FIF CY7C425CY7C42x5...
5)Dual port CY7C136CY7C133CY7C1342...
6)SBSRAM CY7C1329CY7C1339...
7)SDRAM HY57V651620BTC...
8)CPLD CY37000系列CY38000系列CY39000系列...
9)PCI PCI2040CY7C09449...
10)USB AN21xxCY7C68xxx...
11)CodecTLV320AIC23TLV320AIC10...
12)A/DD/AADS7805TLV2543...
具体资料见www.ti.comwww.cypress.com
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:48:20 | 显示全部楼层
二十.什么是boot loader?
DSP的速度尽快EPROMflash的速度较慢DSP片内的RAM很快片外的RAM也较快。为了使DSP充分发挥它的能力必须将程序代码放在RAM中运行。为了方便的将代码从ROM中搬到RAM在不带flashDSPTI在出厂时固化了一段程序在上电后完成从ROM或外设将代码搬到用户指定的RAM中。此段程序称为"boot loader"
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:49:03 | 显示全部楼层
二十一.TMS320C3x如何boot?
MC/MP管脚为高时C3x进入boot状态。C3xboot loaderreset判断外部中断管脚的电平。根据中断配置决定boot的方式为存储器加载还是串口加载其中ROM的地址可以为三个中的一个ROM可以为8位。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:50:21 | 显示全部楼层
二十二.Boot有问题如何解决?
1)仔细检查boot的控制字是否正确。
2)仔细检查外部管脚设置是否正确。
3)仔细检查hex文件是否转换正确。
4)用仿真器跟踪boot过程分析错误原因。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:51:04 | 显示全部楼层
二十三.DSP为什么要初始化?
DSPRESET许多的寄存器的初值一般同用户的要求不一致例如:等待寄存器SP中断定位寄存器等需要通过初始化程序设置为用户要求的数值。
初始化程序的主要作用:
    1)设置寄存器初值。
    2)建立中断向量表。
    3)外围部件初始化。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:51:31 | 显示全部楼层
二十四.DSP有哪些数学库及其它应用软件?
TI公司为了方便客户开发DSP在它的网站上提供了许多程序的示例和应用程序MATHFFTFIR/IIR可以在TI的网页免费下载。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:52:02 | 显示全部楼层
二十五.如何获得DSP专用算法?
TI有许多的Third Party可以通过DSP上的多种算法软件。可以通过TI的网页搜索你所需的算法找到通过算法的公司同相应的公司联系。注意这些算法都是要付费的。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:52:41 | 显示全部楼层
二十六.eXpressDSP是什么?
eXpressDSP是一种实时DSP软件技术它是一种DSP编程的标准利用它可以加快你开发DSP软件的速度。 以往DSP软件的开发没有任何标准不同的人写的程序一般无法连接在一起。DSP软件的调试工具也非常不方便。使得DSP软件的开发往往滞后于硬件的开发。 eXpressDSP集成了CCS(Code Composer Studio)开发平台DSP BIOS实时软件平台DSP算法标准和第三方支持四部分。利用该技术可以使你的软件调试软件进程管理软件的互通及算法的获得都便的容易,这样就可以加快你的软件开发进程。
1)CCSeXpressDSP的基础因此你必须首先拥有CCS软件。
2)DSP BIOSeXpressDSP的基本平台你必须学会所有DSP BIOS
3)DSP算法标准可以保证你的程序可以方便的同其它利用eXpressDSP技术的程序连接在一起。同时也保证你的程序的延续性。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:53:29 | 显示全部楼层
二十七.为什么要用DSP?
3G技术和internate的发展要求处理器的速度越来越高体积越来越小DSP的发展正好能满足这一发展的要求。因为传统的其它处理器都有不同的缺陷。MCU的速度较慢;CPU体积较大功耗较高;嵌入CPU的成本较高。 DSP的发展使得在许多速度要求较高算法较复杂的场合取代MCU或其它处理器而成本有可能更低。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:54:02 | 显示全部楼层
二十八.如何选择DSP?
选择DSP可以根据以下几方面决定:
1)速度: DSP速度一般用MIPSFLOPS表示即百万次/秒钟。根据您对处理速度的要求选择适合的器件。一般选择处理速度不要过高速度高的DSP系统实现也较困难。
2)精度: DSP芯片分为定点、浮点处理器对于运算精度要求很高的处理可选择浮点处理器。定点处理器也可完成浮点运算但精度和速度会有影响。
3)寻址空间: 不同系列DSP程序、数据、I/O空间大小不一与普通MCU不同DSP在一个指令周期内能完成多个操作所以DSP的指令效率很高程序空间一般不会有问题关键是数据空间是否满足。数据空间的大小可以通过DMA的帮助借助程序空间扩大。
4)成本: 一般定点DSP的成本会比浮点DSP的要低速度也较快。要获得低成本的DSP系统尽量用定点算法用定点DSP
5)实现方便: 浮点DSP的结构实现DSP系统较容易不用考虑寻址空间的问题指令对C语言支持的效率也较高。
6)内部部件:根据应用要求选择具有特殊部件的DSP。如:C2000适合于电机控制;OMAP适合于多媒体等。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:55:01 | 显示全部楼层
二十九.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的性能高可以处理较多的任务。

努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:56:01 | 显示全部楼层
三十一.如何编写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的网页上有相关资料。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:56:28 | 显示全部楼层
三十二.如何编写DSP外部的Flash?
DSP的外部Flash编写方法:
1.通过编程器编写:将OUT文件通过HEX转换程序转换为编程器可以接受的格式再由编程器编写。
2.通过DSP软件编写:您需要根据Flash的说明编写Flash的编写程序将应用程序和编写Flash的程序分别loadRAM运行编写程序编写。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:57:04 | 显示全部楼层
三十三.对于C5000,大于48K的程序如何BOOT?
对于C5000片内的BOOT程序在上电后将数据区的内容搬移到程序区的RAM因此FLASH必须在RESET后放在数据区。由于C5000数据区的空间有限一次BOOT的程序不能对于48K
解决的方法如下:
1.RESETFLASH译码在数据区RAM放在程序区片内BOOT程序将程序BOOTRAM中。
2.用户初试化程序发出一个I/O命令(如XFFLASH译码到程序区的高地址。开放数据区用于其它的RAM
3.用户初试化程序中包括第二次BOOT程序(此程序必须用户自己编写)FLASH中没有BOOT的其它代码搬移到RAM中。
4.开始运行用户处理程序。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:57:38 | 显示全部楼层
三十四.DSP外接存储器的控制方式
对于一般的存储器具有RDWRCS等控制信号许多DSPC3xC5000)都没有控制信号直接连接存储器一般采用的方式如下:
1.CS有地址线和PSDSSTRB译码产生;
2./RD=/STRB+/R/W; 3./WR=/STRB+R/W
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:58:22 | 显示全部楼层
三十五.GEL文件的功能?
GEL文件的功能同emuinit.cmd的功能基本相同用于初始化DSP。但它的功能比emuinit的功能有所增强,GELCCS下有一个菜单可以根据DSP的对象不同设置不同的初始化程序。
TMS320LF2407为例:
#define SCSR1 0x7018 ;定义scsr1寄存器
#define SCSR2 0X7019 ;定义scsr2寄存器
#define WDKEY 0x7025 ;定义wdkey寄存器
#define WDNTR 0x7029 ;定义wdntr寄存器
StartUp() ; 开始函数
{
GEL_MapReset(); ; 存储空间复位 GEL_MapAdd(0x000000x7fff11); 定义程序空间从00007fff 可读写
GEL_MapAdd(0x800000x700011); 定义程序空间从8000f000 可读写
GEL_MapAdd(0x000010x1000011); 定义数据空间从000010000可读写
GEL_MapAdd(0xffff2111); 定义i/o 空间0xffff可读写
GEL_MapOn(); 存储空间打开
GEL_MemoryFill(0xffff210x40); 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寄存器赋值
}
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 10:59:35 | 显示全部楼层
三十六.使用TI公司模拟器件与DSP结合使用的好处。
1)在使用TI公司的DSP的同时使用TI公司的模拟可以和DSP进行无缝连接。器件与器件之间不需要任何的连接或转接器件。这样即减少了板卡的尺寸也降低了开发难度。
2)同为TI公司的产品很多器件可以固定搭配使用。少了器件选型的烦恼
3)TICCS中提供插件可以用于DSP和模拟器件的开发非常方便。


三十七.C语言中可以嵌套汇编语言?
可以。在ANSI C标准中的标准用法就是用C语言编写主程序用汇编语言编写子程序中断服务程序一些算法然后用C语言调用这些汇编程序这样效率会相对比较高
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 11:00:10 | 显示全部楼层
三十八.在定点DSP系统中可否实现浮点运算?
当然可以因为DSP都可以用C只要是可以使用c语言的场合都可以实现浮点运算。


三十九.JTAG头的使用会遇到哪些情况?
1)DSPCLKOUT没有输出工作不正常。
2)Emu0Emu1需要上拉。
3)TCK的频率应该为10M
4)3.3V DSPPD脚为3.3V 供电但是仿真器上需要5V电压供电所以PP仿真器盒上需要单独供电。
4)仿真多片DSP。在使用菊花链的时候第一片DSPTDO接到第二片DSPTDI即可。注意当串联DSP比较多的时候信号线要适当的增加驱动。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 11:00:49 | 显示全部楼层
四十.include头文件(.h)的主要作用
头文件一般用于定义程序中的函数、参数、变量和一些宏单元同库函数配合使用。因此在使用库时必须用相应的头文件说明。


四十一.DSP中断向量的位置
1)2000系列dsp的中断向量只能从0000H处开始。所以在我们调试程序的时候要把DSP选择为MP(微处理器方式)把片内的Flash屏蔽掉免去每次更改程序都要重新烧写Flash工作。
2)3x系列dsp的中断向量也只能在固定的地址。
3)50006000系列dsp的中断向量可以重新定位。但是它只能被重新定位到Page0范围内的任何空间。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 11:01:45 | 显示全部楼层
四十二.有源晶振与晶体的区别,应用范围及用法
1)晶体需要用DSP片内的振荡器datasheet上有建议的连接方法。晶体没有电压的问题可以适应于任何DSP建议用晶体。
2)有源晶振不需要DSP的内部振荡器信号比较稳定。有源晶振用法:一脚悬空二脚接地三脚接输出四脚接电压。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 11:02:13 | 显示全部楼层
四十三.程序经常跑飞的原因
1)程序没有结尾或不是循环的程序。
2)nmi管脚没有上拉。
3)在看门狗动作的时候程序会经常跑飞。
4)程序编制不当也会引起程序跑飞。
5)硬件系统有问题。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 11:04:07 | 显示全部楼层
四十四.并行FLASH引导的一点经验
最近BBS上关于FLASHBOOT的讨论很活跃我也多次来此请教。前几天自制的DSP板引导成功早就打算写写这方面的东西。我用的DSP5416以其为核心做了一个相对独立的子系统(硬件、软件、算法)目前都已基本做好。 下面把在FLASH引导方面做的工作向大家汇报一下希望能对大家有所帮助。本人经验和文笔都有限写的不好请大家谅解。
硬件环境:
DSPTMS320VC5416PGE160
FLASHSST39VF400A-70-4C-EK 都是贴片的FLASH映射在DSP数据空间的0x8000-0xFFFF
软件环境: CCS v2.12.01
主程序(要烧入FLASH的程序) DEBUG程序占用空间0x28000-0x2FFFF(片内SARAM中断向量表在0x0080-0x00FF(片内DARAM数据空间使用0x0100-0x7FFF(片内DARAM)。 因为FLASH是贴片的所以需要自己编一个数据搬移程序把要主程序搬移到FLASH中。在写入FLASH数据时还应写入引导表的格式数据。最后在数据空间的0xFFFF处写入引导表的起始地址(这里为0x8000)。
搬移程序: DEBUG程序空间0x38000-0x3FFFF(片内SARAM中断向量表在0x7800-0x78FF(片内DARAM数据空间使用0x5000-0x77FF(片内DARAM)。 搬移程序不能使用与主程序的程序空间和中断向量表重合的物理空间以免覆盖。 烧写时同时打开主程序和搬移程序的PROJECTLOAD主程序LOAD搬移程序然后执行搬移程序烧写OK! 附:搬移程序(仅供参考)
volatile unsigned int *pTemp=(unsigned int *)0x7e00; unsigned int iFlashAddr;
int iLoop; /* 在引导表头存放并行引导关键字 */
iFlashAddr=0x8000;
WriteFlash(iFlashAddr0x10aa);
iFlashAddr++; /* 初始化SWWSR */
WriteFlash(iFlashAddr0x7e00);
iFlashAddr++; /* 初始化BSCR */
WriteFlash(iFlashAddr0x8006);
iFlashAddr++; /* 程序执行的入口地址 */
WriteFlash(iFlashAddr0x0002);
iFlashAddr++;
WriteFlash(iFlashAddr0x8085);
iFlashAddr++; /* 程序长度 */
WriteFlash(iFlashAddr0x7f00);
iFlashAddr++; /* 程序要装载到的地址 */
WriteFlash(iFlashAddr0x0002);
iFlashAddr++;
WriteFlash(iFlashAddr0x8000);
iFlashAddr++;
for (iLoop=0;iLoop<0x7f00;iLoop++)
{ /* 从程序空间读数据放到暂存单元 */
asm(" pshm al");
asm(" pshm ah");
asm(" rsbx cpl");
asm(" ld #00fchdp");
asm(" stm #0000h ah");
asm(" MVDM _iLoop al");
asm(" add #2800h4a");
asm(" reada 0h");
asm(" popm ah");
asm(" popm al");
asm(" ssbx cpl"); /* 把暂存单元内容写入FLASH */
WriteFlash(iFlashAddr*pTemp);
iFlashAddr++; } /* 中断向量表长度 */
WriteFlash(iFlashAddr0x0080);
iFlashAddr++; /* 中断向量表装载地址 */
WriteFlash(iFlashAddr0x0000);
iFlashAddr++;
WriteFlash(iFlashAddr0x0080);
iFlashAddr++;
for (iLoop=0;iLoop<0x0080;iLoop++) { /* 从程序空间读数据放到暂存单元 */
asm(" pshm al");
asm(" pshm ah");
asm(" rsbx cpl");
asm(" ld #00fchdp");
asm(" stm #0000h ah");
asm(" MVDM _iLoop al");
asm(" add #0080h0a");
asm(" reada 0h");
asm(" popm ah");
asm(" popm al");
asm(" ssbx cpl"); /* 把暂存单元内容写入FLASH */
WriteFlash(iFlashAddr*pTemp);
iFlashAddr++;
} /* 写入引导表结束标志 */
WriteFlash(iFlashAddr0x0000);
iFlashAddr++;
WriteFlash(iFlashAddr0x0000); /* 在数据空间的0xFFFF写入引导表起始地址 */
iFlashAddr=0xffff;
WriteFlash(iFlashAddr0x8000);
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 11:05:38 | 显示全部楼层
四十五.关于LF2407A的FLASH烧写问题的几点说明
TI现在关于LF24x写入FLASH的工具最新为c2000flashprogsw_v112。可以支持LF2407LF2407aLF2401及相关的LF240x系列。建议使用此版本。在http://focus.ti.com/docs/tool/toolf.
在使用这个工具时注意:
先解压再执行setup.exe
二、进入cctools图标下有烧写工具;
1、关于FLASH时钟的选择此烧写工具默认最高频率进行FLASH的操作。根据目标系统的工作主频重新要进行PLL设置。方法:先在advance options下面的View Config file中修改倍频。存盘后在相应的目录下(tic2xx\\\\algos\\\\相应目录)运行buildall.bat就可以完成修改了。再进行相应的操作即可。
2、若是你所选的频率不是最高频率还需要设定你自已的timings.xx来代替系统默认的最高频率的timings.xx。例如LF2407a的默认文件是timings.40Timings.xx可以利用include\\\\timings.xlsexcel工作表来生成。然后在advance options下面的View Config file中修改相应的位置。存盘后在相应的目录下运行buildall.bat就可以完成修改了。
3、对于TMS320LF240XA系列还要注意:由于这些DSPFLASH具有加密功能加密地址为程序空间的0x40-0X43H程序禁止写入此空间如果写了此空间的数据被认为是加密位断电后进入保护FLASH状态使FLASH不可重新操作从而使DSP报废烧写完毕后一定要进行Program passwords的操作如果不做加密操作就默认最后一次写入加密位的数据作为密码。
42407A不能用DOS下的烧写软件烧写必须用c2000flashprogsw_v112软件烧写;
5建议如下:
1)、一般调试时RAM中进行;
2)、程序烧写时避开程序空间0x40-0x43H加密区程序最好小于32k;
3)、每次程序烧写完后word0word1word2word3分别输入自己的密码再点击 Program password如果加密成功提示Program is arrayed如果0x400x43h中写入的是ffff认为处于调试状态flash不会加密;
4)、断电后下次重新烧写时需要往word0word3输入已设的密码unlock成功后可以重新烧写了;
6VCPP管脚接在+5V是应直接接的中间不要加电阻。
7、具体事宜请阅读相应目录下的readme1readme2帮助文件。
8.注意*.cmd文件的编写时应该避开40-43H单元好多客户由于没有注意到这里而把FALSH加密。
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 11:06:26 | 显示全部楼层
四十六.如何设置硬件断点?
profiler >profile point -> break point


四十七.c54x的外部中断是电平响应还是沿响应?
是沿响应准确的说它要检测到100(一个clk的高和两个clk的低)的变化才可以。


四十八。参考程序,里面好象都要 disable wachdog,不知道为什么?
watchdog是一个计数器溢出时会复位你的DSPdisable的话你的系统会动不动就reset
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

740

主题

1326

回帖

3546

积分

管理员

春暖花开

Rank: 9Rank: 9Rank: 9

积分
3546
QQ
 楼主| 发表于 2014-8-8 11:13:13 | 显示全部楼层
四十九.时钟电路选择原则
1系统中要求多个不同频率的时钟信号时首选可编程时钟芯片;
2单一时钟信号时选择晶体时钟电路;
3多个同频时钟信号时选择晶振;
4尽量使用DSP片内的PLL降低片外时钟频率提高系统的稳定性;
5C6000C5510C5409AC5416C5420C5421C5441DSP片内无振荡电路不能用晶体时钟电路;
6VC5401VC5402VC5409F281xDSP时钟信号的电平为1.8V建议采用晶体时钟电路
努力打造安富莱高质量微信公众号:点击扫描图片关注
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|Archiver|手机版|硬汉嵌入式论坛

GMT+8, 2024-5-4 02:14 , Processed in 0.419058 second(s), 25 queries .

Powered by Discuz! X3.4 Licensed

Copyright © 2001-2023, Tencent Cloud.

快速回复 返回顶部 返回列表