diff options
-rw-r--r-- | drivers/ata/ahci.c | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/drivers/ata/ahci.c b/drivers/ata/ahci.c index db65f4a16021..c5034d450c62 100644 --- a/drivers/ata/ahci.c +++ b/drivers/ata/ahci.c | |||
@@ -1023,8 +1023,8 @@ static int ahci_exec_polled_cmd(struct ata_port *ap, int pmp, | |||
1023 | return 0; | 1023 | return 0; |
1024 | } | 1024 | } |
1025 | 1025 | ||
1026 | static int ahci_softreset(struct ata_port *ap, unsigned int *class, | 1026 | static int ahci_do_softreset(struct ata_port *ap, unsigned int *class, |
1027 | unsigned long deadline) | 1027 | int pmp, unsigned long deadline) |
1028 | { | 1028 | { |
1029 | const char *reason = NULL; | 1029 | const char *reason = NULL; |
1030 | unsigned long now, msecs; | 1030 | unsigned long now, msecs; |
@@ -1054,7 +1054,7 @@ static int ahci_softreset(struct ata_port *ap, unsigned int *class, | |||
1054 | msecs = jiffies_to_msecs(deadline - now); | 1054 | msecs = jiffies_to_msecs(deadline - now); |
1055 | 1055 | ||
1056 | tf.ctl |= ATA_SRST; | 1056 | tf.ctl |= ATA_SRST; |
1057 | if (ahci_exec_polled_cmd(ap, 0, &tf, 0, | 1057 | if (ahci_exec_polled_cmd(ap, pmp, &tf, 0, |
1058 | AHCI_CMD_RESET | AHCI_CMD_CLR_BUSY, msecs)) { | 1058 | AHCI_CMD_RESET | AHCI_CMD_CLR_BUSY, msecs)) { |
1059 | rc = -EIO; | 1059 | rc = -EIO; |
1060 | reason = "1st FIS failed"; | 1060 | reason = "1st FIS failed"; |
@@ -1066,7 +1066,7 @@ static int ahci_softreset(struct ata_port *ap, unsigned int *class, | |||
1066 | 1066 | ||
1067 | /* issue the second D2H Register FIS */ | 1067 | /* issue the second D2H Register FIS */ |
1068 | tf.ctl &= ~ATA_SRST; | 1068 | tf.ctl &= ~ATA_SRST; |
1069 | ahci_exec_polled_cmd(ap, 0, &tf, 0, 0, 0); | 1069 | ahci_exec_polled_cmd(ap, pmp, &tf, 0, 0, 0); |
1070 | 1070 | ||
1071 | /* spec mandates ">= 2ms" before checking status. | 1071 | /* spec mandates ">= 2ms" before checking status. |
1072 | * We wait 150ms, because that was the magic delay used for | 1072 | * We wait 150ms, because that was the magic delay used for |
@@ -1094,6 +1094,12 @@ static int ahci_softreset(struct ata_port *ap, unsigned int *class, | |||
1094 | return rc; | 1094 | return rc; |
1095 | } | 1095 | } |
1096 | 1096 | ||
1097 | static int ahci_softreset(struct ata_port *ap, unsigned int *class, | ||
1098 | unsigned long deadline) | ||
1099 | { | ||
1100 | return ahci_do_softreset(ap, class, 0, deadline); | ||
1101 | } | ||
1102 | |||
1097 | static int ahci_hardreset(struct ata_port *ap, unsigned int *class, | 1103 | static int ahci_hardreset(struct ata_port *ap, unsigned int *class, |
1098 | unsigned long deadline) | 1104 | unsigned long deadline) |
1099 | { | 1105 | { |