- 1、本文档共14页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
基于SOPC的SD卡WAV音频播放器设计文档
基于SOPC的SD卡WAV音频播放器
设计报告
组员:贾 登 仪器10802班
张子龙 信工10803班
郭建林 信工10803班
日期:2011年5月29日
基于sopc的sd卡wav音频播放器设计
摘要:本设计使用SOPC Builder在FPGA芯片上定制一个高速CPU实现FPGA与SD卡的SPI模式通信,并根据SD卡的FAT32文件系统读取SD卡内的WAV文件,读到的的音频文件数据送到FIFO模块,以将数据根据其采样率均匀输出到DA播放电路,实现了SD卡根目录下WAV文件的顺序播放、暂停、上一曲、下一曲功能。与SD卡的通信在NIOS Ⅱ 软件中用C语言编写,FIFO模块用Verilog HDL语言编写,音频数据的播放由DAC0832、uA741运放、音箱完成。
关键词:FPGA 、SOPC、SD卡、SPI、FAT32、DA0832
一、设计指标:
系统上电后,自动顺序播放sd卡根目录中所有wav音频文件。Wav音频文件的频率可以是8k、16k、24k、32k、44.1k之中的任何一种,硬件电路自动根据实际的歌曲频率切换输出音乐数据的频率。按键实现播放下一曲、上一曲、暂停功能。
扩展功能:通过遥控器红外线控制播放下一曲、上一曲、暂停
二、硬件平台:
CycloneⅡ EP2C5T144C8 FPGA 开发板(自带sd卡模块)
DAC0832+UA741构成的DA转换模块
其他资源:杜邦线、电源、测试用音箱、(单片机)等。
三、软件平台:
QuartusⅡ 8.1 NIOS Ⅱ 8.1 IDE
四、设计方案:
4.1综合分析:
A、选单片机还是FPGA?
虽然我们跟熟悉的是单片机,但是这个课题对时间要求或者说cpu的处理速度要求较高,单片机接24M晶振也达不到速度上的要求,因此选择fpga是比较合适的。Fpga配上50M的晶振实现高速访问sd卡并实时播放音乐文件是可以实现的。
B、用verilog开发还是C语言开发?
接下来又有两个选择,是采用verilog语言开发还是采用SOPC定制软核再在NIOS Ⅱ IDE中用C语言进行编程实现。若采用verilog进行开发,软件编程上难度较大,时序不容易把握再加上实时调试也比较困难。采用C语言编程,在时序控制上比较容易,借助于NIOS Ⅱ IDE的强大在线调试功能,可以很方便的发现程序的错误并改正。综上几点原因我们选择了用定制cpu的方式进行此课题的设计。
C、采用哪种方式访问sd卡,4位SD模式还是spi模式?
4位sd模式对处理器要求较spi模式要高(crc校验不能忽略),还有cmd命令线是双向端口(发送命令和接受命令都经过cmd线),较spi全部单向传输要麻烦。在实际测试下,spi模式在速度上可以达到本课题设计要求,所以选择了spi模式对sd卡进行通信。
4.2怎样从SD卡读取wav音频文件的数据?
Cpu跟SD卡在底层进行spi通信,在软件上层利用FAT32文件系统获取文件的具体相关信息及文件数据。具体流程如下:
获取SD卡第0扇区的5112字节数据→→→计算得到根目录所在扇区→→→
→→→获取根目录所在扇区的5112字节数据→→→计算音频文件所在扇区或开始簇号→→→根据FAT表分析文件所占有簇的分布情况→→→从而读取整个音频文件
4.3如何保证读到的音频文件按其采样频率输出?
由于sd卡读取数据的速度的不可控性,另外WAV音频文件比较大,一首歌多达十到几十M,只能采用边读边放才能保证音乐实时不间断地放出来。播放的速度只取决于歌曲的采样频率,播放速度在播放过程中不能变化。解决方法:cpu只负责读取音乐数据,FIFO模块将数据按歌曲采样频率送到DAC。FIFO模块产生wren(允许写入信号)通知cpu对FIFO
指定数据块内容进行写入新数据,这样播放的速度就始终保持不变,也能保证完整而不重复地播放音乐文件。
五、系统各模块设计
5.1、SD卡spi通信
电路简化示意图:
5.2、SD卡操作时序图:
5.3、CPU及外设设计
FPGA开发板上50M有源晶振为整个系统提供时钟脉冲信号,为了充分地利用FPGA的高速性能,借助QuartusⅡ 中PLL模块对时钟进行3倍频,就可以让cpu的外部时钟频率达到150M。综合考虑速度及FPGA开发板资源情况,选择cpu类型为标准型,执行速度可达到75DMIPS。
您可能关注的文档
- 国际金融学期末复习题.doc
- 国际金融实务考试试题及答案.doc
- 图书销售管理信息系统分析报告.doc
- 图书馆读者评价反馈意见统计报告.doc
- 图解沉香的产地及特征.doc
- 圆周运动中的追及相遇问题.doc
- 图案 装饰画.ppt
- 圆柱轴承辊子电化学光整加工装置的设计.doc
- 圆的周长说课课件稿.ppt
- 圆管涵施工安全技术交底记录表.doc
- 2023-2024学年广东省深圳市龙岗区高二(上)期末物理试卷(含答案).pdf
- 2023-2024学年贵州省贵阳市普通中学高一(下)期末物理试卷(含答案).pdf
- 21.《大自然的声音》课件(共45张PPT).pptx
- 2023年江西省吉安市吉安县小升初数学试卷(含答案).pdf
- 2024-2025学年广东省清远市九校联考高一(上)期中物理试卷(含答案).pdf
- 广东省珠海市六校联考2024-2025学年高二上学期11月期中考试语文试题.pdf
- 2024-2025学年语文六年级上册第4单元-单元素养测试(含答案).pdf
- 2024-2025学年重庆八中高三(上)月考物理试卷(10月份)(含答案).pdf
- 安徽省安庆市潜山市北片学校联考2024-2025学年七年级上学期期中生物学试题(含答案).pdf
- 贵州省部分校2024-2025学年九年级上学期期中联考数学试题(含答案).pdf
文档评论(0)