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