av1decoder: Hold OBU temporal and spatial id in picture struct

NVDEC API requires the information

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/1453>
This commit is contained in:
Seungha Yang 2022-04-28 03:14:54 +09:00
parent 1444dd91c5
commit 1b4121fded
2 changed files with 10 additions and 3 deletions

View file

@ -323,7 +323,7 @@ gst_av1_decoder_decode_tile_group (GstAV1Decoder * self,
static GstFlowReturn static GstFlowReturn
gst_av1_decoder_decode_frame_header (GstAV1Decoder * self, gst_av1_decoder_decode_frame_header (GstAV1Decoder * self,
GstAV1FrameHeaderOBU * frame_header) GstAV1OBU * obu, GstAV1FrameHeaderOBU * frame_header)
{ {
GstAV1DecoderPrivate *priv = self->priv; GstAV1DecoderPrivate *priv = self->priv;
GstAV1DecoderClass *klass = GST_AV1_DECODER_GET_CLASS (self); GstAV1DecoderClass *klass = GST_AV1_DECODER_GET_CLASS (self);
@ -367,6 +367,8 @@ gst_av1_decoder_decode_frame_header (GstAV1Decoder * self,
picture->showable_frame = frame_header->showable_frame; picture->showable_frame = frame_header->showable_frame;
picture->apply_grain = frame_header->film_grain_params.apply_grain; picture->apply_grain = frame_header->film_grain_params.apply_grain;
picture->system_frame_number = priv->current_frame->system_frame_number; picture->system_frame_number = priv->current_frame->system_frame_number;
picture->temporal_id = obu->header.obu_temporal_id;
picture->spatial_id = obu->header.obu_spatial_id;
if (!frame_header->show_frame && !frame_header->showable_frame) if (!frame_header->show_frame && !frame_header->showable_frame)
GST_VIDEO_CODEC_FRAME_FLAG_SET (priv->current_frame, GST_VIDEO_CODEC_FRAME_FLAG_SET (priv->current_frame,
@ -409,7 +411,7 @@ gst_av1_decoder_process_frame_header (GstAV1Decoder * self, GstAV1OBU * obu)
return GST_FLOW_ERROR; return GST_FLOW_ERROR;
} }
return gst_av1_decoder_decode_frame_header (self, &frame_header); return gst_av1_decoder_decode_frame_header (self, obu, &frame_header);
} }
static GstFlowReturn static GstFlowReturn
@ -442,7 +444,7 @@ gst_av1_decoder_process_frame (GstAV1Decoder * self, GstAV1OBU * obu)
return GST_FLOW_ERROR; return GST_FLOW_ERROR;
} }
ret = gst_av1_decoder_decode_frame_header (self, &frame.frame_header); ret = gst_av1_decoder_decode_frame_header (self, obu, &frame.frame_header);
if (ret != GST_FLOW_OK) if (ret != GST_FLOW_OK)
return ret; return ret;

View file

@ -66,6 +66,7 @@ struct _GstAV1Tile
*/ */
struct _GstAV1Picture struct _GstAV1Picture
{ {
/*< private >*/
GstMiniObject parent; GstMiniObject parent;
/* From GstVideoCodecFrame */ /* From GstVideoCodecFrame */
@ -73,6 +74,10 @@ struct _GstAV1Picture
GstAV1FrameHeaderOBU frame_hdr; GstAV1FrameHeaderOBU frame_hdr;
/* from OBU header */
guint8 temporal_id;
guint8 spatial_id;
/* copied from parser */ /* copied from parser */
guint32 display_frame_id; guint32 display_frame_id;
gboolean show_frame; gboolean show_frame;