IB/uverbs: Use get_unused_fd_flags(O_CLOEXEC) instead of get_unused_fd()
authorRoland Dreier <roland@purestorage.com>
Mon, 8 Jul 2013 18:15:45 +0000 (11:15 -0700)
committerRoland Dreier <roland@purestorage.com>
Mon, 8 Jul 2013 18:15:45 +0000 (11:15 -0700)
The macro get_unused_fd() is used to allocate a file descriptor with
default flags.  Those default flags (0) can be "unsafe": O_CLOEXEC must
be used by default to not leak file descriptor across exec().

Replace calls to get_unused_fd() in uverbs with calls to
get_unused_fd_flags(O_CLOEXEC).  Inheriting uverbs fds across exec()
cannot be used to do anything useful.

Based on a patch/suggestion from Yann Droneaud <ydroneaud@opteya.com>.

Signed-off-by: Roland Dreier <roland@purestorage.com>
drivers/infiniband/core/uverbs_cmd.c

index a7d00f6b3bc1c8b2c2ac5cfab340adebd375e7cb..b3c07b0c9f2655bb13b9fb81c6ef38fc2efd8757 100644 (file)
@@ -334,7 +334,7 @@ ssize_t ib_uverbs_get_context(struct ib_uverbs_file *file,
 
        resp.num_comp_vectors = file->device->num_comp_vectors;
 
-       ret = get_unused_fd();
+       ret = get_unused_fd_flags(O_CLOEXEC);
        if (ret < 0)
                goto err_free;
        resp.async_fd = ret;
@@ -1184,7 +1184,7 @@ ssize_t ib_uverbs_create_comp_channel(struct ib_uverbs_file *file,
        if (copy_from_user(&cmd, buf, sizeof cmd))
                return -EFAULT;
 
-       ret = get_unused_fd();
+       ret = get_unused_fd_flags(O_CLOEXEC);
        if (ret < 0)
                return ret;
        resp.fd = ret;