Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/mips/cavium Simplify IPI handling even more for now...
details: https://anonhg.NetBSD.org/src/rev/863fc479f5e7
branches: trunk
changeset: 974011:863fc479f5e7
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Mon Jul 20 14:05:51 2020 +0000
description:
Simplify IPI handling even more for now and run everything at IPL_HIGH.
diffstat:
sys/arch/mips/cavium/octeon_intr.c | 52 ++++++++-----------------------------
1 files changed, 11 insertions(+), 41 deletions(-)
diffs (114 lines):
diff -r 2bb658040f67 -r 863fc479f5e7 sys/arch/mips/cavium/octeon_intr.c
--- a/sys/arch/mips/cavium/octeon_intr.c Mon Jul 20 13:59:57 2020 +0000
+++ b/sys/arch/mips/cavium/octeon_intr.c Mon Jul 20 14:05:51 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: octeon_intr.c,v 1.19 2020/07/20 13:30:41 jmcneill Exp $ */
+/* $NetBSD: octeon_intr.c,v 1.20 2020/07/20 14:05:51 jmcneill Exp $ */
/*
* Copyright 2001, 2002 Wasabi Systems, Inc.
* All rights reserved.
@@ -44,7 +44,7 @@
#define __INTR_PRIVATE
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: octeon_intr.c,v 1.19 2020/07/20 13:30:41 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: octeon_intr.c,v 1.20 2020/07/20 14:05:51 jmcneill Exp $");
#include <sys/param.h>
#include <sys/cpu.h>
@@ -158,42 +158,19 @@
static int octeon_send_ipi(struct cpu_info *, int);
static int octeon_ipi_intr(void *);
-struct octeon_intrhand ipi_intrhands[2] = {
+struct octeon_intrhand ipi_intrhands[1] = {
[0] = {
.ih_func = octeon_ipi_intr,
.ih_arg = (void *)(uintptr_t)__BITS(15,0),
.ih_irq = CIU_INT_MBOX_15_0,
- .ih_ipl = IPL_SCHED,
- },
- [1] = {
- .ih_func = octeon_ipi_intr,
- .ih_arg = (void *)(uintptr_t)__BITS(31,16),
- .ih_irq = CIU_INT_MBOX_31_16,
.ih_ipl = IPL_HIGH,
},
};
-
-#define OCTEON_IPI_SCHED(n) __BIT((n) + 0)
-#define OCTEON_IPI_HIGH(n) __BIT((n) + 16)
-
-static uint32_t octeon_ipi_mbox_mask[NIPIS] = {
- [IPI_NOP] = OCTEON_IPI_SCHED(IPI_NOP),
- [IPI_AST] = OCTEON_IPI_SCHED(IPI_AST),
- [IPI_SHOOTDOWN] = OCTEON_IPI_SCHED(IPI_SHOOTDOWN),
- [IPI_SYNCICACHE] = OCTEON_IPI_SCHED(IPI_SYNCICACHE),
- [IPI_KPREEMPT] = OCTEON_IPI_SCHED(IPI_KPREEMPT),
- [IPI_SUSPEND] = OCTEON_IPI_HIGH(IPI_SUSPEND),
- [IPI_HALT] = OCTEON_IPI_HIGH(IPI_HALT),
- [IPI_XCALL] = OCTEON_IPI_HIGH(IPI_XCALL),
- [IPI_GENERIC] = OCTEON_IPI_HIGH(IPI_GENERIC),
- [IPI_WDOG] = OCTEON_IPI_HIGH(IPI_WDOG),
-};
#endif
struct octeon_intrhand *octciu_intrs[NIRQS] = {
#ifdef MULTIPROCESSOR
[CIU_INT_MBOX_15_0] = &ipi_intrhands[0],
- [CIU_INT_MBOX_31_16] = &ipi_intrhands[1],
#endif
};
@@ -270,8 +247,7 @@
#ifdef MULTIPROCESSOR
// Enable the IPIs
- cpu->cpu_ip3_enable[0] |= __BIT(CIU_INT_MBOX_15_0);
- cpu->cpu_ip4_enable[0] |= __BIT(CIU_INT_MBOX_31_16);
+ cpu->cpu_ip4_enable[0] |= __BIT(CIU_INT_MBOX_15_0);
#endif
if (ci->ci_dev) {
@@ -516,21 +492,16 @@
{
struct cpu_info * const ci = curcpu();
struct cpu_softc * const cpu = ci->ci_softc;
- uint32_t mbox_mask = (uintptr_t) arg;
- uint32_t ipi_mask;
+ uint32_t ipi_mask = (uintptr_t) arg;
- KASSERTMSG((mbox_mask & __BITS(31,16)) == 0 || ci->ci_cpl >= IPL_SCHED,
- "mbox_mask %#"PRIx32" cpl %d", mbox_mask, ci->ci_cpl);
+ KASSERTMSG(ci->ci_cpl == IPL_HIGH,
+ "ipi_mask %#"PRIx32" cpl %d", ipi_mask, ci->ci_cpl);
- mbox_mask &= mips3_ld(cpu->cpu_mbox_set);
- if (mbox_mask == 0)
+ ipi_mask &= mips3_ld(cpu->cpu_mbox_set);
+ if (ipi_mask == 0)
return 0;
- mips3_sd(cpu->cpu_mbox_clr, mbox_mask);
-
- ipi_mask = mbox_mask;
- if (ci->ci_cpl >= IPL_SCHED)
- ipi_mask >>= 16;
+ mips3_sd(cpu->cpu_mbox_clr, ipi_mask);
KASSERT(ipi_mask < __BIT(NIPIS));
@@ -578,12 +549,11 @@
return -1;
struct cpu_softc * const cpu = ci->ci_softc;
- const uint32_t mbox_mask = octeon_ipi_mbox_mask[req];
const uint32_t ipi_mask = __BIT(req);
atomic_or_64(&ci->ci_request_ipis, ipi_mask);
- mips3_sd(cpu->cpu_mbox_set, mbox_mask);
+ mips3_sd(cpu->cpu_mbox_set, ipi_mask);
return 0;
}
Home |
Main Index |
Thread Index |
Old Index