Commit 600d0295 authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

Merge branch 1.0-bugfix

parents d93246d2 b8f23ea7
...@@ -4724,7 +4724,7 @@ AC_ARG_ENABLE(pulse, ...@@ -4724,7 +4724,7 @@ AC_ARG_ENABLE(pulse,
[ --enable-pulse Pulseaudio support (default enabled)]) [ --enable-pulse Pulseaudio support (default enabled)])
if test "${enable_pulse}" != "no" if test "${enable_pulse}" != "no"
then then
PKG_CHECK_MODULES(PULSE, libpulse >= 0.9.8, PKG_CHECK_MODULES(PULSE, libpulse >= 0.9.11,
[ VLC_ADD_PLUGIN([pulse]) [ VLC_ADD_PLUGIN([pulse])
VLC_ADD_CFLAGS([pulse],[${PULSE_CFLAGS}]) VLC_ADD_CFLAGS([pulse],[${PULSE_CFLAGS}])
VLC_ADD_LDFLAGS([pulse],[${PULSE_LIBS}])], VLC_ADD_LDFLAGS([pulse],[${PULSE_LIBS}])],
......
...@@ -176,16 +176,15 @@ static int Open ( vlc_object_t *p_this ) ...@@ -176,16 +176,15 @@ static int Open ( vlc_object_t *p_this )
goto fail; goto fail;
} }
a.maxlength = pa_bytes_per_second(&ss)/4/pa_frame_size(&ss); /* Reduce overall latency to 200mS to reduce audible clicks
a.tlength = a.maxlength*9/10; * Also pulse minreq and internal buffers are now 20mS which reduces resampling
a.prebuf = a.tlength/2; */
a.minreq = a.tlength/10; a.tlength = pa_bytes_per_second(&ss)/5;
a.maxlength = a.tlength * 2;
a.maxlength *= pa_frame_size(&ss); a.prebuf = a.tlength;
a.tlength *= pa_frame_size(&ss); a.minreq = a.tlength / 10;
a.prebuf *= pa_frame_size(&ss);
a.minreq *= pa_frame_size(&ss); /* Buffer size is 20mS */
p_sys->buffer_size = a.minreq; p_sys->buffer_size = a.minreq;
/* Initialise the speaker map setup above */ /* Initialise the speaker map setup above */
...@@ -240,7 +239,7 @@ static int Open ( vlc_object_t *p_this ) ...@@ -240,7 +239,7 @@ static int Open ( vlc_object_t *p_this )
pa_stream_set_write_callback(p_sys->stream, stream_request_cb, p_aout); pa_stream_set_write_callback(p_sys->stream, stream_request_cb, p_aout);
pa_stream_set_latency_update_callback(p_sys->stream, stream_latency_update_cb, p_aout); pa_stream_set_latency_update_callback(p_sys->stream, stream_latency_update_cb, p_aout);
if (pa_stream_connect_playback(p_sys->stream, NULL, &a, PA_STREAM_INTERPOLATE_TIMING|PA_STREAM_AUTO_TIMING_UPDATE, NULL, NULL) < 0) { if (pa_stream_connect_playback(p_sys->stream, NULL, &a, PA_STREAM_INTERPOLATE_TIMING|PA_STREAM_AUTO_TIMING_UPDATE|PA_STREAM_ADJUST_LATENCY, NULL, NULL) < 0) {
msg_Err(p_aout, "Failed to connect stream: %s", pa_strerror(pa_context_errno(p_sys->context))); msg_Err(p_aout, "Failed to connect stream: %s", pa_strerror(pa_context_errno(p_sys->context)));
goto unlock_and_fail; goto unlock_and_fail;
} }
...@@ -448,16 +447,11 @@ static void stream_request_cb(pa_stream *s, size_t length, void *userdata) { ...@@ -448,16 +447,11 @@ static void stream_request_cb(pa_stream *s, size_t length, void *userdata) {
latency = 0; latency = 0;
} }
PULSE_DEBUG( "Pulse stream request latency=%"PRId64"", latency); PULSE_DEBUG( "Pulse stream request latency=%"PRId64"", latency);
next_date = mdate() + latency; next_date = mdate() + latency;
if(p_sys->start_date < next_date + AOUT_PTS_TOLERANCE ){ if(p_sys->start_date < next_date + AOUT_PTS_TOLERANCE ){
/*
vlc_mutex_lock( &p_aout->output_fifo_lock );
p_buffer = aout_FifoPop( p_aout, &p_aout->output.fifo );
vlc_mutex_unlock( &p_aout->output_fifo_lock );
*/
p_buffer = aout_OutputNextBuffer( p_aout, next_date, 0); p_buffer = aout_OutputNextBuffer( p_aout, next_date, 0);
} }
} }
......
...@@ -7,6 +7,8 @@ SOURCES_packetizer_vc1 = vc1.c ...@@ -7,6 +7,8 @@ SOURCES_packetizer_vc1 = vc1.c
SOURCES_packetizer_mlp = mlp.c SOURCES_packetizer_mlp = mlp.c
SOURCES_packetizer_dirac = dirac.c SOURCES_packetizer_dirac = dirac.c
noinst_HEADERS = packetizer_helper.h
libvlc_LTLIBRARIES += \ libvlc_LTLIBRARIES += \
libpacketizer_mpegvideo_plugin.la \ libpacketizer_mpegvideo_plugin.la \
libpacketizer_mpeg4video_plugin.la \ libpacketizer_mpeg4video_plugin.la \
......
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment