aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
Diffstat (limited to 'arch')
-rw-r--r--arch/x86/pci/irq.c261
1 files changed, 125 insertions, 136 deletions
diff --git a/arch/x86/pci/irq.c b/arch/x86/pci/irq.c
index 0908fca901bf..7300567e480b 100644
--- a/arch/x86/pci/irq.c
+++ b/arch/x86/pci/irq.c
@@ -11,8 +11,8 @@
11#include <linux/slab.h> 11#include <linux/slab.h>
12#include <linux/interrupt.h> 12#include <linux/interrupt.h>
13#include <linux/dmi.h> 13#include <linux/dmi.h>
14#include <asm/io.h> 14#include <linux/io.h>
15#include <asm/smp.h> 15#include <linux/smp.h>
16#include <asm/io_apic.h> 16#include <asm/io_apic.h>
17#include <linux/irq.h> 17#include <linux/irq.h>
18#include <linux/acpi.h> 18#include <linux/acpi.h>
@@ -61,7 +61,7 @@ void (*pcibios_disable_irq)(struct pci_dev *dev) = NULL;
61 * and perform checksum verification. 61 * and perform checksum verification.
62 */ 62 */
63 63
64static inline struct irq_routing_table * pirq_check_routing_table(u8 *addr) 64static inline struct irq_routing_table *pirq_check_routing_table(u8 *addr)
65{ 65{
66 struct irq_routing_table *rt; 66 struct irq_routing_table *rt;
67 int i; 67 int i;
@@ -74,7 +74,7 @@ static inline struct irq_routing_table * pirq_check_routing_table(u8 *addr)
74 rt->size < sizeof(struct irq_routing_table)) 74 rt->size < sizeof(struct irq_routing_table))
75 return NULL; 75 return NULL;
76 sum = 0; 76 sum = 0;
77 for (i=0; i < rt->size; i++) 77 for (i = 0; i < rt->size; i++)
78 sum += addr[i]; 78 sum += addr[i];
79 if (!sum) { 79 if (!sum) {
80 DBG(KERN_DEBUG "PCI: Interrupt Routing Table found at 0x%p\n", rt); 80 DBG(KERN_DEBUG "PCI: Interrupt Routing Table found at 0x%p\n", rt);
@@ -100,7 +100,7 @@ static struct irq_routing_table * __init pirq_find_routing_table(void)
100 return rt; 100 return rt;
101 printk(KERN_WARNING "PCI: PIRQ table NOT found at pirqaddr\n"); 101 printk(KERN_WARNING "PCI: PIRQ table NOT found at pirqaddr\n");
102 } 102 }
103 for(addr = (u8 *) __va(0xf0000); addr < (u8 *) __va(0x100000); addr += 16) { 103 for (addr = (u8 *) __va(0xf0000); addr < (u8 *) __va(0x100000); addr += 16) {
104 rt = pirq_check_routing_table(addr); 104 rt = pirq_check_routing_table(addr);
105 if (rt) 105 if (rt)
106 return rt; 106 return rt;
@@ -122,20 +122,20 @@ static void __init pirq_peer_trick(void)
122 struct irq_info *e; 122 struct irq_info *e;
123 123
124 memset(busmap, 0, sizeof(busmap)); 124 memset(busmap, 0, sizeof(busmap));
125 for(i=0; i < (rt->size - sizeof(struct irq_routing_table)) / sizeof(struct irq_info); i++) { 125 for (i = 0; i < (rt->size - sizeof(struct irq_routing_table)) / sizeof(struct irq_info); i++) {
126 e = &rt->slots[i]; 126 e = &rt->slots[i];
127#ifdef DEBUG 127#ifdef DEBUG
128 { 128 {
129 int j; 129 int j;
130 DBG(KERN_DEBUG "%02x:%02x slot=%02x", e->bus, e->devfn/8, e->slot); 130 DBG(KERN_DEBUG "%02x:%02x slot=%02x", e->bus, e->devfn/8, e->slot);
131 for(j=0; j<4; j++) 131 for (j = 0; j < 4; j++)
132 DBG(" %d:%02x/%04x", j, e->irq[j].link, e->irq[j].bitmap); 132 DBG(" %d:%02x/%04x", j, e->irq[j].link, e->irq[j].bitmap);
133 DBG("\n"); 133 DBG("\n");
134 } 134 }
135#endif 135#endif
136 busmap[e->bus] = 1; 136 busmap[e->bus] = 1;
137 } 137 }
138 for(i = 1; i < 256; i++) { 138 for (i = 1; i < 256; i++) {
139 int node; 139 int node;
140 if (!busmap[i] || pci_find_bus(0, i)) 140 if (!busmap[i] || pci_find_bus(0, i))
141 continue; 141 continue;
@@ -285,7 +285,7 @@ static int pirq_ite_get(struct pci_dev *router, struct pci_dev *dev, int pirq)
285 static const unsigned char pirqmap[4] = { 1, 0, 2, 3 }; 285 static const unsigned char pirqmap[4] = { 1, 0, 2, 3 };
286 286
287 WARN_ON_ONCE(pirq > 4); 287 WARN_ON_ONCE(pirq > 4);
288 return read_config_nybble(router,0x43, pirqmap[pirq-1]); 288 return read_config_nybble(router, 0x43, pirqmap[pirq-1]);
289} 289}
290 290
291static int pirq_ite_set(struct pci_dev *router, struct pci_dev *dev, int pirq, int irq) 291static int pirq_ite_set(struct pci_dev *router, struct pci_dev *dev, int pirq, int irq)
@@ -314,7 +314,7 @@ static int pirq_opti_set(struct pci_dev *router, struct pci_dev *dev, int pirq,
314 314
315/* 315/*
316 * Cyrix: nibble offset 0x5C 316 * Cyrix: nibble offset 0x5C
317 * 0x5C bits 7:4 is INTB bits 3:0 is INTA 317 * 0x5C bits 7:4 is INTB bits 3:0 is INTA
318 * 0x5D bits 7:4 is INTD bits 3:0 is INTC 318 * 0x5D bits 7:4 is INTD bits 3:0 is INTC
319 */ 319 */
320static int pirq_cyrix_get(struct pci_dev *router, struct pci_dev *dev, int pirq) 320static int pirq_cyrix_get(struct pci_dev *router, struct pci_dev *dev, int pirq)
@@ -350,7 +350,7 @@ static int pirq_cyrix_set(struct pci_dev *router, struct pci_dev *dev, int pirq,
350 * Apparently there are systems implementing PCI routing table using 350 * Apparently there are systems implementing PCI routing table using
351 * link values 0x01-0x04 and others using 0x41-0x44 for PCI INTA..D. 351 * link values 0x01-0x04 and others using 0x41-0x44 for PCI INTA..D.
352 * We try our best to handle both link mappings. 352 * We try our best to handle both link mappings.
353 * 353 *
354 * Currently (2003-05-21) it appears most SiS chipsets follow the 354 * Currently (2003-05-21) it appears most SiS chipsets follow the
355 * definition of routing registers from the SiS-5595 southbridge. 355 * definition of routing registers from the SiS-5595 southbridge.
356 * According to the SiS 5595 datasheets the revision id's of the 356 * According to the SiS 5595 datasheets the revision id's of the
@@ -370,7 +370,7 @@ static int pirq_cyrix_set(struct pci_dev *router, struct pci_dev *dev, int pirq,
370 * 370 *
371 * 0x62: USBIRQ: 371 * 0x62: USBIRQ:
372 * bit 6 OHCI function disabled (0), enabled (1) 372 * bit 6 OHCI function disabled (0), enabled (1)
373 * 373 *
374 * 0x6a: ACPI/SCI IRQ: bits 4-6 reserved 374 * 0x6a: ACPI/SCI IRQ: bits 4-6 reserved
375 * 375 *
376 * 0x7e: Data Acq. Module IRQ - bits 4-6 reserved 376 * 0x7e: Data Acq. Module IRQ - bits 4-6 reserved
@@ -487,9 +487,7 @@ static int pirq_amd756_get(struct pci_dev *router, struct pci_dev *dev, int pirq
487 u8 irq; 487 u8 irq;
488 irq = 0; 488 irq = 0;
489 if (pirq <= 4) 489 if (pirq <= 4)
490 {
491 irq = read_config_nybble(router, 0x56, pirq - 1); 490 irq = read_config_nybble(router, 0x56, pirq - 1);
492 }
493 printk(KERN_INFO "AMD756: dev %04x:%04x, router pirq : %d get irq : %2d\n", 491 printk(KERN_INFO "AMD756: dev %04x:%04x, router pirq : %d get irq : %2d\n",
494 dev->vendor, dev->device, pirq, irq); 492 dev->vendor, dev->device, pirq, irq);
495 return irq; 493 return irq;
@@ -497,12 +495,10 @@ static int pirq_amd756_get(struct pci_dev *router, struct pci_dev *dev, int pirq
497 495
498static int pirq_amd756_set(struct pci_dev *router, struct pci_dev *dev, int pirq, int irq) 496static int pirq_amd756_set(struct pci_dev *router, struct pci_dev *dev, int pirq, int irq)
499{ 497{
500 printk(KERN_INFO "AMD756: dev %04x:%04x, router pirq : %d SET irq : %2d\n", 498 printk(KERN_INFO "AMD756: dev %04x:%04x, router pirq : %d SET irq : %2d\n",
501 dev->vendor, dev->device, pirq, irq); 499 dev->vendor, dev->device, pirq, irq);
502 if (pirq <= 4) 500 if (pirq <= 4)
503 {
504 write_config_nybble(router, 0x56, pirq - 1, irq); 501 write_config_nybble(router, 0x56, pirq - 1, irq);
505 }
506 return 1; 502 return 1;
507} 503}
508 504
@@ -549,50 +545,49 @@ static __init int intel_router_probe(struct irq_router *r, struct pci_dev *route
549 if (pci_dev_present(pirq_440gx)) 545 if (pci_dev_present(pirq_440gx))
550 return 0; 546 return 0;
551 547
552 switch(device) 548 switch (device) {
553 { 549 case PCI_DEVICE_ID_INTEL_82371FB_0:
554 case PCI_DEVICE_ID_INTEL_82371FB_0: 550 case PCI_DEVICE_ID_INTEL_82371SB_0:
555 case PCI_DEVICE_ID_INTEL_82371SB_0: 551 case PCI_DEVICE_ID_INTEL_82371AB_0:
556 case PCI_DEVICE_ID_INTEL_82371AB_0: 552 case PCI_DEVICE_ID_INTEL_82371MX:
557 case PCI_DEVICE_ID_INTEL_82371MX: 553 case PCI_DEVICE_ID_INTEL_82443MX_0:
558 case PCI_DEVICE_ID_INTEL_82443MX_0: 554 case PCI_DEVICE_ID_INTEL_82801AA_0:
559 case PCI_DEVICE_ID_INTEL_82801AA_0: 555 case PCI_DEVICE_ID_INTEL_82801AB_0:
560 case PCI_DEVICE_ID_INTEL_82801AB_0: 556 case PCI_DEVICE_ID_INTEL_82801BA_0:
561 case PCI_DEVICE_ID_INTEL_82801BA_0: 557 case PCI_DEVICE_ID_INTEL_82801BA_10:
562 case PCI_DEVICE_ID_INTEL_82801BA_10: 558 case PCI_DEVICE_ID_INTEL_82801CA_0:
563 case PCI_DEVICE_ID_INTEL_82801CA_0: 559 case PCI_DEVICE_ID_INTEL_82801CA_12:
564 case PCI_DEVICE_ID_INTEL_82801CA_12: 560 case PCI_DEVICE_ID_INTEL_82801DB_0:
565 case PCI_DEVICE_ID_INTEL_82801DB_0: 561 case PCI_DEVICE_ID_INTEL_82801E_0:
566 case PCI_DEVICE_ID_INTEL_82801E_0: 562 case PCI_DEVICE_ID_INTEL_82801EB_0:
567 case PCI_DEVICE_ID_INTEL_82801EB_0: 563 case PCI_DEVICE_ID_INTEL_ESB_1:
568 case PCI_DEVICE_ID_INTEL_ESB_1: 564 case PCI_DEVICE_ID_INTEL_ICH6_0:
569 case PCI_DEVICE_ID_INTEL_ICH6_0: 565 case PCI_DEVICE_ID_INTEL_ICH6_1:
570 case PCI_DEVICE_ID_INTEL_ICH6_1: 566 case PCI_DEVICE_ID_INTEL_ICH7_0:
571 case PCI_DEVICE_ID_INTEL_ICH7_0: 567 case PCI_DEVICE_ID_INTEL_ICH7_1:
572 case PCI_DEVICE_ID_INTEL_ICH7_1: 568 case PCI_DEVICE_ID_INTEL_ICH7_30:
573 case PCI_DEVICE_ID_INTEL_ICH7_30: 569 case PCI_DEVICE_ID_INTEL_ICH7_31:
574 case PCI_DEVICE_ID_INTEL_ICH7_31: 570 case PCI_DEVICE_ID_INTEL_ESB2_0:
575 case PCI_DEVICE_ID_INTEL_ESB2_0: 571 case PCI_DEVICE_ID_INTEL_ICH8_0:
576 case PCI_DEVICE_ID_INTEL_ICH8_0: 572 case PCI_DEVICE_ID_INTEL_ICH8_1:
577 case PCI_DEVICE_ID_INTEL_ICH8_1: 573 case PCI_DEVICE_ID_INTEL_ICH8_2:
578 case PCI_DEVICE_ID_INTEL_ICH8_2: 574 case PCI_DEVICE_ID_INTEL_ICH8_3:
579 case PCI_DEVICE_ID_INTEL_ICH8_3: 575 case PCI_DEVICE_ID_INTEL_ICH8_4:
580 case PCI_DEVICE_ID_INTEL_ICH8_4: 576 case PCI_DEVICE_ID_INTEL_ICH9_0:
581 case PCI_DEVICE_ID_INTEL_ICH9_0: 577 case PCI_DEVICE_ID_INTEL_ICH9_1:
582 case PCI_DEVICE_ID_INTEL_ICH9_1: 578 case PCI_DEVICE_ID_INTEL_ICH9_2:
583 case PCI_DEVICE_ID_INTEL_ICH9_2: 579 case PCI_DEVICE_ID_INTEL_ICH9_3:
584 case PCI_DEVICE_ID_INTEL_ICH9_3: 580 case PCI_DEVICE_ID_INTEL_ICH9_4:
585 case PCI_DEVICE_ID_INTEL_ICH9_4: 581 case PCI_DEVICE_ID_INTEL_ICH9_5:
586 case PCI_DEVICE_ID_INTEL_ICH9_5: 582 case PCI_DEVICE_ID_INTEL_TOLAPAI_0:
587 case PCI_DEVICE_ID_INTEL_TOLAPAI_0: 583 case PCI_DEVICE_ID_INTEL_ICH10_0:
588 case PCI_DEVICE_ID_INTEL_ICH10_0: 584 case PCI_DEVICE_ID_INTEL_ICH10_1:
589 case PCI_DEVICE_ID_INTEL_ICH10_1: 585 case PCI_DEVICE_ID_INTEL_ICH10_2:
590 case PCI_DEVICE_ID_INTEL_ICH10_2: 586 case PCI_DEVICE_ID_INTEL_ICH10_3:
591 case PCI_DEVICE_ID_INTEL_ICH10_3: 587 r->name = "PIIX/ICH";
592 r->name = "PIIX/ICH"; 588 r->get = pirq_piix_get;
593 r->get = pirq_piix_get; 589 r->set = pirq_piix_set;
594 r->set = pirq_piix_set; 590 return 1;
595 return 1;
596 } 591 }
597 return 0; 592 return 0;
598} 593}
@@ -606,7 +601,7 @@ static __init int via_router_probe(struct irq_router *r,
606 * workarounds for some buggy BIOSes 601 * workarounds for some buggy BIOSes
607 */ 602 */
608 if (device == PCI_DEVICE_ID_VIA_82C586_0) { 603 if (device == PCI_DEVICE_ID_VIA_82C586_0) {
609 switch(router->device) { 604 switch (router->device) {
610 case PCI_DEVICE_ID_VIA_82C686: 605 case PCI_DEVICE_ID_VIA_82C686:
611 /* 606 /*
612 * Asus k7m bios wrongly reports 82C686A 607 * Asus k7m bios wrongly reports 82C686A
@@ -624,7 +619,7 @@ static __init int via_router_probe(struct irq_router *r,
624 } 619 }
625 } 620 }
626 621
627 switch(device) { 622 switch (device) {
628 case PCI_DEVICE_ID_VIA_82C586_0: 623 case PCI_DEVICE_ID_VIA_82C586_0:
629 r->name = "VIA"; 624 r->name = "VIA";
630 r->get = pirq_via586_get; 625 r->get = pirq_via586_get;
@@ -647,13 +642,12 @@ static __init int via_router_probe(struct irq_router *r,
647 642
648static __init int vlsi_router_probe(struct irq_router *r, struct pci_dev *router, u16 device) 643static __init int vlsi_router_probe(struct irq_router *r, struct pci_dev *router, u16 device)
649{ 644{
650 switch(device) 645 switch (device) {
651 { 646 case PCI_DEVICE_ID_VLSI_82C534:
652 case PCI_DEVICE_ID_VLSI_82C534: 647 r->name = "VLSI 82C534";
653 r->name = "VLSI 82C534"; 648 r->get = pirq_vlsi_get;
654 r->get = pirq_vlsi_get; 649 r->set = pirq_vlsi_set;
655 r->set = pirq_vlsi_set; 650 return 1;
656 return 1;
657 } 651 }
658 return 0; 652 return 0;
659} 653}
@@ -661,14 +655,13 @@ static __init int vlsi_router_probe(struct irq_router *r, struct pci_dev *router
661 655
662static __init int serverworks_router_probe(struct irq_router *r, struct pci_dev *router, u16 device) 656static __init int serverworks_router_probe(struct irq_router *r, struct pci_dev *router, u16 device)
663{ 657{
664 switch(device) 658 switch (device) {
665 { 659 case PCI_DEVICE_ID_SERVERWORKS_OSB4:
666 case PCI_DEVICE_ID_SERVERWORKS_OSB4: 660 case PCI_DEVICE_ID_SERVERWORKS_CSB5:
667 case PCI_DEVICE_ID_SERVERWORKS_CSB5: 661 r->name = "ServerWorks";
668 r->name = "ServerWorks"; 662 r->get = pirq_serverworks_get;
669 r->get = pirq_serverworks_get; 663 r->set = pirq_serverworks_set;
670 r->set = pirq_serverworks_set; 664 return 1;
671 return 1;
672 } 665 }
673 return 0; 666 return 0;
674} 667}
@@ -677,7 +670,7 @@ static __init int sis_router_probe(struct irq_router *r, struct pci_dev *router,
677{ 670{
678 if (device != PCI_DEVICE_ID_SI_503) 671 if (device != PCI_DEVICE_ID_SI_503)
679 return 0; 672 return 0;
680 673
681 r->name = "SIS"; 674 r->name = "SIS";
682 r->get = pirq_sis_get; 675 r->get = pirq_sis_get;
683 r->set = pirq_sis_set; 676 r->set = pirq_sis_set;
@@ -686,47 +679,43 @@ static __init int sis_router_probe(struct irq_router *r, struct pci_dev *router,
686 679
687static __init int cyrix_router_probe(struct irq_router *r, struct pci_dev *router, u16 device) 680static __init int cyrix_router_probe(struct irq_router *r, struct pci_dev *router, u16 device)
688{ 681{
689 switch(device) 682 switch (device) {
690 { 683 case PCI_DEVICE_ID_CYRIX_5520:
691 case PCI_DEVICE_ID_CYRIX_5520: 684 r->name = "NatSemi";
692 r->name = "NatSemi"; 685 r->get = pirq_cyrix_get;
693 r->get = pirq_cyrix_get; 686 r->set = pirq_cyrix_set;
694 r->set = pirq_cyrix_set; 687 return 1;
695 return 1;
696 } 688 }
697 return 0; 689 return 0;
698} 690}
699 691
700static __init int opti_router_probe(struct irq_router *r, struct pci_dev *router, u16 device) 692static __init int opti_router_probe(struct irq_router *r, struct pci_dev *router, u16 device)
701{ 693{
702 switch(device) 694 switch (device) {
703 { 695 case PCI_DEVICE_ID_OPTI_82C700:
704 case PCI_DEVICE_ID_OPTI_82C700: 696 r->name = "OPTI";
705 r->name = "OPTI"; 697 r->get = pirq_opti_get;
706 r->get = pirq_opti_get; 698 r->set = pirq_opti_set;
707 r->set = pirq_opti_set; 699 return 1;
708 return 1;
709 } 700 }
710 return 0; 701 return 0;
711} 702}
712 703
713static __init int ite_router_probe(struct irq_router *r, struct pci_dev *router, u16 device) 704static __init int ite_router_probe(struct irq_router *r, struct pci_dev *router, u16 device)
714{ 705{
715 switch(device) 706 switch (device) {
716 { 707 case PCI_DEVICE_ID_ITE_IT8330G_0:
717 case PCI_DEVICE_ID_ITE_IT8330G_0: 708 r->name = "ITE";
718 r->name = "ITE"; 709 r->get = pirq_ite_get;
719 r->get = pirq_ite_get; 710 r->set = pirq_ite_set;
720 r->set = pirq_ite_set; 711 return 1;
721 return 1;
722 } 712 }
723 return 0; 713 return 0;
724} 714}
725 715
726static __init int ali_router_probe(struct irq_router *r, struct pci_dev *router, u16 device) 716static __init int ali_router_probe(struct irq_router *r, struct pci_dev *router, u16 device)
727{ 717{
728 switch(device) 718 switch (device) {
729 {
730 case PCI_DEVICE_ID_AL_M1533: 719 case PCI_DEVICE_ID_AL_M1533:
731 case PCI_DEVICE_ID_AL_M1563: 720 case PCI_DEVICE_ID_AL_M1563:
732 printk(KERN_DEBUG "PCI: Using ALI IRQ Router\n"); 721 printk(KERN_DEBUG "PCI: Using ALI IRQ Router\n");
@@ -740,25 +729,24 @@ static __init int ali_router_probe(struct irq_router *r, struct pci_dev *router,
740 729
741static __init int amd_router_probe(struct irq_router *r, struct pci_dev *router, u16 device) 730static __init int amd_router_probe(struct irq_router *r, struct pci_dev *router, u16 device)
742{ 731{
743 switch(device) 732 switch (device) {
744 { 733 case PCI_DEVICE_ID_AMD_VIPER_740B:
745 case PCI_DEVICE_ID_AMD_VIPER_740B: 734 r->name = "AMD756";
746 r->name = "AMD756"; 735 break;
747 break; 736 case PCI_DEVICE_ID_AMD_VIPER_7413:
748 case PCI_DEVICE_ID_AMD_VIPER_7413: 737 r->name = "AMD766";
749 r->name = "AMD766"; 738 break;
750 break; 739 case PCI_DEVICE_ID_AMD_VIPER_7443:
751 case PCI_DEVICE_ID_AMD_VIPER_7443: 740 r->name = "AMD768";
752 r->name = "AMD768"; 741 break;
753 break; 742 default:
754 default: 743 return 0;
755 return 0;
756 } 744 }
757 r->get = pirq_amd756_get; 745 r->get = pirq_amd756_get;
758 r->set = pirq_amd756_set; 746 r->set = pirq_amd756_set;
759 return 1; 747 return 1;
760} 748}
761 749
762static __init int pico_router_probe(struct irq_router *r, struct pci_dev *router, u16 device) 750static __init int pico_router_probe(struct irq_router *r, struct pci_dev *router, u16 device)
763{ 751{
764 switch (device) { 752 switch (device) {
@@ -800,7 +788,7 @@ static struct pci_dev *pirq_router_dev;
800 * FIXME: should we have an option to say "generic for 788 * FIXME: should we have an option to say "generic for
801 * chipset" ? 789 * chipset" ?
802 */ 790 */
803 791
804static void __init pirq_find_router(struct irq_router *r) 792static void __init pirq_find_router(struct irq_router *r)
805{ 793{
806 struct irq_routing_table *rt = pirq_table; 794 struct irq_routing_table *rt = pirq_table;
@@ -819,7 +807,7 @@ static void __init pirq_find_router(struct irq_router *r)
819 r->name = "default"; 807 r->name = "default";
820 r->get = NULL; 808 r->get = NULL;
821 r->set = NULL; 809 r->set = NULL;
822 810
823 DBG(KERN_DEBUG "PCI: Attempting to find IRQ router for %04x:%04x\n", 811 DBG(KERN_DEBUG "PCI: Attempting to find IRQ router for %04x:%04x\n",
824 rt->rtr_vendor, rt->rtr_device); 812 rt->rtr_vendor, rt->rtr_device);
825 813
@@ -830,7 +818,7 @@ static void __init pirq_find_router(struct irq_router *r)
830 return; 818 return;
831 } 819 }
832 820
833 for( h = pirq_routers; h->vendor; h++) { 821 for (h = pirq_routers; h->vendor; h++) {
834 /* First look for a router match */ 822 /* First look for a router match */
835 if (rt->rtr_vendor == h->vendor && h->probe(r, pirq_router_dev, rt->rtr_device)) 823 if (rt->rtr_vendor == h->vendor && h->probe(r, pirq_router_dev, rt->rtr_device))
836 break; 824 break;
@@ -882,7 +870,7 @@ static int pcibios_lookup_irq(struct pci_dev *dev, int assign)
882 870
883 if (!pirq_table) 871 if (!pirq_table)
884 return 0; 872 return 0;
885 873
886 DBG(KERN_DEBUG "IRQ for %s[%c]", pci_name(dev), 'A' + pin); 874 DBG(KERN_DEBUG "IRQ for %s[%c]", pci_name(dev), 'A' + pin);
887 info = pirq_get_info(dev); 875 info = pirq_get_info(dev);
888 if (!info) { 876 if (!info) {
@@ -921,8 +909,10 @@ static int pcibios_lookup_irq(struct pci_dev *dev, int assign)
921 */ 909 */
922 newirq = dev->irq; 910 newirq = dev->irq;
923 if (newirq && !((1 << newirq) & mask)) { 911 if (newirq && !((1 << newirq) & mask)) {
924 if ( pci_probe & PCI_USE_PIRQ_MASK) newirq = 0; 912 if (pci_probe & PCI_USE_PIRQ_MASK)
925 else printk("\n" KERN_WARNING 913 newirq = 0;
914 else
915 printk("\n" KERN_WARNING
926 "PCI: IRQ %i for device %s doesn't match PIRQ mask " 916 "PCI: IRQ %i for device %s doesn't match PIRQ mask "
927 "- try pci=usepirqmask\n" KERN_DEBUG, newirq, 917 "- try pci=usepirqmask\n" KERN_DEBUG, newirq,
928 pci_name(dev)); 918 pci_name(dev));
@@ -942,8 +932,8 @@ static int pcibios_lookup_irq(struct pci_dev *dev, int assign)
942 irq = pirq & 0xf; 932 irq = pirq & 0xf;
943 DBG(" -> hardcoded IRQ %d\n", irq); 933 DBG(" -> hardcoded IRQ %d\n", irq);
944 msg = "Hardcoded"; 934 msg = "Hardcoded";
945 } else if ( r->get && (irq = r->get(pirq_router_dev, dev, pirq)) && \ 935 } else if (r->get && (irq = r->get(pirq_router_dev, dev, pirq)) && \
946 ((!(pci_probe & PCI_USE_PIRQ_MASK)) || ((1 << irq) & mask)) ) { 936 ((!(pci_probe & PCI_USE_PIRQ_MASK)) || ((1 << irq) & mask))) {
947 DBG(" -> got IRQ %d\n", irq); 937 DBG(" -> got IRQ %d\n", irq);
948 msg = "Found"; 938 msg = "Found";
949 eisa_set_level_irq(irq); 939 eisa_set_level_irq(irq);
@@ -978,15 +968,15 @@ static int pcibios_lookup_irq(struct pci_dev *dev, int assign)
978 continue; 968 continue;
979 if (info->irq[pin].link == pirq) { 969 if (info->irq[pin].link == pirq) {
980 /* We refuse to override the dev->irq information. Give a warning! */ 970 /* We refuse to override the dev->irq information. Give a warning! */
981 if ( dev2->irq && dev2->irq != irq && \ 971 if (dev2->irq && dev2->irq != irq && \
982 (!(pci_probe & PCI_USE_PIRQ_MASK) || \ 972 (!(pci_probe & PCI_USE_PIRQ_MASK) || \
983 ((1 << dev2->irq) & mask)) ) { 973 ((1 << dev2->irq) & mask))) {
984#ifndef CONFIG_PCI_MSI 974#ifndef CONFIG_PCI_MSI
985 printk(KERN_INFO "IRQ routing conflict for %s, have irq %d, want irq %d\n", 975 printk(KERN_INFO "IRQ routing conflict for %s, have irq %d, want irq %d\n",
986 pci_name(dev2), dev2->irq, irq); 976 pci_name(dev2), dev2->irq, irq);
987#endif 977#endif
988 continue; 978 continue;
989 } 979 }
990 dev2->irq = irq; 980 dev2->irq = irq;
991 pirq_penalty[irq]++; 981 pirq_penalty[irq]++;
992 if (dev != dev2) 982 if (dev != dev2)
@@ -1024,8 +1014,7 @@ static void __init pcibios_fixup_irqs(void)
1024 /* 1014 /*
1025 * Recalculate IRQ numbers if we use the I/O APIC. 1015 * Recalculate IRQ numbers if we use the I/O APIC.
1026 */ 1016 */
1027 if (io_apic_assign_pci_irqs) 1017 if (io_apic_assign_pci_irqs) {
1028 {
1029 int irq; 1018 int irq;
1030 1019
1031 if (pin) { 1020 if (pin) {
@@ -1038,10 +1027,10 @@ static void __init pcibios_fixup_irqs(void)
1038 * busses itself so we should get into this branch reliably. 1027 * busses itself so we should get into this branch reliably.
1039 */ 1028 */
1040 if (irq < 0 && dev->bus->parent) { /* go back to the bridge */ 1029 if (irq < 0 && dev->bus->parent) { /* go back to the bridge */
1041 struct pci_dev * bridge = dev->bus->self; 1030 struct pci_dev *bridge = dev->bus->self;
1042 1031
1043 pin = (pin + PCI_SLOT(dev->devfn)) % 4; 1032 pin = (pin + PCI_SLOT(dev->devfn)) % 4;
1044 irq = IO_APIC_get_PCI_irq_vector(bridge->bus->number, 1033 irq = IO_APIC_get_PCI_irq_vector(bridge->bus->number,
1045 PCI_SLOT(bridge->devfn), pin); 1034 PCI_SLOT(bridge->devfn), pin);
1046 if (irq >= 0) 1035 if (irq >= 0)
1047 printk(KERN_WARNING "PCI: using PPB %s[%c] to get irq %d\n", 1036 printk(KERN_WARNING "PCI: using PPB %s[%c] to get irq %d\n",
@@ -1131,7 +1120,7 @@ static int __init pcibios_irq_init(void)
1131 pirq_find_router(&pirq_router); 1120 pirq_find_router(&pirq_router);
1132 if (pirq_table->exclusive_irqs) { 1121 if (pirq_table->exclusive_irqs) {
1133 int i; 1122 int i;
1134 for (i=0; i<16; i++) 1123 for (i = 0; i < 16; i++)
1135 if (!(pirq_table->exclusive_irqs & (1 << i))) 1124 if (!(pirq_table->exclusive_irqs & (1 << i)))
1136 pirq_penalty[i] += 100; 1125 pirq_penalty[i] += 100;
1137 } 1126 }
@@ -1196,10 +1185,10 @@ static int pirq_enable_irq(struct pci_dev *dev)
1196 */ 1185 */
1197 temp_dev = dev; 1186 temp_dev = dev;
1198 while (irq < 0 && dev->bus->parent) { /* go back to the bridge */ 1187 while (irq < 0 && dev->bus->parent) { /* go back to the bridge */
1199 struct pci_dev * bridge = dev->bus->self; 1188 struct pci_dev *bridge = dev->bus->self;
1200 1189
1201 pin = (pin + PCI_SLOT(dev->devfn)) % 4; 1190 pin = (pin + PCI_SLOT(dev->devfn)) % 4;
1202 irq = IO_APIC_get_PCI_irq_vector(bridge->bus->number, 1191 irq = IO_APIC_get_PCI_irq_vector(bridge->bus->number,
1203 PCI_SLOT(bridge->devfn), pin); 1192 PCI_SLOT(bridge->devfn), pin);
1204 if (irq >= 0) 1193 if (irq >= 0)
1205 printk(KERN_WARNING "PCI: using PPB %s[%c] to get irq %d\n", 1194 printk(KERN_WARNING "PCI: using PPB %s[%c] to get irq %d\n",