]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
ptp: Split out PTP_SYS_OFFSET ioctl code
authorThomas Gleixner <tglx@linutronix.de>
Wed, 25 Jun 2025 11:52:31 +0000 (13:52 +0200)
committerJakub Kicinski <kuba@kernel.org>
Fri, 27 Jun 2025 00:54:05 +0000 (17:54 -0700)
Continue the ptp_ioctl() cleanup by splitting out the PTP_SYS_OFFSET ioctl
code into a helper function.

Convert it to __free() to avoid gotos.

No functional change intended.

Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Link: https://patch.msgid.link/20250625115133.113841216@linutronix.de
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/ptp/ptp_chardev.c

index 3e07b6d96536c113a476b33ae8508306c7081fed..d0a621c603a30fe17b4f85a38be84ac3a786cbe8 100644 (file)
@@ -356,18 +356,54 @@ static long ptp_sys_offset_extended(struct ptp_clock *ptp, void __user *arg)
        return copy_to_user(arg, extoff, sizeof(*extoff)) ? -EFAULT : 0;
 }
 
+static long ptp_sys_offset(struct ptp_clock *ptp, void __user *arg)
+{
+       struct ptp_sys_offset *sysoff __free(kfree) = NULL;
+       struct ptp_clock_time *pct;
+       struct timespec64 ts;
+
+       sysoff = memdup_user(arg, sizeof(*sysoff));
+       if (IS_ERR(sysoff))
+               return PTR_ERR(sysoff);
+
+       if (sysoff->n_samples > PTP_MAX_SAMPLES)
+               return -EINVAL;
+
+       pct = &sysoff->ts[0];
+       for (unsigned int i = 0; i < sysoff->n_samples; i++) {
+               struct ptp_clock_info *ops = ptp->info;
+               int err;
+
+               ktime_get_real_ts64(&ts);
+               pct->sec = ts.tv_sec;
+               pct->nsec = ts.tv_nsec;
+               pct++;
+               if (ops->gettimex64)
+                       err = ops->gettimex64(ops, &ts, NULL);
+               else
+                       err = ops->gettime64(ops, &ts);
+               if (err)
+                       return err;
+               pct->sec = ts.tv_sec;
+               pct->nsec = ts.tv_nsec;
+               pct++;
+       }
+       ktime_get_real_ts64(&ts);
+       pct->sec = ts.tv_sec;
+       pct->nsec = ts.tv_nsec;
+
+       return copy_to_user(arg, sysoff, sizeof(*sysoff)) ? -EFAULT : 0;
+}
+
 long ptp_ioctl(struct posix_clock_context *pccontext, unsigned int cmd,
               unsigned long arg)
 {
        struct ptp_clock *ptp =
                container_of(pccontext->clk, struct ptp_clock, clock);
        struct ptp_clock_info *ops = ptp->info;
-       struct ptp_sys_offset *sysoff = NULL;
        struct timestamp_event_queue *tsevq;
-       struct ptp_clock_time *pct;
        unsigned int i, pin_index;
        struct ptp_pin_desc pd;
-       struct timespec64 ts;
        void __user *argptr;
        int err = 0;
 
@@ -410,38 +446,7 @@ long ptp_ioctl(struct posix_clock_context *pccontext, unsigned int cmd,
 
        case PTP_SYS_OFFSET:
        case PTP_SYS_OFFSET2:
-               sysoff = memdup_user((void __user *)arg, sizeof(*sysoff));
-               if (IS_ERR(sysoff)) {
-                       err = PTR_ERR(sysoff);
-                       sysoff = NULL;
-                       break;
-               }
-               if (sysoff->n_samples > PTP_MAX_SAMPLES) {
-                       err = -EINVAL;
-                       break;
-               }
-               pct = &sysoff->ts[0];
-               for (i = 0; i < sysoff->n_samples; i++) {
-                       ktime_get_real_ts64(&ts);
-                       pct->sec = ts.tv_sec;
-                       pct->nsec = ts.tv_nsec;
-                       pct++;
-                       if (ops->gettimex64)
-                               err = ops->gettimex64(ops, &ts, NULL);
-                       else
-                               err = ops->gettime64(ops, &ts);
-                       if (err)
-                               goto out;
-                       pct->sec = ts.tv_sec;
-                       pct->nsec = ts.tv_nsec;
-                       pct++;
-               }
-               ktime_get_real_ts64(&ts);
-               pct->sec = ts.tv_sec;
-               pct->nsec = ts.tv_nsec;
-               if (copy_to_user((void __user *)arg, sysoff, sizeof(*sysoff)))
-                       err = -EFAULT;
-               break;
+               return ptp_sys_offset(ptp, argptr);
 
        case PTP_PIN_GETFUNC:
        case PTP_PIN_GETFUNC2:
@@ -529,9 +534,6 @@ long ptp_ioctl(struct posix_clock_context *pccontext, unsigned int cmd,
                err = -ENOTTY;
                break;
        }
-
-out:
-       kfree(sysoff);
        return err;
 }