嵌入式开发--蒹葭的专栏

Care and Diligence Bring Luck.(谨慎和勤奋才能抓住机遇!)

DSP相关

转载  DSP程序优化方法收藏

1、选择合适的算法和数据结构 选择一种合适的数据结构很重要,如果在一堆随机存放的数中使用了大量的插入和删除指令,那使用链表要快得多。数组与指针语句具有十分密切的关系,一般来说,指针比较灵活简洁,而数组则比较直观,容易理解。对于大部分的编译器,使用指针比使用数组生成的代码更短,执行效率更高。 在许多种情况下,可以用指针运算代替数组索引,这样做常常能产生又快又短的代码。与数组索引相比,指针一般能使代码速度更快,占用空间更少。使用多维数组时差异更明显。下面的代码作用是相同的,但是效率不一样。 阅读全文>

发表于 @ 2008年06月27日 22:44:00|评论(loading...)|收藏

原创 在TMS320F2812上实现从flash拷贝整个程序到RAM上运行的方法探讨收藏

在TMS320F2812上实现从flash拷贝整个程序到RAM上运行的方法探讨阅读全文>

发表于 @ 2008年04月10日 15:35:00|评论(loading...)|收藏

原创 DSP TMS320F2812的SPI使用总结收藏

1. spi速率不能超过15M,超过后会出现严重误码2. 如果接收方式为中断接收,SPICCR字符长度控制位决定了中断的字长。如字长为8,中断等级为1,则每接收一个字节产生一次中断。如字长为16,中断等级为1,则每接收2个字节产生一次中断。3. 注意主模式和从模式的极性一定要相同。主模式为上升沿采样,下降沿输出。从模式也应该为上升沿采样,下降沿输出。否则会出现采样数据不准确。4. 注意数据写入SPITXBUF时是左对齐,而读入SPIRXBUF是右对齐。这个问题在16位字长时不突出。但是在16位以下数据字长时要特别注意。一般方法是做左移运算。5. 注意SPI FIFO的用法。本人在调试过程中,遇到的最大问题就是数据丢失,困扰多天。后来查明原因,因为开启SPI FIFO增强功能,不能根据SpiaRegs.SPISTS.bit.BUFFULL_FLAG来暂停发送数据。因为此时的TXBUF是从TX FIFO中得数据。程序中写入TXBUF,只是写入发送缓冲器即FIFO。根据先进先出原理,你源源不断的向TXBUF写数据,则FIFO里总是保存你最后写入的数据,而不会将Spia阅读全文>

发表于 @ 2008年01月04日 11:50:00|评论(loading...)|收藏

转载 关于DSP中全局变量与局部变量的使用收藏

一般堆栈都在高速ram区,所以局部变量会快一点,而全局变量在ebss或bss区,这个区域比较大,一般定义在外部ram,速度比较慢。所以看你的变量需要的多少来定。 如果是做解码等计算量大的工作,那么程序结构以函数包为主,那么基本上都是用局部变量,如果是做控制,那么需要大量的变量来控制和记录程序运行的流程,那么这些变量基本都是static或全局变量。阅读全文>

发表于 @ 2007年10月26日 23:15:00|评论(loading...)|收藏

原创 FPGA与DSP共享外部总线问题收藏

不知道为什么,FPGA一烧入芯片之后,DSP访问外部总线就无法正常。估计原因出在FPGA的总线上,将原本不是给FPGA的数据当成自己的了。所以DSP无法正常访问。阅读全文>

发表于 @ 2007年08月12日 10:58:00|评论(loading...)|收藏

原创 关于dsp定时器同步需要注意的问题收藏

文/蒹葭 zhang.zhilong#gmail.com 因为项目中某一个芯片时钟和使能信号对同步有非常严格要求。故而采用PWM定时器来解决。 项目参数:F2812,主频100M,外设频率50M。 1. 定时器计数是从0开始计数的。所以要计10个数,则周期寄存器应设为0x09,而不是0x0A 2. 定时器2控制寄存器的T2SWT1位置一。同时注意,在启动定时器之前,不能将两定时器控制寄存器使能位置1。否则不能同步。 3. PWM电平变化,由定时器比较寄存器的数值决定,例如:比较寄存器设为0x05,则表示计数器数值到5(从0开始计数),电平跃变,而不是第五个。 4. 通过将定时器2的SELT1PR位置位与否,来决定定时器2使用定时器1的周期,还是使用自己的周期。 5. 设定计数初始值和周期,控制寄存器之后,使能定时器1.此时,定时器2也同步启动。 相关代码如下: EvaRegs.T1PR = 0x0009; // Timer1 period 阅读全文>

发表于 @ 2007年05月14日 14:42:00|评论(loading...)|收藏

Csdn Blog version 3.1a
Copyright © 蒹葭