xref: /freebsd-src/lib/libsys/thr_self.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_SELF 2
308269e767SBrooks Davis.Os
318269e767SBrooks Davis.Sh NAME
328269e767SBrooks Davis.Nm thr_self
338269e767SBrooks Davis.Nd return thread identifier for the calling 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_self "long *id"
408269e767SBrooks Davis.Sh DESCRIPTION
418269e767SBrooks DavisThe
428269e767SBrooks Davis.Fn thr_self
438269e767SBrooks Davissystem call stores the system-wide thread identifier for the current
448269e767SBrooks Daviskernel-scheduled thread in the variable pointed by the argument
458269e767SBrooks Davis.Va id .
468269e767SBrooks Davis.Pp
478269e767SBrooks DavisThe thread identifier is an integer in the range from
488269e767SBrooks Davis.Dv PID_MAX + 2
498269e767SBrooks Davis(100001) to
508269e767SBrooks Davis.Dv INT_MAX .
518269e767SBrooks DavisThe thread identifier is guaranteed to be unique at any given time,
528269e767SBrooks Davisfor each running thread in the system.
538269e767SBrooks DavisAfter the thread exits, the identifier may be reused.
548269e767SBrooks Davis.Sh RETURN VALUES
558269e767SBrooks DavisIf successful,
568269e767SBrooks Davis.Fn thr_self
578269e767SBrooks Daviswill return zero, otherwise \-1 is returned, and
588269e767SBrooks Davis.Va errno
598269e767SBrooks Davisis set to indicate the error.
608269e767SBrooks Davis.Sh ERRORS
618269e767SBrooks DavisThe
628269e767SBrooks Davis.Fn thr_self
638269e767SBrooks Davisoperation may return the following errors:
648269e767SBrooks Davis.Bl -tag -width Er
658269e767SBrooks Davis.It Bq Er EFAULT
668269e767SBrooks DavisThe memory pointed to by the
678269e767SBrooks Davis.Fa id
688269e767SBrooks Davisargument is not valid.
698269e767SBrooks Davis.El
708269e767SBrooks Davis.Sh SEE ALSO
718269e767SBrooks Davis.Xr _umtx_op 2 ,
728269e767SBrooks Davis.Xr thr_exit 2 ,
738269e767SBrooks Davis.Xr thr_kill 2 ,
748269e767SBrooks Davis.Xr thr_kill2 2 ,
758269e767SBrooks Davis.Xr thr_new 2 ,
768269e767SBrooks Davis.Xr thr_set_name 2 ,
778269e767SBrooks Davis.Xr pthread_getthreadid_np 3 ,
788269e767SBrooks Davis.Xr pthread_self 3
798269e767SBrooks Davis.Sh STANDARDS
808269e767SBrooks DavisThe
818269e767SBrooks Davis.Fn thr_self
828269e767SBrooks Davissystem call is non-standard and is used by
838269e767SBrooks Davis.Lb libthr
848269e767SBrooks Davisto implement
858269e767SBrooks Davis.St -p1003.1-2001
868269e767SBrooks Davis.Xr pthread 3
878269e767SBrooks Davisfunctionality.
888269e767SBrooks Davis.Sh HISTORY
898269e767SBrooks DavisThe
908269e767SBrooks Davis.Fn thr_self
918269e767SBrooks Davissystem call first appeared in
928269e767SBrooks Davis.Fx 5.2 .
93