aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/posix-timers.c
diff options
context:
space:
mode:
Diffstat (limited to 'kernel/posix-timers.c')
-rw-r--r--kernel/posix-timers.c30
1 files changed, 30 insertions, 0 deletions
diff --git a/kernel/posix-timers.c b/kernel/posix-timers.c
index a3fdfd4be0ec..5a5a4f1c0971 100644
--- a/kernel/posix-timers.c
+++ b/kernel/posix-timers.c
@@ -170,6 +170,12 @@ static int posix_clock_realtime_set(const clockid_t which_clock,
170 return do_sys_settimeofday(tp, NULL); 170 return do_sys_settimeofday(tp, NULL);
171} 171}
172 172
173static int posix_clock_realtime_adj(const clockid_t which_clock,
174 struct timex *t)
175{
176 return do_adjtimex(t);
177}
178
173/* 179/*
174 * Get monotonic time for posix timers 180 * Get monotonic time for posix timers
175 */ 181 */
@@ -216,6 +222,7 @@ static __init int init_posix_timers(void)
216 .clock_getres = hrtimer_get_res, 222 .clock_getres = hrtimer_get_res,
217 .clock_get = posix_clock_realtime_get, 223 .clock_get = posix_clock_realtime_get,
218 .clock_set = posix_clock_realtime_set, 224 .clock_set = posix_clock_realtime_set,
225 .clock_adj = posix_clock_realtime_adj,
219 .nsleep = common_nsleep, 226 .nsleep = common_nsleep,
220 .nsleep_restart = hrtimer_nanosleep_restart, 227 .nsleep_restart = hrtimer_nanosleep_restart,
221 .timer_create = common_timer_create, 228 .timer_create = common_timer_create,
@@ -948,6 +955,29 @@ SYSCALL_DEFINE2(clock_gettime, const clockid_t, which_clock,
948 return error; 955 return error;
949} 956}
950 957
958SYSCALL_DEFINE2(clock_adjtime, const clockid_t, which_clock,
959 struct timex __user *, utx)
960{
961 struct k_clock *kc = clockid_to_kclock(which_clock);
962 struct timex ktx;
963 int err;
964
965 if (!kc)
966 return -EINVAL;
967 if (!kc->clock_adj)
968 return -EOPNOTSUPP;
969
970 if (copy_from_user(&ktx, utx, sizeof(ktx)))
971 return -EFAULT;
972
973 err = kc->clock_adj(which_clock, &ktx);
974
975 if (!err && copy_to_user(utx, &ktx, sizeof(ktx)))
976 return -EFAULT;
977
978 return err;
979}
980
951SYSCALL_DEFINE2(clock_getres, const clockid_t, which_clock, 981SYSCALL_DEFINE2(clock_getres, const clockid_t, which_clock,
952 struct timespec __user *, tp) 982 struct timespec __user *, tp)
953{ 983{