171b3fa15SDavid Xu /*
271b3fa15SDavid Xu * Copyright (c) 1995-1998 John Birrell <jb@cimlogic.com.au>
371b3fa15SDavid Xu * All rights reserved.
471b3fa15SDavid Xu *
571b3fa15SDavid Xu * Redistribution and use in source and binary forms, with or without
671b3fa15SDavid Xu * modification, are permitted provided that the following conditions
771b3fa15SDavid Xu * are met:
871b3fa15SDavid Xu * 1. Redistributions of source code must retain the above copyright
971b3fa15SDavid Xu * notice, this list of conditions and the following disclaimer.
1071b3fa15SDavid Xu * 2. Redistributions in binary form must reproduce the above copyright
1171b3fa15SDavid Xu * notice, this list of conditions and the following disclaimer in the
1271b3fa15SDavid Xu * documentation and/or other materials provided with the distribution.
13b0a6dbe6SSimon Schubert * 3. Neither the name of the author nor the names of any co-contributors
1471b3fa15SDavid Xu * may be used to endorse or promote products derived from this software
1571b3fa15SDavid Xu * without specific prior written permission.
1671b3fa15SDavid Xu *
1771b3fa15SDavid Xu * THIS SOFTWARE IS PROVIDED BY JOHN BIRRELL AND CONTRIBUTORS ``AS IS'' AND
1871b3fa15SDavid Xu * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
1971b3fa15SDavid Xu * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
2071b3fa15SDavid Xu * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
2171b3fa15SDavid Xu * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
2271b3fa15SDavid Xu * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2371b3fa15SDavid Xu * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2471b3fa15SDavid Xu * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
2571b3fa15SDavid Xu * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
2671b3fa15SDavid Xu * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
2771b3fa15SDavid Xu * SUCH DAMAGE.
2871b3fa15SDavid Xu *
29b0a6dbe6SSimon Schubert * $FreeBSD: src/lib/libthr/thread/thr_info.c,v 1.10 2007/04/05 07:20:31 davidxu Exp $
3071b3fa15SDavid Xu */
319e2ee207SJoerg Sonnenberger
32fc71f871SDavid Xu #include "namespace.h"
330d9899e7SSepherosa Ziehau #include <sys/lwp.h>
3471b3fa15SDavid Xu #include <stdlib.h>
3571b3fa15SDavid Xu #include <string.h>
360ca59c34SSepherosa Ziehau #include <unistd.h>
3771b3fa15SDavid Xu #include <pthread.h>
38b0a6dbe6SSimon Schubert #include <pthread_np.h>
39fc71f871SDavid Xu #include "un-namespace.h"
40fc71f871SDavid Xu
4171b3fa15SDavid Xu #include "thr_private.h"
4271b3fa15SDavid Xu
43b0a6dbe6SSimon Schubert /* Set the thread name for debug. */
44*ab5dc9acSSascha Wildner int
_pthread_setname_np(pthread_t thread,const char * name)45*ab5dc9acSSascha Wildner _pthread_setname_np(pthread_t thread, const char *name)
46*ab5dc9acSSascha Wildner {
47*ab5dc9acSSascha Wildner pthread_t curthread = tls_get_curthread();
48*ab5dc9acSSascha Wildner int error;
49*ab5dc9acSSascha Wildner int result;
50*ab5dc9acSSascha Wildner
51*ab5dc9acSSascha Wildner result = 0;
52*ab5dc9acSSascha Wildner if (curthread == thread) {
53*ab5dc9acSSascha Wildner if (lwp_setname(thread->tid, name) == -1)
54*ab5dc9acSSascha Wildner result = errno;
55*ab5dc9acSSascha Wildner } else {
56*ab5dc9acSSascha Wildner if ((error = _thr_ref_add(curthread, thread, 0)) == 0) {
57*ab5dc9acSSascha Wildner THR_THREAD_LOCK(curthread, thread);
58*ab5dc9acSSascha Wildner if (thread->state != PS_DEAD) {
59*ab5dc9acSSascha Wildner if (lwp_setname(thread->tid, name) == -1)
60*ab5dc9acSSascha Wildner result = errno;
61*ab5dc9acSSascha Wildner }
62*ab5dc9acSSascha Wildner THR_THREAD_UNLOCK(curthread, thread);
63*ab5dc9acSSascha Wildner _thr_ref_delete(curthread, thread);
64*ab5dc9acSSascha Wildner } else {
65*ab5dc9acSSascha Wildner result = error;
66*ab5dc9acSSascha Wildner }
67*ab5dc9acSSascha Wildner }
68*ab5dc9acSSascha Wildner return (result);
69*ab5dc9acSSascha Wildner }
70*ab5dc9acSSascha Wildner
71b0a6dbe6SSimon Schubert void
_pthread_set_name_np(pthread_t thread,const char * name)720ca59c34SSepherosa Ziehau _pthread_set_name_np(pthread_t thread, const char *name)
73b0a6dbe6SSimon Schubert {
74*ab5dc9acSSascha Wildner (void)_pthread_setname_np(thread, name);
7571b3fa15SDavid Xu }
76aec820bdSzrj
77eb396e51SMatthew Dillon /* Set the thread name for debug. */
78*ab5dc9acSSascha Wildner int
_pthread_getname_np(pthread_t thread,char * name,size_t len)79*ab5dc9acSSascha Wildner _pthread_getname_np(pthread_t thread, char *name, size_t len)
80eb396e51SMatthew Dillon {
81940be950Szrj pthread_t curthread = tls_get_curthread();
82*ab5dc9acSSascha Wildner int error;
83*ab5dc9acSSascha Wildner int result;
84eb396e51SMatthew Dillon
85*ab5dc9acSSascha Wildner result = 0;
86eb396e51SMatthew Dillon if (curthread == thread) {
87*ab5dc9acSSascha Wildner if (lwp_getname(thread->tid, name, len) == -1)
88*ab5dc9acSSascha Wildner result = errno;
89eb396e51SMatthew Dillon } else {
90*ab5dc9acSSascha Wildner if ((error = _thr_ref_add(curthread, thread, 0)) == 0) {
91eb396e51SMatthew Dillon THR_THREAD_LOCK(curthread, thread);
92*ab5dc9acSSascha Wildner if (thread->state != PS_DEAD) {
93*ab5dc9acSSascha Wildner if (lwp_getname(thread->tid, name, len) == -1)
94*ab5dc9acSSascha Wildner result = errno;
95*ab5dc9acSSascha Wildner } else if (len) {
96eb396e51SMatthew Dillon name[0] = 0;
97*ab5dc9acSSascha Wildner }
98eb396e51SMatthew Dillon THR_THREAD_UNLOCK(curthread, thread);
99eb396e51SMatthew Dillon _thr_ref_delete(curthread, thread);
100eb396e51SMatthew Dillon } else if (len) {
101*ab5dc9acSSascha Wildner result = errno = EINVAL;
102eb396e51SMatthew Dillon name[0] = 0;
103*ab5dc9acSSascha Wildner } else {
104*ab5dc9acSSascha Wildner result = error;
105eb396e51SMatthew Dillon }
106eb396e51SMatthew Dillon }
107*ab5dc9acSSascha Wildner return (result);
108*ab5dc9acSSascha Wildner }
109*ab5dc9acSSascha Wildner
110*ab5dc9acSSascha Wildner void
_pthread_get_name_np(pthread_t thread,char * buf,size_t len)111*ab5dc9acSSascha Wildner _pthread_get_name_np(pthread_t thread, char *buf, size_t len)
112*ab5dc9acSSascha Wildner {
113*ab5dc9acSSascha Wildner (void)_pthread_getname_np(thread, buf, len);
114eb396e51SMatthew Dillon }
115eb396e51SMatthew Dillon
116eb396e51SMatthew Dillon __strong_reference(_pthread_get_name_np, pthread_get_name_np);
117*ab5dc9acSSascha Wildner __strong_reference(_pthread_getname_np, pthread_getname_np);
118aec820bdSzrj __strong_reference(_pthread_set_name_np, pthread_set_name_np);
119*ab5dc9acSSascha Wildner __strong_reference(_pthread_setname_np, pthread_setname_np);
120