Skip to content
Snippets Groups Projects
NuttxUserGuide.html 246 KiB
Newer Older
</table>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
  NuttX provides signal interfaces for tasks. Signals are used to
  alter the flow control of tasks by communicating asynchronous events
  within or between task contexts.
  Any task or interrupt handler can post (or send) a signal to a particular task.
  The task being signaled will execute task-specified signal handler
  function the next time that the task has priority.
  The signal handler is a user-supplied function that is bound to
  a specific signal and performs whatever actions are necessary
  whenever the signal is received.
</p>
<p>
  There are no predefined actions for any signal.
  The default action for all signals (i.e., when no signal handler has
  been supplied by the user) is to ignore the signal.
  In this sense, all NuttX are <i>real time</i> signals.
</p>
<p>
  Tasks may also suspend themselves and wait until a signal is received.
</p>
<p>
  The following signal handling interfaces are provided by NuttX:
</p>
<ul>
  <li><a href="#sigemptyset">2.8.1 sigemptyset</a></li>
  <li><a href="#sigfillset">2.8.2 sigfillset</a></li>
  <li><a href="#sigaddset">2.8.3 sigaddset</a></li>
  <li><a href="#sigdelset">2.8.4 sigdelset</a></li>
  <li><a href="#sigismember">2.8.5 sigismember</a></li>
  <li><a href="#sigaction">2.8.6 sigaction</a></li>
  <li><a href="#sigprocmask">2.8.7 sigprocmask</a></li>
  <li><a href="#sigpending">2.8.8 sigpending</a></li>
  <li><a href="#sigsuspend">2.8.9 sigsuspend</a></li>
  <li><a href="#sigwaitinfo">2.8.10 sigwaitinfo</a></li>
  <li><a href="#sigtimedwait">2.8.11 sigtimedwait</a></li>
  <li><a href="#sigqueue">2.8.12 sigqueue</a></li>
  <li><a href="#kill">2.8.13 kill</a></li>
patacongo's avatar
patacongo committed
</ul>
patacongo's avatar
patacongo committed

<H3><a name="sigemptyset">2.8.1 sigemptyset</a></H3>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Function Prototype:</b> 
patacongo's avatar
patacongo committed
    #include &lt;signal.h&gt;
    int sigemptyset(sigset_t *set);
patacongo's avatar
patacongo committed

<p>
<b>Description:</b> This function initializes the signal set specified
by set such that all signals are excluded.
<p>
<b>Input Parameters:</b> 
<ul>
<li><I>set</I>. Signal set to initialize.
</ul>

<p>
<b>Returned Values:</b> 
<ul>
<li>0 (OK), or -1 (ERROR) if the signal set cannot be initialized.
</ul>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Assumptions/Limitations:</b> 
<p>
<b>  POSIX  Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.

<H3><a name="sigfillset">2.8.2 sigfillset</a></H3>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Function Prototype:</b> 
patacongo's avatar
patacongo committed
    #include &lt;signal.h&gt;
    int sigfillset(sigset_t *set);
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Description:</b> This function initializes the signal set specified
patacongo's avatar
patacongo committed
by set such that all signals are included.
patacongo's avatar
patacongo committed
<p>
<b>Input Parameters:</b> 
<ul>
<li><I>set</I>. Signal set to initialize
</ul>

<p>
<b>Returned Values:</b> 
<ul>
<li>0 (OK), or -1 (ERROR) if the signal set cannot be initialized.
</ul>

<p>
<b>Assumptions/Limitations:</b> 
<p>
<b>  POSIX  Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.

<H3><a name="sigaddset">2.8.3 sigaddset</a></H3>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Function Prototype:</b> 
patacongo's avatar
patacongo committed
    #include &lt;signal.h&gt;
    int sigaddset(sigset_t *set, int signo);
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Description:</b> This function adds the signal specified by
patacongo's avatar
patacongo committed
signo to the signal set specified by set.
patacongo's avatar
patacongo committed
<p>
<b>Input Parameters:</b> 
<ul>
<li><I>set</I>. Signal set to add signal to
<li><I>signo</I>. Signal to add
</ul>

<p>
<b>Returned Values:</b> 
<ul>
<li>0 (OK), or -1 (ERROR) if the signal number is invalid.
</ul>

<p>
<b>Assumptions/Limitations:</b> 
<p>
<b>  POSIX  Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.

<H3><a name="sigdelset">2.8.4 sigdelset</a></H3>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Function Prototype:</b> 
patacongo's avatar
patacongo committed
    #include &lt;signal.h&gt;
    int sigdelset(sigset_t *set, int signo);
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Description:</b> This function deletes the signal specified
patacongo's avatar
patacongo committed
by signo from the signal set specified by set.
patacongo's avatar
patacongo committed
<p>
<b>Input Parameters:</b> 
<ul>
<li><I>set</I>. Signal set to delete the signal from
<li><I>signo</I>. Signal to delete
</ul>

<p>
<b>Returned Values:</b> 
<ul>
<li>0 (OK), or -1 (ERROR) if the signal number is invalid.
</ul>

<p>
<b>Assumptions/Limitations:</b> 
<p>
<b>  POSIX  Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.

