mirror of
https://git.code.sf.net/p/quake/quakeforge-old
synced 2025-01-31 20:50:36 +00:00
Improved device handling. By default, quake will now grovel around ALSA'a
device list to find an available output device. This means that for systems with multiple cards or a card with more than one playback device, quake and another app can run at the same time (eg an mp3 player and quake)
This commit is contained in:
parent
9388195afb
commit
008039dd4f
1 changed files with 84 additions and 9 deletions
|
@ -45,7 +45,6 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
# define MAP_FAILED ((void*)-1)
|
# define MAP_FAILED ((void*)-1)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static int tryrates[] = { 11025, 22051, 44100, 8000 };
|
|
||||||
static int snd_inited;
|
static int snd_inited;
|
||||||
|
|
||||||
static snd_pcm_t *pcm_handle;
|
static snd_pcm_t *pcm_handle;
|
||||||
|
@ -54,19 +53,95 @@ static struct snd_pcm_channel_params params;
|
||||||
static struct snd_pcm_channel_setup setup;
|
static struct snd_pcm_channel_setup setup;
|
||||||
static snd_pcm_mmap_control_t *mmap_control = NULL;
|
static snd_pcm_mmap_control_t *mmap_control = NULL;
|
||||||
static char *mmap_data = NULL;
|
static char *mmap_data = NULL;
|
||||||
|
static int card=-1,dev=-1;
|
||||||
|
|
||||||
|
int check_card(int card)
|
||||||
|
{
|
||||||
|
snd_ctl_t *handle;
|
||||||
|
snd_ctl_hw_info_t info;
|
||||||
|
int rc;
|
||||||
|
|
||||||
|
if ((rc = snd_ctl_open(&handle, card)) < 0) {
|
||||||
|
Con_Printf("Error: control open (%i): %s\n", card, snd_strerror(rc));
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
if ((rc = snd_ctl_hw_info(handle, &info)) < 0) {
|
||||||
|
Con_Printf("Error: control hardware info (%i): %s\n", card,
|
||||||
|
snd_strerror(rc));
|
||||||
|
snd_ctl_close(handle);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
snd_ctl_close(handle);
|
||||||
|
if (dev==-1) {
|
||||||
|
for (dev = 0; dev < info.pcmdevs; dev++) {
|
||||||
|
if ((rc=snd_pcm_open(&pcm_handle,card,dev,
|
||||||
|
SND_PCM_OPEN_PLAYBACK
|
||||||
|
| SND_PCM_OPEN_NONBLOCK))==0) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (dev>=0 && dev <info.pcmdevs) {
|
||||||
|
if ((rc=snd_pcm_open(&pcm_handle,card,dev,
|
||||||
|
SND_PCM_OPEN_PLAYBACK
|
||||||
|
| SND_PCM_OPEN_NONBLOCK))==0) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
qboolean SNDDMA_Init(void)
|
qboolean SNDDMA_Init(void)
|
||||||
{
|
{
|
||||||
int card=0,dev=0;
|
int rc=0,i;
|
||||||
int rc;
|
|
||||||
char *err_msg="";
|
char *err_msg="";
|
||||||
int rate,format,bps,stereo,frag_size;
|
int rate,format,bps,stereo,frag_size;
|
||||||
|
unsigned int mask;
|
||||||
|
|
||||||
if ((rc=snd_pcm_open(&pcm_handle,card,dev,SND_PCM_OPEN_PLAYBACK))<0) {
|
mask = snd_cards_mask();
|
||||||
Con_Printf( "Error: audio open error: %s\n", snd_strerror(rc));
|
if (!mask) {
|
||||||
|
Con_Printf("No sound cards detected\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
if ((i=COM_CheckParm("-sndcard"))!=0) {
|
||||||
|
card=atoi(com_argv[i+1]);
|
||||||
|
}
|
||||||
|
if ((i=COM_CheckParm("-snddev"))!=0) {
|
||||||
|
dev=atoi(com_argv[i+1]);
|
||||||
|
}
|
||||||
|
if (card==-1) {
|
||||||
|
for (card=0; card<SND_CARDS; card++) {
|
||||||
|
if (!(mask & (1<<card)))
|
||||||
|
continue;
|
||||||
|
rc=check_card(card);
|
||||||
|
if (rc<0)
|
||||||
|
return 0;
|
||||||
|
if (!rc)
|
||||||
|
goto dev_openned;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (dev==-1) {
|
||||||
|
rc=check_card(card);
|
||||||
|
if (rc<0)
|
||||||
|
return 0;
|
||||||
|
if (!rc)
|
||||||
|
goto dev_openned;
|
||||||
|
} else {
|
||||||
|
if ((rc=snd_pcm_open(&pcm_handle,card,dev,
|
||||||
|
SND_PCM_OPEN_PLAYBACK
|
||||||
|
| SND_PCM_OPEN_NONBLOCK))<0) {
|
||||||
|
Con_Printf("Error: audio open error: %s\n", snd_strerror(rc));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
goto dev_openned;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Con_Printf("Error: audio open error: %s\n", snd_strerror(rc));
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
dev_openned:
|
||||||
|
Con_Printf("Using card %d, device %d.\n", card, dev);
|
||||||
memset(&cinfo, 0, sizeof(cinfo));
|
memset(&cinfo, 0, sizeof(cinfo));
|
||||||
cinfo.channel = SND_PCM_CHANNEL_PLAYBACK;
|
cinfo.channel = SND_PCM_CHANNEL_PLAYBACK;
|
||||||
snd_pcm_channel_info(pcm_handle, &cinfo);
|
snd_pcm_channel_info(pcm_handle, &cinfo);
|
||||||
|
@ -81,7 +156,7 @@ qboolean SNDDMA_Init(void)
|
||||||
rate=11025;
|
rate=11025;
|
||||||
frag_size=128; /* assuming stereo 8 bit */
|
frag_size=128; /* assuming stereo 8 bit */
|
||||||
} else {
|
} else {
|
||||||
Con_Printf( "ALSA: desired rates not supported\n");
|
Con_Printf("ALSA: desired rates not supported\n");
|
||||||
goto error_2;
|
goto error_2;
|
||||||
}
|
}
|
||||||
if (cinfo.formats & SND_PCM_FMT_S16_LE) {
|
if (cinfo.formats & SND_PCM_FMT_S16_LE) {
|
||||||
|
@ -92,7 +167,7 @@ qboolean SNDDMA_Init(void)
|
||||||
format=SND_PCM_SFMT_U8;
|
format=SND_PCM_SFMT_U8;
|
||||||
bps=8;
|
bps=8;
|
||||||
} else {
|
} else {
|
||||||
Con_Printf( "ALSA: desired formats not supported\n");
|
Con_Printf("ALSA: desired formats not supported\n");
|
||||||
goto error_2;
|
goto error_2;
|
||||||
}
|
}
|
||||||
if (cinfo.max_voices>=2) {
|
if (cinfo.max_voices>=2) {
|
||||||
|
@ -164,7 +239,7 @@ qboolean SNDDMA_Init(void)
|
||||||
snd_inited=1;
|
snd_inited=1;
|
||||||
return 1;
|
return 1;
|
||||||
error:
|
error:
|
||||||
Con_Printf( "Error: %s: %s\n", err_msg, snd_strerror(rc));
|
Con_Printf("Error: %s: %s\n", err_msg, snd_strerror(rc));
|
||||||
error_2:
|
error_2:
|
||||||
snd_pcm_close(pcm_handle);
|
snd_pcm_close(pcm_handle);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -196,7 +271,7 @@ Send sound to device if buffer isn't really the dma buffer
|
||||||
void SNDDMA_Submit(void)
|
void SNDDMA_Submit(void)
|
||||||
{
|
{
|
||||||
int count=paintedtime-soundtime;
|
int count=paintedtime-soundtime;
|
||||||
int i,s,e,frags;
|
int i,s,e;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
count+=setup.buf.block.frag_size-1;
|
count+=setup.buf.block.frag_size-1;
|
||||||
|
|
Loading…
Reference in a new issue