passthrough_ll: drop lo_dirp->fd field (#464)
authorStefan Hajnoczi <stefanha@gmail.com>
Sun, 3 Nov 2019 09:43:43 +0000 (10:43 +0100)
committerNikolaus Rath <Nikolaus@rath.org>
Sun, 3 Nov 2019 09:43:43 +0000 (09:43 +0000)
fdopendir(3) takes ownership of the file descriptor.  The presence of
the lo_dirp->fd field could lead to someone incorrectly adding a
close(d->fd) cleanup call in the future.

Do not store the file descriptor in struct lo_dirp since it is unused.

Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Reviewed-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
example/passthrough_ll.c

index 4e3760294addde540d141570cc0414d3e75de304..0f1fda594324700afd2ca93018311d8af674078f 100644 (file)
@@ -596,7 +596,6 @@ static void lo_readlink(fuse_req_t req, fuse_ino_t ino)
 }
 
 struct lo_dirp {
-       int fd;
        DIR *dp;
        struct dirent *entry;
        off_t offset;
@@ -611,15 +610,18 @@ static void lo_opendir(fuse_req_t req, fuse_ino_t ino, struct fuse_file_info *fi
 {
        int error = ENOMEM;
        struct lo_data *lo = lo_data(req);
-       struct lo_dirp *d = calloc(1, sizeof(struct lo_dirp));
+       struct lo_dirp *d;
+       int fd;
+
+       d = calloc(1, sizeof(struct lo_dirp));
        if (d == NULL)
                goto out_err;
 
-       d->fd = openat(lo_fd(req, ino), ".", O_RDONLY);
-       if (d->fd == -1)
+       fd = openat(lo_fd(req, ino), ".", O_RDONLY);
+       if (fd == -1)
                goto out_errno;
 
-       d->dp = fdopendir(d->fd);
+       d->dp = fdopendir(fd);
        if (d->dp == NULL)
                goto out_errno;
 
@@ -636,8 +638,8 @@ out_errno:
        error = errno;
 out_err:
        if (d) {
-               if (d->fd != -1)
-                       close(d->fd);
+               if (fd != -1)
+                       close(fd);
                free(d);
        }
        fuse_reply_err(req, error);