X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;f=snd_alsa.c;h=3f4292c84e7f73edf2a2f49a7f36707c0980a374;hb=0915d731759ea1a90cbb4080ecfd49904196e4f2;hp=4601e9c4da7af434e3ebec72f0514212ee7c80a6;hpb=57f2a6efbacd89bcf6b160603f18a55774640d54;p=xonotic%2Fdarkplaces.git diff --git a/snd_alsa.c b/snd_alsa.c index 4601e9c4..3f4292c8 100644 --- a/snd_alsa.c +++ b/snd_alsa.c @@ -30,7 +30,7 @@ #include "snd_main.h" -#define NB_PERIODS 2 +#define NB_PERIODS 4 static snd_pcm_t* pcm_handle = NULL; static snd_pcm_sframes_t expected_delay = 0; @@ -222,7 +222,14 @@ seqdone: goto init_error; } - buffer_size = requested->speed / 5; + // pick a buffer size that is a power of 2 (by masking off low bits) + buffer_size = i = (int)(requested->speed * 0.15f); + while (buffer_size & (buffer_size-1)) + buffer_size &= (buffer_size-1); + // then check if it is the nearest power of 2 and bump it up if not + if (i - buffer_size >= buffer_size >> 1) + buffer_size *= 2; + err = snd_pcm_hw_params_set_buffer_size_near (pcm_handle, hw_params, &buffer_size); if (err < 0) { @@ -231,6 +238,8 @@ seqdone: goto init_error; } + // pick a period size near the buffer_size we got from ALSA + snd_pcm_hw_params_get_buffer_size (hw_params, &buffer_size); buffer_size /= NB_PERIODS; err = snd_pcm_hw_params_set_period_size_near(pcm_handle, hw_params, &buffer_size, 0); if (err < 0) @@ -344,8 +353,8 @@ static snd_pcm_sframes_t SndSys_Write (const unsigned char* buffer, unsigned int written = snd_pcm_writei (pcm_handle, buffer, nbframes); if (written < 0) { - if (developer.integer >= 1000 && vid_activewindow) - Con_Printf ("SndSys_Write: audio write returned %ld (%s)!\n", + if (developer_insane.integer && vid_activewindow) + Con_DPrintf ("SndSys_Write: audio write returned %ld (%s)!\n", written, snd_strerror (written)); if (SndSys_Recover (written)) @@ -422,7 +431,7 @@ unsigned int SndSys_GetSoundTime (void) err = snd_pcm_delay (pcm_handle, &delay); if (err < 0) { - if (developer.integer >= 1000 && vid_activewindow) + if (developer_insane.integer && vid_activewindow) Con_DPrintf ("SndSys_GetSoundTime: can't get playback delay (%s)\n", snd_strerror (err));