aboutsummaryrefslogtreecommitdiffstats
path: root/os/kernel/src
diff options
context:
space:
mode:
authorgdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4>2009-09-05 15:31:27 +0000
committergdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4>2009-09-05 15:31:27 +0000
commit7dfa36f86d896cdb824a9137a81f324c8243c4d9 (patch)
tree5b83e2db6919eaeaf8705830adea1939885b310a /os/kernel/src
parent3ee19d119a4a960a6bed887a1be775e7e7fd55cb (diff)
downloadChibiOS-7dfa36f86d896cdb824a9137a81f324c8243c4d9.tar.gz
ChibiOS-7dfa36f86d896cdb824a9137a81f324c8243c4d9.tar.bz2
ChibiOS-7dfa36f86d896cdb824a9137a81f324c8243c4d9.zip
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@1148 35acf78f-673a-0410-8e92-d51de3d6d3f4
Diffstat (limited to 'os/kernel/src')
-rw-r--r--os/kernel/src/chschd.c2
-rw-r--r--os/kernel/src/chthreads.c15
2 files changed, 16 insertions, 1 deletions
diff --git a/os/kernel/src/chschd.c b/os/kernel/src/chschd.c
index af24f5cf4..6183180bc 100644
--- a/os/kernel/src/chschd.c
+++ b/os/kernel/src/chschd.c
@@ -211,7 +211,7 @@ void chSchDoRescheduleI(void) {
void chSchRescheduleS(void) {
/* first thread in the runnable queue has higher priority than the running
* thread? */
- if (firstprio(&rlist.r_queue) > currp->p_prio)
+ if (chSchMustRescheduleS())
chSchDoRescheduleI();
}
diff --git a/os/kernel/src/chthreads.c b/os/kernel/src/chthreads.c
index 583bc7c04..c18a4f8cd 100644
--- a/os/kernel/src/chthreads.c
+++ b/os/kernel/src/chthreads.c
@@ -290,6 +290,21 @@ void chThdSleepUntil(systime_t time) {
chSysUnlock();
}
+#if CH_USE_ROUNDROBIN
+/**
+ * @brief Yields the time slot.
+ * @details Yields the CPU control to the next thread in the ready list with
+ * equal priority, if any.
+ */
+void chThdYield(void) {
+
+ chSysLock();
+ if (chSchCanYieldS())
+ chSchDoRescheduleI();
+ chSysUnlock();
+}
+#endif /* CH_USE_ROUNDROBIN */
+
/**
* @brief Terminates the current thread by specifying an exit status code.
*