<H3><a name="sigismember">2.8.5 sigismember</a></H3>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Function Prototype:</b> 
patacongo's avatar
patacongo committed
    #include &lt;signal.h&gt;
    int  sigismember(const sigset_t *set, int signo);
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Description:</b> This function tests whether the signal specified
patacongo's avatar
patacongo committed
by signo is a member of the set specified by set.
patacongo's avatar
patacongo committed
<p>
<b>Input Parameters:</b> 
<ul>
<li><I>set</I>. Signal set to test
<li><I>signo</I>. Signal to test for
</ul>

<p>
<b>Returned Values:</b> 
<ul>
<li>1 (TRUE), if the specified signal is a member of the set,
<li>0 (OK or FALSE), if it is not, or
<li>-1 (ERROR) if the signal number is invalid.
</ul>

<p>
<b>Assumptions/Limitations:</b> 
<p>
<b>  POSIX  Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.

<H3><a name="sigaction">2.8.6 sigaction</a></H3>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Function Prototype:</b> 
patacongo's avatar
patacongo committed
    #include &lt;signal.h&gt;
    int sigaction( int signo, const struct sigaction *act,
                   struct sigaction *oact );
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Description:</b> This function allows the calling task to
patacongo's avatar
patacongo committed
examine and/or specify the action to be associated with a specific
signal.
patacongo's avatar
patacongo committed
<p>
patacongo's avatar
patacongo committed
The structure sigaction, used to describe an action to be taken, is defined
to include the following members:
patacongo's avatar
patacongo committed
<ul>
<li><I>sa_u.sa_handler</I>.  A pointer to a signal-catching function.
<li><I>sa_u.sa_sigaction</I>.  An alternative form for the signal catching
patacongo's avatar
patacongo committed
function.
patacongo's avatar
patacongo committed
<li><I>sa_mask</I>.  Additional set of signals to be blocked during
patacongo's avatar
patacongo committed
execution of the signal-catching function.
patacongo's avatar
patacongo committed
<li><I>sa_flags</I>:  Special flags to affect behavior of a signal.
</ul>
<p>
patacongo's avatar
patacongo committed
If the argument act is not NULL, it points to a structure specifying the
action to be associated with the specified signal.  If the argument oact
is not NULL, the action previously associated with the signal is stored
in the location pointed to by the argument oact.  If the argument act is
NULL, signal handling is unchanged by this function call; thus, the call
patacongo's avatar
patacongo committed
can be used to inquire about the current handling of a given signal.
patacongo's avatar
patacongo committed
<p>
patacongo's avatar
patacongo committed
When a signal is caught by a signal-catching function installed by the
sigaction() function, a new signal mask is calculated and installed for
the duration of the signal-catching function.  This mask is formed by taking
the union of the current signal mask and the value of the sa_mask for the
signal being delivered, and then including the signal being delivered.  If
and when the signal handler returns, the original signal mask is restored.
patacongo's avatar
patacongo committed
<p>
patacongo's avatar
patacongo committed
Signal catching functions execute in the same address environment as the
task that called sigaction() to install the signal-catching function.
patacongo's avatar
patacongo committed
<p>
patacongo's avatar
patacongo committed
Once an action is installed for a specific signal, it remains installed
until another action is explicitly requested by another call to
sigaction().
patacongo's avatar
patacongo committed
<p>
<b>Input Parameters:</b> 
<ul>
<li><I>sig</I>. Signal of interest
<li><I>act</I>. Location of new handler
<li><I>oact</I>. Location to store old handler
</ul>

<p>
<b>Returned Values:</b> 
<ul>
<li>0 (OK), or -1 (ERROR) if the signal number is invalid.
</ul>

<p>
<b>Assumptions/Limitations:</b> 
<p>
<b>  POSIX  Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.
Differences from the POSIX implementation include:
patacongo's avatar
patacongo committed
<ul>
<li>Special values of sa_handler in the struct sigaction act input
patacongo's avatar
patacongo committed
not handled (SIG_DFL, SIG_IGN).
patacongo's avatar
patacongo committed
<li>All sa_flags in struct sigaction of act input are ignored
patacongo's avatar
patacongo committed
(all treated like SA_SIGINFO).
patacongo's avatar
patacongo committed
</ul>
patacongo's avatar
patacongo committed

<H3><a name="sigprocmask">2.8.7 sigprocmask</a></H3>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Function Prototype:</b> 
patacongo's avatar
patacongo committed
    #include &lt;signal.h&gt;
    int sigprocmask(int how, const sigset_t *set, sigset_t *oset);
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Description:</b> This function allows the calling task to
patacongo's avatar
patacongo committed
examine and/or change its signal mask. If the set is not NULL,
then it points to a set of signals to be used to change the currently
blocked set. The value of how indicates the manner in which the
set is changed.
patacongo's avatar
patacongo committed
<p>
patacongo's avatar
patacongo committed
If there are any pending unblocked signals after the call to sigprocmask(),
those signals will be delivered before sigprocmask() returns.
patacongo's avatar
patacongo committed
<p>
patacongo's avatar
patacongo committed
If sigprocmask() fails, the signal mask of the task is not changed.
patacongo's avatar
patacongo committed
<p>
<b>Input Parameters:</b> 
<ul>
<li><I>how</I>. How the signal mast will be changed:
<ul>
patacongo's avatar
patacongo committed
<li><I>SIG_BLOCK</I>. The resulting set is the union of the
patacongo's avatar
patacongo committed
current set and the signal set pointed to by the <I>set</I> input parameter.
patacongo's avatar
patacongo committed
<li><I>SIG_UNBLOCK</I>. The resulting set is the intersection
patacongo's avatar
patacongo committed
of the current set and the complement of the signal set pointed
to by the <I>set</I> input parameter.
patacongo's avatar
patacongo committed
<li><I>SIG_SETMASK</I>. The resulting set is the signal set
patacongo's avatar
patacongo committed
pointed to by the <I>set</I> input parameter.
patacongo's avatar
patacongo committed
</ul>

