Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/pci Fix softint leak in ixl(4) when detaching
details: https://anonhg.NetBSD.org/src/rev/4125fba6c169
branches: trunk
changeset: 967730:4125fba6c169
user: yamaguchi <yamaguchi%NetBSD.org@localhost>
date: Fri Dec 20 01:18:53 2019 +0000
description:
Fix softint leak in ixl(4) when detaching
diffstat:
sys/dev/pci/if_ixl.c | 7 ++++++-
1 files changed, 6 insertions(+), 1 deletions(-)
diffs (35 lines):
diff -r b5f86d52c5b6 -r 4125fba6c169 sys/dev/pci/if_ixl.c
--- a/sys/dev/pci/if_ixl.c Fri Dec 20 01:12:51 2019 +0000
+++ b/sys/dev/pci/if_ixl.c Fri Dec 20 01:18:53 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_ixl.c,v 1.5 2019/12/20 01:12:51 yamaguchi Exp $ */
+/* $NetBSD: if_ixl.c,v 1.6 2019/12/20 01:18:53 yamaguchi Exp $ */
/*
* Copyright (c) 2013-2015, Intel Corporation
@@ -2001,6 +2001,8 @@
qp->qp_si = softint_establish(SOFTINT_NET | SOFTINT_MPSAFE,
ixl_handle_queue, qp);
+ if (qp->qp_si == NULL)
+ goto free;
qp->qp_txr = ixl_txr_alloc(sc, i);
if (qp->qp_txr == NULL)
@@ -2026,6 +2028,8 @@
ixl_txr_free(sc, qp->qp_txr);
if (qp->qp_rxr != NULL)
ixl_rxr_free(sc, qp->qp_rxr);
+ if (qp->qp_si != NULL)
+ softint_disestablish(qp->qp_si);
}
sz = sizeof(sc->sc_qps[0]) * sc->sc_nqueue_pairs_max;
@@ -2047,6 +2051,7 @@
qp = &sc->sc_qps[i];
ixl_txr_free(sc, qp->qp_txr);
ixl_rxr_free(sc, qp->qp_rxr);
+ softint_disestablish(qp->qp_si);
}
sz = sizeof(sc->sc_qps[0]) * sc->sc_nqueue_pairs_max;
Home |
Main Index |
Thread Index |
Old Index