mirror of
https://github.com/Ryujinx/SDL.git
synced 2025-01-11 11:55:35 +00:00
SDL_os2audio.c (OS2_OpenDevice): change spec->samples assignment:
Original code assigned MCIMixSetup.ulSamplesPerSec value to it, but it is just the freq... We now change spec->samples only either if it is 0 or we changed the frequency, by picking a default of ~46 ms at desired frequency (code taken from SDL_audio.c:prepare_audiospec()). With this, the crashes I have been experiencing are gone.
This commit is contained in:
parent
e112b776fc
commit
a3d7913c07
|
@ -268,7 +268,9 @@ static int OS2_OpenDevice(_THIS, void *handle, const char *devname,
|
||||||
MCI_BUFFER_PARMS stMCIBuffer;
|
MCI_BUFFER_PARMS stMCIBuffer;
|
||||||
ULONG ulRC;
|
ULONG ulRC;
|
||||||
ULONG ulIdx;
|
ULONG ulIdx;
|
||||||
|
BOOL new_freq;
|
||||||
|
|
||||||
|
new_freq = FALSE;
|
||||||
SDL_zero(stMCIAmpOpen);
|
SDL_zero(stMCIAmpOpen);
|
||||||
SDL_zero(stMCIBuffer);
|
SDL_zero(stMCIBuffer);
|
||||||
|
|
||||||
|
@ -350,10 +352,12 @@ static int OS2_OpenDevice(_THIS, void *handle, const char *devname,
|
||||||
if ( this->spec.freq < 8000 )
|
if ( this->spec.freq < 8000 )
|
||||||
{
|
{
|
||||||
this->spec.freq = 8000;
|
this->spec.freq = 8000;
|
||||||
|
new_freq = TRUE;
|
||||||
}
|
}
|
||||||
else if ( this->spec.freq > 48000 )
|
else if ( this->spec.freq > 48000 )
|
||||||
{
|
{
|
||||||
this->spec.freq = 48000;
|
this->spec.freq = 48000;
|
||||||
|
new_freq = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Setup mixer.
|
// Setup mixer.
|
||||||
|
@ -377,6 +381,7 @@ static int OS2_OpenDevice(_THIS, void *handle, const char *devname,
|
||||||
MCI_WAIT | MCI_MIXSETUP_INIT, &pAData->stMCIMixSetup, 0 );
|
MCI_WAIT | MCI_MIXSETUP_INIT, &pAData->stMCIMixSetup, 0 );
|
||||||
if ( ( ulRC != MCIERR_SUCCESS ) && ( this->spec.freq > 44100 ) )
|
if ( ( ulRC != MCIERR_SUCCESS ) && ( this->spec.freq > 44100 ) )
|
||||||
{
|
{
|
||||||
|
new_freq = TRUE;
|
||||||
pAData->stMCIMixSetup.ulSamplesPerSec = 44100;
|
pAData->stMCIMixSetup.ulSamplesPerSec = 44100;
|
||||||
this->spec.freq = 44100;
|
this->spec.freq = 44100;
|
||||||
ulRC = mciSendCommand( pAData->usDeviceId, MCI_MIXSETUP,
|
ulRC = mciSendCommand( pAData->usDeviceId, MCI_MIXSETUP,
|
||||||
|
@ -395,13 +400,22 @@ static int OS2_OpenDevice(_THIS, void *handle, const char *devname,
|
||||||
return _MCIError( "MCI_MIXSETUP", ulRC );
|
return _MCIError( "MCI_MIXSETUP", ulRC );
|
||||||
}
|
}
|
||||||
|
|
||||||
this->spec.samples = pAData->stMCIMixSetup.ulSamplesPerSec;
|
if (this->spec.samples == 0 || new_freq == TRUE) {
|
||||||
|
/* also see SDL_audio.c:prepare_audiospec() */
|
||||||
|
/* Pick a default of ~46 ms at desired frequency */
|
||||||
|
Uint32 samples = (this->spec.freq / 1000) * 46;
|
||||||
|
Uint32 power2 = 1;
|
||||||
|
while (power2 < samples) {
|
||||||
|
power2 <<= 1;
|
||||||
|
}
|
||||||
|
this->spec.samples = power2;
|
||||||
|
}
|
||||||
/* Update the fragment size as size in bytes */
|
/* Update the fragment size as size in bytes */
|
||||||
SDL_CalculateAudioSpec( &this->spec );
|
SDL_CalculateAudioSpec( &this->spec );
|
||||||
|
|
||||||
// Allocate memory buffers
|
// Allocate memory buffers
|
||||||
|
|
||||||
stMCIBuffer.ulBufferSize = (this->spec.freq / 1000) * 100;// this->spec.size;
|
stMCIBuffer.ulBufferSize = this->spec.size;// (this->spec.freq / 1000) * 100;
|
||||||
stMCIBuffer.ulNumBuffers = NUM_BUFFERS;
|
stMCIBuffer.ulNumBuffers = NUM_BUFFERS;
|
||||||
stMCIBuffer.pBufList = &pAData->aMixBuffers;
|
stMCIBuffer.pBufList = &pAData->aMixBuffers;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue