summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRaul E Rangel <rrangel@chromium.org>2021-01-13 10:50:37 -0700
committerNico Huber <nico.h@gmx.de>2021-01-24 11:18:23 +0000
commit8b043c058cd58da46db268a9d61b80fd893cf90d (patch)
tree1784e4067490624d9eb3e5bba76ab73711f31ba3
parentd4b58259c4ecb0e68586282b5cde194f66de2bba (diff)
lib/edid_fill_fb: Relax bits_per_pixel constraint
The Picasso VBIOS is not setting the reserved_mask_size correctly. This change relaxes the constraint to allow bpp_mask <= bits_per_pixel. This is how the code previously used to work before CB:39002. BUG=b:177094598, b:177422379 TEST=boot zork and see depthcharge working Signed-off-by: Raul E Rangel <rrangel@chromium.org> Change-Id: I2e67532fa949fbd673269d8d7f1c0d8af6124ac9 Reviewed-on: https://review.coreboot.org/c/coreboot/+/49404 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Nico Huber <nico.h@gmx.de> Reviewed-by: Angel Pons <th3fanbus@gmail.com> Reviewed-by: Yu-Ping Wu <yupingso@google.com>
-rw-r--r--src/lib/edid_fill_fb.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/src/lib/edid_fill_fb.c b/src/lib/edid_fill_fb.c
index 712cd0f525..7e8aa95180 100644
--- a/src/lib/edid_fill_fb.c
+++ b/src/lib/edid_fill_fb.c
@@ -48,10 +48,17 @@ fb_add_framebuffer_info_ex(const struct lb_framebuffer *fb)
bpp_mask = fb->blue_mask_size + fb->green_mask_size + fb->red_mask_size +
fb->reserved_mask_size;
- if (fb->bits_per_pixel != bpp_mask) {
- printk(BIOS_ERR, "%s: BPP=%d and channel bit mask=%d doesn't match."
- " This is a driver bug.\n", __func__, fb->bits_per_pixel, bpp_mask);
+ if (bpp_mask > fb->bits_per_pixel) {
+ printk(BIOS_ERR,
+ "%s: channel bit mask=%d is greater than BPP=%d ."
+ " This is a driver bug. Framebuffer is invalid.\n",
+ __func__, bpp_mask, fb->bits_per_pixel);
return NULL;
+ } else if (bpp_mask != fb->bits_per_pixel) {
+ printk(BIOS_WARNING,
+ "%s: channel bit mask=%d and BPP=%d don't match."
+ " This is a driver bug.\n",
+ __func__, bpp_mask, fb->bits_per_pixel);
}
info = fb_new_framebuffer_info();