7a3408
From 8c46231056f7c633a9f8576018d764e3a0b7251f Mon Sep 17 00:00:00 2001
7a3408
Message-Id: <8c46231056f7c633a9f8576018d764e3a0b7251f@dist-git>
7a3408
From: John Ferlan <jferlan@redhat.com>
7a3408
Date: Thu, 9 Jul 2015 08:28:56 -0400
7a3408
Subject: [PATCH] qemu: Fix integer/boolean logic in qemuSetUnprivSGIO
7a3408
7a3408
https://bugzilla.redhat.com/show_bug.cgi?id=1072736
7a3408
7a3408
Setting of 'val' is a boolean expression, so handle it that way and
7a3408
adjust the check/return logic to be clearer
7a3408
7a3408
Signed-off-by: John Ferlan <jferlan@redhat.com>
7a3408
(cherry picked from commit 69b850fe2a19d0c32ae2f209e8d8463df6ead665)
7a3408
Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
7a3408
---
7a3408
 src/qemu/qemu_conf.c | 10 +++++++---
7a3408
 1 file changed, 7 insertions(+), 3 deletions(-)
7a3408
7a3408
diff --git a/src/qemu/qemu_conf.c b/src/qemu/qemu_conf.c
7a3408
index d41f166..7d317d7 100644
7a3408
--- a/src/qemu/qemu_conf.c
7a3408
+++ b/src/qemu/qemu_conf.c
7a3408
@@ -1433,7 +1433,7 @@ qemuSetUnprivSGIO(virDomainDeviceDefPtr dev)
7a3408
     virDomainHostdevDefPtr hostdev = NULL;
7a3408
     char *sysfs_path = NULL;
7a3408
     const char *path = NULL;
7a3408
-    int val = -1;
7a3408
+    bool val;
7a3408
     int ret = -1;
7a3408
 
7a3408
     /* "sgio" is only valid for block disk; cdrom
7a3408
@@ -1475,8 +1475,12 @@ qemuSetUnprivSGIO(virDomainDeviceDefPtr dev)
7a3408
      * whitelist is enabled.  But if requesting unfiltered access, always call
7a3408
      * virSetDeviceUnprivSGIO, to report an error for unsupported unpriv_sgio.
7a3408
      */
7a3408
-    if ((virFileExists(sysfs_path) || val == 1) &&
7a3408
-        virSetDeviceUnprivSGIO(path, NULL, val) < 0)
7a3408
+    if (!val || !virFileExists(sysfs_path)) {
7a3408
+        ret = 0;
7a3408
+        goto cleanup;
7a3408
+    }
7a3408
+
7a3408
+    if (virSetDeviceUnprivSGIO(path, NULL, 1) < 0)
7a3408
         goto cleanup;
7a3408
 
7a3408
     ret = 0;
7a3408
-- 
7a3408
2.5.1
7a3408