Module Name: src Committed By: riastradh Date: Fri Mar 31 15:00:26 UTC 2023
Modified Files: src/sys/dev: spkr.c Log Message: spkr(4): Avoid some overflow issues. XXX pullup-8 XXX pullup-9 XXX pullup-10 Reported-by: syzbot+1a9980f3631bbd710...@syzkaller.appspotmail.com https://syzkaller.appspot.com/bug?id=ea851fc4688cbac29a567cb49a4fd24d9afff426 Reported-by: syzbot+b4655f9c1734f886d...@syzkaller.appspotmail.com https://syzkaller.appspot.com/bug?id=b61236df29f595e38b12ee533b7b3275c8ec1865 To generate a diff of this commit: cvs rdiff -u -r1.24 -r1.25 src/sys/dev/spkr.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/spkr.c diff -u src/sys/dev/spkr.c:1.24 src/sys/dev/spkr.c:1.25 --- src/sys/dev/spkr.c:1.24 Sat Sep 24 23:16:37 2022 +++ src/sys/dev/spkr.c Fri Mar 31 15:00:26 2023 @@ -1,4 +1,4 @@ -/* $NetBSD: spkr.c,v 1.24 2022/09/24 23:16:37 thorpej Exp $ */ +/* $NetBSD: spkr.c,v 1.25 2023/03/31 15:00:26 riastradh Exp $ */ /* * Copyright (c) 1990 Eric S. Raymond (e...@snark.thyrsus.com) @@ -43,7 +43,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: spkr.c,v 1.24 2022/09/24 23:16:37 thorpej Exp $"); +__KERNEL_RCSID(0, "$NetBSD: spkr.c,v 1.25 2023/03/31 15:00:26 riastradh Exp $"); #if defined(_KERNEL_OPT) #include "wsmux.h" @@ -204,6 +204,7 @@ playtone(struct spkr_softc *sc, int note rest(sc, total); return; } + KASSERTMSG(note < __arraycount(pitchtab), "note=%d", note); /* * Rest 1/8 (if NORMAL) or 3/8 (if STACCATO) in tick. @@ -233,6 +234,10 @@ playstring(struct spkr_softc *sc, const #define GETNUM(cp, v) \ for (v = 0; slen > 0 && isdigit((unsigned char)cp[1]); ) { \ + if (v > INT_MAX/10 - (cp[1] - '0')) { \ + v = INT_MAX; \ + continue; \ + } \ v = v * 10 + (*++cp - '0'); \ slen--; \ } @@ -320,6 +325,8 @@ playstring(struct spkr_softc *sc, const slen--; } else { GETNUM(cp, sc->sc_octave); + KASSERTMSG(sc->sc_octave >= 0, "%d", + sc->sc_octave); if (sc->sc_octave >= NOCTAVES) sc->sc_octave = DFLT_OCTAVE; sc->sc_octprefix = true; @@ -340,6 +347,9 @@ playstring(struct spkr_softc *sc, const case 'N': GETNUM(cp, pitch); + KASSERTMSG(pitch >= 0, "pitch=%d", pitch); + if (pitch >= __arraycount(pitchtab)) + break; for (sustain = 0; slen > 0 && cp[1] == '.'; cp++) { slen--; sustain++;