aboutsummaryrefslogtreecommitdiff
path: root/sys/vm
diff options
context:
space:
mode:
authorAlexander Motin <mav@FreeBSD.org>2015-04-09 13:09:05 +0000
committerAlexander Motin <mav@FreeBSD.org>2015-04-09 13:09:05 +0000
commit0ada3afc253298c6dd80828b14dba1573e608941 (patch)
tree92cfec1ca24ab35cbb70a7a57690f18851f4d602 /sys/vm
parentefb19cf6dbc7fe119072beac8fd27a579161efb3 (diff)
downloadsrc-0ada3afc253298c6dd80828b14dba1573e608941.tar.gz
src-0ada3afc253298c6dd80828b14dba1573e608941.zip
Remove sleeps from geom_up thread on device destruction.
MFC after: 3 days.
Notes
Notes: svn path=/head/; revision=281310
Diffstat (limited to 'sys/vm')
-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 435f412ef809..55e02c456ffd 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