<li><I>set</I>. Location of the new signal mask
<li><I>oset</I>. Location to store the old signal mask
</ul>

<p>
<b>Returned Values:</b> 
<ul>
<li>0 (OK), or -1 (ERROR) if how is invalid.
</ul>

<p>
<b>Assumptions/Limitations:</b> 
<p>
<b>  POSIX  Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.

<H3><a name="sigpending">2.8.8 sigpending</a></H3>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Function Prototype:</b> 
patacongo's avatar
patacongo committed
    #include &lt;signal.h&gt;
    int sigpending( sigset_t *set );
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Description:</b> This function stores the returns the set of
patacongo's avatar
patacongo committed
signals that are blocked for delivery and that are pending for
the calling task in the space pointed to by set.
patacongo's avatar
patacongo committed
<p>
patacongo's avatar
patacongo committed
If the task receiving a signal has the signal blocked via its
sigprocmask, the signal will pend until it is unmasked.  Only one pending
signal (for a given signo) is retained by the system.  This is consistent
with POSIX which states:  &quot;If a subsequent occurrence of a pending
signal is generated, it is implementation defined as to whether the signal
is delivered more than once.&quot;
patacongo's avatar
patacongo committed
<p>
<b>Input Parameters:</b> 
<ul>
<li><I>set</I>. The location to return the pending signal set.
</ul>

<p>
<b>Returned Values:</b> 
<ul>
<li>0 (OK) or -1 (ERROR)
</ul>

<p>
<b>Assumptions/Limitations:</b> 
<p>
<b>  POSIX  Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.

<H3><a name="sigsuspend">2.8.9 sigsuspend</a></H3>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Function Prototype:</b> 
patacongo's avatar
patacongo committed
    #include &lt;signal.h&gt;
    int sigsuspend( const sigset_t *set );
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Description:</b> The sigsuspend() function replaces the signal mask
patacongo's avatar
patacongo committed
with the set of signals pointed to by the argument set and then suspends
the task until delivery of a signal to the task.
patacongo's avatar
patacongo committed
<p>
patacongo's avatar
patacongo committed
If the effect of the set argument is to unblock a pending signal, then
no wait is performed.
patacongo's avatar
patacongo committed
<p>
patacongo's avatar
patacongo committed
The original signal mask is restored when sigsuspend() returns.
patacongo's avatar
patacongo committed
<p>
patacongo's avatar
patacongo committed
Waiting for an empty signal set stops a task without freeing any
resources (a very bad idea).
patacongo's avatar
patacongo committed
<p>
<b>Input Parameters:</b>
<ul>
<li><I>set</I>.  The value of the signal <b>mask</b> to use while
patacongo's avatar
patacongo committed
suspended.
patacongo's avatar
patacongo committed
</ul>

<p>
<b>Returned Values:</b> 
<ul>
<li>-1 (ERROR) always
</ul>

<p>
<b>Assumptions/Limitations:</b> 
<p>
<b>  POSIX  Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.
Differences from the POSIX specification include:
patacongo's avatar
patacongo committed
<ul>
<li>POSIX does not indicate that the original signal mask is restored.
<li>POSIX states that sigsuspend() &quot;suspends the task until
patacongo's avatar
patacongo committed
delivery of a signal whose action is either to execute a signal-catching
function or to terminate the task.&quot;  Only delivery of the signal
is required in the present implementation (even if the signal is ignored).
patacongo's avatar
patacongo committed
</ul>
patacongo's avatar
patacongo committed

<H3><a name="sigwaitinfo">2.8.10 sigwaitinfo</a></H3>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Function Prototype:</b> 
patacongo's avatar
patacongo committed
    #include &lt;signal.h&gt;
    int sigwaitinfo(const sigset_t *set, struct siginfo *info);
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Description:</b> This function is equivalent to sigtimedwait()
patacongo's avatar
patacongo committed
with a NULL timeout parameter. (see below).
patacongo's avatar
patacongo committed
<p>
<b>Input Parameters:</b> 
<ul>
<li><I>set</I>.  The set of pending signals to wait for.
<li><I>info</I>. The returned signal values
</ul>

<p>
<b>Returned Values:</b> 
<ul>
<li>Signal number that cause the wait to be terminated, otherwise
patacongo's avatar
patacongo committed
-1 (ERROR) is returned.
patacongo's avatar
patacongo committed
</ul>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Assumptions/Limitations:</b> 
<p>
<b>  POSIX  Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.

