For formats that are supported only with non-linear modifiers it
doesn't make to much sense to define cpp or char_per_block, so that
will be set to 0.

This patch adds a restriction to force having a modifier attached when
cpp/char_per_block is 0, and to bypass checking the pitch restriction.

This had been discussed here.
[1] 
https://people.freedesktop.org/~cbrill/dri-log/?channel=dri-devel&highlight_names=&date=2018-09-13&show_html=true

Signed-off-by: Alexandru Gheorghe <[email protected]>
Reviewed-by: Liviu Dudau <[email protected]>
---
 drivers/gpu/drm/drm_framebuffer.c | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)

diff --git a/drivers/gpu/drm/drm_framebuffer.c 
b/drivers/gpu/drm/drm_framebuffer.c
index 4e14013788cd..66ec126b7faf 100644
--- a/drivers/gpu/drm/drm_framebuffer.c
+++ b/drivers/gpu/drm/drm_framebuffer.c
@@ -200,6 +200,10 @@ static int framebuffer_check(struct drm_device *dev,
                                        drm_format_info_block_width(info, i) *
                                        drm_format_info_block_height(info, i));
 
+               if (!block_size && (r->modifier[i] == DRM_FORMAT_MOD_LINEAR)) {
+                       DRM_DEBUG_KMS("Format requires non-linear modifier for 
plane %d\n", i);
+                       return -EINVAL;
+               }
                if (!r->handles[i]) {
                        DRM_DEBUG_KMS("no buffer object handle for plane %d\n", 
i);
                        return -EINVAL;
@@ -211,7 +215,7 @@ static int framebuffer_check(struct drm_device *dev,
                if ((uint64_t) height * r->pitches[i] + r->offsets[i] > 
UINT_MAX)
                        return -ERANGE;
 
-               if (r->pitches[i] < min_pitch) {
+               if (block_size && r->pitches[i] < min_pitch) {
                        DRM_DEBUG_KMS("bad pitch %u for plane %d\n", 
r->pitches[i], i);
                        return -EINVAL;
                }
-- 
2.18.0

_______________________________________________
dri-devel mailing list
[email protected]
https://lists.freedesktop.org/mailman/listinfo/dri-devel

Reply via email to