summaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authormatthieu castet <castet.matthieu@free.fr>2009-06-30 23:04:55 +0200
committerRalf Baechle <ralf@linux-mips.org>2009-07-03 16:45:27 +0200
commitea4bbfd0048c53c24f72ef668b39f1247bc243c0 (patch)
treedf871a70349f18842c0a38b51cad2dd3ee65b07a /arch
parentMIPS: CMP: Update sync-r4k for current kernel (diff)
downloadlinux-ea4bbfd0048c53c24f72ef668b39f1247bc243c0.tar.xz
linux-ea4bbfd0048c53c24f72ef668b39f1247bc243c0.zip
MIPS: BC47xx: Fix SSB irq setup
The current ssb irq setup in ssb_mipscore_init has the problem that it configures some device on some irq without checking that the irq is not taken by an other device. For example in my case PCI host is on irq 0 and IPSEC on irq 3. The current code: - store in dev->irq that IPSEC irq is 3 + 2 - do a set_irq 0->3 on PCI host But now IPSEC irq is not routed anymore to the mips code and dev->irq is wrong. This causes a problem described in [1]. This patch tries to solve the problem by making set_irq configure the device we want to take the irq on the shared irq0. The previous example becomes: - store in dev->irq that IPSEC irq is 3 + 2 - do a set_irq 0->3 on PCI host: - irq 3 is already taken by IPSEC. do a set_irq 3->0 on IPSEC I also added some code to print the irq configuration after irq setup to allow easier debugging. And I add extra checking in ssb_mips_irq to report device without irq or device with not routed irq. [1] http://www.danm.de/files/src/bcm5365p/REPORTED_DEVICES Signed-off-by: Matthieu CASTET <castet.matthieu@free.fr> Acked-by : Michael Buesch <mb@bu3sch.de> Tested-by: Florian Fainelli <florian@openwrt.org> Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
Diffstat (limited to 'arch')
0 files changed, 0 insertions, 0 deletions