MFC r208835:
Make sure that interrupt sense settings set after interrupts are enabled are respected. This fixes loading the Apple onboard audio driver (snd_ai2s) as a module after boot, which would previously cause a panic. PR: powerpc/146888 Approved by: re (kensmith)
This commit is contained in:
parent
f7f0093e4d
commit
10119aa3bb
@ -164,6 +164,7 @@ intr_lookup(u_int irq)
|
||||
i->trig = INTR_TRIGGER_CONFORM;
|
||||
i->pol = INTR_POLARITY_CONFORM;
|
||||
i->irq = irq;
|
||||
i->pic = NULL;
|
||||
i->vector = -1;
|
||||
|
||||
mtx_lock(&intr_table_lock);
|
||||
@ -325,6 +326,11 @@ powerpc_setup_intr(const char *name, u_int irq, driver_filter_t filter,
|
||||
|
||||
if (!cold) {
|
||||
error = powerpc_map_irq(i);
|
||||
|
||||
if (!error && (i->trig != INTR_TRIGGER_CONFORM ||
|
||||
i->pol != INTR_POLARITY_CONFORM))
|
||||
PIC_CONFIG(i->pic, i->intline, i->trig, i->pol);
|
||||
|
||||
if (!error && enable)
|
||||
PIC_ENABLE(i->pic, i->intline, i->vector);
|
||||
}
|
||||
@ -350,7 +356,7 @@ powerpc_config_intr(int irq, enum intr_trigger trig, enum intr_polarity pol)
|
||||
i->trig = trig;
|
||||
i->pol = pol;
|
||||
|
||||
if (!cold)
|
||||
if (!cold && i->pic != NULL)
|
||||
PIC_CONFIG(i->pic, i->intline, trig, pol);
|
||||
|
||||
return (0);
|
||||
|
Loading…
x
Reference in New Issue
Block a user