mirror of
https://github.com/adulau/aha.git
synced 2024-12-27 19:26:25 +00:00
libata: fix internal command failure handling
When an internal command fails, it should be failed directly without invoking EH. In the original implemetation, this was accomplished by letting internal command bypass failure handling in ata_qc_complete(). However, later changes added post-successful-completion handling to that code path and the success path is no longer adequate as internal command failure path. One of the visible problems is that internal command failure due to timeout or other freeze conditions would spuriously trigger WARN_ON_ONCE() in the success path. This patch updates failure path such that internal command failure handling is contained there. Signed-off-by: Tejun Heo <tj@kernel.org> Cc: stable@kernel.org Signed-off-by: Jeff Garzik <jgarzik@redhat.com>
This commit is contained in:
parent
4f7c287499
commit
f4b31db92d
1 changed files with 7 additions and 5 deletions
|
@ -5028,12 +5028,14 @@ void ata_qc_complete(struct ata_queued_cmd *qc)
|
|||
qc->flags |= ATA_QCFLAG_FAILED;
|
||||
|
||||
if (unlikely(qc->flags & ATA_QCFLAG_FAILED)) {
|
||||
if (!ata_tag_internal(qc->tag)) {
|
||||
/* always fill result TF for failed qc */
|
||||
fill_result_tf(qc);
|
||||
/* always fill result TF for failed qc */
|
||||
fill_result_tf(qc);
|
||||
|
||||
if (!ata_tag_internal(qc->tag))
|
||||
ata_qc_schedule_eh(qc);
|
||||
return;
|
||||
}
|
||||
else
|
||||
__ata_qc_complete(qc);
|
||||
return;
|
||||
}
|
||||
|
||||
WARN_ON_ONCE(ap->pflags & ATA_PFLAG_FROZEN);
|
||||
|
|
Loading…
Reference in a new issue