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:
Wim Taymans 2009-10-01 12:46:21 +02:00
parent 56b29c9a6b
commit aeacbfed3e
3 changed files with 35 additions and 10 deletions

View file

@ -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;

View file

@ -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;
} }
/** /**

View file

@ -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);