video: dma: Set DMA caps' format field to DMA_DRM

The current way of dma caps uses the drm-format to replace the orginal
format field. The absence of format field means it can accept all formats.
It causes problems when clipping with other old DMA or video/x-raw(ANY)
caps, the result will contain both format field and drm-format field,
which is not valid DMA caps.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/4981>
This commit is contained in:
He Junyan 2023-07-10 18:30:36 +08:00 committed by GStreamer Marge Bot
parent 94c94d34dc
commit bc48588818
2 changed files with 16 additions and 16 deletions

View file

@ -11384,8 +11384,8 @@ gst_video_info_dma_drm_new()</doc>
</method> </method>
<method name="to_caps" c:identifier="gst_video_info_dma_drm_to_caps" version="1.24"> <method name="to_caps" c:identifier="gst_video_info_dma_drm_to_caps" version="1.24">
<doc xml:space="preserve" filename="../subprojects/gst-plugins-base/gst-libs/gst/video/video-info-dma.c">Convert the values of @drm_info into a #GstCaps. Please note that the <doc xml:space="preserve" filename="../subprojects/gst-plugins-base/gst-libs/gst/video/video-info-dma.c">Convert the values of @drm_info into a #GstCaps. Please note that the
@caps returned will be a dma drm caps which does not contain format field, @caps returned will be a dma drm caps which sets format field to DMA_DRM,
but contains a drm-format field instead. The value of drm-format field is and contains a new drm-format field. The value of drm-format field is
composed of a drm fourcc and a modifier, such as NV12:0x0100000000000002.</doc> composed of a drm fourcc and a modifier, such as NV12:0x0100000000000002.</doc>
<source-position filename="../subprojects/gst-plugins-base/gst-libs/gst/video/video-info-dma.h"/> <source-position filename="../subprojects/gst-plugins-base/gst-libs/gst/video/video-info-dma.h"/>
<return-value transfer-ownership="full" nullable="1"> <return-value transfer-ownership="full" nullable="1">
@ -11403,7 +11403,7 @@ info in @drm_info.</doc>
<method name="to_video_info" c:identifier="gst_video_info_dma_drm_to_video_info" version="1.24"> <method name="to_video_info" c:identifier="gst_video_info_dma_drm_to_video_info" version="1.24">
<doc xml:space="preserve" filename="../subprojects/gst-plugins-base/gst-libs/gst/video/video-info-dma.c">Convert the #GstVideoInfoDmaDrm into a traditional #GstVideoInfo with <doc xml:space="preserve" filename="../subprojects/gst-plugins-base/gst-libs/gst/video/video-info-dma.c">Convert the #GstVideoInfoDmaDrm into a traditional #GstVideoInfo with
recognized video format. For DMA kind memory, the non linear DMA format recognized video format. For DMA kind memory, the non linear DMA format
should be recognized as #GST_VIDEO_FORMAT_ENCODED. This helper function should be recognized as #GST_VIDEO_FORMAT_DMA_DRM. This helper function
sets @info's video format into the default value according to @drm_info's sets @info's video format into the default value according to @drm_info's
drm_fourcc field.</doc> drm_fourcc field.</doc>
<source-position filename="../subprojects/gst-plugins-base/gst-libs/gst/video/video-info-dma.h"/> <source-position filename="../subprojects/gst-plugins-base/gst-libs/gst/video/video-info-dma.h"/>

View file

