aboutsummaryrefslogtreecommitdiffstats
path: root/Alc
diff options
context:
space:
mode:
Diffstat (limited to 'Alc')
-rw-r--r--Alc/mmdevapi.c19
1 files changed, 10 insertions, 9 deletions
diff --git a/Alc/mmdevapi.c b/Alc/mmdevapi.c
index 11579efb..82a521f2 100644
--- a/Alc/mmdevapi.c
+++ b/Alc/mmdevapi.c
@@ -258,8 +258,8 @@ static ALCboolean MMDevApiResetPlayback(ALCdevice *device)
MMDevApiData *data = device->ExtraData;
WAVEFORMATEXTENSIBLE OutputType;
WAVEFORMATEX *wfx = NULL;
- REFERENCE_TIME def_per;
- UINT32 buffer_len;
+ REFERENCE_TIME min_per;
+ UINT32 buffer_len, min_len;
HRESULT hr;
hr = IAudioClient_GetMixFormat(data->client, &wfx);
@@ -477,8 +477,9 @@ static ALCboolean MMDevApiResetPlayback(ALCdevice *device)
hr = IAudioClient_Initialize(data->client, AUDCLNT_SHAREMODE_SHARED, 0,
- (ALuint64)device->UpdateSize * 10000000 /
- device->Frequency * device->NumUpdates,
+ ((ALuint64)device->UpdateSize*
+ device->NumUpdates*10000000 +
+ device->Frequency-1) / device->Frequency,
0, &OutputType.Format, NULL);
if(FAILED(hr))
{
@@ -486,7 +487,7 @@ static ALCboolean MMDevApiResetPlayback(ALCdevice *device)
return ALC_FALSE;
}
- hr = IAudioClient_GetDevicePeriod(data->client, &def_per, NULL);
+ hr = IAudioClient_GetDevicePeriod(data->client, NULL, &min_per);
if(SUCCEEDED(hr))
hr = IAudioClient_GetBufferSize(data->client, &buffer_len);
if(FAILED(hr))
@@ -495,14 +496,14 @@ static ALCboolean MMDevApiResetPlayback(ALCdevice *device)
return ALC_FALSE;
}
- device->NumUpdates = (ALuint)((REFERENCE_TIME)buffer_len * 10000000 /
- device->Frequency / def_per);
+ min_len = (min_per*device->Frequency + 10000000-1) / 10000000;
+ device->UpdateSize = __max(device->UpdateSize, min_len);
+ device->NumUpdates = buffer_len / device->UpdateSize;
if(device->NumUpdates <= 1)
{
device->NumUpdates = 1;
- ERR("Audio client returned default_period > buffer_len/2; expect break up\n");
+ ERR("Audio client returned min_period > buffer_len/2; expect break up\n");
}
- device->UpdateSize = buffer_len / device->NumUpdates;
hr = IAudioClient_Start(data->client);
if(FAILED(hr))