Module Name: src Committed By: skrll Date: Sun Jan 19 16:53:20 UTC 2020
Modified Files: src/sys/arch/arm/broadcom: bcm2835_intr.c Log Message: ci_core_id isn't setup early enough after recent arm_cpu_topology changes, so use ci_mpidr as a stop gap fix for cpuid To generate a diff of this commit: cvs rdiff -u -r1.29 -r1.30 src/sys/arch/arm/broadcom/bcm2835_intr.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/arch/arm/broadcom/bcm2835_intr.c diff -u src/sys/arch/arm/broadcom/bcm2835_intr.c:1.29 src/sys/arch/arm/broadcom/bcm2835_intr.c:1.30 --- src/sys/arch/arm/broadcom/bcm2835_intr.c:1.29 Thu Dec 26 11:09:11 2019 +++ src/sys/arch/arm/broadcom/bcm2835_intr.c Sun Jan 19 16:53:20 2020 @@ -1,4 +1,4 @@ -/* $NetBSD: bcm2835_intr.c,v 1.29 2019/12/26 11:09:11 skrll Exp $ */ +/* $NetBSD: bcm2835_intr.c,v 1.30 2020/01/19 16:53:20 skrll Exp $ */ /*- * Copyright (c) 2012, 2015, 2019 The NetBSD Foundation, Inc. @@ -30,7 +30,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: bcm2835_intr.c,v 1.29 2019/12/26 11:09:11 skrll Exp $"); +__KERNEL_RCSID(0, "$NetBSD: bcm2835_intr.c,v 1.30 2020/01/19 16:53:20 skrll Exp $"); #define _INTR_PRIVATE @@ -337,7 +337,7 @@ bcm2835_irq_handler(void *frame) { struct cpu_info * const ci = curcpu(); const int oldipl = ci->ci_cpl; - const cpuid_t cpuid = ci->ci_core_id; + const cpuid_t cpuid = __SHIFTOUT(ci->ci_mpidr, MPIDR_AFF0); const uint32_t oldipl_mask = __BIT(oldipl); int ipl_mask = 0; @@ -700,7 +700,7 @@ static int bcm2836mp_pic_find_pending_irqs(struct pic_softc *pic) { struct cpu_info * const ci = curcpu(); - const cpuid_t cpuid = ci->ci_core_id; + const cpuid_t cpuid = __SHIFTOUT(ci->ci_mpidr, MPIDR_AFF0); uint32_t lpending; int ipl = 0; @@ -741,7 +741,7 @@ bcm2836mp_pic_source_name(struct pic_sof #if defined(MULTIPROCESSOR) static void bcm2836mp_cpu_init(struct pic_softc *pic, struct cpu_info *ci) { - const cpuid_t cpuid = ci->ci_core_id; + const cpuid_t cpuid = __SHIFTOUT(ci->ci_mpidr, MPIDR_AFF0); KASSERT(cpuid < BCM2836_NCPUS); @@ -768,7 +768,7 @@ int bcm2836mp_ipi_handler(void *priv) { const struct cpu_info *ci = curcpu(); - const cpuid_t cpuid = ci->ci_core_id; + const cpuid_t cpuid = __SHIFTOUT(ci->ci_mpidr, MPIDR_AFF0); uint32_t ipimask, bit; KASSERT(cpuid < BCM2836_NCPUS); @@ -817,7 +817,7 @@ bcm2836mp_ipi_handler(void *priv) static void bcm2836mp_intr_init(void *priv, struct cpu_info *ci) { - const cpuid_t cpuid = ci->ci_core_id; + const cpuid_t cpuid = __SHIFTOUT(ci->ci_mpidr, MPIDR_AFF0); struct pic_softc * const pic = &bcm2836mp_pic[cpuid]; KASSERT(cpuid < BCM2836_NCPUS);