diff options
author | Kees Cook <keescook@chromium.org> | 2020-06-10 01:21:38 +0200 |
---|---|---|
committer | Kees Cook <keescook@chromium.org> | 2020-07-13 20:03:45 +0200 |
commit | 910d2f16ac90463a1f5b03d53246c443e2b354b9 (patch) | |
tree | 41a2a88d4cd7dd1de2ce8221d2dc7c2cc96e773e /kernel/pid.c | |
parent | fs: Add receive_fd() wrapper for __receive_fd() (diff) | |
download | linux-910d2f16ac90463a1f5b03d53246c443e2b354b9.tar.xz linux-910d2f16ac90463a1f5b03d53246c443e2b354b9.zip |
pidfd: Replace open-coded receive_fd()
Replace the open-coded version of receive_fd() with a call to the
new helper.
Thanks to Vamshi K Sthambamkadi <vamshi.k.sthambamkadi@gmail.com> for
catching a missed fput() in an earlier version of this patch.
Cc: Christoph Hellwig <hch@lst.de>
Cc: Jakub Kicinski <kuba@kernel.org>
Cc: netdev@vger.kernel.org
Cc: linux-kernel@vger.kernel.org
Reviewed-by: Sargun Dhillon <sargun@sargun.me>
Acked-by: Christian Brauner <christian.brauner@ubuntu.com>
Signed-off-by: Kees Cook <keescook@chromium.org>
Diffstat (limited to 'kernel/pid.c')
-rw-r--r-- | kernel/pid.c | 15 |
1 files changed, 2 insertions, 13 deletions
diff --git a/kernel/pid.c b/kernel/pid.c index ee58530d1aca..da5aea5f04fa 100644 --- a/kernel/pid.c +++ b/kernel/pid.c @@ -636,19 +636,8 @@ static int pidfd_getfd(struct pid *pid, int fd) if (IS_ERR(file)) return PTR_ERR(file); - ret = security_file_receive(file); - if (ret) { - fput(file); - return ret; - } - - ret = get_unused_fd_flags(O_CLOEXEC); - if (ret < 0) { - fput(file); - } else { - __receive_sock(file); - fd_install(ret, file); - } + ret = receive_fd(file, O_CLOEXEC); + fput(file); return ret; } |