2010-05-26 17:29:56 -04:00
|
|
|
$OpenBSD: patch-stream_audio_in_c,v 1.2 2010/05/26 21:29:56 jakemsr Exp $
|
|
|
|
--- stream/audio_in.c.orig Sat Jan 30 22:26:47 2010
|
|
|
|
+++ stream/audio_in.c Mon Mar 8 14:28:42 2010
|
|
|
|
@@ -54,6 +54,12 @@ int audio_in_init(audio_in_t *ai, int type)
|
2009-10-11 09:36:23 -04:00
|
|
|
ai->oss.device = strdup("/dev/dsp");
|
|
|
|
return 0;
|
|
|
|
#endif
|
|
|
|
+#ifdef CONFIG_SNDIO_AUDIO
|
|
|
|
+ case AUDIO_IN_SNDIO:
|
|
|
|
+ ai->sndio.hdl = NULL;
|
|
|
|
+ ai->sndio.device = strdup("default");
|
|
|
|
+ return 0;
|
|
|
|
+#endif
|
|
|
|
default:
|
|
|
|
return -1;
|
|
|
|
}
|
2010-05-26 17:29:56 -04:00
|
|
|
@@ -75,6 +81,12 @@ int audio_in_setup(audio_in_t *ai)
|
2009-10-11 09:36:23 -04:00
|
|
|
ai->setup = 1;
|
|
|
|
return 0;
|
|
|
|
#endif
|
|
|
|
+#ifdef CONFIG_SNDIO_AUDIO
|
|
|
|
+ case AUDIO_IN_SNDIO:
|
|
|
|
+ if (ai_sndio_init(ai) < 0) return -1;
|
|
|
|
+ ai->setup = 1;
|
|
|
|
+ return 0;
|
|
|
|
+#endif
|
|
|
|
default:
|
|
|
|
return -1;
|
|
|
|
}
|
2010-05-26 17:29:56 -04:00
|
|
|
@@ -97,6 +109,13 @@ int audio_in_set_samplerate(audio_in_t *ai, int rate)
|
2009-10-11 09:36:23 -04:00
|
|
|
if (ai_oss_set_samplerate(ai) < 0) return -1;
|
|
|
|
return ai->samplerate;
|
|
|
|
#endif
|
|
|
|
+#ifdef CONFIG_SNDIO_AUDIO
|
|
|
|
+ case AUDIO_IN_SNDIO:
|
|
|
|
+ ai->req_samplerate = rate;
|
|
|
|
+ if (!ai->setup) return 0;
|
|
|
|
+ if (ai_sndio_setup(ai) < 0) return -1;
|
|
|
|
+ return ai->samplerate;
|
|
|
|
+#endif
|
|
|
|
default:
|
|
|
|
return -1;
|
|
|
|
}
|
2010-05-26 17:29:56 -04:00
|
|
|
@@ -119,6 +138,13 @@ int audio_in_set_channels(audio_in_t *ai, int channels
|
2009-10-11 09:36:23 -04:00
|
|
|
if (ai_oss_set_channels(ai) < 0) return -1;
|
|
|
|
return ai->channels;
|
|
|
|
#endif
|
|
|
|
+#ifdef CONFIG_SNDIO_AUDIO
|
|
|
|
+ case AUDIO_IN_SNDIO:
|
|
|
|
+ ai->req_channels = channels;
|
|
|
|
+ if (!ai->setup) return 0;
|
|
|
|
+ if (ai_sndio_setup(ai) < 0) return -1;
|
|
|
|
+ return ai->channels;
|
|
|
|
+#endif
|
|
|
|
default:
|
|
|
|
return -1;
|
|
|
|
}
|
2010-05-26 17:29:56 -04:00
|
|
|
@@ -147,6 +173,12 @@ int audio_in_set_device(audio_in_t *ai, char *device)
|
2009-10-11 09:36:23 -04:00
|
|
|
ai->oss.device = strdup(device);
|
|
|
|
return 0;
|
|
|
|
#endif
|
|
|
|
+#ifdef CONFIG_SNDIO_AUDIO
|
|
|
|
+ case AUDIO_IN_SNDIO:
|
|
|
|
+ if (ai->sndio.device) free(ai->sndio.device);
|
|
|
|
+ ai->sndio.device = strdup(device);
|
|
|
|
+ return 0;
|
|
|
|
+#endif
|
|
|
|
default:
|
|
|
|
return -1;
|
|
|
|
}
|
2010-05-26 17:29:56 -04:00
|
|
|
@@ -172,6 +204,13 @@ int audio_in_uninit(audio_in_t *ai)
|
2009-10-11 09:36:23 -04:00
|
|
|
ai->setup = 0;
|
|
|
|
return 0;
|
|
|
|
#endif
|
|
|
|
+#ifdef CONFIG_SNDIO_AUDIO
|
|
|
|
+ case AUDIO_IN_SNDIO:
|
|
|
|
+ if (ai->sndio.hdl)
|
|
|
|
+ sio_close(ai->sndio.hdl);
|
|
|
|
+ ai->setup = 0;
|
|
|
|
+ return 0;
|
|
|
|
+#endif
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return -1;
|
2010-05-26 17:29:56 -04:00
|
|
|
@@ -188,6 +227,12 @@ int audio_in_start_capture(audio_in_t *ai)
|
2009-10-11 09:36:23 -04:00
|
|
|
case AUDIO_IN_OSS:
|
|
|
|
return 0;
|
|
|
|
#endif
|
|
|
|
+#ifdef CONFIG_SNDIO_AUDIO
|
|
|
|
+ case AUDIO_IN_SNDIO:
|
|
|
|
+ if (!sio_start(ai->sndio.hdl))
|
|
|
|
+ return -1;
|
|
|
|
+ return 0;
|
|
|
|
+#endif
|
|
|
|
default:
|
|
|
|
return -1;
|
|
|
|
}
|
2010-05-26 17:29:56 -04:00
|
|
|
@@ -221,6 +266,19 @@ int audio_in_read_chunk(audio_in_t *ai, unsigned char
|
2009-10-11 09:36:23 -04:00
|
|
|
#ifdef CONFIG_OSS_AUDIO
|
|
|
|
case AUDIO_IN_OSS:
|
|
|
|
ret = read(ai->oss.audio_fd, buffer, ai->blocksize);
|
|
|
|
+ if (ret != ai->blocksize) {
|
|
|
|
+ if (ret < 0) {
|
|
|
|
+ mp_msg(MSGT_TV, MSGL_ERR, MSGTR_MPDEMUX_AUDIOIN_ErrReadingAudio, strerror(errno));
|
|
|
|
+ } else {
|
|
|
|
+ mp_msg(MSGT_TV, MSGL_ERR, MSGTR_MPDEMUX_AUDIOIN_NotEnoughSamples);
|
|
|
|
+ }
|
|
|
|
+ return -1;
|
|
|
|
+ }
|
|
|
|
+ return ret;
|
|
|
|
+#endif
|
|
|
|
+#ifdef CONFIG_SNDIO_AUDIO
|
|
|
|
+ case AUDIO_IN_SNDIO:
|
|
|
|
+ ret = sio_read(ai->sndio.hdl, buffer, ai->blocksize);
|
|
|
|
if (ret != ai->blocksize) {
|
|
|
|
if (ret < 0) {
|
|
|
|
mp_msg(MSGT_TV, MSGL_ERR, MSGTR_MPDEMUX_AUDIOIN_ErrReadingAudio, strerror(errno));
|