| 
        mq_notify  -  Attaches  a  request for asynchronous signal
       notification to a message queue (P1003.1b)
       #include <mqueue.h>
       int mq_notify ( mqd_t mqdes, const struct sigevent  *notification);
       Realtime Library (librt.so, librt.a)
        Specifies  a message queue descriptor.  Specifies a signal
       to be sent when the specified queue accepts a message.  If
       the  notification  argument  is  NULL, and the process has
       previously attached a notification request to the  message
       queue  with  this mqdes argument, the notification request
       is detached and the queue is available for another process
       to attach a notification request.
       The mq_notify function attaches a request for asynchronous
       signal notification to a message  queue  for  the  calling
       process.  Following a call to this function, the specified
       signal is sent to the calling process when the queue transitions
  from  empty  to  non-empty. Two or more processes
       cannot attach notification requests to the same  queue  at
       the same time.
       If  a  process has attached a notification request and any
       process is blocked in  the  execution  of  the  mq_receive
       function  waiting  to  receive  a  message  when a message
       arrives at the  queue,  then  the  appropriate  mq_receive
       function  is  completed and the notification remains pending.
       When the notification has been sent, the  registration  is
       canceled.  In  effect,  it  is a one-shot notification and
       must be re-registered if required.
       Note that the POSIX IPC functions are not  reentrant  with
       respect to signals.  For example, if your application were
       to use a signal to notify it that a queue has become  nonempty
  and then attempt to call mq_receive from the signal
       handler, the signal handler must reside in a thread  other
       than  the tread that called mq_send. Otherwise, a deadlock
       on internal locks would occur.
       On successful completion, the function returns the value 0
       (zero);  otherwise,  the function returns the value -1 and
       sets errno to indicate the error.
       The mq_notify function fails under  the  following  conditions:
  The  mqdes  argument  is not a valid message queue
       descriptor.  A process has already attached to  this  message
  queue  for asynchronous notification, or the calling
       process attempted to cancel a request that was attached by
       another  process.   The requested signo is invalid, or the
       sigev_notify field of the notification structure does  not
       equal SIGEV_SIGNAL.
       Functions: mq_open(3), mq_send(3)
       Guide to Realtime Programming
                                                     mq_notify(3)
[ Back ] |