Commit 7751b8cb authored by Dave Airlie's avatar Dave Airlie

drm/kms/fb: check for depth changes from userspace for resizing.

If userspace (plymouth in this case) asks for a deeper depth,
refuse it as well due to lack of resizing.

This fixes an issue since < 32MB cards went to 8bpp and plymouth
crashes on startup.
Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
parent 992dc9ae
...@@ -606,11 +606,10 @@ int drm_fb_helper_check_var(struct fb_var_screeninfo *var, ...@@ -606,11 +606,10 @@ int drm_fb_helper_check_var(struct fb_var_screeninfo *var,
return -EINVAL; return -EINVAL;
/* Need to resize the fb object !!! */ /* Need to resize the fb object !!! */
if (var->xres > fb->width || var->yres > fb->height) { if (var->bits_per_pixel > fb->bits_per_pixel || var->xres > fb->width || var->yres > fb->height) {
DRM_ERROR("Requested width/height is greater than current fb " DRM_DEBUG("fb userspace requested width/height/bpp is greater than current fb "
"object %dx%d > %dx%d\n", var->xres, var->yres, "object %dx%d-%d > %dx%d-%d\n", var->xres, var->yres, var->bits_per_pixel,
fb->width, fb->height); fb->width, fb->height, fb->bits_per_pixel);
DRM_ERROR("Need resizing code.\n");
return -EINVAL; return -EINVAL;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment