Comment updates
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@754 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
parent
b08da21f90
commit
62d058a834
@ -4697,7 +4697,10 @@ returned to indicate the error:
|
|||||||
A thread attempting to unlock an unlocked mutex will return with an error.</li>
|
A thread attempting to unlock an unlocked mutex will return with an error.</li>
|
||||||
<li><code>PTHREAD_MUTEX_DEFAULT</code>. The default mutex type (PTHREAD_MUTEX_NORMAL).</li>
|
<li><code>PTHREAD_MUTEX_DEFAULT</code>. The default mutex type (PTHREAD_MUTEX_NORMAL).</li>
|
||||||
</ul>
|
</ul>
|
||||||
In NuttX, PTHREAD_MUTEX_NORMAL is not implemented. PTHREAD_MUTEX_ERRORCHECK is the <i>normal</i> behavior.</li>
|
<p>
|
||||||
|
In NuttX, <code>PTHREAD_MUTEX_NORMAL</code> is not implemented. Rather, the behavior described
|
||||||
|
for <code>PTHREAD_MUTEX_ERRORCHECK</code> is the <i>normal</i> behavior.
|
||||||
|
</p>
|
||||||
</ul>
|
</ul>
|
||||||
<p>
|
<p>
|
||||||
<b>Returned Values:</b>
|
<b>Returned Values:</b>
|
||||||
@ -4786,22 +4789,57 @@ interface of the same name.
|
|||||||
</pre>
|
</pre>
|
||||||
<p>
|
<p>
|
||||||
<b>Description:</b>
|
<b>Description:</b>
|
||||||
|
The mutex object referenced by mutex is locked by calling <code>pthread_mutex_lock()</code>.
|
||||||
|
If the mutex is already locked, the calling thread blocks until the mutex
|
||||||
|
becomes available. This operation returns with the mutex object referenced
|
||||||
|
by mutex in the locked state with the calling thread as its owner.
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
If the mutex type is <code>PTHREAD_MUTEX_NORMAL</code>, deadlock detection is not provided.
|
||||||
|
Attempting to relock the mutex causes deadlock. If a thread attempts to unlock
|
||||||
|
a mutex that it has not locked or a mutex which is unlocked, undefined behavior
|
||||||
|
results.
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
In NuttX, <code>PTHREAD_MUTEX_NORMAL</code> is not implemented. Rather, the behavior described
|
||||||
|
for <code>PTHREAD_MUTEX_ERRORCHECK</code> is the <i>normal</i> behavior.
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
If the mutex type is <code>PTHREAD_MUTEX_ERRORCHECK</code>, then error checking is provided.
|
||||||
|
If a thread attempts to relock a mutex that it has already locked, an error
|
||||||
|
will be returned. If a thread attempts to unlock a mutex that it has not
|
||||||
|
locked or a mutex which is unlocked, an error will be returned.
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
If the mutex type is <code>PTHREAD_MUTEX_RECURSIVE</code>, then the mutex maintains the concept
|
||||||
|
of a lock count. When a thread successfully acquires a mutex for the first time,
|
||||||
|
the lock count is set to one. Every time a thread relocks this mutex, the lock count
|
||||||
|
is incremented by one. Each time the thread unlocks the mutex, the lock count is
|
||||||
|
decremented by one. When the lock count reaches zero, the mutex becomes available
|
||||||
|
for other threads to acquire. If a thread attempts to unlock a mutex that it has
|
||||||
|
not locked or a mutex which is unlocked, an error will be returned.
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
If a signal is delivered to a thread waiting for a mutex, upon return from
|
||||||
|
the signal handler the thread resumes waiting for the mutex as if it was
|
||||||
|
not interrupted.
|
||||||
|
</p>
|
||||||
<p>
|
<p>
|
||||||
<b>Input Parameters:</b>
|
<b>Input Parameters:</b>
|
||||||
<p>
|
<p>
|
||||||
<ul>
|
<ul>
|
||||||
<li><code>To be provided</code>.</li>
|
<li><code>mutex</code>. A reference to the mutex to be locked.</li>
|
||||||
</ul>
|
</ul>
|
||||||
<p>
|
<p>
|
||||||
<b>Returned Values:</b>
|
<b>Returned Values:</b>
|
||||||
<p>
|
<p>
|
||||||
If successful, the <I>pthread_mutex_lock()</I> function will return
|
If successful, the <I>pthread_mutex_lock()</I> function will return zero (<I>OK</I>).
|
||||||
zero (<I>OK</I>). Otherwise, an error number will be
|
Otherwise, an error number will be returned to indicate the error:
|
||||||
returned to indicate the error:
|
|
||||||
<p>
|
<p>
|
||||||
<ul>
|
<ul>
|
||||||
<li><code>To be provided</code>. </li>
|
<li><code>To be provided</code>. </li>
|
||||||
</ul>
|
</ul>
|
||||||
|
<p>Note that this function will never return the error EINTR.</p>
|
||||||
<b>Assumptions/Limitations:</b>
|
<b>Assumptions/Limitations:</b>
|
||||||
<p>
|
<p>
|
||||||
<b>POSIX Compatibility:</b> Comparable to the POSIX
|
<b>POSIX Compatibility:</b> Comparable to the POSIX
|
||||||
@ -4817,22 +4855,31 @@ interface of the same name.
|
|||||||
</pre>
|
</pre>
|
||||||
<p>
|
<p>
|
||||||
<b>Description:</b>
|
<b>Description:</b>
|
||||||
|
The function pthread_mutex_trylock() is identical to <a href="#pthreadmutexlock"><code>pthread_mutex_lock()</code></a>
|
||||||
|
except that if the mutex object referenced by mutex is currently locked
|
||||||
|
(by any thread, including the current thread), the call returns immediately
|
||||||
|
with the errno <code>EBUSY</code>.
|
||||||
|
<p>
|
||||||
|
If a signal is delivered to a thread waiting for a mutex, upon return from
|
||||||
|
the signal handler the thread resumes waiting for the mutex as if it was
|
||||||
|
not interrupted.
|
||||||
|
</p>
|
||||||
<p>
|
<p>
|
||||||
<b>Input Parameters:</b>
|
<b>Input Parameters:</b>
|
||||||
<p>
|
<p>
|
||||||
<ul>
|
<ul>
|
||||||
<li><code>To be provided</code>.</li>
|
<li><code>mutex</code>. A reference to the mutex to be locked.</li>
|
||||||
</ul>
|
</ul>
|
||||||
<p>
|
<p>
|
||||||
<b>Returned Values:</b>
|
<b>Returned Values:</b>
|
||||||
<p>
|
<p>
|
||||||
If successful, the <I>pthread_mutex_trylock()</I> function will return
|
If successful, the <I>pthread_mutex_trylock()</I> function will return zero (<I>OK</I>).
|
||||||
zero (<I>OK</I>). Otherwise, an error number will be
|
Otherwise, an error number will be returned to indicate the error:
|
||||||
returned to indicate the error:
|
|
||||||
<p>
|
<p>
|
||||||
<ul>
|
<ul>
|
||||||
<li><code>To be provided</code>. </li>
|
<li><code>To be provided</code>. </li>
|
||||||
</ul>
|
</ul>
|
||||||
|
<p>Note that this function will never return the error EINTR.</p>
|
||||||
<b>Assumptions/Limitations:</b>
|
<b>Assumptions/Limitations:</b>
|
||||||
<p>
|
<p>
|
||||||
<b>POSIX Compatibility:</b> Comparable to the POSIX
|
<b>POSIX Compatibility:</b> Comparable to the POSIX
|
||||||
@ -4849,6 +4896,20 @@ interface of the same name.
|
|||||||
<p>
|
<p>
|
||||||
<b>Description:</b>
|
<b>Description:</b>
|
||||||
<p>
|
<p>
|
||||||
|
The <code>pthread_mutex_unlock()</code> function releases the mutex object referenced
|
||||||
|
by mutex. The manner in which a mutex is released is dependent upon the
|
||||||
|
mutex's type attribute. If there are threads blocked on the mutex object
|
||||||
|
referenced by mutex when <code>pthread_mutex_unlock()</code> is called, resulting in
|
||||||
|
the mutex becoming available, the scheduling policy is used to determine
|
||||||
|
which thread shall acquire the mutex. (In the case of <code>PTHREAD_MUTEX_RECURSIVE</code>
|
||||||
|
mutexes, the mutex becomes available when the count reaches zero and the
|
||||||
|
calling thread no longer has any locks on this mutex).
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
If a signal is delivered to a thread waiting for a mutex, upon return from
|
||||||
|
the signal handler the thread resumes waiting for the mutex as if it was
|
||||||
|
not interrupted.
|
||||||
|
</p>
|
||||||
<b>Input Parameters:</b>
|
<b>Input Parameters:</b>
|
||||||
<p>
|
<p>
|
||||||
<ul>
|
<ul>
|
||||||
@ -4864,6 +4925,7 @@ returned to indicate the error:
|
|||||||
<ul>
|
<ul>
|
||||||
<li><code>To be provided</code>. </li>
|
<li><code>To be provided</code>. </li>
|
||||||
</ul>
|
</ul>
|
||||||
|
<p>Note that this function will never return the error EINTR.</p>
|
||||||
<b>Assumptions/Limitations:</b>
|
<b>Assumptions/Limitations:</b>
|
||||||
<p>
|
<p>
|
||||||
<b>POSIX Compatibility:</b> Comparable to the POSIX
|
<b>POSIX Compatibility:</b> Comparable to the POSIX
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/************************************************************
|
/****************************************************************************
|
||||||
* pthread_initialize.c
|
* pthread_initialize.c
|
||||||
*
|
*
|
||||||
* Copyright (C) 2007 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2007, 2008 Gregory Nutt. All rights reserved.
|
||||||
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@ -14,7 +14,7 @@
|
|||||||
* notice, this list of conditions and the following disclaimer in
|
* notice, this list of conditions and the following disclaimer in
|
||||||
* the documentation and/or other materials provided with the
|
* the documentation and/or other materials provided with the
|
||||||
* distribution.
|
* distribution.
|
||||||
* 3. Neither the name Gregory Nutt nor the names of its contributors may be
|
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||||
* used to endorse or promote products derived from this software
|
* used to endorse or promote products derived from this software
|
||||||
* without specific prior written permission.
|
* without specific prior written permission.
|
||||||
*
|
*
|
||||||
@ -31,28 +31,28 @@
|
|||||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/************************************************************
|
/****************************************************************************
|
||||||
* Included Files
|
* Included Files
|
||||||
************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <semaphore.h>
|
#include <semaphore.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include "pthread_internal.h"
|
#include "pthread_internal.h"
|
||||||
|
|
||||||
/************************************************************
|
/****************************************************************************
|
||||||
* Definitions
|
* Definitions
|
||||||
************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/************************************************************
|
/****************************************************************************
|
||||||
* Private Type Declarations
|
* Private Type Declarations
|
||||||
************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/************************************************************
|
/****************************************************************************
|
||||||
* Global Variables
|
* Global Variables
|
||||||
************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/* This is the head of a private singly linked list. It
|
/* This is the head of a private singly linked list. It
|
||||||
* is used to retain information about the spawned threads.
|
* is used to retain information about the spawned threads.
|
||||||
@ -73,19 +73,19 @@ sem_t g_join_semaphore;
|
|||||||
|
|
||||||
ubyte g_pthread_num_keys;
|
ubyte g_pthread_num_keys;
|
||||||
|
|
||||||
/************************************************************
|
/****************************************************************************
|
||||||
* Private Variables
|
* Private Variables
|
||||||
************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/************************************************************
|
/****************************************************************************
|
||||||
* Private Functions
|
* Private Functions
|
||||||
************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/************************************************************
|
/****************************************************************************
|
||||||
* Public Functions
|
* Public Functions
|
||||||
************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/************************************************************
|
/****************************************************************************
|
||||||
* Function: pthread_initialize
|
* Function: pthread_initialize
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
@ -100,7 +100,7 @@ ubyte g_pthread_num_keys;
|
|||||||
*
|
*
|
||||||
* Assumptions:
|
* Assumptions:
|
||||||
*
|
*
|
||||||
************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
void pthread_initialize(void)
|
void pthread_initialize(void)
|
||||||
{
|
{
|
||||||
@ -117,7 +117,7 @@ void pthread_initialize(void)
|
|||||||
(void)sem_init(&g_join_semaphore, 0, 1);
|
(void)sem_init(&g_join_semaphore, 0, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************
|
/****************************************************************************
|
||||||
* Function: pthread_takesemaphore and pthread_givesemaphore
|
* Function: pthread_takesemaphore and pthread_givesemaphore
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
@ -127,11 +127,12 @@ void pthread_initialize(void)
|
|||||||
* None
|
* None
|
||||||
*
|
*
|
||||||
* Return Value:
|
* Return Value:
|
||||||
* None
|
* 0 on success or an ERROR on failure with errno value set to EINVAL.
|
||||||
|
* Note that the errno EINTR is never returned by this function.
|
||||||
*
|
*
|
||||||
* Assumptions:
|
* Assumptions:
|
||||||
*
|
*
|
||||||
************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
int pthread_takesemaphore(sem_t *sem)
|
int pthread_takesemaphore(sem_t *sem)
|
||||||
{
|
{
|
||||||
@ -173,8 +174,9 @@ int pthread_givesemaphore(sem_t *sem)
|
|||||||
/* Give the semaphore */
|
/* Give the semaphore */
|
||||||
|
|
||||||
if (sem_post(sem) == OK)
|
if (sem_post(sem) == OK)
|
||||||
|
{
|
||||||
return OK;
|
return OK;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* sem_post() reported an error */
|
/* sem_post() reported an error */
|
||||||
|
@ -73,13 +73,39 @@
|
|||||||
* Function: pthread_mutex_lock
|
* Function: pthread_mutex_lock
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Lock a mutex.
|
* The mutex object referenced by mutex is locked by calling pthread_mutex_lock().
|
||||||
|
* If the mutex is already locked, the calling thread blocks until the mutex
|
||||||
|
* becomes available. This operation returns with the mutex object referenced
|
||||||
|
* by mutex in the locked state with the calling thread as its owner.
|
||||||
|
*
|
||||||
|
* If the mutex type is PTHREAD_MUTEX_NORMAL, deadlock detection is not provided.
|
||||||
|
* Attempting to relock the mutex causes deadlock. If a thread attempts to unlock
|
||||||
|
* a mutex that it has not locked or a mutex which is unlocked, undefined behavior
|
||||||
|
* results.
|
||||||
|
*
|
||||||
|
* If the mutex type is PTHREAD_MUTEX_ERRORCHECK, then error checking is provided.
|
||||||
|
* If a thread attempts to relock a mutex that it has already locked, an error
|
||||||
|
* will be returned. If a thread attempts to unlock a mutex that it has not
|
||||||
|
* locked or a mutex which is unlocked, an error will be returned.
|
||||||
|
*
|
||||||
|
* If the mutex type is PTHREAD_MUTEX_RECURSIVE, then the mutex maintains the concept
|
||||||
|
* of a lock count. When a thread successfully acquires a mutex for the first time,
|
||||||
|
* the lock count is set to one. Every time a thread relocks this mutex, the lock count
|
||||||
|
* is incremented by one. Each time the thread unlocks the mutex, the lock count is
|
||||||
|
* decremented by one. When the lock count reaches zero, the mutex becomes available
|
||||||
|
* for other threads to acquire. If a thread attempts to unlock a mutex that it has
|
||||||
|
* not locked or a mutex which is unlocked, an error will be returned.
|
||||||
|
*
|
||||||
|
* If a signal is delivered to a thread waiting for a mutex, upon return from
|
||||||
|
* the signal handler the thread resumes waiting for the mutex as if it was
|
||||||
|
* not interrupted.
|
||||||
*
|
*
|
||||||
* Parameters:
|
* Parameters:
|
||||||
* None
|
* mutex - A reference to the mutex to be locked.
|
||||||
*
|
*
|
||||||
* Return Value:
|
* Return Value:
|
||||||
* None
|
* 0 on success or an errno value on failure. Note that the errno EINTR
|
||||||
|
* is never returned by pthread_mutex_lock().
|
||||||
*
|
*
|
||||||
* Assumptions:
|
* Assumptions:
|
||||||
*
|
*
|
||||||
|
@ -74,13 +74,21 @@
|
|||||||
* Function: pthread_mutex_trylock
|
* Function: pthread_mutex_trylock
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Attempt to lock a mutex
|
* The function pthread_mutex_trylock() is identical to pthread_mutex_lock()
|
||||||
|
* except that if the mutex object referenced by mutex is currently locked
|
||||||
|
* (by any thread, including the current thread), the call returns immediately
|
||||||
|
* with the errno EBUSY.
|
||||||
|
*
|
||||||
|
* If a signal is delivered to a thread waiting for a mutex, upon return from
|
||||||
|
* the signal handler the thread resumes waiting for the mutex as if it was
|
||||||
|
* not interrupted.
|
||||||
*
|
*
|
||||||
* Parameters:
|
* Parameters:
|
||||||
* None
|
* mutex - A reference to the mutex to be locked.
|
||||||
*
|
*
|
||||||
* Return Value:
|
* Return Value:
|
||||||
* None
|
* 0 on success or an errno value on failure. Note that the errno EINTR
|
||||||
|
* is never returned by pthread_mutex_lock().
|
||||||
*
|
*
|
||||||
* Assumptions:
|
* Assumptions:
|
||||||
*
|
*
|
||||||
|
@ -75,6 +75,10 @@
|
|||||||
* Description:
|
* Description:
|
||||||
* Unlock a mutex.
|
* Unlock a mutex.
|
||||||
*
|
*
|
||||||
|
* If a signal is delivered to a thread waiting for a mutex, upon return from
|
||||||
|
* the signal handler the thread resumes waiting for the mutex as if it was
|
||||||
|
* not interrupted.
|
||||||
|
*
|
||||||
* Parameters:
|
* Parameters:
|
||||||
* None
|
* None
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user