mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-31 20:48:56 +00:00
va: Only change video format in gst_va_video_info_from_dma_info()
The current way of using gst_video_info_set_format() will change all fields of the GstVideoInfo. We only need to change its format, stride and offset fields. In order to keep the consistency with th common drm API, we rename the gst_va_video_info_from_dma_info() into gst_va_dma_drm_info_to_video_info(). Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/4883>
This commit is contained in:
parent
e92dea5ce6
commit
6accb7a1f5
3 changed files with 18 additions and 9 deletions
|
@ -365,10 +365,12 @@ gst_va_video_surface_format_from_image_format (GstVideoFormat image_format,
|
||||||
/* Convert the GstVideoInfoDmaDrm into a traditional GstVideoInfo
|
/* Convert the GstVideoInfoDmaDrm into a traditional GstVideoInfo
|
||||||
with recognized format. */
|
with recognized format. */
|
||||||
gboolean
|
gboolean
|
||||||
gst_va_video_info_from_dma_info (GstVideoInfo * info,
|
gst_va_dma_drm_info_to_video_info (const GstVideoInfoDmaDrm * drm_info,
|
||||||
const GstVideoInfoDmaDrm * drm_info)
|
GstVideoInfo * info)
|
||||||
{
|
{
|
||||||
GstVideoFormat video_format;
|
GstVideoFormat video_format;
|
||||||
|
GstVideoInfo tmp_info;
|
||||||
|
guint i;
|
||||||
|
|
||||||
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);
|
||||||
|
@ -387,12 +389,19 @@ gst_va_video_info_from_dma_info (GstVideoInfo * info,
|
||||||
if (video_format == GST_VIDEO_FORMAT_UNKNOWN)
|
if (video_format == GST_VIDEO_FORMAT_UNKNOWN)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
*info = drm_info->vinfo;
|
if (!gst_video_info_set_format (&tmp_info, video_format,
|
||||||
|
GST_VIDEO_INFO_WIDTH (&drm_info->vinfo),
|
||||||
if (!gst_video_info_set_format (info, video_format,
|
GST_VIDEO_INFO_HEIGHT (&drm_info->vinfo)))
|
||||||
GST_VIDEO_INFO_WIDTH (info), GST_VIDEO_INFO_HEIGHT (info)))
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
|
*info = drm_info->vinfo;
|
||||||
|
info->finfo = tmp_info.finfo;
|
||||||
|
for (i = 0; i < GST_VIDEO_MAX_PLANES; i++)
|
||||||
|
info->stride[i] = tmp_info.stride[i];
|
||||||
|
for (i = 0; i < GST_VIDEO_MAX_PLANES; i++)
|
||||||
|
info->offset[i] = tmp_info.offset[i];
|
||||||
|
info->size = tmp_info.size;
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -56,8 +56,8 @@ GstVideoFormat gst_va_video_surface_format_from_image_format (GstVideoFor
|
||||||
GArray * surface_formats);
|
GArray * surface_formats);
|
||||||
|
|
||||||
GST_VA_API
|
GST_VA_API
|
||||||
gboolean gst_va_video_info_from_dma_info (GstVideoInfo * info,
|
gboolean gst_va_dma_drm_info_to_video_info (const GstVideoInfoDmaDrm * drm_info,
|
||||||
const GstVideoInfoDmaDrm * drm_info);
|
GstVideoInfo * info);
|
||||||
|
|
||||||
GST_VA_API
|
GST_VA_API
|
||||||
void gst_va_video_format_fix_map (VAImageFormat * image_formats,
|
void gst_va_video_format_fix_map (VAImageFormat * image_formats,
|
||||||
|
|
|
@ -325,7 +325,7 @@ gst_va_video_info_from_caps (GstVideoInfo * info, guint64 * modifier,
|
||||||
if (!gst_video_info_dma_drm_from_caps (&drm_info, caps))
|
if (!gst_video_info_dma_drm_from_caps (&drm_info, caps))
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
if (!gst_va_video_info_from_dma_info (info, &drm_info))
|
if (!gst_va_dma_drm_info_to_video_info (&drm_info, info))
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
if (modifier)
|
if (modifier)
|
||||||
|
|
Loading…
Reference in a new issue