Skip to content

Commit

Permalink
intrng: add calling pic_init_secondary on all registered PICs
Browse files Browse the repository at this point in the history
There is potential for non-root PICs to need per-processor
initialization.  Few root PICs try to propogate the call.  As such add
a pass of calling pic_init_secondary() on all children with a non-root
value.

Differential Revision: https://reviews.freebsd.org/D40474
  • Loading branch information
ehem committed Dec 16, 2024
1 parent 8557078 commit 00577d6
Show file tree
Hide file tree
Showing 6 changed files with 39 additions and 3 deletions.
7 changes: 7 additions & 0 deletions sys/arm/arm/gic.c
Original file line number Diff line number Diff line change
Expand Up @@ -205,6 +205,13 @@ arm_gic_init_secondary(device_t dev, uint32_t rootnum)
struct arm_gic_softc *sc = device_get_softc(dev);
u_int irq, cpu;

if (rootnum >= INTR_ROOT_COUNT) {
/*
* Per-processor setup for devices with PPI interrupts?
*/
return;
}

/* Set the mask so we can find this CPU to send it IPIs */
cpu = PCPU_GET(cpuid);
MPASS(cpu < GIC_MAXCPU);
Expand Down
7 changes: 7 additions & 0 deletions sys/arm/broadcom/bcm2835/bcm2836.c
Original file line number Diff line number Diff line change
Expand Up @@ -543,6 +543,13 @@ bcm_lintc_init_secondary(device_t dev, uint32_t rootnum)
u_int cpu;
struct bcm_lintc_softc *sc;

if (rootnum >= INTR_ROOT_COUNT) {
/*
* Per-processor setup for devices with PPI interrupts?
*/
return;
}

cpu = PCPU_GET(cpuid);
sc = device_get_softc(dev);

Expand Down
7 changes: 7 additions & 0 deletions sys/arm64/arm64/gic_v3.c
Original file line number Diff line number Diff line change
Expand Up @@ -1103,6 +1103,13 @@ gic_v3_init_secondary(device_t dev, uint32_t rootnum)
u_int cpu, irq;
int err, i;

if (rootnum >= INTR_ROOT_COUNT) {
/*
* Per-processor setup for devices with PPI interrupts?
*/
return;
}

sc = device_get_softc(dev);
cpu = PCPU_GET(cpuid);

Expand Down
7 changes: 7 additions & 0 deletions sys/arm64/arm64/gicv3_its.c
Original file line number Diff line number Diff line change
Expand Up @@ -1297,6 +1297,13 @@ gicv3_its_init_secondary(device_t dev, uint32_t rootnum)
{
struct gicv3_its_softc *sc;

if (rootnum >= INTR_ROOT_COUNT) {
/*
* Per-processor setup for devices with PPI interrupts?
*/
return;
}

sc = device_get_softc(dev);

/*
Expand Down
7 changes: 4 additions & 3 deletions sys/kern/subr_intr.c
Original file line number Diff line number Diff line change
Expand Up @@ -1570,19 +1570,20 @@ dosoftints(void)
void
intr_pic_init_secondary(void)
{
struct intr_pic *pic;
device_t dev;
uint32_t rootnum;

/*
* QQQ: Only root PICs are aware of other CPUs ???
*/
//mtx_lock(&isrc_table_lock);
for (rootnum = 0; rootnum < INTR_ROOT_COUNT; rootnum++) {
dev = intr_irq_roots[rootnum].dev;
if (dev != NULL) {
PIC_INIT_SECONDARY(dev, rootnum);
}
}

SLIST_FOREACH(pic, &pic_list, pic_next)
PIC_INIT_SECONDARY(pic->pic_dev, INTR_ROOT_COUNT);
//mtx_unlock(&isrc_table_lock);
}
#endif
Expand Down
7 changes: 7 additions & 0 deletions sys/riscv/riscv/intc.c
Original file line number Diff line number Diff line change
Expand Up @@ -247,6 +247,13 @@ intc_init_secondary(device_t dev, uint32_t rootnum)
struct intr_irqsrc *isrc;
u_int cpu, irq;

if (rootnum >= INTR_ROOT_COUNT) {
/*
* Per-processor setup for devices with PPI interrupts?
*/
return;
}

sc = device_get_softc(dev);
cpu = PCPU_GET(cpuid);

Check warning on line 259 in sys/riscv/riscv/intc.c

View workflow job for this annotation

GitHub Actions / Style Checker

Missing Signed-off-by: line
Expand Down

0 comments on commit 00577d6

Please sign in to comment.