X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=bertos%2Fkern%2Fsem.c;h=ac4e7d969bb4afa5bd505a182a16a59b9a31372f;hb=bafb0b64bbebb8632d3aa4c1440c5e19c87a2d24;hp=0f31fa067b9fff651945b60076adaf3e855e05f4;hpb=791e167e053bdd9250d34a9a5ccae6ccde4d6679;p=bertos.git diff --git a/bertos/kern/sem.c b/bertos/kern/sem.c index 0f31fa06..ac4e7d96 100644 --- a/bertos/kern/sem.c +++ b/bertos/kern/sem.c @@ -27,22 +27,23 @@ * the GNU General Public License. * * Copyright 2001, 2004 Develer S.r.l. (http://www.develer.com/) - * Copyright 1999, 2000, 2001 Bernardo Innocenti - * + * Copyright 1999, 2000, 2001 Bernie Innocenti * --> * * \brief Semaphore based synchronization services. * * \version $Id$ - * - * \author Bernardo Innocenti + * \author Bernie Innocenti */ #include "sem.h" +#include + +#include // ASSERT_IRQ_DISABLED() + #include #include #include -#include INLINE void sem_verify(struct Semaphore *s) { @@ -53,7 +54,6 @@ INLINE void sem_verify(struct Semaphore *s) ASSERT(s->nest_count < 128); // heuristic max } - /** * \brief Initialize a Semaphore structure. */ @@ -128,7 +128,7 @@ void sem_obtain(struct Semaphore *s) * be locked for us. */ proc_permit(); - proc_schedule(); + proc_switch(); } else { @@ -178,7 +178,7 @@ void sem_release(struct Semaphore *s) { s->nest_count = 1; s->owner = proc; - SCHED_ENQUEUE(proc); + ATOMIC(SCHED_ENQUEUE(proc)); } }