<H3><a name="sigtimedwait">2.8.11 sigtimedwait</a></H3>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Function Prototype:</b> 
patacongo's avatar
patacongo committed
    #include &lt;signal.h&gt;
    int sigtimedwait( const sigset_t *set, struct siginfo *info,
                      const struct timespec *timeout );
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Description:</b> This function selects the pending signal set
patacongo's avatar
patacongo committed
specified by the argument set. If multiple signals are pending in set,
it will remove and return the lowest numbered one. If no signals in set
are pending at the time of the call, the calling task will be suspended
until one of the signals in set becomes pending OR until the task
interrupted by an unblocked signal OR until the time interval specified by
timeout (if any), has expired. If timeout is NULL, then the timeout interval
is forever.
patacongo's avatar
patacongo committed
<p>
patacongo's avatar
patacongo committed
If the info argument is non-NULL, the selected signal number is
stored in the si_signo member and the cause of the signal is store
in the si_code member. The content of si_value is only meaningful
if the signal was generated by sigqueue(). The following values
for si_code are defined in signal.h:
patacongo's avatar
patacongo committed
<ul>
  <li><I>SI_USER</I>. Signal sent from kill, raise, or abort
  <li><I>SI_QUEUE</I>. Signal sent from sigqueue
  <li><I>SI_TIMER</I>. Signal is result of timer expiration
patacongo's avatar
patacongo committed
  <li><I>SI_ASYNCIO</I>. Signal is the result of asynchronous IO completion 
patacongo's avatar
patacongo committed
  <li><I>SI_MESGQ</I>. Signal generated by arrival of a message on an empty message queue.
</ul>

<p>
<b>Input Parameters:</b> 
<ul>
<li><I>set</I>.  The set of pending signals to wait for.
<li><I>info</I>. The returned signal values
<li><I>timeout</I>. The amount of time to wait
</ul>

<p>
<b>Returned Values:</b> 
<ul>
<li>Signal number that cause the wait to be terminated, otherwise
patacongo's avatar
patacongo committed
-1 (ERROR) is returned.
patacongo's avatar
patacongo committed
</ul>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Assumptions/Limitations:</b> 
<p>
<b>  POSIX  Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.
Differences from the POSIX interface include:
patacongo's avatar
patacongo committed
<ul>
<li>Values for si_codes differ
<li>No mechanism to return cause of ERROR. (It can be inferred
patacongo's avatar
patacongo committed
from si_code in a non-standard way).
patacongo's avatar
patacongo committed
<li>POSIX states that &quot;If no signal is pending at the time of the
patacongo's avatar
patacongo committed
call, the calling task shall be suspended until one or more signals
in set become pending or until it is interrupted by an unblocked,
<I>caught</I> signal.&quot;  The present implementation does not require
that the unblocked signal be caught; the task will be resumed even if
the unblocked signal is ignored.
patacongo's avatar
patacongo committed
</ul>
patacongo's avatar
patacongo committed

<H3><a name="sigqueue">2.8.12 sigqueue</a></H3>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Function Prototype:</b> 
patacongo's avatar
patacongo committed
    #include &lt;signal.h&gt;
    int sigqueue (int tid, int signo, union sigval value);
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Description:</b> This function sends the signal specified by
patacongo's avatar
patacongo committed
signo with the signal parameter value to the task specified
by tid.
patacongo's avatar
patacongo committed
<p>
patacongo's avatar
patacongo committed
If the receiving task has the signal blocked via its sigprocmask,
the signal will pend until it is unmasked.  Only one pending signal
(for a given signo) is retained by the system.  This is consistent with
POSIX which states:  &quot;If a subsequent occurrence of a pending signal
is generated, it is implementation defined as to whether the signal
is delivered more than once.&quot;
patacongo's avatar
patacongo committed
<p>
<b>Input Parameters:</b> 
<ul>
<li><I>tid</I>. ID of the task to receive signal
<li><I>signo</I>. Signal number
<li><I>value</I>. Value to pass to task with signal
</ul>

<p>
<b>Returned Values:</b> 
<ul>
<li>
patacongo's avatar
patacongo committed
  On  success (at least one signal was sent), zero (OK) is returned.
patacongo's avatar
patacongo committed
  On error, -1 (ERROR) is returned, and <a href="#ErrnoAccess"><code>errno</code></a> is set appropriately.
patacongo's avatar
patacongo committed
  <ul>
    <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>EPERM</code>.  The task does not have permission to send the signal to the receiving process.</li>
    <li><code>ESRCH</code>. No process has a PID matching pid.</li>
  </ul>
patacongo's avatar
patacongo committed
</ul>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Assumptions/Limitations:</b> 
<p>
<b>  POSIX  Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.
Differences from the POSIX interface include:
patacongo's avatar
patacongo committed
<ul>
<li>Default action is to ignore signals.
<li>Signals are processed one at a time in order
<li>POSIX states that, &quot;If signo is zero (the null signal), error
patacongo's avatar
patacongo committed
checking will be performed but no signal is actually sent.&quot;
There is no null signal in the present implementation; a zero signal will
be sent.
patacongo's avatar
patacongo committed
</ul>
patacongo's avatar
patacongo committed

<H3><a name="kill">2.8.13 kill</a></H3>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Function Prototype:</b> 
patacongo's avatar
patacongo committed
   #include &lt;sys/types.h&gt;
   #include &ltsignal.h&gt;
   int kill(pid_t pid, int sig);
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<p>
<b>Description:</b> 
patacongo's avatar
patacongo committed
  The kill() system call can be used to send any signal to
  any task.
</p>
<p>
  If the receiving task has the signal blocked via its sigprocmask,
  the signal will pend until it is unmasked.  Only one pending signal
  (for a given signo) is retained by the system.  This is consistent with
  POSIX which states:  &quot;If a subsequent occurrence of a pending signal
  is generated, it is implementation defined as to whether the signal
  is delivered more than once.&quot;
