Movatterモバイル変換


[0]ホーム

URL:


man7.org > Linux >man-pages

Linux/UNIX system programming training


sigevent(3type) — Linux manual page

NAME |SYNOPSIS |DESCRIPTION |STANDARDS |HISTORY |NOTES |SEE ALSO |COLOPHON

sigevent(3type)sigevent(3type)

NAME        top

       sigevent, sigval - structure for notification from asynchronous       routines

SYNOPSIS        top

#include <signal.h>struct sigevent {int             sigev_notify;/* Notification type */int             sigev_signo;/* Signal number */union sigval    sigev_value;/* Data passed with notification */typeof(void (union sigval))  *sigev_notify_function;                                          /* Notification function                                             (SIGEV_THREAD) */pthread_attr_t *sigev_notify_attributes;                                          /* Notification attributes */           /* Linux only: */pid_t           sigev_notify_thread_id;                                          /* ID of thread to signal                                             (SIGEV_THREAD_ID) */};union sigval {/* Data passed with notification */int             sival_int;/* Integer value */void           *sival_ptr;/* Pointer value */};

DESCRIPTION        top

sigevent       Thesigevent structure is used by various APIs to describe the way       a process is to be notified about an event (e.g., completion of an       asynchronous request, expiration of a timer, or the arrival of a       message).       The definition shown in the SYNOPSIS is approximate: some of the       fields in thesigevent structure may be defined as part of a       union.  Programs should employ only those fields relevant to the       value specified insigev_notify.       Thesigev_notify field specifies how notification is to be       performed.  This field can have one of the following values:SIGEV_NONE              A "null" notification: don't do anything when the event              occurs.SIGEV_SIGNAL              Notify the process by sending the signal specified insigev_signo.              If the signal is caught with a signal handler that was              registered using thesigaction(2)SA_SIGINFOflag, then the              following fields are set in thesiginfo_t structure that is              passed as the second argument of the handler:si_code                     This field is set to a value that depends on the API                     delivering the notification.si_signo                     This field is set to the signal number (i.e., the                     same value as insigev_signo).si_value                     This field is set to the value specified insigev_value.              Depending on the API, other fields may also be set in thesiginfo_t structure.              The same information is also available if the signal is              accepted usingsigwaitinfo(2).SIGEV_THREAD              Notify the process by invokingsigev_notify_function "as              if" it were the start function of a new thread.  (Among the              implementation possibilities here are that each timer              notification could result in the creation of a new thread,              or that a single thread is created to receive all              notifications.)  The function is invoked withsigev_value              as its sole argument.  Ifsigev_notify_attributes is not              NULL, it should point to apthread_attr_t structure that              defines attributes for the new thread (seepthread_attr_init(3)).SIGEV_THREAD_ID(Linux-specific)              Currently used only by POSIX timers; seetimer_create(2).sigval       Data passed with a signal.

STANDARDS        top

       POSIX.1-2008.

HISTORY        top

       POSIX.1-2001.<aio.h> and<time.h> definesigevent since POSIX.1-2008.

NOTES        top

       The following headers also providesigevent:<aio.h>,<mqueue.h>,       and<time.h>.

SEE ALSO        top

timer_create(2),getaddrinfo_a(3),lio_listio(3),mq_notify(3),pthread_sigqueue(3),sigqueue(3),aiocb(3type),siginfo_t(3type)

COLOPHON        top

       This page is part of theman-pages (Linux kernel and C library       user-space interface documentation) project.  Information about       the project can be found at        ⟨https://www.kernel.org/doc/man-pages/⟩.  If you have a bug report       for this manual page, see       ⟨https://git.kernel.org/pub/scm/docs/man-pages/man-pages.git/tree/CONTRIBUTING⟩.       This page was obtained from the tarball man-pages-6.15.tar.gz       fetched from       ⟨https://mirrors.edge.kernel.org/pub/linux/docs/man-pages/⟩ on       2025-08-11.  If you discover any rendering problems in this HTML       version of the page, or you believe there is a better or more up-       to-date source for the page, or you have corrections or       improvements to the information in this COLOPHON (which isnot       part of the original manual page), send a mail to       man-pages@man7.orgLinux man-pages 6.15            2025-05-17sigevent(3type)

Pages that refer to this page:timer_create(2)aio_cancel(3)aio_fsync(3)aio_read(3)aio_write(3)getaddrinfo_a(3)lio_listio(3)mq_notify(3)aio(7)pthreads(7)signal(7)



HTML rendering created 2025-09-06 byMichael Kerrisk, author ofThe Linux Programming Interface.

For details of in-depthLinux/UNIX system programming training courses that I teach, lookhere.

Hosting byjambit GmbH.

Cover of TLPI


[8]ページ先頭

©2009-2025 Movatter.jp