On Wed, 2018-04-04 at 09:27 +0200, Hannes Reinecke wrote:
diff --git a/drivers/scsi/scsi_lib.c b/drivers/scsi/scsi_lib.c index 393f9db8f41b..9389c41e2829 100644 --- a/drivers/scsi/scsi_lib.c +++ b/drivers/scsi/scsi_lib.c @@ -905,6 +905,12 @@ void scsi_io_completion(struct scsi_cmnd *cmd, unsigned int good_bytes) goto requeue; error = __scsi_error_from_host_byte(cmd, result);
- /*
* If the hostbyte was DID_OK, but the sense code is valid
* we always should set BLK_STS_IOERR.
*/
- if (error == BLK_STS_OK && sense_valid)
error = BLK_STS_IOERR;
if (host_byte(result) == DID_RESET) { /* Third party bus reset or reset for error recovery
__scsi_error_from_host_byte() has two callers. Why does this patch only update one of these two callers?
Regarding commit e39a97353e53, the description of that commit is as follows: "When converting __scsi_error_from_host_byte() to BLK_STS error codes the case DID_OK was forgotten, resulting in it always returning an error." However, the comment above that function reads as follows: "translate SCSI error code into errno". If I have a look at the v4.12 SCSI core (before the blkstatus_t conversion) then I see that __scsi_error_from_host_byte() never returns 0. That means that the description of commit e39a97353e53 ("scsi: core: return BLK_STS_OK for DID_OK in __scsi_error_from_host_byte()") is wrong. Does that mean that commit e39a97353e53 should be reverted?
Thanks,
Bart.