Commit e13a55b1 authored by Linus Torvalds's avatar Linus Torvalds

Fix posix timer direct user space access

This makes us do the proper copy_to_user() for the new
posix timers code.

Acked by Christoph Lameter <clameter@sgi.com>.
parent 4042fd20
...@@ -1326,12 +1326,8 @@ sys_clock_settime(clockid_t which_clock, const struct timespec __user *tp) ...@@ -1326,12 +1326,8 @@ sys_clock_settime(clockid_t which_clock, const struct timespec __user *tp)
return do_sys_settimeofday(&new_tp, NULL); return do_sys_settimeofday(&new_tp, NULL);
} }
asmlinkage long static int do_clock_gettime(clockid_t which_clock, struct timespec *tp)
sys_clock_gettime(clockid_t which_clock, struct timespec __user *tp)
{ {
struct timespec rtn_tp;
int error = 0;
/* Process process specific clocks */ /* Process process specific clocks */
if (which_clock < 0) { if (which_clock < 0) {
task_t *t; task_t *t;
...@@ -1359,9 +1355,17 @@ sys_clock_gettime(clockid_t which_clock, struct timespec __user *tp) ...@@ -1359,9 +1355,17 @@ sys_clock_gettime(clockid_t which_clock, struct timespec __user *tp)
!posix_clocks[which_clock].res) !posix_clocks[which_clock].res)
return -EINVAL; return -EINVAL;
error = do_posix_gettime(&posix_clocks[which_clock], &rtn_tp); return do_posix_gettime(&posix_clocks[which_clock], tp);
}
asmlinkage long
sys_clock_gettime(clockid_t which_clock, struct timespec __user *tp)
{
struct timespec kernel_tp;
int error;
if (!error && copy_to_user(tp, &rtn_tp, sizeof (rtn_tp))) error = do_clock_gettime(which_clock, &kernel_tp);
if (!error && copy_to_user(tp, &kernel_tp, sizeof (kernel_tp)))
error = -EFAULT; error = -EFAULT;
return error; return error;
......
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