Module Name: src Committed By: riastradh Date: Thu Feb 23 02:47:52 UTC 2023
Modified Files: src/sys/dev/wscons: wsemul_vt100_subr.c Log Message: wscons(4): Ignore nonsense tab stops in vt100 emulation. XXX pullup-8 XXX pullup-9 XXX pullup-10 To generate a diff of this commit: cvs rdiff -u -r1.26 -r1.27 src/sys/dev/wscons/wsemul_vt100_subr.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/dev/wscons/wsemul_vt100_subr.c diff -u src/sys/dev/wscons/wsemul_vt100_subr.c:1.26 src/sys/dev/wscons/wsemul_vt100_subr.c:1.27 --- src/sys/dev/wscons/wsemul_vt100_subr.c:1.26 Wed Jan 18 17:02:17 2023 +++ src/sys/dev/wscons/wsemul_vt100_subr.c Thu Feb 23 02:47:52 2023 @@ -1,4 +1,4 @@ -/* $NetBSD: wsemul_vt100_subr.c,v 1.26 2023/01/18 17:02:17 christos Exp $ */ +/* $NetBSD: wsemul_vt100_subr.c,v 1.27 2023/02/23 02:47:52 riastradh Exp $ */ /* * Copyright (c) 1998 @@ -27,7 +27,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: wsemul_vt100_subr.c,v 1.26 2023/01/18 17:02:17 christos Exp $"); +__KERNEL_RCSID(0, "$NetBSD: wsemul_vt100_subr.c,v 1.27 2023/02/23 02:47:52 riastradh Exp $"); #include <sys/param.h> #include <sys/systm.h> @@ -773,12 +773,22 @@ wsemul_vt100_handle_dcs(struct vt100base char c = edp->dcsarg[i]; switch (c) { case '0': case '1': case '2': case '3': case '4': - case '5': case '6': case '7': case '8': case '9': - pos = pos * 10 + (edp->dcsarg[i] - '0'); + case '5': case '6': case '7': case '8': case '9': { + const int c0 = c - '0'; + if (pos < 0 || + pos > INT_MAX/10 || + pos * 10 > edp->ncols - c0) { + pos = -1; + break; + } + pos = pos * 10 + c0; break; + } case '/': - if (pos > 0) + if (pos > 0) { + KASSERT(pos <= edp->ncols); edp->tabs[pos - 1] = 1; + } pos = 0; break; default: @@ -788,8 +798,10 @@ wsemul_vt100_handle_dcs(struct vt100base break; } } - if (pos > 0) + if (pos > 0) { + KASSERT(pos <= edp->ncols); edp->tabs[pos - 1] = 1; + } break; default: panic("wsemul_vt100_handle_dcs: bad type %d", edp->dcstype);