]> xenbits.xensource.com Git - qemu-xen.git/commitdiff
virtiofsd: fv_create_listen_socket error path socket leak
authorDr. David Alan Gilbert <dgilbert@redhat.com>
Fri, 31 Jan 2020 19:52:14 +0000 (19:52 +0000)
committerDr. David Alan Gilbert <dgilbert@redhat.com>
Mon, 10 Feb 2020 17:24:43 +0000 (17:24 +0000)
If we fail when bringing up the socket we can leak the listen_fd;
in practice the daemon will exit so it's not really a problem.

Fixes: Coverity CID 1413121
Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
tools/virtiofsd/fuse_virtio.c

index 80a6e929dfc3003b8479353401e4e6d8687ff015..dd1c605dbf63510f2bb335dd1ba2c91d877c53bd 100644 (file)
@@ -916,6 +916,7 @@ static int fv_create_listen_socket(struct fuse_session *se)
     old_umask = umask(0077);
     if (bind(listen_sock, (struct sockaddr *)&un, addr_len) == -1) {
         fuse_log(FUSE_LOG_ERR, "vhost socket bind: %m\n");
+        close(listen_sock);
         umask(old_umask);
         return -1;
     }
@@ -923,6 +924,7 @@ static int fv_create_listen_socket(struct fuse_session *se)
 
     if (listen(listen_sock, 1) == -1) {
         fuse_log(FUSE_LOG_ERR, "vhost socket listen: %m\n");
+        close(listen_sock);
         return -1;
     }