9ae3a8
From 8bb562cbc4c70ea2d338db0e86d99b0578a73955 Mon Sep 17 00:00:00 2001
9ae3a8
From: Fam Zheng <famz@redhat.com>
9ae3a8
Date: Fri, 4 Apr 2014 05:55:59 +0200
9ae3a8
Subject: [PATCH 04/12] block/iscsi: fix segfault if writesame fails
9ae3a8
9ae3a8
RH-Author: Fam Zheng <famz@redhat.com>
9ae3a8
Message-id: <1396590962-25815-5-git-send-email-famz@redhat.com>
9ae3a8
Patchwork-id: 58341
9ae3a8
O-Subject: [RHEL-7 0day qemu-kvm PATCH 4/7] block/iscsi: fix segfault if writesame fails
9ae3a8
Bugzilla: 1083413
9ae3a8
RH-Acked-by: Paolo Bonzini <pbonzini@redhat.com>
9ae3a8
RH-Acked-by: Markus Armbruster <armbru@redhat.com>
9ae3a8
RH-Acked-by: Kevin Wolf <kwolf@redhat.com>
9ae3a8
RH-Acked-by: Jeffrey Cody <jcody@redhat.com>
9ae3a8
9ae3a8
From: Peter Lieven <pl@kamp.de>
9ae3a8
9ae3a8
commit fa6252b0 introduced a segfault because it tries
9ae3a8
to read iTask.task->sense after iTask.task has been
9ae3a8
freed.
9ae3a8
9ae3a8
Signed-off-by: Peter Lieven <pl@kamp.de>
9ae3a8
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
9ae3a8
(cherry picked from commit d9738fd2463f71530d8d92fbb52ebdd1d78074fc)
9ae3a8
Signed-off-by: Fam Zheng <famz@redhat.com>
9ae3a8
---
9ae3a8
 block/iscsi.c | 17 +++++++++--------
9ae3a8
 1 file changed, 9 insertions(+), 8 deletions(-)
9ae3a8
9ae3a8
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
9ae3a8
---
9ae3a8
 block/iscsi.c |   17 +++++++++--------
9ae3a8
 1 files changed, 9 insertions(+), 8 deletions(-)
9ae3a8
9ae3a8
diff --git a/block/iscsi.c b/block/iscsi.c
9ae3a8
index d3c8802..4a535e3 100644
9ae3a8
--- a/block/iscsi.c
9ae3a8
+++ b/block/iscsi.c
9ae3a8
@@ -1010,6 +1010,15 @@ retry:
9ae3a8
         qemu_coroutine_yield();
9ae3a8
     }
9ae3a8
 
9ae3a8
+    if (iTask.status == SCSI_STATUS_CHECK_CONDITION &&
9ae3a8
+        iTask.task->sense.key == SCSI_SENSE_ILLEGAL_REQUEST &&
9ae3a8
+        iTask.task->sense.ascq == SCSI_SENSE_ASCQ_INVALID_OPERATION_CODE) {
9ae3a8
+        /* WRITE SAME is not supported by the target */
9ae3a8
+        iscsilun->has_write_same = false;
9ae3a8
+        scsi_free_scsi_task(iTask.task);
9ae3a8
+        return -ENOTSUP;
9ae3a8
+    }
9ae3a8
+
9ae3a8
     if (iTask.task != NULL) {
9ae3a8
         scsi_free_scsi_task(iTask.task);
9ae3a8
         iTask.task = NULL;
9ae3a8
@@ -1020,14 +1029,6 @@ retry:
9ae3a8
     }
9ae3a8
 
9ae3a8
     if (iTask.status != SCSI_STATUS_GOOD) {
9ae3a8
-        if (iTask.status == SCSI_STATUS_CHECK_CONDITION &&
9ae3a8
-            iTask.task->sense.key == SCSI_SENSE_ILLEGAL_REQUEST &&
9ae3a8
-            iTask.task->sense.ascq == SCSI_SENSE_ASCQ_INVALID_OPERATION_CODE) {
9ae3a8
-            /* WRITE SAME is not supported by the target */
9ae3a8
-            iscsilun->has_write_same = false;
9ae3a8
-            return -ENOTSUP;
9ae3a8
-        }
9ae3a8
-
9ae3a8
         return -EIO;
9ae3a8
     }
9ae3a8
 
9ae3a8
-- 
9ae3a8
1.7.1
9ae3a8