Commit dc3c3377 authored by Alan's avatar Alan Committed by Linus Torvalds

[PATCH] libata: fix combined mode

This is a slight variant on the patch I posted December 16th to fix
libata combined mode handling. The only real change is that we now
correctly also reserve BAR1,2,4. That is basically a neatness issue.

Jeff was unhappy about two things

1. That it didn't work in the case of one channel native one channel
legacy.

This is a silly complaint because the SFF layer in libata doesn't handle
this case yet anyway.

2. The case where combined mode is in use and IDE=n.

In this case the libata quirk code reserves the resources in question
correctly already.

Once the combined mode stuff is redone properly (2.6.21) then the entire
mess turns into a single pci_request_regions() for all cases and all the
ugly resource hackery goes away.

I'm sending this now rather than after running full test suites so that
it can get the maximal testing in a short time. I'll be running tests on
this after lunch.
Signed-off-by: default avatarAlan Cox <alan@redhat.com>
Cc: Jeff Garzik <jgarzik@pobox.com>
Acked-by: default avatarAlessandro Suardi <alessandro.suardi@gmail.com>
Acked-by: default avatarTheodore Tso <tytso@mit.edu>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent e22a9a8b
...@@ -1027,13 +1027,15 @@ int ata_pci_init_one (struct pci_dev *pdev, struct ata_port_info **port_info, ...@@ -1027,13 +1027,15 @@ int ata_pci_init_one (struct pci_dev *pdev, struct ata_port_info **port_info,
#endif #endif
} }
rc = pci_request_regions(pdev, DRV_NAME); if (!legacy_mode) {
if (rc) { rc = pci_request_regions(pdev, DRV_NAME);
disable_dev_on_err = 0; if (rc) {
goto err_out; disable_dev_on_err = 0;
} goto err_out;
}
if (legacy_mode) { } else {
/* Deal with combined mode hack. This side of the logic all
goes away once the combined mode hack is killed in 2.6.21 */
if (!request_region(ATA_PRIMARY_CMD, 8, "libata")) { if (!request_region(ATA_PRIMARY_CMD, 8, "libata")) {
struct resource *conflict, res; struct resource *conflict, res;
res.start = ATA_PRIMARY_CMD; res.start = ATA_PRIMARY_CMD;
...@@ -1071,6 +1073,13 @@ int ata_pci_init_one (struct pci_dev *pdev, struct ata_port_info **port_info, ...@@ -1071,6 +1073,13 @@ int ata_pci_init_one (struct pci_dev *pdev, struct ata_port_info **port_info,
} }
} else } else
legacy_mode |= ATA_PORT_SECONDARY; legacy_mode |= ATA_PORT_SECONDARY;
if (legacy_mode & ATA_PORT_PRIMARY)
pci_request_region(pdev, 1, DRV_NAME);
if (legacy_mode & ATA_PORT_SECONDARY)
pci_request_region(pdev, 3, DRV_NAME);
/* If there is a DMA resource, allocate it */
pci_request_region(pdev, 4, DRV_NAME);
} }
/* we have legacy mode, but all ports are unavailable */ /* we have legacy mode, but all ports are unavailable */
...@@ -1114,11 +1123,20 @@ int ata_pci_init_one (struct pci_dev *pdev, struct ata_port_info **port_info, ...@@ -1114,11 +1123,20 @@ int ata_pci_init_one (struct pci_dev *pdev, struct ata_port_info **port_info,
err_out_ent: err_out_ent:
kfree(probe_ent); kfree(probe_ent);
err_out_regions: err_out_regions:
if (legacy_mode & ATA_PORT_PRIMARY) /* All this conditional stuff is needed for the combined mode hack
release_region(ATA_PRIMARY_CMD, 8); until 2.6.21 when it can go */
if (legacy_mode & ATA_PORT_SECONDARY) if (legacy_mode) {
release_region(ATA_SECONDARY_CMD, 8); pci_release_region(pdev, 4);
pci_release_regions(pdev); if (legacy_mode & ATA_PORT_PRIMARY) {
release_region(ATA_PRIMARY_CMD, 8);
pci_release_region(pdev, 1);
}
if (legacy_mode & ATA_PORT_SECONDARY) {
release_region(ATA_SECONDARY_CMD, 8);
pci_release_region(pdev, 3);
}
} else
pci_release_regions(pdev);
err_out: err_out:
if (disable_dev_on_err) if (disable_dev_on_err)
pci_disable_device(pdev); pci_disable_device(pdev);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment