#include <config.h>
#include <sys/tm.h>
#include <atomic.h>
Go to the source code of this file.
Defines | |
#define | __critsec_h__ |
#define | locked_decrement(counter) atomic_dec(counter) |
don't use locked_decrement anymore but atomic_dec() | |
#define | initialize_critical_section(cs) (cs)->count=0 |
initialize critical section | |
#define | leave_critical_section(cs) atomic_dec(&(cs)->count) |
leave critical section | |
#define | destroy_critical_section(cs) |
destroy critical section (does nothing) | |
Typedefs | |
typedef struct critsec | critsec_t |
critical section type definition | |
Functions | |
wakeup_t | wait_critical_section (wakeup_t data) |
wakeup when critical section is available | |
int | enter_critical_section (critsec_t *cs) |
enter critical section |
Defines types and functions to implement critical sections.
Definition in file critsec.h.
#define destroy_critical_section | ( | cs | ) |
destroy critical section (does nothing)
currently there are no resources that are dynamically allocated.
cs | pointer to critical section (critsec_t) |
#define initialize_critical_section | ( | cs | ) | (cs)->count=0 |
initialize critical section
sets count field of critical section to zero
cs | pointer to critical section (critsec_t) |
#define leave_critical_section | ( | cs | ) | atomic_dec(&(cs)->count) |
leave critical section
allow other tasks to enter critical regions of code protected by this critical section.
cs | pointer to critical section (critsec_t) |
Definition at line 100 of file critsec.h.
Referenced by CriticalSectionBlock::~CriticalSectionBlock().
#define locked_decrement | ( | counter | ) | atomic_dec(counter) |
typedef struct critsec critsec_t |
int enter_critical_section | ( | critsec_t * | cs | ) |
enter critical section
block other tasks if they attempt to enter a region of code protected by the same critical section.
cs | pointer to critical section (critsec_t) |
Referenced by CriticalSectionBlock::CriticalSectionBlock().
wakeup when critical section is available
wakeup function used to sleep a task until a critical section is available. called while processing an interrupt, so interrupts are already disabled.
brickOS is released under the
Mozilla Public License.
Original code copyright 1998-2005 by the authors. |