summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVadim Bendebury <vbendeb@chromium.org>2012-09-28 15:11:17 +0000
committerAnatolij Gustschin <agust@denx.de>2012-11-07 00:57:27 +0100
commitd484b52e6fcb28dc011ce45718294496c6ea83d0 (patch)
treefce605b5e5a41a56b5c0546a5956805980afa87b
parent45d7f52511f43b71b623a502fdf31feb905f70a1 (diff)
downloadu-boot-imx-d484b52e6fcb28dc011ce45718294496c6ea83d0.zip
u-boot-imx-d484b52e6fcb28dc011ce45718294496c6ea83d0.tar.gz
u-boot-imx-d484b52e6fcb28dc011ce45718294496c6ea83d0.tar.bz2
video: Skip bitmaps which do not fit into the screen in cfb_console
The cfb console driver is trying to prevent bitmaps to spill over the screen, but the calculations assume that at least part of the bitmap fits into the screen area. In reality there could be bitmap elements which are completely out of the screen area, they just need to be discarded. Signed-off-by: Vadim Bendebury <vbendeb@chromium.org> Signed-off-by: Simon Glass <sjg@chromium.org>
-rw-r--r--drivers/video/cfb_console.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/drivers/video/cfb_console.c b/drivers/video/cfb_console.c
index 6f5d4f2..9388859 100644
--- a/drivers/video/cfb_console.c
+++ b/drivers/video/cfb_console.c
@@ -1515,6 +1515,13 @@ int video_display_bitmap(ulong bmp_image, int x, int y)
padded_line = (((width * bpp + 7) / 8) + 3) & ~0x3;
+ /*
+ * Just ignore elements which are completely beyond screen
+ * dimensions.
+ */
+ if ((x >= VIDEO_VISIBLE_COLS) || (y >= VIDEO_VISIBLE_ROWS))
+ return 0;
+
#ifdef CONFIG_SPLASH_SCREEN_ALIGN
if (x == BMP_ALIGN_CENTER)
x = max(0, (VIDEO_VISIBLE_COLS - width) / 2);