#include <SV_Semaphore_Simple.h>
Inheritance diagram for ACE_SV_Semaphore_Simple:
Public Types | |
enum | { ACE_CREATE = IPC_CREAT, ACE_EXCL = IPC_EXCL, ACE_OPEN = 0 } |
Public Member Functions | |
ACE_SV_Semaphore_Simple (void) | |
ACE_SV_Semaphore_Simple (key_t key, short flags=ACE_SV_Semaphore_Simple::ACE_CREATE, int initial_value=1, u_short nsems=1, mode_t perms=ACE_DEFAULT_FILE_PERMS) | |
ACE_SV_Semaphore_Simple (const char *name, short flags=ACE_SV_Semaphore_Simple::ACE_CREATE, int initial_value=1, u_short nsems=1, mode_t perms=ACE_DEFAULT_FILE_PERMS) | |
ACE_SV_Semaphore_Simple (const wchar_t *name, short flags=ACE_SV_Semaphore_Simple::ACE_CREATE, int initial_value=1, u_short nsems=1, mode_t perms=ACE_DEFAULT_FILE_PERMS) | |
~ACE_SV_Semaphore_Simple (void) | |
int | open (const char *name, short flags=ACE_SV_Semaphore_Simple::ACE_CREATE, int initial_value=1, u_short nsems=1, mode_t perms=ACE_DEFAULT_FILE_PERMS) |
int | open (const wchar_t *name, short flags=ACE_SV_Semaphore_Simple::ACE_CREATE, int initial_value=1, u_short nsems=1, mode_t perms=ACE_DEFAULT_FILE_PERMS) |
int | open (key_t key, short flags=ACE_SV_Semaphore_Simple::ACE_CREATE, int initial_value=1, u_short nsems=1, mode_t perms=ACE_DEFAULT_FILE_PERMS) |
int | close (void) |
int | remove (void) const |
int | acquire (u_short n=0, short flags=0) const |
int | acquire_read (u_short n=0, short flags=0) const |
Acquire a semaphore for reading. | |
int | acquire_write (u_short n=0, short flags=0) const |
Acquire a semaphore for writing. | |
int | tryacquire (u_short n=0, short flags=0) const |
Non-blocking version of . | |
int | tryacquire_read (u_short n=0, short flags=0) const |
Try to acquire the semaphore for reading. | |
int | tryacquire_write (u_short n=0, short flags=0) const |
Try to acquire the semaphore for writing. | |
int | release (u_short n=0, short flags=0) const |
int | op (short val, u_short semnum=0, short flags=SEM_UNDO) const |
int | op (sembuf op_vec[], u_short nsems) const |
General ACE_SV_Semaphore operation on an array of SV_Semaphores. | |
int | control (int cmd, semun arg, u_short n=0) const |
int | control (int cmd, int value=0, u_short n=0) const |
int | get_id (void) const |
Get underlying internal id. | |
void | dump (void) const |
Dump the state of an object. | |
Public Attributes | |
ACE_ALLOC_HOOK_DECLARE | |
Declare the dynamic allocation hooks. | |
Protected Member Functions | |
int | init (key_t k=static_cast< key_t >(ACE_INVALID_SEM_KEY), int i=-1) |
key_t | name_2_key (const char *name) |
Protected Attributes | |
key_t | key_ |
Semaphore key. | |
int | internal_id_ |
Internal ID to identify the semaphore group within this process. | |
int | sem_number_ |
Number of semaphores we're creating. |
Definition at line 50 of file SV_Semaphore_Simple.h.
|
Definition at line 53 of file SV_Semaphore_Simple.h.
00054 { 00055 ACE_CREATE = IPC_CREAT, 00056 ACE_EXCL = IPC_EXCL, 00057 ACE_OPEN = 0 00058 }; |
|
Definition at line 216 of file SV_Semaphore_Simple.cpp. References ACE_TRACE, and init().
|
|
Definition at line 108 of file SV_Semaphore_Simple.cpp. References ACE_ERROR, ACE_TEXT, ACE_TRACE, LM_ERROR, mode_t, and open().
|
|
Definition at line 174 of file SV_Semaphore_Simple.cpp. References ACE_ERROR, ACE_TEXT, ACE_TRACE, LM_ERROR, mode_t, and open().
00179 { 00180 ACE_TRACE ("ACE_SV_Semaphore_Simple::ACE_SV_Semaphore_Simple"); 00181 if (this->open (name, 00182 flags, 00183 initial_value, 00184 n, 00185 perms) == -1) 00186 ACE_ERROR ((LM_ERROR, 00187 ACE_TEXT ("%p\n"), 00188 ACE_TEXT ("ACE_SV_Semaphore_Simple::ACE_SV_Semaphore_Simple"))); 00189 } |
|
Definition at line 192 of file SV_Semaphore_Simple.cpp. References ACE_ERROR, ACE_TEXT, ACE_TRACE, LM_ERROR, mode_t, and open().
00197 { 00198 ACE_TRACE ("ACE_SV_Semaphore_Simple::ACE_SV_Semaphore_Simple(wchar_t)"); 00199 if (this->open (ACE_Wide_To_Ascii (name).char_rep (), 00200 flags, 00201 initial_value, 00202 nsems, 00203 perms) == -1) 00204 ACE_ERROR ((LM_ERROR, 00205 ACE_TEXT ("%p\n"), 00206 ACE_TEXT ("ACE_SV_Semaphore_Simple::ACE_SV_Semaphore_Simple"))); 00207 } |
|
Definition at line 210 of file SV_Semaphore_Simple.cpp. References ACE_TRACE, and close().
|
|
Wait until a ACE_SV_Semaphore's value is greater than 0, the decrement it by 1 and return. Dijkstra's P operation, Tannenbaums DOWN operation. Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 64 of file SV_Semaphore_Simple.inl. References ACE_TRACE, and op(). Referenced by ACE_SV_Semaphore_Complex::acquire(), acquire_read(), and acquire_write().
|
|
Acquire a semaphore for reading.
Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 71 of file SV_Semaphore_Simple.inl. References ACE_TRACE, and acquire().
|
|
Acquire a semaphore for writing.
Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 78 of file SV_Semaphore_Simple.inl. References ACE_TRACE, and acquire().
|
|
Close a ACE_SV_Semaphore, marking it as invalid for subsequent operations... Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 43 of file SV_Semaphore_Simple.inl. References ACE_TRACE, and init(). Referenced by ~ACE_SV_Semaphore_Simple().
|
|
Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 27 of file SV_Semaphore_Simple.cpp. References ACE_TRACE, ACE_OS::semctl(), and semun::val.
00030 { 00031 ACE_TRACE ("ACE_SV_Semaphore_Simple::control"); 00032 if (this->internal_id_ == -1) 00033 return -1; 00034 else 00035 { 00036 semun semctl_arg; 00037 00038 semctl_arg.val = value; 00039 return ACE_OS::semctl (this->internal_id_, 00040 semnum, 00041 cmd, 00042 semctl_arg); 00043 } 00044 } |
|
Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 30 of file SV_Semaphore_Simple.inl. References ACE_TRACE, and ACE_OS::semctl(). Referenced by ACE_SV_Semaphore_Complex::close(), ACE_SV_Semaphore_Complex::control(), ACE_SV_Semaphore_Complex::open(), and remove().
00033 { 00034 ACE_TRACE ("ACE_SV_Semaphore_Simple::control"); 00035 return this->internal_id_ == -1 ? 00036 -1 : ACE_OS::semctl (this->internal_id_, n, cmd, arg); 00037 } |
|
Dump the state of an object.
Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 19 of file SV_Semaphore_Simple.cpp. References ACE_TRACE.
00020 { 00021 #if defined (ACE_HAS_DUMP) 00022 ACE_TRACE ("ACE_SV_Semaphore_Simple::dump"); 00023 #endif /* ACE_HAS_DUMP */ 00024 } |
|
Get underlying internal id.
Definition at line 122 of file SV_Semaphore_Simple.inl. References ACE_TRACE.
00123 { 00124 ACE_TRACE ("ACE_SV_Semaphore_Simple::get_id"); 00125 return this->internal_id_; 00126 } |
|
Convert name to key This function is used internally to create keys for the semaphores. A valid name contains letters and digits only and MUST start with a letter. The method for generating names is not very sophisticated, so caller should not pass strings which match each other for the first LUSED characters when he wants to get a different key. Definition at line 47 of file SV_Semaphore_Simple.cpp. References ACE_TRACE. Referenced by ACE_SV_Semaphore_Complex::ACE_SV_Semaphore_Complex(), ACE_SV_Semaphore_Simple(), close(), ACE_SV_Semaphore_Complex::close(), and ACE_SV_Semaphore_Complex::open().
00048 { 00049 ACE_TRACE ("ACE_SV_Semaphore_Simple::init"); 00050 this->key_ = k; 00051 this->internal_id_ = i; 00052 return 0; 00053 } |
|
Definition at line 128 of file SV_Semaphore_Simple.cpp. References ACE_INVALID_SEM_KEY, ACE_TRACE, and ACE::crc32(). Referenced by ACE_SV_Semaphore_Complex::ACE_SV_Semaphore_Complex(), and open().
00129 { 00130 ACE_TRACE ("ACE_SV_Semaphore_Simple::name_2_key"); 00131 00132 if (name == 0) 00133 { 00134 errno = EINVAL; 00135 return static_cast<key_t> (ACE_INVALID_SEM_KEY); 00136 } 00137 00138 // Basically "hash" the values in the <name>. This won't 00139 // necessarily guarantee uniqueness of all keys. 00140 // But (IMHO) CRC32 is good enough for most purposes (Carlos) 00141 #if defined (ACE_WIN64) 00142 // The cast below is legit... 00143 # pragma warning(push) 00144 # pragma warning(disable : 4312) 00145 #endif /* ACE_WIN64 */ 00146 return (key_t) ACE::crc32 (name); 00147 #if defined (ACE_WIN64) 00148 # pragma warning(pop) 00149 #endif /* ACE_WIN64 */ 00150 } |
|
General ACE_SV_Semaphore operation on an array of SV_Semaphores.
Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 52 of file SV_Semaphore_Simple.inl. References ACE_TRACE, and ACE_OS::semop().
00053 { 00054 ACE_TRACE ("ACE_SV_Semaphore_Simple::op"); 00055 return this->internal_id_ == -1 00056 ? -1 : ACE_OS::semop (this->internal_id_, op_vec, n); 00057 } |
|
General ACE_SV_Semaphore operation. Increment or decrement by a specific amount (positive or negative; amount can`t be zero). Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 59 of file SV_Semaphore_Simple.cpp. References ACE_TRACE, and ACE_OS::semop(). Referenced by acquire(), ACE_SV_Semaphore_Complex::op(), release(), and tryacquire().
00060 { 00061 ACE_TRACE ("ACE_SV_Semaphore_Simple::op"); 00062 sembuf op_op; 00063 00064 op_op.sem_num = n; 00065 op_op.sem_flg = flags; 00066 00067 if (this->internal_id_ == -1) 00068 return -1; 00069 else if ((op_op.sem_op = val) == 0) 00070 return -1; 00071 else 00072 return ACE_OS::semop (this->internal_id_, &op_op, 1); 00073 } |
|
Open or create one or more SV_Semaphores. We return 0 if all is OK, else -1. Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 79 of file SV_Semaphore_Simple.cpp. References ACE_BIT_ENABLED, ACE_INVALID_SEM_KEY, ACE_TRACE, IPC_CREAT, IPC_PRIVATE, mode_t, sem_number_, ACE_OS::semctl(), ACE_OS::semget(), SETVAL, and semun::val.
00084 { 00085 ACE_TRACE ("ACE_SV_Semaphore_Simple::open"); 00086 union semun ivalue; 00087 00088 if (k == IPC_PRIVATE || k == static_cast<key_t> (ACE_INVALID_SEM_KEY)) 00089 return -1; 00090 00091 ivalue.val = initial_value; 00092 this->key_ = k; 00093 this->sem_number_ = n; 00094 00095 this->internal_id_ = ACE_OS::semget (this->key_, n, perms | flags); 00096 00097 if (this->internal_id_ == -1) 00098 return -1; 00099 00100 if (ACE_BIT_ENABLED (flags, IPC_CREAT)) 00101 for (int i = 0; i < n; i++) 00102 if (ACE_OS::semctl (this->internal_id_, i, SETVAL, ivalue) == -1) 00103 return -1; 00104 00105 return 0; 00106 } |
|
Definition at line 14 of file SV_Semaphore_Simple.inl. References ACE_TRACE, mode_t, and open().
00019 { 00020 ACE_TRACE ("ACE_SV_Semaphore_Simple::open (wchar_t)"); 00021 return this->open (ACE_Wide_To_Ascii (name).char_rep (), 00022 flags, 00023 initial_value, 00024 nsems, 00025 perms); 00026 } |
|
Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 156 of file SV_Semaphore_Simple.cpp. References ACE_DEFAULT_SEM_KEY, ACE_TRACE, mode_t, and name_2_key(). Referenced by ACE_SV_Semaphore_Simple(), and open().
00161 { 00162 ACE_TRACE ("ACE_SV_Semaphore_Simple::open"); 00163 00164 key_t key; 00165 00166 if (name == 0) 00167 key = ACE_DEFAULT_SEM_KEY; 00168 else 00169 key = this->name_2_key (name); 00170 00171 return this->open (key, flags, initial_value, n, perms); 00172 } |
|
Increment ACE_SV_Semaphore by one. Dijkstra's V operation, Tannenbaums UP operation. Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 115 of file SV_Semaphore_Simple.inl. References ACE_TRACE, and op(). Referenced by ACE_SV_Semaphore_Complex::release().
|
|
Remove all SV_Semaphores associated with a particular key. This call is intended to be called from a server, for example, when it is being shut down, as we do an IPC_RMID on the ACE_SV_Semaphore, regardless of whether other processes may be using it or not. Most other processes should use below. Definition at line 229 of file SV_Semaphore_Simple.cpp. References ACE_TRACE, control(), and IPC_RMID. Referenced by ACE_SV_Semaphore_Complex::close().
00230 { 00231 ACE_TRACE ("ACE_SV_Semaphore_Simple::remove"); 00232 int const result = this->control (IPC_RMID); 00233 ((ACE_SV_Semaphore_Simple *) this)->init (); 00234 return result; 00235 } |
|
Non-blocking version of .
Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 87 of file SV_Semaphore_Simple.inl. References ACE_TRACE, IPC_NOWAIT, and op(). Referenced by ACE_SV_Semaphore_Complex::tryacquire(), tryacquire_read(), and tryacquire_write().
|
|
Try to acquire the semaphore for reading.
Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 96 of file SV_Semaphore_Simple.inl. References ACE_TRACE, and tryacquire().
00097 { 00098 ACE_TRACE ("ACE_SV_Semaphore_Simple::tryacquire_read"); 00099 return this->tryacquire (n, flags); 00100 } |
|
Try to acquire the semaphore for writing.
Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 105 of file SV_Semaphore_Simple.inl. References ACE_TRACE, and tryacquire().
00106 { 00107 ACE_TRACE ("ACE_SV_Semaphore_Simple::tryacquire_write"); 00108 return this->tryacquire (n, flags); 00109 } |
|
Declare the dynamic allocation hooks.
Reimplemented in ACE_SV_Semaphore_Complex. Definition at line 163 of file SV_Semaphore_Simple.h. |
|
Internal ID to identify the semaphore group within this process.
Definition at line 170 of file SV_Semaphore_Simple.h. |
|
Semaphore key.
Definition at line 167 of file SV_Semaphore_Simple.h. |
|
Number of semaphores we're creating.
Definition at line 173 of file SV_Semaphore_Simple.h. Referenced by open(). |