mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-06 23:45:35 +00:00
jitterbuffer: flesh out buffering mode some more
Add a buffering state to the jitterbuffer and wait until buffering ends before pushing out packets.
This commit is contained in:
parent
56b29c9a6b
commit
aeacbfed3e
3 changed files with 35 additions and 10 deletions
|
@ -1438,6 +1438,9 @@ again:
|
||||||
id = NULL;
|
id = NULL;
|
||||||
/* always wait if we are blocked */
|
/* always wait if we are blocked */
|
||||||
if (G_LIKELY (!priv->blocked)) {
|
if (G_LIKELY (!priv->blocked)) {
|
||||||
|
/* we're buffering, wait */
|
||||||
|
if (rtp_jitter_buffer_is_buffering (priv->jbuf))
|
||||||
|
goto do_wait;
|
||||||
/* if we have a packet, we can exit the loop and grab it */
|
/* if we have a packet, we can exit the loop and grab it */
|
||||||
if (rtp_jitter_buffer_num_packets (priv->jbuf) > 0)
|
if (rtp_jitter_buffer_num_packets (priv->jbuf) > 0)
|
||||||
break;
|
break;
|
||||||
|
@ -1460,6 +1463,7 @@ again:
|
||||||
GST_OBJECT_UNLOCK (jitterbuffer);
|
GST_OBJECT_UNLOCK (jitterbuffer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
do_wait:
|
||||||
/* now we wait */
|
/* now we wait */
|
||||||
GST_DEBUG_OBJECT (jitterbuffer, "waiting");
|
GST_DEBUG_OBJECT (jitterbuffer, "waiting");
|
||||||
priv->waiting = TRUE;
|
priv->waiting = TRUE;
|
||||||
|
|
|
@ -125,6 +125,12 @@ void
|
||||||
rtp_jitter_buffer_set_mode (RTPJitterBuffer * jbuf, RTPJitterBufferMode mode)
|
rtp_jitter_buffer_set_mode (RTPJitterBuffer * jbuf, RTPJitterBufferMode mode)
|
||||||
{
|
{
|
||||||
jbuf->mode = mode;
|
jbuf->mode = mode;
|
||||||
|
|
||||||
|
if (mode == RTP_JITTER_BUFFER_MODE_BUFFER) {
|
||||||
|
/* when we're in buffering mode, always set our state to buffering, we'll
|
||||||
|
* get out of it when we push the next buffer */
|
||||||
|
jbuf->buffering = TRUE;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -510,14 +516,19 @@ rtp_jitter_buffer_insert (RTPJitterBuffer * jbuf, GstBuffer * buf,
|
||||||
time = 0;
|
time = 0;
|
||||||
else
|
else
|
||||||
time = -1;
|
time = -1;
|
||||||
|
|
||||||
time = calculate_skew (jbuf, rtptime, time, clock_rate, max_delay);
|
time = calculate_skew (jbuf, rtptime, time, clock_rate, max_delay);
|
||||||
break;
|
break;
|
||||||
case RTP_JITTER_BUFFER_MODE_SLAVE:
|
case RTP_JITTER_BUFFER_MODE_SLAVE:
|
||||||
time = calculate_skew (jbuf, rtptime, time, clock_rate, max_delay);
|
time = calculate_skew (jbuf, rtptime, time, clock_rate, max_delay);
|
||||||
break;
|
break;
|
||||||
case RTP_JITTER_BUFFER_MODE_BUFFER:
|
case RTP_JITTER_BUFFER_MODE_BUFFER:
|
||||||
time = GST_BUFFER_TIMESTAMP (buf);
|
/* send -1 for all timestamps except the first one. This will make the
|
||||||
|
* timestamps increase according to the RTP timestamps. When in buffering
|
||||||
|
* mode we will adjust the outgoing timestamps relative with how long we
|
||||||
|
* buffered */
|
||||||
|
if (jbuf->base_time != -1)
|
||||||
|
time = -1;
|
||||||
|
time = calculate_skew (jbuf, rtptime, time, clock_rate, max_delay);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
@ -607,6 +618,21 @@ rtp_jitter_buffer_flush (RTPJitterBuffer * jbuf)
|
||||||
gst_buffer_unref (buffer);
|
gst_buffer_unref (buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* rtp_jitter_buffer_is_buffering:
|
||||||
|
* @jbuf: an #RTPJitterBuffer
|
||||||
|
*
|
||||||
|
* Check if @jbuf is buffering currently. Users of the jitterbuffer should not
|
||||||
|
* pop packets while in buffering mode.
|
||||||
|
*
|
||||||
|
* Returns: the buffering state of @jbuf
|
||||||
|
*/
|
||||||
|
gboolean
|
||||||
|
rtp_jitter_buffer_is_buffering (RTPJitterBuffer * jbuf)
|
||||||
|
{
|
||||||
|
return jbuf->buffering;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* rtp_jitter_buffer_num_packets:
|
* rtp_jitter_buffer_num_packets:
|
||||||
* @jbuf: an #RTPJitterBuffer
|
* @jbuf: an #RTPJitterBuffer
|
||||||
|
@ -618,16 +644,9 @@ rtp_jitter_buffer_flush (RTPJitterBuffer * jbuf)
|
||||||
guint
|
guint
|
||||||
rtp_jitter_buffer_num_packets (RTPJitterBuffer * jbuf)
|
rtp_jitter_buffer_num_packets (RTPJitterBuffer * jbuf)
|
||||||
{
|
{
|
||||||
guint result;
|
|
||||||
|
|
||||||
g_return_val_if_fail (jbuf != NULL, 0);
|
g_return_val_if_fail (jbuf != NULL, 0);
|
||||||
|
|
||||||
if (!jbuf->buffering)
|
return jbuf->packets->length;
|
||||||
result = jbuf->packets->length;
|
|
||||||
else
|
|
||||||
result = 0;
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -120,6 +120,8 @@ GstBuffer * rtp_jitter_buffer_pop (RTPJitterBuffer *jbuf)
|
||||||
|
|
||||||
void rtp_jitter_buffer_flush (RTPJitterBuffer *jbuf);
|
void rtp_jitter_buffer_flush (RTPJitterBuffer *jbuf);
|
||||||
|
|
||||||
|
gboolean rtp_jitter_buffer_is_buffering (RTPJitterBuffer * jbuf);
|
||||||
|
|
||||||
guint rtp_jitter_buffer_num_packets (RTPJitterBuffer *jbuf);
|
guint rtp_jitter_buffer_num_packets (RTPJitterBuffer *jbuf);
|
||||||
guint32 rtp_jitter_buffer_get_ts_diff (RTPJitterBuffer *jbuf);
|
guint32 rtp_jitter_buffer_get_ts_diff (RTPJitterBuffer *jbuf);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue