diff options
author | jhb <jhb@FreeBSD.org> | 2005-03-31 22:54:48 +0000 |
---|---|---|
committer | jhb <jhb@FreeBSD.org> | 2005-03-31 22:54:48 +0000 |
commit | 76cb101294622496d32b4a3b91c71aa3fb9e5e01 (patch) | |
tree | c2019acfbd7ad2f4c43cfb8500fe17cc04f28d45 /sys/posix4 | |
parent | 7df6205a90101feffc3df4a79dcc125713355c92 (diff) | |
download | FreeBSD-src-76cb101294622496d32b4a3b91c71aa3fb9e5e01.zip FreeBSD-src-76cb101294622496d32b4a3b91c71aa3fb9e5e01.tar.gz |
Actually commit the code for kern_sched_get_rr_interval().
Diffstat (limited to 'sys/posix4')
-rw-r--r-- | sys/posix4/p1003_1b.c | 33 |
1 files changed, 20 insertions, 13 deletions
diff --git a/sys/posix4/p1003_1b.c b/sys/posix4/p1003_1b.c index 35d1bca..7f366f1 100644 --- a/sys/posix4/p1003_1b.c +++ b/sys/posix4/p1003_1b.c @@ -45,6 +45,7 @@ __FBSDID("$FreeBSD$"); #include <sys/module.h> #include <sys/mutex.h> #include <sys/proc.h> +#include <sys/syscallsubr.h> #include <sys/sysctl.h> #include <sys/sysent.h> #include <sys/syslog.h> @@ -305,35 +306,41 @@ int sched_get_priority_min(struct thread *td, int sched_rr_get_interval(struct thread *td, struct sched_rr_get_interval_args *uap) { + struct timespec timespec; + int error; + + error = kern_sched_rr_get_interval(td, uap->pid, ×pec); + if (error == 0) + error = copyout(×pec, uap->interval, sizeof(timespec)); + return (error); +} + +int kern_sched_rr_get_interval(struct thread *td, pid_t pid, + struct timespec *ts) +{ int e; struct thread *targettd; - struct timespec timespec; struct proc *targetp; mtx_lock(&Giant); - if (uap->pid == 0) { + if (pid == 0) { targettd = td; targetp = td->td_proc; PROC_LOCK(targetp); } else { - targetp = pfind(uap->pid); + targetp = pfind(pid); if (targetp == NULL) { - e = ESRCH; - goto done2; + mtx_unlock(&Giant); + return (ESRCH); } targettd = FIRST_THREAD_IN_PROC(targetp); /* XXXKSE */ } e = p_cansee(td, targetp); - PROC_UNLOCK(targetp); - if (e == 0) { + if (e == 0) e = ksched_rr_get_interval(&td->td_retval[0], ksched, targettd, - ×pec); - if (e == 0) - e = copyout(×pec, uap->interval, - sizeof(timespec)); - } -done2: + ts); + PROC_UNLOCK(targetp); mtx_unlock(&Giant); return (e); } |