summaryrefslogtreecommitdiffstats
path: root/sys/kern
diff options
context:
space:
mode:
authordchagin <dchagin@FreeBSD.org>2016-01-09 14:40:38 +0000
committerdchagin <dchagin@FreeBSD.org>2016-01-09 14:40:38 +0000
commitfd9d33be2a51f313e557a77d61add75b4a80bedc (patch)
tree0b16992f86d0d5aae92d3865a01553fe6fe2609c /sys/kern
parenta07a85c065f084d084b8a1a0d5a42e79c99962e6 (diff)
downloadFreeBSD-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.c19
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
OpenPOWER on IntegriCloud