Update errno discussion

git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@627 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
patacongo 2008-02-03 17:09:22 +00:00
parent 97a52f1b17
commit 2ab10a107f

View File

@ -21,7 +21,7 @@ User's Manual
<p> <p>
Gregory Nutt Gregory Nutt
<p> <p>
<small>Last Update: December 10, 2007</small> <small>Last Update: Februrary 2, 2008</small>
</center> </center>
<h1>1.0 <A NAME="Introduction">Introduction</a></h1> <h1>1.0 <A NAME="Introduction">Introduction</a></h1>
@ -62,9 +62,15 @@ Gregory Nutt
<b>Section 3.0, <a href="#Data_Structures">OS Data Structures</a></b>: <b>Section 3.0, <a href="#Data_Structures">OS Data Structures</a></b>:
This section documents the data structures that are used at the NuttX This section documents the data structures that are used at the NuttX
interface. interface.
<ul>
<li>Paragraph 3.1 <a href="#ScalarType">Scalar Types</a></li>
<li>Paragraph 3.2 <a href="#HiddenStructures">Hidden Interface Structures</a></li>
<li>Paragraph 3.3 <a href="#ErrnoAccess">Access to the <code>errno</code> Variable</a></li>
<li>Paragraph 3.4 <a href="#UserStructures">User Interface Structures</a></li>
</ul>
</li> </li>
<li> <li>
<a href="#index">Index</a> <a href="#index"><b>Index</b></a>
</li> </li>
</ul> </ul>
@ -227,7 +233,7 @@ paragraphs.
<li> <li>
Returns the non-zero task ID of the new task or Returns the non-zero task ID of the new task or
ERROR if memory is insufficient or the task cannot be ERROR if memory is insufficient or the task cannot be
created (errno is not set). created (<a href="#ErrnoAccess"><code>errno</code></a> is not set).
</LI> </LI>
</ul> </ul>
@ -296,7 +302,7 @@ VxWorks provides the following similar interface:
<ul> <ul>
<li><p>OK, or ERROR if the task cannot be initialized.</P> <li><p>OK, or ERROR if the task cannot be initialized.</P>
<p>This function can only failure is it is unable to assign <p>This function can only failure is it is unable to assign
a new, unique task ID to the TCB (errno is not set).</P> a new, unique task ID to the TCB (<a href="#ErrnoAccess"><code>errno</code></a> is not set).</P>
</ul> </ul>
<p> <p>
<b>Assumptions/Limitations:</b> <b>Assumptions/Limitations:</b>
@ -348,7 +354,7 @@ task_init argument).
<p> <p>
<b>Returned Values:</b> <b>Returned Values:</b>
<ul> <ul>
<li>OK, or ERROR if the task cannot be activated (errno is not set). <li>OK, or ERROR if the task cannot be activated (<a href="#ErrnoAccess"><code>errno</code></a> is not set).
</ul> </ul>
<p> <p>
@ -399,7 +405,7 @@ zero signifies the calling task.
<b>Returned Values:</b> <b>Returned Values:</b>
<ul> <ul>
<li>OK, or ERROR if the task cannot be deleted. <li>OK, or ERROR if the task cannot be deleted.
This function can fail if the provided pid does not correspond to a task (errno is not set) This function can fail if the provided pid does not correspond to a task (<a href="#ErrnoAccess"><code>errno</code></a> is not set)
</ul> </ul>
<p> <p>
@ -613,7 +619,7 @@ Compatible with the POSIX interface of the same name.
<p> <p>
<b>Returned Values:</b> <b>Returned Values:</b>
On success, sched_setparam() returns 0 (OK). On success, sched_setparam() returns 0 (OK).
On error, -1 (ERROR) is returned, and<code>errno</code>is set appropriately. On error, -1 (ERROR) is returned, and <a href="#ErrnoAccess"><code>errno</code></a> is set appropriately.
</p> </p>
<ul> <ul>
@ -714,7 +720,7 @@ interface of the same name.
<p> <p>
<b>Returned Values:</b> <b>Returned Values:</b>
On success, <i>sched_setscheduler()</i> returns OK (zero). On On success, <i>sched_setscheduler()</i> returns OK (zero). On
error, ERROR (-1) is returned, and<code>errno</code>is set appropriately: error, ERROR (-1) is returned, and <a href="#ErrnoAccess"><code>errno</code></a> is set appropriately:
</p> </p>
<ul> <ul>
<li>EINVAL The scheduling policy is not one of the <li>EINVAL The scheduling policy is not one of the
@ -762,7 +768,7 @@ policy.
<li> <li>
On success, <i>sched_getscheduler()</i> returns the policy for On success, <i>sched_getscheduler()</i> returns the policy for
the task (either SCHED_FIFO or SCHED_RR). the task (either SCHED_FIFO or SCHED_RR).
On error, ERROR (-1) is returned, and<code>errno</code>is set appropriately: On error, ERROR (-1) is returned, and <a href="#ErrnoAccess"><code>errno</code></a> is set appropriately:
<ul> <ul>
<li>ESRCH The task whose ID is pid could not be found.</li> <li>ESRCH The task whose ID is pid could not be found.</li>
</ul> </ul>
@ -775,7 +781,7 @@ policy.
interface of the same name. interface of the same name.
Differences from the full POSIX implementation include: Differences from the full POSIX implementation include:
<ul> <ul>
<li>Does not report errors via <I>errno</I>. <li>Does not report errors via <a href="#ErrnoAccess"><code>errno</code></a>.
</ul> </ul>
<H3><a name="sched_yield">2.2.5 sched_yield</a></H3> <H3><a name="sched_yield">2.2.5 sched_yield</a></H3>
@ -894,7 +900,7 @@ priority of the calling task is returned.
<p> <p>
<b>Returned Values:</b> <b>Returned Values:</b>
On success, sched_rr_get_interval() returns OK (0). On On success, sched_rr_get_interval() returns OK (0). On
error, ERROR (-1) is returned, and<code>errno</code>is set to: error, ERROR (-1) is returned, and <a href="#ErrnoAccess"><code>errno</code></a> is set to:
</p> </p>
<ul> <ul>
<li>EFAULT Cannot copy to interval</LI> <li>EFAULT Cannot copy to interval</LI>
@ -1216,7 +1222,7 @@ interface of the same name.
<p> <p>
<b>Returned Values:</b> <b>Returned Values:</b>
On success, <code>mq_send()</code> returns 0 (<code>OK</code>); On success, <code>mq_send()</code> returns 0 (<code>OK</code>);
on error, -1 (<code>ERROR</code>) is returned, with <code>errno</code> set on error, -1 (<code>ERROR</code>) is returned, with <a href="#ErrnoAccess"><code>errno</code></a> set
to indicate the error: to indicate the error:
</p> </p>
<ul> <ul>
@ -1299,7 +1305,7 @@ interface of the same name.
<p> <p>
<b>Returned Values:</b> <b>Returned Values:</b>
On success, <code>mq_send()</code> returns 0 (<code>OK</code>); On success, <code>mq_send()</code> returns 0 (<code>OK</code>);
on error, -1 (<code>ERROR</code>) is returned, with <code>errno</code> set on error, -1 (<code>ERROR</code>) is returned, with <a href="#ErrnoAccess"><code>errno</code></a> set
to indicate the error: to indicate the error:
</p> </p>
<ul> <ul>
@ -1370,7 +1376,7 @@ interface of the same name.
<p> <p>
<b>Returned Values:</b>. <b>Returned Values:</b>.
One success, the length of the selected message in bytes is returned. One success, the length of the selected message in bytes is returned.
On failure, -1 (<code>ERROR</code>) is returned and the <code>errno</code> is set appropriately: On failure, -1 (<code>ERROR</code>) is returned and the <a href="#ErrnoAccess"><code>errno</code></a> is set appropriately:
</p> </p>
<ul> <ul>
<li> <li>
@ -1451,7 +1457,7 @@ interface of the same name.
<p> <p>
<b>Returned Values:</b>. <b>Returned Values:</b>.
One success, the length of the selected message in bytes is returned. One success, the length of the selected message in bytes is returned.
On failure, -1 (<code>ERROR</code>) is returned and the <code>errno</code> is set appropriately: On failure, -1 (<code>ERROR</code>) is returned and the <a href="#ErrnoAccess"><code>errno</code></a> is set appropriately:
</p> </p>
<ul> <ul>
<li> <li>
@ -1516,7 +1522,7 @@ registration.
<li><I>mqdes</I>. Message queue descriptor <li><I>mqdes</I>. Message queue descriptor
<li><I>notification</I>. Real-time signal structure containing: <li><I>notification</I>. Real-time signal structure containing:
<ul> <ul>
<li><I>sigev_notify</I>. Should be osSIGEV_SIGNAL (but actually <li><I>sigev_notify</I>. Should be SIGEV_SIGNAL (but actually
ignored) ignored)
<li><I>sigev_signo</I>. The signo to use for the notification <li><I>sigev_signo</I>. The signo to use for the notification
<li><I>sigev_value</I>. Value associated with the signal <li><I>sigev_value</I>. Value associated with the signal
@ -1951,9 +1957,8 @@ the lock or the call is interrupted by a signal.
</ul> </ul>
<p> <p>
If <I>sem_wait</I> returns -1 (ERROR) then the cause of the failure If <I>sem_wait</I> returns -1 (ERROR) then the cause of the failure
will be indicated by the thread-specific <I>errno</I> value (a pointer will be indicated by the thread-specific <a href="#ErrnoAccess"><code>errno</code></a>.
to this value can be obtained using <I>get_errno_ptr()</I>). The following The following lists the possible values for <a href="#ErrnoAccess"><code>errno</code></a>:
lists the possible values for <I>errno</I>:
<p> <p>
<ul> <ul>
<li><I>EINVAL</I>: Indicates that the <I>sem</I> input parameter is <li><I>EINVAL</I>: Indicates that the <I>sem</I> input parameter is
@ -1992,9 +1997,8 @@ returns without blocking.
<li>0 (OK) or -1 (ERROR) if unsuccessful <li>0 (OK) or -1 (ERROR) if unsuccessful
</ul> </ul>
If <I>sem_wait</I> returns -1 (ERROR) then the cause of the failure If <I>sem_wait</I> returns -1 (ERROR) then the cause of the failure
will be indicated by the thread-specific <I>errno</I> value (a pointer will be indicated by the thread-specific <a href="#ErrnoAccess"><code>errno</code></a>.
to this value can be obtained using <I>get_errno_ptr()</I>). The following The following lists the possible values for <a href="#ErrnoAccess"><code>errno</code></a>:
lists the possible values for <I>errno</I>:
<p> <p>
<ul> <ul>
<li><I>EINVAL</I>: Indicates that the <I>sem</I> input parameter is <li><I>EINVAL</I>: Indicates that the <I>sem</I> input parameter is
@ -2522,7 +2526,7 @@ VxWorks provides the following comparable interface:
If the call succeeds, <code>timer_create()</code> will return 0 (<code>OK</code>) and update the If the call succeeds, <code>timer_create()</code> will return 0 (<code>OK</code>) and update the
location referenced by <code>timerid</code> to a <code>timer_t</code>, which can be passed to the location referenced by <code>timerid</code> to a <code>timer_t</code>, which can be passed to the
other per-thread timer calls. If an error occurs, the function will return other per-thread timer calls. If an error occurs, the function will return
a value of -1 (<code>ERROR</code>) and set<code>errno</code>to indicate the error. a value of -1 (<code>ERROR</code>) and set <a href="#ErrnoAccess"><code>errno</code></a> to indicate the error.
</p> </p>
<ul> <ul>
<li><code>EAGAIN</code>. The system lacks sufficient signal queuing resources to honor the <li><code>EAGAIN</code>. The system lacks sufficient signal queuing resources to honor the
@ -2570,7 +2574,8 @@ VxWorks provides the following comparable interface:
</p> </p>
<p> <p>
If successful, the <I>timer_delete()</I> function will return zero (<I>OK</I>). If successful, the <I>timer_delete()</I> function will return zero (<I>OK</I>).
Otherwise, the function will return a value of -1 (ERROR) and set<code>errno</code>to indicate the error: Otherwise, the function will return a value of -1 (ERROR) and set
<a href="#ErrnoAccess"><code>errno</code></a> to indicate the error:
</p> </p>
<ul> <ul>
<li><code>EINVAL</code>. The timer specified timerid is not valid.</li> <li><code>EINVAL</code>. The timer specified timerid is not valid.</li>
@ -2647,7 +2652,8 @@ VxWorks provides the following comparable interface:
</p> </p>
<p> <p>
If the timer_gettime() succeeds, a value of 0 (OK) will be returned. If the timer_gettime() succeeds, a value of 0 (OK) will be returned.
If an error occurs, the value -1 (ERROR) will be returned, and<code>errno</code>set to indicate the error. If an error occurs, the value -1 (ERROR) will be returned, and
<a href="#ErrnoAccess"><code>errno</code></a> set to indicate the error.
</p> </p>
<ul> <ul>
<li><code>EINVAL</code>. The timerid argument does not correspond to an ID returned by timer_create() but not yet deleted by timer_delete().</li> <li><code>EINVAL</code>. The timerid argument does not correspond to an ID returned by timer_create() but not yet deleted by timer_delete().</li>
@ -3065,12 +3071,12 @@ If sigprocmask() fails, the signal mask of the task is not changed.
<ul> <ul>
<li><I>how</I>. How the signal mast will be changed: <li><I>how</I>. How the signal mast will be changed:
<ul> <ul>
<li><I>osSIG_BLOCK</I>. The resulting set is the union of the <li><I>SIG_BLOCK</I>. The resulting set is the union of the
current set and the signal set pointed to by the <I>set</I> input parameter. current set and the signal set pointed to by the <I>set</I> input parameter.
<li><I>osSIG_UNBLOCK</I>. The resulting set is the intersection <li><I>SIG_UNBLOCK</I>. The resulting set is the intersection
of the current set and the complement of the signal set pointed of the current set and the complement of the signal set pointed
to by the <I>set</I> input parameter. to by the <I>set</I> input parameter.
<li><I>osSIG_SETMASK</I>. The resulting set is the signal set <li><I>SIG_SETMASK</I>. The resulting set is the signal set
pointed to by the <I>set</I> input parameter. pointed to by the <I>set</I> input parameter.
</ul> </ul>
@ -3307,7 +3313,7 @@ is delivered more than once.&quot;
<ul> <ul>
<li> <li>
On success (at least one signal was sent), zero (OK) is returned. On success (at least one signal was sent), zero (OK) is returned.
On error, -1 (ERROR) is returned, and<code>errno</code>is set appropriately. On error, -1 (ERROR) is returned, and <a href="#ErrnoAccess"><code>errno</code></a> is set appropriately.
<ul> <ul>
<li><code>EGAIN</code>. The limit of signals which may be queued has been reached.</li> <li><code>EGAIN</code>. The limit of signals which may be queued has been reached.</li>
<li><code>EINVAL</code>. signo was invalid.</li> <li><code>EINVAL</code>. signo was invalid.</li>
@ -5860,7 +5866,7 @@ Those socket APIs are discussed in the following paragraphs.</p>
</ul> </ul>
<p> <p>
<b>Returned Values:</b> <b>Returned Values:</b>
0 on success; -1 on error with<code>errno</code>set appropriately: 0 on success; -1 on error with <a href="#ErrnoAccess"><code>errno</code></a> set appropriately:
</p> </p>
<ul> <ul>
<li><code>EACCES</code>. <li><code>EACCES</code>.
@ -5906,7 +5912,7 @@ Those socket APIs are discussed in the following paragraphs.</p>
</ul> </ul>
<p> <p>
<b>Returned Values:</b> <b>Returned Values:</b>
0 on success; -1 on error with<code>errno</code>set appropriately: 0 on success; -1 on error with <a href="#ErrnoAccess"><code>errno</code></a> set appropriately:
</p> </p>
<ul> <ul>
<li><code>EACCES</code> <li><code>EACCES</code>
@ -5961,7 +5967,7 @@ Those socket APIs are discussed in the following paragraphs.</p>
</ul> </ul>
<p> <p>
<b>Returned Values:</b> <b>Returned Values:</b>
0 on success; -1 on error with<code>errno</code>set appropriately: 0 on success; -1 on error with <a href="#ErrnoAccess"><code>errno</code></a> set appropriately:
</p> </p>
<li><code>EACCES</code> or </code>EPERM</code>: <li><code>EACCES</code> or </code>EPERM</code>:
The user tried to connect to a broadcast address without having the The user tried to connect to a broadcast address without having the
@ -6028,7 +6034,8 @@ Those socket APIs are discussed in the following paragraphs.</p>
</ul> </ul>
<p> <p>
<b>Returned Values:</b> <b>Returned Values:</b>
On success, zero is returned. On error, -1 is returned, and errno is set appropriately. On success, zero is returned. On error, -1 is returned, and
<a href="#ErrnoAccess"><code>errno</code></a> is set appropriately.
</p> </p>
<ul> <ul>
<li><code>EADDRINUSE</code>: Another socket is already listening on the same port.</li> <li><code>EADDRINUSE</code>: Another socket is already listening on the same port.</li>
@ -6177,7 +6184,8 @@ Those socket APIs are discussed in the following paragraphs.</p>
</ul> </ul>
<p> <p>
<b>Returned Values:</b> <b>Returned Values:</b>
On success, returns the number of characters sent. On error, -1 is returned, and<code>errno</code>is set appropriately: On success, returns the number of characters sent. On error, -1 is returned,
and <a href="#ErrnoAccess"><code>errno</code></a> is set appropriately:
</p> </p>
<ul> <ul>
<li><code>EAGAIN</code> or <code>EWOULDBLOCK</code>. <li><code>EAGAIN</code> or <code>EWOULDBLOCK</code>.
@ -6284,7 +6292,7 @@ Those socket APIs are discussed in the following paragraphs.</p>
<p> <p>
<b>Returned Values:</b> <b>Returned Values:</b>
On success, returns the number of characters sent. On success, returns the number of characters sent.
On error, -1 is returned, and errno is set appropriately: On error, -1 is returned, and <a href="#ErrnoAccess"><code>errno</code></a> is set appropriately:
</p> </p>
<ul> <ul>
<li><code>EAGAIN</code>. <li><code>EAGAIN</code>.
@ -6348,7 +6356,7 @@ Those socket APIs are discussed in the following paragraphs.</p>
<p> <p>
<b>Returned Values:</b> <b>Returned Values:</b>
On success, returns the number of characters sent. On success, returns the number of characters sent.
On error, -1 is returned, and errno is set appropriately: On error, -1 is returned, and <a href="#ErrnoAccess"><code>errno</code></a> is set appropriately:
</p> </p>
<ul> <ul>
<li><code>BADF</code>. <li><code>BADF</code>.
@ -6411,7 +6419,7 @@ Those socket APIs are discussed in the following paragraphs.</p>
<p> <p>
<b>Returned Values:</b> <b>Returned Values:</b>
On success, returns the number of characters sent. On success, returns the number of characters sent.
On error, -1 is returned, and errno is set appropriately: On error, -1 is returned, and <a href="#ErrnoAccess"><code>errno</code></a> is set appropriately:
</p> </p>
<ul> <ul>
<li><code>BADF</code>. <li><code>BADF</code>.
@ -6428,8 +6436,8 @@ Those socket APIs are discussed in the following paragraphs.</p>
</ul> </ul>
<hr> <hr>
<h1>3.0 <A NAME="Data_Structures">OS Data Structures</a></h1> <h1>3.0 <A NAME="Data_Structures">OS Data Structures</A></h1>
<H2>3.1 Scalar types</H2> <H2>3.1 <A NAME="ScalarType">Scalar Types</A></H2>
<p> <p>
Many of the types used to communicate with NuttX are simple Many of the types used to communicate with NuttX are simple
scalar types. These types are used to provide architecture independence scalar types. These types are used to provide architecture independence
@ -6443,7 +6451,7 @@ interface include:
<li>time_t <li>time_t
</ul> </ul>
<H2>3.2 Hidden Interface Structures</H2> <H2>3.2 <A NAME="HiddenStructures">Hidden Interface Structures</A></H2>
<p> <p>
Several of the types used to interface with NuttX are Several of the types used to interface with NuttX are
structures that are intended to be hidden from the application. structures that are intended to be hidden from the application.
@ -6458,37 +6466,47 @@ OS resources. These hidden structures include:
<li>pthread_key_t <li>pthread_key_t
</ul> </ul>
<p> <p>
In order to maintain portability, applications should not reference In order to maintain portability, applications should not reference
specific elements within these hidden structures. These hidden specific elements within these hidden structures. These hidden
structures will not be described further in this user's manual. structures will not be described further in this user's manual.
</p>
<p> <p>
<H2>3.3. Access to the <I>errno</I> Variable</H2> <H2>3.3 <A NAME="ErrnoAccess">Access to the <code>errno</code> Variable</A></H2>
<p> <p>
A pointer to the thread-specific <I>errno</I>. value is available through a A pointer to the thread-specific <code>errno</code> value is available through a
function call: function call:
</p>
<p> <p>
<b>Function Prototype:</b> <b>Function Prototype:</b>
<p> <p>
<pre> int *get_errno_ptr( void )</pre> <pre> #include <errno.h>
#define errno *get_errno_ptr()
int *get_errno_ptr( void )</pre>
<p> <p>
<b>Description</b>: <I>osGetErrnorPtr()</I> returns a pointer to <b>Description</b>:
the thread-specific <I>errno</I> value. <code>get_errno_ptr()</code> returns a pointer to the thread-specific <code>errno</code> value.
Note that the symbol <code>errno</code> is defined to be <code>get_errno_ptr()</code> so that the usual
access by referencing the symbol <code>errno</code> will work as expected.
</p>
<p> <p>
This differs somewhat from the use for<code>errno</code>in a multi-threaded process environment: There is a unique, private <code>errno</code> value for each NuttX task.
Each pthread will have its own private copy of<code>errno</code>and the<code>errno</code>will not be shared However, the implementation of <code>errno</code> differs somewhat from the use of
between pthreads. <code>errno</code> in most multi-threaded process environments:
In NuttX, each pthread will also have its own private copy of <code>errno</code> and the
<code>errno</code> will not be shared between pthreads.
This is, perhaps, non-standard but promotes better thread independence.
<p> <p>
<b>Input Parameters</b>: None <b>Input Parameters</b>: None
<p> <p>
<b>Returned Values</b>: <b>Returned Values</b>:
<p> <p>
<ul> <ul>
<li>A pointer to the thread-specific <I>errno</I> value. <li>A pointer to the thread-specific <code>errno</code> value.
</ul> </ul>
<p> <p>
<H2>3.4 User Interface Structures</H2> <H2>3.4 <A NAME="UserStructures">User Interface Structures</A></H2>
<p> <p>
<H3>3.4.1 main_t</H3> <H3>3.4.1 main_t</H3>
<p> <p>