mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-24 08:08:22 +00:00
rtpvp8pay: rtpvp9pay: access picture_id property atomically
Atomically set and get the picture_id. This changeset only atomically gets the picture-id when such property is queried on the element, on every other place where it is accessed internally it is accessed directly. This is because there is no MT scenario where we would be modifying this value and reading it internally in parallel. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/4530>
This commit is contained in:
parent
e4d8cda9a1
commit
0cee3cd833
4 changed files with 46 additions and 37 deletions
|
@ -109,34 +109,41 @@ picture_id_field_len (GstVP8RtpPayPictureIDMode mode)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_rtp_vp8_pay_picture_id_reset (GstRtpVP8Pay * obj)
|
gst_rtp_vp8_pay_picture_id_reset (GstRtpVP8Pay * self)
|
||||||
{
|
{
|
||||||
gint nbits;
|
gint nbits;
|
||||||
|
gint old_picture_id = self->picture_id;
|
||||||
|
gint picture_id = 0;
|
||||||
|
|
||||||
if (obj->picture_id_mode == VP8_PAY_NO_PICTURE_ID) {
|
if (self->picture_id_mode != VP8_PAY_NO_PICTURE_ID) {
|
||||||
obj->picture_id = 0;
|
if (self->picture_id_offset == -1) {
|
||||||
|
picture_id = g_random_int ();
|
||||||
} else {
|
} else {
|
||||||
if (obj->picture_id_offset == -1)
|
picture_id = self->picture_id_offset;
|
||||||
obj->picture_id = g_random_int ();
|
|
||||||
else
|
|
||||||
obj->picture_id = obj->picture_id_offset;
|
|
||||||
|
|
||||||
nbits = picture_id_field_len (obj->picture_id_mode);
|
|
||||||
obj->picture_id &= (1 << nbits) - 1;
|
|
||||||
}
|
}
|
||||||
|
nbits = picture_id_field_len (self->picture_id_mode);
|
||||||
|
picture_id &= (1 << nbits) - 1;
|
||||||
|
}
|
||||||
|
g_atomic_int_set (&self->picture_id, picture_id);
|
||||||
|
|
||||||
|
GST_LOG_OBJECT (self, "picture-id reset %d -> %d",
|
||||||
|
old_picture_id, picture_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_rtp_vp8_pay_picture_id_increment (GstRtpVP8Pay * obj)
|
gst_rtp_vp8_pay_picture_id_increment (GstRtpVP8Pay * self)
|
||||||
{
|
{
|
||||||
gint nbits;
|
gint nbits;
|
||||||
|
|
||||||
if (obj->picture_id_mode == VP8_PAY_NO_PICTURE_ID)
|
if (self->picture_id_mode == VP8_PAY_NO_PICTURE_ID)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
nbits = picture_id_field_len (obj->picture_id_mode);
|
/* Atomically increment and wrap the picture id if it overflows */
|
||||||
obj->picture_id++;
|
nbits = picture_id_field_len (self->picture_id_mode);
|
||||||
obj->picture_id &= (1 << nbits) - 1;
|
gint picture_id = g_atomic_int_get (&self->picture_id);
|
||||||
|
picture_id++;
|
||||||
|
picture_id &= (1 << nbits) - 1;
|
||||||
|
g_atomic_int_set (&self->picture_id, picture_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -247,7 +254,7 @@ gst_rtp_vp8_pay_get_property (GObject * object,
|
||||||
|
|
||||||
switch (prop_id) {
|
switch (prop_id) {
|
||||||
case PROP_PICTURE_ID:
|
case PROP_PICTURE_ID:
|
||||||
g_value_set_int (value, rtpvp8pay->picture_id);
|
g_value_set_int (value, g_atomic_int_get (&rtpvp8pay->picture_id));
|
||||||
break;
|
break;
|
||||||
case PROP_PICTURE_ID_MODE:
|
case PROP_PICTURE_ID_MODE:
|
||||||
g_value_set_enum (value, rtpvp8pay->picture_id_mode);
|
g_value_set_enum (value, rtpvp8pay->picture_id_mode);
|
||||||
|
@ -711,9 +718,9 @@ gst_rtp_vp8_pay_sink_event (GstRTPBasePayload * payload, GstEvent * event)
|
||||||
GstEventType event_type = GST_EVENT_TYPE (event);
|
GstEventType event_type = GST_EVENT_TYPE (event);
|
||||||
|
|
||||||
if (event_type == GST_EVENT_GAP || event_type == GST_EVENT_FLUSH_START) {
|
if (event_type == GST_EVENT_GAP || event_type == GST_EVENT_FLUSH_START) {
|
||||||
guint picture_id = self->picture_id;
|
gint picture_id = self->picture_id;
|
||||||
gst_rtp_vp8_pay_picture_id_increment (self);
|
gst_rtp_vp8_pay_picture_id_increment (self);
|
||||||
GST_DEBUG_OBJECT (payload, "Incrementing picture ID on %s event %u->%u",
|
GST_DEBUG_OBJECT (payload, "Incrementing picture ID on %s event %d -> %d",
|
||||||
GST_EVENT_TYPE_NAME (event), picture_id, self->picture_id);
|
GST_EVENT_TYPE_NAME (event), picture_id, self->picture_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -63,7 +63,7 @@ struct _GstRtpVP8Pay
|
||||||
guint partition_size[9];
|
guint partition_size[9];
|
||||||
GstVP8RtpPayPictureIDMode picture_id_mode;
|
GstVP8RtpPayPictureIDMode picture_id_mode;
|
||||||
gint picture_id_offset;
|
gint picture_id_offset;
|
||||||
guint16 picture_id;
|
gint picture_id;
|
||||||
gboolean temporal_scalability_fields_present;
|
gboolean temporal_scalability_fields_present;
|
||||||
guint8 tl0picidx;
|
guint8 tl0picidx;
|
||||||
};
|
};
|
||||||
|
|
|
@ -113,22 +113,22 @@ static void
|
||||||
gst_rtp_vp9_pay_picture_id_reset (GstRtpVP9Pay * self)
|
gst_rtp_vp9_pay_picture_id_reset (GstRtpVP9Pay * self)
|
||||||
{
|
{
|
||||||
gint nbits;
|
gint nbits;
|
||||||
guint16 old_picture_id = self->picture_id;
|
gint old_picture_id = self->picture_id;
|
||||||
|
gint picture_id = 0;
|
||||||
|
|
||||||
if (self->picture_id_mode == VP9_PAY_NO_PICTURE_ID) {
|
if (self->picture_id_mode != VP9_PAY_NO_PICTURE_ID) {
|
||||||
self->picture_id = 0;
|
if (self->picture_id_offset == -1) {
|
||||||
|
picture_id = g_random_int ();
|
||||||
} else {
|
} else {
|
||||||
if (self->picture_id_offset == DEFAULT_PICTURE_ID_OFFSET) {
|
picture_id = self->picture_id_offset;
|
||||||
self->picture_id = g_random_int ();
|
|
||||||
} else {
|
|
||||||
self->picture_id = self->picture_id_offset;
|
|
||||||
}
|
}
|
||||||
nbits = picture_id_field_len (self->picture_id_mode);
|
nbits = picture_id_field_len (self->picture_id_mode);
|
||||||
self->picture_id &= (1 << nbits) - 1;
|
picture_id &= (1 << nbits) - 1;
|
||||||
}
|
}
|
||||||
|
g_atomic_int_set (&self->picture_id, picture_id);
|
||||||
|
|
||||||
GST_LOG_OBJECT (self, "picture-id reset %u -> %u",
|
GST_LOG_OBJECT (self, "picture-id reset %d -> %d",
|
||||||
old_picture_id, self->picture_id);
|
old_picture_id, picture_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -229,7 +229,7 @@ gst_rtp_vp9_pay_get_property (GObject * object,
|
||||||
|
|
||||||
switch (prop_id) {
|
switch (prop_id) {
|
||||||
case PROP_PICTURE_ID:
|
case PROP_PICTURE_ID:
|
||||||
g_value_set_int (value, rtpvp9pay->picture_id);
|
g_value_set_int (value, g_atomic_int_get (&rtpvp9pay->picture_id));
|
||||||
break;
|
break;
|
||||||
case PROP_PICTURE_ID_MODE:
|
case PROP_PICTURE_ID_MODE:
|
||||||
g_value_set_enum (value, rtpvp9pay->picture_id_mode);
|
g_value_set_enum (value, rtpvp9pay->picture_id_mode);
|
||||||
|
@ -545,10 +545,12 @@ gst_rtp_vp9_pay_picture_id_increment (GstRtpVP9Pay * self)
|
||||||
if (self->picture_id_mode == VP9_PAY_NO_PICTURE_ID)
|
if (self->picture_id_mode == VP9_PAY_NO_PICTURE_ID)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/* Increment and wrap the picture id if it overflows */
|
/* Atomically increment and wrap the picture id if it overflows */
|
||||||
nbits = picture_id_field_len (self->picture_id_mode);
|
nbits = picture_id_field_len (self->picture_id_mode);
|
||||||
self->picture_id++;
|
gint picture_id = g_atomic_int_get (&self->picture_id);
|
||||||
self->picture_id &= (1 << nbits) - 1;
|
picture_id++;
|
||||||
|
picture_id &= (1 << nbits) - 1;
|
||||||
|
g_atomic_int_set (&self->picture_id, picture_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
static GstFlowReturn
|
static GstFlowReturn
|
||||||
|
@ -601,9 +603,9 @@ gst_rtp_vp9_pay_sink_event (GstRTPBasePayload * payload, GstEvent * event)
|
||||||
GstEventType event_type = GST_EVENT_TYPE (event);
|
GstEventType event_type = GST_EVENT_TYPE (event);
|
||||||
|
|
||||||
if (event_type == GST_EVENT_GAP || event_type == GST_EVENT_FLUSH_START) {
|
if (event_type == GST_EVENT_GAP || event_type == GST_EVENT_FLUSH_START) {
|
||||||
guint picture_id = self->picture_id;
|
gint picture_id = self->picture_id;
|
||||||
gst_rtp_vp9_pay_picture_id_increment (self);
|
gst_rtp_vp9_pay_picture_id_increment (self);
|
||||||
GST_DEBUG_OBJECT (payload, "Incrementing picture ID on %s event %u->%u",
|
GST_DEBUG_OBJECT (payload, "Incrementing picture ID on %s event %d -> %d",
|
||||||
GST_EVENT_TYPE_NAME (event), picture_id, self->picture_id);
|
GST_EVENT_TYPE_NAME (event), picture_id, self->picture_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -61,7 +61,7 @@ struct _GstRtpVP9Pay
|
||||||
guint height;
|
guint height;
|
||||||
GstVP9RtpPayPictureIDMode picture_id_mode;
|
GstVP9RtpPayPictureIDMode picture_id_mode;
|
||||||
gint picture_id_offset;
|
gint picture_id_offset;
|
||||||
guint16 picture_id;
|
gint picture_id;
|
||||||
};
|
};
|
||||||
|
|
||||||
GType gst_rtp_vp9_pay_get_type (void);
|
GType gst_rtp_vp9_pay_get_type (void);
|
||||||
|
|
Loading…
Reference in a new issue