Skip to content

Commit 4b676af

Browse files
KAGA-KOKOkuba-moo
authored andcommitted
ptp: Split out PTP_SYS_OFFSET ioctl code
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 <[email protected]> Link: https://patch.msgid.link/[email protected] Signed-off-by: Jakub Kicinski <[email protected]>
1 parent 37e42f8 commit 4b676af

File tree

1 file changed

+40
-38
lines changed

1 file changed

+40
-38
lines changed

drivers/ptp/ptp_chardev.c

Lines changed: 40 additions & 38 deletions
Original file line numberDiff line numberDiff line change
@@ -356,18 +356,54 @@ static long ptp_sys_offset_extended(struct ptp_clock *ptp, void __user *arg)
356356
return copy_to_user(arg, extoff, sizeof(*extoff)) ? -EFAULT : 0;
357357
}
358358

359+
static long ptp_sys_offset(struct ptp_clock *ptp, void __user *arg)
360+
{
361+
struct ptp_sys_offset *sysoff __free(kfree) = NULL;
362+
struct ptp_clock_time *pct;
363+
struct timespec64 ts;
364+
365+
sysoff = memdup_user(arg, sizeof(*sysoff));
366+
if (IS_ERR(sysoff))
367+
return PTR_ERR(sysoff);
368+
369+
if (sysoff->n_samples > PTP_MAX_SAMPLES)
370+
return -EINVAL;
371+
372+
pct = &sysoff->ts[0];
373+
for (unsigned int i = 0; i < sysoff->n_samples; i++) {
374+
struct ptp_clock_info *ops = ptp->info;
375+
int err;
376+
377+
ktime_get_real_ts64(&ts);
378+
pct->sec = ts.tv_sec;
379+
pct->nsec = ts.tv_nsec;
380+
pct++;
381+
if (ops->gettimex64)
382+
err = ops->gettimex64(ops, &ts, NULL);
383+
else
384+
err = ops->gettime64(ops, &ts);
385+
if (err)
386+
return err;
387+
pct->sec = ts.tv_sec;
388+
pct->nsec = ts.tv_nsec;
389+
pct++;
390+
}
391+
ktime_get_real_ts64(&ts);
392+
pct->sec = ts.tv_sec;
393+
pct->nsec = ts.tv_nsec;
394+
395+
return copy_to_user(arg, sysoff, sizeof(*sysoff)) ? -EFAULT : 0;
396+
}
397+
359398
long ptp_ioctl(struct posix_clock_context *pccontext, unsigned int cmd,
360399
unsigned long arg)
361400
{
362401
struct ptp_clock *ptp =
363402
container_of(pccontext->clk, struct ptp_clock, clock);
364403
struct ptp_clock_info *ops = ptp->info;
365-
struct ptp_sys_offset *sysoff = NULL;
366404
struct timestamp_event_queue *tsevq;
367-
struct ptp_clock_time *pct;
368405
unsigned int i, pin_index;
369406
struct ptp_pin_desc pd;
370-
struct timespec64 ts;
371407
void __user *argptr;
372408
int err = 0;
373409

@@ -410,38 +446,7 @@ long ptp_ioctl(struct posix_clock_context *pccontext, unsigned int cmd,
410446

411447
case PTP_SYS_OFFSET:
412448
case PTP_SYS_OFFSET2:
413-
sysoff = memdup_user((void __user *)arg, sizeof(*sysoff));
414-
if (IS_ERR(sysoff)) {
415-
err = PTR_ERR(sysoff);
416-
sysoff = NULL;
417-
break;
418-
}
419-
if (sysoff->n_samples > PTP_MAX_SAMPLES) {
420-
err = -EINVAL;
421-
break;
422-
}
423-
pct = &sysoff->ts[0];
424-
for (i = 0; i < sysoff->n_samples; i++) {
425-
ktime_get_real_ts64(&ts);
426-
pct->sec = ts.tv_sec;
427-
pct->nsec = ts.tv_nsec;
428-
pct++;
429-
if (ops->gettimex64)
430-
err = ops->gettimex64(ops, &ts, NULL);
431-
else
432-
err = ops->gettime64(ops, &ts);
433-
if (err)
434-
goto out;
435-
pct->sec = ts.tv_sec;
436-
pct->nsec = ts.tv_nsec;
437-
pct++;
438-
}
439-
ktime_get_real_ts64(&ts);
440-
pct->sec = ts.tv_sec;
441-
pct->nsec = ts.tv_nsec;
442-
if (copy_to_user((void __user *)arg, sysoff, sizeof(*sysoff)))
443-
err = -EFAULT;
444-
break;
449+
return ptp_sys_offset(ptp, argptr);
445450

446451
case PTP_PIN_GETFUNC:
447452
case PTP_PIN_GETFUNC2:
@@ -529,9 +534,6 @@ long ptp_ioctl(struct posix_clock_context *pccontext, unsigned int cmd,
529534
err = -ENOTTY;
530535
break;
531536
}
532-
533-
out:
534-
kfree(sysoff);
535537
return err;
536538
}
537539

0 commit comments

Comments
 (0)