aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ata/libata-core.c
diff options
context:
space:
mode:
authorTejun Heo <htejun@gmail.com>2007-08-06 05:36:23 -0400
committerJeff Garzik <jeff@garzik.org>2007-10-12 14:55:30 -0400
commitf58229f8060055b08b34008ea08f31de1e2f003c (patch)
tree6ca5ef546671cb975ef3632fb032c238eaf1bb4c /drivers/ata/libata-core.c
parent9af5c9c97dc9d599281778864c72b385f0c63341 (diff)
libata-link: implement and use link/device iterators
Multiple links and different number of devices per link should be considered to iterate over links and devices. This patch implements and uses link and device iterators - ata_port_for_each_link() and ata_link_for_each_dev() - and ata_link_max_devices(). This change makes a lot of functions iterate over only possible devices instead of from dev 0 to dev ATA_MAX_DEVICES. All such changes have been examined and nothing should be broken. While at it, add a separating comment before device helpers to distinguish them better from link helpers and others. Signed-off-by: Tejun Heo <htejun@gmail.com> Signed-off-by: Jeff Garzik <jeff@garzik.org>
Diffstat (limited to 'drivers/ata/libata-core.c')
-rw-r--r--drivers/ata/libata-core.c58
1 files changed, 24 insertions, 34 deletions
diff --git a/drivers/ata/libata-core.c b/drivers/ata/libata-core.c
index dd2de485124a..f30c4771b3af 100644
--- a/drivers/ata/libata-core.c
+++ b/drivers/ata/libata-core.c
@@ -2105,21 +2105,19 @@ int ata_bus_probe(struct ata_port *ap)
2105{ 2105{
2106 unsigned int classes[ATA_MAX_DEVICES]; 2106 unsigned int classes[ATA_MAX_DEVICES];
2107 int tries[ATA_MAX_DEVICES]; 2107 int tries[ATA_MAX_DEVICES];
2108 int i, rc; 2108 int rc;
2109 struct ata_device *dev; 2109 struct ata_device *dev;
2110 2110
2111 ata_port_probe(ap); 2111 ata_port_probe(ap);
2112 2112
2113 for (i = 0; i < ATA_MAX_DEVICES; i++) 2113 ata_link_for_each_dev(dev, &ap->link)
2114 tries[i] = ATA_PROBE_MAX_TRIES; 2114 tries[dev->devno] = ATA_PROBE_MAX_TRIES;
2115 2115
2116 retry: 2116 retry:
2117 /* reset and determine device classes */ 2117 /* reset and determine device classes */
2118 ap->ops->phy_reset(ap); 2118 ap->ops->phy_reset(ap);
2119 2119
2120 for (i = 0; i < ATA_MAX_DEVICES; i++) { 2120 ata_link_for_each_dev(dev, &ap->link) {
2121 dev = &ap->link.device[i];
2122
2123 if (!(ap->flags & ATA_FLAG_DISABLED) && 2121 if (!(ap->flags & ATA_FLAG_DISABLED) &&
2124 dev->class != ATA_DEV_UNKNOWN) 2122 dev->class != ATA_DEV_UNKNOWN)
2125 classes[dev->devno] = dev->class; 2123 classes[dev->devno] = dev->class;
@@ -2134,18 +2132,16 @@ int ata_bus_probe(struct ata_port *ap)
2134 /* after the reset the device state is PIO 0 and the controller 2132 /* after the reset the device state is PIO 0 and the controller
2135 state is undefined. Record the mode */ 2133 state is undefined. Record the mode */
2136 2134
2137 for (i = 0; i < ATA_MAX_DEVICES; i++) 2135 ata_link_for_each_dev(dev, &ap->link)
2138 ap->link.device[i].pio_mode = XFER_PIO_0; 2136 dev->pio_mode = XFER_PIO_0;
2139 2137
2140 /* read IDENTIFY page and configure devices. We have to do the identify 2138 /* read IDENTIFY page and configure devices. We have to do the identify
2141 specific sequence bass-ackwards so that PDIAG- is released by 2139 specific sequence bass-ackwards so that PDIAG- is released by
2142 the slave device */ 2140 the slave device */
2143 2141
2144 for (i = ATA_MAX_DEVICES - 1; i >= 0; i--) { 2142 ata_link_for_each_dev(dev, &ap->link) {
2145 dev = &ap->link.device[i]; 2143 if (tries[dev->devno])
2146 2144 dev->class = classes[dev->devno];
2147 if (tries[i])
2148 dev->class = classes[i];
2149 2145
2150 if (!ata_dev_enabled(dev)) 2146 if (!ata_dev_enabled(dev))
2151 continue; 2147 continue;
@@ -2163,8 +2159,7 @@ int ata_bus_probe(struct ata_port *ap)
2163 /* After the identify sequence we can now set up the devices. We do 2159 /* After the identify sequence we can now set up the devices. We do
2164 this in the normal order so that the user doesn't get confused */ 2160 this in the normal order so that the user doesn't get confused */
2165 2161
2166 for(i = 0; i < ATA_MAX_DEVICES; i++) { 2162 ata_link_for_each_dev(dev, &ap->link) {
2167 dev = &ap->link.device[i];
2168 if (!ata_dev_enabled(dev)) 2163 if (!ata_dev_enabled(dev))
2169 continue; 2164 continue;
2170 2165
@@ -2180,8 +2175,8 @@ int ata_bus_probe(struct ata_port *ap)
2180 if (rc) 2175 if (rc)
2181 goto fail; 2176 goto fail;
2182 2177
2183 for (i = 0; i < ATA_MAX_DEVICES; i++) 2178 ata_link_for_each_dev(dev, &ap->link)
2184 if (ata_dev_enabled(&ap->link.device[i])) 2179 if (ata_dev_enabled(dev))
2185 return 0; 2180 return 0;
2186 2181
2187 /* no device present, disable port */ 2182 /* no device present, disable port */
@@ -2803,16 +2798,14 @@ static int ata_dev_set_mode(struct ata_device *dev)
2803 2798
2804int ata_do_set_mode(struct ata_port *ap, struct ata_device **r_failed_dev) 2799int ata_do_set_mode(struct ata_port *ap, struct ata_device **r_failed_dev)
2805{ 2800{
2801 struct ata_link *link = &ap->link;
2806 struct ata_device *dev; 2802 struct ata_device *dev;
2807 int i, rc = 0, used_dma = 0, found = 0; 2803 int rc = 0, used_dma = 0, found = 0;
2808
2809 2804
2810 /* step 1: calculate xfer_mask */ 2805 /* step 1: calculate xfer_mask */
2811 for (i = 0; i < ATA_MAX_DEVICES; i++) { 2806 ata_link_for_each_dev(dev, link) {
2812 unsigned int pio_mask, dma_mask; 2807 unsigned int pio_mask, dma_mask;
2813 2808
2814 dev = &ap->link.device[i];
2815
2816 if (!ata_dev_enabled(dev)) 2809 if (!ata_dev_enabled(dev))
2817 continue; 2810 continue;
2818 2811
@@ -2831,8 +2824,7 @@ int ata_do_set_mode(struct ata_port *ap, struct ata_device **r_failed_dev)
2831 goto out; 2824 goto out;
2832 2825
2833 /* step 2: always set host PIO timings */ 2826 /* step 2: always set host PIO timings */
2834 for (i = 0; i < ATA_MAX_DEVICES; i++) { 2827 ata_link_for_each_dev(dev, link) {
2835 dev = &ap->link.device[i];
2836 if (!ata_dev_enabled(dev)) 2828 if (!ata_dev_enabled(dev))
2837 continue; 2829 continue;
2838 2830
@@ -2849,9 +2841,7 @@ int ata_do_set_mode(struct ata_port *ap, struct ata_device **r_failed_dev)
2849 } 2841 }
2850 2842
2851 /* step 3: set host DMA timings */ 2843 /* step 3: set host DMA timings */
2852 for (i = 0; i < ATA_MAX_DEVICES; i++) { 2844 ata_link_for_each_dev(dev, link) {
2853 dev = &ap->link.device[i];
2854
2855 if (!ata_dev_enabled(dev) || !dev->dma_mode) 2845 if (!ata_dev_enabled(dev) || !dev->dma_mode)
2856 continue; 2846 continue;
2857 2847
@@ -2862,9 +2852,7 @@ int ata_do_set_mode(struct ata_port *ap, struct ata_device **r_failed_dev)
2862 } 2852 }
2863 2853
2864 /* step 4: update devices' xfer mode */ 2854 /* step 4: update devices' xfer mode */
2865 for (i = 0; i < ATA_MAX_DEVICES; i++) { 2855 ata_link_for_each_dev(dev, link) {
2866 dev = &ap->link.device[i];
2867
2868 /* don't update suspended devices' xfer mode */ 2856 /* don't update suspended devices' xfer mode */
2869 if (!ata_dev_enabled(dev)) 2857 if (!ata_dev_enabled(dev))
2870 continue; 2858 continue;
@@ -6113,6 +6101,7 @@ struct ata_port *ata_port_alloc(struct ata_host *host)
6113 6101
6114 ap->link.ap = ap; 6102 ap->link.ap = ap;
6115 6103
6104 /* can't use iterator, ap isn't initialized yet */
6116 for (i = 0; i < ATA_MAX_DEVICES; i++) { 6105 for (i = 0; i < ATA_MAX_DEVICES; i++) {
6117 struct ata_device *dev = &ap->link.device[i]; 6106 struct ata_device *dev = &ap->link.device[i];
6118 dev->link = &ap->link; 6107 dev->link = &ap->link;
@@ -6453,7 +6442,8 @@ int ata_host_register(struct ata_host *host, struct scsi_host_template *sht)
6453 /* kick EH for boot probing */ 6442 /* kick EH for boot probing */
6454 spin_lock_irqsave(ap->lock, flags); 6443 spin_lock_irqsave(ap->lock, flags);
6455 6444
6456 ehi->probe_mask = (1 << ATA_MAX_DEVICES) - 1; 6445 ehi->probe_mask =
6446 (1 << ata_link_max_devices(&ap->link)) - 1;
6457 ehi->action |= ATA_EH_SOFTRESET; 6447 ehi->action |= ATA_EH_SOFTRESET;
6458 ehi->flags |= ATA_EHI_NO_AUTOPSY | ATA_EHI_QUIET; 6448 ehi->flags |= ATA_EHI_NO_AUTOPSY | ATA_EHI_QUIET;
6459 6449
@@ -6551,7 +6541,7 @@ int ata_host_activate(struct ata_host *host, int irq,
6551void ata_port_detach(struct ata_port *ap) 6541void ata_port_detach(struct ata_port *ap)
6552{ 6542{
6553 unsigned long flags; 6543 unsigned long flags;
6554 int i; 6544 struct ata_device *dev;
6555 6545
6556 if (!ap->ops->error_handler) 6546 if (!ap->ops->error_handler)
6557 goto skip_eh; 6547 goto skip_eh;
@@ -6568,8 +6558,8 @@ void ata_port_detach(struct ata_port *ap)
6568 */ 6558 */
6569 spin_lock_irqsave(ap->lock, flags); 6559 spin_lock_irqsave(ap->lock, flags);
6570 6560
6571 for (i = 0; i < ATA_MAX_DEVICES; i++) 6561 ata_link_for_each_dev(dev, &ap->link)
6572 ata_dev_disable(&ap->link.device[i]); 6562 ata_dev_disable(dev);
6573 6563
6574 spin_unlock_irqrestore(ap->lock, flags); 6564 spin_unlock_irqrestore(ap->lock, flags);
6575 6565