the libmad samples need to be scaled properly. the
previous assumption was that it is 32 bits, but it
really is MAD_F_FRACTBITS + sign bit and rest used
for overflow.
thanks eekee!
rate = pcm->samplerate;
chans = pcm->channels;
- snprint(fmt, sizeof(fmt), "s32r%dc%d", rate, chans);
+ snprint(fmt, sizeof(fmt), "s%dr%dc%d", MAD_F_FRACBITS+1, rate, chans);
if(ifd >= 0){
close(ifd);
p = buf + j*4;
for(i=0; i < pcm->length; i++){
v = *s++;
+
+ /* clipping */
+ if(v >= MAD_F_ONE)
+ v = MAD_F_ONE-1;
+ else if(v < -MAD_F_ONE)
+ v = -MAD_F_ONE;
+
p[0] = v, v>>=8;
p[1] = v, v>>=8;
p[2] = v, v>>=8;