dm: video: check bounds for column and row
authorHeinrich Schuchardt <xypron.glpk@gmx.de>
Wed, 19 Sep 2018 17:15:14 +0000 (19:15 +0200)
committerAlexander Graf <agraf@suse.de>
Sun, 23 Sep 2018 19:55:31 +0000 (21:55 +0200)
CSI H can be used to position the cursor. The calling application may
specify a location that is beyond the limits of the screen. This may
lead to an illegal memory access.

Signed-off-by: Heinrich Schuchardt <xypron.glpk@gmx.de>
Signed-off-by: Alexander Graf <agraf@suse.de>
drivers/video/vidconsole-uclass.c

index f1d3ad3..0c36a5d 100644 (file)
@@ -213,6 +213,14 @@ static void vidconsole_escape_char(struct udevice *dev, char ch)
                s++;    /* ; */
                s = parsenum(s, &col);
 
+               /*
+                * Ensure we stay in the bounds of the screen.
+                */
+               if (row >= priv->rows)
+                       row = priv->rows - 1;
+               if (col >= priv->cols)
+                       col = priv->cols - 1;
+
                priv->ycur = row * priv->y_charsize;
                priv->xcur_frac = priv->xstart_frac +
                        VID_TO_POS(col * priv->x_charsize);