aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/pci/hotplug/cpqphp.h58
-rw-r--r--drivers/pci/hotplug/cpqphp_core.c56
-rw-r--r--drivers/pci/hotplug/cpqphp_ctrl.c86
-rw-r--r--drivers/pci/hotplug/cpqphp_nvram.c18
-rw-r--r--drivers/pci/hotplug/cpqphp_pci.c14
5 files changed, 110 insertions, 122 deletions
diff --git a/drivers/pci/hotplug/cpqphp.h b/drivers/pci/hotplug/cpqphp.h
index afaf8f69f73e..b627dfd74500 100644
--- a/drivers/pci/hotplug/cpqphp.h
+++ b/drivers/pci/hotplug/cpqphp.h
@@ -150,25 +150,25 @@ struct ctrl_reg { /* offset */
150 150
151/* offsets to the controller registers based on the above structure layout */ 151/* offsets to the controller registers based on the above structure layout */
152enum ctrl_offsets { 152enum ctrl_offsets {
153 SLOT_RST = offsetof(struct ctrl_reg, slot_RST), 153 SLOT_RST = offsetof(struct ctrl_reg, slot_RST),
154 SLOT_ENABLE = offsetof(struct ctrl_reg, slot_enable), 154 SLOT_ENABLE = offsetof(struct ctrl_reg, slot_enable),
155 MISC = offsetof(struct ctrl_reg, misc), 155 MISC = offsetof(struct ctrl_reg, misc),
156 LED_CONTROL = offsetof(struct ctrl_reg, led_control), 156 LED_CONTROL = offsetof(struct ctrl_reg, led_control),
157 INT_INPUT_CLEAR = offsetof(struct ctrl_reg, int_input_clear), 157 INT_INPUT_CLEAR = offsetof(struct ctrl_reg, int_input_clear),
158 INT_MASK = offsetof(struct ctrl_reg, int_mask), 158 INT_MASK = offsetof(struct ctrl_reg, int_mask),
159 CTRL_RESERVED0 = offsetof(struct ctrl_reg, reserved0), 159 CTRL_RESERVED0 = offsetof(struct ctrl_reg, reserved0),
160 CTRL_RESERVED1 = offsetof(struct ctrl_reg, reserved1), 160 CTRL_RESERVED1 = offsetof(struct ctrl_reg, reserved1),
161 CTRL_RESERVED2 = offsetof(struct ctrl_reg, reserved1), 161 CTRL_RESERVED2 = offsetof(struct ctrl_reg, reserved1),
162 GEN_OUTPUT_AB = offsetof(struct ctrl_reg, gen_output_AB), 162 GEN_OUTPUT_AB = offsetof(struct ctrl_reg, gen_output_AB),
163 NON_INT_INPUT = offsetof(struct ctrl_reg, non_int_input), 163 NON_INT_INPUT = offsetof(struct ctrl_reg, non_int_input),
164 CTRL_RESERVED3 = offsetof(struct ctrl_reg, reserved3), 164 CTRL_RESERVED3 = offsetof(struct ctrl_reg, reserved3),
165 CTRL_RESERVED4 = offsetof(struct ctrl_reg, reserved4), 165 CTRL_RESERVED4 = offsetof(struct ctrl_reg, reserved4),
166 CTRL_RESERVED5 = offsetof(struct ctrl_reg, reserved5), 166 CTRL_RESERVED5 = offsetof(struct ctrl_reg, reserved5),
167 CTRL_RESERVED6 = offsetof(struct ctrl_reg, reserved6), 167 CTRL_RESERVED6 = offsetof(struct ctrl_reg, reserved6),
168 CTRL_RESERVED7 = offsetof(struct ctrl_reg, reserved7), 168 CTRL_RESERVED7 = offsetof(struct ctrl_reg, reserved7),
169 CTRL_RESERVED8 = offsetof(struct ctrl_reg, reserved8), 169 CTRL_RESERVED8 = offsetof(struct ctrl_reg, reserved8),
170 SLOT_MASK = offsetof(struct ctrl_reg, slot_mask), 170 SLOT_MASK = offsetof(struct ctrl_reg, slot_mask),
171 CTRL_RESERVED9 = offsetof(struct ctrl_reg, reserved9), 171 CTRL_RESERVED9 = offsetof(struct ctrl_reg, reserved9),
172 CTRL_RESERVED10 = offsetof(struct ctrl_reg, reserved10), 172 CTRL_RESERVED10 = offsetof(struct ctrl_reg, reserved10),
173 CTRL_RESERVED11 = offsetof(struct ctrl_reg, reserved11), 173 CTRL_RESERVED11 = offsetof(struct ctrl_reg, reserved11),
174 SLOT_SERR = offsetof(struct ctrl_reg, slot_SERR), 174 SLOT_SERR = offsetof(struct ctrl_reg, slot_SERR),
@@ -220,15 +220,15 @@ struct slot_rt {
220/* offsets to the hotplug slot resource table registers based on the above structure layout */ 220/* offsets to the hotplug slot resource table registers based on the above structure layout */
221enum slot_rt_offsets { 221enum slot_rt_offsets {
222 DEV_FUNC = offsetof(struct slot_rt, dev_func), 222 DEV_FUNC = offsetof(struct slot_rt, dev_func),
223 PRIMARY_BUS = offsetof(struct slot_rt, primary_bus), 223 PRIMARY_BUS = offsetof(struct slot_rt, primary_bus),
224 SECONDARY_BUS = offsetof(struct slot_rt, secondary_bus), 224 SECONDARY_BUS = offsetof(struct slot_rt, secondary_bus),
225 MAX_BUS = offsetof(struct slot_rt, max_bus), 225 MAX_BUS = offsetof(struct slot_rt, max_bus),
226 IO_BASE = offsetof(struct slot_rt, io_base), 226 IO_BASE = offsetof(struct slot_rt, io_base),
227 IO_LENGTH = offsetof(struct slot_rt, io_length), 227 IO_LENGTH = offsetof(struct slot_rt, io_length),
228 MEM_BASE = offsetof(struct slot_rt, mem_base), 228 MEM_BASE = offsetof(struct slot_rt, mem_base),
229 MEM_LENGTH = offsetof(struct slot_rt, mem_length), 229 MEM_LENGTH = offsetof(struct slot_rt, mem_length),
230 PRE_MEM_BASE = offsetof(struct slot_rt, pre_mem_base), 230 PRE_MEM_BASE = offsetof(struct slot_rt, pre_mem_base),
231 PRE_MEM_LENGTH = offsetof(struct slot_rt, pre_mem_length), 231 PRE_MEM_LENGTH = offsetof(struct slot_rt, pre_mem_length),
232}; 232};
233 233
234struct pci_func { 234struct pci_func {
@@ -471,7 +471,7 @@ static inline void return_resource(struct pci_resource **head, struct pci_resour
471static inline void set_SOGO(struct controller *ctrl) 471static inline void set_SOGO(struct controller *ctrl)
472{ 472{
473 u16 misc; 473 u16 misc;
474 474
475 misc = readw(ctrl->hpc_reg + MISC); 475 misc = readw(ctrl->hpc_reg + MISC);
476 misc = (misc | 0x0001) & 0xFFFB; 476 misc = (misc | 0x0001) & 0xFFFB;
477 writew(misc, ctrl->hpc_reg + MISC); 477 writew(misc, ctrl->hpc_reg + MISC);
@@ -481,7 +481,7 @@ static inline void set_SOGO(struct controller *ctrl)
481static inline void amber_LED_on(struct controller *ctrl, u8 slot) 481static inline void amber_LED_on(struct controller *ctrl, u8 slot)
482{ 482{
483 u32 led_control; 483 u32 led_control;
484 484
485 led_control = readl(ctrl->hpc_reg + LED_CONTROL); 485 led_control = readl(ctrl->hpc_reg + LED_CONTROL);
486 led_control |= (0x01010000L << slot); 486 led_control |= (0x01010000L << slot);
487 writel(led_control, ctrl->hpc_reg + LED_CONTROL); 487 writel(led_control, ctrl->hpc_reg + LED_CONTROL);
@@ -491,7 +491,7 @@ static inline void amber_LED_on(struct controller *ctrl, u8 slot)
491static inline void amber_LED_off(struct controller *ctrl, u8 slot) 491static inline void amber_LED_off(struct controller *ctrl, u8 slot)
492{ 492{
493 u32 led_control; 493 u32 led_control;
494 494
495 led_control = readl(ctrl->hpc_reg + LED_CONTROL); 495 led_control = readl(ctrl->hpc_reg + LED_CONTROL);
496 led_control &= ~(0x01010000L << slot); 496 led_control &= ~(0x01010000L << slot);
497 writel(led_control, ctrl->hpc_reg + LED_CONTROL); 497 writel(led_control, ctrl->hpc_reg + LED_CONTROL);
@@ -504,7 +504,7 @@ static inline int read_amber_LED(struct controller *ctrl, u8 slot)
504 504
505 led_control = readl(ctrl->hpc_reg + LED_CONTROL); 505 led_control = readl(ctrl->hpc_reg + LED_CONTROL);
506 led_control &= (0x01010000L << slot); 506 led_control &= (0x01010000L << slot);
507 507
508 return led_control ? 1 : 0; 508 return led_control ? 1 : 0;
509} 509}
510 510
@@ -512,7 +512,7 @@ static inline int read_amber_LED(struct controller *ctrl, u8 slot)
512static inline void green_LED_on(struct controller *ctrl, u8 slot) 512static inline void green_LED_on(struct controller *ctrl, u8 slot)
513{ 513{
514 u32 led_control; 514 u32 led_control;
515 515
516 led_control = readl(ctrl->hpc_reg + LED_CONTROL); 516 led_control = readl(ctrl->hpc_reg + LED_CONTROL);
517 led_control |= 0x0101L << slot; 517 led_control |= 0x0101L << slot;
518 writel(led_control, ctrl->hpc_reg + LED_CONTROL); 518 writel(led_control, ctrl->hpc_reg + LED_CONTROL);
@@ -521,7 +521,7 @@ static inline void green_LED_on(struct controller *ctrl, u8 slot)
521static inline void green_LED_off(struct controller *ctrl, u8 slot) 521static inline void green_LED_off(struct controller *ctrl, u8 slot)
522{ 522{
523 u32 led_control; 523 u32 led_control;
524 524
525 led_control = readl(ctrl->hpc_reg + LED_CONTROL); 525 led_control = readl(ctrl->hpc_reg + LED_CONTROL);
526 led_control &= ~(0x0101L << slot); 526 led_control &= ~(0x0101L << slot);
527 writel(led_control, ctrl->hpc_reg + LED_CONTROL); 527 writel(led_control, ctrl->hpc_reg + LED_CONTROL);
@@ -531,7 +531,7 @@ static inline void green_LED_off(struct controller *ctrl, u8 slot)
531static inline void green_LED_blink(struct controller *ctrl, u8 slot) 531static inline void green_LED_blink(struct controller *ctrl, u8 slot)
532{ 532{
533 u32 led_control; 533 u32 led_control;
534 534
535 led_control = readl(ctrl->hpc_reg + LED_CONTROL); 535 led_control = readl(ctrl->hpc_reg + LED_CONTROL);
536 led_control &= ~(0x0101L << slot); 536 led_control &= ~(0x0101L << slot);
537 led_control |= (0x0001L << slot); 537 led_control |= (0x0001L << slot);
@@ -586,11 +586,11 @@ static inline u8 read_slot_enable(struct controller *ctrl)
586static inline u8 get_controller_speed(struct controller *ctrl) 586static inline u8 get_controller_speed(struct controller *ctrl)
587{ 587{
588 u8 curr_freq; 588 u8 curr_freq;
589 u16 misc; 589 u16 misc;
590 590
591 if (ctrl->pcix_support) { 591 if (ctrl->pcix_support) {
592 curr_freq = readb(ctrl->hpc_reg + NEXT_CURR_FREQ); 592 curr_freq = readb(ctrl->hpc_reg + NEXT_CURR_FREQ);
593 if ((curr_freq & 0xB0) == 0xB0) 593 if ((curr_freq & 0xB0) == 0xB0)
594 return PCI_SPEED_133MHz_PCIX; 594 return PCI_SPEED_133MHz_PCIX;
595 if ((curr_freq & 0xA0) == 0xA0) 595 if ((curr_freq & 0xA0) == 0xA0)
596 return PCI_SPEED_100MHz_PCIX; 596 return PCI_SPEED_100MHz_PCIX;
@@ -602,10 +602,10 @@ static inline u8 get_controller_speed(struct controller *ctrl)
602 return PCI_SPEED_33MHz; 602 return PCI_SPEED_33MHz;
603 } 603 }
604 604
605 misc = readw(ctrl->hpc_reg + MISC); 605 misc = readw(ctrl->hpc_reg + MISC);
606 return (misc & 0x0800) ? PCI_SPEED_66MHz : PCI_SPEED_33MHz; 606 return (misc & 0x0800) ? PCI_SPEED_66MHz : PCI_SPEED_33MHz;
607} 607}
608 608
609 609
610/* 610/*
611 * get_adapter_speed - find the max supported frequency/mode of adapter. 611 * get_adapter_speed - find the max supported frequency/mode of adapter.
diff --git a/drivers/pci/hotplug/cpqphp_core.c b/drivers/pci/hotplug/cpqphp_core.c
index c2e1bcbb28a7..55eae4c233c9 100644
--- a/drivers/pci/hotplug/cpqphp_core.c
+++ b/drivers/pci/hotplug/cpqphp_core.c
@@ -25,7 +25,7 @@
25 * Send feedback to <greg@kroah.com> 25 * Send feedback to <greg@kroah.com>
26 * 26 *
27 * Jan 12, 2003 - Added 66/100/133MHz PCI-X support, 27 * Jan 12, 2003 - Added 66/100/133MHz PCI-X support,
28 * Torben Mathiasen <torben.mathiasen@hp.com> 28 * Torben Mathiasen <torben.mathiasen@hp.com>
29 * 29 *
30 */ 30 */
31 31
@@ -100,8 +100,8 @@ static struct hotplug_slot_ops cpqphp_hotplug_slot_ops = {
100 .get_attention_status = get_attention_status, 100 .get_attention_status = get_attention_status,
101 .get_latch_status = get_latch_status, 101 .get_latch_status = get_latch_status,
102 .get_adapter_status = get_adapter_status, 102 .get_adapter_status = get_adapter_status,
103 .get_max_bus_speed = get_max_bus_speed, 103 .get_max_bus_speed = get_max_bus_speed,
104 .get_cur_bus_speed = get_cur_bus_speed, 104 .get_cur_bus_speed = get_cur_bus_speed,
105}; 105};
106 106
107 107
@@ -144,7 +144,7 @@ static void __iomem * detect_SMBIOS_pointer(void __iomem *begin, void __iomem *e
144 break; 144 break;
145 } 145 }
146 } 146 }
147 147
148 if (!status) 148 if (!status)
149 fp = NULL; 149 fp = NULL;
150 150
@@ -292,7 +292,7 @@ static void __iomem *get_SMBIOS_entry(void __iomem *smbios_start,
292 if (!smbios_table) 292 if (!smbios_table)
293 return NULL; 293 return NULL;
294 294
295 if (!previous) { 295 if (!previous) {
296 previous = smbios_start; 296 previous = smbios_start;
297 } else { 297 } else {
298 previous = get_subsequent_smbios_entry(smbios_start, 298 previous = get_subsequent_smbios_entry(smbios_start,
@@ -300,7 +300,7 @@ static void __iomem *get_SMBIOS_entry(void __iomem *smbios_start,
300 } 300 }
301 301
302 while (previous) { 302 while (previous) {
303 if (readb(previous + SMBIOS_GENERIC_TYPE) != type) { 303 if (readb(previous + SMBIOS_GENERIC_TYPE) != type) {
304 previous = get_subsequent_smbios_entry(smbios_start, 304 previous = get_subsequent_smbios_entry(smbios_start,
305 smbios_table, previous); 305 smbios_table, previous);
306 } else { 306 } else {
@@ -426,7 +426,7 @@ static int ctrl_slot_setup(struct controller *ctrl,
426 cpq_get_latch_status(ctrl, slot); 426 cpq_get_latch_status(ctrl, slot);
427 hotplug_slot_info->adapter_status = 427 hotplug_slot_info->adapter_status =
428 get_presence_status(ctrl, slot); 428 get_presence_status(ctrl, slot);
429 429
430 dbg("registering bus %d, dev %d, number %d, " 430 dbg("registering bus %d, dev %d, number %d, "
431 "ctrl->slot_device_offset %d, slot %d\n", 431 "ctrl->slot_device_offset %d, slot %d\n",
432 slot->bus, slot->device, 432 slot->bus, slot->device,
@@ -440,7 +440,7 @@ static int ctrl_slot_setup(struct controller *ctrl,
440 err("pci_hp_register failed with error %d\n", result); 440 err("pci_hp_register failed with error %d\n", result);
441 goto error_info; 441 goto error_info;
442 } 442 }
443 443
444 slot->next = ctrl->slot; 444 slot->next = ctrl->slot;
445 ctrl->slot = slot; 445 ctrl->slot = slot;
446 446
@@ -563,9 +563,9 @@ get_slot_mapping(struct pci_bus *bus, u8 bus_num, u8 dev_num, u8 *slot)
563 563
564 } 564 }
565 565
566 // If we got here, we didn't find an entry in the IRQ mapping table 566 // If we got here, we didn't find an entry in the IRQ mapping table
567 // for the target PCI device. If we did determine that the target 567 // for the target PCI device. If we did determine that the target
568 // device is on the other side of a PCI-to-PCI bridge, return the 568 // device is on the other side of a PCI-to-PCI bridge, return the
569 // slot number for the bridge. 569 // slot number for the bridge.
570 if (bridgeSlot != 0xFF) { 570 if (bridgeSlot != 0xFF) {
571 *slot = bridgeSlot; 571 *slot = bridgeSlot;
@@ -719,7 +719,7 @@ static int hardware_test(struct hotplug_slot *hotplug_slot, u32 value)
719 719
720 dbg("%s - physical_slot = %s\n", __func__, slot_name(slot)); 720 dbg("%s - physical_slot = %s\n", __func__, slot_name(slot));
721 721
722 return cpqhp_hardware_test(ctrl, value); 722 return cpqhp_hardware_test(ctrl, value);
723} 723}
724 724
725 725
@@ -738,7 +738,7 @@ static int get_attention_status(struct hotplug_slot *hotplug_slot, u8 *value)
738{ 738{
739 struct slot *slot = hotplug_slot->private; 739 struct slot *slot = hotplug_slot->private;
740 struct controller *ctrl = slot->ctrl; 740 struct controller *ctrl = slot->ctrl;
741 741
742 dbg("%s - physical_slot = %s\n", __func__, slot_name(slot)); 742 dbg("%s - physical_slot = %s\n", __func__, slot_name(slot));
743 743
744 *value = cpq_get_attention_status(ctrl, slot); 744 *value = cpq_get_attention_status(ctrl, slot);
@@ -832,7 +832,7 @@ static int cpqhpc_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
832 } 832 }
833 833
834 /* Check for the proper subsytem ID's 834 /* Check for the proper subsytem ID's
835 * Intel uses a different SSID programming model than Compaq. 835 * Intel uses a different SSID programming model than Compaq.
836 * For Intel, each SSID bit identifies a PHP capability. 836 * For Intel, each SSID bit identifies a PHP capability.
837 * Also Intel HPC's may have RID=0. 837 * Also Intel HPC's may have RID=0.
838 */ 838 */
@@ -1087,7 +1087,7 @@ static int cpqhpc_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
1087 if (rc) { 1087 if (rc) {
1088 goto err_free_bus; 1088 goto err_free_bus;
1089 } 1089 }
1090 1090
1091 dbg("pdev = %p\n", pdev); 1091 dbg("pdev = %p\n", pdev);
1092 dbg("pci resource start %llx\n", (unsigned long long)pci_resource_start(pdev, 0)); 1092 dbg("pci resource start %llx\n", (unsigned long long)pci_resource_start(pdev, 0));
1093 dbg("pci resource len %llx\n", (unsigned long long)pci_resource_len(pdev, 0)); 1093 dbg("pci resource len %llx\n", (unsigned long long)pci_resource_len(pdev, 0));
@@ -1182,7 +1182,7 @@ static int cpqhpc_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
1182 __func__, rc); 1182 __func__, rc);
1183 goto err_iounmap; 1183 goto err_iounmap;
1184 } 1184 }
1185 1185
1186 /* Mask all general input interrupts */ 1186 /* Mask all general input interrupts */
1187 writel(0xFFFFFFFFL, ctrl->hpc_reg + INT_MASK); 1187 writel(0xFFFFFFFFL, ctrl->hpc_reg + INT_MASK);
1188 1188
@@ -1291,7 +1291,6 @@ err_disable_device:
1291 return rc; 1291 return rc;
1292} 1292}
1293 1293
1294
1295static int one_time_init(void) 1294static int one_time_init(void)
1296{ 1295{
1297 int loop; 1296 int loop;
@@ -1328,10 +1327,10 @@ static int one_time_init(void)
1328 retval = -EIO; 1327 retval = -EIO;
1329 goto error; 1328 goto error;
1330 } 1329 }
1331 1330
1332 /* Now, map the int15 entry point if we are on compaq specific hardware */ 1331 /* Now, map the int15 entry point if we are on compaq specific hardware */
1333 compaq_nvram_init(cpqhp_rom_start); 1332 compaq_nvram_init(cpqhp_rom_start);
1334 1333
1335 /* Map smbios table entry point structure */ 1334 /* Map smbios table entry point structure */
1336 smbios_table = detect_SMBIOS_pointer(cpqhp_rom_start, 1335 smbios_table = detect_SMBIOS_pointer(cpqhp_rom_start,
1337 cpqhp_rom_start + ROM_PHY_LEN); 1336 cpqhp_rom_start + ROM_PHY_LEN);
@@ -1361,7 +1360,6 @@ error:
1361 return retval; 1360 return retval;
1362} 1361}
1363 1362
1364
1365static void __exit unload_cpqphpd(void) 1363static void __exit unload_cpqphpd(void)
1366{ 1364{
1367 struct pci_func *next; 1365 struct pci_func *next;
@@ -1381,10 +1379,10 @@ static void __exit unload_cpqphpd(void)
1381 if (ctrl->hpc_reg) { 1379 if (ctrl->hpc_reg) {
1382 u16 misc; 1380 u16 misc;
1383 rc = read_slot_enable (ctrl); 1381 rc = read_slot_enable (ctrl);
1384 1382
1385 writeb(0, ctrl->hpc_reg + SLOT_SERR); 1383 writeb(0, ctrl->hpc_reg + SLOT_SERR);
1386 writel(0xFFFFFFC0L | ~rc, ctrl->hpc_reg + INT_MASK); 1384 writel(0xFFFFFFC0L | ~rc, ctrl->hpc_reg + INT_MASK);
1387 1385
1388 misc = readw(ctrl->hpc_reg + MISC); 1386 misc = readw(ctrl->hpc_reg + MISC);
1389 misc &= 0xFFFD; 1387 misc &= 0xFFFD;
1390 writew(misc, ctrl->hpc_reg + MISC); 1388 writew(misc, ctrl->hpc_reg + MISC);
@@ -1475,27 +1473,23 @@ static void __exit unload_cpqphpd(void)
1475 iounmap(smbios_start); 1473 iounmap(smbios_start);
1476} 1474}
1477 1475
1478
1479
1480static struct pci_device_id hpcd_pci_tbl[] = { 1476static struct pci_device_id hpcd_pci_tbl[] = {
1481 { 1477 {
1482 /* handle any PCI Hotplug controller */ 1478 /* handle any PCI Hotplug controller */
1483 .class = ((PCI_CLASS_SYSTEM_PCI_HOTPLUG << 8) | 0x00), 1479 .class = ((PCI_CLASS_SYSTEM_PCI_HOTPLUG << 8) | 0x00),
1484 .class_mask = ~0, 1480 .class_mask = ~0,
1485 1481
1486 /* no matter who makes it */ 1482 /* no matter who makes it */
1487 .vendor = PCI_ANY_ID, 1483 .vendor = PCI_ANY_ID,
1488 .device = PCI_ANY_ID, 1484 .device = PCI_ANY_ID,
1489 .subvendor = PCI_ANY_ID, 1485 .subvendor = PCI_ANY_ID,
1490 .subdevice = PCI_ANY_ID, 1486 .subdevice = PCI_ANY_ID,
1491 1487
1492 }, { /* end: all zeroes */ } 1488 }, { /* end: all zeroes */ }
1493}; 1489};
1494 1490
1495MODULE_DEVICE_TABLE(pci, hpcd_pci_tbl); 1491MODULE_DEVICE_TABLE(pci, hpcd_pci_tbl);
1496 1492
1497
1498
1499static struct pci_driver cpqhpc_driver = { 1493static struct pci_driver cpqhpc_driver = {
1500 .name = "compaq_pci_hotplug", 1494 .name = "compaq_pci_hotplug",
1501 .id_table = hpcd_pci_tbl, 1495 .id_table = hpcd_pci_tbl,
@@ -1503,8 +1497,6 @@ static struct pci_driver cpqhpc_driver = {
1503 /* remove: cpqhpc_remove_one, */ 1497 /* remove: cpqhpc_remove_one, */
1504}; 1498};
1505 1499
1506
1507
1508static int __init cpqhpc_init(void) 1500static int __init cpqhpc_init(void)
1509{ 1501{
1510 int result; 1502 int result;
@@ -1518,7 +1510,6 @@ static int __init cpqhpc_init(void)
1518 return result; 1510 return result;
1519} 1511}
1520 1512
1521
1522static void __exit cpqhpc_cleanup(void) 1513static void __exit cpqhpc_cleanup(void)
1523{ 1514{
1524 dbg("unload_cpqphpd()\n"); 1515 dbg("unload_cpqphpd()\n");
@@ -1529,8 +1520,5 @@ static void __exit cpqhpc_cleanup(void)
1529 cpqhp_shutdown_debugfs(); 1520 cpqhp_shutdown_debugfs();
1530} 1521}
1531 1522
1532
1533module_init(cpqhpc_init); 1523module_init(cpqhpc_init);
1534module_exit(cpqhpc_cleanup); 1524module_exit(cpqhpc_cleanup);
1535
1536
diff --git a/drivers/pci/hotplug/cpqphp_ctrl.c b/drivers/pci/hotplug/cpqphp_ctrl.c
index cc227a8c4b11..ec3a76519af2 100644
--- a/drivers/pci/hotplug/cpqphp_ctrl.c
+++ b/drivers/pci/hotplug/cpqphp_ctrl.c
@@ -642,7 +642,7 @@ static struct pci_resource *get_max_resource(struct pci_resource **head, u32 siz
642 return NULL; 642 return NULL;
643 643
644 for (max = *head; max; max = max->next) { 644 for (max = *head; max; max = max->next) {
645 /* If not big enough we could probably just bail, 645 /* If not big enough we could probably just bail,
646 * instead we'll continue to the next. */ 646 * instead we'll continue to the next. */
647 if (max->length < size) 647 if (max->length < size)
648 continue; 648 continue;
@@ -886,7 +886,7 @@ irqreturn_t cpqhp_ctrl_intr(int IRQ, void *data)
886 u32 Diff; 886 u32 Diff;
887 u32 temp_dword; 887 u32 temp_dword;
888 888
889 889
890 misc = readw(ctrl->hpc_reg + MISC); 890 misc = readw(ctrl->hpc_reg + MISC);
891 /*************************************** 891 /***************************************
892 * Check to see if it was our interrupt 892 * Check to see if it was our interrupt
@@ -1130,33 +1130,33 @@ static u8 set_controller_speed(struct controller *ctrl, u8 adapter_speed, u8 hp_
1130 u8 slot_power = readb(ctrl->hpc_reg + SLOT_POWER); 1130 u8 slot_power = readb(ctrl->hpc_reg + SLOT_POWER);
1131 u16 reg16; 1131 u16 reg16;
1132 u32 leds = readl(ctrl->hpc_reg + LED_CONTROL); 1132 u32 leds = readl(ctrl->hpc_reg + LED_CONTROL);
1133 1133
1134 if (ctrl->speed == adapter_speed) 1134 if (ctrl->speed == adapter_speed)
1135 return 0; 1135 return 0;
1136 1136
1137 /* We don't allow freq/mode changes if we find another adapter running 1137 /* We don't allow freq/mode changes if we find another adapter running
1138 * in another slot on this controller */ 1138 * in another slot on this controller */
1139 for(slot = ctrl->slot; slot; slot = slot->next) { 1139 for(slot = ctrl->slot; slot; slot = slot->next) {
1140 if (slot->device == (hp_slot + ctrl->slot_device_offset)) 1140 if (slot->device == (hp_slot + ctrl->slot_device_offset))
1141 continue; 1141 continue;
1142 if (!slot->hotplug_slot || !slot->hotplug_slot->info) 1142 if (!slot->hotplug_slot || !slot->hotplug_slot->info)
1143 continue; 1143 continue;
1144 if (slot->hotplug_slot->info->adapter_status == 0) 1144 if (slot->hotplug_slot->info->adapter_status == 0)
1145 continue; 1145 continue;
1146 /* If another adapter is running on the same segment but at a 1146 /* If another adapter is running on the same segment but at a
1147 * lower speed/mode, we allow the new adapter to function at 1147 * lower speed/mode, we allow the new adapter to function at
1148 * this rate if supported */ 1148 * this rate if supported */
1149 if (ctrl->speed < adapter_speed) 1149 if (ctrl->speed < adapter_speed)
1150 return 0; 1150 return 0;
1151 1151
1152 return 1; 1152 return 1;
1153 } 1153 }
1154 1154
1155 /* If the controller doesn't support freq/mode changes and the 1155 /* If the controller doesn't support freq/mode changes and the
1156 * controller is running at a higher mode, we bail */ 1156 * controller is running at a higher mode, we bail */
1157 if ((ctrl->speed > adapter_speed) && (!ctrl->pcix_speed_capability)) 1157 if ((ctrl->speed > adapter_speed) && (!ctrl->pcix_speed_capability))
1158 return 1; 1158 return 1;
1159 1159
1160 /* But we allow the adapter to run at a lower rate if possible */ 1160 /* But we allow the adapter to run at a lower rate if possible */
1161 if ((ctrl->speed < adapter_speed) && (!ctrl->pcix_speed_capability)) 1161 if ((ctrl->speed < adapter_speed) && (!ctrl->pcix_speed_capability))
1162 return 0; 1162 return 0;
@@ -1171,22 +1171,22 @@ static u8 set_controller_speed(struct controller *ctrl, u8 adapter_speed, u8 hp_
1171 1171
1172 writel(0x0L, ctrl->hpc_reg + LED_CONTROL); 1172 writel(0x0L, ctrl->hpc_reg + LED_CONTROL);
1173 writeb(0x00, ctrl->hpc_reg + SLOT_ENABLE); 1173 writeb(0x00, ctrl->hpc_reg + SLOT_ENABLE);
1174 1174
1175 set_SOGO(ctrl); 1175 set_SOGO(ctrl);
1176 wait_for_ctrl_irq(ctrl); 1176 wait_for_ctrl_irq(ctrl);
1177 1177
1178 if (adapter_speed != PCI_SPEED_133MHz_PCIX) 1178 if (adapter_speed != PCI_SPEED_133MHz_PCIX)
1179 reg = 0xF5; 1179 reg = 0xF5;
1180 else 1180 else
1181 reg = 0xF4; 1181 reg = 0xF4;
1182 pci_write_config_byte(ctrl->pci_dev, 0x41, reg); 1182 pci_write_config_byte(ctrl->pci_dev, 0x41, reg);
1183 1183
1184 reg16 = readw(ctrl->hpc_reg + NEXT_CURR_FREQ); 1184 reg16 = readw(ctrl->hpc_reg + NEXT_CURR_FREQ);
1185 reg16 &= ~0x000F; 1185 reg16 &= ~0x000F;
1186 switch(adapter_speed) { 1186 switch(adapter_speed) {
1187 case(PCI_SPEED_133MHz_PCIX): 1187 case(PCI_SPEED_133MHz_PCIX):
1188 reg = 0x75; 1188 reg = 0x75;
1189 reg16 |= 0xB; 1189 reg16 |= 0xB;
1190 break; 1190 break;
1191 case(PCI_SPEED_100MHz_PCIX): 1191 case(PCI_SPEED_100MHz_PCIX):
1192 reg = 0x74; 1192 reg = 0x74;
@@ -1203,47 +1203,47 @@ static u8 set_controller_speed(struct controller *ctrl, u8 adapter_speed, u8 hp_
1203 default: /* 33MHz PCI 2.2 */ 1203 default: /* 33MHz PCI 2.2 */
1204 reg = 0x71; 1204 reg = 0x71;
1205 break; 1205 break;
1206 1206
1207 } 1207 }
1208 reg16 |= 0xB << 12; 1208 reg16 |= 0xB << 12;
1209 writew(reg16, ctrl->hpc_reg + NEXT_CURR_FREQ); 1209 writew(reg16, ctrl->hpc_reg + NEXT_CURR_FREQ);
1210 1210
1211 mdelay(5); 1211 mdelay(5);
1212 1212
1213 /* Reenable interrupts */ 1213 /* Reenable interrupts */
1214 writel(0, ctrl->hpc_reg + INT_MASK); 1214 writel(0, ctrl->hpc_reg + INT_MASK);
1215 1215
1216 pci_write_config_byte(ctrl->pci_dev, 0x41, reg); 1216 pci_write_config_byte(ctrl->pci_dev, 0x41, reg);
1217 1217
1218 /* Restart state machine */ 1218 /* Restart state machine */
1219 reg = ~0xF; 1219 reg = ~0xF;
1220 pci_read_config_byte(ctrl->pci_dev, 0x43, &reg); 1220 pci_read_config_byte(ctrl->pci_dev, 0x43, &reg);
1221 pci_write_config_byte(ctrl->pci_dev, 0x43, reg); 1221 pci_write_config_byte(ctrl->pci_dev, 0x43, reg);
1222 1222
1223 /* Only if mode change...*/ 1223 /* Only if mode change...*/
1224 if (((ctrl->speed == PCI_SPEED_66MHz) && (adapter_speed == PCI_SPEED_66MHz_PCIX)) || 1224 if (((ctrl->speed == PCI_SPEED_66MHz) && (adapter_speed == PCI_SPEED_66MHz_PCIX)) ||
1225 ((ctrl->speed == PCI_SPEED_66MHz_PCIX) && (adapter_speed == PCI_SPEED_66MHz))) 1225 ((ctrl->speed == PCI_SPEED_66MHz_PCIX) && (adapter_speed == PCI_SPEED_66MHz)))
1226 set_SOGO(ctrl); 1226 set_SOGO(ctrl);
1227 1227
1228 wait_for_ctrl_irq(ctrl); 1228 wait_for_ctrl_irq(ctrl);
1229 mdelay(1100); 1229 mdelay(1100);
1230 1230
1231 /* Restore LED/Slot state */ 1231 /* Restore LED/Slot state */
1232 writel(leds, ctrl->hpc_reg + LED_CONTROL); 1232 writel(leds, ctrl->hpc_reg + LED_CONTROL);
1233 writeb(slot_power, ctrl->hpc_reg + SLOT_ENABLE); 1233 writeb(slot_power, ctrl->hpc_reg + SLOT_ENABLE);
1234 1234
1235 set_SOGO(ctrl); 1235 set_SOGO(ctrl);
1236 wait_for_ctrl_irq(ctrl); 1236 wait_for_ctrl_irq(ctrl);
1237 1237
1238 ctrl->speed = adapter_speed; 1238 ctrl->speed = adapter_speed;
1239 slot = cpqhp_find_slot(ctrl, hp_slot + ctrl->slot_device_offset); 1239 slot = cpqhp_find_slot(ctrl, hp_slot + ctrl->slot_device_offset);
1240 1240
1241 info("Successfully changed frequency/mode for adapter in slot %d\n", 1241 info("Successfully changed frequency/mode for adapter in slot %d\n",
1242 slot->number); 1242 slot->number);
1243 return 0; 1243 return 0;
1244} 1244}
1245 1245
1246/* the following routines constitute the bulk of the 1246/* the following routines constitute the bulk of the
1247 hotplug controller logic 1247 hotplug controller logic
1248 */ 1248 */
1249 1249
@@ -1299,7 +1299,7 @@ static u32 board_replaced(struct pci_func *func, struct controller *ctrl)
1299 1299
1300 /* Wait for SOBS to be unset */ 1300 /* Wait for SOBS to be unset */
1301 wait_for_ctrl_irq (ctrl); 1301 wait_for_ctrl_irq (ctrl);
1302 1302
1303 adapter_speed = get_adapter_speed(ctrl, hp_slot); 1303 adapter_speed = get_adapter_speed(ctrl, hp_slot);
1304 if (ctrl->speed != adapter_speed) 1304 if (ctrl->speed != adapter_speed)
1305 if (set_controller_speed(ctrl, adapter_speed, hp_slot)) 1305 if (set_controller_speed(ctrl, adapter_speed, hp_slot))
@@ -1443,12 +1443,12 @@ static u32 board_added(struct pci_func *func, struct controller *ctrl)
1443 1443
1444 /* Wait for SOBS to be unset */ 1444 /* Wait for SOBS to be unset */
1445 wait_for_ctrl_irq (ctrl); 1445 wait_for_ctrl_irq (ctrl);
1446 1446
1447 adapter_speed = get_adapter_speed(ctrl, hp_slot); 1447 adapter_speed = get_adapter_speed(ctrl, hp_slot);
1448 if (ctrl->speed != adapter_speed) 1448 if (ctrl->speed != adapter_speed)
1449 if (set_controller_speed(ctrl, adapter_speed, hp_slot)) 1449 if (set_controller_speed(ctrl, adapter_speed, hp_slot))
1450 rc = WRONG_BUS_FREQUENCY; 1450 rc = WRONG_BUS_FREQUENCY;
1451 1451
1452 /* turn off board without attaching to the bus */ 1452 /* turn off board without attaching to the bus */
1453 disable_slot_power (ctrl, hp_slot); 1453 disable_slot_power (ctrl, hp_slot);
1454 1454
@@ -1461,7 +1461,7 @@ static u32 board_added(struct pci_func *func, struct controller *ctrl)
1461 1461
1462 if (rc) 1462 if (rc)
1463 return rc; 1463 return rc;
1464 1464
1465 p_slot = cpqhp_find_slot(ctrl, hp_slot + ctrl->slot_device_offset); 1465 p_slot = cpqhp_find_slot(ctrl, hp_slot + ctrl->slot_device_offset);
1466 1466
1467 /* turn on board and blink green LED */ 1467 /* turn on board and blink green LED */
@@ -1859,12 +1859,12 @@ static void interrupt_event_handler(struct controller *ctrl)
1859 info(msg_button_on, p_slot->number); 1859 info(msg_button_on, p_slot->number);
1860 } 1860 }
1861 mutex_lock(&ctrl->crit_sect); 1861 mutex_lock(&ctrl->crit_sect);
1862 1862
1863 dbg("blink green LED and turn off amber\n"); 1863 dbg("blink green LED and turn off amber\n");
1864 1864
1865 amber_LED_off (ctrl, hp_slot); 1865 amber_LED_off (ctrl, hp_slot);
1866 green_LED_blink (ctrl, hp_slot); 1866 green_LED_blink (ctrl, hp_slot);
1867 1867
1868 set_SOGO(ctrl); 1868 set_SOGO(ctrl);
1869 1869
1870 /* Wait for SOBS to be unset */ 1870 /* Wait for SOBS to be unset */
@@ -1958,7 +1958,7 @@ void cpqhp_pushbutton_thread(unsigned long slot)
1958 if (cpqhp_process_SI(ctrl, func) != 0) { 1958 if (cpqhp_process_SI(ctrl, func) != 0) {
1959 amber_LED_on(ctrl, hp_slot); 1959 amber_LED_on(ctrl, hp_slot);
1960 green_LED_off(ctrl, hp_slot); 1960 green_LED_off(ctrl, hp_slot);
1961 1961
1962 set_SOGO(ctrl); 1962 set_SOGO(ctrl);
1963 1963
1964 /* Wait for SOBS to be unset */ 1964 /* Wait for SOBS to be unset */
@@ -2079,7 +2079,7 @@ int cpqhp_process_SS(struct controller *ctrl, struct pci_func *func)
2079 struct pci_bus *pci_bus = ctrl->pci_bus; 2079 struct pci_bus *pci_bus = ctrl->pci_bus;
2080 int physical_slot=0; 2080 int physical_slot=0;
2081 2081
2082 device = func->device; 2082 device = func->device;
2083 func = cpqhp_slot_find(ctrl->bus, device, index++); 2083 func = cpqhp_slot_find(ctrl->bus, device, index++);
2084 p_slot = cpqhp_find_slot(ctrl, device); 2084 p_slot = cpqhp_find_slot(ctrl, device);
2085 if (p_slot) { 2085 if (p_slot) {
@@ -2216,7 +2216,7 @@ int cpqhp_hardware_test(struct controller *ctrl, int test_num)
2216 long_delay((3*HZ)/10); 2216 long_delay((3*HZ)/10);
2217 work_LED = work_LED >> 16; 2217 work_LED = work_LED >> 16;
2218 writel(work_LED, ctrl->hpc_reg + LED_CONTROL); 2218 writel(work_LED, ctrl->hpc_reg + LED_CONTROL);
2219 2219
2220 set_SOGO(ctrl); 2220 set_SOGO(ctrl);
2221 2221
2222 /* Wait for SOGO interrupt */ 2222 /* Wait for SOGO interrupt */
@@ -2339,7 +2339,7 @@ static u32 configure_new_device(struct controller * ctrl, struct pci_func * func
2339 2339
2340 2340
2341/* 2341/*
2342 Configuration logic that involves the hotplug data structures and 2342 Configuration logic that involves the hotplug data structures and
2343 their bookkeeping 2343 their bookkeeping
2344 */ 2344 */
2345 2345
@@ -2917,17 +2917,17 @@ static int configure_new_function(struct controller *ctrl, struct pci_func *func
2917 } /* End of base register loop */ 2917 } /* End of base register loop */
2918 if (cpqhp_legacy_mode) { 2918 if (cpqhp_legacy_mode) {
2919 /* Figure out which interrupt pin this function uses */ 2919 /* Figure out which interrupt pin this function uses */
2920 rc = pci_bus_read_config_byte (pci_bus, devfn, 2920 rc = pci_bus_read_config_byte (pci_bus, devfn,
2921 PCI_INTERRUPT_PIN, &temp_byte); 2921 PCI_INTERRUPT_PIN, &temp_byte);
2922 2922
2923 /* If this function needs an interrupt and we are behind 2923 /* If this function needs an interrupt and we are behind
2924 * a bridge and the pin is tied to something that's 2924 * a bridge and the pin is tied to something that's
2925 * alread mapped, set this one the same */ 2925 * alread mapped, set this one the same */
2926 if (temp_byte && resources->irqs && 2926 if (temp_byte && resources->irqs &&
2927 (resources->irqs->valid_INT & 2927 (resources->irqs->valid_INT &
2928 (0x01 << ((temp_byte + resources->irqs->barber_pole - 1) & 0x03)))) { 2928 (0x01 << ((temp_byte + resources->irqs->barber_pole - 1) & 0x03)))) {
2929 /* We have to share with something already set up */ 2929 /* We have to share with something already set up */
2930 IRQ = resources->irqs->interrupt[(temp_byte + 2930 IRQ = resources->irqs->interrupt[(temp_byte +
2931 resources->irqs->barber_pole - 1) & 0x03]; 2931 resources->irqs->barber_pole - 1) & 0x03];
2932 } else { 2932 } else {
2933 /* Program IRQ based on card type */ 2933 /* Program IRQ based on card type */
diff --git a/drivers/pci/hotplug/cpqphp_nvram.c b/drivers/pci/hotplug/cpqphp_nvram.c
index cb174888002b..76e110f0e3a6 100644
--- a/drivers/pci/hotplug/cpqphp_nvram.c
+++ b/drivers/pci/hotplug/cpqphp_nvram.c
@@ -113,7 +113,7 @@ static u32 add_byte( u32 **p_buffer, u8 value, u32 *used, u32 *avail)
113 113
114 if ((*used + 1) > *avail) 114 if ((*used + 1) > *avail)
115 return(1); 115 return(1);
116 116
117 *((u8*)*p_buffer) = value; 117 *((u8*)*p_buffer) = value;
118 tByte = (u8**)p_buffer; 118 tByte = (u8**)p_buffer;
119 (*tByte)++; 119 (*tByte)++;
@@ -170,10 +170,10 @@ static u32 access_EV (u16 operation, u8 *ev_name, u8 *buffer, u32 *buf_size)
170 unsigned long flags; 170 unsigned long flags;
171 int op = operation; 171 int op = operation;
172 int ret_val; 172 int ret_val;
173 173
174 if (!compaq_int15_entry_point) 174 if (!compaq_int15_entry_point)
175 return -ENODEV; 175 return -ENODEV;
176 176
177 spin_lock_irqsave(&int15_lock, flags); 177 spin_lock_irqsave(&int15_lock, flags);
178 __asm__ ( 178 __asm__ (
179 "xorl %%ebx,%%ebx\n" \ 179 "xorl %%ebx,%%ebx\n" \
@@ -187,7 +187,7 @@ static u32 access_EV (u16 operation, u8 *ev_name, u8 *buffer, u32 *buf_size)
187 "D" (buffer), "m" (compaq_int15_entry_point) 187 "D" (buffer), "m" (compaq_int15_entry_point)
188 : "%ebx", "%edx"); 188 : "%ebx", "%edx");
189 spin_unlock_irqrestore(&int15_lock, flags); 189 spin_unlock_irqrestore(&int15_lock, flags);
190 190
191 return((ret_val & 0xFF00) >> 8); 191 return((ret_val & 0xFF00) >> 8);
192} 192}
193 193
@@ -263,7 +263,7 @@ static u32 store_HRT (void __iomem *rom_start)
263 p_EV_header = (struct ev_hrt_header *) pFill; 263 p_EV_header = (struct ev_hrt_header *) pFill;
264 264
265 ctrl = cpqhp_ctrl_list; 265 ctrl = cpqhp_ctrl_list;
266 266
267 // The revision of this structure 267 // The revision of this structure
268 rc = add_byte( &pFill, 1 + ctrl->push_flag, &usedbytes, &available); 268 rc = add_byte( &pFill, 1 + ctrl->push_flag, &usedbytes, &available);
269 if (rc) 269 if (rc)
@@ -401,7 +401,7 @@ static u32 store_HRT (void __iomem *rom_start)
401 401
402 ctrl = ctrl->next; 402 ctrl = ctrl->next;
403 } 403 }
404 404
405 p_EV_header->num_of_ctrl = numCtrl; 405 p_EV_header->num_of_ctrl = numCtrl;
406 406
407 // Now store the EV 407 // Now store the EV
@@ -479,7 +479,7 @@ int compaq_nvram_load (void __iomem *rom_start, struct controller *ctrl)
479 function = p_ev_ctrl->function; 479 function = p_ev_ctrl->function;
480 480
481 while ((bus != ctrl->bus) || 481 while ((bus != ctrl->bus) ||
482 (device != PCI_SLOT(ctrl->pci_dev->devfn)) || 482 (device != PCI_SLOT(ctrl->pci_dev->devfn)) ||
483 (function != PCI_FUNC(ctrl->pci_dev->devfn))) { 483 (function != PCI_FUNC(ctrl->pci_dev->devfn))) {
484 nummem = p_ev_ctrl->mem_avail; 484 nummem = p_ev_ctrl->mem_avail;
485 numpmem = p_ev_ctrl->p_mem_avail; 485 numpmem = p_ev_ctrl->p_mem_avail;
@@ -640,14 +640,14 @@ int compaq_nvram_load (void __iomem *rom_start, struct controller *ctrl)
640 if (rc) 640 if (rc)
641 return(rc); 641 return(rc);
642 } else { 642 } else {
643 if ((evbuffer[0] != 0) && (!ctrl->push_flag)) 643 if ((evbuffer[0] != 0) && (!ctrl->push_flag))
644 return 1; 644 return 1;
645 } 645 }
646 646
647 return 0; 647 return 0;
648} 648}
649 649
650 650
651int compaq_nvram_store (void __iomem *rom_start) 651int compaq_nvram_store (void __iomem *rom_start)
652{ 652{
653 int rc = 1; 653 int rc = 1;
diff --git a/drivers/pci/hotplug/cpqphp_pci.c b/drivers/pci/hotplug/cpqphp_pci.c
index 6c0ed0fcb8ee..573a2702fb6a 100644
--- a/drivers/pci/hotplug/cpqphp_pci.c
+++ b/drivers/pci/hotplug/cpqphp_pci.c
@@ -82,7 +82,7 @@ static void __iomem *detect_HRT_floating_pointer(void __iomem *begin, void __iom
82} 82}
83 83
84 84
85int cpqhp_configure_device (struct controller* ctrl, struct pci_func* func) 85int cpqhp_configure_device (struct controller* ctrl, struct pci_func* func)
86{ 86{
87 unsigned char bus; 87 unsigned char bus;
88 struct pci_bus *child; 88 struct pci_bus *child;
@@ -116,10 +116,10 @@ int cpqhp_configure_device (struct controller* ctrl, struct pci_func* func)
116} 116}
117 117
118 118
119int cpqhp_unconfigure_device(struct pci_func* func) 119int cpqhp_unconfigure_device(struct pci_func* func)
120{ 120{
121 int j; 121 int j;
122 122
123 dbg("%s: bus/dev/func = %x/%x/%x\n", __func__, func->bus, func->device, func->function); 123 dbg("%s: bus/dev/func = %x/%x/%x\n", __func__, func->bus, func->device, func->function);
124 124
125 for (j=0; j<8 ; j++) { 125 for (j=0; j<8 ; j++) {
@@ -195,8 +195,8 @@ int cpqhp_set_irq (u8 bus_num, u8 dev_num, u8 int_pin, u8 irq_num)
195 195
196 196
197/* 197/*
198 * WTF??? This function isn't in the code, yet a function calls it, but the 198 * WTF??? This function isn't in the code, yet a function calls it, but the
199 * compiler optimizes it away? strange. Here as a placeholder to keep the 199 * compiler optimizes it away? strange. Here as a placeholder to keep the
200 * compiler happy. 200 * compiler happy.
201 */ 201 */
202static int PCI_ScanBusNonBridge (u8 bus, u8 device) 202static int PCI_ScanBusNonBridge (u8 bus, u8 device)
@@ -398,7 +398,7 @@ int cpqhp_save_config(struct controller *ctrl, int busnumber, int is_hot_plug)
398 398
399 index = 0; 399 index = 0;
400 new_slot = cpqhp_slot_find(busnumber, device, index++); 400 new_slot = cpqhp_slot_find(busnumber, device, index++);
401 while (new_slot && 401 while (new_slot &&
402 (new_slot->function != (u8) function)) 402 (new_slot->function != (u8) function))
403 new_slot = cpqhp_slot_find(busnumber, device, index++); 403 new_slot = cpqhp_slot_find(busnumber, device, index++);
404 404
@@ -1168,7 +1168,7 @@ int cpqhp_valid_replace(struct controller *ctrl, struct pci_func * func)
1168 * this function is for hot plug ADD! 1168 * this function is for hot plug ADD!
1169 * 1169 *
1170 * returns 0 if success 1170 * returns 0 if success
1171 */ 1171 */
1172int cpqhp_find_available_resources(struct controller *ctrl, void __iomem *rom_start) 1172int cpqhp_find_available_resources(struct controller *ctrl, void __iomem *rom_start)
1173{ 1173{
1174 u8 temp; 1174 u8 temp;