Blame SOURCES/kvm-virtiofsd-Fix-fuse_daemonize-ignored-return-values.patch

ddf19c
From 9f726593bc3acbc247876dcc4d79fbf046958003 Mon Sep 17 00:00:00 2001
ddf19c
From: "Dr. David Alan Gilbert" <dgilbert@redhat.com>
ddf19c
Date: Mon, 27 Jan 2020 19:00:49 +0100
ddf19c
Subject: [PATCH 018/116] virtiofsd: Fix fuse_daemonize ignored return values
ddf19c
MIME-Version: 1.0
ddf19c
Content-Type: text/plain; charset=UTF-8
ddf19c
Content-Transfer-Encoding: 8bit
ddf19c
ddf19c
RH-Author: Dr. David Alan Gilbert <dgilbert@redhat.com>
ddf19c
Message-id: <20200127190227.40942-15-dgilbert@redhat.com>
ddf19c
Patchwork-id: 93469
ddf19c
O-Subject: [RHEL-AV-8.2 qemu-kvm PATCH 014/112] virtiofsd: Fix fuse_daemonize ignored return values
ddf19c
Bugzilla: 1694164
ddf19c
RH-Acked-by: Philippe Mathieu-Daudé <philmd@redhat.com>
ddf19c
RH-Acked-by: Stefan Hajnoczi <stefanha@redhat.com>
ddf19c
RH-Acked-by: Sergio Lopez Pascual <slp@redhat.com>
ddf19c
ddf19c
From: "Dr. David Alan Gilbert" <dgilbert@redhat.com>
ddf19c
ddf19c
QEMU's compiler enables warnings/errors for ignored values
ddf19c
and the (void) trick used in the fuse code isn't enough.
ddf19c
Turn all the return values into a return value on the function.
ddf19c
ddf19c
Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
ddf19c
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
ddf19c
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
ddf19c
Tested-by: Philippe Mathieu-Daudé <philmd@redhat.com>
ddf19c
Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
ddf19c
(cherry picked from commit 30d8e49760712d65697ea517c53671bd1d214fc7)
ddf19c
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
ddf19c
---
ddf19c
 tools/virtiofsd/helper.c | 33 ++++++++++++++++++++++-----------
ddf19c
 1 file changed, 22 insertions(+), 11 deletions(-)
ddf19c
ddf19c
diff --git a/tools/virtiofsd/helper.c b/tools/virtiofsd/helper.c
ddf19c
index 5e6f205..d9227d7 100644
ddf19c
--- a/tools/virtiofsd/helper.c
ddf19c
+++ b/tools/virtiofsd/helper.c
ddf19c
@@ -10,12 +10,10 @@
ddf19c
  * See the file COPYING.LIB.
ddf19c
  */
ddf19c
 
ddf19c
-#include "config.h"
ddf19c
 #include "fuse_i.h"
ddf19c
 #include "fuse_lowlevel.h"
ddf19c
 #include "fuse_misc.h"
ddf19c
 #include "fuse_opt.h"
ddf19c
-#include "mount_util.h"
ddf19c
 
ddf19c
 #include <errno.h>
ddf19c
 #include <limits.h>
ddf19c
@@ -171,6 +169,7 @@ int fuse_parse_cmdline(struct fuse_args *args, struct fuse_cmdline_opts *opts)
ddf19c
 
ddf19c
 int fuse_daemonize(int foreground)
ddf19c
 {
ddf19c
+    int ret = 0, rett;
ddf19c
     if (!foreground) {
ddf19c
         int nullfd;
ddf19c
         int waiter[2];
ddf19c
@@ -192,8 +191,8 @@ int fuse_daemonize(int foreground)
ddf19c
         case 0:
ddf19c
             break;
ddf19c
         default:
ddf19c
-            (void)read(waiter[0], &completed, sizeof(completed));
ddf19c
-            _exit(0);
ddf19c
+            _exit(read(waiter[0], &completed,
ddf19c
+                       sizeof(completed) != sizeof(completed)));
ddf19c
         }
ddf19c
 
ddf19c
         if (setsid() == -1) {
ddf19c
@@ -201,13 +200,22 @@ int fuse_daemonize(int foreground)
ddf19c
             return -1;
ddf19c
         }
ddf19c
 
ddf19c
-        (void)chdir("/");
ddf19c
+        ret = chdir("/");
ddf19c
 
ddf19c
         nullfd = open("/dev/null", O_RDWR, 0);
ddf19c
         if (nullfd != -1) {
ddf19c
-            (void)dup2(nullfd, 0);
ddf19c
-            (void)dup2(nullfd, 1);
ddf19c
-            (void)dup2(nullfd, 2);
ddf19c
+            rett = dup2(nullfd, 0);
ddf19c
+            if (!ret) {
ddf19c
+                ret = rett;
ddf19c
+            }
ddf19c
+            rett = dup2(nullfd, 1);
ddf19c
+            if (!ret) {
ddf19c
+                ret = rett;
ddf19c
+            }
ddf19c
+            rett = dup2(nullfd, 2);
ddf19c
+            if (!ret) {
ddf19c
+                ret = rett;
ddf19c
+            }
ddf19c
             if (nullfd > 2) {
ddf19c
                 close(nullfd);
ddf19c
             }
ddf19c
@@ -215,13 +223,16 @@ int fuse_daemonize(int foreground)
ddf19c
 
ddf19c
         /* Propagate completion of daemon initialization */
ddf19c
         completed = 1;
ddf19c
-        (void)write(waiter[1], &completed, sizeof(completed));
ddf19c
+        rett = write(waiter[1], &completed, sizeof(completed));
ddf19c
+        if (!ret) {
ddf19c
+            ret = rett;
ddf19c
+        }
ddf19c
         close(waiter[0]);
ddf19c
         close(waiter[1]);
ddf19c
     } else {
ddf19c
-        (void)chdir("/");
ddf19c
+        ret = chdir("/");
ddf19c
     }
ddf19c
-    return 0;
ddf19c
+    return ret;
ddf19c
 }
ddf19c
 
ddf19c
 void fuse_apply_conn_info_opts(struct fuse_conn_info_opts *opts,
ddf19c
-- 
ddf19c
1.8.3.1
ddf19c