ide: factor out code for tuning devices from ide_probe_port()

* Factor out code for tuning devices from ide_probe_port()
  to ide_port_tune_devices().

* Move ide_port_tune_devices() call from ide_probe_port()
  to ide_device_add_all().

There should be no functionality changes caused by this patch.
Signed-off-by: default avatarBartlomiej Zolnierkiewicz <bzolnier@gmail.com>
parent 139ddfca
...@@ -794,6 +794,13 @@ static int ide_probe_port(ide_hwif_t *hwif) ...@@ -794,6 +794,13 @@ static int ide_probe_port(ide_hwif_t *hwif)
if (!hwif->present) if (!hwif->present)
return -ENODEV; return -ENODEV;
return 0;
}
static void ide_port_tune_devices(ide_hwif_t *hwif)
{
int unit;
for (unit = 0; unit < MAX_DRIVES; unit++) { for (unit = 0; unit < MAX_DRIVES; unit++) {
ide_drive_t *drive = &hwif->drives[unit]; ide_drive_t *drive = &hwif->drives[unit];
...@@ -827,8 +834,6 @@ static int ide_probe_port(ide_hwif_t *hwif) ...@@ -827,8 +834,6 @@ static int ide_probe_port(ide_hwif_t *hwif)
else else
drive->no_io_32bit = drive->id->dword_io ? 1 : 0; drive->no_io_32bit = drive->id->dword_io ? 1 : 0;
} }
return 0;
} }
#if MAX_HWIFS > 1 #if MAX_HWIFS > 1
...@@ -1309,8 +1314,12 @@ int ide_device_add_all(u8 *idx) ...@@ -1309,8 +1314,12 @@ int ide_device_add_all(u8 *idx)
continue; continue;
} }
if (ide_probe_port(hwif) < 0) if (ide_probe_port(hwif) < 0) {
ide_hwif_release_regions(hwif); ide_hwif_release_regions(hwif);
continue;
}
ide_port_tune_devices(hwif);
} }
for (i = 0; i < MAX_HWIFS; i++) { for (i = 0; i < MAX_HWIFS; i++) {
......
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