xref: /freebsd-src/lib/libsys/thr_wake.2 (revision dab59af3bcc7cb7ba01569d3044894b3e860ad56)
1*dab59af3SLi-Wen Hsu.\" Copyright (c) 2016 The FreeBSD Foundation
28269e767SBrooks Davis.\"
38269e767SBrooks Davis.\" This documentation was written by
48269e767SBrooks Davis.\" Konstantin Belousov <kib@FreeBSD.org> under sponsorship
58269e767SBrooks Davis.\" from the FreeBSD Foundation.
68269e767SBrooks Davis.\"
78269e767SBrooks Davis.\" Redistribution and use in source and binary forms, with or without
88269e767SBrooks Davis.\" modification, are permitted provided that the following conditions
98269e767SBrooks Davis.\" are met:
108269e767SBrooks Davis.\" 1. Redistributions of source code must retain the above copyright
118269e767SBrooks Davis.\"    notice, this list of conditions and the following disclaimer.
128269e767SBrooks Davis.\" 2. Redistributions in binary form must reproduce the above copyright
138269e767SBrooks Davis.\"    notice, this list of conditions and the following disclaimer in the
148269e767SBrooks Davis.\"    documentation and/or other materials provided with the distribution.
158269e767SBrooks Davis.\"
168269e767SBrooks Davis.\" THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
178269e767SBrooks Davis.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
188269e767SBrooks Davis.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
198269e767SBrooks Davis.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE
208269e767SBrooks Davis.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
218269e767SBrooks Davis.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
228269e767SBrooks Davis.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
238269e767SBrooks Davis.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
248269e767SBrooks Davis.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
258269e767SBrooks Davis.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
268269e767SBrooks Davis.\" SUCH DAMAGE.
278269e767SBrooks Davis.\"
288269e767SBrooks Davis.Dd May 5, 2020
298269e767SBrooks Davis.Dt THR_WAKE 2
308269e767SBrooks Davis.Os
318269e767SBrooks Davis.Sh NAME
328269e767SBrooks Davis.Nm thr_wake
338269e767SBrooks Davis.Nd wake up the suspended thread
348269e767SBrooks Davis.Sh LIBRARY
358269e767SBrooks Davis.Lb libc
368269e767SBrooks Davis.Sh SYNOPSIS
378269e767SBrooks Davis.In sys/thr.h
388269e767SBrooks Davis.Ft int
398269e767SBrooks Davis.Fn thr_wake "long id"
408269e767SBrooks Davis.Sh DESCRIPTION
418269e767SBrooks Davis.Bf -symbolic
428269e767SBrooks DavisThis function is intended for implementing threading.
438269e767SBrooks DavisNormal applications should use
448269e767SBrooks Davis.Xr pthread_cond_timedwait 3
458269e767SBrooks Davistogether with
468269e767SBrooks Davis.Xr pthread_cond_broadcast 3
478269e767SBrooks Davisfor typical safe suspension with cooperation of the thread
488269e767SBrooks Davisbeing suspended, or
498269e767SBrooks Davis.Xr pthread_suspend_np 3
508269e767SBrooks Davisand
518269e767SBrooks Davis.Xr pthread_resume_np 3
528269e767SBrooks Davisin some specific situations, instead.
538269e767SBrooks Davis.Ef
548269e767SBrooks Davis.Pp
558269e767SBrooks DavisPassing the thread identifier of the calling thread
568269e767SBrooks Davis.Po
578269e767SBrooks Davissee
588269e767SBrooks Davis.Xr thr_self 2
598269e767SBrooks Davis.Pc
608269e767SBrooks Davisto
618269e767SBrooks Davis.Fn thr_wake
628269e767SBrooks Davissets a thread's flag to cause the next signal-interruptible sleep
638269e767SBrooks Davisof that thread in the kernel to fail immediately with the
648269e767SBrooks Davis.Er EINTR
658269e767SBrooks Daviserror.
668269e767SBrooks DavisThe flag is cleared by an interruptible sleep attempt or by a call to
678269e767SBrooks Davis.Xr thr_suspend 2 .
688269e767SBrooks DavisThis is used by the system threading library to implement cancellation.
698269e767SBrooks Davis.Pp
708269e767SBrooks DavisIf
718269e767SBrooks Davis.Fa id
728269e767SBrooks Davisis not equal to the current thread identifier, the specified thread is
738269e767SBrooks Daviswoken up if suspended by the
748269e767SBrooks Davis.Xr thr_suspend 2
758269e767SBrooks Davissystem call.
768269e767SBrooks DavisIf the thread is not suspended at the time of the
778269e767SBrooks Davis.Nm
788269e767SBrooks Daviscall, the wake is remembered and the next attempt of the thread to
798269e767SBrooks Davissuspend itself with the
808269e767SBrooks Davis.Xr thr_suspend 2
818269e767SBrooks Davisresults in immediate return with success.
828269e767SBrooks DavisOnly one wake is remembered.
838269e767SBrooks Davis.Sh RETURN VALUES
848269e767SBrooks Davis.Rv -std thr_wake
858269e767SBrooks Davis.Sh ERRORS
868269e767SBrooks DavisThe
878269e767SBrooks Davis.Fn thr_wake
888269e767SBrooks Davisoperation returns these errors:
898269e767SBrooks Davis.Bl -tag -width Er
908269e767SBrooks Davis.It Bq Er ESRCH
918269e767SBrooks DavisThe specified thread was not found or does not belong to the process
928269e767SBrooks Davisof the calling thread.
938269e767SBrooks Davis.El
948269e767SBrooks Davis.Sh SEE ALSO
958269e767SBrooks Davis.Xr ps 1 ,
968269e767SBrooks Davis.Xr thr_self 2 ,
978269e767SBrooks Davis.Xr thr_suspend 2 ,
988269e767SBrooks Davis.Xr pthread_cancel 3 ,
998269e767SBrooks Davis.Xr pthread_resume_np 3 ,
1008269e767SBrooks Davis.Xr pthread_suspend_np 3
1018269e767SBrooks Davis.Sh STANDARDS
1028269e767SBrooks DavisThe
1038269e767SBrooks Davis.Fn thr_suspend
1048269e767SBrooks Davissystem call is non-standard and is used by
1058269e767SBrooks Davis.Lb libthr
1068269e767SBrooks Davisto implement
1078269e767SBrooks Davis.St -p1003.1-2001
1088269e767SBrooks Davis.Xr pthread 3
1098269e767SBrooks Davisfunctionality.
1108269e767SBrooks Davis.Sh HISTORY
1118269e767SBrooks DavisThe
1128269e767SBrooks Davis.Fn thr_suspend
1138269e767SBrooks Davissystem call first appeared in
1148269e767SBrooks Davis.Fx 5.2 .
115