aboutsummaryrefslogtreecommitdiffhomepage
path: root/audio
diff options
context:
space:
mode:
authorGravatar Dmitrij D. Czarkoff <czarkoff@gmail.com>2015-03-25 23:43:37 +0100
committerGravatar wm4 <wm4@nowhere>2015-03-26 00:09:15 +0100
commit58e0292a9f7009adea9e4ee1e0349019a58fe0b8 (patch)
tree39fb5f7b48fbfeeb81b1ef0764b1a0b1235df3db /audio
parenta60e725113ff4b932be84dc84d3095ac65fe287a (diff)
ao_sndio: open device in blocking mode, don't inflate buffer artificially
The code actually uses blocking mode, so opening sound device in non-blocking mode results in choppy sound. Also, inflating the buffer isn't necessary in blocking mode, so the function may simply return without doing anything.
Diffstat (limited to 'audio')
-rw-r--r--audio/out/ao_sndio.c22
1 files changed, 2 insertions, 20 deletions
diff --git a/audio/out/ao_sndio.c b/audio/out/ao_sndio.c
index 2daa63f4ed..80add47a64 100644
--- a/audio/out/ao_sndio.c
+++ b/audio/out/ao_sndio.c
@@ -125,7 +125,7 @@ static int init(struct ao *ao)
const struct af_to_par *ap;
int i;
- p->hdl = sio_open(p->dev, SIO_PLAY, 1);
+ p->hdl = sio_open(p->dev, SIO_PLAY, 0);
if (p->hdl == NULL) {
MP_ERR(ao, "can't open sndio %s\n", p->dev);
goto error;
@@ -304,25 +304,7 @@ static void audio_pause(struct ao *ao)
*/
static void audio_resume(struct ao *ao)
{
- struct priv *p = ao->priv;
- int n, count, todo;
-
- /*
- * we want to start with buffers full, because mpv uses
- * get_delay() as clock, which would cause video to
- * accelerate while buffers are filled.
- */
- todo = p->par.bufsz * p->par.pchan * p->par.bps;
- while (todo > 0) {
- count = todo;
- if (count > SILENCE_NMAX)
- count = SILENCE_NMAX;
- n = sio_write(p->hdl, p->silence, count);
- if (n == 0)
- break;
- todo -= n;
- p->delay += n;
- }
+ return;
}
#define OPT_BASE_STRUCT struct priv