Optimized wave writing a bit.
This commit is contained in:
@@ -2104,8 +2104,7 @@ static void raw_audio_write(unsigned int samples)
|
|||||||
void ProcessSoundBuffer();
|
void ProcessSoundBuffer();
|
||||||
extern int DSPBuffer[1280];
|
extern int DSPBuffer[1280];
|
||||||
extern unsigned int BufferSizeB, BufferSizeW;
|
extern unsigned int BufferSizeB, BufferSizeW;
|
||||||
unsigned int i = 0;
|
int *d = DSPBuffer, *d_end;
|
||||||
int temp;
|
|
||||||
|
|
||||||
if (samples > 1280)
|
if (samples > 1280)
|
||||||
{
|
{
|
||||||
@@ -2118,12 +2117,11 @@ static void raw_audio_write(unsigned int samples)
|
|||||||
|
|
||||||
asm_call(ProcessSoundBuffer);
|
asm_call(ProcessSoundBuffer);
|
||||||
|
|
||||||
for (i = 0; i < BufferSizeB; i++)
|
for (d_end = DSPBuffer+samples; d < d_end; d++)
|
||||||
{
|
{
|
||||||
temp = DSPBuffer[i];
|
if ((unsigned int)(*d + 0x8000) <= 0xFFFF) {fwrite2((short)*d, raw_vid.ap); continue; }
|
||||||
if (temp > 32767) { temp = 32767; }
|
if (*d > 0x7FFF) { fwrite2(0x7FFF, raw_vid.ap); }
|
||||||
else if (temp < -32768) { temp =-32768; }
|
else { 0x8000; }
|
||||||
fwrite2((short)temp, raw_vid.ap);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user