1 // SPDX-License-Identifier: GPL-2.0-or-later 2 /* 3 * libata-eh.c - libata error handling 4 * 5 * Copyright 2006 Tejun Heo <htejun@gmail.com> 6 * 7 * libata documentation is available via 'make {ps|pdf}docs', 8 * as Documentation/driver-api/libata.rst 9 * 10 * Hardware documentation available from http://www.t13.org/ and 11 * http://www.sata-io.org/ 12 */ 13 14 #include <linux/kernel.h> 15 #include <linux/blkdev.h> 16 #include <linux/export.h> 17 #include <linux/pci.h> 18 #include <scsi/scsi.h> 19 #include <scsi/scsi_host.h> 20 #include <scsi/scsi_eh.h> 21 #include <scsi/scsi_device.h> 22 #include <scsi/scsi_cmnd.h> 23 #include <scsi/scsi_dbg.h> 24 #include "../scsi/scsi_transport_api.h" 25 26 #include <linux/libata.h> 27 28 #include <trace/events/libata.h> 29 #include "libata.h" 30 31 enum { 32 /* speed down verdicts */ 33 ATA_EH_SPDN_NCQ_OFF = (1 << 0), 34 ATA_EH_SPDN_SPEED_DOWN = (1 << 1), 35 ATA_EH_SPDN_FALLBACK_TO_PIO = (1 << 2), 36 ATA_EH_SPDN_KEEP_ERRORS = (1 << 3), 37 38 /* error flags */ 39 ATA_EFLAG_IS_IO = (1 << 0), 40 ATA_EFLAG_DUBIOUS_XFER = (1 << 1), 41 ATA_EFLAG_OLD_ER = (1 << 31), 42 43 /* error categories */ 44 ATA_ECAT_NONE = 0, 45 ATA_ECAT_ATA_BUS = 1, 46 ATA_ECAT_TOUT_HSM = 2, 47 ATA_ECAT_UNK_DEV = 3, 48 ATA_ECAT_DUBIOUS_NONE = 4, 49 ATA_ECAT_DUBIOUS_ATA_BUS = 5, 50 ATA_ECAT_DUBIOUS_TOUT_HSM = 6, 51 ATA_ECAT_DUBIOUS_UNK_DEV = 7, 52 ATA_ECAT_NR = 8, 53 54 ATA_EH_CMD_DFL_TIMEOUT = 5000, 55 56 /* always put at least this amount of time between resets */ 57 ATA_EH_RESET_COOL_DOWN = 5000, 58 59 /* Waiting in ->prereset can never be reliable. It's 60 * sometimes nice to wait there but it can't be depended upon; 61 * otherwise, we wouldn't be resetting. Just give it enough 62 * time for most drives to spin up. 63 */ 64 ATA_EH_PRERESET_TIMEOUT = 10000, 65 ATA_EH_FASTDRAIN_INTERVAL = 3000, 66 67 ATA_EH_UA_TRIES = 5, 68 69 /* probe speed down parameters, see ata_eh_schedule_probe() */ 70 ATA_EH_PROBE_TRIAL_INTERVAL = 60000, /* 1 min */ 71 ATA_EH_PROBE_TRIALS = 2, 72 }; 73 74 /* The following table determines how we sequence resets. Each entry 75 * represents timeout for that try. The first try can be soft or 76 * hardreset. All others are hardreset if available. In most cases 77 * the first reset w/ 10sec timeout should succeed. Following entries 78 * are mostly for error handling, hotplug and those outlier devices that 79 * take an exceptionally long time to recover from reset. 80 */ 81 static const unsigned long ata_eh_reset_timeouts[] = { 82 10000, /* most drives spin up by 10sec */ 83 10000, /* > 99% working drives spin up before 20sec */ 84 35000, /* give > 30 secs of idleness for outlier devices */ 85 5000, /* and sweet one last chance */ 86 ULONG_MAX, /* > 1 min has elapsed, give up */ 87 }; 88 89 static const unsigned long ata_eh_identify_timeouts[] = { 90 5000, /* covers > 99% of successes and not too boring on failures */ 91 10000, /* combined time till here is enough even for media access */ 92 30000, /* for true idiots */ 93 ULONG_MAX, 94 }; 95 96 static const unsigned long ata_eh_revalidate_timeouts[] = { 97 15000, /* Some drives are slow to read log pages when waking-up */ 98 15000, /* combined time till here is enough even for media access */ 99 ULONG_MAX, 100 }; 101 102 static const unsigned long ata_eh_flush_timeouts[] = { 103 15000, /* be generous with flush */ 104 15000, /* ditto */ 105 30000, /* and even more generous */ 106 ULONG_MAX, 107 }; 108 109 static const unsigned long ata_eh_other_timeouts[] = { 110 5000, /* same rationale as identify timeout */ 111 10000, /* ditto */ 112 /* but no merciful 30sec for other commands, it just isn't worth it */ 113 ULONG_MAX, 114 }; 115 116 struct ata_eh_cmd_timeout_ent { 117 const u8 *commands; 118 const unsigned long *timeouts; 119 }; 120 121 /* The following table determines timeouts to use for EH internal 122 * commands. Each table entry is a command class and matches the 123 * commands the entry applies to and the timeout table to use. 124 * 125 * On the retry after a command timed out, the next timeout value from 126 * the table is used. If the table doesn't contain further entries, 127 * the last value is used. 128 * 129 * ehc->cmd_timeout_idx keeps track of which timeout to use per 130 * command class, so if SET_FEATURES times out on the first try, the 131 * next try will use the second timeout value only for that class. 132 */ 133 #define CMDS(cmds...) (const u8 []){ cmds, 0 } 134 static const struct ata_eh_cmd_timeout_ent 135 ata_eh_cmd_timeout_table[ATA_EH_CMD_TIMEOUT_TABLE_SIZE] = { 136 { .commands = CMDS(ATA_CMD_ID_ATA, ATA_CMD_ID_ATAPI), 137 .timeouts = ata_eh_identify_timeouts, }, 138 { .commands = CMDS(ATA_CMD_READ_LOG_EXT, ATA_CMD_READ_LOG_DMA_EXT), 139 .timeouts = ata_eh_revalidate_timeouts, }, 140 { .commands = CMDS(ATA_CMD_READ_NATIVE_MAX, ATA_CMD_READ_NATIVE_MAX_EXT), 141 .timeouts = ata_eh_other_timeouts, }, 142 { .commands = CMDS(ATA_CMD_SET_MAX, ATA_CMD_SET_MAX_EXT), 143 .timeouts = ata_eh_other_timeouts, }, 144 { .commands = CMDS(ATA_CMD_SET_FEATURES), 145 .timeouts = ata_eh_other_timeouts, }, 146 { .commands = CMDS(ATA_CMD_INIT_DEV_PARAMS), 147 .timeouts = ata_eh_other_timeouts, }, 148 { .commands = CMDS(ATA_CMD_FLUSH, ATA_CMD_FLUSH_EXT), 149 .timeouts = ata_eh_flush_timeouts }, 150 }; 151 #undef CMDS 152 153 static void __ata_port_freeze(struct ata_port *ap); 154 #ifdef CONFIG_PM 155 static void ata_eh_handle_port_suspend(struct ata_port *ap); 156 static void ata_eh_handle_port_resume(struct ata_port *ap); 157 #else /* CONFIG_PM */ 158 static void ata_eh_handle_port_suspend(struct ata_port *ap) 159 { } 160 161 static void ata_eh_handle_port_resume(struct ata_port *ap) 162 { } 163 #endif /* CONFIG_PM */ 164 165 static __printf(2, 0) void __ata_ehi_pushv_desc(struct ata_eh_info *ehi, 166 const char *fmt, va_list args) 167 { 168 ehi->desc_len += vscnprintf(ehi->desc + ehi->desc_len, 169 ATA_EH_DESC_LEN - ehi->desc_len, 170 fmt, args); 171 } 172 173 /** 174 * __ata_ehi_push_desc - push error description without adding separator 175 * @ehi: target EHI 176 * @fmt: printf format string 177 * 178 * Format string according to @fmt and append it to @ehi->desc. 179 * 180 * LOCKING: 181 * spin_lock_irqsave(host lock) 182 */ 183 void __ata_ehi_push_desc(struct ata_eh_info *ehi, const char *fmt, ...) 184 { 185 va_list args; 186 187 va_start(args, fmt); 188 __ata_ehi_pushv_desc(ehi, fmt, args); 189 va_end(args); 190 } 191 EXPORT_SYMBOL_GPL(__ata_ehi_push_desc); 192 193 /** 194 * ata_ehi_push_desc - push error description with separator 195 * @ehi: target EHI 196 * @fmt: printf format string 197 * 198 * Format string according to @fmt and append it to @ehi->desc. 199 * If @ehi->desc is not empty, ", " is added in-between. 200 * 201 * LOCKING: 202 * spin_lock_irqsave(host lock) 203 */ 204 void ata_ehi_push_desc(struct ata_eh_info *ehi, const char *fmt, ...) 205 { 206 va_list args; 207 208 if (ehi->desc_len) 209 __ata_ehi_push_desc(ehi, ", "); 210 211 va_start(args, fmt); 212 __ata_ehi_pushv_desc(ehi, fmt, args); 213 va_end(args); 214 } 215 EXPORT_SYMBOL_GPL(ata_ehi_push_desc); 216 217 /** 218 * ata_ehi_clear_desc - clean error description 219 * @ehi: target EHI 220 * 221 * Clear @ehi->desc. 222 * 223 * LOCKING: 224 * spin_lock_irqsave(host lock) 225 */ 226 void ata_ehi_clear_desc(struct ata_eh_info *ehi) 227 { 228 ehi->desc[0] = '\0'; 229 ehi->desc_len = 0; 230 } 231 EXPORT_SYMBOL_GPL(ata_ehi_clear_desc); 232 233 /** 234 * ata_port_desc - append port description 235 * @ap: target ATA port 236 * @fmt: printf format string 237 * 238 * Format string according to @fmt and append it to port 239 * description. If port description is not empty, " " is added 240 * in-between. This function is to be used while initializing 241 * ata_host. The description is printed on host registration. 242 * 243 * LOCKING: 244 * None. 245 */ 246 void ata_port_desc(struct ata_port *ap, const char *fmt, ...) 247 { 248 va_list args; 249 250 WARN_ON(!(ap->pflags & ATA_PFLAG_INITIALIZING)); 251 252 if (ap->link.eh_info.desc_len) 253 __ata_ehi_push_desc(&ap->link.eh_info, " "); 254 255 va_start(args, fmt); 256 __ata_ehi_pushv_desc(&ap->link.eh_info, fmt, args); 257 va_end(args); 258 } 259 EXPORT_SYMBOL_GPL(ata_port_desc); 260 261 #ifdef CONFIG_PCI 262 /** 263 * ata_port_pbar_desc - append PCI BAR description 264 * @ap: target ATA port 265 * @bar: target PCI BAR 266 * @offset: offset into PCI BAR 267 * @name: name of the area 268 * 269 * If @offset is negative, this function formats a string which 270 * contains the name, address, size and type of the BAR and 271 * appends it to the port description. If @offset is zero or 272 * positive, only name and offsetted address is appended. 273 * 274 * LOCKING: 275 * None. 276 */ 277 void ata_port_pbar_desc(struct ata_port *ap, int bar, ssize_t offset, 278 const char *name) 279 { 280 struct pci_dev *pdev = to_pci_dev(ap->host->dev); 281 char *type = ""; 282 unsigned long long start, len; 283 284 if (pci_resource_flags(pdev, bar) & IORESOURCE_MEM) 285 type = "m"; 286 else if (pci_resource_flags(pdev, bar) & IORESOURCE_IO) 287 type = "i"; 288 289 start = (unsigned long long)pci_resource_start(pdev, bar); 290 len = (unsigned long long)pci_resource_len(pdev, bar); 291 292 if (offset < 0) 293 ata_port_desc(ap, "%s %s%llu@0x%llx", name, type, len, start); 294 else 295 ata_port_desc(ap, "%s 0x%llx", name, 296 start + (unsigned long long)offset); 297 } 298 EXPORT_SYMBOL_GPL(ata_port_pbar_desc); 299 #endif /* CONFIG_PCI */ 300 301 static int ata_lookup_timeout_table(u8 cmd) 302 { 303 int i; 304 305 for (i = 0; i < ATA_EH_CMD_TIMEOUT_TABLE_SIZE; i++) { 306 const u8 *cur; 307 308 for (cur = ata_eh_cmd_timeout_table[i].commands; *cur; cur++) 309 if (*cur == cmd) 310 return i; 311 } 312 313 return -1; 314 } 315 316 /** 317 * ata_internal_cmd_timeout - determine timeout for an internal command 318 * @dev: target device 319 * @cmd: internal command to be issued 320 * 321 * Determine timeout for internal command @cmd for @dev. 322 * 323 * LOCKING: 324 * EH context. 325 * 326 * RETURNS: 327 * Determined timeout. 328 */ 329 unsigned long ata_internal_cmd_timeout(struct ata_device *dev, u8 cmd) 330 { 331 struct ata_eh_context *ehc = &dev->link->eh_context; 332 int ent = ata_lookup_timeout_table(cmd); 333 int idx; 334 335 if (ent < 0) 336 return ATA_EH_CMD_DFL_TIMEOUT; 337 338 idx = ehc->cmd_timeout_idx[dev->devno][ent]; 339 return ata_eh_cmd_timeout_table[ent].timeouts[idx]; 340 } 341 342 /** 343 * ata_internal_cmd_timed_out - notification for internal command timeout 344 * @dev: target device 345 * @cmd: internal command which timed out 346 * 347 * Notify EH that internal command @cmd for @dev timed out. This 348 * function should be called only for commands whose timeouts are 349 * determined using ata_internal_cmd_timeout(). 350 * 351 * LOCKING: 352 * EH context. 353 */ 354 void ata_internal_cmd_timed_out(struct ata_device *dev, u8 cmd) 355 { 356 struct ata_eh_context *ehc = &dev->link->eh_context; 357 int ent = ata_lookup_timeout_table(cmd); 358 int idx; 359 360 if (ent < 0) 361 return; 362 363 idx = ehc->cmd_timeout_idx[dev->devno][ent]; 364 if (ata_eh_cmd_timeout_table[ent].timeouts[idx + 1] != ULONG_MAX) 365 ehc->cmd_timeout_idx[dev->devno][ent]++; 366 } 367 368 static void ata_ering_record(struct ata_ering *ering, unsigned int eflags, 369 unsigned int err_mask) 370 { 371 struct ata_ering_entry *ent; 372 373 WARN_ON(!err_mask); 374 375 ering->cursor++; 376 ering->cursor %= ATA_ERING_SIZE; 377 378 ent = &ering->ring[ering->cursor]; 379 ent->eflags = eflags; 380 ent->err_mask = err_mask; 381 ent->timestamp = get_jiffies_64(); 382 } 383 384 static struct ata_ering_entry *ata_ering_top(struct ata_ering *ering) 385 { 386 struct ata_ering_entry *ent = &ering->ring[ering->cursor]; 387 388 if (ent->err_mask) 389 return ent; 390 return NULL; 391 } 392 393 int ata_ering_map(struct ata_ering *ering, 394 int (*map_fn)(struct ata_ering_entry *, void *), 395 void *arg) 396 { 397 int idx, rc = 0; 398 struct ata_ering_entry *ent; 399 400 idx = ering->cursor; 401 do { 402 ent = &ering->ring[idx]; 403 if (!ent->err_mask) 404 break; 405 rc = map_fn(ent, arg); 406 if (rc) 407 break; 408 idx = (idx - 1 + ATA_ERING_SIZE) % ATA_ERING_SIZE; 409 } while (idx != ering->cursor); 410 411 return rc; 412 } 413 414 static int ata_ering_clear_cb(struct ata_ering_entry *ent, void *void_arg) 415 { 416 ent->eflags |= ATA_EFLAG_OLD_ER; 417 return 0; 418 } 419 420 static void ata_ering_clear(struct ata_ering *ering) 421 { 422 ata_ering_map(ering, ata_ering_clear_cb, NULL); 423 } 424 425 static unsigned int ata_eh_dev_action(struct ata_device *dev) 426 { 427 struct ata_eh_context *ehc = &dev->link->eh_context; 428 429 return ehc->i.action | ehc->i.dev_action[dev->devno]; 430 } 431 432 static void ata_eh_clear_action(struct ata_link *link, struct ata_device *dev, 433 struct ata_eh_info *ehi, unsigned int action) 434 { 435 struct ata_device *tdev; 436 437 if (!dev) { 438 ehi->action &= ~action; 439 ata_for_each_dev(tdev, link, ALL) 440 ehi->dev_action[tdev->devno] &= ~action; 441 } else { 442 /* doesn't make sense for port-wide EH actions */ 443 WARN_ON(!(action & ATA_EH_PERDEV_MASK)); 444 445 /* break ehi->action into ehi->dev_action */ 446 if (ehi->action & action) { 447 ata_for_each_dev(tdev, link, ALL) 448 ehi->dev_action[tdev->devno] |= 449 ehi->action & action; 450 ehi->action &= ~action; 451 } 452 453 /* turn off the specified per-dev action */ 454 ehi->dev_action[dev->devno] &= ~action; 455 } 456 } 457 458 /** 459 * ata_eh_acquire - acquire EH ownership 460 * @ap: ATA port to acquire EH ownership for 461 * 462 * Acquire EH ownership for @ap. This is the basic exclusion 463 * mechanism for ports sharing a host. Only one port hanging off 464 * the same host can claim the ownership of EH. 465 * 466 * LOCKING: 467 * EH context. 468 */ 469 void ata_eh_acquire(struct ata_port *ap) 470 { 471 mutex_lock(&ap->host->eh_mutex); 472 WARN_ON_ONCE(ap->host->eh_owner); 473 ap->host->eh_owner = current; 474 } 475 476 /** 477 * ata_eh_release - release EH ownership 478 * @ap: ATA port to release EH ownership for 479 * 480 * Release EH ownership for @ap if the caller. The caller must 481 * have acquired EH ownership using ata_eh_acquire() previously. 482 * 483 * LOCKING: 484 * EH context. 485 */ 486 void ata_eh_release(struct ata_port *ap) 487 { 488 WARN_ON_ONCE(ap->host->eh_owner != current); 489 ap->host->eh_owner = NULL; 490 mutex_unlock(&ap->host->eh_mutex); 491 } 492 493 static void ata_eh_unload(struct ata_port *ap) 494 { 495 struct ata_link *link; 496 struct ata_device *dev; 497 unsigned long flags; 498 499 /* Restore SControl IPM and SPD for the next driver and 500 * disable attached devices. 501 */ 502 ata_for_each_link(link, ap, PMP_FIRST) { 503 sata_scr_write(link, SCR_CONTROL, link->saved_scontrol & 0xff0); 504 ata_for_each_dev(dev, link, ALL) 505 ata_dev_disable(dev); 506 } 507 508 /* freeze and set UNLOADED */ 509 spin_lock_irqsave(ap->lock, flags); 510 511 ata_port_freeze(ap); /* won't be thawed */ 512 ap->pflags &= ~ATA_PFLAG_EH_PENDING; /* clear pending from freeze */ 513 ap->pflags |= ATA_PFLAG_UNLOADED; 514 515 spin_unlock_irqrestore(ap->lock, flags); 516 } 517 518 /** 519 * ata_scsi_error - SCSI layer error handler callback 520 * @host: SCSI host on which error occurred 521 * 522 * Handles SCSI-layer-thrown error events. 523 * 524 * LOCKING: 525 * Inherited from SCSI layer (none, can sleep) 526 * 527 * RETURNS: 528 * Zero. 529 */ 530 void ata_scsi_error(struct Scsi_Host *host) 531 { 532 struct ata_port *ap = ata_shost_to_port(host); 533 unsigned long flags; 534 LIST_HEAD(eh_work_q); 535 536 DPRINTK("ENTER\n"); 537 538 spin_lock_irqsave(host->host_lock, flags); 539 list_splice_init(&host->eh_cmd_q, &eh_work_q); 540 spin_unlock_irqrestore(host->host_lock, flags); 541 542 ata_scsi_cmd_error_handler(host, ap, &eh_work_q); 543 544 /* If we timed raced normal completion and there is nothing to 545 recover nr_timedout == 0 why exactly are we doing error recovery ? */ 546 ata_scsi_port_error_handler(host, ap); 547 548 /* finish or retry handled scmd's and clean up */ 549 WARN_ON(!list_empty(&eh_work_q)); 550 551 DPRINTK("EXIT\n"); 552 } 553 554 /** 555 * ata_scsi_cmd_error_handler - error callback for a list of commands 556 * @host: scsi host containing the port 557 * @ap: ATA port within the host 558 * @eh_work_q: list of commands to process 559 * 560 * process the given list of commands and return those finished to the 561 * ap->eh_done_q. This function is the first part of the libata error 562 * handler which processes a given list of failed commands. 563 */ 564 void ata_scsi_cmd_error_handler(struct Scsi_Host *host, struct ata_port *ap, 565 struct list_head *eh_work_q) 566 { 567 int i; 568 unsigned long flags; 569 570 /* make sure sff pio task is not running */ 571 ata_sff_flush_pio_task(ap); 572 573 /* synchronize with host lock and sort out timeouts */ 574 575 /* For new EH, all qcs are finished in one of three ways - 576 * normal completion, error completion, and SCSI timeout. 577 * Both completions can race against SCSI timeout. When normal 578 * completion wins, the qc never reaches EH. When error 579 * completion wins, the qc has ATA_QCFLAG_FAILED set. 580 * 581 * When SCSI timeout wins, things are a bit more complex. 582 * Normal or error completion can occur after the timeout but 583 * before this point. In such cases, both types of 584 * completions are honored. A scmd is determined to have 585 * timed out iff its associated qc is active and not failed. 586 */ 587 spin_lock_irqsave(ap->lock, flags); 588 if (ap->ops->error_handler) { 589 struct scsi_cmnd *scmd, *tmp; 590 int nr_timedout = 0; 591 592 /* This must occur under the ap->lock as we don't want 593 a polled recovery to race the real interrupt handler 594 595 The lost_interrupt handler checks for any completed but 596 non-notified command and completes much like an IRQ handler. 597 598 We then fall into the error recovery code which will treat 599 this as if normal completion won the race */ 600 601 if (ap->ops->lost_interrupt) 602 ap->ops->lost_interrupt(ap); 603 604 list_for_each_entry_safe(scmd, tmp, eh_work_q, eh_entry) { 605 struct ata_queued_cmd *qc; 606 607 ata_qc_for_each_raw(ap, qc, i) { 608 if (qc->flags & ATA_QCFLAG_ACTIVE && 609 qc->scsicmd == scmd) 610 break; 611 } 612 613 if (i < ATA_MAX_QUEUE) { 614 /* the scmd has an associated qc */ 615 if (!(qc->flags & ATA_QCFLAG_FAILED)) { 616 /* which hasn't failed yet, timeout */ 617 qc->err_mask |= AC_ERR_TIMEOUT; 618 qc->flags |= ATA_QCFLAG_FAILED; 619 nr_timedout++; 620 } 621 } else { 622 /* Normal completion occurred after 623 * SCSI timeout but before this point. 624 * Successfully complete it. 625 */ 626 scmd->retries = scmd->allowed; 627 scsi_eh_finish_cmd(scmd, &ap->eh_done_q); 628 } 629 } 630 631 /* If we have timed out qcs. They belong to EH from 632 * this point but the state of the controller is 633 * unknown. Freeze the port to make sure the IRQ 634 * handler doesn't diddle with those qcs. This must 635 * be done atomically w.r.t. setting QCFLAG_FAILED. 636 */ 637 if (nr_timedout) 638 __ata_port_freeze(ap); 639 640 641 /* initialize eh_tries */ 642 ap->eh_tries = ATA_EH_MAX_TRIES; 643 } 644 spin_unlock_irqrestore(ap->lock, flags); 645 646 } 647 EXPORT_SYMBOL(ata_scsi_cmd_error_handler); 648 649 /** 650 * ata_scsi_port_error_handler - recover the port after the commands 651 * @host: SCSI host containing the port 652 * @ap: the ATA port 653 * 654 * Handle the recovery of the port @ap after all the commands 655 * have been recovered. 656 */ 657 void ata_scsi_port_error_handler(struct Scsi_Host *host, struct ata_port *ap) 658 { 659 unsigned long flags; 660 661 /* invoke error handler */ 662 if (ap->ops->error_handler) { 663 struct ata_link *link; 664 665 /* acquire EH ownership */ 666 ata_eh_acquire(ap); 667 repeat: 668 /* kill fast drain timer */ 669 del_timer_sync(&ap->fastdrain_timer); 670 671 /* process port resume request */ 672 ata_eh_handle_port_resume(ap); 673 674 /* fetch & clear EH info */ 675 spin_lock_irqsave(ap->lock, flags); 676 677 ata_for_each_link(link, ap, HOST_FIRST) { 678 struct ata_eh_context *ehc = &link->eh_context; 679 struct ata_device *dev; 680 681 memset(&link->eh_context, 0, sizeof(link->eh_context)); 682 link->eh_context.i = link->eh_info; 683 memset(&link->eh_info, 0, sizeof(link->eh_info)); 684 685 ata_for_each_dev(dev, link, ENABLED) { 686 int devno = dev->devno; 687 688 ehc->saved_xfer_mode[devno] = dev->xfer_mode; 689 if (ata_ncq_enabled(dev)) 690 ehc->saved_ncq_enabled |= 1 << devno; 691 } 692 } 693 694 ap->pflags |= ATA_PFLAG_EH_IN_PROGRESS; 695 ap->pflags &= ~ATA_PFLAG_EH_PENDING; 696 ap->excl_link = NULL; /* don't maintain exclusion over EH */ 697 698 spin_unlock_irqrestore(ap->lock, flags); 699 700 /* invoke EH, skip if unloading or suspended */ 701 if (!(ap->pflags & (ATA_PFLAG_UNLOADING | ATA_PFLAG_SUSPENDED))) 702 ap->ops->error_handler(ap); 703 else { 704 /* if unloading, commence suicide */ 705 if ((ap->pflags & ATA_PFLAG_UNLOADING) && 706 !(ap->pflags & ATA_PFLAG_UNLOADED)) 707 ata_eh_unload(ap); 708 ata_eh_finish(ap); 709 } 710 711 /* process port suspend request */ 712 ata_eh_handle_port_suspend(ap); 713 714 /* Exception might have happened after ->error_handler 715 * recovered the port but before this point. Repeat 716 * EH in such case. 717 */ 718 spin_lock_irqsave(ap->lock, flags); 719 720 if (ap->pflags & ATA_PFLAG_EH_PENDING) { 721 if (--ap->eh_tries) { 722 spin_unlock_irqrestore(ap->lock, flags); 723 goto repeat; 724 } 725 ata_port_err(ap, 726 "EH pending after %d tries, giving up\n", 727 ATA_EH_MAX_TRIES); 728 ap->pflags &= ~ATA_PFLAG_EH_PENDING; 729 } 730 731 /* this run is complete, make sure EH info is clear */ 732 ata_for_each_link(link, ap, HOST_FIRST) 733 memset(&link->eh_info, 0, sizeof(link->eh_info)); 734 735 /* end eh (clear host_eh_scheduled) while holding 736 * ap->lock such that if exception occurs after this 737 * point but before EH completion, SCSI midlayer will 738 * re-initiate EH. 739 */ 740 ap->ops->end_eh(ap); 741 742 spin_unlock_irqrestore(ap->lock, flags); 743 ata_eh_release(ap); 744 } else { 745 WARN_ON(ata_qc_from_tag(ap, ap->link.active_tag) == NULL); 746 ap->ops->eng_timeout(ap); 747 } 748 749 scsi_eh_flush_done_q(&ap->eh_done_q); 750 751 /* clean up */ 752 spin_lock_irqsave(ap->lock, flags); 753 754 if (ap->pflags & ATA_PFLAG_LOADING) 755 ap->pflags &= ~ATA_PFLAG_LOADING; 756 else if ((ap->pflags & ATA_PFLAG_SCSI_HOTPLUG) && 757 !(ap->flags & ATA_FLAG_SAS_HOST)) 758 schedule_delayed_work(&ap->hotplug_task, 0); 759 760 if (ap->pflags & ATA_PFLAG_RECOVERED) 761 ata_port_info(ap, "EH complete\n"); 762 763 ap->pflags &= ~(ATA_PFLAG_SCSI_HOTPLUG | ATA_PFLAG_RECOVERED); 764 765 /* tell wait_eh that we're done */ 766 ap->pflags &= ~ATA_PFLAG_EH_IN_PROGRESS; 767 wake_up_all(&ap->eh_wait_q); 768 769 spin_unlock_irqrestore(ap->lock, flags); 770 } 771 EXPORT_SYMBOL_GPL(ata_scsi_port_error_handler); 772 773 /** 774 * ata_port_wait_eh - Wait for the currently pending EH to complete 775 * @ap: Port to wait EH for 776 * 777 * Wait until the currently pending EH is complete. 778 * 779 * LOCKING: 780 * Kernel thread context (may sleep). 781 */ 782 void ata_port_wait_eh(struct ata_port *ap) 783 { 784 unsigned long flags; 785 DEFINE_WAIT(wait); 786 787 retry: 788 spin_lock_irqsave(ap->lock, flags); 789 790 while (ap->pflags & (ATA_PFLAG_EH_PENDING | ATA_PFLAG_EH_IN_PROGRESS)) { 791 prepare_to_wait(&ap->eh_wait_q, &wait, TASK_UNINTERRUPTIBLE); 792 spin_unlock_irqrestore(ap->lock, flags); 793 schedule(); 794 spin_lock_irqsave(ap->lock, flags); 795 } 796 finish_wait(&ap->eh_wait_q, &wait); 797 798 spin_unlock_irqrestore(ap->lock, flags); 799 800 /* make sure SCSI EH is complete */ 801 if (scsi_host_in_recovery(ap->scsi_host)) { 802 ata_msleep(ap, 10); 803 goto retry; 804 } 805 } 806 EXPORT_SYMBOL_GPL(ata_port_wait_eh); 807 808 static int ata_eh_nr_in_flight(struct ata_port *ap) 809 { 810 struct ata_queued_cmd *qc; 811 unsigned int tag; 812 int nr = 0; 813 814 /* count only non-internal commands */ 815 ata_qc_for_each(ap, qc, tag) { 816 if (qc) 817 nr++; 818 } 819 820 return nr; 821 } 822 823 void ata_eh_fastdrain_timerfn(struct timer_list *t) 824 { 825 struct ata_port *ap = from_timer(ap, t, fastdrain_timer); 826 unsigned long flags; 827 int cnt; 828 829 spin_lock_irqsave(ap->lock, flags); 830 831 cnt = ata_eh_nr_in_flight(ap); 832 833 /* are we done? */ 834 if (!cnt) 835 goto out_unlock; 836 837 if (cnt == ap->fastdrain_cnt) { 838 struct ata_queued_cmd *qc; 839 unsigned int tag; 840 841 /* No progress during the last interval, tag all 842 * in-flight qcs as timed out and freeze the port. 843 */ 844 ata_qc_for_each(ap, qc, tag) { 845 if (qc) 846 qc->err_mask |= AC_ERR_TIMEOUT; 847 } 848 849 ata_port_freeze(ap); 850 } else { 851 /* some qcs have finished, give it another chance */ 852 ap->fastdrain_cnt = cnt; 853 ap->fastdrain_timer.expires = 854 ata_deadline(jiffies, ATA_EH_FASTDRAIN_INTERVAL); 855 add_timer(&ap->fastdrain_timer); 856 } 857 858 out_unlock: 859 spin_unlock_irqrestore(ap->lock, flags); 860 } 861 862 /** 863 * ata_eh_set_pending - set ATA_PFLAG_EH_PENDING and activate fast drain 864 * @ap: target ATA port 865 * @fastdrain: activate fast drain 866 * 867 * Set ATA_PFLAG_EH_PENDING and activate fast drain if @fastdrain 868 * is non-zero and EH wasn't pending before. Fast drain ensures 869 * that EH kicks in in timely manner. 870 * 871 * LOCKING: 872 * spin_lock_irqsave(host lock) 873 */ 874 static void ata_eh_set_pending(struct ata_port *ap, int fastdrain) 875 { 876 int cnt; 877 878 /* already scheduled? */ 879 if (ap->pflags & ATA_PFLAG_EH_PENDING) 880 return; 881 882 ap->pflags |= ATA_PFLAG_EH_PENDING; 883 884 if (!fastdrain) 885 return; 886 887 /* do we have in-flight qcs? */ 888 cnt = ata_eh_nr_in_flight(ap); 889 if (!cnt) 890 return; 891 892 /* activate fast drain */ 893 ap->fastdrain_cnt = cnt; 894 ap->fastdrain_timer.expires = 895 ata_deadline(jiffies, ATA_EH_FASTDRAIN_INTERVAL); 896 add_timer(&ap->fastdrain_timer); 897 } 898 899 /** 900 * ata_qc_schedule_eh - schedule qc for error handling 901 * @qc: command to schedule error handling for 902 * 903 * Schedule error handling for @qc. EH will kick in as soon as 904 * other commands are drained. 905 * 906 * LOCKING: 907 * spin_lock_irqsave(host lock) 908 */ 909 void ata_qc_schedule_eh(struct ata_queued_cmd *qc) 910 { 911 struct ata_port *ap = qc->ap; 912 913 WARN_ON(!ap->ops->error_handler); 914 915 qc->flags |= ATA_QCFLAG_FAILED; 916 ata_eh_set_pending(ap, 1); 917 918 /* The following will fail if timeout has already expired. 919 * ata_scsi_error() takes care of such scmds on EH entry. 920 * Note that ATA_QCFLAG_FAILED is unconditionally set after 921 * this function completes. 922 */ 923 blk_abort_request(scsi_cmd_to_rq(qc->scsicmd)); 924 } 925 926 /** 927 * ata_std_sched_eh - non-libsas ata_ports issue eh with this common routine 928 * @ap: ATA port to schedule EH for 929 * 930 * LOCKING: inherited from ata_port_schedule_eh 931 * spin_lock_irqsave(host lock) 932 */ 933 void ata_std_sched_eh(struct ata_port *ap) 934 { 935 WARN_ON(!ap->ops->error_handler); 936 937 if (ap->pflags & ATA_PFLAG_INITIALIZING) 938 return; 939 940 ata_eh_set_pending(ap, 1); 941 scsi_schedule_eh(ap->scsi_host); 942 943 DPRINTK("port EH scheduled\n"); 944 } 945 EXPORT_SYMBOL_GPL(ata_std_sched_eh); 946 947 /** 948 * ata_std_end_eh - non-libsas ata_ports complete eh with this common routine 949 * @ap: ATA port to end EH for 950 * 951 * In the libata object model there is a 1:1 mapping of ata_port to 952 * shost, so host fields can be directly manipulated under ap->lock, in 953 * the libsas case we need to hold a lock at the ha->level to coordinate 954 * these events. 955 * 956 * LOCKING: 957 * spin_lock_irqsave(host lock) 958 */ 959 void ata_std_end_eh(struct ata_port *ap) 960 { 961 struct Scsi_Host *host = ap->scsi_host; 962 963 host->host_eh_scheduled = 0; 964 } 965 EXPORT_SYMBOL(ata_std_end_eh); 966 967 968 /** 969 * ata_port_schedule_eh - schedule error handling without a qc 970 * @ap: ATA port to schedule EH for 971 * 972 * Schedule error handling for @ap. EH will kick in as soon as 973 * all commands are drained. 974 * 975 * LOCKING: 976 * spin_lock_irqsave(host lock) 977 */ 978 void ata_port_schedule_eh(struct ata_port *ap) 979 { 980 /* see: ata_std_sched_eh, unless you know better */ 981 ap->ops->sched_eh(ap); 982 } 983 EXPORT_SYMBOL_GPL(ata_port_schedule_eh); 984 985 static int ata_do_link_abort(struct ata_port *ap, struct ata_link *link) 986 { 987 struct ata_queued_cmd *qc; 988 int tag, nr_aborted = 0; 989 990 WARN_ON(!ap->ops->error_handler); 991 992 /* we're gonna abort all commands, no need for fast drain */ 993 ata_eh_set_pending(ap, 0); 994 995 /* include internal tag in iteration */ 996 ata_qc_for_each_with_internal(ap, qc, tag) { 997 if (qc && (!link || qc->dev->link == link)) { 998 qc->flags |= ATA_QCFLAG_FAILED; 999 ata_qc_complete(qc); 1000 nr_aborted++; 1001 } 1002 } 1003 1004 if (!nr_aborted) 1005 ata_port_schedule_eh(ap); 1006 1007 return nr_aborted; 1008 } 1009 1010 /** 1011 * ata_link_abort - abort all qc's on the link 1012 * @link: ATA link to abort qc's for 1013 * 1014 * Abort all active qc's active on @link and schedule EH. 1015 * 1016 * LOCKING: 1017 * spin_lock_irqsave(host lock) 1018 * 1019 * RETURNS: 1020 * Number of aborted qc's. 1021 */ 1022 int ata_link_abort(struct ata_link *link) 1023 { 1024 return ata_do_link_abort(link->ap, link); 1025 } 1026 EXPORT_SYMBOL_GPL(ata_link_abort); 1027 1028 /** 1029 * ata_port_abort - abort all qc's on the port 1030 * @ap: ATA port to abort qc's for 1031 * 1032 * Abort all active qc's of @ap and schedule EH. 1033 * 1034 * LOCKING: 1035 * spin_lock_irqsave(host_set lock) 1036 * 1037 * RETURNS: 1038 * Number of aborted qc's. 1039 */ 1040 int ata_port_abort(struct ata_port *ap) 1041 { 1042 return ata_do_link_abort(ap, NULL); 1043 } 1044 EXPORT_SYMBOL_GPL(ata_port_abort); 1045 1046 /** 1047 * __ata_port_freeze - freeze port 1048 * @ap: ATA port to freeze 1049 * 1050 * This function is called when HSM violation or some other 1051 * condition disrupts normal operation of the port. Frozen port 1052 * is not allowed to perform any operation until the port is 1053 * thawed, which usually follows a successful reset. 1054 * 1055 * ap->ops->freeze() callback can be used for freezing the port 1056 * hardware-wise (e.g. mask interrupt and stop DMA engine). If a 1057 * port cannot be frozen hardware-wise, the interrupt handler 1058 * must ack and clear interrupts unconditionally while the port 1059 * is frozen. 1060 * 1061 * LOCKING: 1062 * spin_lock_irqsave(host lock) 1063 */ 1064 static void __ata_port_freeze(struct ata_port *ap) 1065 { 1066 WARN_ON(!ap->ops->error_handler); 1067 1068 if (ap->ops->freeze) 1069 ap->ops->freeze(ap); 1070 1071 ap->pflags |= ATA_PFLAG_FROZEN; 1072 1073 DPRINTK("ata%u port frozen\n", ap->print_id); 1074 } 1075 1076 /** 1077 * ata_port_freeze - abort & freeze port 1078 * @ap: ATA port to freeze 1079 * 1080 * Abort and freeze @ap. The freeze operation must be called 1081 * first, because some hardware requires special operations 1082 * before the taskfile registers are accessible. 1083 * 1084 * LOCKING: 1085 * spin_lock_irqsave(host lock) 1086 * 1087 * RETURNS: 1088 * Number of aborted commands. 1089 */ 1090 int ata_port_freeze(struct ata_port *ap) 1091 { 1092 int nr_aborted; 1093 1094 WARN_ON(!ap->ops->error_handler); 1095 1096 __ata_port_freeze(ap); 1097 nr_aborted = ata_port_abort(ap); 1098 1099 return nr_aborted; 1100 } 1101 EXPORT_SYMBOL_GPL(ata_port_freeze); 1102 1103 /** 1104 * ata_eh_freeze_port - EH helper to freeze port 1105 * @ap: ATA port to freeze 1106 * 1107 * Freeze @ap. 1108 * 1109 * LOCKING: 1110 * None. 1111 */ 1112 void ata_eh_freeze_port(struct ata_port *ap) 1113 { 1114 unsigned long flags; 1115 1116 if (!ap->ops->error_handler) 1117 return; 1118 1119 spin_lock_irqsave(ap->lock, flags); 1120 __ata_port_freeze(ap); 1121 spin_unlock_irqrestore(ap->lock, flags); 1122 } 1123 EXPORT_SYMBOL_GPL(ata_eh_freeze_port); 1124 1125 /** 1126 * ata_eh_thaw_port - EH helper to thaw port 1127 * @ap: ATA port to thaw 1128 * 1129 * Thaw frozen port @ap. 1130 * 1131 * LOCKING: 1132 * None. 1133 */ 1134 void ata_eh_thaw_port(struct ata_port *ap) 1135 { 1136 unsigned long flags; 1137 1138 if (!ap->ops->error_handler) 1139 return; 1140 1141 spin_lock_irqsave(ap->lock, flags); 1142 1143 ap->pflags &= ~ATA_PFLAG_FROZEN; 1144 1145 if (ap->ops->thaw) 1146 ap->ops->thaw(ap); 1147 1148 spin_unlock_irqrestore(ap->lock, flags); 1149 1150 DPRINTK("ata%u port thawed\n", ap->print_id); 1151 } 1152 1153 static void ata_eh_scsidone(struct scsi_cmnd *scmd) 1154 { 1155 /* nada */ 1156 } 1157 1158 static void __ata_eh_qc_complete(struct ata_queued_cmd *qc) 1159 { 1160 struct ata_port *ap = qc->ap; 1161 struct scsi_cmnd *scmd = qc->scsicmd; 1162 unsigned long flags; 1163 1164 spin_lock_irqsave(ap->lock, flags); 1165 qc->scsidone = ata_eh_scsidone; 1166 __ata_qc_complete(qc); 1167 WARN_ON(ata_tag_valid(qc->tag)); 1168 spin_unlock_irqrestore(ap->lock, flags); 1169 1170 scsi_eh_finish_cmd(scmd, &ap->eh_done_q); 1171 } 1172 1173 /** 1174 * ata_eh_qc_complete - Complete an active ATA command from EH 1175 * @qc: Command to complete 1176 * 1177 * Indicate to the mid and upper layers that an ATA command has 1178 * completed. To be used from EH. 1179 */ 1180 void ata_eh_qc_complete(struct ata_queued_cmd *qc) 1181 { 1182 struct scsi_cmnd *scmd = qc->scsicmd; 1183 scmd->retries = scmd->allowed; 1184 __ata_eh_qc_complete(qc); 1185 } 1186 1187 /** 1188 * ata_eh_qc_retry - Tell midlayer to retry an ATA command after EH 1189 * @qc: Command to retry 1190 * 1191 * Indicate to the mid and upper layers that an ATA command 1192 * should be retried. To be used from EH. 1193 * 1194 * SCSI midlayer limits the number of retries to scmd->allowed. 1195 * scmd->allowed is incremented for commands which get retried 1196 * due to unrelated failures (qc->err_mask is zero). 1197 */ 1198 void ata_eh_qc_retry(struct ata_queued_cmd *qc) 1199 { 1200 struct scsi_cmnd *scmd = qc->scsicmd; 1201 if (!qc->err_mask) 1202 scmd->allowed++; 1203 __ata_eh_qc_complete(qc); 1204 } 1205 1206 /** 1207 * ata_dev_disable - disable ATA device 1208 * @dev: ATA device to disable 1209 * 1210 * Disable @dev. 1211 * 1212 * Locking: 1213 * EH context. 1214 */ 1215 void ata_dev_disable(struct ata_device *dev) 1216 { 1217 if (!ata_dev_enabled(dev)) 1218 return; 1219 1220 if (ata_msg_drv(dev->link->ap)) 1221 ata_dev_warn(dev, "disabled\n"); 1222 ata_acpi_on_disable(dev); 1223 ata_down_xfermask_limit(dev, ATA_DNXFER_FORCE_PIO0 | ATA_DNXFER_QUIET); 1224 dev->class++; 1225 1226 /* From now till the next successful probe, ering is used to 1227 * track probe failures. Clear accumulated device error info. 1228 */ 1229 ata_ering_clear(&dev->ering); 1230 } 1231 EXPORT_SYMBOL_GPL(ata_dev_disable); 1232 1233 /** 1234 * ata_eh_detach_dev - detach ATA device 1235 * @dev: ATA device to detach 1236 * 1237 * Detach @dev. 1238 * 1239 * LOCKING: 1240 * None. 1241 */ 1242 void ata_eh_detach_dev(struct ata_device *dev) 1243 { 1244 struct ata_link *link = dev->link; 1245 struct ata_port *ap = link->ap; 1246 struct ata_eh_context *ehc = &link->eh_context; 1247 unsigned long flags; 1248 1249 ata_dev_disable(dev); 1250 1251 spin_lock_irqsave(ap->lock, flags); 1252 1253 dev->flags &= ~ATA_DFLAG_DETACH; 1254 1255 if (ata_scsi_offline_dev(dev)) { 1256 dev->flags |= ATA_DFLAG_DETACHED; 1257 ap->pflags |= ATA_PFLAG_SCSI_HOTPLUG; 1258 } 1259 1260 /* clear per-dev EH info */ 1261 ata_eh_clear_action(link, dev, &link->eh_info, ATA_EH_PERDEV_MASK); 1262 ata_eh_clear_action(link, dev, &link->eh_context.i, ATA_EH_PERDEV_MASK); 1263 ehc->saved_xfer_mode[dev->devno] = 0; 1264 ehc->saved_ncq_enabled &= ~(1 << dev->devno); 1265 1266 spin_unlock_irqrestore(ap->lock, flags); 1267 } 1268 1269 /** 1270 * ata_eh_about_to_do - about to perform eh_action 1271 * @link: target ATA link 1272 * @dev: target ATA dev for per-dev action (can be NULL) 1273 * @action: action about to be performed 1274 * 1275 * Called just before performing EH actions to clear related bits 1276 * in @link->eh_info such that eh actions are not unnecessarily 1277 * repeated. 1278 * 1279 * LOCKING: 1280 * None. 1281 */ 1282 void ata_eh_about_to_do(struct ata_link *link, struct ata_device *dev, 1283 unsigned int action) 1284 { 1285 struct ata_port *ap = link->ap; 1286 struct ata_eh_info *ehi = &link->eh_info; 1287 struct ata_eh_context *ehc = &link->eh_context; 1288 unsigned long flags; 1289 1290 spin_lock_irqsave(ap->lock, flags); 1291 1292 ata_eh_clear_action(link, dev, ehi, action); 1293 1294 /* About to take EH action, set RECOVERED. Ignore actions on 1295 * slave links as master will do them again. 1296 */ 1297 if (!(ehc->i.flags & ATA_EHI_QUIET) && link != ap->slave_link) 1298 ap->pflags |= ATA_PFLAG_RECOVERED; 1299 1300 spin_unlock_irqrestore(ap->lock, flags); 1301 } 1302 1303 /** 1304 * ata_eh_done - EH action complete 1305 * @link: ATA link for which EH actions are complete 1306 * @dev: target ATA dev for per-dev action (can be NULL) 1307 * @action: action just completed 1308 * 1309 * Called right after performing EH actions to clear related bits 1310 * in @link->eh_context. 1311 * 1312 * LOCKING: 1313 * None. 1314 */ 1315 void ata_eh_done(struct ata_link *link, struct ata_device *dev, 1316 unsigned int action) 1317 { 1318 struct ata_eh_context *ehc = &link->eh_context; 1319 1320 ata_eh_clear_action(link, dev, &ehc->i, action); 1321 } 1322 1323 /** 1324 * ata_err_string - convert err_mask to descriptive string 1325 * @err_mask: error mask to convert to string 1326 * 1327 * Convert @err_mask to descriptive string. Errors are 1328 * prioritized according to severity and only the most severe 1329 * error is reported. 1330 * 1331 * LOCKING: 1332 * None. 1333 * 1334 * RETURNS: 1335 * Descriptive string for @err_mask 1336 */ 1337 static const char *ata_err_string(unsigned int err_mask) 1338 { 1339 if (err_mask & AC_ERR_HOST_BUS) 1340 return "host bus error"; 1341 if (err_mask & AC_ERR_ATA_BUS) 1342 return "ATA bus error"; 1343 if (err_mask & AC_ERR_TIMEOUT) 1344 return "timeout"; 1345 if (err_mask & AC_ERR_HSM) 1346 return "HSM violation"; 1347 if (err_mask & AC_ERR_SYSTEM) 1348 return "internal error"; 1349 if (err_mask & AC_ERR_MEDIA) 1350 return "media error"; 1351 if (err_mask & AC_ERR_INVALID) 1352 return "invalid argument"; 1353 if (err_mask & AC_ERR_DEV) 1354 return "device error"; 1355 if (err_mask & AC_ERR_NCQ) 1356 return "NCQ error"; 1357 if (err_mask & AC_ERR_NODEV_HINT) 1358 return "Polling detection error"; 1359 return "unknown error"; 1360 } 1361 1362 /** 1363 * atapi_eh_tur - perform ATAPI TEST_UNIT_READY 1364 * @dev: target ATAPI device 1365 * @r_sense_key: out parameter for sense_key 1366 * 1367 * Perform ATAPI TEST_UNIT_READY. 1368 * 1369 * LOCKING: 1370 * EH context (may sleep). 1371 * 1372 * RETURNS: 1373 * 0 on success, AC_ERR_* mask on failure. 1374 */ 1375 unsigned int atapi_eh_tur(struct ata_device *dev, u8 *r_sense_key) 1376 { 1377 u8 cdb[ATAPI_CDB_LEN] = { TEST_UNIT_READY, 0, 0, 0, 0, 0 }; 1378 struct ata_taskfile tf; 1379 unsigned int err_mask; 1380 1381 ata_tf_init(dev, &tf); 1382 1383 tf.flags |= ATA_TFLAG_ISADDR | ATA_TFLAG_DEVICE; 1384 tf.command = ATA_CMD_PACKET; 1385 tf.protocol = ATAPI_PROT_NODATA; 1386 1387 err_mask = ata_exec_internal(dev, &tf, cdb, DMA_NONE, NULL, 0, 0); 1388 if (err_mask == AC_ERR_DEV) 1389 *r_sense_key = tf.feature >> 4; 1390 return err_mask; 1391 } 1392 1393 /** 1394 * ata_eh_request_sense - perform REQUEST_SENSE_DATA_EXT 1395 * @qc: qc to perform REQUEST_SENSE_SENSE_DATA_EXT to 1396 * @cmd: scsi command for which the sense code should be set 1397 * 1398 * Perform REQUEST_SENSE_DATA_EXT after the device reported CHECK 1399 * SENSE. This function is an EH helper. 1400 * 1401 * LOCKING: 1402 * Kernel thread context (may sleep). 1403 */ 1404 static void ata_eh_request_sense(struct ata_queued_cmd *qc, 1405 struct scsi_cmnd *cmd) 1406 { 1407 struct ata_device *dev = qc->dev; 1408 struct ata_taskfile tf; 1409 unsigned int err_mask; 1410 1411 if (qc->ap->pflags & ATA_PFLAG_FROZEN) { 1412 ata_dev_warn(dev, "sense data available but port frozen\n"); 1413 return; 1414 } 1415 1416 if (!cmd || qc->flags & ATA_QCFLAG_SENSE_VALID) 1417 return; 1418 1419 if (!ata_id_sense_reporting_enabled(dev->id)) { 1420 ata_dev_warn(qc->dev, "sense data reporting disabled\n"); 1421 return; 1422 } 1423 1424 DPRINTK("ATA request sense\n"); 1425 1426 ata_tf_init(dev, &tf); 1427 tf.flags |= ATA_TFLAG_ISADDR | ATA_TFLAG_DEVICE; 1428 tf.flags |= ATA_TFLAG_LBA | ATA_TFLAG_LBA48; 1429 tf.command = ATA_CMD_REQ_SENSE_DATA; 1430 tf.protocol = ATA_PROT_NODATA; 1431 1432 err_mask = ata_exec_internal(dev, &tf, NULL, DMA_NONE, NULL, 0, 0); 1433 /* Ignore err_mask; ATA_ERR might be set */ 1434 if (tf.command & ATA_SENSE) { 1435 ata_scsi_set_sense(dev, cmd, tf.lbah, tf.lbam, tf.lbal); 1436 qc->flags |= ATA_QCFLAG_SENSE_VALID; 1437 } else { 1438 ata_dev_warn(dev, "request sense failed stat %02x emask %x\n", 1439 tf.command, err_mask); 1440 } 1441 } 1442 1443 /** 1444 * atapi_eh_request_sense - perform ATAPI REQUEST_SENSE 1445 * @dev: device to perform REQUEST_SENSE to 1446 * @sense_buf: result sense data buffer (SCSI_SENSE_BUFFERSIZE bytes long) 1447 * @dfl_sense_key: default sense key to use 1448 * 1449 * Perform ATAPI REQUEST_SENSE after the device reported CHECK 1450 * SENSE. This function is EH helper. 1451 * 1452 * LOCKING: 1453 * Kernel thread context (may sleep). 1454 * 1455 * RETURNS: 1456 * 0 on success, AC_ERR_* mask on failure 1457 */ 1458 unsigned int atapi_eh_request_sense(struct ata_device *dev, 1459 u8 *sense_buf, u8 dfl_sense_key) 1460 { 1461 u8 cdb[ATAPI_CDB_LEN] = 1462 { REQUEST_SENSE, 0, 0, 0, SCSI_SENSE_BUFFERSIZE, 0 }; 1463 struct ata_port *ap = dev->link->ap; 1464 struct ata_taskfile tf; 1465 1466 DPRINTK("ATAPI request sense\n"); 1467 1468 memset(sense_buf, 0, SCSI_SENSE_BUFFERSIZE); 1469 1470 /* initialize sense_buf with the error register, 1471 * for the case where they are -not- overwritten 1472 */ 1473 sense_buf[0] = 0x70; 1474 sense_buf[2] = dfl_sense_key; 1475 1476 /* some devices time out if garbage left in tf */ 1477 ata_tf_init(dev, &tf); 1478 1479 tf.flags |= ATA_TFLAG_ISADDR | ATA_TFLAG_DEVICE; 1480 tf.command = ATA_CMD_PACKET; 1481 1482 /* is it pointless to prefer PIO for "safety reasons"? */ 1483 if (ap->flags & ATA_FLAG_PIO_DMA) { 1484 tf.protocol = ATAPI_PROT_DMA; 1485 tf.feature |= ATAPI_PKT_DMA; 1486 } else { 1487 tf.protocol = ATAPI_PROT_PIO; 1488 tf.lbam = SCSI_SENSE_BUFFERSIZE; 1489 tf.lbah = 0; 1490 } 1491 1492 return ata_exec_internal(dev, &tf, cdb, DMA_FROM_DEVICE, 1493 sense_buf, SCSI_SENSE_BUFFERSIZE, 0); 1494 } 1495 1496 /** 1497 * ata_eh_analyze_serror - analyze SError for a failed port 1498 * @link: ATA link to analyze SError for 1499 * 1500 * Analyze SError if available and further determine cause of 1501 * failure. 1502 * 1503 * LOCKING: 1504 * None. 1505 */ 1506 static void ata_eh_analyze_serror(struct ata_link *link) 1507 { 1508 struct ata_eh_context *ehc = &link->eh_context; 1509 u32 serror = ehc->i.serror; 1510 unsigned int err_mask = 0, action = 0; 1511 u32 hotplug_mask; 1512 1513 if (serror & (SERR_PERSISTENT | SERR_DATA)) { 1514 err_mask |= AC_ERR_ATA_BUS; 1515 action |= ATA_EH_RESET; 1516 } 1517 if (serror & SERR_PROTOCOL) { 1518 err_mask |= AC_ERR_HSM; 1519 action |= ATA_EH_RESET; 1520 } 1521 if (serror & SERR_INTERNAL) { 1522 err_mask |= AC_ERR_SYSTEM; 1523 action |= ATA_EH_RESET; 1524 } 1525 1526 /* Determine whether a hotplug event has occurred. Both 1527 * SError.N/X are considered hotplug events for enabled or 1528 * host links. For disabled PMP links, only N bit is 1529 * considered as X bit is left at 1 for link plugging. 1530 */ 1531 if (link->lpm_policy > ATA_LPM_MAX_POWER) 1532 hotplug_mask = 0; /* hotplug doesn't work w/ LPM */ 1533 else if (!(link->flags & ATA_LFLAG_DISABLED) || ata_is_host_link(link)) 1534 hotplug_mask = SERR_PHYRDY_CHG | SERR_DEV_XCHG; 1535 else 1536 hotplug_mask = SERR_PHYRDY_CHG; 1537 1538 if (serror & hotplug_mask) 1539 ata_ehi_hotplugged(&ehc->i); 1540 1541 ehc->i.err_mask |= err_mask; 1542 ehc->i.action |= action; 1543 } 1544 1545 /** 1546 * ata_eh_analyze_tf - analyze taskfile of a failed qc 1547 * @qc: qc to analyze 1548 * @tf: Taskfile registers to analyze 1549 * 1550 * Analyze taskfile of @qc and further determine cause of 1551 * failure. This function also requests ATAPI sense data if 1552 * available. 1553 * 1554 * LOCKING: 1555 * Kernel thread context (may sleep). 1556 * 1557 * RETURNS: 1558 * Determined recovery action 1559 */ 1560 static unsigned int ata_eh_analyze_tf(struct ata_queued_cmd *qc, 1561 const struct ata_taskfile *tf) 1562 { 1563 unsigned int tmp, action = 0; 1564 u8 stat = tf->command, err = tf->feature; 1565 1566 if ((stat & (ATA_BUSY | ATA_DRQ | ATA_DRDY)) != ATA_DRDY) { 1567 qc->err_mask |= AC_ERR_HSM; 1568 return ATA_EH_RESET; 1569 } 1570 1571 if (stat & (ATA_ERR | ATA_DF)) { 1572 qc->err_mask |= AC_ERR_DEV; 1573 /* 1574 * Sense data reporting does not work if the 1575 * device fault bit is set. 1576 */ 1577 if (stat & ATA_DF) 1578 stat &= ~ATA_SENSE; 1579 } else { 1580 return 0; 1581 } 1582 1583 switch (qc->dev->class) { 1584 case ATA_DEV_ZAC: 1585 if (stat & ATA_SENSE) 1586 ata_eh_request_sense(qc, qc->scsicmd); 1587 fallthrough; 1588 case ATA_DEV_ATA: 1589 if (err & ATA_ICRC) 1590 qc->err_mask |= AC_ERR_ATA_BUS; 1591 if (err & (ATA_UNC | ATA_AMNF)) 1592 qc->err_mask |= AC_ERR_MEDIA; 1593 if (err & ATA_IDNF) 1594 qc->err_mask |= AC_ERR_INVALID; 1595 break; 1596 1597 case ATA_DEV_ATAPI: 1598 if (!(qc->ap->pflags & ATA_PFLAG_FROZEN)) { 1599 tmp = atapi_eh_request_sense(qc->dev, 1600 qc->scsicmd->sense_buffer, 1601 qc->result_tf.feature >> 4); 1602 if (!tmp) 1603 qc->flags |= ATA_QCFLAG_SENSE_VALID; 1604 else 1605 qc->err_mask |= tmp; 1606 } 1607 } 1608 1609 if (qc->flags & ATA_QCFLAG_SENSE_VALID) { 1610 enum scsi_disposition ret = scsi_check_sense(qc->scsicmd); 1611 /* 1612 * SUCCESS here means that the sense code could be 1613 * evaluated and should be passed to the upper layers 1614 * for correct evaluation. 1615 * FAILED means the sense code could not be interpreted 1616 * and the device would need to be reset. 1617 * NEEDS_RETRY and ADD_TO_MLQUEUE means that the 1618 * command would need to be retried. 1619 */ 1620 if (ret == NEEDS_RETRY || ret == ADD_TO_MLQUEUE) { 1621 qc->flags |= ATA_QCFLAG_RETRY; 1622 qc->err_mask |= AC_ERR_OTHER; 1623 } else if (ret != SUCCESS) { 1624 qc->err_mask |= AC_ERR_HSM; 1625 } 1626 } 1627 if (qc->err_mask & (AC_ERR_HSM | AC_ERR_TIMEOUT | AC_ERR_ATA_BUS)) 1628 action |= ATA_EH_RESET; 1629 1630 return action; 1631 } 1632 1633 static int ata_eh_categorize_error(unsigned int eflags, unsigned int err_mask, 1634 int *xfer_ok) 1635 { 1636 int base = 0; 1637 1638 if (!(eflags & ATA_EFLAG_DUBIOUS_XFER)) 1639 *xfer_ok = 1; 1640 1641 if (!*xfer_ok) 1642 base = ATA_ECAT_DUBIOUS_NONE; 1643 1644 if (err_mask & AC_ERR_ATA_BUS) 1645 return base + ATA_ECAT_ATA_BUS; 1646 1647 if (err_mask & AC_ERR_TIMEOUT) 1648 return base + ATA_ECAT_TOUT_HSM; 1649 1650 if (eflags & ATA_EFLAG_IS_IO) { 1651 if (err_mask & AC_ERR_HSM) 1652 return base + ATA_ECAT_TOUT_HSM; 1653 if ((err_mask & 1654 (AC_ERR_DEV|AC_ERR_MEDIA|AC_ERR_INVALID)) == AC_ERR_DEV) 1655 return base + ATA_ECAT_UNK_DEV; 1656 } 1657 1658 return 0; 1659 } 1660 1661 struct speed_down_verdict_arg { 1662 u64 since; 1663 int xfer_ok; 1664 int nr_errors[ATA_ECAT_NR]; 1665 }; 1666 1667 static int speed_down_verdict_cb(struct ata_ering_entry *ent, void *void_arg) 1668 { 1669 struct speed_down_verdict_arg *arg = void_arg; 1670 int cat; 1671 1672 if ((ent->eflags & ATA_EFLAG_OLD_ER) || (ent->timestamp < arg->since)) 1673 return -1; 1674 1675 cat = ata_eh_categorize_error(ent->eflags, ent->err_mask, 1676 &arg->xfer_ok); 1677 arg->nr_errors[cat]++; 1678 1679 return 0; 1680 } 1681 1682 /** 1683 * ata_eh_speed_down_verdict - Determine speed down verdict 1684 * @dev: Device of interest 1685 * 1686 * This function examines error ring of @dev and determines 1687 * whether NCQ needs to be turned off, transfer speed should be 1688 * stepped down, or falling back to PIO is necessary. 1689 * 1690 * ECAT_ATA_BUS : ATA_BUS error for any command 1691 * 1692 * ECAT_TOUT_HSM : TIMEOUT for any command or HSM violation for 1693 * IO commands 1694 * 1695 * ECAT_UNK_DEV : Unknown DEV error for IO commands 1696 * 1697 * ECAT_DUBIOUS_* : Identical to above three but occurred while 1698 * data transfer hasn't been verified. 1699 * 1700 * Verdicts are 1701 * 1702 * NCQ_OFF : Turn off NCQ. 1703 * 1704 * SPEED_DOWN : Speed down transfer speed but don't fall back 1705 * to PIO. 1706 * 1707 * FALLBACK_TO_PIO : Fall back to PIO. 1708 * 1709 * Even if multiple verdicts are returned, only one action is 1710 * taken per error. An action triggered by non-DUBIOUS errors 1711 * clears ering, while one triggered by DUBIOUS_* errors doesn't. 1712 * This is to expedite speed down decisions right after device is 1713 * initially configured. 1714 * 1715 * The following are speed down rules. #1 and #2 deal with 1716 * DUBIOUS errors. 1717 * 1718 * 1. If more than one DUBIOUS_ATA_BUS or DUBIOUS_TOUT_HSM errors 1719 * occurred during last 5 mins, SPEED_DOWN and FALLBACK_TO_PIO. 1720 * 1721 * 2. If more than one DUBIOUS_TOUT_HSM or DUBIOUS_UNK_DEV errors 1722 * occurred during last 5 mins, NCQ_OFF. 1723 * 1724 * 3. If more than 8 ATA_BUS, TOUT_HSM or UNK_DEV errors 1725 * occurred during last 5 mins, FALLBACK_TO_PIO 1726 * 1727 * 4. If more than 3 TOUT_HSM or UNK_DEV errors occurred 1728 * during last 10 mins, NCQ_OFF. 1729 * 1730 * 5. If more than 3 ATA_BUS or TOUT_HSM errors, or more than 6 1731 * UNK_DEV errors occurred during last 10 mins, SPEED_DOWN. 1732 * 1733 * LOCKING: 1734 * Inherited from caller. 1735 * 1736 * RETURNS: 1737 * OR of ATA_EH_SPDN_* flags. 1738 */ 1739 static unsigned int ata_eh_speed_down_verdict(struct ata_device *dev) 1740 { 1741 const u64 j5mins = 5LLU * 60 * HZ, j10mins = 10LLU * 60 * HZ; 1742 u64 j64 = get_jiffies_64(); 1743 struct speed_down_verdict_arg arg; 1744 unsigned int verdict = 0; 1745 1746 /* scan past 5 mins of error history */ 1747 memset(&arg, 0, sizeof(arg)); 1748 arg.since = j64 - min(j64, j5mins); 1749 ata_ering_map(&dev->ering, speed_down_verdict_cb, &arg); 1750 1751 if (arg.nr_errors[ATA_ECAT_DUBIOUS_ATA_BUS] + 1752 arg.nr_errors[ATA_ECAT_DUBIOUS_TOUT_HSM] > 1) 1753 verdict |= ATA_EH_SPDN_SPEED_DOWN | 1754 ATA_EH_SPDN_FALLBACK_TO_PIO | ATA_EH_SPDN_KEEP_ERRORS; 1755 1756 if (arg.nr_errors[ATA_ECAT_DUBIOUS_TOUT_HSM] + 1757 arg.nr_errors[ATA_ECAT_DUBIOUS_UNK_DEV] > 1) 1758 verdict |= ATA_EH_SPDN_NCQ_OFF | ATA_EH_SPDN_KEEP_ERRORS; 1759 1760 if (arg.nr_errors[ATA_ECAT_ATA_BUS] + 1761 arg.nr_errors[ATA_ECAT_TOUT_HSM] + 1762 arg.nr_errors[ATA_ECAT_UNK_DEV] > 6) 1763 verdict |= ATA_EH_SPDN_FALLBACK_TO_PIO; 1764 1765 /* scan past 10 mins of error history */ 1766 memset(&arg, 0, sizeof(arg)); 1767 arg.since = j64 - min(j64, j10mins); 1768 ata_ering_map(&dev->ering, speed_down_verdict_cb, &arg); 1769 1770 if (arg.nr_errors[ATA_ECAT_TOUT_HSM] + 1771 arg.nr_errors[ATA_ECAT_UNK_DEV] > 3) 1772 verdict |= ATA_EH_SPDN_NCQ_OFF; 1773 1774 if (arg.nr_errors[ATA_ECAT_ATA_BUS] + 1775 arg.nr_errors[ATA_ECAT_TOUT_HSM] > 3 || 1776 arg.nr_errors[ATA_ECAT_UNK_DEV] > 6) 1777 verdict |= ATA_EH_SPDN_SPEED_DOWN; 1778 1779 return verdict; 1780 } 1781 1782 /** 1783 * ata_eh_speed_down - record error and speed down if necessary 1784 * @dev: Failed device 1785 * @eflags: mask of ATA_EFLAG_* flags 1786 * @err_mask: err_mask of the error 1787 * 1788 * Record error and examine error history to determine whether 1789 * adjusting transmission speed is necessary. It also sets 1790 * transmission limits appropriately if such adjustment is 1791 * necessary. 1792 * 1793 * LOCKING: 1794 * Kernel thread context (may sleep). 1795 * 1796 * RETURNS: 1797 * Determined recovery action. 1798 */ 1799 static unsigned int ata_eh_speed_down(struct ata_device *dev, 1800 unsigned int eflags, unsigned int err_mask) 1801 { 1802 struct ata_link *link = ata_dev_phys_link(dev); 1803 int xfer_ok = 0; 1804 unsigned int verdict; 1805 unsigned int action = 0; 1806 1807 /* don't bother if Cat-0 error */ 1808 if (ata_eh_categorize_error(eflags, err_mask, &xfer_ok) == 0) 1809 return 0; 1810 1811 /* record error and determine whether speed down is necessary */ 1812 ata_ering_record(&dev->ering, eflags, err_mask); 1813 verdict = ata_eh_speed_down_verdict(dev); 1814 1815 /* turn off NCQ? */ 1816 if ((verdict & ATA_EH_SPDN_NCQ_OFF) && 1817 (dev->flags & (ATA_DFLAG_PIO | ATA_DFLAG_NCQ | 1818 ATA_DFLAG_NCQ_OFF)) == ATA_DFLAG_NCQ) { 1819 dev->flags |= ATA_DFLAG_NCQ_OFF; 1820 ata_dev_warn(dev, "NCQ disabled due to excessive errors\n"); 1821 goto done; 1822 } 1823 1824 /* speed down? */ 1825 if (verdict & ATA_EH_SPDN_SPEED_DOWN) { 1826 /* speed down SATA link speed if possible */ 1827 if (sata_down_spd_limit(link, 0) == 0) { 1828 action |= ATA_EH_RESET; 1829 goto done; 1830 } 1831 1832 /* lower transfer mode */ 1833 if (dev->spdn_cnt < 2) { 1834 static const int dma_dnxfer_sel[] = 1835 { ATA_DNXFER_DMA, ATA_DNXFER_40C }; 1836 static const int pio_dnxfer_sel[] = 1837 { ATA_DNXFER_PIO, ATA_DNXFER_FORCE_PIO0 }; 1838 int sel; 1839 1840 if (dev->xfer_shift != ATA_SHIFT_PIO) 1841 sel = dma_dnxfer_sel[dev->spdn_cnt]; 1842 else 1843 sel = pio_dnxfer_sel[dev->spdn_cnt]; 1844 1845 dev->spdn_cnt++; 1846 1847 if (ata_down_xfermask_limit(dev, sel) == 0) { 1848 action |= ATA_EH_RESET; 1849 goto done; 1850 } 1851 } 1852 } 1853 1854 /* Fall back to PIO? Slowing down to PIO is meaningless for 1855 * SATA ATA devices. Consider it only for PATA and SATAPI. 1856 */ 1857 if ((verdict & ATA_EH_SPDN_FALLBACK_TO_PIO) && (dev->spdn_cnt >= 2) && 1858 (link->ap->cbl != ATA_CBL_SATA || dev->class == ATA_DEV_ATAPI) && 1859 (dev->xfer_shift != ATA_SHIFT_PIO)) { 1860 if (ata_down_xfermask_limit(dev, ATA_DNXFER_FORCE_PIO) == 0) { 1861 dev->spdn_cnt = 0; 1862 action |= ATA_EH_RESET; 1863 goto done; 1864 } 1865 } 1866 1867 return 0; 1868 done: 1869 /* device has been slowed down, blow error history */ 1870 if (!(verdict & ATA_EH_SPDN_KEEP_ERRORS)) 1871 ata_ering_clear(&dev->ering); 1872 return action; 1873 } 1874 1875 /** 1876 * ata_eh_worth_retry - analyze error and decide whether to retry 1877 * @qc: qc to possibly retry 1878 * 1879 * Look at the cause of the error and decide if a retry 1880 * might be useful or not. We don't want to retry media errors 1881 * because the drive itself has probably already taken 10-30 seconds 1882 * doing its own internal retries before reporting the failure. 1883 */ 1884 static inline int ata_eh_worth_retry(struct ata_queued_cmd *qc) 1885 { 1886 if (qc->err_mask & AC_ERR_MEDIA) 1887 return 0; /* don't retry media errors */ 1888 if (qc->flags & ATA_QCFLAG_IO) 1889 return 1; /* otherwise retry anything from fs stack */ 1890 if (qc->err_mask & AC_ERR_INVALID) 1891 return 0; /* don't retry these */ 1892 return qc->err_mask != AC_ERR_DEV; /* retry if not dev error */ 1893 } 1894 1895 /** 1896 * ata_eh_quiet - check if we need to be quiet about a command error 1897 * @qc: qc to check 1898 * 1899 * Look at the qc flags anbd its scsi command request flags to determine 1900 * if we need to be quiet about the command failure. 1901 */ 1902 static inline bool ata_eh_quiet(struct ata_queued_cmd *qc) 1903 { 1904 if (qc->scsicmd && scsi_cmd_to_rq(qc->scsicmd)->rq_flags & RQF_QUIET) 1905 qc->flags |= ATA_QCFLAG_QUIET; 1906 return qc->flags & ATA_QCFLAG_QUIET; 1907 } 1908 1909 /** 1910 * ata_eh_link_autopsy - analyze error and determine recovery action 1911 * @link: host link to perform autopsy on 1912 * 1913 * Analyze why @link failed and determine which recovery actions 1914 * are needed. This function also sets more detailed AC_ERR_* 1915 * values and fills sense data for ATAPI CHECK SENSE. 1916 * 1917 * LOCKING: 1918 * Kernel thread context (may sleep). 1919 */ 1920 static void ata_eh_link_autopsy(struct ata_link *link) 1921 { 1922 struct ata_port *ap = link->ap; 1923 struct ata_eh_context *ehc = &link->eh_context; 1924 struct ata_queued_cmd *qc; 1925 struct ata_device *dev; 1926 unsigned int all_err_mask = 0, eflags = 0; 1927 int tag, nr_failed = 0, nr_quiet = 0; 1928 u32 serror; 1929 int rc; 1930 1931 DPRINTK("ENTER\n"); 1932 1933 if (ehc->i.flags & ATA_EHI_NO_AUTOPSY) 1934 return; 1935 1936 /* obtain and analyze SError */ 1937 rc = sata_scr_read(link, SCR_ERROR, &serror); 1938 if (rc == 0) { 1939 ehc->i.serror |= serror; 1940 ata_eh_analyze_serror(link); 1941 } else if (rc != -EOPNOTSUPP) { 1942 /* SError read failed, force reset and probing */ 1943 ehc->i.probe_mask |= ATA_ALL_DEVICES; 1944 ehc->i.action |= ATA_EH_RESET; 1945 ehc->i.err_mask |= AC_ERR_OTHER; 1946 } 1947 1948 /* analyze NCQ failure */ 1949 ata_eh_analyze_ncq_error(link); 1950 1951 /* any real error trumps AC_ERR_OTHER */ 1952 if (ehc->i.err_mask & ~AC_ERR_OTHER) 1953 ehc->i.err_mask &= ~AC_ERR_OTHER; 1954 1955 all_err_mask |= ehc->i.err_mask; 1956 1957 ata_qc_for_each_raw(ap, qc, tag) { 1958 if (!(qc->flags & ATA_QCFLAG_FAILED) || 1959 ata_dev_phys_link(qc->dev) != link) 1960 continue; 1961 1962 /* inherit upper level err_mask */ 1963 qc->err_mask |= ehc->i.err_mask; 1964 1965 /* analyze TF */ 1966 ehc->i.action |= ata_eh_analyze_tf(qc, &qc->result_tf); 1967 1968 /* DEV errors are probably spurious in case of ATA_BUS error */ 1969 if (qc->err_mask & AC_ERR_ATA_BUS) 1970 qc->err_mask &= ~(AC_ERR_DEV | AC_ERR_MEDIA | 1971 AC_ERR_INVALID); 1972 1973 /* any real error trumps unknown error */ 1974 if (qc->err_mask & ~AC_ERR_OTHER) 1975 qc->err_mask &= ~AC_ERR_OTHER; 1976 1977 /* 1978 * SENSE_VALID trumps dev/unknown error and revalidation. Upper 1979 * layers will determine whether the command is worth retrying 1980 * based on the sense data and device class/type. Otherwise, 1981 * determine directly if the command is worth retrying using its 1982 * error mask and flags. 1983 */ 1984 if (qc->flags & ATA_QCFLAG_SENSE_VALID) 1985 qc->err_mask &= ~(AC_ERR_DEV | AC_ERR_OTHER); 1986 else if (ata_eh_worth_retry(qc)) 1987 qc->flags |= ATA_QCFLAG_RETRY; 1988 1989 /* accumulate error info */ 1990 ehc->i.dev = qc->dev; 1991 all_err_mask |= qc->err_mask; 1992 if (qc->flags & ATA_QCFLAG_IO) 1993 eflags |= ATA_EFLAG_IS_IO; 1994 trace_ata_eh_link_autopsy_qc(qc); 1995 1996 /* Count quiet errors */ 1997 if (ata_eh_quiet(qc)) 1998 nr_quiet++; 1999 nr_failed++; 2000 } 2001 2002 /* If all failed commands requested silence, then be quiet */ 2003 if (nr_quiet == nr_failed) 2004 ehc->i.flags |= ATA_EHI_QUIET; 2005 2006 /* enforce default EH actions */ 2007 if (ap->pflags & ATA_PFLAG_FROZEN || 2008 all_err_mask & (AC_ERR_HSM | AC_ERR_TIMEOUT)) 2009 ehc->i.action |= ATA_EH_RESET; 2010 else if (((eflags & ATA_EFLAG_IS_IO) && all_err_mask) || 2011 (!(eflags & ATA_EFLAG_IS_IO) && (all_err_mask & ~AC_ERR_DEV))) 2012 ehc->i.action |= ATA_EH_REVALIDATE; 2013 2014 /* If we have offending qcs and the associated failed device, 2015 * perform per-dev EH action only on the offending device. 2016 */ 2017 if (ehc->i.dev) { 2018 ehc->i.dev_action[ehc->i.dev->devno] |= 2019 ehc->i.action & ATA_EH_PERDEV_MASK; 2020 ehc->i.action &= ~ATA_EH_PERDEV_MASK; 2021 } 2022 2023 /* propagate timeout to host link */ 2024 if ((all_err_mask & AC_ERR_TIMEOUT) && !ata_is_host_link(link)) 2025 ap->link.eh_context.i.err_mask |= AC_ERR_TIMEOUT; 2026 2027 /* record error and consider speeding down */ 2028 dev = ehc->i.dev; 2029 if (!dev && ((ata_link_max_devices(link) == 1 && 2030 ata_dev_enabled(link->device)))) 2031 dev = link->device; 2032 2033 if (dev) { 2034 if (dev->flags & ATA_DFLAG_DUBIOUS_XFER) 2035 eflags |= ATA_EFLAG_DUBIOUS_XFER; 2036 ehc->i.action |= ata_eh_speed_down(dev, eflags, all_err_mask); 2037 trace_ata_eh_link_autopsy(dev, ehc->i.action, all_err_mask); 2038 } 2039 DPRINTK("EXIT\n"); 2040 } 2041 2042 /** 2043 * ata_eh_autopsy - analyze error and determine recovery action 2044 * @ap: host port to perform autopsy on 2045 * 2046 * Analyze all links of @ap and determine why they failed and 2047 * which recovery actions are needed. 2048 * 2049 * LOCKING: 2050 * Kernel thread context (may sleep). 2051 */ 2052 void ata_eh_autopsy(struct ata_port *ap) 2053 { 2054 struct ata_link *link; 2055 2056 ata_for_each_link(link, ap, EDGE) 2057 ata_eh_link_autopsy(link); 2058 2059 /* Handle the frigging slave link. Autopsy is done similarly 2060 * but actions and flags are transferred over to the master 2061 * link and handled from there. 2062 */ 2063 if (ap->slave_link) { 2064 struct ata_eh_context *mehc = &ap->link.eh_context; 2065 struct ata_eh_context *sehc = &ap->slave_link->eh_context; 2066 2067 /* transfer control flags from master to slave */ 2068 sehc->i.flags |= mehc->i.flags & ATA_EHI_TO_SLAVE_MASK; 2069 2070 /* perform autopsy on the slave link */ 2071 ata_eh_link_autopsy(ap->slave_link); 2072 2073 /* transfer actions from slave to master and clear slave */ 2074 ata_eh_about_to_do(ap->slave_link, NULL, ATA_EH_ALL_ACTIONS); 2075 mehc->i.action |= sehc->i.action; 2076 mehc->i.dev_action[1] |= sehc->i.dev_action[1]; 2077 mehc->i.flags |= sehc->i.flags; 2078 ata_eh_done(ap->slave_link, NULL, ATA_EH_ALL_ACTIONS); 2079 } 2080 2081 /* Autopsy of fanout ports can affect host link autopsy. 2082 * Perform host link autopsy last. 2083 */ 2084 if (sata_pmp_attached(ap)) 2085 ata_eh_link_autopsy(&ap->link); 2086 } 2087 2088 /** 2089 * ata_get_cmd_descript - get description for ATA command 2090 * @command: ATA command code to get description for 2091 * 2092 * Return a textual description of the given command, or NULL if the 2093 * command is not known. 2094 * 2095 * LOCKING: 2096 * None 2097 */ 2098 const char *ata_get_cmd_descript(u8 command) 2099 { 2100 #ifdef CONFIG_ATA_VERBOSE_ERROR 2101 static const struct 2102 { 2103 u8 command; 2104 const char *text; 2105 } cmd_descr[] = { 2106 { ATA_CMD_DEV_RESET, "DEVICE RESET" }, 2107 { ATA_CMD_CHK_POWER, "CHECK POWER MODE" }, 2108 { ATA_CMD_STANDBY, "STANDBY" }, 2109 { ATA_CMD_IDLE, "IDLE" }, 2110 { ATA_CMD_EDD, "EXECUTE DEVICE DIAGNOSTIC" }, 2111 { ATA_CMD_DOWNLOAD_MICRO, "DOWNLOAD MICROCODE" }, 2112 { ATA_CMD_DOWNLOAD_MICRO_DMA, "DOWNLOAD MICROCODE DMA" }, 2113 { ATA_CMD_NOP, "NOP" }, 2114 { ATA_CMD_FLUSH, "FLUSH CACHE" }, 2115 { ATA_CMD_FLUSH_EXT, "FLUSH CACHE EXT" }, 2116 { ATA_CMD_ID_ATA, "IDENTIFY DEVICE" }, 2117 { ATA_CMD_ID_ATAPI, "IDENTIFY PACKET DEVICE" }, 2118 { ATA_CMD_SERVICE, "SERVICE" }, 2119 { ATA_CMD_READ, "READ DMA" }, 2120 { ATA_CMD_READ_EXT, "READ DMA EXT" }, 2121 { ATA_CMD_READ_QUEUED, "READ DMA QUEUED" }, 2122 { ATA_CMD_READ_STREAM_EXT, "READ STREAM EXT" }, 2123 { ATA_CMD_READ_STREAM_DMA_EXT, "READ STREAM DMA EXT" }, 2124 { ATA_CMD_WRITE, "WRITE DMA" }, 2125 { ATA_CMD_WRITE_EXT, "WRITE DMA EXT" }, 2126 { ATA_CMD_WRITE_QUEUED, "WRITE DMA QUEUED EXT" }, 2127 { ATA_CMD_WRITE_STREAM_EXT, "WRITE STREAM EXT" }, 2128 { ATA_CMD_WRITE_STREAM_DMA_EXT, "WRITE STREAM DMA EXT" }, 2129 { ATA_CMD_WRITE_FUA_EXT, "WRITE DMA FUA EXT" }, 2130 { ATA_CMD_WRITE_QUEUED_FUA_EXT, "WRITE DMA QUEUED FUA EXT" }, 2131 { ATA_CMD_FPDMA_READ, "READ FPDMA QUEUED" }, 2132 { ATA_CMD_FPDMA_WRITE, "WRITE FPDMA QUEUED" }, 2133 { ATA_CMD_FPDMA_SEND, "SEND FPDMA QUEUED" }, 2134 { ATA_CMD_FPDMA_RECV, "RECEIVE FPDMA QUEUED" }, 2135 { ATA_CMD_PIO_READ, "READ SECTOR(S)" }, 2136 { ATA_CMD_PIO_READ_EXT, "READ SECTOR(S) EXT" }, 2137 { ATA_CMD_PIO_WRITE, "WRITE SECTOR(S)" }, 2138 { ATA_CMD_PIO_WRITE_EXT, "WRITE SECTOR(S) EXT" }, 2139 { ATA_CMD_READ_MULTI, "READ MULTIPLE" }, 2140 { ATA_CMD_READ_MULTI_EXT, "READ MULTIPLE EXT" }, 2141 { ATA_CMD_WRITE_MULTI, "WRITE MULTIPLE" }, 2142 { ATA_CMD_WRITE_MULTI_EXT, "WRITE MULTIPLE EXT" }, 2143 { ATA_CMD_WRITE_MULTI_FUA_EXT, "WRITE MULTIPLE FUA EXT" }, 2144 { ATA_CMD_SET_FEATURES, "SET FEATURES" }, 2145 { ATA_CMD_SET_MULTI, "SET MULTIPLE MODE" }, 2146 { ATA_CMD_VERIFY, "READ VERIFY SECTOR(S)" }, 2147 { ATA_CMD_VERIFY_EXT, "READ VERIFY SECTOR(S) EXT" }, 2148 { ATA_CMD_WRITE_UNCORR_EXT, "WRITE UNCORRECTABLE EXT" }, 2149 { ATA_CMD_STANDBYNOW1, "STANDBY IMMEDIATE" }, 2150 { ATA_CMD_IDLEIMMEDIATE, "IDLE IMMEDIATE" }, 2151 { ATA_CMD_SLEEP, "SLEEP" }, 2152 { ATA_CMD_INIT_DEV_PARAMS, "INITIALIZE DEVICE PARAMETERS" }, 2153 { ATA_CMD_READ_NATIVE_MAX, "READ NATIVE MAX ADDRESS" }, 2154 { ATA_CMD_READ_NATIVE_MAX_EXT, "READ NATIVE MAX ADDRESS EXT" }, 2155 { ATA_CMD_SET_MAX, "SET MAX ADDRESS" }, 2156 { ATA_CMD_SET_MAX_EXT, "SET MAX ADDRESS EXT" }, 2157 { ATA_CMD_READ_LOG_EXT, "READ LOG EXT" }, 2158 { ATA_CMD_WRITE_LOG_EXT, "WRITE LOG EXT" }, 2159 { ATA_CMD_READ_LOG_DMA_EXT, "READ LOG DMA EXT" }, 2160 { ATA_CMD_WRITE_LOG_DMA_EXT, "WRITE LOG DMA EXT" }, 2161 { ATA_CMD_TRUSTED_NONDATA, "TRUSTED NON-DATA" }, 2162 { ATA_CMD_TRUSTED_RCV, "TRUSTED RECEIVE" }, 2163 { ATA_CMD_TRUSTED_RCV_DMA, "TRUSTED RECEIVE DMA" }, 2164 { ATA_CMD_TRUSTED_SND, "TRUSTED SEND" }, 2165 { ATA_CMD_TRUSTED_SND_DMA, "TRUSTED SEND DMA" }, 2166 { ATA_CMD_PMP_READ, "READ BUFFER" }, 2167 { ATA_CMD_PMP_READ_DMA, "READ BUFFER DMA" }, 2168 { ATA_CMD_PMP_WRITE, "WRITE BUFFER" }, 2169 { ATA_CMD_PMP_WRITE_DMA, "WRITE BUFFER DMA" }, 2170 { ATA_CMD_CONF_OVERLAY, "DEVICE CONFIGURATION OVERLAY" }, 2171 { ATA_CMD_SEC_SET_PASS, "SECURITY SET PASSWORD" }, 2172 { ATA_CMD_SEC_UNLOCK, "SECURITY UNLOCK" }, 2173 { ATA_CMD_SEC_ERASE_PREP, "SECURITY ERASE PREPARE" }, 2174 { ATA_CMD_SEC_ERASE_UNIT, "SECURITY ERASE UNIT" }, 2175 { ATA_CMD_SEC_FREEZE_LOCK, "SECURITY FREEZE LOCK" }, 2176 { ATA_CMD_SEC_DISABLE_PASS, "SECURITY DISABLE PASSWORD" }, 2177 { ATA_CMD_CONFIG_STREAM, "CONFIGURE STREAM" }, 2178 { ATA_CMD_SMART, "SMART" }, 2179 { ATA_CMD_MEDIA_LOCK, "DOOR LOCK" }, 2180 { ATA_CMD_MEDIA_UNLOCK, "DOOR UNLOCK" }, 2181 { ATA_CMD_DSM, "DATA SET MANAGEMENT" }, 2182 { ATA_CMD_CHK_MED_CRD_TYP, "CHECK MEDIA CARD TYPE" }, 2183 { ATA_CMD_CFA_REQ_EXT_ERR, "CFA REQUEST EXTENDED ERROR" }, 2184 { ATA_CMD_CFA_WRITE_NE, "CFA WRITE SECTORS WITHOUT ERASE" }, 2185 { ATA_CMD_CFA_TRANS_SECT, "CFA TRANSLATE SECTOR" }, 2186 { ATA_CMD_CFA_ERASE, "CFA ERASE SECTORS" }, 2187 { ATA_CMD_CFA_WRITE_MULT_NE, "CFA WRITE MULTIPLE WITHOUT ERASE" }, 2188 { ATA_CMD_REQ_SENSE_DATA, "REQUEST SENSE DATA EXT" }, 2189 { ATA_CMD_SANITIZE_DEVICE, "SANITIZE DEVICE" }, 2190 { ATA_CMD_ZAC_MGMT_IN, "ZAC MANAGEMENT IN" }, 2191 { ATA_CMD_ZAC_MGMT_OUT, "ZAC MANAGEMENT OUT" }, 2192 { ATA_CMD_READ_LONG, "READ LONG (with retries)" }, 2193 { ATA_CMD_READ_LONG_ONCE, "READ LONG (without retries)" }, 2194 { ATA_CMD_WRITE_LONG, "WRITE LONG (with retries)" }, 2195 { ATA_CMD_WRITE_LONG_ONCE, "WRITE LONG (without retries)" }, 2196 { ATA_CMD_RESTORE, "RECALIBRATE" }, 2197 { 0, NULL } /* terminate list */ 2198 }; 2199 2200 unsigned int i; 2201 for (i = 0; cmd_descr[i].text; i++) 2202 if (cmd_descr[i].command == command) 2203 return cmd_descr[i].text; 2204 #endif 2205 2206 return NULL; 2207 } 2208 EXPORT_SYMBOL_GPL(ata_get_cmd_descript); 2209 2210 /** 2211 * ata_eh_link_report - report error handling to user 2212 * @link: ATA link EH is going on 2213 * 2214 * Report EH to user. 2215 * 2216 * LOCKING: 2217 * None. 2218 */ 2219 static void ata_eh_link_report(struct ata_link *link) 2220 { 2221 struct ata_port *ap = link->ap; 2222 struct ata_eh_context *ehc = &link->eh_context; 2223 struct ata_queued_cmd *qc; 2224 const char *frozen, *desc; 2225 char tries_buf[6] = ""; 2226 int tag, nr_failed = 0; 2227 2228 if (ehc->i.flags & ATA_EHI_QUIET) 2229 return; 2230 2231 desc = NULL; 2232 if (ehc->i.desc[0] != '\0') 2233 desc = ehc->i.desc; 2234 2235 ata_qc_for_each_raw(ap, qc, tag) { 2236 if (!(qc->flags & ATA_QCFLAG_FAILED) || 2237 ata_dev_phys_link(qc->dev) != link || 2238 ((qc->flags & ATA_QCFLAG_QUIET) && 2239 qc->err_mask == AC_ERR_DEV)) 2240 continue; 2241 if (qc->flags & ATA_QCFLAG_SENSE_VALID && !qc->err_mask) 2242 continue; 2243 2244 nr_failed++; 2245 } 2246 2247 if (!nr_failed && !ehc->i.err_mask) 2248 return; 2249 2250 frozen = ""; 2251 if (ap->pflags & ATA_PFLAG_FROZEN) 2252 frozen = " frozen"; 2253 2254 if (ap->eh_tries < ATA_EH_MAX_TRIES) 2255 snprintf(tries_buf, sizeof(tries_buf), " t%d", 2256 ap->eh_tries); 2257 2258 if (ehc->i.dev) { 2259 ata_dev_err(ehc->i.dev, "exception Emask 0x%x " 2260 "SAct 0x%x SErr 0x%x action 0x%x%s%s\n", 2261 ehc->i.err_mask, link->sactive, ehc->i.serror, 2262 ehc->i.action, frozen, tries_buf); 2263 if (desc) 2264 ata_dev_err(ehc->i.dev, "%s\n", desc); 2265 } else { 2266 ata_link_err(link, "exception Emask 0x%x " 2267 "SAct 0x%x SErr 0x%x action 0x%x%s%s\n", 2268 ehc->i.err_mask, link->sactive, ehc->i.serror, 2269 ehc->i.action, frozen, tries_buf); 2270 if (desc) 2271 ata_link_err(link, "%s\n", desc); 2272 } 2273 2274 #ifdef CONFIG_ATA_VERBOSE_ERROR 2275 if (ehc->i.serror) 2276 ata_link_err(link, 2277 "SError: { %s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s}\n", 2278 ehc->i.serror & SERR_DATA_RECOVERED ? "RecovData " : "", 2279 ehc->i.serror & SERR_COMM_RECOVERED ? "RecovComm " : "", 2280 ehc->i.serror & SERR_DATA ? "UnrecovData " : "", 2281 ehc->i.serror & SERR_PERSISTENT ? "Persist " : "", 2282 ehc->i.serror & SERR_PROTOCOL ? "Proto " : "", 2283 ehc->i.serror & SERR_INTERNAL ? "HostInt " : "", 2284 ehc->i.serror & SERR_PHYRDY_CHG ? "PHYRdyChg " : "", 2285 ehc->i.serror & SERR_PHY_INT_ERR ? "PHYInt " : "", 2286 ehc->i.serror & SERR_COMM_WAKE ? "CommWake " : "", 2287 ehc->i.serror & SERR_10B_8B_ERR ? "10B8B " : "", 2288 ehc->i.serror & SERR_DISPARITY ? "Dispar " : "", 2289 ehc->i.serror & SERR_CRC ? "BadCRC " : "", 2290 ehc->i.serror & SERR_HANDSHAKE ? "Handshk " : "", 2291 ehc->i.serror & SERR_LINK_SEQ_ERR ? "LinkSeq " : "", 2292 ehc->i.serror & SERR_TRANS_ST_ERROR ? "TrStaTrns " : "", 2293 ehc->i.serror & SERR_UNRECOG_FIS ? "UnrecFIS " : "", 2294 ehc->i.serror & SERR_DEV_XCHG ? "DevExch " : ""); 2295 #endif 2296 2297 ata_qc_for_each_raw(ap, qc, tag) { 2298 struct ata_taskfile *cmd = &qc->tf, *res = &qc->result_tf; 2299 char data_buf[20] = ""; 2300 char cdb_buf[70] = ""; 2301 2302 if (!(qc->flags & ATA_QCFLAG_FAILED) || 2303 ata_dev_phys_link(qc->dev) != link || !qc->err_mask) 2304 continue; 2305 2306 if (qc->dma_dir != DMA_NONE) { 2307 static const char *dma_str[] = { 2308 [DMA_BIDIRECTIONAL] = "bidi", 2309 [DMA_TO_DEVICE] = "out", 2310 [DMA_FROM_DEVICE] = "in", 2311 }; 2312 const char *prot_str = NULL; 2313 2314 switch (qc->tf.protocol) { 2315 case ATA_PROT_UNKNOWN: 2316 prot_str = "unknown"; 2317 break; 2318 case ATA_PROT_NODATA: 2319 prot_str = "nodata"; 2320 break; 2321 case ATA_PROT_PIO: 2322 prot_str = "pio"; 2323 break; 2324 case ATA_PROT_DMA: 2325 prot_str = "dma"; 2326 break; 2327 case ATA_PROT_NCQ: 2328 prot_str = "ncq dma"; 2329 break; 2330 case ATA_PROT_NCQ_NODATA: 2331 prot_str = "ncq nodata"; 2332 break; 2333 case ATAPI_PROT_NODATA: 2334 prot_str = "nodata"; 2335 break; 2336 case ATAPI_PROT_PIO: 2337 prot_str = "pio"; 2338 break; 2339 case ATAPI_PROT_DMA: 2340 prot_str = "dma"; 2341 break; 2342 } 2343 snprintf(data_buf, sizeof(data_buf), " %s %u %s", 2344 prot_str, qc->nbytes, dma_str[qc->dma_dir]); 2345 } 2346 2347 if (ata_is_atapi(qc->tf.protocol)) { 2348 const u8 *cdb = qc->cdb; 2349 size_t cdb_len = qc->dev->cdb_len; 2350 2351 if (qc->scsicmd) { 2352 cdb = qc->scsicmd->cmnd; 2353 cdb_len = qc->scsicmd->cmd_len; 2354 } 2355 __scsi_format_command(cdb_buf, sizeof(cdb_buf), 2356 cdb, cdb_len); 2357 } else { 2358 const char *descr = ata_get_cmd_descript(cmd->command); 2359 if (descr) 2360 ata_dev_err(qc->dev, "failed command: %s\n", 2361 descr); 2362 } 2363 2364 ata_dev_err(qc->dev, 2365 "cmd %02x/%02x:%02x:%02x:%02x:%02x/%02x:%02x:%02x:%02x:%02x/%02x " 2366 "tag %d%s\n %s" 2367 "res %02x/%02x:%02x:%02x:%02x:%02x/%02x:%02x:%02x:%02x:%02x/%02x " 2368 "Emask 0x%x (%s)%s\n", 2369 cmd->command, cmd->feature, cmd->nsect, 2370 cmd->lbal, cmd->lbam, cmd->lbah, 2371 cmd->hob_feature, cmd->hob_nsect, 2372 cmd->hob_lbal, cmd->hob_lbam, cmd->hob_lbah, 2373 cmd->device, qc->tag, data_buf, cdb_buf, 2374 res->command, res->feature, res->nsect, 2375 res->lbal, res->lbam, res->lbah, 2376 res->hob_feature, res->hob_nsect, 2377 res->hob_lbal, res->hob_lbam, res->hob_lbah, 2378 res->device, qc->err_mask, ata_err_string(qc->err_mask), 2379 qc->err_mask & AC_ERR_NCQ ? " <F>" : ""); 2380 2381 #ifdef CONFIG_ATA_VERBOSE_ERROR 2382 if (res->command & (ATA_BUSY | ATA_DRDY | ATA_DF | ATA_DRQ | 2383 ATA_SENSE | ATA_ERR)) { 2384 if (res->command & ATA_BUSY) 2385 ata_dev_err(qc->dev, "status: { Busy }\n"); 2386 else 2387 ata_dev_err(qc->dev, "status: { %s%s%s%s%s}\n", 2388 res->command & ATA_DRDY ? "DRDY " : "", 2389 res->command & ATA_DF ? "DF " : "", 2390 res->command & ATA_DRQ ? "DRQ " : "", 2391 res->command & ATA_SENSE ? "SENSE " : "", 2392 res->command & ATA_ERR ? "ERR " : ""); 2393 } 2394 2395 if (cmd->command != ATA_CMD_PACKET && 2396 (res->feature & (ATA_ICRC | ATA_UNC | ATA_AMNF | 2397 ATA_IDNF | ATA_ABORTED))) 2398 ata_dev_err(qc->dev, "error: { %s%s%s%s%s}\n", 2399 res->feature & ATA_ICRC ? "ICRC " : "", 2400 res->feature & ATA_UNC ? "UNC " : "", 2401 res->feature & ATA_AMNF ? "AMNF " : "", 2402 res->feature & ATA_IDNF ? "IDNF " : "", 2403 res->feature & ATA_ABORTED ? "ABRT " : ""); 2404 #endif 2405 } 2406 } 2407 2408 /** 2409 * ata_eh_report - report error handling to user 2410 * @ap: ATA port to report EH about 2411 * 2412 * Report EH to user. 2413 * 2414 * LOCKING: 2415 * None. 2416 */ 2417 void ata_eh_report(struct ata_port *ap) 2418 { 2419 struct ata_link *link; 2420 2421 ata_for_each_link(link, ap, HOST_FIRST) 2422 ata_eh_link_report(link); 2423 } 2424 2425 static int ata_do_reset(struct ata_link *link, ata_reset_fn_t reset, 2426 unsigned int *classes, unsigned long deadline, 2427 bool clear_classes) 2428 { 2429 struct ata_device *dev; 2430 2431 if (clear_classes) 2432 ata_for_each_dev(dev, link, ALL) 2433 classes[dev->devno] = ATA_DEV_UNKNOWN; 2434 2435 return reset(link, classes, deadline); 2436 } 2437 2438 static int ata_eh_followup_srst_needed(struct ata_link *link, int rc) 2439 { 2440 if ((link->flags & ATA_LFLAG_NO_SRST) || ata_link_offline(link)) 2441 return 0; 2442 if (rc == -EAGAIN) 2443 return 1; 2444 if (sata_pmp_supported(link->ap) && ata_is_host_link(link)) 2445 return 1; 2446 return 0; 2447 } 2448 2449 int ata_eh_reset(struct ata_link *link, int classify, 2450 ata_prereset_fn_t prereset, ata_reset_fn_t softreset, 2451 ata_reset_fn_t hardreset, ata_postreset_fn_t postreset) 2452 { 2453 struct ata_port *ap = link->ap; 2454 struct ata_link *slave = ap->slave_link; 2455 struct ata_eh_context *ehc = &link->eh_context; 2456 struct ata_eh_context *sehc = slave ? &slave->eh_context : NULL; 2457 unsigned int *classes = ehc->classes; 2458 unsigned int lflags = link->flags; 2459 int verbose = !(ehc->i.flags & ATA_EHI_QUIET); 2460 int max_tries = 0, try = 0; 2461 struct ata_link *failed_link; 2462 struct ata_device *dev; 2463 unsigned long deadline, now; 2464 ata_reset_fn_t reset; 2465 unsigned long flags; 2466 u32 sstatus; 2467 int nr_unknown, rc; 2468 2469 /* 2470 * Prepare to reset 2471 */ 2472 while (ata_eh_reset_timeouts[max_tries] != ULONG_MAX) 2473 max_tries++; 2474 if (link->flags & ATA_LFLAG_RST_ONCE) 2475 max_tries = 1; 2476 if (link->flags & ATA_LFLAG_NO_HRST) 2477 hardreset = NULL; 2478 if (link->flags & ATA_LFLAG_NO_SRST) 2479 softreset = NULL; 2480 2481 /* make sure each reset attempt is at least COOL_DOWN apart */ 2482 if (ehc->i.flags & ATA_EHI_DID_RESET) { 2483 now = jiffies; 2484 WARN_ON(time_after(ehc->last_reset, now)); 2485 deadline = ata_deadline(ehc->last_reset, 2486 ATA_EH_RESET_COOL_DOWN); 2487 if (time_before(now, deadline)) 2488 schedule_timeout_uninterruptible(deadline - now); 2489 } 2490 2491 spin_lock_irqsave(ap->lock, flags); 2492 ap->pflags |= ATA_PFLAG_RESETTING; 2493 spin_unlock_irqrestore(ap->lock, flags); 2494 2495 ata_eh_about_to_do(link, NULL, ATA_EH_RESET); 2496 2497 ata_for_each_dev(dev, link, ALL) { 2498 /* If we issue an SRST then an ATA drive (not ATAPI) 2499 * may change configuration and be in PIO0 timing. If 2500 * we do a hard reset (or are coming from power on) 2501 * this is true for ATA or ATAPI. Until we've set a 2502 * suitable controller mode we should not touch the 2503 * bus as we may be talking too fast. 2504 */ 2505 dev->pio_mode = XFER_PIO_0; 2506 dev->dma_mode = 0xff; 2507 2508 /* If the controller has a pio mode setup function 2509 * then use it to set the chipset to rights. Don't 2510 * touch the DMA setup as that will be dealt with when 2511 * configuring devices. 2512 */ 2513 if (ap->ops->set_piomode) 2514 ap->ops->set_piomode(ap, dev); 2515 } 2516 2517 /* prefer hardreset */ 2518 reset = NULL; 2519 ehc->i.action &= ~ATA_EH_RESET; 2520 if (hardreset) { 2521 reset = hardreset; 2522 ehc->i.action |= ATA_EH_HARDRESET; 2523 } else if (softreset) { 2524 reset = softreset; 2525 ehc->i.action |= ATA_EH_SOFTRESET; 2526 } 2527 2528 if (prereset) { 2529 unsigned long deadline = ata_deadline(jiffies, 2530 ATA_EH_PRERESET_TIMEOUT); 2531 2532 if (slave) { 2533 sehc->i.action &= ~ATA_EH_RESET; 2534 sehc->i.action |= ehc->i.action; 2535 } 2536 2537 rc = prereset(link, deadline); 2538 2539 /* If present, do prereset on slave link too. Reset 2540 * is skipped iff both master and slave links report 2541 * -ENOENT or clear ATA_EH_RESET. 2542 */ 2543 if (slave && (rc == 0 || rc == -ENOENT)) { 2544 int tmp; 2545 2546 tmp = prereset(slave, deadline); 2547 if (tmp != -ENOENT) 2548 rc = tmp; 2549 2550 ehc->i.action |= sehc->i.action; 2551 } 2552 2553 if (rc) { 2554 if (rc == -ENOENT) { 2555 ata_link_dbg(link, "port disabled--ignoring\n"); 2556 ehc->i.action &= ~ATA_EH_RESET; 2557 2558 ata_for_each_dev(dev, link, ALL) 2559 classes[dev->devno] = ATA_DEV_NONE; 2560 2561 rc = 0; 2562 } else 2563 ata_link_err(link, 2564 "prereset failed (errno=%d)\n", 2565 rc); 2566 goto out; 2567 } 2568 2569 /* prereset() might have cleared ATA_EH_RESET. If so, 2570 * bang classes, thaw and return. 2571 */ 2572 if (reset && !(ehc->i.action & ATA_EH_RESET)) { 2573 ata_for_each_dev(dev, link, ALL) 2574 classes[dev->devno] = ATA_DEV_NONE; 2575 if ((ap->pflags & ATA_PFLAG_FROZEN) && 2576 ata_is_host_link(link)) 2577 ata_eh_thaw_port(ap); 2578 rc = 0; 2579 goto out; 2580 } 2581 } 2582 2583 retry: 2584 /* 2585 * Perform reset 2586 */ 2587 if (ata_is_host_link(link)) 2588 ata_eh_freeze_port(ap); 2589 2590 deadline = ata_deadline(jiffies, ata_eh_reset_timeouts[try++]); 2591 2592 if (reset) { 2593 if (verbose) 2594 ata_link_info(link, "%s resetting link\n", 2595 reset == softreset ? "soft" : "hard"); 2596 2597 /* mark that this EH session started with reset */ 2598 ehc->last_reset = jiffies; 2599 if (reset == hardreset) 2600 ehc->i.flags |= ATA_EHI_DID_HARDRESET; 2601 else 2602 ehc->i.flags |= ATA_EHI_DID_SOFTRESET; 2603 2604 rc = ata_do_reset(link, reset, classes, deadline, true); 2605 if (rc && rc != -EAGAIN) { 2606 failed_link = link; 2607 goto fail; 2608 } 2609 2610 /* hardreset slave link if existent */ 2611 if (slave && reset == hardreset) { 2612 int tmp; 2613 2614 if (verbose) 2615 ata_link_info(slave, "hard resetting link\n"); 2616 2617 ata_eh_about_to_do(slave, NULL, ATA_EH_RESET); 2618 tmp = ata_do_reset(slave, reset, classes, deadline, 2619 false); 2620 switch (tmp) { 2621 case -EAGAIN: 2622 rc = -EAGAIN; 2623 break; 2624 case 0: 2625 break; 2626 default: 2627 failed_link = slave; 2628 rc = tmp; 2629 goto fail; 2630 } 2631 } 2632 2633 /* perform follow-up SRST if necessary */ 2634 if (reset == hardreset && 2635 ata_eh_followup_srst_needed(link, rc)) { 2636 reset = softreset; 2637 2638 if (!reset) { 2639 ata_link_err(link, 2640 "follow-up softreset required but no softreset available\n"); 2641 failed_link = link; 2642 rc = -EINVAL; 2643 goto fail; 2644 } 2645 2646 ata_eh_about_to_do(link, NULL, ATA_EH_RESET); 2647 rc = ata_do_reset(link, reset, classes, deadline, true); 2648 if (rc) { 2649 failed_link = link; 2650 goto fail; 2651 } 2652 } 2653 } else { 2654 if (verbose) 2655 ata_link_info(link, 2656 "no reset method available, skipping reset\n"); 2657 if (!(lflags & ATA_LFLAG_ASSUME_CLASS)) 2658 lflags |= ATA_LFLAG_ASSUME_ATA; 2659 } 2660 2661 /* 2662 * Post-reset processing 2663 */ 2664 ata_for_each_dev(dev, link, ALL) { 2665 /* After the reset, the device state is PIO 0 and the 2666 * controller state is undefined. Reset also wakes up 2667 * drives from sleeping mode. 2668 */ 2669 dev->pio_mode = XFER_PIO_0; 2670 dev->flags &= ~ATA_DFLAG_SLEEPING; 2671 2672 if (ata_phys_link_offline(ata_dev_phys_link(dev))) 2673 continue; 2674 2675 /* apply class override */ 2676 if (lflags & ATA_LFLAG_ASSUME_ATA) 2677 classes[dev->devno] = ATA_DEV_ATA; 2678 else if (lflags & ATA_LFLAG_ASSUME_SEMB) 2679 classes[dev->devno] = ATA_DEV_SEMB_UNSUP; 2680 } 2681 2682 /* record current link speed */ 2683 if (sata_scr_read(link, SCR_STATUS, &sstatus) == 0) 2684 link->sata_spd = (sstatus >> 4) & 0xf; 2685 if (slave && sata_scr_read(slave, SCR_STATUS, &sstatus) == 0) 2686 slave->sata_spd = (sstatus >> 4) & 0xf; 2687 2688 /* thaw the port */ 2689 if (ata_is_host_link(link)) 2690 ata_eh_thaw_port(ap); 2691 2692 /* postreset() should clear hardware SError. Although SError 2693 * is cleared during link resume, clearing SError here is 2694 * necessary as some PHYs raise hotplug events after SRST. 2695 * This introduces race condition where hotplug occurs between 2696 * reset and here. This race is mediated by cross checking 2697 * link onlineness and classification result later. 2698 */ 2699 if (postreset) { 2700 postreset(link, classes); 2701 if (slave) 2702 postreset(slave, classes); 2703 } 2704 2705 /* 2706 * Some controllers can't be frozen very well and may set spurious 2707 * error conditions during reset. Clear accumulated error 2708 * information and re-thaw the port if frozen. As reset is the 2709 * final recovery action and we cross check link onlineness against 2710 * device classification later, no hotplug event is lost by this. 2711 */ 2712 spin_lock_irqsave(link->ap->lock, flags); 2713 memset(&link->eh_info, 0, sizeof(link->eh_info)); 2714 if (slave) 2715 memset(&slave->eh_info, 0, sizeof(link->eh_info)); 2716 ap->pflags &= ~ATA_PFLAG_EH_PENDING; 2717 spin_unlock_irqrestore(link->ap->lock, flags); 2718 2719 if (ap->pflags & ATA_PFLAG_FROZEN) 2720 ata_eh_thaw_port(ap); 2721 2722 /* 2723 * Make sure onlineness and classification result correspond. 2724 * Hotplug could have happened during reset and some 2725 * controllers fail to wait while a drive is spinning up after 2726 * being hotplugged causing misdetection. By cross checking 2727 * link on/offlineness and classification result, those 2728 * conditions can be reliably detected and retried. 2729 */ 2730 nr_unknown = 0; 2731 ata_for_each_dev(dev, link, ALL) { 2732 if (ata_phys_link_online(ata_dev_phys_link(dev))) { 2733 if (classes[dev->devno] == ATA_DEV_UNKNOWN) { 2734 ata_dev_dbg(dev, "link online but device misclassified\n"); 2735 classes[dev->devno] = ATA_DEV_NONE; 2736 nr_unknown++; 2737 } 2738 } else if (ata_phys_link_offline(ata_dev_phys_link(dev))) { 2739 if (ata_class_enabled(classes[dev->devno])) 2740 ata_dev_dbg(dev, 2741 "link offline, clearing class %d to NONE\n", 2742 classes[dev->devno]); 2743 classes[dev->devno] = ATA_DEV_NONE; 2744 } else if (classes[dev->devno] == ATA_DEV_UNKNOWN) { 2745 ata_dev_dbg(dev, 2746 "link status unknown, clearing UNKNOWN to NONE\n"); 2747 classes[dev->devno] = ATA_DEV_NONE; 2748 } 2749 } 2750 2751 if (classify && nr_unknown) { 2752 if (try < max_tries) { 2753 ata_link_warn(link, 2754 "link online but %d devices misclassified, retrying\n", 2755 nr_unknown); 2756 failed_link = link; 2757 rc = -EAGAIN; 2758 goto fail; 2759 } 2760 ata_link_warn(link, 2761 "link online but %d devices misclassified, " 2762 "device detection might fail\n", nr_unknown); 2763 } 2764 2765 /* reset successful, schedule revalidation */ 2766 ata_eh_done(link, NULL, ATA_EH_RESET); 2767 if (slave) 2768 ata_eh_done(slave, NULL, ATA_EH_RESET); 2769 ehc->last_reset = jiffies; /* update to completion time */ 2770 ehc->i.action |= ATA_EH_REVALIDATE; 2771 link->lpm_policy = ATA_LPM_UNKNOWN; /* reset LPM state */ 2772 2773 rc = 0; 2774 out: 2775 /* clear hotplug flag */ 2776 ehc->i.flags &= ~ATA_EHI_HOTPLUGGED; 2777 if (slave) 2778 sehc->i.flags &= ~ATA_EHI_HOTPLUGGED; 2779 2780 spin_lock_irqsave(ap->lock, flags); 2781 ap->pflags &= ~ATA_PFLAG_RESETTING; 2782 spin_unlock_irqrestore(ap->lock, flags); 2783 2784 return rc; 2785 2786 fail: 2787 /* if SCR isn't accessible on a fan-out port, PMP needs to be reset */ 2788 if (!ata_is_host_link(link) && 2789 sata_scr_read(link, SCR_STATUS, &sstatus)) 2790 rc = -ERESTART; 2791 2792 if (try >= max_tries) { 2793 /* 2794 * Thaw host port even if reset failed, so that the port 2795 * can be retried on the next phy event. This risks 2796 * repeated EH runs but seems to be a better tradeoff than 2797 * shutting down a port after a botched hotplug attempt. 2798 */ 2799 if (ata_is_host_link(link)) 2800 ata_eh_thaw_port(ap); 2801 goto out; 2802 } 2803 2804 now = jiffies; 2805 if (time_before(now, deadline)) { 2806 unsigned long delta = deadline - now; 2807 2808 ata_link_warn(failed_link, 2809 "reset failed (errno=%d), retrying in %u secs\n", 2810 rc, DIV_ROUND_UP(jiffies_to_msecs(delta), 1000)); 2811 2812 ata_eh_release(ap); 2813 while (delta) 2814 delta = schedule_timeout_uninterruptible(delta); 2815 ata_eh_acquire(ap); 2816 } 2817 2818 /* 2819 * While disks spinup behind PMP, some controllers fail sending SRST. 2820 * They need to be reset - as well as the PMP - before retrying. 2821 */ 2822 if (rc == -ERESTART) { 2823 if (ata_is_host_link(link)) 2824 ata_eh_thaw_port(ap); 2825 goto out; 2826 } 2827 2828 if (try == max_tries - 1) { 2829 sata_down_spd_limit(link, 0); 2830 if (slave) 2831 sata_down_spd_limit(slave, 0); 2832 } else if (rc == -EPIPE) 2833 sata_down_spd_limit(failed_link, 0); 2834 2835 if (hardreset) 2836 reset = hardreset; 2837 goto retry; 2838 } 2839 2840 static inline void ata_eh_pull_park_action(struct ata_port *ap) 2841 { 2842 struct ata_link *link; 2843 struct ata_device *dev; 2844 unsigned long flags; 2845 2846 /* 2847 * This function can be thought of as an extended version of 2848 * ata_eh_about_to_do() specially crafted to accommodate the 2849 * requirements of ATA_EH_PARK handling. Since the EH thread 2850 * does not leave the do {} while () loop in ata_eh_recover as 2851 * long as the timeout for a park request to *one* device on 2852 * the port has not expired, and since we still want to pick 2853 * up park requests to other devices on the same port or 2854 * timeout updates for the same device, we have to pull 2855 * ATA_EH_PARK actions from eh_info into eh_context.i 2856 * ourselves at the beginning of each pass over the loop. 2857 * 2858 * Additionally, all write accesses to &ap->park_req_pending 2859 * through reinit_completion() (see below) or complete_all() 2860 * (see ata_scsi_park_store()) are protected by the host lock. 2861 * As a result we have that park_req_pending.done is zero on 2862 * exit from this function, i.e. when ATA_EH_PARK actions for 2863 * *all* devices on port ap have been pulled into the 2864 * respective eh_context structs. If, and only if, 2865 * park_req_pending.done is non-zero by the time we reach 2866 * wait_for_completion_timeout(), another ATA_EH_PARK action 2867 * has been scheduled for at least one of the devices on port 2868 * ap and we have to cycle over the do {} while () loop in 2869 * ata_eh_recover() again. 2870 */ 2871 2872 spin_lock_irqsave(ap->lock, flags); 2873 reinit_completion(&ap->park_req_pending); 2874 ata_for_each_link(link, ap, EDGE) { 2875 ata_for_each_dev(dev, link, ALL) { 2876 struct ata_eh_info *ehi = &link->eh_info; 2877 2878 link->eh_context.i.dev_action[dev->devno] |= 2879 ehi->dev_action[dev->devno] & ATA_EH_PARK; 2880 ata_eh_clear_action(link, dev, ehi, ATA_EH_PARK); 2881 } 2882 } 2883 spin_unlock_irqrestore(ap->lock, flags); 2884 } 2885 2886 static void ata_eh_park_issue_cmd(struct ata_device *dev, int park) 2887 { 2888 struct ata_eh_context *ehc = &dev->link->eh_context; 2889 struct ata_taskfile tf; 2890 unsigned int err_mask; 2891 2892 ata_tf_init(dev, &tf); 2893 if (park) { 2894 ehc->unloaded_mask |= 1 << dev->devno; 2895 tf.command = ATA_CMD_IDLEIMMEDIATE; 2896 tf.feature = 0x44; 2897 tf.lbal = 0x4c; 2898 tf.lbam = 0x4e; 2899 tf.lbah = 0x55; 2900 } else { 2901 ehc->unloaded_mask &= ~(1 << dev->devno); 2902 tf.command = ATA_CMD_CHK_POWER; 2903 } 2904 2905 tf.flags |= ATA_TFLAG_DEVICE | ATA_TFLAG_ISADDR; 2906 tf.protocol = ATA_PROT_NODATA; 2907 err_mask = ata_exec_internal(dev, &tf, NULL, DMA_NONE, NULL, 0, 0); 2908 if (park && (err_mask || tf.lbal != 0xc4)) { 2909 ata_dev_err(dev, "head unload failed!\n"); 2910 ehc->unloaded_mask &= ~(1 << dev->devno); 2911 } 2912 } 2913 2914 static int ata_eh_revalidate_and_attach(struct ata_link *link, 2915 struct ata_device **r_failed_dev) 2916 { 2917 struct ata_port *ap = link->ap; 2918 struct ata_eh_context *ehc = &link->eh_context; 2919 struct ata_device *dev; 2920 unsigned int new_mask = 0; 2921 unsigned long flags; 2922 int rc = 0; 2923 2924 DPRINTK("ENTER\n"); 2925 2926 /* For PATA drive side cable detection to work, IDENTIFY must 2927 * be done backwards such that PDIAG- is released by the slave 2928 * device before the master device is identified. 2929 */ 2930 ata_for_each_dev(dev, link, ALL_REVERSE) { 2931 unsigned int action = ata_eh_dev_action(dev); 2932 unsigned int readid_flags = 0; 2933 2934 if (ehc->i.flags & ATA_EHI_DID_RESET) 2935 readid_flags |= ATA_READID_POSTRESET; 2936 2937 if ((action & ATA_EH_REVALIDATE) && ata_dev_enabled(dev)) { 2938 WARN_ON(dev->class == ATA_DEV_PMP); 2939 2940 if (ata_phys_link_offline(ata_dev_phys_link(dev))) { 2941 rc = -EIO; 2942 goto err; 2943 } 2944 2945 ata_eh_about_to_do(link, dev, ATA_EH_REVALIDATE); 2946 rc = ata_dev_revalidate(dev, ehc->classes[dev->devno], 2947 readid_flags); 2948 if (rc) 2949 goto err; 2950 2951 ata_eh_done(link, dev, ATA_EH_REVALIDATE); 2952 2953 /* Configuration may have changed, reconfigure 2954 * transfer mode. 2955 */ 2956 ehc->i.flags |= ATA_EHI_SETMODE; 2957 2958 /* schedule the scsi_rescan_device() here */ 2959 schedule_work(&(ap->scsi_rescan_task)); 2960 } else if (dev->class == ATA_DEV_UNKNOWN && 2961 ehc->tries[dev->devno] && 2962 ata_class_enabled(ehc->classes[dev->devno])) { 2963 /* Temporarily set dev->class, it will be 2964 * permanently set once all configurations are 2965 * complete. This is necessary because new 2966 * device configuration is done in two 2967 * separate loops. 2968 */ 2969 dev->class = ehc->classes[dev->devno]; 2970 2971 if (dev->class == ATA_DEV_PMP) 2972 rc = sata_pmp_attach(dev); 2973 else 2974 rc = ata_dev_read_id(dev, &dev->class, 2975 readid_flags, dev->id); 2976 2977 /* read_id might have changed class, store and reset */ 2978 ehc->classes[dev->devno] = dev->class; 2979 dev->class = ATA_DEV_UNKNOWN; 2980 2981 switch (rc) { 2982 case 0: 2983 /* clear error info accumulated during probe */ 2984 ata_ering_clear(&dev->ering); 2985 new_mask |= 1 << dev->devno; 2986 break; 2987 case -ENOENT: 2988 /* IDENTIFY was issued to non-existent 2989 * device. No need to reset. Just 2990 * thaw and ignore the device. 2991 */ 2992 ata_eh_thaw_port(ap); 2993 break; 2994 default: 2995 goto err; 2996 } 2997 } 2998 } 2999 3000 /* PDIAG- should have been released, ask cable type if post-reset */ 3001 if ((ehc->i.flags & ATA_EHI_DID_RESET) && ata_is_host_link(link)) { 3002 if (ap->ops->cable_detect) 3003 ap->cbl = ap->ops->cable_detect(ap); 3004 ata_force_cbl(ap); 3005 } 3006 3007 /* Configure new devices forward such that user doesn't see 3008 * device detection messages backwards. 3009 */ 3010 ata_for_each_dev(dev, link, ALL) { 3011 if (!(new_mask & (1 << dev->devno))) 3012 continue; 3013 3014 dev->class = ehc->classes[dev->devno]; 3015 3016 if (dev->class == ATA_DEV_PMP) 3017 continue; 3018 3019 ehc->i.flags |= ATA_EHI_PRINTINFO; 3020 rc = ata_dev_configure(dev); 3021 ehc->i.flags &= ~ATA_EHI_PRINTINFO; 3022 if (rc) { 3023 dev->class = ATA_DEV_UNKNOWN; 3024 goto err; 3025 } 3026 3027 spin_lock_irqsave(ap->lock, flags); 3028 ap->pflags |= ATA_PFLAG_SCSI_HOTPLUG; 3029 spin_unlock_irqrestore(ap->lock, flags); 3030 3031 /* new device discovered, configure xfermode */ 3032 ehc->i.flags |= ATA_EHI_SETMODE; 3033 } 3034 3035 return 0; 3036 3037 err: 3038 *r_failed_dev = dev; 3039 DPRINTK("EXIT rc=%d\n", rc); 3040 return rc; 3041 } 3042 3043 /** 3044 * ata_set_mode - Program timings and issue SET FEATURES - XFER 3045 * @link: link on which timings will be programmed 3046 * @r_failed_dev: out parameter for failed device 3047 * 3048 * Set ATA device disk transfer mode (PIO3, UDMA6, etc.). If 3049 * ata_set_mode() fails, pointer to the failing device is 3050 * returned in @r_failed_dev. 3051 * 3052 * LOCKING: 3053 * PCI/etc. bus probe sem. 3054 * 3055 * RETURNS: 3056 * 0 on success, negative errno otherwise 3057 */ 3058 int ata_set_mode(struct ata_link *link, struct ata_device **r_failed_dev) 3059 { 3060 struct ata_port *ap = link->ap; 3061 struct ata_device *dev; 3062 int rc; 3063 3064 /* if data transfer is verified, clear DUBIOUS_XFER on ering top */ 3065 ata_for_each_dev(dev, link, ENABLED) { 3066 if (!(dev->flags & ATA_DFLAG_DUBIOUS_XFER)) { 3067 struct ata_ering_entry *ent; 3068 3069 ent = ata_ering_top(&dev->ering); 3070 if (ent) 3071 ent->eflags &= ~ATA_EFLAG_DUBIOUS_XFER; 3072 } 3073 } 3074 3075 /* has private set_mode? */ 3076 if (ap->ops->set_mode) 3077 rc = ap->ops->set_mode(link, r_failed_dev); 3078 else 3079 rc = ata_do_set_mode(link, r_failed_dev); 3080 3081 /* if transfer mode has changed, set DUBIOUS_XFER on device */ 3082 ata_for_each_dev(dev, link, ENABLED) { 3083 struct ata_eh_context *ehc = &link->eh_context; 3084 u8 saved_xfer_mode = ehc->saved_xfer_mode[dev->devno]; 3085 u8 saved_ncq = !!(ehc->saved_ncq_enabled & (1 << dev->devno)); 3086 3087 if (dev->xfer_mode != saved_xfer_mode || 3088 ata_ncq_enabled(dev) != saved_ncq) 3089 dev->flags |= ATA_DFLAG_DUBIOUS_XFER; 3090 } 3091 3092 return rc; 3093 } 3094 3095 /** 3096 * atapi_eh_clear_ua - Clear ATAPI UNIT ATTENTION after reset 3097 * @dev: ATAPI device to clear UA for 3098 * 3099 * Resets and other operations can make an ATAPI device raise 3100 * UNIT ATTENTION which causes the next operation to fail. This 3101 * function clears UA. 3102 * 3103 * LOCKING: 3104 * EH context (may sleep). 3105 * 3106 * RETURNS: 3107 * 0 on success, -errno on failure. 3108 */ 3109 static int atapi_eh_clear_ua(struct ata_device *dev) 3110 { 3111 int i; 3112 3113 for (i = 0; i < ATA_EH_UA_TRIES; i++) { 3114 u8 *sense_buffer = dev->link->ap->sector_buf; 3115 u8 sense_key = 0; 3116 unsigned int err_mask; 3117 3118 err_mask = atapi_eh_tur(dev, &sense_key); 3119 if (err_mask != 0 && err_mask != AC_ERR_DEV) { 3120 ata_dev_warn(dev, 3121 "TEST_UNIT_READY failed (err_mask=0x%x)\n", 3122 err_mask); 3123 return -EIO; 3124 } 3125 3126 if (!err_mask || sense_key != UNIT_ATTENTION) 3127 return 0; 3128 3129 err_mask = atapi_eh_request_sense(dev, sense_buffer, sense_key); 3130 if (err_mask) { 3131 ata_dev_warn(dev, "failed to clear " 3132 "UNIT ATTENTION (err_mask=0x%x)\n", err_mask); 3133 return -EIO; 3134 } 3135 } 3136 3137 ata_dev_warn(dev, "UNIT ATTENTION persists after %d tries\n", 3138 ATA_EH_UA_TRIES); 3139 3140 return 0; 3141 } 3142 3143 /** 3144 * ata_eh_maybe_retry_flush - Retry FLUSH if necessary 3145 * @dev: ATA device which may need FLUSH retry 3146 * 3147 * If @dev failed FLUSH, it needs to be reported upper layer 3148 * immediately as it means that @dev failed to remap and already 3149 * lost at least a sector and further FLUSH retrials won't make 3150 * any difference to the lost sector. However, if FLUSH failed 3151 * for other reasons, for example transmission error, FLUSH needs 3152 * to be retried. 3153 * 3154 * This function determines whether FLUSH failure retry is 3155 * necessary and performs it if so. 3156 * 3157 * RETURNS: 3158 * 0 if EH can continue, -errno if EH needs to be repeated. 3159 */ 3160 static int ata_eh_maybe_retry_flush(struct ata_device *dev) 3161 { 3162 struct ata_link *link = dev->link; 3163 struct ata_port *ap = link->ap; 3164 struct ata_queued_cmd *qc; 3165 struct ata_taskfile tf; 3166 unsigned int err_mask; 3167 int rc = 0; 3168 3169 /* did flush fail for this device? */ 3170 if (!ata_tag_valid(link->active_tag)) 3171 return 0; 3172 3173 qc = __ata_qc_from_tag(ap, link->active_tag); 3174 if (qc->dev != dev || (qc->tf.command != ATA_CMD_FLUSH_EXT && 3175 qc->tf.command != ATA_CMD_FLUSH)) 3176 return 0; 3177 3178 /* if the device failed it, it should be reported to upper layers */ 3179 if (qc->err_mask & AC_ERR_DEV) 3180 return 0; 3181 3182 /* flush failed for some other reason, give it another shot */ 3183 ata_tf_init(dev, &tf); 3184 3185 tf.command = qc->tf.command; 3186 tf.flags |= ATA_TFLAG_DEVICE; 3187 tf.protocol = ATA_PROT_NODATA; 3188 3189 ata_dev_warn(dev, "retrying FLUSH 0x%x Emask 0x%x\n", 3190 tf.command, qc->err_mask); 3191 3192 err_mask = ata_exec_internal(dev, &tf, NULL, DMA_NONE, NULL, 0, 0); 3193 if (!err_mask) { 3194 /* 3195 * FLUSH is complete but there's no way to 3196 * successfully complete a failed command from EH. 3197 * Making sure retry is allowed at least once and 3198 * retrying it should do the trick - whatever was in 3199 * the cache is already on the platter and this won't 3200 * cause infinite loop. 3201 */ 3202 qc->scsicmd->allowed = max(qc->scsicmd->allowed, 1); 3203 } else { 3204 ata_dev_warn(dev, "FLUSH failed Emask 0x%x\n", 3205 err_mask); 3206 rc = -EIO; 3207 3208 /* if device failed it, report it to upper layers */ 3209 if (err_mask & AC_ERR_DEV) { 3210 qc->err_mask |= AC_ERR_DEV; 3211 qc->result_tf = tf; 3212 if (!(ap->pflags & ATA_PFLAG_FROZEN)) 3213 rc = 0; 3214 } 3215 } 3216 return rc; 3217 } 3218 3219 /** 3220 * ata_eh_set_lpm - configure SATA interface power management 3221 * @link: link to configure power management 3222 * @policy: the link power management policy 3223 * @r_failed_dev: out parameter for failed device 3224 * 3225 * Enable SATA Interface power management. This will enable 3226 * Device Interface Power Management (DIPM) for min_power and 3227 * medium_power_with_dipm policies, and then call driver specific 3228 * callbacks for enabling Host Initiated Power management. 3229 * 3230 * LOCKING: 3231 * EH context. 3232 * 3233 * RETURNS: 3234 * 0 on success, -errno on failure. 3235 */ 3236 static int ata_eh_set_lpm(struct ata_link *link, enum ata_lpm_policy policy, 3237 struct ata_device **r_failed_dev) 3238 { 3239 struct ata_port *ap = ata_is_host_link(link) ? link->ap : NULL; 3240 struct ata_eh_context *ehc = &link->eh_context; 3241 struct ata_device *dev, *link_dev = NULL, *lpm_dev = NULL; 3242 enum ata_lpm_policy old_policy = link->lpm_policy; 3243 bool no_dipm = link->ap->flags & ATA_FLAG_NO_DIPM; 3244 unsigned int hints = ATA_LPM_EMPTY | ATA_LPM_HIPM; 3245 unsigned int err_mask; 3246 int rc; 3247 3248 /* if the link or host doesn't do LPM, noop */ 3249 if (!IS_ENABLED(CONFIG_SATA_HOST) || 3250 (link->flags & ATA_LFLAG_NO_LPM) || (ap && !ap->ops->set_lpm)) 3251 return 0; 3252 3253 /* 3254 * DIPM is enabled only for MIN_POWER as some devices 3255 * misbehave when the host NACKs transition to SLUMBER. Order 3256 * device and link configurations such that the host always 3257 * allows DIPM requests. 3258 */ 3259 ata_for_each_dev(dev, link, ENABLED) { 3260 bool hipm = ata_id_has_hipm(dev->id); 3261 bool dipm = ata_id_has_dipm(dev->id) && !no_dipm; 3262 3263 /* find the first enabled and LPM enabled devices */ 3264 if (!link_dev) 3265 link_dev = dev; 3266 3267 if (!lpm_dev && (hipm || dipm)) 3268 lpm_dev = dev; 3269 3270 hints &= ~ATA_LPM_EMPTY; 3271 if (!hipm) 3272 hints &= ~ATA_LPM_HIPM; 3273 3274 /* disable DIPM before changing link config */ 3275 if (policy < ATA_LPM_MED_POWER_WITH_DIPM && dipm) { 3276 err_mask = ata_dev_set_feature(dev, 3277 SETFEATURES_SATA_DISABLE, SATA_DIPM); 3278 if (err_mask && err_mask != AC_ERR_DEV) { 3279 ata_dev_warn(dev, 3280 "failed to disable DIPM, Emask 0x%x\n", 3281 err_mask); 3282 rc = -EIO; 3283 goto fail; 3284 } 3285 } 3286 } 3287 3288 if (ap) { 3289 rc = ap->ops->set_lpm(link, policy, hints); 3290 if (!rc && ap->slave_link) 3291 rc = ap->ops->set_lpm(ap->slave_link, policy, hints); 3292 } else 3293 rc = sata_pmp_set_lpm(link, policy, hints); 3294 3295 /* 3296 * Attribute link config failure to the first (LPM) enabled 3297 * device on the link. 3298 */ 3299 if (rc) { 3300 if (rc == -EOPNOTSUPP) { 3301 link->flags |= ATA_LFLAG_NO_LPM; 3302 return 0; 3303 } 3304 dev = lpm_dev ? lpm_dev : link_dev; 3305 goto fail; 3306 } 3307 3308 /* 3309 * Low level driver acked the transition. Issue DIPM command 3310 * with the new policy set. 3311 */ 3312 link->lpm_policy = policy; 3313 if (ap && ap->slave_link) 3314 ap->slave_link->lpm_policy = policy; 3315 3316 /* host config updated, enable DIPM if transitioning to MIN_POWER */ 3317 ata_for_each_dev(dev, link, ENABLED) { 3318 if (policy >= ATA_LPM_MED_POWER_WITH_DIPM && !no_dipm && 3319 ata_id_has_dipm(dev->id)) { 3320 err_mask = ata_dev_set_feature(dev, 3321 SETFEATURES_SATA_ENABLE, SATA_DIPM); 3322 if (err_mask && err_mask != AC_ERR_DEV) { 3323 ata_dev_warn(dev, 3324 "failed to enable DIPM, Emask 0x%x\n", 3325 err_mask); 3326 rc = -EIO; 3327 goto fail; 3328 } 3329 } 3330 } 3331 3332 link->last_lpm_change = jiffies; 3333 link->flags |= ATA_LFLAG_CHANGED; 3334 3335 return 0; 3336 3337 fail: 3338 /* restore the old policy */ 3339 link->lpm_policy = old_policy; 3340 if (ap && ap->slave_link) 3341 ap->slave_link->lpm_policy = old_policy; 3342 3343 /* if no device or only one more chance is left, disable LPM */ 3344 if (!dev || ehc->tries[dev->devno] <= 2) { 3345 ata_link_warn(link, "disabling LPM on the link\n"); 3346 link->flags |= ATA_LFLAG_NO_LPM; 3347 } 3348 if (r_failed_dev) 3349 *r_failed_dev = dev; 3350 return rc; 3351 } 3352 3353 int ata_link_nr_enabled(struct ata_link *link) 3354 { 3355 struct ata_device *dev; 3356 int cnt = 0; 3357 3358 ata_for_each_dev(dev, link, ENABLED) 3359 cnt++; 3360 return cnt; 3361 } 3362 3363 static int ata_link_nr_vacant(struct ata_link *link) 3364 { 3365 struct ata_device *dev; 3366 int cnt = 0; 3367 3368 ata_for_each_dev(dev, link, ALL) 3369 if (dev->class == ATA_DEV_UNKNOWN) 3370 cnt++; 3371 return cnt; 3372 } 3373 3374 static int ata_eh_skip_recovery(struct ata_link *link) 3375 { 3376 struct ata_port *ap = link->ap; 3377 struct ata_eh_context *ehc = &link->eh_context; 3378 struct ata_device *dev; 3379 3380 /* skip disabled links */ 3381 if (link->flags & ATA_LFLAG_DISABLED) 3382 return 1; 3383 3384 /* skip if explicitly requested */ 3385 if (ehc->i.flags & ATA_EHI_NO_RECOVERY) 3386 return 1; 3387 3388 /* thaw frozen port and recover failed devices */ 3389 if ((ap->pflags & ATA_PFLAG_FROZEN) || ata_link_nr_enabled(link)) 3390 return 0; 3391 3392 /* reset at least once if reset is requested */ 3393 if ((ehc->i.action & ATA_EH_RESET) && 3394 !(ehc->i.flags & ATA_EHI_DID_RESET)) 3395 return 0; 3396 3397 /* skip if class codes for all vacant slots are ATA_DEV_NONE */ 3398 ata_for_each_dev(dev, link, ALL) { 3399 if (dev->class == ATA_DEV_UNKNOWN && 3400 ehc->classes[dev->devno] != ATA_DEV_NONE) 3401 return 0; 3402 } 3403 3404 return 1; 3405 } 3406 3407 static int ata_count_probe_trials_cb(struct ata_ering_entry *ent, void *void_arg) 3408 { 3409 u64 interval = msecs_to_jiffies(ATA_EH_PROBE_TRIAL_INTERVAL); 3410 u64 now = get_jiffies_64(); 3411 int *trials = void_arg; 3412 3413 if ((ent->eflags & ATA_EFLAG_OLD_ER) || 3414 (ent->timestamp < now - min(now, interval))) 3415 return -1; 3416 3417 (*trials)++; 3418 return 0; 3419 } 3420 3421 static int ata_eh_schedule_probe(struct ata_device *dev) 3422 { 3423 struct ata_eh_context *ehc = &dev->link->eh_context; 3424 struct ata_link *link = ata_dev_phys_link(dev); 3425 int trials = 0; 3426 3427 if (!(ehc->i.probe_mask & (1 << dev->devno)) || 3428 (ehc->did_probe_mask & (1 << dev->devno))) 3429 return 0; 3430 3431 ata_eh_detach_dev(dev); 3432 ata_dev_init(dev); 3433 ehc->did_probe_mask |= (1 << dev->devno); 3434 ehc->i.action |= ATA_EH_RESET; 3435 ehc->saved_xfer_mode[dev->devno] = 0; 3436 ehc->saved_ncq_enabled &= ~(1 << dev->devno); 3437 3438 /* the link maybe in a deep sleep, wake it up */ 3439 if (link->lpm_policy > ATA_LPM_MAX_POWER) { 3440 if (ata_is_host_link(link)) 3441 link->ap->ops->set_lpm(link, ATA_LPM_MAX_POWER, 3442 ATA_LPM_EMPTY); 3443 else 3444 sata_pmp_set_lpm(link, ATA_LPM_MAX_POWER, 3445 ATA_LPM_EMPTY); 3446 } 3447 3448 /* Record and count probe trials on the ering. The specific 3449 * error mask used is irrelevant. Because a successful device 3450 * detection clears the ering, this count accumulates only if 3451 * there are consecutive failed probes. 3452 * 3453 * If the count is equal to or higher than ATA_EH_PROBE_TRIALS 3454 * in the last ATA_EH_PROBE_TRIAL_INTERVAL, link speed is 3455 * forced to 1.5Gbps. 3456 * 3457 * This is to work around cases where failed link speed 3458 * negotiation results in device misdetection leading to 3459 * infinite DEVXCHG or PHRDY CHG events. 3460 */ 3461 ata_ering_record(&dev->ering, 0, AC_ERR_OTHER); 3462 ata_ering_map(&dev->ering, ata_count_probe_trials_cb, &trials); 3463 3464 if (trials > ATA_EH_PROBE_TRIALS) 3465 sata_down_spd_limit(link, 1); 3466 3467 return 1; 3468 } 3469 3470 static int ata_eh_handle_dev_fail(struct ata_device *dev, int err) 3471 { 3472 struct ata_eh_context *ehc = &dev->link->eh_context; 3473 3474 /* -EAGAIN from EH routine indicates retry without prejudice. 3475 * The requester is responsible for ensuring forward progress. 3476 */ 3477 if (err != -EAGAIN) 3478 ehc->tries[dev->devno]--; 3479 3480 switch (err) { 3481 case -ENODEV: 3482 /* device missing or wrong IDENTIFY data, schedule probing */ 3483 ehc->i.probe_mask |= (1 << dev->devno); 3484 fallthrough; 3485 case -EINVAL: 3486 /* give it just one more chance */ 3487 ehc->tries[dev->devno] = min(ehc->tries[dev->devno], 1); 3488 fallthrough; 3489 case -EIO: 3490 if (ehc->tries[dev->devno] == 1) { 3491 /* This is the last chance, better to slow 3492 * down than lose it. 3493 */ 3494 sata_down_spd_limit(ata_dev_phys_link(dev), 0); 3495 if (dev->pio_mode > XFER_PIO_0) 3496 ata_down_xfermask_limit(dev, ATA_DNXFER_PIO); 3497 } 3498 } 3499 3500 if (ata_dev_enabled(dev) && !ehc->tries[dev->devno]) { 3501 /* disable device if it has used up all its chances */ 3502 ata_dev_disable(dev); 3503 3504 /* detach if offline */ 3505 if (ata_phys_link_offline(ata_dev_phys_link(dev))) 3506 ata_eh_detach_dev(dev); 3507 3508 /* schedule probe if necessary */ 3509 if (ata_eh_schedule_probe(dev)) { 3510 ehc->tries[dev->devno] = ATA_EH_DEV_TRIES; 3511 memset(ehc->cmd_timeout_idx[dev->devno], 0, 3512 sizeof(ehc->cmd_timeout_idx[dev->devno])); 3513 } 3514 3515 return 1; 3516 } else { 3517 ehc->i.action |= ATA_EH_RESET; 3518 return 0; 3519 } 3520 } 3521 3522 /** 3523 * ata_eh_recover - recover host port after error 3524 * @ap: host port to recover 3525 * @prereset: prereset method (can be NULL) 3526 * @softreset: softreset method (can be NULL) 3527 * @hardreset: hardreset method (can be NULL) 3528 * @postreset: postreset method (can be NULL) 3529 * @r_failed_link: out parameter for failed link 3530 * 3531 * This is the alpha and omega, eum and yang, heart and soul of 3532 * libata exception handling. On entry, actions required to 3533 * recover each link and hotplug requests are recorded in the 3534 * link's eh_context. This function executes all the operations 3535 * with appropriate retrials and fallbacks to resurrect failed 3536 * devices, detach goners and greet newcomers. 3537 * 3538 * LOCKING: 3539 * Kernel thread context (may sleep). 3540 * 3541 * RETURNS: 3542 * 0 on success, -errno on failure. 3543 */ 3544 int ata_eh_recover(struct ata_port *ap, ata_prereset_fn_t prereset, 3545 ata_reset_fn_t softreset, ata_reset_fn_t hardreset, 3546 ata_postreset_fn_t postreset, 3547 struct ata_link **r_failed_link) 3548 { 3549 struct ata_link *link; 3550 struct ata_device *dev; 3551 int rc, nr_fails; 3552 unsigned long flags, deadline; 3553 3554 DPRINTK("ENTER\n"); 3555 3556 /* prep for recovery */ 3557 ata_for_each_link(link, ap, EDGE) { 3558 struct ata_eh_context *ehc = &link->eh_context; 3559 3560 /* re-enable link? */ 3561 if (ehc->i.action & ATA_EH_ENABLE_LINK) { 3562 ata_eh_about_to_do(link, NULL, ATA_EH_ENABLE_LINK); 3563 spin_lock_irqsave(ap->lock, flags); 3564 link->flags &= ~ATA_LFLAG_DISABLED; 3565 spin_unlock_irqrestore(ap->lock, flags); 3566 ata_eh_done(link, NULL, ATA_EH_ENABLE_LINK); 3567 } 3568 3569 ata_for_each_dev(dev, link, ALL) { 3570 if (link->flags & ATA_LFLAG_NO_RETRY) 3571 ehc->tries[dev->devno] = 1; 3572 else 3573 ehc->tries[dev->devno] = ATA_EH_DEV_TRIES; 3574 3575 /* collect port action mask recorded in dev actions */ 3576 ehc->i.action |= ehc->i.dev_action[dev->devno] & 3577 ~ATA_EH_PERDEV_MASK; 3578 ehc->i.dev_action[dev->devno] &= ATA_EH_PERDEV_MASK; 3579 3580 /* process hotplug request */ 3581 if (dev->flags & ATA_DFLAG_DETACH) 3582 ata_eh_detach_dev(dev); 3583 3584 /* schedule probe if necessary */ 3585 if (!ata_dev_enabled(dev)) 3586 ata_eh_schedule_probe(dev); 3587 } 3588 } 3589 3590 retry: 3591 rc = 0; 3592 3593 /* if UNLOADING, finish immediately */ 3594 if (ap->pflags & ATA_PFLAG_UNLOADING) 3595 goto out; 3596 3597 /* prep for EH */ 3598 ata_for_each_link(link, ap, EDGE) { 3599 struct ata_eh_context *ehc = &link->eh_context; 3600 3601 /* skip EH if possible. */ 3602 if (ata_eh_skip_recovery(link)) 3603 ehc->i.action = 0; 3604 3605 ata_for_each_dev(dev, link, ALL) 3606 ehc->classes[dev->devno] = ATA_DEV_UNKNOWN; 3607 } 3608 3609 /* reset */ 3610 ata_for_each_link(link, ap, EDGE) { 3611 struct ata_eh_context *ehc = &link->eh_context; 3612 3613 if (!(ehc->i.action & ATA_EH_RESET)) 3614 continue; 3615 3616 rc = ata_eh_reset(link, ata_link_nr_vacant(link), 3617 prereset, softreset, hardreset, postreset); 3618 if (rc) { 3619 ata_link_err(link, "reset failed, giving up\n"); 3620 goto out; 3621 } 3622 } 3623 3624 do { 3625 unsigned long now; 3626 3627 /* 3628 * clears ATA_EH_PARK in eh_info and resets 3629 * ap->park_req_pending 3630 */ 3631 ata_eh_pull_park_action(ap); 3632 3633 deadline = jiffies; 3634 ata_for_each_link(link, ap, EDGE) { 3635 ata_for_each_dev(dev, link, ALL) { 3636 struct ata_eh_context *ehc = &link->eh_context; 3637 unsigned long tmp; 3638 3639 if (dev->class != ATA_DEV_ATA && 3640 dev->class != ATA_DEV_ZAC) 3641 continue; 3642 if (!(ehc->i.dev_action[dev->devno] & 3643 ATA_EH_PARK)) 3644 continue; 3645 tmp = dev->unpark_deadline; 3646 if (time_before(deadline, tmp)) 3647 deadline = tmp; 3648 else if (time_before_eq(tmp, jiffies)) 3649 continue; 3650 if (ehc->unloaded_mask & (1 << dev->devno)) 3651 continue; 3652 3653 ata_eh_park_issue_cmd(dev, 1); 3654 } 3655 } 3656 3657 now = jiffies; 3658 if (time_before_eq(deadline, now)) 3659 break; 3660 3661 ata_eh_release(ap); 3662 deadline = wait_for_completion_timeout(&ap->park_req_pending, 3663 deadline - now); 3664 ata_eh_acquire(ap); 3665 } while (deadline); 3666 ata_for_each_link(link, ap, EDGE) { 3667 ata_for_each_dev(dev, link, ALL) { 3668 if (!(link->eh_context.unloaded_mask & 3669 (1 << dev->devno))) 3670 continue; 3671 3672 ata_eh_park_issue_cmd(dev, 0); 3673 ata_eh_done(link, dev, ATA_EH_PARK); 3674 } 3675 } 3676 3677 /* the rest */ 3678 nr_fails = 0; 3679 ata_for_each_link(link, ap, PMP_FIRST) { 3680 struct ata_eh_context *ehc = &link->eh_context; 3681 3682 if (sata_pmp_attached(ap) && ata_is_host_link(link)) 3683 goto config_lpm; 3684 3685 /* revalidate existing devices and attach new ones */ 3686 rc = ata_eh_revalidate_and_attach(link, &dev); 3687 if (rc) 3688 goto rest_fail; 3689 3690 /* if PMP got attached, return, pmp EH will take care of it */ 3691 if (link->device->class == ATA_DEV_PMP) { 3692 ehc->i.action = 0; 3693 return 0; 3694 } 3695 3696 /* configure transfer mode if necessary */ 3697 if (ehc->i.flags & ATA_EHI_SETMODE) { 3698 rc = ata_set_mode(link, &dev); 3699 if (rc) 3700 goto rest_fail; 3701 ehc->i.flags &= ~ATA_EHI_SETMODE; 3702 } 3703 3704 /* If reset has been issued, clear UA to avoid 3705 * disrupting the current users of the device. 3706 */ 3707 if (ehc->i.flags & ATA_EHI_DID_RESET) { 3708 ata_for_each_dev(dev, link, ALL) { 3709 if (dev->class != ATA_DEV_ATAPI) 3710 continue; 3711 rc = atapi_eh_clear_ua(dev); 3712 if (rc) 3713 goto rest_fail; 3714 if (zpodd_dev_enabled(dev)) 3715 zpodd_post_poweron(dev); 3716 } 3717 } 3718 3719 /* retry flush if necessary */ 3720 ata_for_each_dev(dev, link, ALL) { 3721 if (dev->class != ATA_DEV_ATA && 3722 dev->class != ATA_DEV_ZAC) 3723 continue; 3724 rc = ata_eh_maybe_retry_flush(dev); 3725 if (rc) 3726 goto rest_fail; 3727 } 3728 3729 config_lpm: 3730 /* configure link power saving */ 3731 if (link->lpm_policy != ap->target_lpm_policy) { 3732 rc = ata_eh_set_lpm(link, ap->target_lpm_policy, &dev); 3733 if (rc) 3734 goto rest_fail; 3735 } 3736 3737 /* this link is okay now */ 3738 ehc->i.flags = 0; 3739 continue; 3740 3741 rest_fail: 3742 nr_fails++; 3743 if (dev) 3744 ata_eh_handle_dev_fail(dev, rc); 3745 3746 if (ap->pflags & ATA_PFLAG_FROZEN) { 3747 /* PMP reset requires working host port. 3748 * Can't retry if it's frozen. 3749 */ 3750 if (sata_pmp_attached(ap)) 3751 goto out; 3752 break; 3753 } 3754 } 3755 3756 if (nr_fails) 3757 goto retry; 3758 3759 out: 3760 if (rc && r_failed_link) 3761 *r_failed_link = link; 3762 3763 DPRINTK("EXIT, rc=%d\n", rc); 3764 return rc; 3765 } 3766 3767 /** 3768 * ata_eh_finish - finish up EH 3769 * @ap: host port to finish EH for 3770 * 3771 * Recovery is complete. Clean up EH states and retry or finish 3772 * failed qcs. 3773 * 3774 * LOCKING: 3775 * None. 3776 */ 3777 void ata_eh_finish(struct ata_port *ap) 3778 { 3779 struct ata_queued_cmd *qc; 3780 int tag; 3781 3782 /* retry or finish qcs */ 3783 ata_qc_for_each_raw(ap, qc, tag) { 3784 if (!(qc->flags & ATA_QCFLAG_FAILED)) 3785 continue; 3786 3787 if (qc->err_mask) { 3788 /* FIXME: Once EH migration is complete, 3789 * generate sense data in this function, 3790 * considering both err_mask and tf. 3791 */ 3792 if (qc->flags & ATA_QCFLAG_RETRY) 3793 ata_eh_qc_retry(qc); 3794 else 3795 ata_eh_qc_complete(qc); 3796 } else { 3797 if (qc->flags & ATA_QCFLAG_SENSE_VALID) { 3798 ata_eh_qc_complete(qc); 3799 } else { 3800 /* feed zero TF to sense generation */ 3801 memset(&qc->result_tf, 0, sizeof(qc->result_tf)); 3802 ata_eh_qc_retry(qc); 3803 } 3804 } 3805 } 3806 3807 /* make sure nr_active_links is zero after EH */ 3808 WARN_ON(ap->nr_active_links); 3809 ap->nr_active_links = 0; 3810 } 3811 3812 /** 3813 * ata_do_eh - do standard error handling 3814 * @ap: host port to handle error for 3815 * 3816 * @prereset: prereset method (can be NULL) 3817 * @softreset: softreset method (can be NULL) 3818 * @hardreset: hardreset method (can be NULL) 3819 * @postreset: postreset method (can be NULL) 3820 * 3821 * Perform standard error handling sequence. 3822 * 3823 * LOCKING: 3824 * Kernel thread context (may sleep). 3825 */ 3826 void ata_do_eh(struct ata_port *ap, ata_prereset_fn_t prereset, 3827 ata_reset_fn_t softreset, ata_reset_fn_t hardreset, 3828 ata_postreset_fn_t postreset) 3829 { 3830 struct ata_device *dev; 3831 int rc; 3832 3833 ata_eh_autopsy(ap); 3834 ata_eh_report(ap); 3835 3836 rc = ata_eh_recover(ap, prereset, softreset, hardreset, postreset, 3837 NULL); 3838 if (rc) { 3839 ata_for_each_dev(dev, &ap->link, ALL) 3840 ata_dev_disable(dev); 3841 } 3842 3843 ata_eh_finish(ap); 3844 } 3845 3846 /** 3847 * ata_std_error_handler - standard error handler 3848 * @ap: host port to handle error for 3849 * 3850 * Standard error handler 3851 * 3852 * LOCKING: 3853 * Kernel thread context (may sleep). 3854 */ 3855 void ata_std_error_handler(struct ata_port *ap) 3856 { 3857 struct ata_port_operations *ops = ap->ops; 3858 ata_reset_fn_t hardreset = ops->hardreset; 3859 3860 /* ignore built-in hardreset if SCR access is not available */ 3861 if (hardreset == sata_std_hardreset && !sata_scr_valid(&ap->link)) 3862 hardreset = NULL; 3863 3864 ata_do_eh(ap, ops->prereset, ops->softreset, hardreset, ops->postreset); 3865 } 3866 EXPORT_SYMBOL_GPL(ata_std_error_handler); 3867 3868 #ifdef CONFIG_PM 3869 /** 3870 * ata_eh_handle_port_suspend - perform port suspend operation 3871 * @ap: port to suspend 3872 * 3873 * Suspend @ap. 3874 * 3875 * LOCKING: 3876 * Kernel thread context (may sleep). 3877 */ 3878 static void ata_eh_handle_port_suspend(struct ata_port *ap) 3879 { 3880 unsigned long flags; 3881 int rc = 0; 3882 struct ata_device *dev; 3883 3884 /* are we suspending? */ 3885 spin_lock_irqsave(ap->lock, flags); 3886 if (!(ap->pflags & ATA_PFLAG_PM_PENDING) || 3887 ap->pm_mesg.event & PM_EVENT_RESUME) { 3888 spin_unlock_irqrestore(ap->lock, flags); 3889 return; 3890 } 3891 spin_unlock_irqrestore(ap->lock, flags); 3892 3893 WARN_ON(ap->pflags & ATA_PFLAG_SUSPENDED); 3894 3895 /* 3896 * If we have a ZPODD attached, check its zero 3897 * power ready status before the port is frozen. 3898 * Only needed for runtime suspend. 3899 */ 3900 if (PMSG_IS_AUTO(ap->pm_mesg)) { 3901 ata_for_each_dev(dev, &ap->link, ENABLED) { 3902 if (zpodd_dev_enabled(dev)) 3903 zpodd_on_suspend(dev); 3904 } 3905 } 3906 3907 /* tell ACPI we're suspending */ 3908 rc = ata_acpi_on_suspend(ap); 3909 if (rc) 3910 goto out; 3911 3912 /* suspend */ 3913 ata_eh_freeze_port(ap); 3914 3915 if (ap->ops->port_suspend) 3916 rc = ap->ops->port_suspend(ap, ap->pm_mesg); 3917 3918 ata_acpi_set_state(ap, ap->pm_mesg); 3919 out: 3920 /* update the flags */ 3921 spin_lock_irqsave(ap->lock, flags); 3922 3923 ap->pflags &= ~ATA_PFLAG_PM_PENDING; 3924 if (rc == 0) 3925 ap->pflags |= ATA_PFLAG_SUSPENDED; 3926 else if (ap->pflags & ATA_PFLAG_FROZEN) 3927 ata_port_schedule_eh(ap); 3928 3929 spin_unlock_irqrestore(ap->lock, flags); 3930 3931 return; 3932 } 3933 3934 /** 3935 * ata_eh_handle_port_resume - perform port resume operation 3936 * @ap: port to resume 3937 * 3938 * Resume @ap. 3939 * 3940 * LOCKING: 3941 * Kernel thread context (may sleep). 3942 */ 3943 static void ata_eh_handle_port_resume(struct ata_port *ap) 3944 { 3945 struct ata_link *link; 3946 struct ata_device *dev; 3947 unsigned long flags; 3948 3949 /* are we resuming? */ 3950 spin_lock_irqsave(ap->lock, flags); 3951 if (!(ap->pflags & ATA_PFLAG_PM_PENDING) || 3952 !(ap->pm_mesg.event & PM_EVENT_RESUME)) { 3953 spin_unlock_irqrestore(ap->lock, flags); 3954 return; 3955 } 3956 spin_unlock_irqrestore(ap->lock, flags); 3957 3958 WARN_ON(!(ap->pflags & ATA_PFLAG_SUSPENDED)); 3959 3960 /* 3961 * Error timestamps are in jiffies which doesn't run while 3962 * suspended and PHY events during resume isn't too uncommon. 3963 * When the two are combined, it can lead to unnecessary speed 3964 * downs if the machine is suspended and resumed repeatedly. 3965 * Clear error history. 3966 */ 3967 ata_for_each_link(link, ap, HOST_FIRST) 3968 ata_for_each_dev(dev, link, ALL) 3969 ata_ering_clear(&dev->ering); 3970 3971 ata_acpi_set_state(ap, ap->pm_mesg); 3972 3973 if (ap->ops->port_resume) 3974 ap->ops->port_resume(ap); 3975 3976 /* tell ACPI that we're resuming */ 3977 ata_acpi_on_resume(ap); 3978 3979 /* update the flags */ 3980 spin_lock_irqsave(ap->lock, flags); 3981 ap->pflags &= ~(ATA_PFLAG_PM_PENDING | ATA_PFLAG_SUSPENDED); 3982 spin_unlock_irqrestore(ap->lock, flags); 3983 } 3984 #endif /* CONFIG_PM */ 3985