summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
authorMike Belopuhov <mikeb@cvs.openbsd.org>2019-12-13 02:16:54 +0000
committerMike Belopuhov <mikeb@cvs.openbsd.org>2019-12-13 02:16:54 +0000
commit1fe1e9031c37071bea5181de67f15c2671810f3a (patch)
treeec3da59d533689d8fae4a5883960f6620f38837d /sys/dev
parent5ef3b9457b97c839edc9a7dd4578521d3de10357 (diff)
Always release interrupt source when unmasking the interrupt
xen_intr_unmask_release was not decrementing the reference counter on the interrupt source structure when bailing out early which led to the refcnt overflow. From niklas, ok mlarkin
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/pv/xen.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/sys/dev/pv/xen.c b/sys/dev/pv/xen.c
index a2a63537378..1257b2a9a9e 100644
--- a/sys/dev/pv/xen.c
+++ b/sys/dev/pv/xen.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: xen.c,v 1.93 2018/01/21 18:54:46 mikeb Exp $ */
+/* $OpenBSD: xen.c,v 1.94 2019/12/13 02:16:53 mikeb Exp $ */
/*
* Copyright (c) 2015, 2016, 2017 Mike Belopuhov
@@ -650,8 +650,10 @@ xen_intr_unmask_release(struct xen_softc *sc, struct xen_intsrc *xi)
struct evtchn_unmask eu;
xi->xi_masked = 0;
- if (!test_bit(xi->xi_port, &sc->sc_ipg->evtchn_mask[0]))
+ if (!test_bit(xi->xi_port, &sc->sc_ipg->evtchn_mask[0])) {
+ xen_intsrc_release(sc, xi);
return (0);
+ }
eu.port = xi->xi_port;
xen_intsrc_release(sc, xi);
return (xen_evtchn_hypercall(sc, EVTCHNOP_unmask, &eu, sizeof(eu)));