aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/acpi/pci_link.c73
1 files changed, 27 insertions, 46 deletions
diff --git a/drivers/acpi/pci_link.c b/drivers/acpi/pci_link.c
index 6c772ca76bd1..19bc3bcda602 100644
--- a/drivers/acpi/pci_link.c
+++ b/drivers/acpi/pci_link.c
@@ -43,13 +43,14 @@
43#include <acpi/acpi_bus.h> 43#include <acpi/acpi_bus.h>
44#include <acpi/acpi_drivers.h> 44#include <acpi/acpi_drivers.h>
45 45
46#define _COMPONENT ACPI_PCI_COMPONENT 46#define _COMPONENT ACPI_PCI_COMPONENT
47ACPI_MODULE_NAME("pci_link"); 47ACPI_MODULE_NAME("pci_link");
48#define ACPI_PCI_LINK_CLASS "pci_irq_routing" 48#define ACPI_PCI_LINK_CLASS "pci_irq_routing"
49#define ACPI_PCI_LINK_DEVICE_NAME "PCI Interrupt Link" 49#define ACPI_PCI_LINK_DEVICE_NAME "PCI Interrupt Link"
50#define ACPI_PCI_LINK_FILE_INFO "info" 50#define ACPI_PCI_LINK_FILE_INFO "info"
51#define ACPI_PCI_LINK_FILE_STATUS "state" 51#define ACPI_PCI_LINK_FILE_STATUS "state"
52#define ACPI_PCI_LINK_MAX_POSSIBLE 16 52#define ACPI_PCI_LINK_MAX_POSSIBLE 16
53
53static int acpi_pci_link_add(struct acpi_device *device); 54static int acpi_pci_link_add(struct acpi_device *device);
54static int acpi_pci_link_remove(struct acpi_device *device, int type); 55static int acpi_pci_link_remove(struct acpi_device *device, int type);
55 56
@@ -66,7 +67,7 @@ static struct acpi_driver acpi_pci_link_driver = {
66 .ops = { 67 .ops = {
67 .add = acpi_pci_link_add, 68 .add = acpi_pci_link_add,
68 .remove = acpi_pci_link_remove, 69 .remove = acpi_pci_link_remove,
69 }, 70 },
70}; 71};
71 72
72/* 73/*
@@ -76,7 +77,7 @@ static struct acpi_driver acpi_pci_link_driver = {
76struct acpi_pci_link_irq { 77struct acpi_pci_link_irq {
77 u8 active; /* Current IRQ */ 78 u8 active; /* Current IRQ */
78 u8 triggering; /* All IRQs */ 79 u8 triggering; /* All IRQs */
79 u8 polarity; /* All IRQs */ 80 u8 polarity; /* All IRQs */
80 u8 resource_type; 81 u8 resource_type;
81 u8 possible_count; 82 u8 possible_count;
82 u8 possible[ACPI_PCI_LINK_MAX_POSSIBLE]; 83 u8 possible[ACPI_PCI_LINK_MAX_POSSIBLE];
@@ -85,15 +86,15 @@ struct acpi_pci_link_irq {
85}; 86};
86 87
87struct acpi_pci_link { 88struct acpi_pci_link {
88 struct list_head node; 89 struct list_head node;
89 struct acpi_device *device; 90 struct acpi_device *device;
90 struct acpi_pci_link_irq irq; 91 struct acpi_pci_link_irq irq;
91 int refcnt; 92 int refcnt;
92}; 93};
93 94
94static struct { 95static struct {
95 int count; 96 int count;
96 struct list_head entries; 97 struct list_head entries;
97} acpi_link; 98} acpi_link;
98static DEFINE_MUTEX(acpi_link_lock); 99static DEFINE_MUTEX(acpi_link_lock);
99 100
@@ -104,13 +105,12 @@ static DEFINE_MUTEX(acpi_link_lock);
104/* 105/*
105 * set context (link) possible list from resource list 106 * set context (link) possible list from resource list
106 */ 107 */
107static acpi_status 108static acpi_status acpi_pci_link_check_possible(struct acpi_resource *resource,
108acpi_pci_link_check_possible(struct acpi_resource *resource, void *context) 109 void *context)
109{ 110{
110 struct acpi_pci_link *link = context; 111 struct acpi_pci_link *link = context;
111 u32 i = 0; 112 u32 i = 0;
112 113
113
114 switch (resource->type) { 114 switch (resource->type) {
115 case ACPI_RESOURCE_TYPE_START_DEPENDENT: 115 case ACPI_RESOURCE_TYPE_START_DEPENDENT:
116 case ACPI_RESOURCE_TYPE_END_TAG: 116 case ACPI_RESOURCE_TYPE_END_TAG:
@@ -179,7 +179,6 @@ static int acpi_pci_link_get_possible(struct acpi_pci_link *link)
179{ 179{
180 acpi_status status; 180 acpi_status status;
181 181
182
183 if (!link) 182 if (!link)
184 return -EINVAL; 183 return -EINVAL;
185 184
@@ -197,12 +196,11 @@ static int acpi_pci_link_get_possible(struct acpi_pci_link *link)
197 return 0; 196 return 0;
198} 197}
199 198
200static acpi_status 199static acpi_status acpi_pci_link_check_current(struct acpi_resource *resource,
201acpi_pci_link_check_current(struct acpi_resource *resource, void *context) 200 void *context)
202{ 201{
203 int *irq = (int *)context; 202 int *irq = (int *)context;
204 203
205
206 switch (resource->type) { 204 switch (resource->type) {
207 case ACPI_RESOURCE_TYPE_START_DEPENDENT: 205 case ACPI_RESOURCE_TYPE_START_DEPENDENT:
208 case ACPI_RESOURCE_TYPE_END_TAG: 206 case ACPI_RESOURCE_TYPE_END_TAG:
@@ -316,7 +314,6 @@ static int acpi_pci_link_set(struct acpi_pci_link *link, int irq)
316 } *resource; 314 } *resource;
317 struct acpi_buffer buffer = { 0, NULL }; 315 struct acpi_buffer buffer = { 0, NULL };
318 316
319
320 if (!link || !irq) 317 if (!link || !irq)
321 return -EINVAL; 318 return -EINVAL;
322 319
@@ -479,10 +476,10 @@ static int acpi_irq_penalty[ACPI_MAX_IRQS] = {
479 PIRQ_PENALTY_PCI_AVAILABLE, /* IRQ9 PCI, often acpi */ 476 PIRQ_PENALTY_PCI_AVAILABLE, /* IRQ9 PCI, often acpi */
480 PIRQ_PENALTY_PCI_AVAILABLE, /* IRQ10 PCI */ 477 PIRQ_PENALTY_PCI_AVAILABLE, /* IRQ10 PCI */
481 PIRQ_PENALTY_PCI_AVAILABLE, /* IRQ11 PCI */ 478 PIRQ_PENALTY_PCI_AVAILABLE, /* IRQ11 PCI */
482 PIRQ_PENALTY_ISA_USED, /* IRQ12 mouse */ 479 PIRQ_PENALTY_ISA_USED, /* IRQ12 mouse */
483 PIRQ_PENALTY_ISA_USED, /* IRQ13 fpe, sometimes */ 480 PIRQ_PENALTY_ISA_USED, /* IRQ13 fpe, sometimes */
484 PIRQ_PENALTY_ISA_USED, /* IRQ14 ide0 */ 481 PIRQ_PENALTY_ISA_USED, /* IRQ14 ide0 */
485 PIRQ_PENALTY_ISA_USED, /* IRQ15 ide1 */ 482 PIRQ_PENALTY_ISA_USED, /* IRQ15 ide1 */
486 /* >IRQ15 */ 483 /* >IRQ15 */
487}; 484};
488 485
@@ -492,12 +489,10 @@ int __init acpi_irq_penalty_init(void)
492 struct acpi_pci_link *link = NULL; 489 struct acpi_pci_link *link = NULL;
493 int i = 0; 490 int i = 0;
494 491
495
496 /* 492 /*
497 * Update penalties to facilitate IRQ balancing. 493 * Update penalties to facilitate IRQ balancing.
498 */ 494 */
499 list_for_each(node, &acpi_link.entries) { 495 list_for_each(node, &acpi_link.entries) {
500
501 link = list_entry(node, struct acpi_pci_link, node); 496 link = list_entry(node, struct acpi_pci_link, node);
502 if (!link) { 497 if (!link) {
503 printk(KERN_ERR PREFIX "Invalid link context\n"); 498 printk(KERN_ERR PREFIX "Invalid link context\n");
@@ -527,7 +522,6 @@ int __init acpi_irq_penalty_init(void)
527 } 522 }
528 /* Add a penalty for the SCI */ 523 /* Add a penalty for the SCI */
529 acpi_irq_penalty[acpi_gbl_FADT.sci_interrupt] += PIRQ_PENALTY_PCI_USING; 524 acpi_irq_penalty[acpi_gbl_FADT.sci_interrupt] += PIRQ_PENALTY_PCI_USING;
530
531 return 0; 525 return 0;
532} 526}
533 527
@@ -538,7 +532,6 @@ static int acpi_pci_link_allocate(struct acpi_pci_link *link)
538 int irq; 532 int irq;
539 int i; 533 int i;
540 534
541
542 if (link->irq.initialized) { 535 if (link->irq.initialized) {
543 if (link->refcnt == 0) 536 if (link->refcnt == 0)
544 /* This means the link is disabled but initialized */ 537 /* This means the link is disabled but initialized */
@@ -566,11 +559,10 @@ static int acpi_pci_link_allocate(struct acpi_pci_link *link)
566 /* 559 /*
567 * if active found, use it; else pick entry from end of possible list. 560 * if active found, use it; else pick entry from end of possible list.
568 */ 561 */
569 if (link->irq.active) { 562 if (link->irq.active)
570 irq = link->irq.active; 563 irq = link->irq.active;
571 } else { 564 else
572 irq = link->irq.possible[link->irq.possible_count - 1]; 565 irq = link->irq.possible[link->irq.possible_count - 1];
573 }
574 566
575 if (acpi_irq_balance || !link->irq.active) { 567 if (acpi_irq_balance || !link->irq.active) {
576 /* 568 /*
@@ -599,7 +591,6 @@ static int acpi_pci_link_allocate(struct acpi_pci_link *link)
599 } 591 }
600 592
601 link->irq.initialized = 1; 593 link->irq.initialized = 1;
602
603 return 0; 594 return 0;
604} 595}
605 596
@@ -608,17 +599,13 @@ static int acpi_pci_link_allocate(struct acpi_pci_link *link)
608 * success: return IRQ >= 0 599 * success: return IRQ >= 0
609 * failure: return -1 600 * failure: return -1
610 */ 601 */
611 602int acpi_pci_link_allocate_irq(acpi_handle handle, int index, int *triggering,
612int 603 int *polarity, char **name)
613acpi_pci_link_allocate_irq(acpi_handle handle,
614 int index,
615 int *triggering, int *polarity, char **name)
616{ 604{
617 int result = 0; 605 int result = 0;
618 struct acpi_device *device = NULL; 606 struct acpi_device *device = NULL;
619 struct acpi_pci_link *link = NULL; 607 struct acpi_pci_link *link = NULL;
620 608
621
622 result = acpi_bus_get_device(handle, &device); 609 result = acpi_bus_get_device(handle, &device);
623 if (result) { 610 if (result) {
624 printk(KERN_ERR PREFIX "Invalid link device\n"); 611 printk(KERN_ERR PREFIX "Invalid link device\n");
@@ -673,7 +660,6 @@ int acpi_pci_link_free_irq(acpi_handle handle)
673 struct acpi_pci_link *link = NULL; 660 struct acpi_pci_link *link = NULL;
674 acpi_status result; 661 acpi_status result;
675 662
676
677 result = acpi_bus_get_device(handle, &device); 663 result = acpi_bus_get_device(handle, &device);
678 if (result) { 664 if (result) {
679 printk(KERN_ERR PREFIX "Invalid link device\n"); 665 printk(KERN_ERR PREFIX "Invalid link device\n");
@@ -708,9 +694,9 @@ int acpi_pci_link_free_irq(acpi_handle handle)
708 "Link %s is dereferenced\n", 694 "Link %s is dereferenced\n",
709 acpi_device_bid(link->device))); 695 acpi_device_bid(link->device)));
710 696
711 if (link->refcnt == 0) { 697 if (link->refcnt == 0)
712 acpi_evaluate_object(link->device->handle, "_DIS", NULL, NULL); 698 acpi_evaluate_object(link->device->handle, "_DIS", NULL, NULL);
713 } 699
714 mutex_unlock(&acpi_link_lock); 700 mutex_unlock(&acpi_link_lock);
715 return (link->irq.active); 701 return (link->irq.active);
716} 702}
@@ -726,7 +712,6 @@ static int acpi_pci_link_add(struct acpi_device *device)
726 int i = 0; 712 int i = 0;
727 int found = 0; 713 int found = 0;
728 714
729
730 if (!device) 715 if (!device)
731 return -EINVAL; 716 return -EINVAL;
732 717
@@ -784,11 +769,10 @@ static int acpi_pci_link_add(struct acpi_device *device)
784 769
785static int acpi_pci_link_resume(struct acpi_pci_link *link) 770static int acpi_pci_link_resume(struct acpi_pci_link *link)
786{ 771{
787
788 if (link->refcnt && link->irq.active && link->irq.initialized) 772 if (link->refcnt && link->irq.active && link->irq.initialized)
789 return (acpi_pci_link_set(link, link->irq.active)); 773 return (acpi_pci_link_set(link, link->irq.active));
790 else 774
791 return 0; 775 return 0;
792} 776}
793 777
794static int irqrouter_resume(struct sys_device *dev) 778static int irqrouter_resume(struct sys_device *dev)
@@ -811,7 +795,6 @@ static int acpi_pci_link_remove(struct acpi_device *device, int type)
811{ 795{
812 struct acpi_pci_link *link = NULL; 796 struct acpi_pci_link *link = NULL;
813 797
814
815 if (!device || !acpi_driver_data(device)) 798 if (!device || !acpi_driver_data(device))
816 return -EINVAL; 799 return -EINVAL;
817 800
@@ -822,7 +805,6 @@ static int acpi_pci_link_remove(struct acpi_device *device, int type)
822 mutex_unlock(&acpi_link_lock); 805 mutex_unlock(&acpi_link_lock);
823 806
824 kfree(link); 807 kfree(link);
825
826 return 0; 808 return 0;
827} 809}
828 810
@@ -931,7 +913,6 @@ static int __init irqrouter_init_sysfs(void)
931{ 913{
932 int error; 914 int error;
933 915
934
935 if (acpi_disabled || acpi_noirq) 916 if (acpi_disabled || acpi_noirq)
936 return 0; 917 return 0;
937 918