mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-03 14:08:56 +00:00
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:
parent
94c94d34dc
commit
bc48588818
2 changed files with 16 additions and 16 deletions
|
@ -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"/>
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue