dev builds
themes manual
device status forums
mailing lists
IRC bugs
dev guide

Rockbox mail archive

Subject: WAV codec: dvi adpcm broken again

WAV codec: dvi adpcm broken again

From: Frederic Devernay <>
Date: Tue, 21 Mar 2006 00:35:41 +0100

As Thom guessed, he broke the WAV codec while code-policing it...

So, Thom, I'm donating that DVI ADPCM file from my own private
collection so that you can fix your bug :-)
get it at (it's recorded from
an Olympus voice recorder). You can attach it to the codecs page in the
wiki if you want (it's 15Kb).

I'm attaching a patch the DEBUGFs I use for the WAV codec, you'll see
that chunksize==0 so that the file doesn't play. The previous version


Index: apps/codecs/wav.c
RCS file: /cvsroot/rockbox/apps/codecs/wav.c,v
retrieving revision 1.22
diff -u -r1.22 wav.c
--- apps/codecs/wav.c 20 Mar 2006 20:32:19 -0000 1.22
+++ apps/codecs/wav.c 20 Mar 2006 23:32:39 -0000
_at__at_ -349,6 +349,7 _at__at_
         n -= i + 8;
+ DEBUGF("WAVE formattag=0x%04x, channels=%d, avgbytespersec=%d, bitspersample=%d\n", formattag, channels, avgbytespersec, bitspersample);
     if (channels == 0) {
         DEBUGF("CODEC_ERROR: 'fmt ' chunk not found or 0-channels file\n");
         i = CODEC_ERROR;
_at__at_ -450,6 +451,7 _at__at_
         wavbuf = (uint8_t *)ci->request_buffer((long *)&n, chunksize);
+ DEBUGF("WAVE: decoding %d bytes (requested %d)\n", n, chunksize);
         if (n == 0)
             break; /* End of stream */
_at__at_ -500,6 +502,7 _at__at_
             for (i = 0; i < nblocks; i++) {
                 size_t decodedsize = samplesperblock*channels;
+ DEBUGF("WAVE: DVI_ADPCM: decoding block %d/%d\n", i+1, nblocks);
                 if (decode_dvi_adpcm(ci, ((uint8_t *)wavbuf) + i*blockalign,
                                      blockalign, channels, bitspersample,
                                      samples + i*samplesperblock*channels,
Received on 2006-03-21

Page template was last modified "Tue Sep 7 00:00:02 2021" The Rockbox Crew -- Privacy Policy