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