Module Name: src Committed By: reinoud Date: Tue Jan 26 16:40:16 UTC 2021
Modified Files: src/sys/dev/pci: virtio_pci.c Log Message: Fix indexing bug in clean up code on error in virtio PCI v1.0 attach code. Thanks go to Rin Okuyama for spotting it. To generate a diff of this commit: cvs rdiff -u -r1.25 -r1.26 src/sys/dev/pci/virtio_pci.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/pci/virtio_pci.c diff -u src/sys/dev/pci/virtio_pci.c:1.25 src/sys/dev/pci/virtio_pci.c:1.26 --- src/sys/dev/pci/virtio_pci.c:1.25 Sun Jan 24 15:59:35 2021 +++ src/sys/dev/pci/virtio_pci.c Tue Jan 26 16:40:16 2021 @@ -1,4 +1,4 @@ -/* $NetBSD: virtio_pci.c,v 1.25 2021/01/24 15:59:35 reinoud Exp $ */ +/* $NetBSD: virtio_pci.c,v 1.26 2021/01/26 16:40:16 reinoud Exp $ */ /* * Copyright (c) 2020 The NetBSD Foundation, Inc. @@ -28,7 +28,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: virtio_pci.c,v 1.25 2021/01/24 15:59:35 reinoud Exp $"); +__KERNEL_RCSID(0, "$NetBSD: virtio_pci.c,v 1.26 2021/01/26 16:40:16 reinoud Exp $"); #include <sys/param.h> #include <sys/systm.h> @@ -444,7 +444,7 @@ virtio_pci_attach_10(device_t self, void bus_size_t bars[NMAPREG] = { 0 }; int bars_idx[NMAPREG] = { 0 }; struct virtio_pci_cap *caps[] = { &common, &isr, &device, ¬ify.cap }; - int i, j = 0, ret = 0; + int i, j, ret = 0; if (virtio_pci_find_cap(psc, VIRTIO_PCI_CAP_COMMON_CFG, &common, sizeof(common))) @@ -471,7 +471,7 @@ virtio_pci_attach_10(device_t self, void bars[bar] = len; } - for (i = 0; i < __arraycount(bars); i++) { + for (i = j = 0; i < __arraycount(bars); i++) { int reg; pcireg_t type; if (bars[i] == 0) @@ -551,10 +551,10 @@ virtio_pci_attach_10(device_t self, void err: /* undo our pci_mapreg_map()s */ for (i = 0; i < __arraycount(bars); i++) { - if (bars[i] == 0) + if (psc->sc_bars_iosize[i] == 0) continue; - bus_space_unmap(psc->sc_bars_iot[j], psc->sc_bars_ioh[j], - psc->sc_bars_iosize[j]); + bus_space_unmap(psc->sc_bars_iot[i], psc->sc_bars_ioh[i], + psc->sc_bars_iosize[i]); } return ret; }