File: critsec.h

package info (click to toggle)
brickos 0.9.0-1
  • links: PTS
  • area: main
  • in suites: sarge
  • size: 1,700 kB
  • ctags: 1,727
  • sloc: ansic: 9,139; cpp: 860; makefile: 717; asm: 693; sh: 123; perl: 61
file content (119 lines) | stat: -rw-r--r-- 3,705 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
/*! \file include/critsec.h
    \brief Interface: critical section management
    \author Joseph A. Woolley <jawoolley@users.sourceforge.net>

    Defines types and functions to implement critical sections.
 */

/*
 *  The contents of this file are subject to the Mozilla Public License
 *  Version 1.0 (the "License"); you may not use this file except in
 *  compliance with the License. You may obtain a copy of the License
 *  at http://www.mozilla.org/MPL/
 *
 *  Software distributed under the License is distributed on an "AS IS"
 *  basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
 *  the License for the specific language governing rights and
 *  limitations under the License.
 *
 *  The Original Code is legOS code, released October 17, 1999.
 *
 *  The Initial Developer of the Original Code is Markus L. Noga.
 *  Portions created by Markus L. Noga are Copyright (C) 1999
 *  Markus L. Noga. All Rights Reserved.
 *
 *  Contributor(s): Joseph A. Woolley <jawoolley@users.sourceforge.net>
 */

#if !defined(__critsec_h__)
#define __critsec_h__

#if defined(__cplusplus)
extern "C" {
#endif // __cplusplus

#include <config.h>

#if defined(CONF_TM) && defined(CONF_CRITICAL_SECTIONS)
#include <sys/tm.h>
#include <atomic.h>

#ifndef DOXYGEN_SHOULD_SKIP_INTERNALS
//! critical section data structure
/*! tracks current count (level of nesting)
    and the task that is in the critical section(s)
    count will be zero when no tasks are within
    a critical section.
 */
struct critsec {
  atomic_t count;
  tdata_t* task;
};
#endif //  DOXYGEN_SHOULD_SKIP_INTERNALS

//! critical section type definition
typedef struct critsec critsec_t;

//! don't use locked_decrement anymore but atomic_dec()
/*! @deprecated use atomic_dec() instead
 */
#define locked_decrement(counter) atomic_dec(counter)

//! 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.
    \return 0 to continue waiting, non-zero to wakeup task.
    \sa enter_critical_section
 */ 
extern wakeup_t wait_critical_section(wakeup_t data);

//! initialize critical section
/*! sets count field of critical section to zero
    \param cs pointer to critical section (critsec_t)
    \return always 0
    \sa enter_critical_section
    \sa leave_critical_section
    \sa destroy_critical_section
 */
#define initialize_critical_section(cs) (cs)->count=0

//! enter critical section
/*! block other tasks if they attempt to enter a
    region of code protected by the same critical section.
    \param cs pointer to critical section (critsec_t)
    \return 1 if successful, 0 if failure
    \sa initialize_critical_section
    \sa leave_critical_section
    \sa destroy_critical_section
 */
extern int enter_critical_section(critsec_t* cs);

//! leave critical section
/*! allow other tasks to enter critical regions
    of code protected by this critical section.
    \param cs pointer to critical section (critsec_t)
    \return results of locked_decrement (always 0)
    \sa initialize_critical_section
    \sa enter_critical_section
    \sa destroy_critical_section
 */
#define leave_critical_section(cs) atomic_dec(&(cs)->count)

//! destroy critical section (does nothing)
/*! currently there are no resources that are dynamically
    allocated.
    \param cs pointer to critical section (critsec_t)
    \sa initialize_critical_section
    \sa enter_critical_section
    \sa leave_critical_section
 */
#define destroy_critical_section(cs)

#endif // CONF_TM && CONF_CRITICAL_SECTIONS

#if defined(__cplusplus)
}
#endif // __cplusplus

#endif // __critsec_h__