提交 86c238aa 编写于 作者: L Laurent Pinchart 提交者: Archit Taneja

drm: Implement the drm_format_*() helpers as drm_format_info() wrappers

Turn the drm_format_*() helpers into wrappers around the drm_format_info
lookup function to centralize all format information in a single place.
Signed-off-by: NLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Reviewed-by: NTomi Valkeinen <tomi.valkeinen@ti.com>
Reviewed-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
Reviewed-by: NEric Engestrom <eric.engestrom@imgtec.com>
Signed-off-by: NArchit Taneja <architt@codeaurora.org>
Link: http://patchwork.freedesktop.org/patch/msgid/1476744081-24485-3-git-send-email-laurent.pinchart@ideasonboard.com
上级 84770cc2
...@@ -198,69 +198,22 @@ EXPORT_SYMBOL(drm_format_info); ...@@ -198,69 +198,22 @@ EXPORT_SYMBOL(drm_format_info);
void drm_fb_get_bpp_depth(uint32_t format, unsigned int *depth, void drm_fb_get_bpp_depth(uint32_t format, unsigned int *depth,
int *bpp) int *bpp)
{ {
char *format_name; const struct drm_format_info *info;
switch (format) { info = drm_format_info(format);
case DRM_FORMAT_C8: if (!info || !info->depth) {
case DRM_FORMAT_RGB332: char *format_name = drm_get_format_name(format);
case DRM_FORMAT_BGR233:
*depth = 8;
*bpp = 8;
break;
case DRM_FORMAT_XRGB1555:
case DRM_FORMAT_XBGR1555:
case DRM_FORMAT_RGBX5551:
case DRM_FORMAT_BGRX5551:
case DRM_FORMAT_ARGB1555:
case DRM_FORMAT_ABGR1555:
case DRM_FORMAT_RGBA5551:
case DRM_FORMAT_BGRA5551:
*depth = 15;
*bpp = 16;
break;
case DRM_FORMAT_RGB565:
case DRM_FORMAT_BGR565:
*depth = 16;
*bpp = 16;
break;
case DRM_FORMAT_RGB888:
case DRM_FORMAT_BGR888:
*depth = 24;
*bpp = 24;
break;
case DRM_FORMAT_XRGB8888:
case DRM_FORMAT_XBGR8888:
case DRM_FORMAT_RGBX8888:
case DRM_FORMAT_BGRX8888:
*depth = 24;
*bpp = 32;
break;
case DRM_FORMAT_XRGB2101010:
case DRM_FORMAT_XBGR2101010:
case DRM_FORMAT_RGBX1010102:
case DRM_FORMAT_BGRX1010102:
case DRM_FORMAT_ARGB2101010:
case DRM_FORMAT_ABGR2101010:
case DRM_FORMAT_RGBA1010102:
case DRM_FORMAT_BGRA1010102:
*depth = 30;
*bpp = 32;
break;
case DRM_FORMAT_ARGB8888:
case DRM_FORMAT_ABGR8888:
case DRM_FORMAT_RGBA8888:
case DRM_FORMAT_BGRA8888:
*depth = 32;
*bpp = 32;
break;
default:
format_name = drm_get_format_name(format);
DRM_DEBUG_KMS("unsupported pixel format %s\n", format_name); DRM_DEBUG_KMS("unsupported pixel format %s\n", format_name);
kfree(format_name); kfree(format_name);
*depth = 0; *depth = 0;
*bpp = 0; *bpp = 0;
break; return;
} }
*depth = info->depth;
*bpp = info->cpp[0] * 8;
} }
EXPORT_SYMBOL(drm_fb_get_bpp_depth); EXPORT_SYMBOL(drm_fb_get_bpp_depth);
...@@ -273,28 +226,10 @@ EXPORT_SYMBOL(drm_fb_get_bpp_depth); ...@@ -273,28 +226,10 @@ EXPORT_SYMBOL(drm_fb_get_bpp_depth);
*/ */
int drm_format_num_planes(uint32_t format) int drm_format_num_planes(uint32_t format)
{ {
switch (format) { const struct drm_format_info *info;
case DRM_FORMAT_YUV410:
case DRM_FORMAT_YVU410: info = drm_format_info(format);
case DRM_FORMAT_YUV411: return info ? info->num_planes : 1;
case DRM_FORMAT_YVU411:
case DRM_FORMAT_YUV420:
case DRM_FORMAT_YVU420:
case DRM_FORMAT_YUV422:
case DRM_FORMAT_YVU422:
case DRM_FORMAT_YUV444:
case DRM_FORMAT_YVU444:
return 3;
case DRM_FORMAT_NV12:
case DRM_FORMAT_NV21:
case DRM_FORMAT_NV16:
case DRM_FORMAT_NV61:
case DRM_FORMAT_NV24:
case DRM_FORMAT_NV42:
return 2;
default:
return 1;
}
} }
EXPORT_SYMBOL(drm_format_num_planes); EXPORT_SYMBOL(drm_format_num_planes);
...@@ -308,40 +243,13 @@ EXPORT_SYMBOL(drm_format_num_planes); ...@@ -308,40 +243,13 @@ EXPORT_SYMBOL(drm_format_num_planes);
*/ */
int drm_format_plane_cpp(uint32_t format, int plane) int drm_format_plane_cpp(uint32_t format, int plane)
{ {
unsigned int depth; const struct drm_format_info *info;
int bpp;
if (plane >= drm_format_num_planes(format)) info = drm_format_info(format);
if (!info || plane >= info->num_planes)
return 0; return 0;
switch (format) { return info->cpp[plane];
case DRM_FORMAT_YUYV:
case DRM_FORMAT_YVYU:
case DRM_FORMAT_UYVY:
case DRM_FORMAT_VYUY:
return 2;
case DRM_FORMAT_NV12:
case DRM_FORMAT_NV21:
case DRM_FORMAT_NV16:
case DRM_FORMAT_NV61:
case DRM_FORMAT_NV24:
case DRM_FORMAT_NV42:
return plane ? 2 : 1;
case DRM_FORMAT_YUV410:
case DRM_FORMAT_YVU410:
case DRM_FORMAT_YUV411:
case DRM_FORMAT_YVU411:
case DRM_FORMAT_YUV420:
case DRM_FORMAT_YVU420:
case DRM_FORMAT_YUV422:
case DRM_FORMAT_YVU422:
case DRM_FORMAT_YUV444:
case DRM_FORMAT_YVU444:
return 1;
default:
drm_fb_get_bpp_depth(format, &depth, &bpp);
return bpp >> 3;
}
} }
EXPORT_SYMBOL(drm_format_plane_cpp); EXPORT_SYMBOL(drm_format_plane_cpp);
...@@ -355,28 +263,10 @@ EXPORT_SYMBOL(drm_format_plane_cpp); ...@@ -355,28 +263,10 @@ EXPORT_SYMBOL(drm_format_plane_cpp);
*/ */
int drm_format_horz_chroma_subsampling(uint32_t format) int drm_format_horz_chroma_subsampling(uint32_t format)
{ {
switch (format) { const struct drm_format_info *info;
case DRM_FORMAT_YUV411:
case DRM_FORMAT_YVU411: info = drm_format_info(format);
case DRM_FORMAT_YUV410: return info ? info->hsub : 1;
case DRM_FORMAT_YVU410:
return 4;
case DRM_FORMAT_YUYV:
case DRM_FORMAT_YVYU:
case DRM_FORMAT_UYVY:
case DRM_FORMAT_VYUY:
case DRM_FORMAT_NV12:
case DRM_FORMAT_NV21:
case DRM_FORMAT_NV16:
case DRM_FORMAT_NV61:
case DRM_FORMAT_YUV422:
case DRM_FORMAT_YVU422:
case DRM_FORMAT_YUV420:
case DRM_FORMAT_YVU420:
return 2;
default:
return 1;
}
} }
EXPORT_SYMBOL(drm_format_horz_chroma_subsampling); EXPORT_SYMBOL(drm_format_horz_chroma_subsampling);
...@@ -390,18 +280,10 @@ EXPORT_SYMBOL(drm_format_horz_chroma_subsampling); ...@@ -390,18 +280,10 @@ EXPORT_SYMBOL(drm_format_horz_chroma_subsampling);
*/ */
int drm_format_vert_chroma_subsampling(uint32_t format) int drm_format_vert_chroma_subsampling(uint32_t format)
{ {
switch (format) { const struct drm_format_info *info;
case DRM_FORMAT_YUV410:
case DRM_FORMAT_YVU410: info = drm_format_info(format);
return 4; return info ? info->vsub : 1;
case DRM_FORMAT_YUV420:
case DRM_FORMAT_YVU420:
case DRM_FORMAT_NV12:
case DRM_FORMAT_NV21:
return 2;
default:
return 1;
}
} }
EXPORT_SYMBOL(drm_format_vert_chroma_subsampling); EXPORT_SYMBOL(drm_format_vert_chroma_subsampling);
...@@ -416,13 +298,16 @@ EXPORT_SYMBOL(drm_format_vert_chroma_subsampling); ...@@ -416,13 +298,16 @@ EXPORT_SYMBOL(drm_format_vert_chroma_subsampling);
*/ */
int drm_format_plane_width(int width, uint32_t format, int plane) int drm_format_plane_width(int width, uint32_t format, int plane)
{ {
if (plane >= drm_format_num_planes(format)) const struct drm_format_info *info;
info = drm_format_info(format);
if (!info || plane >= info->num_planes)
return 0; return 0;
if (plane == 0) if (plane == 0)
return width; return width;
return width / drm_format_horz_chroma_subsampling(format); return width / info->hsub;
} }
EXPORT_SYMBOL(drm_format_plane_width); EXPORT_SYMBOL(drm_format_plane_width);
...@@ -437,12 +322,15 @@ EXPORT_SYMBOL(drm_format_plane_width); ...@@ -437,12 +322,15 @@ EXPORT_SYMBOL(drm_format_plane_width);
*/ */
int drm_format_plane_height(int height, uint32_t format, int plane) int drm_format_plane_height(int height, uint32_t format, int plane)
{ {
if (plane >= drm_format_num_planes(format)) const struct drm_format_info *info;
info = drm_format_info(format);
if (!info || plane >= info->num_planes)
return 0; return 0;
if (plane == 0) if (plane == 0)
return height; return height;
return height / drm_format_vert_chroma_subsampling(format); return height / info->vsub;
} }
EXPORT_SYMBOL(drm_format_plane_height); EXPORT_SYMBOL(drm_format_plane_height);
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册