diff options
author | Nico Huber <nico.h@gmx.de> | 2023-07-14 00:09:00 +0200 |
---|---|---|
committer | Felix Held <felix-coreboot@felixheld.de> | 2023-07-17 14:49:04 +0000 |
commit | 99eee16a13a57c0df2025ffd2ddd3460eb696b4d (patch) | |
tree | d3cfbe1ceb55bc0b064586524c6a4f2b05d6224c /src/lib/bootsplash.c | |
parent | 9b186e0ffef42bd1ef673bcada7d7cf5d5220d49 (diff) | |
download | coreboot-99eee16a13a57c0df2025ffd2ddd3460eb696b4d.tar.gz coreboot-99eee16a13a57c0df2025ffd2ddd3460eb696b4d.tar.bz2 coreboot-99eee16a13a57c0df2025ffd2ddd3460eb696b4d.zip |
Center bootsplash on bigger framebuffers
In the JPEG decoder, use `bytes_per_line` instead of `width` for
address calculations, to allow for bigger framebuffers. When
calling jpeg_decode(), add an offset to the framebuffer address
so the picture gets centered.
Change-Id: I0174bdccfaad425e708a5fa50bcb28a1b98a23f7
Signed-off-by: Nico Huber <nico.h@gmx.de>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/76424
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Martin L Roth <gaumless@gmail.com>
Reviewed-by: Paul Menzel <paulepanter@mailbox.org>
Reviewed-by: Subrata Banik <subratabanik@google.com>
Diffstat (limited to 'src/lib/bootsplash.c')
-rw-r--r-- | src/lib/bootsplash.c | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/src/lib/bootsplash.c b/src/lib/bootsplash.c index 0eb94dc81280..3ab11aca6fad 100644 --- a/src/lib/bootsplash.c +++ b/src/lib/bootsplash.c @@ -11,7 +11,8 @@ void set_bootsplash(unsigned char *framebuffer, unsigned int x_resolution, - unsigned int y_resolution, unsigned int fb_resolution) + unsigned int y_resolution, unsigned int bytes_per_line, + unsigned int fb_resolution) { printk(BIOS_INFO, "Setting up bootsplash in %dx%d@%d\n", x_resolution, y_resolution, fb_resolution); @@ -27,9 +28,20 @@ void set_bootsplash(unsigned char *framebuffer, unsigned int x_resolution, printk(BIOS_DEBUG, "Bootsplash image resolution: %dx%d\n", image_width, image_height); + if (image_width > x_resolution || image_height > y_resolution) { + printk(BIOS_NOTICE, "Bootsplash image can't fit framebuffer.\n"); + cbfs_unmap(jpeg); + return; + } + + /* center image: */ + framebuffer += (y_resolution - image_height) / 2 * bytes_per_line + + (x_resolution - image_width) / 2 * (fb_resolution / 8); + decdata = malloc(sizeof(*decdata)); - int ret = jpeg_decode(jpeg, framebuffer, x_resolution, y_resolution, fb_resolution, - decdata); + int ret = jpeg_decode(jpeg, framebuffer, image_width, image_height, + bytes_per_line, fb_resolution, decdata); + free(decdata); cbfs_unmap(jpeg); if (ret != 0) { printk(BIOS_ERR, "Bootsplash could not be decoded. jpeg_decode returned %d.\n", |