mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 09:55:36 +00:00
decklink{audio,video}src: Take the capture times from the pipeline clock
Not from the decklink clock. Both will return exactly the same time once the decklink clock got slaved to the pipeline clock and received the first observation, but until then it will return bogus values. But as both return exactly the same values, we can as well use the pipeline clock directly.
This commit is contained in:
parent
6725ff5598
commit
22b0a4dad5
4 changed files with 61 additions and 43 deletions
|
@ -474,24 +474,37 @@ public:
|
||||||
VideoInputFrameArrived (IDeckLinkVideoInputFrame * video_frame,
|
VideoInputFrameArrived (IDeckLinkVideoInputFrame * video_frame,
|
||||||
IDeckLinkAudioInputPacket * audio_packet)
|
IDeckLinkAudioInputPacket * audio_packet)
|
||||||
{
|
{
|
||||||
GstClockTime clock_time = gst_clock_get_time (m_input->clock);
|
GstElement *videosrc = NULL, *audiosrc = NULL;
|
||||||
|
void (*got_video_frame) (GstElement * videosrc,
|
||||||
|
IDeckLinkVideoInputFrame * frame, GstDecklinkModeEnum mode) = NULL;
|
||||||
|
void (*got_audio_packet) (GstElement * videosrc,
|
||||||
|
IDeckLinkAudioInputPacket * packet) = NULL;
|
||||||
|
GstDecklinkModeEnum mode;
|
||||||
|
|
||||||
g_mutex_lock (&m_input->lock);
|
g_mutex_lock (&m_input->lock);
|
||||||
if (m_input->got_video_frame) {
|
if (m_input->videosrc) {
|
||||||
GstClockTime capture_time = clock_time -
|
videosrc = GST_ELEMENT_CAST (gst_object_ref (m_input->videosrc));
|
||||||
gst_element_get_base_time (m_input->videosrc);
|
got_video_frame = m_input->got_video_frame;
|
||||||
m_input->got_video_frame (m_input->videosrc, video_frame,
|
|
||||||
gst_decklink_get_mode_enum_from_bmd (m_input->mode->mode),
|
|
||||||
capture_time);
|
|
||||||
}
|
}
|
||||||
|
mode = gst_decklink_get_mode_enum_from_bmd (m_input->mode->mode);
|
||||||
|
|
||||||
if (m_input->got_audio_packet) {
|
if (m_input->audiosrc) {
|
||||||
GstClockTime capture_time = clock_time -
|
audiosrc = GST_ELEMENT_CAST (gst_object_ref (m_input->audiosrc));
|
||||||
gst_element_get_base_time (m_input->audiosrc);
|
got_audio_packet = m_input->got_audio_packet;
|
||||||
m_input->got_audio_packet (m_input->audiosrc, audio_packet, capture_time);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
g_mutex_unlock (&m_input->lock);
|
g_mutex_unlock (&m_input->lock);
|
||||||
|
|
||||||
|
if (got_video_frame && videosrc) {
|
||||||
|
got_video_frame (videosrc, video_frame, mode);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (got_audio_packet && audiosrc) {
|
||||||
|
m_input->got_audio_packet (audiosrc, audio_packet);
|
||||||
|
}
|
||||||
|
|
||||||
|
gst_object_replace ((GstObject **) & videosrc, NULL);
|
||||||
|
gst_object_replace ((GstObject **) & audiosrc, NULL);
|
||||||
|
|
||||||
return S_OK;
|
return S_OK;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -169,12 +169,12 @@ struct _GstDecklinkInput {
|
||||||
GMutex lock;
|
GMutex lock;
|
||||||
|
|
||||||
/* Set by the video source */
|
/* Set by the video source */
|
||||||
void (*got_video_frame) (GstElement *videosrc, IDeckLinkVideoInputFrame * frame, GstDecklinkModeEnum mode, GstClockTime capture_time);
|
void (*got_video_frame) (GstElement *videosrc, IDeckLinkVideoInputFrame * frame, GstDecklinkModeEnum mode);
|
||||||
/* Configured mode or NULL */
|
/* Configured mode or NULL */
|
||||||
const GstDecklinkMode *mode;
|
const GstDecklinkMode *mode;
|
||||||
|
|
||||||
/* Set by the audio source */
|
/* Set by the audio source */
|
||||||
void (*got_audio_packet) (GstElement *videosrc, IDeckLinkAudioInputPacket * packet, GstClockTime capture_time);
|
void (*got_audio_packet) (GstElement *videosrc, IDeckLinkAudioInputPacket * packet);
|
||||||
|
|
||||||
GstElement *audiosrc;
|
GstElement *audiosrc;
|
||||||
gboolean audio_enabled;
|
gboolean audio_enabled;
|
||||||
|
|
|
@ -411,9 +411,25 @@ gst_decklink_audio_src_get_caps (GstBaseSrc * bsrc, GstCaps * filter)
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_decklink_audio_src_got_packet (GstElement * element,
|
gst_decklink_audio_src_got_packet (GstElement * element,
|
||||||
IDeckLinkAudioInputPacket * packet, GstClockTime capture_time)
|
IDeckLinkAudioInputPacket * packet)
|
||||||
{
|
{
|
||||||
GstDecklinkAudioSrc *self = GST_DECKLINK_AUDIO_SRC_CAST (element);
|
GstDecklinkAudioSrc *self = GST_DECKLINK_AUDIO_SRC_CAST (element);
|
||||||
|
GstClock *clock;
|
||||||
|
GstClockTime capture_time;
|
||||||
|
|
||||||
|
clock = gst_element_get_clock (element);
|
||||||
|
if (clock) {
|
||||||
|
GstClockTime clock_time, base_time;
|
||||||
|
|
||||||
|
clock_time = gst_clock_get_time (clock);
|
||||||
|
g_return_if_fail (clock_time != GST_CLOCK_TIME_NONE);
|
||||||
|
base_time = gst_element_get_base_time (element);
|
||||||
|
g_return_if_fail (base_time != GST_CLOCK_TIME_NONE);
|
||||||
|
capture_time = clock_time - base_time;
|
||||||
|
gst_object_unref (clock);
|
||||||
|
} else {
|
||||||
|
capture_time = GST_CLOCK_TIME_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
GST_LOG_OBJECT (self, "Got audio packet at %" GST_TIME_FORMAT,
|
GST_LOG_OBJECT (self, "Got audio packet at %" GST_TIME_FORMAT,
|
||||||
GST_TIME_ARGS (capture_time));
|
GST_TIME_ARGS (capture_time));
|
||||||
|
@ -748,18 +764,6 @@ gst_decklink_audio_src_change_state (GstElement * element,
|
||||||
self->next_offset = -1;
|
self->next_offset = -1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case GST_STATE_CHANGE_PAUSED_TO_PLAYING:{
|
|
||||||
GstClock *clock;
|
|
||||||
|
|
||||||
clock = gst_element_get_clock (GST_ELEMENT_CAST (self));
|
|
||||||
if (clock && clock != self->input->clock) {
|
|
||||||
gst_clock_set_master (self->input->clock, clock);
|
|
||||||
}
|
|
||||||
if (clock)
|
|
||||||
gst_object_unref (clock);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -773,7 +777,6 @@ gst_decklink_audio_src_change_state (GstElement * element,
|
||||||
gst_element_post_message (element,
|
gst_element_post_message (element,
|
||||||
gst_message_new_clock_lost (GST_OBJECT_CAST (element),
|
gst_message_new_clock_lost (GST_OBJECT_CAST (element),
|
||||||
self->input->clock));
|
self->input->clock));
|
||||||
gst_clock_set_master (self->input->clock, NULL);
|
|
||||||
|
|
||||||
g_queue_foreach (&self->current_packets, (GFunc) capture_packet_free,
|
g_queue_foreach (&self->current_packets, (GFunc) capture_packet_free,
|
||||||
NULL);
|
NULL);
|
||||||
|
|
|
@ -364,10 +364,25 @@ gst_decklink_video_src_get_caps (GstBaseSrc * bsrc, GstCaps * filter)
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_decklink_video_src_got_frame (GstElement * element,
|
gst_decklink_video_src_got_frame (GstElement * element,
|
||||||
IDeckLinkVideoInputFrame * frame, GstDecklinkModeEnum mode,
|
IDeckLinkVideoInputFrame * frame, GstDecklinkModeEnum mode)
|
||||||
GstClockTime capture_time)
|
|
||||||
{
|
{
|
||||||
GstDecklinkVideoSrc *self = GST_DECKLINK_VIDEO_SRC_CAST (element);
|
GstDecklinkVideoSrc *self = GST_DECKLINK_VIDEO_SRC_CAST (element);
|
||||||
|
GstClock *clock;
|
||||||
|
GstClockTime capture_time;
|
||||||
|
|
||||||
|
clock = gst_element_get_clock (element);
|
||||||
|
if (clock) {
|
||||||
|
GstClockTime clock_time, base_time;
|
||||||
|
|
||||||
|
clock_time = gst_clock_get_time (clock);
|
||||||
|
g_return_if_fail (clock_time != GST_CLOCK_TIME_NONE);
|
||||||
|
base_time = gst_element_get_base_time (element);
|
||||||
|
g_return_if_fail (base_time != GST_CLOCK_TIME_NONE);
|
||||||
|
capture_time = clock_time - base_time;
|
||||||
|
gst_object_unref (clock);
|
||||||
|
} else {
|
||||||
|
capture_time = GST_CLOCK_TIME_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
GST_LOG_OBJECT (self, "Got video frame at %" GST_TIME_FORMAT,
|
GST_LOG_OBJECT (self, "Got video frame at %" GST_TIME_FORMAT,
|
||||||
GST_TIME_ARGS (capture_time));
|
GST_TIME_ARGS (capture_time));
|
||||||
|
@ -637,18 +652,6 @@ gst_decklink_video_src_change_state (GstElement * element,
|
||||||
self->input->clock, TRUE));
|
self->input->clock, TRUE));
|
||||||
self->flushing = FALSE;
|
self->flushing = FALSE;
|
||||||
break;
|
break;
|
||||||
case GST_STATE_CHANGE_PAUSED_TO_PLAYING:{
|
|
||||||
GstClock *clock;
|
|
||||||
|
|
||||||
clock = gst_element_get_clock (GST_ELEMENT_CAST (self));
|
|
||||||
if (clock && clock != self->input->clock) {
|
|
||||||
gst_clock_set_master (self->input->clock, clock);
|
|
||||||
}
|
|
||||||
if (clock)
|
|
||||||
gst_object_unref (clock);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -662,7 +665,6 @@ gst_decklink_video_src_change_state (GstElement * element,
|
||||||
gst_element_post_message (element,
|
gst_element_post_message (element,
|
||||||
gst_message_new_clock_lost (GST_OBJECT_CAST (element),
|
gst_message_new_clock_lost (GST_OBJECT_CAST (element),
|
||||||
self->input->clock));
|
self->input->clock));
|
||||||
gst_clock_set_master (self->input->clock, NULL);
|
|
||||||
g_mutex_lock (&self->input->lock);
|
g_mutex_lock (&self->input->lock);
|
||||||
self->input->clock_start_time = GST_CLOCK_TIME_NONE;
|
self->input->clock_start_time = GST_CLOCK_TIME_NONE;
|
||||||
self->input->clock_last_time = 0;
|
self->input->clock_last_time = 0;
|
||||||
|
|
Loading…
Reference in a new issue