mirror of https://github.com/PCSX2/pcsx2.git
SPU2Ghz: Part one of a bigger update
git-svn-id: http://pcsx2-playground.googlecode.com/svn/trunk@202 a6443dda-0b58-4228-96e9-037be469359c
This commit is contained in:
parent
e6d4aaf114
commit
6c2d95f27d
|
@ -363,7 +363,8 @@ void GetVoiceValues(s32& Value) {
|
||||||
vc.SP+=pitch;
|
vc.SP+=pitch;
|
||||||
while(vc.SP>=4096)
|
while(vc.SP>=4096)
|
||||||
{
|
{
|
||||||
DT=0;
|
//this isn't needed. it's garaunteed to be assigned a valid value.
|
||||||
|
//DT=0;
|
||||||
|
|
||||||
if(vc.Noise)
|
if(vc.Noise)
|
||||||
GetNoiseValues(DT);
|
GetNoiseValues(DT);
|
||||||
|
@ -379,7 +380,6 @@ void GetVoiceValues(s32& Value) {
|
||||||
}
|
}
|
||||||
|
|
||||||
CalculateADSR();
|
CalculateADSR();
|
||||||
// CalculateADSR();
|
|
||||||
|
|
||||||
if(vc.ADSR.Phase==0)
|
if(vc.ADSR.Phase==0)
|
||||||
{
|
{
|
||||||
|
@ -388,12 +388,18 @@ void GetVoiceValues(s32& Value) {
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if(Interpolation==0) {
|
// if SP is zero then we landed perfectly on a sample source, no
|
||||||
|
// interpolation necessary (this is important too, since the
|
||||||
|
// interpolator will pick the wrong sample to mix).
|
||||||
|
|
||||||
|
if(Interpolation==0 || vc.SP == 0) {
|
||||||
Data = vc.PV1;
|
Data = vc.PV1;
|
||||||
}
|
}
|
||||||
else if(Interpolation==1) //linear
|
else if(Interpolation==1) //linear
|
||||||
{
|
{
|
||||||
s64 t0 = vc.PV1 - vc.PV2;
|
// [Air]: Inverted the interpolation delta. The old way was generating
|
||||||
|
// inverted waveforms.
|
||||||
|
s64 t0 = vc.PV2 - vc.PV1;
|
||||||
s64 t1 = vc.PV1;
|
s64 t1 = vc.PV1;
|
||||||
Data = (((t0*vc.SP)>>12) + t1);
|
Data = (((t0*vc.SP)>>12) + t1);
|
||||||
}
|
}
|
||||||
|
@ -403,11 +409,11 @@ void GetVoiceValues(s32& Value) {
|
||||||
s64 a1 = vc.PV4 - vc.PV3 - a0;
|
s64 a1 = vc.PV4 - vc.PV3 - a0;
|
||||||
s64 a2 = vc.PV1 - vc.PV4;
|
s64 a2 = vc.PV1 - vc.PV4;
|
||||||
s64 a3 = vc.PV2;
|
s64 a3 = vc.PV2;
|
||||||
s64 mu = vc.SP;
|
s64 mu = 4096-vc.SP;
|
||||||
|
|
||||||
s64 t0 = ((a0 )*mu)>>12;
|
s64 t0 = ((a0 )*mu)>>18; //all 3 were >>12, was causing ugly, loud overflow sound
|
||||||
s64 t1 = ((t0+a1)*mu)>>12;
|
s64 t1 = ((t0+a1)*mu)>>18;
|
||||||
s64 t2 = ((t1+a2)*mu)>>12;
|
s64 t2 = ((t1+a2)*mu)>>18;
|
||||||
s64 t3 = ((t2+a3));
|
s64 t3 = ((t2+a3));
|
||||||
|
|
||||||
Data = t3;
|
Data = t3;
|
||||||
|
@ -417,7 +423,7 @@ void GetVoiceValues(s32& Value) {
|
||||||
|
|
||||||
vc.OutX=abs(Value);
|
vc.OutX=abs(Value);
|
||||||
}
|
}
|
||||||
if(vc.PeakX<vc.OutX) vc.PeakX=vc.OutX;
|
//if(vc.PeakX<vc.OutX) vc.PeakX=vc.OutX;
|
||||||
}
|
}
|
||||||
|
|
||||||
/////////////////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
|
@ -282,7 +282,7 @@ float valAccum1 = 1.0f;
|
||||||
float valAccum2 = 1.0f;
|
float valAccum2 = 1.0f;
|
||||||
u32 numAccum = 1;
|
u32 numAccum = 1;
|
||||||
|
|
||||||
const u32 numUpdates = 112;
|
const u32 numUpdates = 96;
|
||||||
|
|
||||||
float lastTempo=1;
|
float lastTempo=1;
|
||||||
float cTempo=1;
|
float cTempo=1;
|
||||||
|
@ -312,21 +312,21 @@ void UpdateTempoChange()
|
||||||
s32 bufferSize = sndBuffer->GetBufferSize();
|
s32 bufferSize = sndBuffer->GetBufferSize();
|
||||||
|
|
||||||
//Emergency stretch to compensate for FPS fluctuations and keep the buffers happy
|
//Emergency stretch to compensate for FPS fluctuations and keep the buffers happy
|
||||||
bool a=(bufferUsage < CurBufferSize * 2.5);
|
bool a=(bufferUsage < CurBufferSize * 4);
|
||||||
bool b=(bufferUsage >= (bufferSize - CurBufferSize * 2.5));
|
bool b=(bufferUsage >= (bufferSize - CurBufferSize * 4));
|
||||||
|
|
||||||
if(a!=b)
|
if(a!=b)
|
||||||
{
|
{
|
||||||
if (bufferUsage < CurBufferSize) { cTempo*=0.7f; }
|
if (bufferUsage < CurBufferSize * 1.5) { cTempo*=0.70f; }
|
||||||
else if(bufferUsage < CurBufferSize * 2) { cTempo*=0.90f; }
|
else if(bufferUsage < CurBufferSize * 2) { cTempo*=0.90f; }
|
||||||
else if(bufferUsage < CurBufferSize * 2.5) { cTempo*=0.95f; }
|
else if(bufferUsage < CurBufferSize * 3.9) { cTempo*=0.95f; }
|
||||||
|
|
||||||
if (bufferUsage > (bufferSize - CurBufferSize)) { cTempo*=1.3f; }
|
if (bufferUsage > (bufferSize - CurBufferSize * 1.5)) { cTempo*=1.30f; }
|
||||||
else if(bufferUsage > (bufferSize - CurBufferSize * 2)) { cTempo*=1.10f; }
|
else if(bufferUsage > (bufferSize - CurBufferSize * 2)) { cTempo*=1.10f; }
|
||||||
else if(bufferUsage > (bufferSize - CurBufferSize * 2.5)) { cTempo*=1.05f; }
|
else if(bufferUsage > (bufferSize - CurBufferSize * 3.9)) { cTempo*=1.05f; }
|
||||||
|
|
||||||
if (cTempo != lastTempo) {
|
if (cTempo != lastTempo) {
|
||||||
printf("%f %d\n",cTempo,bufferUsage);
|
//printf("%f %d\n",cTempo,bufferUsage);
|
||||||
pSoundTouch->setTempo(cTempo);
|
pSoundTouch->setTempo(cTempo);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -354,12 +354,12 @@ void UpdateTempoChange()
|
||||||
|
|
||||||
if((valAccum < 1.05f) && (valAccum > 0.95f) /*&& (valAccum != 1)*/)
|
if((valAccum < 1.05f) && (valAccum > 0.95f) /*&& (valAccum != 1)*/)
|
||||||
{
|
{
|
||||||
printf("Timestretch Debug > Playbackpeed: %f (difference disregarded, using 1.0).\n",valAccum);
|
//printf("Timestretch Debug > Playbackpeed: %f (difference disregarded, using 1.0).\n",valAccum);
|
||||||
valAccum = 1.0f;
|
valAccum = 1.0f;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
printf("Timestretch Debug > Playbackpeed: %f\n",valAccum);
|
// printf("Timestretch Debug > Playbackpeed: %f\n",valAccum);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (valAccum != lastTempo) //only update soundtouch object when needed
|
if (valAccum != lastTempo) //only update soundtouch object when needed
|
||||||
|
|
Loading…
Reference in New Issue