I’m trying to play 44100khz FLAC files from an SD card on a Panda II with the FEZ Music Shield. I’ve loaded the FLAC patch plugin, and the file “plays”, but it is VERY choppy. I’m thinking that it may be the rate at which I’m reading data from the SD card?? Here’s my code (slightly modified version of GHI driver):
private void PlayStreamThread()
{
this.spiPort.Config = this.spiDataConfig;
while (this.playState == PlayState.Playing && this.playBackStream.Position < this.playBackStream.Length)
{
while (this.dataReq.Read() == false)
; // wait till done
if (this.playBackStream.Length - this.playBackStream.Position <= 32)
this.playBackStream.Read(this.blockBuffer, 0, (int)(this.playBackStream.Length - this.playBackStream.Position));
else
this.playBackStream.Read(this.blockBuffer, 0, 32);
this.spiPort.Write(this.blockBuffer);
}
while (this.playState == PlayState.Playing)
Thread.Sleep(100);
this.CancelPlay();
if (this.playBackStream != null)
{
this.playBackStream.Close();
this.playBackStream = null;
}
}
@ Hyperlisk - @ jasdev
Hi, where is the bottleneck? Which codecs can be used with managed code on our NETMF mainboards? What are the datarates that can be reached with reading from SD-card?
Regards
Roland
@ andre.m -
thank you. I think, the decoding is done by the FEZ Music Shield, which is nothing else (I think) as the GHI Music module. The issue is to bring the data of the encoded (compressed) music file fast enough to this decoding device.
Roland
Btw: Where is WouterH, so many valuable posts an last online Jan. 14, 2013
@ Hyperlisk - I remember seeing something about an RLP driver for use with the music shield. I’ll try to find it.
@ RoSchmi - Yes, the issue is not the music shield. It uses the VS1053b chip to do the decoding, and it plays mp3 files from SD just fine. The data sheet for the FLAC plugin indicates that it is capable of playing 44khz files. The bottleneck must be in the SPI interface or in the SD interface.
@ andre.m - I remember seeing something from Whouter. I’ll try to find it.
@ Architect - thanks I didn’t know you could send larger chunks of data to the device. I’ll re-read the manual, and try it tonight.
@ Architect -
Hi,
I read in the manual that only for chunks of 32 byte it is guaranteed that the buffer of the VS1053b chip has enough free space to hold the sent data. How did you manage to avoid buffer overflow?
Regards
Roland
The first two changes seemed to have little or no affect.
The third change did help a lot, but did not eliminate the problem, and if I made that buffer too large, I would end up with the overflow condition that RoSchmi mentioned.
I’m marking Architect’s answer since his suggestion helped the most.
Next I’m going to try to port godFather89’s code to the Panda II: