mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-21 22:58:16 +00:00
rtpmanager: skip RTPSources which are not ready in the RTCP generation
If a stream has an 'irregular' frame rate (e.g. metadata) RTCP SR may be generated way too early, before the RTPSource has received the first packet after Latency was configured in the pipeline. We skip such RTPSources in the RTCP generation. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/7777>
This commit is contained in:
parent
91d987d6b7
commit
8c8cffe080
2 changed files with 19 additions and 4 deletions
|
@ -3819,7 +3819,7 @@ typedef struct
|
||||||
gboolean timeout_inactive_sources;
|
gboolean timeout_inactive_sources;
|
||||||
} ReportData;
|
} ReportData;
|
||||||
|
|
||||||
static void
|
static gboolean
|
||||||
session_start_rtcp (RTPSession * sess, ReportData * data)
|
session_start_rtcp (RTPSession * sess, ReportData * data)
|
||||||
{
|
{
|
||||||
GstRTCPPacket *packet = &data->packet;
|
GstRTCPPacket *packet = &data->packet;
|
||||||
|
@ -3844,8 +3844,11 @@ session_start_rtcp (RTPSession * sess, ReportData * data)
|
||||||
gst_rtcp_buffer_add_packet (rtcp, GST_RTCP_TYPE_SR, packet);
|
gst_rtcp_buffer_add_packet (rtcp, GST_RTCP_TYPE_SR, packet);
|
||||||
|
|
||||||
/* get latest stats */
|
/* get latest stats */
|
||||||
rtp_source_get_new_sr (own, data->ntpnstime, data->running_time,
|
if (!rtp_source_get_new_sr (own, data->ntpnstime, data->running_time,
|
||||||
&ntptime, &rtptime, &packet_count, &octet_count);
|
&ntptime, &rtptime, &packet_count, &octet_count)) {
|
||||||
|
gst_rtcp_buffer_unmap (&data->rtcpbuf);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
/* store stats */
|
/* store stats */
|
||||||
rtp_source_process_sr (own, data->current_time, ntptime, rtptime,
|
rtp_source_process_sr (own, data->current_time, ntptime, rtptime,
|
||||||
packet_count, octet_count);
|
packet_count, octet_count);
|
||||||
|
@ -3861,6 +3864,8 @@ session_start_rtcp (RTPSession * sess, ReportData * data)
|
||||||
gst_rtcp_buffer_add_packet (rtcp, GST_RTCP_TYPE_RR, packet);
|
gst_rtcp_buffer_add_packet (rtcp, GST_RTCP_TYPE_RR, packet);
|
||||||
gst_rtcp_packet_rr_set_ssrc (packet, own->ssrc);
|
gst_rtcp_packet_rr_set_ssrc (packet, own->ssrc);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* construct a Sender or Receiver Report */
|
/* construct a Sender or Receiver Report */
|
||||||
|
@ -4541,7 +4546,10 @@ generate_rtcp (const gchar * key, RTPSource * source, ReportData * data)
|
||||||
data->source = source;
|
data->source = source;
|
||||||
|
|
||||||
/* open packet */
|
/* open packet */
|
||||||
session_start_rtcp (sess, data);
|
if (!session_start_rtcp (sess, data)) {
|
||||||
|
GST_WARNING ("source %08x can not generate RTCP", source->ssrc);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (source->marked_bye) {
|
if (source->marked_bye) {
|
||||||
/* send BYE */
|
/* send BYE */
|
||||||
|
|
|
@ -1627,6 +1627,13 @@ rtp_source_get_new_sr (RTPSource * src, guint64 ntpnstime,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (src->clock_rate != -1) {
|
if (src->clock_rate != -1) {
|
||||||
|
/* if no running time has been set yet we wait until we get one */
|
||||||
|
if (src->last_rtime == -1) {
|
||||||
|
GST_WARNING ("running time not set, can not create SR for SSRC %u",
|
||||||
|
src->ssrc);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
/* get the diff between the clock running_time and the buffer running_time.
|
/* get the diff between the clock running_time and the buffer running_time.
|
||||||
* This is the elapsed time, as measured against the pipeline clock, between
|
* This is the elapsed time, as measured against the pipeline clock, between
|
||||||
* when the rtp timestamp was observed and the current running_time.
|
* when the rtp timestamp was observed and the current running_time.
|
||||||
|
|
Loading…
Reference in a new issue