</p>
<p>
<b>Input Parameters:</b> 
<ul>
<li><I>pid</I>. The id of the task to receive the signal.
  The POSIX <code>kill()</code> specification encodes process group
  information as zero and negative pid values.
  Only positive, non-zero values of pid are supported by this
  implementation. ID of the task to receive signal
patacongo's avatar
patacongo committed
<li><I>signo</I>. The signal number to send.
patacongo's avatar
patacongo committed
  If signo is zero, no signal is sent, but all error checking is performed.
patacongo's avatar
patacongo committed
</ul>
patacongo's avatar
patacongo committed

<p>
patacongo's avatar
patacongo committed
  <b>Returned Values:</b> 
  <ul>
    <li>OK or ERROR
  </ul>
patacongo's avatar
patacongo committed
</p>

<p>
patacongo's avatar
patacongo committed
  <b>Assumptions/Limitations:</b> 
patacongo's avatar
patacongo committed
</p>
<p>
  <b>POSIX  Compatibility:</b>
    Comparable to the POSIX interface of the same name.
    Differences from the POSIX interface include:
</p>
<ul>
  <li>Default action is to ignore signals.</li>
  <li>Signals are processed one at a time in order </li>
  <li>Sending of signals to 'process groups' is not supported in NuttX.</li>
</ul>

<table width ="100%">
  <tr bgcolor="#e4e4e4">
  <td>
    <a name="Pthread"><h2>2.9 Pthread Interfaces</h2></a>
  </td>
  </tr>
</table>

patacongo's avatar
patacongo committed
<p>
  NuttX does not support <i>processes</i> in the way that, say, Linux does.
  NuttX only supports simple threads or tasks running within the same address space.
  For the most part, threads and tasks are interchangeable and differ primarily
  only in such things as the inheritance of file descriptors.
  Basically, threads are initialized and uninitialized differently and share a
  few more resources than tasks.
<p>
  The following pthread interfaces are supported in some form by NuttX:
</p>
patacongo's avatar
patacongo committed
<ul>
  <li><a href="#pthreadattrinit">2.9.1 pthread_attr_init</a></li>
  <li><a href="#pthreadattrdestroy">2.9.2 pthread_attr_destroy</a></li>
  <li><a href="#pthreadattrsetschedpolity">2.9.3 pthread_attr_setschedpolicy</a></li>
  <li><a href="#pthreadattrgetschedpolicy">2.9.4 pthread_attr_getschedpolicy</a></li>
  <li><a href="#pthreadattrsetschedparam">2.9.5 pthread_attr_setschedparam</a></li>
  <li><a href="#pthreadattrgetschedparam">2.9.6 pthread_attr_getschedparam</a></li>
  <li><a href="#pthreadattrsetinheritsched">2.9.7 pthread_attr_setinheritsched</a></li>
  <li><a href="#pthreadattrgetinheritsched">2.9.8 pthread_attr_getinheritsched</a></li>
  <li><a href="#pthreadattrsetstacksize">2.9.9 pthread_attr_setstacksize</a></li>
  <li><a href="#pthreadattrgetstacksize">2.9.10 pthread_attr_getstacksize</a></li>
  <li><a href="#pthreadcreate">2.9.11 pthread_create</a></li>
  <li><a href="#pthreaddetach">2.9.12 pthread_detach</a></li>
  <li><a href="#pthreadexit">2.9.13 pthread_exit</a></li>
  <li><a href="#pthreadcancel">2.9.14 pthread_cancel</a></li>
  <li><a href="#pthreadsetcancelstate">2.9.15 pthread_setcancelstate</a></li>
  <li><a href="#pthreadtestcancelstate">2.9.16 pthread_testcancelstate</a></li>
  <li><a href="#pthreadjoin">2.9.17 pthread_join</a></li>
  <li><a href="#pthreadyield">2.9.18 pthread_yield</a></li>
  <li><a href="#pthreadself">2.9.19 pthread_self</a></li>
  <li><a href="#pthreadgetschedparam">2.9.20 pthread_getschedparam</a></li>
  <li><a href="#pthreadsetschedparam">2.9.21 pthread_setschedparam</a></li>
  <li><a href="#pthreadkeycreate">2.9.22 pthread_key_create</a></li>
  <li><a href="#pthreadsetspecific">2.9.23 pthread_setspecific</a></li>
  <li><a href="#pthreadgetspecific">2.9.24 pthread_getspecific</a></li>
  <li><a href="#pthreadkeydelete">2.9.25 pthread_key_delete</a></li>
  <li><a href="#pthreadmutexattrinit">2.9.26 pthread_mutexattr_init</a></li>
  <li><a href="#pthreadmutexattrdestroy">2.9.27 pthread_mutexattr_destroy</a></li>
  <li><a href="#pthreadmutexattrgetpshared">2.9.28 pthread_mutexattr_getpshared</a></li>
  <li><a href="#pthreadmutexattrsetpshared">2.9.29 pthread_mutexattr_setpshared</a></li>
  <li><a href="#pthreadmutexattrgettype">2.9.30 pthread_mutexattr_gettype</a></li>
  <li><a href="#pthreadmutexattrsettype">2.9.31 pthread_mutexattr_settype</a></li>  
  <li><a href="#pthreadmutexinit">2.9.32 pthread_mutex_init</a></li>
  <li><a href="#pthreadmutexdestrory">2.9.33 pthread_mutex_destroy</a></li>
  <li><a href="#pthreadmutexlock">2.9.34 pthread_mutex_lock</a></li>
  <li><a href="#pthreadmutextrylock">2.9.35 pthread_mutex_trylock</a></li>
  <li><a href="#pthreadmutexunlock">2.9.36 pthread_mutex_unlock</a></li>
  <li><a href="#pthreadconaddrinit">2.9.37 pthread_condattr_init</a></li>
  <li><a href="#pthreadocndattrdestroy">2.9.38 pthread_condattr_destroy</a></li>
  <li><a href="#pthreadcondinit">2.9.39 pthread_cond_init</a></li>
  <li><a href="#pthreadconddestroy">2.9.40 pthread_cond_destroy</a></li>
  <li><a href="#pthreadcondbroadcast">2.9.41 pthread_cond_broadcast</a></li>
  <li><a href="#pthreadcondsignal">2.9.42 pthread_cond_signal</a></li>
  <li><a href="#pthreadcondwait">2.9.43 pthread_cond_wait</a></li>
  <li><a href="#pthreadcondtimedwait">2.9.44 pthread_cond_timedwait</a></li>
  <li><a href="#pthreadbarrierattrinit">2.9.45 pthread_barrierattr_init</a></li>
  <li><a href="#pthreadbarrierattrdestroy">2.9.46 pthread_barrierattr_destroy</a></li>
  <li><a href="#pthreadbarrierattrsetpshared">2.9.47 pthread_barrierattr_setpshared</a></li>
  <li><a href="#pthreadbarrierattrgetpshared">2.9.48 pthread_barrierattr_getpshared</a></li>
  <li><a href="#pthreadbarrierinit">2.9.49 pthread_barrier_init</a></li>
  <li><a href="#pthreadbarrierdestroy">2.9.50 pthread_barrier_destroy</a></li>
  <li><a href="#pthreadbarrierwait">2.9.51 pthread_barrier_wait</a></li>
  <li><a href="#pthreadonce">2.9.52 pthread_once</a></li>
  <li><a href="#pthreadkill">2.9.53 pthread_kill</a></li>
  <li><a href="#pthreadsigmask">2.9.54 pthread_sigmask</a></li>
