powerpc/85xx: Fix oops during MSI driver probe on MPC85xxMDS boards

Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
From: Linux Kernel Mailing List
Date: Thursday, February 18, 2010 - 9:59 am

Gitweb:     http://git.kernel.org/linus/fa644298eb24ab05b32acf6cc0f2265b833280e1
Commit:     fa644298eb24ab05b32acf6cc0f2265b833280e1
Parent:     724e6d3fe8003c3f60bf404bf22e4e331327c596
Author:     Anton Vorontsov <avorontsov@ru.mvista.com>
AuthorDate: Tue Dec 15 12:58:09 2009 +0000
Committer:  Kumar Gala <galak@kernel.crashing.org>
CommitDate: Sat Feb 13 14:23:22 2010 -0600

    powerpc/85xx: Fix oops during MSI driver probe on MPC85xxMDS boards
    
    MPC85xx chips report the wrong value in feature reporting register,
    and that causes the following oops:
    
     Unable to handle kernel paging request for data at address 0x00000c00
     Faulting instruction address: 0xc0019294
     Oops: Kernel access of bad area, sig: 11 [#1]
     MPC8569 MDS
     Modules linked in:
     [...]
     NIP [c0019294] mpic_set_irq_type+0x2f0/0x368
     LR [c0019124] mpic_set_irq_type+0x180/0x368
     Call Trace:
     [ef851d60] [c0019124] mpic_set_irq_type+0x180/0x368 (unreliable)
     [ef851d90] [c007958c] __irq_set_trigger+0x44/0xd4
     [ef851db0] [c007b550] set_irq_type+0x40/0x7c
     [ef851dc0] [c0004a60] irq_create_of_mapping+0xb4/0x114
     [ef851df0] [c0004af0] irq_of_parse_and_map+0x30/0x40
     [ef851e20] [c0405678] fsl_of_msi_probe+0x1a0/0x328
     [ef851e60] [c02e6438] of_platform_device_probe+0x5c/0x84
     [...]
    
    This is because mpic_alloc() assigns wrong values to
    mpic->isu_{size,shift,mask}, and things eventually break when
    _mpic_irq_read() is trying to use them.
    
    This patch fixes the issue by enabling MPIC_BROKEN_FRR_NIRQS quirk.
    
    Signed-off-by: Anton Vorontsov <avorontsov@ru.mvista.com>
    Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
---
 arch/powerpc/platforms/85xx/mpc85xx_mds.c |    3 ++-
 1 files changed, 2 insertions(+), 1 deletions(-)

diff --git a/arch/powerpc/platforms/85xx/mpc85xx_mds.c b/arch/powerpc/platforms/85xx/mpc85xx_mds.c
index 21f61b8..cc29c0f 100644
--- a/arch/powerpc/platforms/85xx/mpc85xx_mds.c
+++ b/arch/powerpc/platforms/85xx/mpc85xx_mds.c
@@ -338,7 +338,8 @@ static void __init mpc85xx_mds_pic_init(void)
 	}
 
 	mpic = mpic_alloc(np, r.start,
-			MPIC_PRIMARY | MPIC_WANTS_RESET | MPIC_BIG_ENDIAN,
+			MPIC_PRIMARY | MPIC_WANTS_RESET | MPIC_BIG_ENDIAN |
+			MPIC_BROKEN_FRR_NIRQS,
 			0, 256, " OpenPIC  ");
 	BUG_ON(mpic == NULL);
 	of_node_put(np);
--
To unsubscribe from this list: send the line "unsubscribe git-commits-head" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
powerpc/85xx: Fix oops during MSI driver probe on MPC85xxM ..., Linux Kernel Mailing ..., (Thu Feb 18, 9:59 am)