@ -232,7 +232,9 @@ gst_video_is_dma_drm_caps (const GstCaps * caps)
return FALSE; return FALSE;
structure = gst_caps_get_structure (caps, 0); structure = gst_caps_get_structure (caps, 0);
if (gst_structure_has_field (structure, "format"))
if (g_strcmp0 (gst_structure_get_string (structure, "format"),
"DMA_DRM") != 0)
return FALSE; return FALSE;
return TRUE; return TRUE;
@ -243,8 +245,8 @@ gst_video_is_dma_drm_caps (const GstCaps * caps)
* @drm_info: a #GstVideoInfoDmaDrm * @drm_info: a #GstVideoInfoDmaDrm
* *
* Convert the values of @drm_info into a #GstCaps. Please note that the * Convert the values of @drm_info into a #GstCaps. Please note that the
* @caps returned will be a dma drm caps which does not contain format field, * @caps returned will be a dma drm caps which sets format field to DMA_DRM,
* but contains a drm-format field instead. The value of drm-format field is * and contains a new drm-format field. The value of drm-format field is
* composed of a drm fourcc and a modifier, such as NV12:0x0100000000000002. * composed of a drm fourcc and a modifier, such as NV12:0x0100000000000002.
* *
* Returns: (transfer full) (nullable): a new #GstCaps containing the * Returns: (transfer full) (nullable): a new #GstCaps containing the
@ -273,8 +275,8 @@ gst_video_info_dma_drm_to_caps (const GstVideoInfoDmaDrm * drm_info)
drm_info->drm_modifier); drm_info->drm_modifier);
structure = gst_caps_get_structure (caps, 0); structure = gst_caps_get_structure (caps, 0);
gst_structure_remove_field (structure, "format"); gst_structure_set (structure, "format", G_TYPE_STRING, "DMA_DRM",
gst_structure_set (structure, "drm-format", G_TYPE_STRING, str, NULL); "drm-format", G_TYPE_STRING, str, NULL);
g_free (str); g_free (str);
@ -337,17 +339,15 @@ gst_video_info_dma_drm_from_caps (GstVideoInfoDmaDrm * drm_info,
} }
/* If the modifier is linear, set the according format in video info, /* If the modifier is linear, set the according format in video info,
* otherwise, just set the format to GST_VIDEO_FORMAT_ENCODED. */ * otherwise, just let the format to be GST_VIDEO_FORMAT_DMA_DRM. */
/* TODO: Some well known tiled format such as NV12_4L4, NV12_16L16, /* TODO: Some well known tiled format such as NV12_4L4, NV12_16L16,
* NV12_64Z32, NV12_16L32S */ * NV12_64Z32, NV12_16L32S */
format = gst_video_dma_drm_fourcc_to_format (fourcc); format = gst_video_dma_drm_fourcc_to_format (fourcc);
if (modifier == DRM_FORMAT_MOD_LINEAR && format != GST_VIDEO_FORMAT_UNKNOWN) { if (modifier == DRM_FORMAT_MOD_LINEAR && format != GST_VIDEO_FORMAT_UNKNOWN) {
gst_structure_set (structure, "format", G_TYPE_STRING, gst_structure_set (structure, "format", G_TYPE_STRING,
gst_video_format_to_string (format), NULL); gst_video_format_to_string (format), NULL);
} else {
gst_structure_set (structure, "format", G_TYPE_STRING,
gst_video_format_to_string (GST_VIDEO_FORMAT_ENCODED), NULL);
} }
gst_structure_remove_field (structure, "drm-format"); gst_structure_remove_field (structure, "drm-format");
if (!gst_video_info_from_caps (&drm_info->vinfo, tmp_caps)) { if (!gst_video_info_from_caps (&drm_info->vinfo, tmp_caps)) {
@ -432,13 +432,13 @@ gst_video_info_dma_drm_from_video_info (GstVideoInfoDmaDrm * drm_info,
drm_info->drm_fourcc = fourcc; drm_info->drm_fourcc = fourcc;
drm_info->drm_modifier = modifier; drm_info->drm_modifier = modifier;
/* no need to change format to GST_VIDEO_INFO_ENCODED since its modifier is /* no need to change format to GST_VIDEO_INFO_DMA_DRM since its modifier is
* linear */ * linear */
if (modifier == DRM_FORMAT_MOD_LINEAR) if (modifier == DRM_FORMAT_MOD_LINEAR)
return TRUE; return TRUE;
return gst_video_info_set_interlaced_format (&drm_info->vinfo, return gst_video_info_set_interlaced_format (&drm_info->vinfo,
GST_VIDEO_FORMAT_ENCODED, GST_VIDEO_INFO_INTERLACE_MODE (info), GST_VIDEO_FORMAT_DMA_DRM, GST_VIDEO_INFO_INTERLACE_MODE (info),
GST_VIDEO_INFO_WIDTH (info), GST_VIDEO_INFO_HEIGHT (info)); GST_VIDEO_INFO_WIDTH (info), GST_VIDEO_INFO_HEIGHT (info));
} }
@ -449,7 +449,7 @@ gst_video_info_dma_drm_from_video_info (GstVideoInfoDmaDrm * drm_info,
* *
* Convert the #GstVideoInfoDmaDrm into a traditional #GstVideoInfo with * Convert the #GstVideoInfoDmaDrm into a traditional #GstVideoInfo with
* recognized video format. For DMA kind memory, the non linear DMA format * recognized video format. For DMA kind memory, the non linear DMA format
* should be recognized as #GST_VIDEO_FORMAT_ENCODED. This helper function * should be recognized as #GST_VIDEO_FORMAT_DMA_DRM. This helper function
* sets @info's video format into the default value according to @drm_info's * sets @info's video format into the default value according to @drm_info's
* drm_fourcc field. * drm_fourcc field.
* *
@ -468,7 +468,7 @@ gst_video_info_dma_drm_to_video_info (const GstVideoInfoDmaDrm * drm_info,
g_return_val_if_fail (drm_info, FALSE); g_return_val_if_fail (drm_info, FALSE);
g_return_val_if_fail (info, FALSE); g_return_val_if_fail (info, FALSE);
if (GST_VIDEO_INFO_FORMAT (&drm_info->vinfo) != GST_VIDEO_FORMAT_ENCODED) { if (GST_VIDEO_INFO_FORMAT (&drm_info->vinfo) != GST_VIDEO_FORMAT_DMA_DRM) {
*info = drm_info->vinfo; *info = drm_info->vinfo;
return TRUE; return TRUE;
} }