va: use GstVideoInfoDmaDrm when importing buffers

In the case of encoders and filters when importing a DMABuf, use
GstVideoInfoDmaDrm to get the drm fourcc and modifier.

In both cases, instead of keeping the original GstVideoInfoDmaDrm from caps, the
GstVideoInfo part of the structure is converted as canonical one, given the
format from the fourcc. It's kept in the way to handle V4L2 linear DMABufs and
to avoid too many changes in the current code.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/5264>
This commit is contained in:
Víctor Manuel Jáquez Leal 2023-11-08 13:59:44 +01:00 committed by GStreamer Marge Bot
parent 7c0227145c
commit 9f5b2c4e25
6 changed files with 41 additions and 24 deletions

View file

@ -40,26 +40,20 @@ _try_import_dmabuf_unlocked (GstVaBufferImporter * importer, GstBuffer * inbuf)
{ {
GstVideoMeta *meta; GstVideoMeta *meta;
GstVideoInfo in_info = *importer->in_info; GstVideoInfo in_info = *importer->in_info;
GstVideoInfoDmaDrm drm_info; GstVideoInfoDmaDrm drm_info = *importer->in_drm_info;
GstMemory *mems[GST_VIDEO_MAX_PLANES]; GstMemory *mems[GST_VIDEO_MAX_PLANES];
guint i, n_mem, n_planes, usage_hint; guint i, n_planes, usage_hint;
gsize offset[GST_VIDEO_MAX_PLANES]; gsize offset[GST_VIDEO_MAX_PLANES];
uintptr_t fd[GST_VIDEO_MAX_PLANES]; uintptr_t fd[GST_VIDEO_MAX_PLANES];
gsize plane_size[GST_VIDEO_MAX_PLANES]; gsize plane_size[GST_VIDEO_MAX_PLANES];
GstVideoAlignment align = { 0, }; GstVideoAlignment align = { 0, };
GstVideoFormat format;
/* This will eliminate most non-dmabuf out there */ /* This will eliminate most non-dmabuf out there */
if (!gst_is_dmabuf_memory (gst_buffer_peek_memory (inbuf, 0))) if (!gst_is_dmabuf_memory (gst_buffer_peek_memory (inbuf, 0)))
return FALSE; return FALSE;
n_mem = gst_buffer_n_memory (inbuf);
n_planes = GST_VIDEO_INFO_N_PLANES (&in_info); n_planes = GST_VIDEO_INFO_N_PLANES (&in_info);
/* We cannot have multiple dmabuf per plane */
if (n_mem > n_planes)
return FALSE;
meta = gst_buffer_get_video_meta (inbuf); meta = gst_buffer_get_video_meta (inbuf);
/* Update video info importerd on video meta */ /* Update video info importerd on video meta */
@ -67,7 +61,9 @@ _try_import_dmabuf_unlocked (GstVaBufferImporter * importer, GstBuffer * inbuf)
GST_VIDEO_INFO_WIDTH (&in_info) = meta->width; GST_VIDEO_INFO_WIDTH (&in_info) = meta->width;
GST_VIDEO_INFO_HEIGHT (&in_info) = meta->height; GST_VIDEO_INFO_HEIGHT (&in_info) = meta->height;
for (i = 0; i < meta->n_planes; i++) { g_assert (n_planes == meta->n_planes);
for (i = 0; i < n_planes; i++) {
GST_VIDEO_INFO_PLANE_OFFSET (&in_info, i) = meta->offset[i]; GST_VIDEO_INFO_PLANE_OFFSET (&in_info, i) = meta->offset[i];
GST_VIDEO_INFO_PLANE_STRIDE (&in_info, i) = meta->stride[i]; GST_VIDEO_INFO_PLANE_STRIDE (&in_info, i) = meta->stride[i];
} }
@ -104,12 +100,6 @@ _try_import_dmabuf_unlocked (GstVaBufferImporter * importer, GstBuffer * inbuf)
usage_hint = va_get_surface_usage_hint (importer->display, usage_hint = va_get_surface_usage_hint (importer->display,
importer->entrypoint, GST_PAD_SINK, TRUE); importer->entrypoint, GST_PAD_SINK, TRUE);
/* FIXME(victor): don't assume the modifier */
format = GST_VIDEO_INFO_FORMAT (&in_info);
drm_info.drm_fourcc = gst_va_drm_fourcc_from_video_format (format);
drm_info.drm_modifier = DRM_FORMAT_MOD_LINEAR;
drm_info.vinfo = in_info;
/* Now create a VASurfaceID for the buffer */ /* Now create a VASurfaceID for the buffer */
return gst_va_dmabuf_memories_setup (importer->display, &drm_info, mems, fd, return gst_va_dmabuf_memories_setup (importer->display, &drm_info, mems, fd,
offset, usage_hint); offset, usage_hint);

View file

@ -36,7 +36,10 @@ struct _GstVaBufferImporter
GstVaDisplay *display; GstVaDisplay *display;
VAEntrypoint entrypoint; VAEntrypoint entrypoint;
GstVideoInfo *in_info; union {
GstVideoInfo *in_info;
GstVideoInfoDmaDrm *in_drm_info;
};
GstVideoInfo *sinkpad_info; GstVideoInfo *sinkpad_info;
gpointer pool_data; gpointer pool_data;

View file

@ -261,7 +261,7 @@ gst_va_base_enc_import_input_buffer (GstVaBaseEnc * base,
#endif #endif
.display = base->display, .display = base->display,
.entrypoint = GST_VA_BASE_ENC_ENTRYPOINT (base), .entrypoint = GST_VA_BASE_ENC_ENTRYPOINT (base),
.in_info = &base->in_info, .in_drm_info = &base->in_drm_info,
.sinkpad_info = &base->priv->sinkpad_info, .sinkpad_info = &base->priv->sinkpad_info,
.get_sinkpad_pool = _get_sinkpad_pool, .get_sinkpad_pool = _get_sinkpad_pool,
}; };
@ -679,8 +679,18 @@ gst_va_base_enc_set_format (GstVideoEncoder * venc, GstVideoCodecState * state)
g_return_val_if_fail (state->caps != NULL, FALSE); g_return_val_if_fail (state->caps != NULL, FALSE);
if (!gst_va_video_info_from_caps (&base->in_info, NULL, state->caps)) if (!gst_video_is_dma_drm_caps (state->caps)) {
return FALSE; gst_video_info_dma_drm_init (&base->in_drm_info);
base->in_info = state->info;
} else {
GstVideoInfo info;
if (!gst_video_info_dma_drm_from_caps (&base->in_drm_info, state->caps))
return FALSE;
if (!gst_va_dma_drm_info_to_video_info (&base->in_drm_info, &info))
return FALSE;
base->in_info = info;
}
if (base->input_state) if (base->input_state)
gst_video_codec_state_unref (base->input_state); gst_video_codec_state_unref (base->input_state);

View file

@ -65,7 +65,10 @@ struct _GstVaBaseEnc
GQueue output_list; GQueue output_list;
GstVideoCodecState *input_state; GstVideoCodecState *input_state;
GstVideoInfo in_info; union {
GstVideoInfo in_info;
GstVideoInfoDmaDrm in_drm_info;
};
/*< private >*/ /*< private >*/
GstVaBaseEncPrivate *priv; GstVaBaseEncPrivate *priv;

View file

@ -178,8 +178,16 @@ gst_va_base_transform_set_caps (GstBaseTransform * trans, GstCaps * incaps,
gboolean res; gboolean res;
/* input caps */ /* input caps */
if (!gst_va_video_info_from_caps (&in_info, NULL, incaps)) if (!gst_video_is_dma_drm_caps (incaps)) {
goto invalid_caps; gst_video_info_dma_drm_init (&self->in_drm_info);
if (!gst_video_info_from_caps (&in_info, incaps))
goto invalid_caps;
} else {
if (!gst_video_info_dma_drm_from_caps (&self->in_drm_info, incaps))
goto invalid_caps;
if (!gst_va_dma_drm_info_to_video_info (&self->in_drm_info, &in_info))
goto invalid_caps;
}
/* output caps */ /* output caps */
if (!gst_va_video_info_from_caps (&out_info, NULL, outcaps)) if (!gst_va_video_info_from_caps (&out_info, NULL, outcaps))
@ -864,7 +872,7 @@ gst_va_base_transform_import_buffer (GstVaBaseTransform * self,
#endif #endif
.display = self->display, .display = self->display,
.entrypoint = VAEntrypointVideoProc, .entrypoint = VAEntrypointVideoProc,
.in_info = &self->in_info, .in_drm_info = &self->in_drm_info,
.sinkpad_info = &self->priv->sinkpad_info, .sinkpad_info = &self->priv->sinkpad_info,
.get_sinkpad_pool = _get_sinkpad_pool, .get_sinkpad_pool = _get_sinkpad_pool,
}; };

View file

@ -47,7 +47,10 @@ struct _GstVaBaseTransform
GstCaps *in_caps; GstCaps *in_caps;
GstCaps *out_caps; GstCaps *out_caps;
GstVideoInfo in_info; union {
GstVideoInfo in_info;
GstVideoInfoDmaDrm in_drm_info;
};
GstVideoInfo out_info; GstVideoInfo out_info;
gboolean negotiated; gboolean negotiated;