diff options
| author | Brandon Low <lostlogic@rockbox.org> | 2006-11-11 05:33:24 +0000 |
|---|---|---|
| committer | Brandon Low <lostlogic@rockbox.org> | 2006-11-11 05:33:24 +0000 |
| commit | 8a82892e52127f50efaafaeda3ae841e8bbefe2d (patch) | |
| tree | 1dfa1a18c05018045db4fe8e67d1dc3fbc5a2d72 /firmware/kernel.c | |
| parent | 806d8f3505ef7e477f9af4d1b07fe30cd1f28fb3 (diff) | |
| download | rockbox-8a82892e52127f50efaafaeda3ae841e8bbefe2d.zip rockbox-8a82892e52127f50efaafaeda3ae841e8bbefe2d.tar.gz rockbox-8a82892e52127f50efaafaeda3ae841e8bbefe2d.tar.bz2 rockbox-8a82892e52127f50efaafaeda3ae841e8bbefe2d.tar.xz | |
Thread API enhancements.
1) block_thread -> block_thread + block_thread_w_tmo -- this call was always used in distinct ways so having one call with a conditional was ugly.
2) enhance Slasheri's scheduler controlled boost concept. now any thread may trigger a boost which will last until that thread next sleeps.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@11509 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'firmware/kernel.c')
| -rw-r--r-- | firmware/kernel.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/firmware/kernel.c b/firmware/kernel.c index 959122e..79f26f5 100644 --- a/firmware/kernel.c +++ b/firmware/kernel.c @@ -132,7 +132,7 @@ void queue_wait(struct event_queue *q, struct event *ev) { if (q->read == q->write) { - block_thread(&q->thread, 0); + block_thread(&q->thread); } *ev = q->events[(q->read++) & QUEUE_LENGTH_MASK]; @@ -142,7 +142,7 @@ void queue_wait_w_tmo(struct event_queue *q, struct event *ev, int ticks) { if (q->read == q->write && ticks > 0) { - block_thread(&q->thread, ticks); + block_thread_w_tmo(&q->thread, ticks); } if (q->read != q->write) @@ -469,7 +469,7 @@ void mutex_lock(struct mutex *m) if (m->locked) { /* Wait until the lock is open... */ - block_thread(&m->thread, 0); + block_thread(&m->thread); } /* ...and lock it */ |