</ul>
<p>
  No support for the following pthread interfaces is provided by NuttX:
patacongo's avatar
patacongo committed
</p>
<ul>
  <li><code>pthread_atfork</code>. register fork handlers.</li>
  <li><code>pthread_attr_getdetachstate</code>. get and set the detachstate attribute.</li>
  <li><code>pthread_attr_getguardsize</code>. get and set the thread guardsize attribute.</li>
  <li><code>pthread_attr_getinheritsched</code>. get and set the inheritsched attribute.</li>
  <li><code>pthread_attr_getscope</code>. get and set the contentionscope attribute.</li>
  <li><code>pthread_attr_getstack</code>. get and set stack attributes.</li>
  <li><code>pthread_attr_getstackaddr</code>. get and set the stackaddr attribute.</li>
  <li><code>pthread_attr_setdetachstate</code>. get and set the detachstate attribute.</li>
  <li><code>pthread_attr_setguardsize</code>. get and set the thread guardsize attribute.</li>
  <li><code>pthread_attr_setscope</code>. get and set the contentionscope attribute.</li>
  <li><code>pthread_attr_setstack</code>. get and set stack attributes.</li>
  <li><code>pthread_attr_setstackaddr</code>. get and set the stackaddr attribute.</li>
  <li><code>pthread_barrier_destroy</code>. destroy and initialize a barrier object.</li>
  <li><code>pthread_barrier_init</code>. destroy and initialize a barrier object.</li>
  <li><code>pthread_barrier_wait</code>. synchronize at a barrier.</li>
  <li><code>pthread_cleanup_pop</code>. establish cancellation handlers.</li>
  <li><code>pthread_cleanup_push</code>. establish cancellation handlers.</li>
  <li><code>pthread_condattr_getclock</code>. set the clock selection condition variable attribute.</li>
  <li><code>pthread_condattr_getpshared</code>. get the process-shared condition variable attribute.</li>
  <li><code>pthread_condattr_setclock</code>. set the clock selection condition variable attribute.</li>
  <li><code>pthread_condattr_setpshared</code>. set the process-shared condition variable attribute.</li>
