Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev Remove the virtio child driver finalisation check KA...
details: https://anonhg.NetBSD.org/src/rev/3e819fbc9777
branches: trunk
changeset: 1018065:3e819fbc9777
user: reinoud <reinoud%NetBSD.org@localhost>
date: Wed Jan 20 21:59:48 2021 +0000
description:
Remove the virtio child driver finalisation check KASSERT that, while it
should never trigger, a possible bug in a child driver shouldn't have to panic
the kernel. Instead report the internal error.
diffstat:
sys/dev/acpi/virtio_acpi.c | 10 ++--------
sys/dev/fdt/virtio_mmio_fdt.c | 10 ++--------
sys/dev/pci/virtio.c | 13 +++++++++++--
sys/dev/pci/virtio_pci.c | 10 ++--------
sys/dev/pci/virtiovar.h | 3 ++-
5 files changed, 19 insertions(+), 27 deletions(-)
diffs (151 lines):
diff -r a4c9d12b4ef9 -r 3e819fbc9777 sys/dev/acpi/virtio_acpi.c
--- a/sys/dev/acpi/virtio_acpi.c Wed Jan 20 21:39:09 2021 +0000
+++ b/sys/dev/acpi/virtio_acpi.c Wed Jan 20 21:59:48 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: virtio_acpi.c,v 1.5 2021/01/20 19:46:48 reinoud Exp $ */
+/* $NetBSD: virtio_acpi.c,v 1.6 2021/01/20 21:59:48 reinoud Exp $ */
/*-
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: virtio_acpi.c,v 1.5 2021/01/20 19:46:48 reinoud Exp $");
+__KERNEL_RCSID(0, "$NetBSD: virtio_acpi.c,v 1.6 2021/01/20 21:59:48 reinoud Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -168,12 +168,6 @@
if (virtio_attach_failed(vsc))
return 0;
- /*
- * Make sure child drivers initialize interrupts via call
- * to virtio_child_attach_finish().
- */
- KASSERT(msc->sc_ih != NULL);
-
return 0;
}
diff -r a4c9d12b4ef9 -r 3e819fbc9777 sys/dev/fdt/virtio_mmio_fdt.c
--- a/sys/dev/fdt/virtio_mmio_fdt.c Wed Jan 20 21:39:09 2021 +0000
+++ b/sys/dev/fdt/virtio_mmio_fdt.c Wed Jan 20 21:59:48 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: virtio_mmio_fdt.c,v 1.5 2021/01/20 19:46:48 reinoud Exp $ */
+/* $NetBSD: virtio_mmio_fdt.c,v 1.6 2021/01/20 21:59:48 reinoud Exp $ */
/*
* Copyright (c) 2018 Jonathan A. Kollasch
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: virtio_mmio_fdt.c,v 1.5 2021/01/20 19:46:48 reinoud Exp $");
+__KERNEL_RCSID(0, "$NetBSD: virtio_mmio_fdt.c,v 1.6 2021/01/20 21:59:48 reinoud Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -128,12 +128,6 @@
if (virtio_attach_failed(vsc))
return 0;
- /*
- * Make sure child drivers initialize interrupts via call
- * to virtio_child_attach_finish().
- */
- KASSERT(msc->sc_ih != NULL);
-
return 0;
}
diff -r a4c9d12b4ef9 -r 3e819fbc9777 sys/dev/pci/virtio.c
--- a/sys/dev/pci/virtio.c Wed Jan 20 21:39:09 2021 +0000
+++ b/sys/dev/pci/virtio.c Wed Jan 20 21:59:48 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: virtio.c,v 1.43 2021/01/20 19:46:48 reinoud Exp $ */
+/* $NetBSD: virtio.c,v 1.44 2021/01/20 21:59:48 reinoud Exp $ */
/*
* Copyright (c) 2020 The NetBSD Foundation, Inc.
@@ -28,7 +28,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: virtio.c,v 1.43 2021/01/20 19:46:48 reinoud Exp $");
+__KERNEL_RCSID(0, "$NetBSD: virtio.c,v 1.44 2021/01/20 21:59:48 reinoud Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -1084,6 +1084,7 @@
{
int r;
+ sc->sc_finished_called = true;
r = sc->sc_ops->setup_interrupts(sc);
if (r != 0) {
aprint_error_dev(sc->sc_dev, "failed to setup interrupts\n");
@@ -1187,6 +1188,14 @@
aprint_error_dev(self, "virtio configuration failed\n");
return 1;
}
+
+ /* sanity check */
+ if (!sc->sc_finished_called) {
+ aprint_error_dev(self, "virtio internal error, child driver "
+ "signaled OK but didn't initialize interrupts\n");
+ return 1;
+ }
+
return 0;
}
diff -r a4c9d12b4ef9 -r 3e819fbc9777 sys/dev/pci/virtio_pci.c
--- a/sys/dev/pci/virtio_pci.c Wed Jan 20 21:39:09 2021 +0000
+++ b/sys/dev/pci/virtio_pci.c Wed Jan 20 21:59:48 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: virtio_pci.c,v 1.15 2021/01/20 19:46:48 reinoud Exp $ */
+/* $NetBSD: virtio_pci.c,v 1.16 2021/01/20 21:59:48 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.15 2021/01/20 19:46:48 reinoud Exp $");
+__KERNEL_RCSID(0, "$NetBSD: virtio_pci.c,v 1.16 2021/01/20 21:59:48 reinoud Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -351,12 +351,6 @@
if (virtio_attach_failed(sc))
return 0;
- /*
- * Make sure child drivers initialize interrupts via call
- * to virtio_child_attach_finish().
- */
- KASSERT(psc->sc_ihs_num != 0);
-
return 0;
}
diff -r a4c9d12b4ef9 -r 3e819fbc9777 sys/dev/pci/virtiovar.h
--- a/sys/dev/pci/virtiovar.h Wed Jan 20 21:39:09 2021 +0000
+++ b/sys/dev/pci/virtiovar.h Wed Jan 20 21:59:48 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: virtiovar.h,v 1.17 2021/01/20 19:46:48 reinoud Exp $ */
+/* $NetBSD: virtiovar.h,v 1.18 2021/01/20 21:59:48 reinoud Exp $ */
/*
* Copyright (c) 2010 Minoura Makoto.
@@ -171,6 +171,7 @@
uint64_t sc_active_features;
bool sc_indirect;
bool sc_version_1;
+ bool sc_finished_called;
int sc_nvqs; /* set by child */
struct virtqueue *sc_vqs; /* set by child */
Home |
Main Index |
Thread Index |
Old Index