FPGA 读写SD卡音乐播放例程Verilog逻辑源码Quartus工程文件+文档说明,,FPGA型号Cyclone4E系列中的EP4CE6F17C8,Quartus版本17.1。
实验简介
在其他实验中我们已经完成了 SD 卡读写和音频模块的录音播放,本实验通过搜索 SD 卡中
WAV 音乐文件,然后送到音频模块播放,完成一个简单音乐播放器的功能。
2 实验原理
本实验一个关键是在没有文件系统的情况下,搜索 SD 卡每个扇区的内容,匹配出 WAV 文件,
这里有一个假设:假设每一个文件都是从一个扇区第一个字节开始而且文件是连续存储的,经过
大量实验,发现 FAT32 文件格式中的文件确实如此。
2.1 WAV 文件格式
大部分的文件都有文件头,WAV 也丌例外,我们通过分析 SD 卡一个扇区的前几个字节,判
断这个文件是否为 WAV 文件。
WAV 文件作为多媒体中使用的声波文件格式之一,它是以 RIFF 格式为标准的。RIFF 是英文
Resource Interchange File Format 的缩写,每个 WAV 文件的头四个字节便是“RIFF”,所以本实验
就简单的以每个扇区的前 4 个字节是否为“RIFF”判断该文件是否为 WAV 文件,紧接着 4 个字节
表示文件的大小,这样我们就可以确定要读取的数据量。WAV 文件头大小是 88 字节,在播放时
要把前 88 个字节的文件头去掉。
module top(
input clk,
input rst_n,
input key1,
input wm8731_bclk, //audio bit clock
input wm8731_daclrc, //DAC sample rate left right clock
output wm8731_dacdat, //DAC audio data output
input wm8731_adclrc, //ADC sample rate left right clock
input wm8731_adcdat, //ADC audio data input
inout wm8731_scl, //I2C clock
inout wm8731_sda, //I2C data
output sd_ncs, //SD card chip select (SPI mode)
output sd_dclk, //SD card clock
output sd_mosi, //SD card controller data output
input sd_miso, //SD card controller data input
output [5:0] seg_sel,
output [7:0] seg_data
);
wire[9:0] lut_index;
wire[31:0] lut_data;
wire[3:0] state_code;
wire[6:0] seg_data_0;
//I2C master controller
i2c_config i2c_config_m0(
.rst (~rst_n ),
.clk (clk ),