diff options
author | dchagin <dchagin@FreeBSD.org> | 2016-01-09 14:40:38 +0000 |
---|---|---|
committer | dchagin <dchagin@FreeBSD.org> | 2016-01-09 14:40:38 +0000 |
commit | fd9d33be2a51f313e557a77d61add75b4a80bedc (patch) | |
tree | 0b16992f86d0d5aae92d3865a01553fe6fe2609c /sys/kern | |
parent | a07a85c065f084d084b8a1a0d5a42e79c99962e6 (diff) | |
download | FreeBSD-src-fd9d33be2a51f313e557a77d61add75b4a80bedc.zip FreeBSD-src-fd9d33be2a51f313e557a77d61add75b4a80bedc.tar.gz |
MFC r283374:
In preparation for switching linuxulator to the use the native 1:1
threads refactor kern_sched_rr_get_interval() and sys_sched_rr_get_interval().
Add a kern_sched_rr_get_interval() counterpart which takes a targettd
parameter to allow specify target thread directly by callee (new Linuxulator).
Linuxulator temporarily uses first thread in proc.
Move linux_sched_rr_get_interval() to the MI part.
Diffstat (limited to 'sys/kern')
-rw-r--r-- | sys/kern/p1003_1b.c | 19 |
1 files changed, 16 insertions, 3 deletions
diff --git a/sys/kern/p1003_1b.c b/sys/kern/p1003_1b.c index fb89efc..3d1656a 100644 --- a/sys/kern/p1003_1b.c +++ b/sys/kern/p1003_1b.c @@ -296,13 +296,26 @@ kern_sched_rr_get_interval(struct thread *td, pid_t pid, targettd = FIRST_THREAD_IN_PROC(targetp); } - e = p_cansee(td, targetp); - if (e == 0) - e = ksched_rr_get_interval(ksched, targettd, ts); + e = kern_sched_rr_get_interval_td(td, targettd, ts); PROC_UNLOCK(targetp); return (e); } +int +kern_sched_rr_get_interval_td(struct thread *td, struct thread *targettd, + struct timespec *ts) +{ + struct proc *p; + int error; + + p = targettd->td_proc; + PROC_LOCK_ASSERT(p, MA_OWNED); + + error = p_cansee(td, p); + if (error == 0) + error = ksched_rr_get_interval(ksched, targettd, ts); + return (error); +} #endif static void |