From: Michael Buesch Date: Fri, 4 Jul 2008 21:44:37 +0000 (+0200) Subject: ssb-pcicore: Fix IRQ-vector init on embedded devices X-Git-Tag: v3.12-rc1~20134^2~18 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=9e095a687b3561972272063260e14ab1bc21de08;p=kernel%2Fkernel-generic.git ssb-pcicore: Fix IRQ-vector init on embedded devices On embedded devices we must not route the interrupts through the PCI core, if our host-bus is not PCI. Reported-by: Steve Brown Signed-off-by: Michael Buesch Signed-off-by: John W. Linville --- diff --git a/drivers/ssb/driver_pcicore.c b/drivers/ssb/driver_pcicore.c index d28c538..538c570 100644 --- a/drivers/ssb/driver_pcicore.c +++ b/drivers/ssb/driver_pcicore.c @@ -537,6 +537,13 @@ int ssb_pcicore_dev_irqvecs_enable(struct ssb_pcicore *pc, int err = 0; u32 tmp; + if (dev->bus->bustype != SSB_BUSTYPE_PCI) { + /* This SSB device is not on a PCI host-bus. So the IRQs are + * not routed through the PCI core. + * So we must not enable routing through the PCI core. */ + goto out; + } + if (!pdev) goto out; bus = pdev->bus;