patacongo's avatar
patacongo committed
  <li><code>pthread_getconcurrency</code>. get and set the level of concurrency.</li>
  <li><code>pthread_getcpuclockid</code>. access a thread CPU-time clock.</li>
  <li><code>pthread_mutex_getprioceiling</code>. get and set the priority ceiling of a mutex.</li>
  <li><code>pthread_mutex_setprioceiling</code>. get and set the priority ceiling of a mutex.</li>
  <li><code>pthread_mutex_timedlock</code>. lock a mutex.</li>
  <li><code>pthread_mutexattr_getprioceiling</code>. get and set the prioceiling attribute of the mutex attributes object.</li>
  <li><code>pthread_mutexattr_getprotocol</code>. get and set the protocol attribute of the mutex attributes object.</li>
  <li><code>pthread_mutexattr_setprioceiling</code>. get and set the prioceiling attribute of the mutex attributes object.</li>
  <li><code>pthread_mutexattr_setprotocol</code>. get and set the protocol attribute of the mutex attributes object.</li>
  <li><code>pthread_rwlock_destroy</code>. destroy and initialize a read-write lock object.</li>
  <li><code>pthread_rwlock_init</code>. destroy and initialize a read-write lock object.</li>
  <li><code>pthread_rwlock_rdlock</code>. lock a read-write lock object for reading.</li>
  <li><code>pthread_rwlock_timedrdlock</code>. lock a read-write lock for reading.</li>
  <li><code>pthread_rwlock_timedwrlock</code>. lock a read-write lock for writing.</li>
  <li><code>pthread_rwlock_tryrdlock</code>. lock a read-write lock object for reading.</li>
  <li><code>pthread_rwlock_trywrlock</code>. lock a read-write lock object for writing.</li>
  <li><code>pthread_rwlock_unlock</code>. unlock a read-write lock object.</li>
  <li><code>pthread_rwlock_wrlock</code>. lock a read-write lock object for writing.</li>
  <li><code>pthread_rwlockattr_destroy</code>. destroy and initialize the read-write lock attributes object.</li>
  <li><code>pthread_rwlockattr_getpshared</code>. get and set the process-shared attribute of the read-write lock attributes object.</li>
  <li><code>pthread_rwlockattr_init</code>. destroy and initialize the read-write lock attributes object.</li>
  <li><code>pthread_rwlockattr_setpshared</code>. get and set the process-shared attribute of the read-write lock attributes object.</li>
  <li><code>pthread_setcanceltype</code>. set cancelability state.</li>
  <li><code>pthread_setconcurrency</code>. get and set the level of concurrency.</li>
  <li><code>pthread_spin_destroy</code>. destroy or initialize a spin lock object.</li>
  <li><code>pthread_spin_init</code>. destroy or initialize a spin lock object.</li>
  <li><code>pthread_spin_lock</code>. lock a spin lock object.</li>
  <li><code>pthread_spin_trylock</code>. lock a spin lock object.</li>
  <li><code>pthread_spin_unlock</code>. unlock a spin lock object.</li>
  <li><code>pthread_testcancel</code>. set cancelability state.</li>
</ul>
patacongo's avatar
patacongo committed

patacongo's avatar
patacongo committed
<H3><a name="pthreadattrinit">2.9.1 pthread_attr_init</a></H3>
<p>
<b>Function Prototype:</b>
<p>
patacongo's avatar
patacongo committed
    #include &lt;pthread.h&gt;
    int pthread_attr_init(pthread_attr_t *attr);
patacongo's avatar
patacongo committed
<p>
<b>Description:</b>
patacongo's avatar
patacongo committed
Initializes a thread attributes object (attr) with default values
for all of the individual attributes used by the implementation.
patacongo's avatar
patacongo committed
<p>
<b>Input Parameters:</b>
<p>
<ul>
  <li><code>To be provided</code>.</li>
</ul>
<p>
<b>Returned Values:</b>
<p>
If successful, the <I>pthread_attr_init()</I> function will return
patacongo's avatar
patacongo committed
zero (<I>OK</I>).  Otherwise, an error number will be
returned to indicate the error:
patacongo's avatar
patacongo committed
<p>
<ul>
  <li><code>To be provided</code>. </li>
</ul>
<b>Assumptions/Limitations:</b>
<p>
<b>POSIX Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.
patacongo's avatar
patacongo committed
<p>
<H3><a name="pthreadattrdestroy">2.9.2 pthread_attr_destroy</a></H3>
<p>
<b>Function Prototype:</b>
<p>
patacongo's avatar
patacongo committed
    #include &lt;pthread.h&gt;
    int pthread_attr_destroy(pthread_attr_t *attr);
patacongo's avatar
patacongo committed
<p>
<b>Description:</b>
patacongo's avatar
patacongo committed
An attributes object can be deleted when it is no longer needed.
patacongo's avatar
patacongo committed
<p>
<b>Input Parameters:</b>
<p>
<ul>
  <li><code>To be provided</code>.</li>
</ul>
<p>
<b>Returned Values:</b>
<p>
If successful, the <I>pthread_attr_destroy()</I> function will return
patacongo's avatar
patacongo committed
zero (<I>OK</I>).  Otherwise, an error number will be
returned to indicate the error:
patacongo's avatar
patacongo committed
<p>
<ul>
  <li><code>To be provided</code>. </li>
</ul>
<b>Assumptions/Limitations:</b>
<p>
<b>POSIX Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.
patacongo's avatar
patacongo committed
<p>
<H3><a name="pthreadattrsetschedpolity">2.9.3 pthread_attr_setschedpolicy</a></H3>
<p>
<b>Function Prototype:</b>
<p>
patacongo's avatar
patacongo committed
    #include &lt;pthread.h&gt;
    int pthread_attr_setschedpolicy(pthread_attr_t *attr, int policy);
patacongo's avatar
patacongo committed
<p>
<b>Description:</b>
<p>
<b>Input Parameters:</b>
<p>
<ul>
  <li><code>To be provided</code>.</li>
</ul>
<p>
<b>Returned Values:</b>
<p>
If successful, the <I>pthread_attr_setschedpolicy()</I> function will return
patacongo's avatar
patacongo committed
zero (<I>OK</I>).  Otherwise, an error number will be
returned to indicate the error:
patacongo's avatar
patacongo committed
<p>
<ul>
  <li><code>To be provided</code>. </li>
</ul>
<b>Assumptions/Limitations:</b>
<p>
<b>POSIX Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.

