]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
timerfd: switch to CLASS(fd)
authorAl Viro <viro@zeniv.linux.org.uk>
Sat, 1 Jun 2024 01:39:04 +0000 (21:39 -0400)
committerAl Viro <viro@zeniv.linux.org.uk>
Sun, 3 Nov 2024 06:28:06 +0000 (01:28 -0500)
Fold timerfd_fget() into both callers to have fdget() and fdput() in
the same scope.  Could be done in different ways, but this is probably
the smallest solution.

Reviewed-by: Christian Brauner <brauner@kernel.org>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
fs/timerfd.c

index 137523e0bb211389888283b1a87c25c1aa4991ef..4c32244b05083ded00892da3fcd4334120c12fff 100644 (file)
@@ -394,19 +394,6 @@ static const struct file_operations timerfd_fops = {
        .unlocked_ioctl = timerfd_ioctl,
 };
 
-static int timerfd_fget(int fd, struct fd *p)
-{
-       struct fd f = fdget(fd);
-       if (!fd_file(f))
-               return -EBADF;
-       if (fd_file(f)->f_op != &timerfd_fops) {
-               fdput(f);
-               return -EINVAL;
-       }
-       *p = f;
-       return 0;
-}
-
 SYSCALL_DEFINE2(timerfd_create, int, clockid, int, flags)
 {
        int ufd;
@@ -471,7 +458,6 @@ static int do_timerfd_settime(int ufd, int flags,
                const struct itimerspec64 *new,
                struct itimerspec64 *old)
 {
-       struct fd f;
        struct timerfd_ctx *ctx;
        int ret;
 
@@ -479,15 +465,17 @@ static int do_timerfd_settime(int ufd, int flags,
                 !itimerspec64_valid(new))
                return -EINVAL;
 
-       ret = timerfd_fget(ufd, &f);
-       if (ret)
-               return ret;
+       CLASS(fd, f)(ufd);
+       if (fd_empty(f))
+               return -EBADF;
+
+       if (fd_file(f)->f_op != &timerfd_fops)
+               return -EINVAL;
+
        ctx = fd_file(f)->private_data;
 
-       if (isalarm(ctx) && !capable(CAP_WAKE_ALARM)) {
-               fdput(f);
+       if (isalarm(ctx) && !capable(CAP_WAKE_ALARM))
                return -EPERM;
-       }
 
        timerfd_setup_cancel(ctx, flags);
 
@@ -535,17 +523,18 @@ static int do_timerfd_settime(int ufd, int flags,
        ret = timerfd_setup(ctx, flags, new);
 
        spin_unlock_irq(&ctx->wqh.lock);
-       fdput(f);
        return ret;
 }
 
 static int do_timerfd_gettime(int ufd, struct itimerspec64 *t)
 {
-       struct fd f;
        struct timerfd_ctx *ctx;
-       int ret = timerfd_fget(ufd, &f);
-       if (ret)
-               return ret;
+       CLASS(fd, f)(ufd);
+
+       if (fd_empty(f))
+               return -EBADF;
+       if (fd_file(f)->f_op != &timerfd_fops)
+               return -EINVAL;
        ctx = fd_file(f)->private_data;
 
        spin_lock_irq(&ctx->wqh.lock);
@@ -567,7 +556,6 @@ static int do_timerfd_gettime(int ufd, struct itimerspec64 *t)
        t->it_value = ktime_to_timespec64(timerfd_get_remaining(ctx));
        t->it_interval = ktime_to_timespec64(ctx->tintv);
        spin_unlock_irq(&ctx->wqh.lock);
-       fdput(f);
        return 0;
 }