diff options
author | Ted Unangst <tedu@cvs.openbsd.org> | 2014-12-15 20:38:23 +0000 |
---|---|---|
committer | Ted Unangst <tedu@cvs.openbsd.org> | 2014-12-15 20:38:23 +0000 |
commit | b1fc9943e6b8f60f8ffca5341364a8e7c24657da (patch) | |
tree | f42da018768cd3997adad78cefd6561406878304 /sys/uvm/uvm_glue.c | |
parent | 2bda58c0e564705751c7e7eada8961850d84d632 (diff) |
don't drop the kernel lock everytime. on a busy system, this results in
the reaper spending more than half its time in uvm_pause. we want the
system to be interactive, but we want throughput too. this seems like a
decent balance.
Diffstat (limited to 'sys/uvm/uvm_glue.c')
-rw-r--r-- | sys/uvm/uvm_glue.c | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/sys/uvm/uvm_glue.c b/sys/uvm/uvm_glue.c index 7a9618aa496..9eff05e49e9 100644 --- a/sys/uvm/uvm_glue.c +++ b/sys/uvm/uvm_glue.c @@ -1,4 +1,4 @@ -/* $OpenBSD: uvm_glue.c,v 1.68 2014/12/05 04:12:48 uebayasi Exp $ */ +/* $OpenBSD: uvm_glue.c,v 1.69 2014/12/15 20:38:22 tedu Exp $ */ /* $NetBSD: uvm_glue.c,v 1.44 2001/02/06 19:54:44 eeh Exp $ */ /* @@ -467,8 +467,12 @@ uvm_atopg(vaddr_t kva) void uvm_pause(void) { - KERNEL_UNLOCK(); - KERNEL_LOCK(); + static unsigned int toggle; + if (toggle++ > 128) { + toggle = 0; + KERNEL_UNLOCK(); + KERNEL_LOCK(); + } if (curcpu()->ci_schedstate.spc_schedflags & SPCF_SHOULDYIELD) preempt(NULL); } |