patacongo's avatar
patacongo committed
<H3><a name="pthreadattrgetschedpolicy">2.9.4 pthread_attr_getschedpolicy</a></H3>
<p>
<b>Function Prototype:</b>
<p>
patacongo's avatar
patacongo committed
    #include &lt;pthread.h&gt;
    int pthread_attr_getschedpolicy(pthread_attr_t *attr, int *policy);
patacongo's avatar
patacongo committed
<p>
<b>Description:</b>
<p>
<b>Input Parameters:</b>
<p>
<ul>
  <li><code>To be provided</code>.</li>
</ul>
<p>
<b>Returned Values:</b>
<p>
If successful, the <I>pthread_attr_getschedpolicy()</I> function will return
patacongo's avatar
patacongo committed
zero (<I>OK</I>).  Otherwise, an error number will be
returned to indicate the error:
patacongo's avatar
patacongo committed
<p>
<ul>
  <li><code>To be provided</code>. </li>
</ul>
<b>Assumptions/Limitations:</b>
<p>
<b>POSIX Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.

patacongo's avatar
patacongo committed
<H3><a name="pthreadattrsetschedparam">2.9.5 pthread_attr_getschedpolicy</a></H3>
<p>
<b>Function Prototype:</b>
<p>
patacongo's avatar
patacongo committed
   #include &lt;pthread.h&gt;
    int pthread_attr_setschedparam(pthread_attr_t *attr,
				      const struct sched_param *param);
patacongo's avatar
patacongo committed
<p>
<b>Description:</b>
<p>
<b>Input Parameters:</b>
<p>
<ul>
  <li><code>To be provided</code>.</li>
</ul>
<p>
<b>Returned Values:</b>
<p>
If successful, the <I>pthread_attr_getschedpolicy()</I> function will return
patacongo's avatar
patacongo committed
zero (<I>OK</I>).  Otherwise, an error number will be
returned to indicate the error:
patacongo's avatar
patacongo committed
<p>
<ul>
  <li><code>To be provided</code>. </li>
</ul>
<b>Assumptions/Limitations:</b>
<p>
<b>POSIX Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.

patacongo's avatar
patacongo committed
<H3><a name="pthreadattrgetschedparam">2.9.6 pthread_attr_getschedparam</a></H3>
<p>
<b>Function Prototype:</b>
<p>
patacongo's avatar
patacongo committed
   #include &lt;pthread.h&gt;
     int pthread_attr_getschedparam(pthread_attr_t *attr,
				      struct sched_param *param);
patacongo's avatar
patacongo committed
<p>
<b>Description:</b>
<p>
<b>Input Parameters:</b>
<p>
<ul>
  <li><code>To be provided</code>.</li>
</ul>
<p>
<b>Returned Values:</b>
<p>
If successful, the <I>pthread_attr_getschedparam()</I> function will return
patacongo's avatar
patacongo committed
zero (<I>OK</I>).  Otherwise, an error number will be
returned to indicate the error:
patacongo's avatar
patacongo committed
<p>
<ul>
  <li><code>To be provided</code>. </li>
</ul>
<b>Assumptions/Limitations:</b>
<p>
<b>POSIX Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.

patacongo's avatar
patacongo committed
<H3><a name="pthreadattrsetinheritsched">2.9.7 pthread_attr_setinheritsched</a></H3>
<p>
<b>Function Prototype:</b>
<p>
patacongo's avatar
patacongo committed
   #include &lt;pthread.h&gt;
    int pthread_attr_setinheritsched(pthread_attr_t *attr,
					int inheritsched);
patacongo's avatar
patacongo committed
<p>
<b>Description:</b>
<p>
<b>Input Parameters:</b>
<p>
<ul>
  <li><code>To be provided</code>.</li>
</ul>
<p>
<b>Returned Values:</b>
<p>
If successful, the <I>pthread_attr_setinheritsched()</I> function will return
patacongo's avatar
patacongo committed
zero (<I>OK</I>).  Otherwise, an error number will be
returned to indicate the error:
patacongo's avatar
patacongo committed
<p>
<ul>
  <li><code>To be provided</code>. </li>
</ul>
<b>Assumptions/Limitations:</b>
<p>
<b>POSIX Compatibility:</b> Comparable to the POSIX
patacongo's avatar
patacongo committed
interface of the same name.
patacongo's avatar
patacongo committed
<p>
<H3><a name="pthreadattrgetinheritsched">2.9.8 pthread_attr_getinheritsched</a></H3>
<p>
<b>Function Prototype:</b>
<p>
patacongo's avatar
patacongo committed
   #include &lt;pthread.h&gt;
     int pthread_attr_getinheritsched(const pthread_attr_t *attr,
					int *inheritsched);
patacongo's avatar
patacongo committed
<p>
<b>Description:</b>
<p>
<b>Input Parameters:</b>
<p>
<ul>
  <li><code>To be provided</code>.</li>
</ul>
<p>
<b>Returned Values:</b>
<p>
If successful, the <I>pthread_attr_getinheritsched()</I> function will return
patacongo's avatar
patacongo committed
zero (<I>OK</I>).  Otherwise, an error number will be
returned to indicate the error:
patacongo's avatar
patacongo committed
<p>
<ul>
  <li><code>To be provided</code>. </li>
</ul>
<b>Assumptions/Limitations:</b>
<p>
<b>POSIX Compatibility:</b> Comparable to the POSIX