* No ownership is taken of @nal */
static GstFlowReturn
gst_h264_parse_push_codec_buffer (GstH264Parse * h264parse,
- GstBuffer * nal, GstClockTime ts)
+ GstBuffer * nal, GstBuffer * buffer)
{
GstMapInfo map;
GstBuffer *wrapped_nal;
map.data, map.size);
gst_buffer_unmap (nal, &map);
- GST_BUFFER_TIMESTAMP (wrapped_nal) = ts;
+ GST_BUFFER_PTS (wrapped_nal) = GST_BUFFER_PTS (buffer);
+ GST_BUFFER_DTS (wrapped_nal) = GST_BUFFER_DTS (buffer);
GST_BUFFER_DURATION (wrapped_nal) = 0;
return gst_pad_push (GST_BASE_PARSE_SRC_PAD (h264parse), wrapped_nal);
GstBuffer *codec_nal;
gint i;
gboolean send_done = FALSE;
- GstClockTime timestamp = GST_BUFFER_TIMESTAMP (buffer);
if (h264parse->have_sps_in_frame && h264parse->have_pps_in_frame) {
GST_DEBUG_OBJECT (h264parse, "SPS/PPS exist in frame, will not insert");
for (i = 0; i < GST_H264_MAX_SPS_COUNT; i++) {
if ((codec_nal = h264parse->sps_nals[i])) {
GST_DEBUG_OBJECT (h264parse, "sending SPS nal");
- gst_h264_parse_push_codec_buffer (h264parse, codec_nal, timestamp);
+ gst_h264_parse_push_codec_buffer (h264parse, codec_nal, buffer);
send_done = TRUE;
}
}
for (i = 0; i < GST_H264_MAX_PPS_COUNT; i++) {
if ((codec_nal = h264parse->pps_nals[i])) {
GST_DEBUG_OBJECT (h264parse, "sending PPS nal");
- gst_h264_parse_push_codec_buffer (h264parse, codec_nal, timestamp);
+ gst_h264_parse_push_codec_buffer (h264parse, codec_nal, buffer);
send_done = TRUE;
}
}
gst_buffer_fill (aud_buffer, 0, (guint8 *) (au_delim + 4), 2);
buffer = frame->buffer;
- gst_h264_parse_push_codec_buffer (h264parse, aud_buffer,
- GST_BUFFER_TIMESTAMP (buffer));
+ gst_h264_parse_push_codec_buffer (h264parse, aud_buffer, buffer);
gst_buffer_unref (aud_buffer);
}
} else {