429 lines
18 KiB
C
429 lines
18 KiB
C
/****************************************************************************
|
|
* include/nuttx/signal.h
|
|
*
|
|
* Copyright (C) 2015, 2017 Gregory Nutt. All rights reserved.
|
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
*
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in
|
|
* the documentation and/or other materials provided with the
|
|
* distribution.
|
|
* 3. Neither the name NuttX nor the names of its contributors may be
|
|
* used to endorse or promote products derived from this software
|
|
* without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#ifndef __INCLUDE_NUTTX_SIGNAL_H
|
|
#define __INCLUDE_NUTTX_SIGNAL_H
|
|
|
|
/****************************************************************************
|
|
* Included Files
|
|
****************************************************************************/
|
|
|
|
#include <nuttx/config.h>
|
|
|
|
#include <sys/types.h>
|
|
#include <signal.h>
|
|
|
|
/****************************************************************************
|
|
* Public Function Prototypes
|
|
****************************************************************************/
|
|
|
|
/* Most internal nxsig_* interfaces are not available in the user space in
|
|
* PROTECTED and KERNEL builds. In that context, the application signal
|
|
* interfaces must be used. The differences between the two sets of
|
|
* interfaces are: (1) the nxsig_* interfaces do not cause cancellation
|
|
* points and (2) they do not modify the errno variable.
|
|
*
|
|
* This is only important when compiling libraries (libc or libnx) that are
|
|
* used both by the OS (libkc.a and libknx.a) or by the applications
|
|
* (libuc.a and libunx.a). The that case, the correct interface must be
|
|
* used for the build context.
|
|
*
|
|
* The interfaces sigtimedwait(), sigwait(), sigwaitinfo(), sleep(),
|
|
* nanosleep(), and usleep() are cancellation points.
|
|
*
|
|
* REVISIT: The fact that these interfaces are cancellation points is an
|
|
* issue and may cause violations: It use of these internally will cause
|
|
* the calling function to become a cancellation points!
|
|
*/
|
|
|
|
#if defined(CONFIG_BUILD_FLAT) || defined(__KERNEL__)
|
|
# define _SIG_PROCMASK(h,s,o) nxsig_procmask(h,s,o)
|
|
# define _SIG_QUEUE(p,s,v) nxsig_queue(p,s,v)
|
|
# define _SIG_KILL(p,s) nxsig_kill(p,s);
|
|
# define _SIG_WAITINFO(s,i) nxsig_timedwait(s,i,NULL)
|
|
# define _SIG_NANOSLEEP(r,a) nxsig_nanosleep(r,a)
|
|
# define _SIG_SLEEP(s) nxsig_sleep(s)
|
|
# define _SIG_USLEEP(u) nxsig_usleep(u)
|
|
# define _SIG_ERRNO(r) (-(r))
|
|
# define _SIG_ERRVAL(r) (r)
|
|
#else
|
|
# define _SIG_PROCMASK(h,s,o) sigprocmask(h,s,o)
|
|
# define _SIG_QUEUE(p,s,v) sigqueue(p,s,v)
|
|
# define _SIG_KILL(p,s) kill(p,s);
|
|
# define _SIG_WAITINFO(s,i) sigwaitinfo(s,i)
|
|
# define _SIG_NANOSLEEP(r,a) nanosleep(r,a)
|
|
# define _SIG_SLEEP(s) sleep(s)
|
|
# define _SIG_USLEEP(u) usleep(u)
|
|
# define _SIG_ERRNO(r) errno
|
|
# define _SIG_ERRVAL(r) (-errno)
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Public Function Prototypes
|
|
****************************************************************************/
|
|
|
|
struct timespec; /* Forward reference */
|
|
|
|
/****************************************************************************
|
|
* Name: nxsig_procmask
|
|
*
|
|
* Description:
|
|
* This function allows the calling process to 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.
|
|
*
|
|
* If there any pending unblocked signals after the call to
|
|
* nxsig_procmask(), those signals will be delivered before
|
|
* nxsig_procmask() returns.
|
|
*
|
|
* If nxsig_procmask() fails, the signal mask of the process is not changed
|
|
* by this function call.
|
|
*
|
|
* This is an internal OS interface. It is functionally equivalent to
|
|
* sigprocmask() except that it does not modify the errno value.
|
|
*
|
|
* Parameters:
|
|
* how - How the signal mast will be changed:
|
|
* SIG_BLOCK - The resulting set is the union of the current set
|
|
* and the signal set pointed to by 'set'.
|
|
* SIG_UNBLOCK - The resulting set is the intersection of the current
|
|
* set and the complement of the signal set pointed to
|
|
* by 'set'.
|
|
* SIG_SETMASK - The resulting set is the signal set pointed to by
|
|
* 'set'.
|
|
* set - Location of the new signal mask
|
|
* oset - Location to store the old signal mask
|
|
*
|
|
* Return Value:
|
|
* This is an internal OS interface and should not be used by applications.
|
|
* It follows the NuttX internal error return policy: Zero (OK) is
|
|
* returned on success. A negated errno value is returned on failure.
|
|
*
|
|
* EINVAL - The 'how' argument is invalid.
|
|
*
|
|
****************************************************************************/
|
|
|
|
int nxsig_procmask(int how, FAR const sigset_t *set, FAR sigset_t *oset);
|
|
|
|
/****************************************************************************
|
|
* Name: nxsig_queue
|
|
*
|
|
* Description:
|
|
* This function sends the signal specified by signo with the signal
|
|
* parameter value to the process specified by pid.
|
|
*
|
|
* If the receiving process has the signal blocked via the sigprocmask,
|
|
* the signal will pend until it is unmasked. Only one pending signal (per
|
|
* signo) is retained. This is consistent with POSIX which states, "If
|
|
* a subsequent occurrence of a pending signal is generated, it is
|
|
* implementation defined as to whether the signal is delivered more than
|
|
* once.
|
|
*
|
|
* This is an internal OS interface. It is functionally equivalent to
|
|
* sigqueue() except that it does not modify the errno value.
|
|
*
|
|
* Parameters:
|
|
* pid - Process ID of task to receive signal
|
|
* signo - Signal number
|
|
* value - Value to pass to task with signal
|
|
*
|
|
* Return Value:
|
|
* This is an internal OS interface and should not be used by applications.
|
|
* It follows the NuttX internal error return policy: Zero (OK) is
|
|
* returned on success. A negated errno value is returned on failure.
|
|
*
|
|
* EGAIN - The limit of signals which may be queued has been reached.
|
|
* EINVAL - sig was invalid.
|
|
* EPERM - The process does not have permission to send the
|
|
* signal to the receiving process.
|
|
* ESRCH - No process has a PID matching pid.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#ifdef CONFIG_CAN_PASS_STRUCTS
|
|
int nxsig_queue(int pid, int signo, union sigval value);
|
|
#else
|
|
int nxsig_queue(int pid, int signo, void *sival_ptr);
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Name: nxsig_kill
|
|
*
|
|
* Description:
|
|
* The nxsig_kill() system call can be used to send any signal to any task.
|
|
*
|
|
* This is an internal OS interface. It is functionally equivalent to
|
|
* the POSIX standard kill() function but does not modify the appliation
|
|
* errno variable.
|
|
*
|
|
* Limitation: Sending of signals to 'process groups' is not
|
|
* supported in NuttX
|
|
*
|
|
* Parameters:
|
|
* pid - The id of the task to receive the signal. The POSIX nxsig_kill
|
|
* specification encodes process group information as zero and
|
|
* negative pid values. Only positive, non-zero values of pid are
|
|
* supported by this implementation.
|
|
* signo - The signal number to send. If signo is zero, no signal is
|
|
* sent, but all error checking is performed.
|
|
*
|
|
* Returned Value:
|
|
* This is an internal OS interface and should not be used by applications.
|
|
* It follows the NuttX internal error return policy: Zero (OK) is
|
|
* returned on success. A negated errno value is returned on failure.
|
|
*
|
|
* EINVAL An invalid signal was specified.
|
|
* EPERM The process does not have permission to send the
|
|
* signal to any of the target processes.
|
|
* ESRCH The pid or process group does not exist.
|
|
* ENOSYS Do not support sending signals to process groups.
|
|
*
|
|
****************************************************************************/
|
|
|
|
int nxsig_kill(pid_t pid, int signo);
|
|
|
|
/****************************************************************************
|
|
* Name: nxsig_waitinfo
|
|
*
|
|
* Description:
|
|
* This function is equivalent to nxsig_timedwait with a NULL timeout
|
|
* parameter.
|
|
*
|
|
* This is an internal OS interface. It is functionally equivalent to
|
|
* sigwaitinfo() except that:
|
|
*
|
|
* - It is not a cancellaction point, and
|
|
* - It does not modify the errno value.
|
|
*
|
|
* Parameters:
|
|
* set - The pending signal set
|
|
* info - The returned value
|
|
*
|
|
* Return Value:
|
|
* This is an internal OS interface and should not be used by applications.
|
|
* It follows the NuttX internal error return policy: Zero (OK) is
|
|
* returned on success. A negated errno value is returned on failure.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#define nxsig_waitinfo(s,i) nxsig_timedwait(s,i,NULL)
|
|
|
|
/****************************************************************************
|
|
* Name: nxsig_timedwait
|
|
*
|
|
* Description:
|
|
* This function selects the pending signal set 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 process will be suspended until one of the
|
|
* signals in set becomes pending, OR until the process is 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.
|
|
*
|
|
* 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 din the
|
|
* si_code member. The content of si_value is only meaningful if the
|
|
* signal was generated by sigqueue().
|
|
*
|
|
* This is an internal OS interface. It is functionally equivalent to
|
|
* sigtimedwait() except that:
|
|
*
|
|
* - It is not a cancellaction point, and
|
|
* - It does not modify the errno value.
|
|
*
|
|
* Parameters:
|
|
* set - The pending signal set.
|
|
* info - The returned value (may be NULL).
|
|
* timeout - The amount of time to wait (may be NULL)
|
|
*
|
|
* Return Value:
|
|
* This is an internal OS interface and should not be used by applications.
|
|
* It follows the NuttX internal error return policy: Zero (OK) is
|
|
* returned on success. A negated errno value is returned on failure.
|
|
*
|
|
* EAGAIN - No signal specified by set was generated within the specified
|
|
* timeout period.
|
|
* EINTR - The wait was interrupted by an unblocked, caught signal.
|
|
*
|
|
****************************************************************************/
|
|
|
|
int nxsig_timedwait(FAR const sigset_t *set, FAR struct siginfo *info,
|
|
FAR const struct timespec *timeout);
|
|
int nxsig_timedwait(FAR const sigset_t *set, FAR struct siginfo *info,
|
|
FAR const struct timespec *timeout);
|
|
|
|
/****************************************************************************
|
|
* Name: nxsig_nanosleep
|
|
*
|
|
* Description:
|
|
* The nxsig_nanosleep() function causes the current thread to be
|
|
* suspended from execution until either the time interval specified by
|
|
* the rqtp argument has elapsed or a signal is delivered to the calling
|
|
* thread and its action is to invoke a signal-catching function or to
|
|
* terminate the process. The suspension time may be longer than requested
|
|
* because the argument value is rounded up to an integer multiple of the
|
|
* sleep resolution or because of the scheduling of other activity by the
|
|
* system. But, except for the case of being interrupted by a signal, the
|
|
* suspension time will not be less than the time specified by rqtp, as
|
|
* measured by the system clock, CLOCK_REALTIME.
|
|
*
|
|
* The use of the nxsig_nanosleep() function has no effect on the action
|
|
* or blockage of any signal.
|
|
*
|
|
* Parameters:
|
|
* rqtp - The amount of time to be suspended from execution.
|
|
* rmtp - If the rmtp argument is non-NULL, the timespec structure
|
|
* referenced by it is updated to contain the amount of time
|
|
* remaining in the interval (the requested time minus the time
|
|
* actually slept)
|
|
*
|
|
* Returned Value:
|
|
* If the nxsig_nanosleep() function returns because the requested time
|
|
* has elapsed, its return value is zero.
|
|
*
|
|
* If the nxsig_nanosleep() function returns because it has been
|
|
* interrupted by a signal, the function returns a negated errno value
|
|
* indicate the interruption. If the rmtp argument is non-NULL, the
|
|
* timespec structure referenced by it is updated to contain the amount
|
|
* of time remaining in the interval (the requested time minus the time
|
|
* actually slept). If the rmtp argument is NULL, the remaining time is
|
|
* not returned.
|
|
*
|
|
* If nxsig_nanosleep() fails, it returns a negated errno indicating the
|
|
* cause of the failure. The nxsig_nanosleep() function will fail if:
|
|
*
|
|
* EINTR - The nxsig_nanosleep() function was interrupted by a signal.
|
|
* EINVAL - The rqtp argument specified a nanosecond value less than
|
|
* zero or greater than or equal to 1000 million.
|
|
* ENOSYS - The nxsig_nanosleep() function is not supported by this
|
|
* implementation.
|
|
*
|
|
****************************************************************************/
|
|
|
|
int nxsig_nanosleep(FAR const struct timespec *rqtp,
|
|
FAR struct timespec *rmtp);
|
|
|
|
/****************************************************************************
|
|
* Name: nxsig_sleep
|
|
*
|
|
* Description:
|
|
* The nxsig_sleep() function will cause the calling thread to be
|
|
* suspended from execution until either the number of real-time seconds
|
|
* specified by the argument 'seconds' has elapsed or a signal is
|
|
* delivered to the calling thread.
|
|
*
|
|
* This is an internal OS interface. It is functionally equivalent to
|
|
* the standard sleep() application interface except that:
|
|
*
|
|
* - It is not a cancellaction point, and
|
|
* - There is no check that the action of the signal is to invoke a
|
|
* signal-catching function or to terminate the process.
|
|
*
|
|
* See the description of sleep() for additional information that is not
|
|
* duplicated here.
|
|
*
|
|
* Parameters:
|
|
* seconds - The number of seconds to sleep
|
|
*
|
|
* Returned Value:
|
|
* If nxsig_sleep() returns because the requested time has elapsed, the
|
|
* value returned will be zero (OK). If nxsig_sleep() returns because of
|
|
* premature arousal due to delivery of a signal, the return value will
|
|
* be the "unslept" amount (the requested time minus the time actually
|
|
* slept) in seconds.
|
|
*
|
|
****************************************************************************/
|
|
|
|
unsigned int nxsig_sleep(unsigned int seconds);
|
|
|
|
/****************************************************************************
|
|
* Name: nxsig_usleep
|
|
*
|
|
* Description:
|
|
* The nxsig_usleep() function will cause the calling thread to be
|
|
* suspended from execution until either the number of real-time
|
|
* microseconds specified by the argument 'usec' has elapsed or a signal
|
|
* is delivered to the calling thread. The suspension time may be longer
|
|
* than requested due to the scheduling of other activity by the system.
|
|
*
|
|
* This is an internal OS interface. It is functionally equivalent to
|
|
* the standard nxsig_usleep() application interface except that:
|
|
*
|
|
* - It is not a cancellaction point, and
|
|
* - It does not modify the errno value.
|
|
*
|
|
* See the description of usleep() for additional information that is not
|
|
* duplicated here.
|
|
*
|
|
* Parameters:
|
|
* usec - the number of microseconds to wait.
|
|
*
|
|
* Returned Value:
|
|
* This is an internal OS interface and should not be used by applications.
|
|
* It follows the NuttX internal error return policy: Zero (OK) is
|
|
* returned on success. A negated errno value is returned on failure.
|
|
*
|
|
****************************************************************************/
|
|
|
|
int nxsig_usleep(useconds_t usec);
|
|
|
|
/****************************************************************************
|
|
* Name: nxsig_notification
|
|
*
|
|
* Description:
|
|
* Notify a client a signal event via a function call. This function is
|
|
* an internal OS interface that implements the common logic for signal
|
|
* event notification for the case of SIGEV_THREAD.
|
|
*
|
|
* Input Parameters:
|
|
* pid - The task/thread ID a the client thread to be signaled.
|
|
* event - The instance of struct sigevent that describes how to signal
|
|
* the client.
|
|
*
|
|
* Returned Value:
|
|
* This is an internal OS interface and should not be used by applications.
|
|
* It follows the NuttX internal error return policy: Zero (OK) is
|
|
* returned on success. A negated errno value is returned on failure.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#if defined(CONFIG_SIG_EVTHREAD) && defined(CONFIG_BUILD_FLAT)
|
|
int nxsig_notification(pid_t pid, FAR struct sigevent *event);
|
|
#endif
|
|
|
|
#endif /* __INCLUDE_NUTTX_SIGNAL_H */
|