fix unsigned 16bit samples sb16 output
Imported-from: https://svn.code.sf.net/p/dosbox/code-0/dosbox/trunk@2690
This commit is contained in:
parent
2bb31be532
commit
be9a70adfd
3 changed files with 32 additions and 13 deletions
|
@ -50,12 +50,14 @@ public:
|
|||
void SetFreq(Bitu _freq);
|
||||
void Mix(Bitu _needed);
|
||||
void AddSilence(void); //Fill up until needed
|
||||
template<bool _8bit,bool stereo>
|
||||
template<bool _8bit,bool stereo,bool signeddata>
|
||||
void AddSamples(Bitu len,void * data);
|
||||
void AddSamples_m8(Bitu len,Bit8u * data);
|
||||
void AddSamples_s8(Bitu len,Bit8u * data);
|
||||
void AddSamples_m16(Bitu len,Bit16s * data);
|
||||
void AddSamples_s16(Bitu len,Bit16s * data);
|
||||
void AddSamples_m16u(Bitu len,Bit16u * data);
|
||||
void AddSamples_s16u(Bitu len,Bit16u * data);
|
||||
void AddStretched(Bitu len,Bit16s * data); //Strech block up into needed data
|
||||
void FillUp(void);
|
||||
void Enable(bool _yesno);
|
||||
|
|
|
@ -16,7 +16,7 @@
|
|||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*/
|
||||
|
||||
/* $Id: mixer.cpp,v 1.40 2006-05-18 11:32:09 qbix79 Exp $ */
|
||||
/* $Id: mixer.cpp,v 1.41 2006-08-21 20:08:26 c2woody Exp $ */
|
||||
|
||||
/*
|
||||
Remove the sdl code from here and have it handeld in the sdlmain.
|
||||
|
@ -178,11 +178,12 @@ void MixerChannel::AddSilence(void) {
|
|||
}
|
||||
}
|
||||
|
||||
template<bool _8bits,bool stereo>
|
||||
template<bool _8bits,bool stereo,bool signeddata>
|
||||
INLINE void MixerChannel::AddSamples(Bitu len,void * data) {
|
||||
Bits diff[2];
|
||||
Bit8u * data8=(Bit8u*)data;
|
||||
Bit16s * data16=(Bit16s*)data;
|
||||
Bit16u * data16u=(Bit16u*)data;
|
||||
Bitu mixpos=mixer.pos+done;
|
||||
freq_index&=MIXER_REMAIN;
|
||||
Bitu pos=0;Bitu new_pos;
|
||||
|
@ -204,11 +205,20 @@ thestart:
|
|||
diff[0]=(((Bit8s)(data8[pos] ^ 0x80)) << 8)-last[0];
|
||||
}
|
||||
} else {
|
||||
if (stereo) {
|
||||
diff[0]=data16[pos*2+0]-last[0];
|
||||
diff[1]=data16[pos*2+1]-last[1];
|
||||
if (signeddata) {
|
||||
if (stereo) {
|
||||
diff[0]=data16[pos*2+0]-last[0];
|
||||
diff[1]=data16[pos*2+1]-last[1];
|
||||
} else {
|
||||
diff[0]=data16[pos]-last[0];
|
||||
}
|
||||
} else {
|
||||
diff[0]=data16[pos]-last[0];
|
||||
if (stereo) {
|
||||
diff[0]=data16u[pos*2+0]-last[0];
|
||||
diff[1]=data16u[pos*2+1]-last[1];
|
||||
} else {
|
||||
diff[0]=data16u[pos]-last[0];
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -252,16 +262,22 @@ void MixerChannel::AddStretched(Bitu len,Bit16s * data) {
|
|||
};
|
||||
|
||||
void MixerChannel::AddSamples_m8(Bitu len,Bit8u * data) {
|
||||
AddSamples<true,false>(len,data);
|
||||
AddSamples<true,false,false>(len,data);
|
||||
}
|
||||
void MixerChannel::AddSamples_s8(Bitu len,Bit8u * data) {
|
||||
AddSamples<true,true>(len,data);
|
||||
AddSamples<true,true,false>(len,data);
|
||||
}
|
||||
void MixerChannel::AddSamples_m16(Bitu len,Bit16s * data) {
|
||||
AddSamples<false,false>(len,data);
|
||||
AddSamples<false,false,true>(len,data);
|
||||
}
|
||||
void MixerChannel::AddSamples_s16(Bitu len,Bit16s * data) {
|
||||
AddSamples<false,true>(len,data);
|
||||
AddSamples<false,true,true>(len,data);
|
||||
}
|
||||
void MixerChannel::AddSamples_m16u(Bitu len,Bit16u * data) {
|
||||
AddSamples<false,false,false>(len,data);
|
||||
}
|
||||
void MixerChannel::AddSamples_s16u(Bitu len,Bit16u * data) {
|
||||
AddSamples<false,true,false>(len,data);
|
||||
}
|
||||
|
||||
void MixerChannel::FillUp(void) {
|
||||
|
|
|
@ -16,7 +16,7 @@
|
|||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*/
|
||||
|
||||
/* $Id: sblaster.cpp,v 1.55 2006-08-16 16:08:24 c2woody Exp $ */
|
||||
/* $Id: sblaster.cpp,v 1.56 2006-08-21 20:08:26 c2woody Exp $ */
|
||||
|
||||
#include <string.h>
|
||||
#include <math.h>
|
||||
|
@ -418,7 +418,8 @@ static void GenerateDMASound(Bitu size) {
|
|||
if (sb.dma.stereo) {
|
||||
read=sb.dma.chan->Read(size,(Bit8u *)&sb.dma.buf.b16[sb.dma.remain_size]);
|
||||
Bitu total=read+sb.dma.remain_size;
|
||||
sb.chan->AddSamples_s16(total>>1,sb.dma.buf.b16);
|
||||
if (sb.dma.sign) sb.chan->AddSamples_s16(total>>1,sb.dma.buf.b16);
|
||||
else sb.chan->AddSamples_s16u(total>>1,(Bit16u *)sb.dma.buf.b16);
|
||||
if (total&1) {
|
||||
sb.dma.remain_size=1;
|
||||
sb.dma.buf.b16[0]=sb.dma.buf.b16[total-1];
|
||||
|
|
Loading…
Add table
Reference in a new issue