diff options
author | Visa Hankala <visa@cvs.openbsd.org> | 2015-07-27 16:33:41 +0000 |
---|---|---|
committer | Visa Hankala <visa@cvs.openbsd.org> | 2015-07-27 16:33:41 +0000 |
commit | 144c2e2dd6601d1b38900f8eb255657ad31f79db (patch) | |
tree | 35344a5353308486cf20bfbd4a8f087b838e0af4 | |
parent | e16e211b7396e88f99f5da102cd1bd5dbcdd5d90 (diff) |
Allow coalescing of IPI requests on mips64, to make IPI sending
non-blocking. This improves performance on systems that have more than
a few cores and where there is a heavy IPI load. Currently the only
place where coalescing must not happen is rendezvous processing, but
there invocations are serialized by the rendezvous mutex.
ok miod@
-rw-r--r-- | sys/arch/mips64/mips64/ipifuncs.c | 11 |
1 files changed, 4 insertions, 7 deletions
diff --git a/sys/arch/mips64/mips64/ipifuncs.c b/sys/arch/mips64/mips64/ipifuncs.c index d3e9d789f77..ddae5f3adbc 100644 --- a/sys/arch/mips64/mips64/ipifuncs.c +++ b/sys/arch/mips64/mips64/ipifuncs.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ipifuncs.c,v 1.10 2015/04/20 19:08:52 miod Exp $ */ +/* $OpenBSD: ipifuncs.c,v 1.11 2015/07/27 16:33:40 visa Exp $ */ /* $NetBSD: ipifuncs.c,v 1.40 2008/04/28 20:23:10 martin Exp $ */ /*- @@ -98,15 +98,12 @@ mips64_ipi_intr(void *arg) KASSERT (cpuid == cpu_number()); - /* figure out which ipi are pending */ - pending_ipis = ipi_mailbox[cpuid]; /* clear ipi interrupt */ hw_ipi_intr_clear(cpuid); + /* get and clear pending ipis */ + pending_ipis = atomic_swap_uint(&ipi_mailbox[cpuid], 0); if (pending_ipis > 0) { - /* clear pending ipi, since we're about to handle them */ - atomic_clearbits_int(&ipi_mailbox[cpuid], pending_ipis); - for (bit = 0; bit < MIPS64_NIPIS; bit++) if (pending_ipis & (1UL << bit)) (*ipifuncs[bit])(); @@ -128,7 +125,7 @@ mips64_send_ipi(unsigned int cpuid, unsigned int ipimask) panic("mips_send_ipi: CPU %ld not running", cpuid); #endif - atomic_wait_and_setbits_int(&ipi_mailbox[cpuid], ipimask); + atomic_setbits_int(&ipi_mailbox[cpuid], ipimask); hw_ipi_intr_set(cpuid); } |