Commit e6071b18 authored by Arnd Bergmann's avatar Arnd Bergmann

y2038: vdso: nds32: open-code timespec_add_ns()

The nds32 vdso is now the last user of the deprecated timespec_add_ns().

Change it to an open-coded version like the one it already uses in
do_realtime(). What we should really do though is to use the
generic vdso implementation that is now used in x86. arm and mips.
Signed-off-by: default avatarArnd Bergmann <arnd@arndb.de>
parent 21346564
...@@ -81,22 +81,20 @@ static notrace int do_realtime_coarse(struct __kernel_old_timespec *ts, ...@@ -81,22 +81,20 @@ static notrace int do_realtime_coarse(struct __kernel_old_timespec *ts,
static notrace int do_monotonic_coarse(struct __kernel_old_timespec *ts, static notrace int do_monotonic_coarse(struct __kernel_old_timespec *ts,
struct vdso_data *vdata) struct vdso_data *vdata)
{ {
struct timespec tomono;
u32 seq; u32 seq;
u64 ns;
do { do {
seq = vdso_read_begin(vdata); seq = vdso_read_begin(vdata);
ts->tv_sec = vdata->xtime_coarse_sec; ts->tv_sec = vdata->xtime_coarse_sec + vdata->wtm_clock_sec;
ts->tv_nsec = vdata->xtime_coarse_nsec; ns = vdata->xtime_coarse_nsec + vdata->wtm_clock_nsec;
tomono.tv_sec = vdata->wtm_clock_sec;
tomono.tv_nsec = vdata->wtm_clock_nsec;
} while (vdso_read_retry(vdata, seq)); } while (vdso_read_retry(vdata, seq));
ts->tv_sec += tomono.tv_sec; ts->tv_sec += __iter_div_u64_rem(ns, NSEC_PER_SEC, &ns);
timespec_add_ns(ts, tomono.tv_nsec); ts->tv_nsec = ns;
return 0; return 0;
} }
...@@ -135,26 +133,25 @@ static notrace int do_realtime(struct __kernel_old_timespec *ts, struct vdso_dat ...@@ -135,26 +133,25 @@ static notrace int do_realtime(struct __kernel_old_timespec *ts, struct vdso_dat
static notrace int do_monotonic(struct __kernel_old_timespec *ts, struct vdso_data *vdata) static notrace int do_monotonic(struct __kernel_old_timespec *ts, struct vdso_data *vdata)
{ {
struct timespec tomono; u64 ns;
u64 nsecs;
u32 seq; u32 seq;
do { do {
seq = vdso_read_begin(vdata); seq = vdso_read_begin(vdata);
ts->tv_sec = vdata->xtime_clock_sec; ts->tv_sec = vdata->xtime_clock_sec;
nsecs = vdata->xtime_clock_nsec; ns = vdata->xtime_clock_nsec;
nsecs += vgetsns(vdata); ns += vgetsns(vdata);
nsecs >>= vdata->cs_shift; ns >>= vdata->cs_shift;
tomono.tv_sec = vdata->wtm_clock_sec; ts->tv_sec += vdata->wtm_clock_sec;
tomono.tv_nsec = vdata->wtm_clock_nsec; ns += vdata->wtm_clock_nsec;
} while (vdso_read_retry(vdata, seq)); } while (vdso_read_retry(vdata, seq));
ts->tv_sec += tomono.tv_sec; ts->tv_sec += __iter_div_u64_rem(ns, NSEC_PER_SEC, &ns);
ts->tv_nsec = 0; ts->tv_nsec = ns;
timespec_add_ns(ts, nsecs + tomono.tv_nsec);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment