Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 17595
b: refs/heads/master
c: 6ba1b91
h: refs/heads/master
i:
  17593: 23aef58
  17591: c7ee206
v: v3
  • Loading branch information
Thomas Gleixner authored and Linus Torvalds committed Jan 10, 2006
1 parent cf4baf0 commit 76c0774
Show file tree
Hide file tree
Showing 3 changed files with 15 additions and 57 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 10c94ec16dd187f8d8dfdbb088e98330c05bf03c
refs/heads/master: 6ba1b91213e81aa92b5cf7539f7d2a94ff54947c
14 changes: 14 additions & 0 deletions trunk/kernel/hrtimer.c
Original file line number Diff line number Diff line change
Expand Up @@ -707,6 +707,20 @@ long hrtimer_nanosleep(struct timespec *rqtp, struct timespec __user *rmtp,
return -ERESTART_RESTARTBLOCK;
}

asmlinkage long
sys_nanosleep(struct timespec __user *rqtp, struct timespec __user *rmtp)
{
struct timespec tu;

if (copy_from_user(&tu, rqtp, sizeof(tu)))
return -EFAULT;

if (!timespec_valid(&tu))
return -EINVAL;

return hrtimer_nanosleep(&tu, rmtp, HRTIMER_REL, CLOCK_MONOTONIC);
}

/*
* Functions related to boot-time initialization:
*/
Expand Down
56 changes: 0 additions & 56 deletions trunk/kernel/timer.c
Original file line number Diff line number Diff line change
Expand Up @@ -1120,62 +1120,6 @@ asmlinkage long sys_gettid(void)
return current->pid;
}

static long __sched nanosleep_restart(struct restart_block *restart)
{
unsigned long expire = restart->arg0, now = jiffies;
struct timespec __user *rmtp = (struct timespec __user *) restart->arg1;
long ret;

/* Did it expire while we handled signals? */
if (!time_after(expire, now))
return 0;

expire = schedule_timeout_interruptible(expire - now);

ret = 0;
if (expire) {
struct timespec t;
jiffies_to_timespec(expire, &t);

ret = -ERESTART_RESTARTBLOCK;
if (rmtp && copy_to_user(rmtp, &t, sizeof(t)))
ret = -EFAULT;
/* The 'restart' block is already filled in */
}
return ret;
}

asmlinkage long sys_nanosleep(struct timespec __user *rqtp, struct timespec __user *rmtp)
{
struct timespec t;
unsigned long expire;
long ret;

if (copy_from_user(&t, rqtp, sizeof(t)))
return -EFAULT;

if ((t.tv_nsec >= 1000000000L) || (t.tv_nsec < 0) || (t.tv_sec < 0))
return -EINVAL;

expire = timespec_to_jiffies(&t) + (t.tv_sec || t.tv_nsec);
expire = schedule_timeout_interruptible(expire);

ret = 0;
if (expire) {
struct restart_block *restart;
jiffies_to_timespec(expire, &t);
if (rmtp && copy_to_user(rmtp, &t, sizeof(t)))
return -EFAULT;

restart = &current_thread_info()->restart_block;
restart->fn = nanosleep_restart;
restart->arg0 = jiffies + expire;
restart->arg1 = (unsigned long) rmtp;
ret = -ERESTART_RESTARTBLOCK;
}
return ret;
}

/*
* sys_sysinfo - fill in sysinfo struct
*/
Expand Down

0 comments on commit 76c0774

Please sign in to comment.