diff options
| author | Bartlomiej Zolnierkiewicz <bzolnier@gmail.com> | 2009-03-24 18:22:51 -0400 |
|---|---|---|
| committer | Bartlomiej Zolnierkiewicz <bzolnier@gmail.com> | 2009-03-24 18:22:51 -0400 |
| commit | f65dedfd7b75f19bde42bafbe84fddce18c42499 (patch) | |
| tree | 51a853e59afbd785a78e963181ae9f66c5af7c8f | |
| parent | 5bae8bf4508004d46487b3a18769d0ccff01c532 (diff) | |
ide: use ide_pci_is_in_compatibility_mode() in ide_pci_init_{one,two}()
Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
| -rw-r--r-- | drivers/ide/setup-pci.c | 16 |
1 files changed, 6 insertions, 10 deletions
diff --git a/drivers/ide/setup-pci.c b/drivers/ide/setup-pci.c index fa645fc41b86..79e3244691ec 100644 --- a/drivers/ide/setup-pci.c +++ b/drivers/ide/setup-pci.c | |||
| @@ -568,13 +568,11 @@ int ide_pci_init_one(struct pci_dev *dev, const struct ide_port_info *d, | |||
| 568 | goto out; | 568 | goto out; |
| 569 | 569 | ||
| 570 | /* fixup IRQ */ | 570 | /* fixup IRQ */ |
| 571 | hw[1].irq = hw[0].irq = ret; | 571 | if (ide_pci_is_in_compatibility_mode(dev)) { |
| 572 | |||
| 573 | if ((ret == 0 && (d->host_flags & IDE_HFLAG_LEGACY_IRQS)) || | ||
| 574 | (d->host_flags & IDE_HFLAG_FORCE_LEGACY_IRQS)) { | ||
| 575 | hw[0].irq = pci_get_legacy_ide_irq(dev, 0); | 572 | hw[0].irq = pci_get_legacy_ide_irq(dev, 0); |
| 576 | hw[1].irq = pci_get_legacy_ide_irq(dev, 1); | 573 | hw[1].irq = pci_get_legacy_ide_irq(dev, 1); |
| 577 | } | 574 | } else |
| 575 | hw[1].irq = hw[0].irq = ret; | ||
| 578 | 576 | ||
| 579 | ret = ide_host_register(host, d, hws); | 577 | ret = ide_host_register(host, d, hws); |
| 580 | if (ret) | 578 | if (ret) |
| @@ -625,13 +623,11 @@ int ide_pci_init_two(struct pci_dev *dev1, struct pci_dev *dev2, | |||
| 625 | goto out; | 623 | goto out; |
| 626 | 624 | ||
| 627 | /* fixup IRQ */ | 625 | /* fixup IRQ */ |
| 628 | hw[i*2 + 1].irq = hw[i*2].irq = ret; | 626 | if (ide_pci_is_in_compatibility_mode(pdev[i])) { |
| 629 | |||
| 630 | if ((ret == 0 && (d->host_flags & IDE_HFLAG_LEGACY_IRQS)) || | ||
| 631 | (d->host_flags & IDE_HFLAG_FORCE_LEGACY_IRQS)) { | ||
| 632 | hw[i*2].irq = pci_get_legacy_ide_irq(pdev[i], 0); | 627 | hw[i*2].irq = pci_get_legacy_ide_irq(pdev[i], 0); |
| 633 | hw[i*2 + 1].irq = pci_get_legacy_ide_irq(pdev[i], 1); | 628 | hw[i*2 + 1].irq = pci_get_legacy_ide_irq(pdev[i], 1); |
| 634 | } | 629 | } else |
| 630 | hw[i*2 + 1].irq = hw[i*2].irq = ret; | ||
| 635 | } | 631 | } |
| 636 | 632 | ||
| 637 | ret = ide_host_register(host, d, hws); | 633 | ret = ide_host_register(host, d, hws); |
