mirror of
https://github.com/torvalds/linux.git
synced 2024-11-23 20:51:44 +00:00
ptp: use the 64 bit get/set time methods for the posix clock.
This patch changes the posix clock code to prefer the new methods whenever they are implemented by the PHC drivers. Signed-off-by: Richard Cochran <richardcochran@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
e13cfcb03e
commit
d7d38f5bd7
@ -107,13 +107,28 @@ static int ptp_clock_getres(struct posix_clock *pc, struct timespec *tp)
|
||||
static int ptp_clock_settime(struct posix_clock *pc, const struct timespec *tp)
|
||||
{
|
||||
struct ptp_clock *ptp = container_of(pc, struct ptp_clock, clock);
|
||||
return ptp->info->settime(ptp->info, tp);
|
||||
struct timespec64 ts = timespec_to_timespec64(*tp);
|
||||
|
||||
return ptp->info->settime64 ?
|
||||
ptp->info->settime64(ptp->info, &ts) :
|
||||
ptp->info->settime(ptp->info, tp);
|
||||
}
|
||||
|
||||
static int ptp_clock_gettime(struct posix_clock *pc, struct timespec *tp)
|
||||
{
|
||||
struct ptp_clock *ptp = container_of(pc, struct ptp_clock, clock);
|
||||
return ptp->info->gettime(ptp->info, tp);
|
||||
struct timespec64 ts;
|
||||
int err;
|
||||
|
||||
if (ptp->info->gettime64) {
|
||||
err = ptp->info->gettime64(ptp->info, &ts);
|
||||
if (!err)
|
||||
*tp = timespec64_to_timespec(ts);
|
||||
} else {
|
||||
err = ptp->info->gettime(ptp->info, tp);
|
||||
}
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
static int ptp_clock_adjtime(struct posix_clock *pc, struct timex *tx)
|
||||
|
Loading…
Reference in New Issue
Block a user