原创 [转]sd+vs1003,优化过程

2010-5-14 11:09 3244 10 11 分类: MCU/ 嵌入式
最近在开发一个类似数码像框类的东西,不过需要播放mp3.在开发mp3模块的时候出现了不少问题,特此记录.
     首先说明下大致的思路.os使用了uc/os-II(v2.52),如果要量产,还要考虑换到免费的liunx.芯片使用了
 arm7核的LPC2210,mp3模块使用了VS1003,存储模块使用了sd卡.之所以不用一些集成了图象与mp3解码
的芯片,是因为想在该次开发中多用到一些东西,多练下手,如果最后要出货,为了成本考虑,可能还是要大改.
     
     调整好sd卡模块后,经过1个星期左右的努力,正玄测试mp3模块终于能够发出声音了,迫不及待的把sd卡部分合进来,编译,通过,调试,然后发现没有声音.
     调试了近1天,才发现是自己的spi初始化程序与vs1003的reset顺序反了.因为我的sd卡与vs1003模块
使用了同一个spi接口,sd卡的读写是一个任务,vs1003的操作是另外一个任务,spi的初始化是放在sd卡任务中的
vs1003的reset是放在自己的任务中.
    修改后,顺利的播放出了音乐.此时,问题也就来了,播放192kbs的mp3时候还算顺畅,但是播放320kbps的时候
极其的卡,根本无法听.
 原因主要是sd 卡的读写速度以及vs1003的通信速度跟不上,所以系统需要优化.
 1.首先,把vs1003的spi口与sd卡的spi口分开.LPC2210正好有2个spi口.这一步很关键,不然后面的优化
   手段无从说起.
   该项改动花了1天半的时间,测试后发现情况差不多,并没有好转,这也在意料之中.
 2.提高spi的通信速度,也就是尽量提高spi接口的sck,提高了最大极限.这个和vs1003和LPC2210都有关系,
   该项优化并不是主要的手段,提升效果也有限.但是至少要保证速度慢不是这里的问题.我现在的spi的通信
   速度都在6Mhz以上.
 3.buff的调整,该项优化是重头戏.开始使用了一种双buff的手段,是在网络上看来的,也就是2块buffer,
   一块被用在vs1003通信的时候,另一块就可以用在sd卡读了.vs1003数据发送完了,直接取另一块来发送,不用
   读好一块发一块,有一种并行的思想在里面.
   但是,如果想要这样的效果,必须在vs1003的发送过程中有空闲的时间并切换到sd任务上去读取.vs1003发送的
   过程中唯一可能有空闲的时候是DREQ为低的时候.所以必须保证在DREQ为低不能发送数据的时候有任务切换.
   这里的手段很多,用中断,或则uc/os中的OSTimeDlyHMSM,OSTimeDly都行.
     需要特别注意的是OSTimeDlyHMSM函数,如果你的时间片是一秒200次,那使用OSTimeDlyHMSM等待一毫秒是
   没有用的,因为等待的最小单位就是1000/200=5ms了.
     对一个320kbps的mp3来说,0.5k的数据可以支持0.5/(320/8)=1/80=12.5ms,所以等待1个tick是可以的.
     
     所以,根据这些分析的结果对程序进行了修改,每块buff都取4k,正好是fat32的一个簇大小.sd卡与
   vs1003发送两个任务使用邮箱通信.
     
   该项修改花了近半天的时间,结果失败,呵呵.不过效果好点了,卡的不是那么厉害了.
 4.这时,注意力转向了sd卡的读写速度.如果文件系统使用的是zlg/fs,那么速度会非常慢.
   主要是开放出来的zlg/fs是学习版的,高速版的是要卖钱的.不想买就只有自己动手.
   我在这里主要增加了一个一次读取多块的函数,最大可以到一次读取一个簇.这样速度都有几十
   K每秒了.速度虽然还是不好,不过对付下现在的问题也该够了.
 5.第二次的buff调整.仔细考虑后,发现要提高现有的速度,buff的设计并不合理,vs1003的发送与
   sd卡的读写最好相互完全独立,不需要相互通信.这里可以借鉴tcp/ip协议里的数据报文.
   所以,这次我把buff设计为1k左右,把数量提高到8个(这里的大小和数量最好要设计为可以调节的,
   方便在数量和大小之间找到平衡点).并记录每个buff的读取序号,不然发送的时候不知道先发哪个了.
   该种方法获得很大的成功,在1k大小,4个buff的时候,320kbps的播放已经非常流畅.
 
 6.虽然已经可以播放320kbps的mp3,但是心里还是很悬,因为整个系统要做的事情除了mp3播放,还有很多
   事情要做.所以系统还需要优化.
   下面的方向就是spi中断的使用.在spi通信中,没有使用中断,而是使用了一个循环等待
   发送完毕,每一个byte的发送和接收,有5到7us的时间被浪费了,如果能使用中断的话,
   配合数量够多的buff,整体速度会有很大的提高(但是单次读取的速度说不定更慢了).
   
   该项优化还没有完全实现.


文章评论1条评论)

登录后参与讨论

用户1046291 2011-2-14 23:20

同感,我用的是lpc2138+FatFs+sd卡,用DA输出播放WAV格式的音乐,采用双BUF后,也不能播放高采样率的音乐,问题就在于 sd卡读数据跟不上,“供不应求”
相关推荐阅读
用户244424 2014-08-28 02:05
[转自21IC]旁路电容、去耦电容和消振电容答疑
在三极管放大器中,以共发射极的多级放大器为例,信号从基极输入,在基极偏置电路和集电极负载的作用下,从集电极斩输出,以上是放大器的工作过程。 为何要在发射极加旁路电容呢? 这是因为发射极电阻...
用户244424 2012-11-02 14:19
C语言 头文件 相对路径 (有局限性)
使用当对路径 假如在当前文件夹下的ABC文件夹下: #include   ".\\ABC\\head.h " 假如在当前的上一级文件夹下的ABC文件夹: #include   "..\\ABC\\...
用户244424 2012-03-21 15:14
基本知识: 宏定义的作用范围
  假如在主文件 main.c 中定义 #define _count_buf_size_ 100 #define _Mesure_buf_max_ 15   那么到其他c文件...
用户244424 2011-08-22 23:15
Win7 虚拟机 NAT方式 共享上网
开始对虚拟机NAT方式一点不了解,半天搞不对虚拟机共享上网,网上查了很多教程,明明按着做了还是不对,连接不上,以为是 Visual Network Editor 里的网关设置不对,于是越试越糊涂,最后...
用户244424 2011-08-20 01:19
各种 位数据 倒序 函数
/****************************************//* 函数名称: SwapD7_D0 */ /* 函数功能: D7-D0位置交换 *//****...
用户244424 2011-03-01 15:09
IAR 开发STM32 ARM 版本不兼容 解决办法之一
对于V4 和V5不兼容的解决方法很多了,最近用V6 版开发,结果同事用V5.3版 ,我调通之后代码给他,结果他那边显示错误,配置资料失效了,查看是版本不同导致的懒得转换,但是没办法还是得转换,只好新建...
我要评论
1
10
关闭 站长推荐上一条 /2 下一条