Module Name: src Committed By: riastradh Date: Mon Jun 27 18:56:56 UTC 2022
Modified Files: src/sys/dev/usb: umidi.c Log Message: umidi(4): Fix fencepost in error branch. Reported-by: syzbot+0bbf3d81c15fd1354...@syzkaller.appspotmail.com To generate a diff of this commit: cvs rdiff -u -r1.87 -r1.88 src/sys/dev/usb/umidi.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/usb/umidi.c diff -u src/sys/dev/usb/umidi.c:1.87 src/sys/dev/usb/umidi.c:1.88 --- src/sys/dev/usb/umidi.c:1.87 Sun Apr 17 13:15:15 2022 +++ src/sys/dev/usb/umidi.c Mon Jun 27 18:56:56 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: umidi.c,v 1.87 2022/04/17 13:15:15 riastradh Exp $ */ +/* $NetBSD: umidi.c,v 1.88 2022/06/27 18:56:56 riastradh Exp $ */ /* * Copyright (c) 2001, 2012, 2014 The NetBSD Foundation, Inc. @@ -32,7 +32,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: umidi.c,v 1.87 2022/04/17 13:15:15 riastradh Exp $"); +__KERNEL_RCSID(0, "$NetBSD: umidi.c,v 1.88 2022/06/27 18:56:56 riastradh Exp $"); #ifdef _KERNEL_OPT #include "opt_usb.h" @@ -739,7 +739,7 @@ alloc_all_endpoints(struct umidi_softc * ep = sc->sc_endpoints; for (i = sc->sc_out_num_endpoints+sc->sc_in_num_endpoints; i > 0; i--) { - err = alloc_pipe(ep++); + err = alloc_pipe(ep); if (err != USBD_NORMAL_COMPLETION) { for (; ep != sc->sc_endpoints; ep--) free_pipe(ep-1); @@ -747,6 +747,7 @@ alloc_all_endpoints(struct umidi_softc * sc->sc_endpoints = sc->sc_out_ep = sc->sc_in_ep = NULL; break; } + ep++; } return err; }