summaryrefslogtreecommitdiffstats
path: root/sys/vm/swap_pager.c
diff options
context:
space:
mode:
authormav <mav@FreeBSD.org>2015-04-09 13:09:05 +0000
committermav <mav@FreeBSD.org>2015-04-09 13:09:05 +0000
commit2e38078077c5e0f74c769cb66f0ecaa931f8186e (patch)
tree92cfec1ca24ab35cbb70a7a57690f18851f4d602 /sys/vm/swap_pager.c
parent1af0fcc87ba7c58849e9f6ad9e0d7a8f8ace2e4d (diff)
downloadFreeBSD-src-2e38078077c5e0f74c769cb66f0ecaa931f8186e.zip
FreeBSD-src-2e38078077c5e0f74c769cb66f0ecaa931f8186e.tar.gz
Remove sleeps from geom_up thread on device destruction.
MFC after: 3 days.
Diffstat (limited to 'sys/vm/swap_pager.c')
-rw-r--r--sys/vm/swap_pager.c12
1 files changed, 5 insertions, 7 deletions
diff --git a/sys/vm/swap_pager.c b/sys/vm/swap_pager.c
index 435f412..55e02c4 100644
--- a/sys/vm/swap_pager.c
+++ b/sys/vm/swap_pager.c
@@ -2579,7 +2579,6 @@ swapgeom_done(struct bio *bp2)
struct swdevt *sp;
struct buf *bp;
struct g_consumer *cp;
- int destroy;
bp = bp2->bio_caller2;
cp = bp2->bio_from;
@@ -2590,15 +2589,14 @@ swapgeom_done(struct bio *bp2)
bp->b_error = bp2->bio_error;
bufdone(bp);
mtx_lock(&sw_dev_mtx);
- destroy = ((--cp->index) == 0 && cp->private);
- if (destroy) {
- sp = bp2->bio_caller1;
- sp->sw_id = NULL;
+ if ((--cp->index) == 0 && cp->private) {
+ if (g_post_event(swapgeom_close_ev, cp, M_NOWAIT, NULL) == 0) {
+ sp = bp2->bio_caller1;
+ sp->sw_id = NULL;
+ }
}
mtx_unlock(&sw_dev_mtx);
g_destroy_bio(bp2);
- if (destroy)
- g_waitfor_event(swapgeom_close_ev, cp, M_WAITOK, NULL);
}
static void
OpenPOWER on IntegriCloud