From bba49ee66cfd3ac31178d8cdd1fe731c5bf5bf21 Mon Sep 17 00:00:00 2001 From: Mike Snitzer Date: Mon, 13 Feb 2012 18:35:11 -0500 Subject: [PATCH] --- yaml --- r: 292974 b: refs/heads/master c: 47ac56db133cb0b6cf3c8b156db854c158fb9dae h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/drivers/scsi/scsi_error.c | 8 ++++++++ 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index 715bb8e45c03..59450fce49cb 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 89730393f260aef7fce9f6fd475da148517a4c5c +refs/heads/master: 47ac56db133cb0b6cf3c8b156db854c158fb9dae diff --git a/trunk/drivers/scsi/scsi_error.c b/trunk/drivers/scsi/scsi_error.c index 6ae3b5dbd379..f66e90db3bee 100644 --- a/trunk/drivers/scsi/scsi_error.c +++ b/trunk/drivers/scsi/scsi_error.c @@ -366,6 +366,14 @@ static int scsi_check_sense(struct scsi_cmnd *scmd) return TARGET_ERROR; case ILLEGAL_REQUEST: + if (sshdr.asc == 0x20 || /* Invalid command operation code */ + sshdr.asc == 0x21 || /* Logical block address out of range */ + sshdr.asc == 0x24 || /* Invalid field in cdb */ + sshdr.asc == 0x26) { /* Parameter value invalid */ + return TARGET_ERROR; + } + return SUCCESS; + default: return SUCCESS; }