[PATCH 10/26] scsi: stop decoding if scsi_normalize_sense() fails

2014-10-07 Thread Hannes Reinecke
If scsi_normalize_sense() fails we couldn't decode the sense
buffer, and the scsi_sense_hdr fields are invalid.
For those cases we should rather dump the sense buffer
and not try to decode invalid fields.

Reviewed-by: Robert Elliott 
Reviewed-by: Christoph Hellwig 
Signed-off-by: Hannes Reinecke 
---
 drivers/scsi/constants.c | 34 --
 1 file changed, 16 insertions(+), 18 deletions(-)

diff --git a/drivers/scsi/constants.c b/drivers/scsi/constants.c
index f9e2317..0b74e94 100644
--- a/drivers/scsi/constants.c
+++ b/drivers/scsi/constants.c
@@ -1435,26 +1435,21 @@ scsi_print_sense_hdr(const struct scsi_device *sdev, 
const char *name,
 EXPORT_SYMBOL(scsi_print_sense_hdr);
 
 static void
-scsi_decode_sense_buffer(const unsigned char *sense_buffer, int sense_len,
-  struct scsi_sense_hdr *sshdr)
+scsi_dump_sense_buffer(const unsigned char *sense_buffer, int sense_len)
 {
-   int k, num, res;
-
-   res = scsi_normalize_sense(sense_buffer, sense_len, sshdr);
-   if (0 == res) {
-   /* this may be SCSI-1 sense data */
-   num = (sense_len < 32) ? sense_len : 32;
-   printk("Unrecognized sense data (in hex):");
-   for (k = 0; k < num; ++k) {
-   if (0 == (k % 16)) {
-   printk("\n");
-   printk(KERN_INFO "");
-   }
-   printk("%02x ", sense_buffer[k]);
+   int k, num;
+
+   num = (sense_len < 32) ? sense_len : 32;
+   printk("Unrecognized sense data (in hex):");
+   for (k = 0; k < num; ++k) {
+   if (0 == (k % 16)) {
+   printk("\n");
+   printk(KERN_INFO "");
}
-   printk("\n");
-   return;
+   printk("%02x ", sense_buffer[k]);
}
+   printk("\n");
+   return;
 }
 
 static void
@@ -1524,7 +1519,10 @@ void __scsi_print_sense(const struct scsi_device *sdev, 
const char *name,
 {
struct scsi_sense_hdr sshdr;
 
-   scsi_decode_sense_buffer(sense_buffer, sense_len, &sshdr);
+   if (!scsi_normalize_sense(sense_buffer, sense_len, &sshdr)) {
+   scsi_dump_sense_buffer(sense_buffer, sense_len);
+   return;
+   }
scsi_show_sense_hdr(sdev, name, &sshdr);
scsi_decode_sense_extras(sense_buffer, sense_len, &sshdr);
scsi_show_extd_sense(sdev, name, sshdr.asc, sshdr.ascq);
-- 
1.8.5.2

--
To unsubscribe from this list: send the line "unsubscribe linux-scsi" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[PATCH 10/26] scsi: stop decoding if scsi_normalize_sense() fails

2014-10-06 Thread Hannes Reinecke
If scsi_normalize_sense() fails we couldn't decode the sense
buffer, and the scsi_sense_hdr fields are invalid.
For those cases we should rather dump the sense buffer
and not try to decode invalid fields.

Reviewed-by: Robert Elliott 
Reviewed-by: Christoph Hellwig 
Signed-off-by: Hannes Reinecke 
---
 drivers/scsi/constants.c | 34 --
 1 file changed, 16 insertions(+), 18 deletions(-)

diff --git a/drivers/scsi/constants.c b/drivers/scsi/constants.c
index f9e2317..0b74e94 100644
--- a/drivers/scsi/constants.c
+++ b/drivers/scsi/constants.c
@@ -1435,26 +1435,21 @@ scsi_print_sense_hdr(const struct scsi_device *sdev, 
const char *name,
 EXPORT_SYMBOL(scsi_print_sense_hdr);
 
 static void
-scsi_decode_sense_buffer(const unsigned char *sense_buffer, int sense_len,
-  struct scsi_sense_hdr *sshdr)
+scsi_dump_sense_buffer(const unsigned char *sense_buffer, int sense_len)
 {
-   int k, num, res;
-
-   res = scsi_normalize_sense(sense_buffer, sense_len, sshdr);
-   if (0 == res) {
-   /* this may be SCSI-1 sense data */
-   num = (sense_len < 32) ? sense_len : 32;
-   printk("Unrecognized sense data (in hex):");
-   for (k = 0; k < num; ++k) {
-   if (0 == (k % 16)) {
-   printk("\n");
-   printk(KERN_INFO "");
-   }
-   printk("%02x ", sense_buffer[k]);
+   int k, num;
+
+   num = (sense_len < 32) ? sense_len : 32;
+   printk("Unrecognized sense data (in hex):");
+   for (k = 0; k < num; ++k) {
+   if (0 == (k % 16)) {
+   printk("\n");
+   printk(KERN_INFO "");
}
-   printk("\n");
-   return;
+   printk("%02x ", sense_buffer[k]);
}
+   printk("\n");
+   return;
 }
 
 static void
@@ -1524,7 +1519,10 @@ void __scsi_print_sense(const struct scsi_device *sdev, 
const char *name,
 {
struct scsi_sense_hdr sshdr;
 
-   scsi_decode_sense_buffer(sense_buffer, sense_len, &sshdr);
+   if (!scsi_normalize_sense(sense_buffer, sense_len, &sshdr)) {
+   scsi_dump_sense_buffer(sense_buffer, sense_len);
+   return;
+   }
scsi_show_sense_hdr(sdev, name, &sshdr);
scsi_decode_sense_extras(sense_buffer, sense_len, &sshdr);
scsi_show_extd_sense(sdev, name, sshdr.asc, sshdr.ascq);
-- 
1.8.5.2

--
To unsubscribe from this list: send the line "unsubscribe linux-scsi" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html