summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVisa Hankala <visa@cvs.openbsd.org>2015-07-27 16:33:41 +0000
committerVisa Hankala <visa@cvs.openbsd.org>2015-07-27 16:33:41 +0000
commit144c2e2dd6601d1b38900f8eb255657ad31f79db (patch)
tree35344a5353308486cf20bfbd4a8f087b838e0af4
parente16e211b7396e88f99f5da102cd1bd5dbcdd5d90 (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.c11
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);
}