aboutsummaryrefslogtreecommitdiffstats
path: root/arch/sparc64/kernel/prom.c
diff options
context:
space:
mode:
authorDavid S. Miller <davem@sunset.davemloft.net>2007-06-07 19:58:22 -0400
committerDavid S. Miller <davem@sunset.davemloft.net>2007-06-07 19:59:51 -0400
commitec4d18f219e71ef682fe2d7b9a6d121617fef6d5 (patch)
tree2384d96fc5e4c158f9ef6da34c22af25bf576736 /arch/sparc64/kernel/prom.c
parent321566c2504445160b18e1508a73081579923a6b (diff)
[SPARC64]: Fix SBUS IRQ regression caused by PCI-E driver.
We used to access the 64-bit IRQ IMAP and ICLR registers of bus controllers 4-bytes in and as a 32-bit register word, since only the low 32-bits were relevant. This seemed like a good idea at the time. But the PCI-E controller requires full 8-byte 64-bit access to these registers, so we switched over to accessing them fully. SBUS was not adjusted properly, which broke interrupts completely. Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'arch/sparc64/kernel/prom.c')
-rw-r--r--arch/sparc64/kernel/prom.c54
1 files changed, 27 insertions, 27 deletions
diff --git a/arch/sparc64/kernel/prom.c b/arch/sparc64/kernel/prom.c
index 6f4a5284b0ea..61036b346664 100644
--- a/arch/sparc64/kernel/prom.c
+++ b/arch/sparc64/kernel/prom.c
@@ -933,29 +933,29 @@ static void __init fire_irq_trans_init(struct device_node *dp)
933 * This should conform to both Sunfire/Wildfire server and Fusion 933 * This should conform to both Sunfire/Wildfire server and Fusion
934 * desktop designs. 934 * desktop designs.
935 */ 935 */
936#define SYSIO_IMAP_SLOT0 0x2c04UL 936#define SYSIO_IMAP_SLOT0 0x2c00UL
937#define SYSIO_IMAP_SLOT1 0x2c0cUL 937#define SYSIO_IMAP_SLOT1 0x2c08UL
938#define SYSIO_IMAP_SLOT2 0x2c14UL 938#define SYSIO_IMAP_SLOT2 0x2c10UL
939#define SYSIO_IMAP_SLOT3 0x2c1cUL 939#define SYSIO_IMAP_SLOT3 0x2c18UL
940#define SYSIO_IMAP_SCSI 0x3004UL 940#define SYSIO_IMAP_SCSI 0x3000UL
941#define SYSIO_IMAP_ETH 0x300cUL 941#define SYSIO_IMAP_ETH 0x3008UL
942#define SYSIO_IMAP_BPP 0x3014UL 942#define SYSIO_IMAP_BPP 0x3010UL
943#define SYSIO_IMAP_AUDIO 0x301cUL 943#define SYSIO_IMAP_AUDIO 0x3018UL
944#define SYSIO_IMAP_PFAIL 0x3024UL 944#define SYSIO_IMAP_PFAIL 0x3020UL
945#define SYSIO_IMAP_KMS 0x302cUL 945#define SYSIO_IMAP_KMS 0x3028UL
946#define SYSIO_IMAP_FLPY 0x3034UL 946#define SYSIO_IMAP_FLPY 0x3030UL
947#define SYSIO_IMAP_SHW 0x303cUL 947#define SYSIO_IMAP_SHW 0x3038UL
948#define SYSIO_IMAP_KBD 0x3044UL 948#define SYSIO_IMAP_KBD 0x3040UL
949#define SYSIO_IMAP_MS 0x304cUL 949#define SYSIO_IMAP_MS 0x3048UL
950#define SYSIO_IMAP_SER 0x3054UL 950#define SYSIO_IMAP_SER 0x3050UL
951#define SYSIO_IMAP_TIM0 0x3064UL 951#define SYSIO_IMAP_TIM0 0x3060UL
952#define SYSIO_IMAP_TIM1 0x306cUL 952#define SYSIO_IMAP_TIM1 0x3068UL
953#define SYSIO_IMAP_UE 0x3074UL 953#define SYSIO_IMAP_UE 0x3070UL
954#define SYSIO_IMAP_CE 0x307cUL 954#define SYSIO_IMAP_CE 0x3078UL
955#define SYSIO_IMAP_SBERR 0x3084UL 955#define SYSIO_IMAP_SBERR 0x3080UL
956#define SYSIO_IMAP_PMGMT 0x308cUL 956#define SYSIO_IMAP_PMGMT 0x3088UL
957#define SYSIO_IMAP_GFX 0x3094UL 957#define SYSIO_IMAP_GFX 0x3090UL
958#define SYSIO_IMAP_EUPA 0x309cUL 958#define SYSIO_IMAP_EUPA 0x3098UL
959 959
960#define bogon ((unsigned long) -1) 960#define bogon ((unsigned long) -1)
961static unsigned long sysio_irq_offsets[] = { 961static unsigned long sysio_irq_offsets[] = {
@@ -1006,10 +1006,10 @@ static unsigned long sysio_irq_offsets[] = {
1006 * Interrupt Clear register pointer, SYSIO specific version. 1006 * Interrupt Clear register pointer, SYSIO specific version.
1007 */ 1007 */
1008#define SYSIO_ICLR_UNUSED0 0x3400UL 1008#define SYSIO_ICLR_UNUSED0 0x3400UL
1009#define SYSIO_ICLR_SLOT0 0x340cUL 1009#define SYSIO_ICLR_SLOT0 0x3408UL
1010#define SYSIO_ICLR_SLOT1 0x344cUL 1010#define SYSIO_ICLR_SLOT1 0x3448UL
1011#define SYSIO_ICLR_SLOT2 0x348cUL 1011#define SYSIO_ICLR_SLOT2 0x3488UL
1012#define SYSIO_ICLR_SLOT3 0x34ccUL 1012#define SYSIO_ICLR_SLOT3 0x34c8UL
1013static unsigned long sysio_imap_to_iclr(unsigned long imap) 1013static unsigned long sysio_imap_to_iclr(unsigned long imap)
1014{ 1014{
1015 unsigned long diff = SYSIO_ICLR_UNUSED0 - SYSIO_IMAP_SLOT0; 1015 unsigned long diff = SYSIO_ICLR_UNUSED0 - SYSIO_IMAP_SLOT0;