diff options
author | gdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2009-09-06 08:52:46 +0000 |
---|---|---|
committer | gdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2009-09-06 08:52:46 +0000 |
commit | 5d2ad7ce56f9efaba58104c60690a0d076236004 (patch) | |
tree | 54209544b9df80c673d68c47c4a8768b416985d8 /os/kernel | |
parent | 9bf1ff3c8e6bb93f9c160c63c1a934244c864f9c (diff) | |
download | ChibiOS-5d2ad7ce56f9efaba58104c60690a0d076236004.tar.gz ChibiOS-5d2ad7ce56f9efaba58104c60690a0d076236004.tar.bz2 ChibiOS-5d2ad7ce56f9efaba58104c60690a0d076236004.zip |
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@1151 35acf78f-673a-0410-8e92-d51de3d6d3f4
Diffstat (limited to 'os/kernel')
-rw-r--r-- | os/kernel/include/scheduler.h | 3 | ||||
-rw-r--r-- | os/kernel/src/chschd.c | 55 | ||||
-rw-r--r-- | os/kernel/src/chthreads.c | 3 |
3 files changed, 54 insertions, 7 deletions
diff --git a/os/kernel/include/scheduler.h b/os/kernel/include/scheduler.h index 00294e190..8aa692e58 100644 --- a/os/kernel/include/scheduler.h +++ b/os/kernel/include/scheduler.h @@ -98,6 +98,9 @@ extern "C" { void chSchDoRescheduleI(void); void chSchRescheduleS(void); bool_t chSchRescRequiredI(void); +#if CH_USE_ROUNDROBIN + void chSchDoYieldS(void); +#endif #ifdef __cplusplus } #endif diff --git a/os/kernel/src/chschd.c b/os/kernel/src/chschd.c index 6183180bc..929f114e5 100644 --- a/os/kernel/src/chschd.c +++ b/os/kernel/src/chschd.c @@ -61,7 +61,7 @@ Thread *chSchReadyI(Thread *tp) { Thread *cp; tp->p_state = PRREADY; - cp = (Thread *)&rlist; + cp = (Thread *)&rlist.r_queue; do { cp = cp->p_next; } while (cp->p_prio >= tp->p_prio); @@ -71,6 +71,22 @@ Thread *chSchReadyI(Thread *tp) { return tp; } +#if 0 +INLINE Thread *chSchReadyReverseI(Thread *tp) { + Thread *cp; + + tp->p_state = PRREADY; + cp = (Thread *)&rlist.r_queue; + do { + cp = cp->p_prev; + } while ((cp->p_prio < tp->p_prio) && (cp->p_prio < tp->p_prio)); + /* Insertion on p_next.*/ + tp->p_next = (tp->p_prev = cp)->p_next; + tp->p_next->p_prev = cp->p_next = tp; + return tp; +} +#endif + /** * @brief Puts the current thread to sleep into the specified state. * @details The thread goes into a sleeping state. The @ref thread_states are @@ -109,7 +125,7 @@ static void wakeup(void *p) { #if CH_USE_CONDVARS case PRWTCOND: #endif - /* States requiring dequeuing. */ + /* States requiring dequeuing.*/ dequeue(tp); } #endif @@ -193,7 +209,7 @@ void chSchWakeupS(Thread *ntp, msg_t msg) { void chSchDoRescheduleI(void) { Thread *otp = currp; - /* pick the first thread from the ready queue and makes it current */ + /* Pick the first thread from the ready queue and makes it current.*/ (currp = fifo_remove(&rlist.r_queue))->p_state = PRCURR; chSchReadyI(otp); #if CH_USE_ROUNDROBIN @@ -209,8 +225,8 @@ void chSchDoRescheduleI(void) { * the ready list then make the higher priority thread running. */ void chSchRescheduleS(void) { - /* first thread in the runnable queue has higher priority than the running - * thread? */ + /* First thread in the runnable queue has higher priority than the running + * thread?.*/ if (chSchMustRescheduleS()) chSchDoRescheduleI(); } @@ -239,4 +255,33 @@ bool_t chSchRescRequiredI(void) { #endif } +#if CH_USE_ROUNDROBIN +void chSchDoYieldS(void) { + + if (chSchCanYieldS()) { + Thread *cp = (Thread *)&rlist.r_queue; + Thread *otp = currp; + + /* + * Note, the following insertion code works because we know that on the + * ready list there is at least one thread with priority equal or higher + * than the current one. + */ + otp->p_state = PRREADY; + do { + cp = cp->p_prev; + } while (cp->p_prio < otp->p_prio); + /* Insertion on p_next.*/ + otp->p_next = (otp->p_prev = cp)->p_next; + otp->p_next->p_prev = cp->p_next = otp; + + /* Pick the first thread from the ready queue and makes it current.*/ + (currp = fifo_remove(&rlist.r_queue))->p_state = PRCURR; + rlist.r_preempt = CH_TIME_QUANTUM; + chDbgTrace(otp, currp); + chSysSwitchI(otp, currp); + } +} +#endif /* CH_USE_ROUNDROBIN */ + /** @} */ diff --git a/os/kernel/src/chthreads.c b/os/kernel/src/chthreads.c index c18a4f8cd..a3028867a 100644 --- a/os/kernel/src/chthreads.c +++ b/os/kernel/src/chthreads.c @@ -299,8 +299,7 @@ void chThdSleepUntil(systime_t time) { void chThdYield(void) { chSysLock(); - if (chSchCanYieldS()) - chSchDoRescheduleI(); + chSchDoYieldS(); chSysUnlock(); } #endif /* CH_USE_ROUNDROBIN */ |