[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v3 8/8] hw/ide/ahci: fix broken SError handling
From: |
Niklas Cassel |
Subject: |
[PATCH v3 8/8] hw/ide/ahci: fix broken SError handling |
Date: |
Fri, 9 Jun 2023 16:08:44 +0200 |
From: Niklas Cassel <niklas.cassel@wdc.com>
When encountering an NCQ error, you should not write the NCQ tag to the
SError register. This is completely wrong.
The SError register has a clear definition, where each bit represents a
different error, see PxSERR definition in AHCI 1.3.1.
If we write a random value (like the NCQ tag) in SError, e.g. Linux will
read SError, and will trigger arbitrary error handling depending on the
NCQ tag that happened to be executing.
In case of success, ncq_cb() will call ncq_finish().
In case of error, ncq_cb() will call ncq_err() (which will clear
ncq_tfs->used), and then call ncq_finish(), thus using ncq_tfs->used is
sufficient to tell if finished should get set or not.
Signed-off-by: Niklas Cassel <niklas.cassel@wdc.com>
---
hw/ide/ahci.c | 3 +--
1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/hw/ide/ahci.c b/hw/ide/ahci.c
index ef6c9fc378..d0a774bc17 100644
--- a/hw/ide/ahci.c
+++ b/hw/ide/ahci.c
@@ -1012,7 +1012,6 @@ static void ncq_err(NCQTransferState *ncq_tfs)
ide_state->error = ABRT_ERR;
ide_state->status = READY_STAT | ERR_STAT;
- ncq_tfs->drive->port_regs.scr_err |= (1 << ncq_tfs->tag);
qemu_sglist_destroy(&ncq_tfs->sglist);
ncq_tfs->used = 0;
}
@@ -1022,7 +1021,7 @@ static void ncq_finish(NCQTransferState *ncq_tfs)
/* If we didn't error out, set our finished bit. Errored commands
* do not get a bit set for the SDB FIS ACT register, nor do they
* clear the outstanding bit in scr_act (PxSACT). */
- if (!(ncq_tfs->drive->port_regs.scr_err & (1 << ncq_tfs->tag))) {
+ if (ncq_tfs->used) {
ncq_tfs->drive->finished |= (1 << ncq_tfs->tag);
}
--
2.40.1
- [PATCH v3 0/8] misc AHCI cleanups, Niklas Cassel, 2023/06/09
- [PATCH v3 1/8] hw/ide/ahci: remove stray backslash, Niklas Cassel, 2023/06/09
- [PATCH v3 2/8] hw/ide/core: set ERR_STAT in unsupported command completion, Niklas Cassel, 2023/06/09
- [PATCH v3 3/8] hw/ide/ahci: write D2H FIS when processing NCQ command, Niklas Cassel, 2023/06/09
- [PATCH v3 5/8] hw/ide/ahci: PxSACT and PxCI is cleared when PxCMD.ST is cleared, Niklas Cassel, 2023/06/09
- [PATCH v3 4/8] hw/ide/ahci: simplify and document PxCI handling, Niklas Cassel, 2023/06/09
- [PATCH v3 7/8] hw/ide/ahci: fix ahci_write_fis_sdb(), Niklas Cassel, 2023/06/09
- [PATCH v3 6/8] hw/ide/ahci: PxCI should not get cleared when ERR_STAT is set, Niklas Cassel, 2023/06/09
- [PATCH v3 8/8] hw/ide/ahci: fix broken SError handling,
Niklas Cassel <=