mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-09 14:43:16 +00:00
drm/core: Calculate bpp in afbc helper
Some drivers (komeda, malidp) don't set anything in cpp. If that is the case the right value can be inferred from the format. Then the "bpp" member can be eliminated from struct drm_afbc_framebuffer. Signed-off-by: Andrzej Pietrasiewicz <andrzej.p@collabora.com> Acked-by: Daniel Vetter <daniel.vetter@ffwll.ch> Link: https://patchwork.freedesktop.org/patch/msgid/20200331155308.6345-3-andrzej.p@collabora.com
This commit is contained in:
parent
88f1b29a44
commit
bcf6293d7a
@ -404,21 +404,6 @@ Contact: Laurent Pinchart, respective driver maintainers
|
|||||||
|
|
||||||
Level: Intermediate
|
Level: Intermediate
|
||||||
|
|
||||||
Encode cpp properly in malidp
|
|
||||||
-----------------------------
|
|
||||||
|
|
||||||
cpp (chars per pixel) is not encoded properly in malidp, zero is
|
|
||||||
used instead. afbc implementation needs bpp or cpp, but if it is
|
|
||||||
zero it needs to be provided elsewhere, and so the bpp field exists
|
|
||||||
in struct drm_afbc_framebuffer.
|
|
||||||
|
|
||||||
Properly encode cpp in malidp and remove the bpp field in struct
|
|
||||||
drm_afbc_framebuffer.
|
|
||||||
|
|
||||||
Contact: malidp maintainers
|
|
||||||
|
|
||||||
Level: Intermediate
|
|
||||||
|
|
||||||
Core refactorings
|
Core refactorings
|
||||||
=================
|
=================
|
||||||
|
|
||||||
|
@ -309,11 +309,37 @@ drm_gem_fb_create_with_dirty(struct drm_device *dev, struct drm_file *file,
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(drm_gem_fb_create_with_dirty);
|
EXPORT_SYMBOL_GPL(drm_gem_fb_create_with_dirty);
|
||||||
|
|
||||||
|
static __u32 drm_gem_afbc_get_bpp(struct drm_device *dev,
|
||||||
|
const struct drm_mode_fb_cmd2 *mode_cmd)
|
||||||
|
{
|
||||||
|
const struct drm_format_info *info;
|
||||||
|
|
||||||
|
info = drm_get_format_info(dev, mode_cmd);
|
||||||
|
|
||||||
|
/* use whatever a driver has set */
|
||||||
|
if (info->cpp[0])
|
||||||
|
return info->cpp[0] * 8;
|
||||||
|
|
||||||
|
/* guess otherwise */
|
||||||
|
switch (info->format) {
|
||||||
|
case DRM_FORMAT_YUV420_8BIT:
|
||||||
|
return 12;
|
||||||
|
case DRM_FORMAT_YUV420_10BIT:
|
||||||
|
return 15;
|
||||||
|
case DRM_FORMAT_VUY101010:
|
||||||
|
return 30;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* all attempts failed */
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int drm_gem_afbc_min_size(struct drm_device *dev,
|
static int drm_gem_afbc_min_size(struct drm_device *dev,
|
||||||
const struct drm_mode_fb_cmd2 *mode_cmd,
|
const struct drm_mode_fb_cmd2 *mode_cmd,
|
||||||
struct drm_afbc_framebuffer *afbc_fb)
|
struct drm_afbc_framebuffer *afbc_fb)
|
||||||
{
|
{
|
||||||
const struct drm_format_info *info;
|
|
||||||
__u32 n_blocks, w_alignment, h_alignment, hdr_alignment;
|
__u32 n_blocks, w_alignment, h_alignment, hdr_alignment;
|
||||||
/* remove bpp when all users properly encode cpp in drm_format_info */
|
/* remove bpp when all users properly encode cpp in drm_format_info */
|
||||||
__u32 bpp;
|
__u32 bpp;
|
||||||
@ -351,12 +377,11 @@ static int drm_gem_afbc_min_size(struct drm_device *dev,
|
|||||||
afbc_fb->aligned_height = ALIGN(mode_cmd->height, h_alignment);
|
afbc_fb->aligned_height = ALIGN(mode_cmd->height, h_alignment);
|
||||||
afbc_fb->offset = mode_cmd->offsets[0];
|
afbc_fb->offset = mode_cmd->offsets[0];
|
||||||
|
|
||||||
info = drm_get_format_info(dev, mode_cmd);
|
bpp = drm_gem_afbc_get_bpp(dev, mode_cmd);
|
||||||
/*
|
if (!bpp) {
|
||||||
* Change to always using info->cpp[0]
|
drm_dbg_kms(dev, "Invalid AFBC bpp value: %d\n", bpp);
|
||||||
* when all users properly encode it
|
return -EINVAL;
|
||||||
*/
|
}
|
||||||
bpp = info->cpp[0] ? info->cpp[0] * 8 : afbc_fb->bpp;
|
|
||||||
|
|
||||||
n_blocks = (afbc_fb->aligned_width * afbc_fb->aligned_height)
|
n_blocks = (afbc_fb->aligned_width * afbc_fb->aligned_height)
|
||||||
/ AFBC_SUPERBLOCK_PIXELS;
|
/ AFBC_SUPERBLOCK_PIXELS;
|
||||||
|
@ -331,13 +331,6 @@ struct drm_afbc_framebuffer {
|
|||||||
* @afbc_size: minimum size of afbc buffer
|
* @afbc_size: minimum size of afbc buffer
|
||||||
*/
|
*/
|
||||||
u32 afbc_size;
|
u32 afbc_size;
|
||||||
/**
|
|
||||||
* @bpp: bpp value for this afbc buffer
|
|
||||||
* To be removed when users such as malidp
|
|
||||||
* properly store the cpp in drm_format_info.
|
|
||||||
* New users should not start using this field.
|
|
||||||
*/
|
|
||||||
u32 bpp;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#define fb_to_afbc_fb(x) container_of(x, struct drm_afbc_framebuffer, base)
|
#define fb_to_afbc_fb(x) container_of(x, struct drm_afbc_framebuffer, base)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user