mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 02:15:31 +00:00
videotestsrc: Protect videoinfo with object lock
The videoinfo is set in the streaming thread, but can be read by any thread from the various queries, so protect it with the object lock.
This commit is contained in:
parent
18e55dcdc0
commit
4fdb5ab675
2 changed files with 22 additions and 2 deletions
|
@ -874,6 +874,8 @@ gst_video_test_src_setcaps (GstBaseSrc * bsrc, GstCaps * caps)
|
||||||
|
|
||||||
structure = gst_caps_get_structure (caps, 0);
|
structure = gst_caps_get_structure (caps, 0);
|
||||||
|
|
||||||
|
GST_OBJECT_LOCK (videotestsrc);
|
||||||
|
|
||||||
if (gst_structure_has_name (structure, "video/x-raw")) {
|
if (gst_structure_has_name (structure, "video/x-raw")) {
|
||||||
/* we can use the parsing code */
|
/* we can use the parsing code */
|
||||||
if (!gst_video_info_from_caps (&info, caps))
|
if (!gst_video_info_from_caps (&info, caps))
|
||||||
|
@ -946,16 +948,20 @@ gst_video_test_src_setcaps (GstBaseSrc * bsrc, GstCaps * caps)
|
||||||
videotestsrc->running_time = 0;
|
videotestsrc->running_time = 0;
|
||||||
videotestsrc->n_frames = 0;
|
videotestsrc->n_frames = 0;
|
||||||
|
|
||||||
|
GST_OBJECT_UNLOCK (videotestsrc);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
/* ERRORS */
|
/* ERRORS */
|
||||||
parse_failed:
|
parse_failed:
|
||||||
{
|
{
|
||||||
|
GST_OBJECT_UNLOCK (videotestsrc);
|
||||||
GST_DEBUG_OBJECT (bsrc, "failed to parse caps");
|
GST_DEBUG_OBJECT (bsrc, "failed to parse caps");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
unsupported_caps:
|
unsupported_caps:
|
||||||
{
|
{
|
||||||
|
GST_OBJECT_UNLOCK (videotestsrc);
|
||||||
GST_DEBUG_OBJECT (bsrc, "unsupported caps: %" GST_PTR_FORMAT, caps);
|
GST_DEBUG_OBJECT (bsrc, "unsupported caps: %" GST_PTR_FORMAT, caps);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
@ -975,27 +981,33 @@ gst_video_test_src_query (GstBaseSrc * bsrc, GstQuery * query)
|
||||||
GstFormat src_fmt, dest_fmt;
|
GstFormat src_fmt, dest_fmt;
|
||||||
gint64 src_val, dest_val;
|
gint64 src_val, dest_val;
|
||||||
|
|
||||||
|
GST_OBJECT_LOCK (src);
|
||||||
gst_query_parse_convert (query, &src_fmt, &src_val, &dest_fmt, &dest_val);
|
gst_query_parse_convert (query, &src_fmt, &src_val, &dest_fmt, &dest_val);
|
||||||
res =
|
res =
|
||||||
gst_video_info_convert (&src->info, src_fmt, src_val, dest_fmt,
|
gst_video_info_convert (&src->info, src_fmt, src_val, dest_fmt,
|
||||||
&dest_val);
|
&dest_val);
|
||||||
gst_query_set_convert (query, src_fmt, src_val, dest_fmt, dest_val);
|
gst_query_set_convert (query, src_fmt, src_val, dest_fmt, dest_val);
|
||||||
|
GST_OBJECT_UNLOCK (src);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case GST_QUERY_LATENCY:
|
case GST_QUERY_LATENCY:
|
||||||
{
|
{
|
||||||
|
GST_OBJECT_LOCK (src);
|
||||||
if (src->info.fps_n > 0) {
|
if (src->info.fps_n > 0) {
|
||||||
GstClockTime latency;
|
GstClockTime latency;
|
||||||
|
|
||||||
latency =
|
latency =
|
||||||
gst_util_uint64_scale (GST_SECOND, src->info.fps_d,
|
gst_util_uint64_scale (GST_SECOND, src->info.fps_d,
|
||||||
src->info.fps_n);
|
src->info.fps_n);
|
||||||
|
GST_OBJECT_UNLOCK (src);
|
||||||
gst_query_set_latency (query,
|
gst_query_set_latency (query,
|
||||||
gst_base_src_is_live (GST_BASE_SRC_CAST (src)), latency,
|
gst_base_src_is_live (GST_BASE_SRC_CAST (src)), latency,
|
||||||
GST_CLOCK_TIME_NONE);
|
GST_CLOCK_TIME_NONE);
|
||||||
GST_DEBUG_OBJECT (src, "Reporting latency of %" GST_TIME_FORMAT,
|
GST_DEBUG_OBJECT (src, "Reporting latency of %" GST_TIME_FORMAT,
|
||||||
GST_TIME_ARGS (latency));
|
GST_TIME_ARGS (latency));
|
||||||
res = TRUE;
|
res = TRUE;
|
||||||
|
} else {
|
||||||
|
GST_OBJECT_UNLOCK (src);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1006,16 +1018,22 @@ gst_video_test_src_query (GstBaseSrc * bsrc, GstQuery * query)
|
||||||
gst_query_parse_duration (query, &format, NULL);
|
gst_query_parse_duration (query, &format, NULL);
|
||||||
switch (format) {
|
switch (format) {
|
||||||
case GST_FORMAT_TIME:{
|
case GST_FORMAT_TIME:{
|
||||||
gint64 dur = gst_util_uint64_scale_int_round (bsrc->num_buffers
|
gint64 dur;
|
||||||
|
|
||||||
|
GST_OBJECT_LOCK (src);
|
||||||
|
dur = gst_util_uint64_scale_int_round (bsrc->num_buffers
|
||||||
* GST_SECOND, src->info.fps_d, src->info.fps_n);
|
* GST_SECOND, src->info.fps_d, src->info.fps_n);
|
||||||
res = TRUE;
|
res = TRUE;
|
||||||
gst_query_set_duration (query, GST_FORMAT_TIME, dur);
|
gst_query_set_duration (query, GST_FORMAT_TIME, dur);
|
||||||
|
GST_OBJECT_UNLOCK (src);
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
case GST_FORMAT_BYTES:
|
case GST_FORMAT_BYTES:
|
||||||
|
GST_OBJECT_LOCK (src);
|
||||||
res = TRUE;
|
res = TRUE;
|
||||||
gst_query_set_duration (query, GST_FORMAT_BYTES,
|
gst_query_set_duration (query, GST_FORMAT_BYTES,
|
||||||
bsrc->num_buffers * src->info.size);
|
bsrc->num_buffers * src->info.size);
|
||||||
|
GST_OBJECT_UNLOCK (src);
|
||||||
goto done;
|
goto done;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
@ -1192,12 +1210,14 @@ gst_video_test_src_start (GstBaseSrc * basesrc)
|
||||||
{
|
{
|
||||||
GstVideoTestSrc *src = GST_VIDEO_TEST_SRC (basesrc);
|
GstVideoTestSrc *src = GST_VIDEO_TEST_SRC (basesrc);
|
||||||
|
|
||||||
|
GST_OBJECT_LOCK (src);
|
||||||
src->running_time = 0;
|
src->running_time = 0;
|
||||||
src->n_frames = 0;
|
src->n_frames = 0;
|
||||||
src->accum_frames = 0;
|
src->accum_frames = 0;
|
||||||
src->accum_rtime = 0;
|
src->accum_rtime = 0;
|
||||||
|
|
||||||
gst_video_info_init (&src->info);
|
gst_video_info_init (&src->info);
|
||||||
|
GST_OBJECT_UNLOCK (src);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
|
@ -146,7 +146,7 @@ struct _GstVideoTestSrc {
|
||||||
GstVideoTestSrcPattern pattern_type;
|
GstVideoTestSrcPattern pattern_type;
|
||||||
|
|
||||||
/* video state */
|
/* video state */
|
||||||
GstVideoInfo info;
|
GstVideoInfo info; /* protected by the object or stream lock */
|
||||||
GstVideoChromaResample *subsample;
|
GstVideoChromaResample *subsample;
|
||||||
gboolean bayer;
|
gboolean bayer;
|
||||||
gint x_invert;
|
gint x_invert;
|
||||||
|
|
Loading…
Reference in a new issue