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>
}
struct lo_dirp {
- int fd;
DIR *dp;
struct dirent *entry;
off_t offset;
{
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;
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);