1 /* GNU Objective C Runtime Thread Interface
2 Copyright (C) 1996, 1997 Free Software Foundation, Inc.
3 Contributed by Galen C. Hunt (gchunt@cs.rochester.edu)
4 Conditions added by Mircea Oancea (mircea@first.elcom.pub.ro)
6 This file is part of GNU CC.
8 GNU CC is free software; you can redistribute it and/or modify it under the
9 terms of the GNU General Public License as published by the Free Software
10 Foundation; either version 2, or (at your option) any later version.
12 GNU CC is distributed in the hope that it will be useful, but WITHOUT ANY
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
14 FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
17 You should have received a copy of the GNU General Public License along with
18 GNU CC; see the file COPYING. If not, write to the Free Software
19 Foundation, 59 Temple Place - Suite 330,
20 Boston, MA 02111-1307, USA. */
22 /* As a special exception, if you link this library with files compiled with
23 GCC to produce an executable, this does not cause the resulting executable
24 to be covered by the GNU General Public License. This exception does not
25 however invalidate any other reasons why the executable file might be
26 covered by the GNU General Public License. */
35 /* Key structure for maintaining thread specific storage */
36 static thread_key_t __objc_thread_data_key
;
38 /* Backend initialization functions */
40 /* Initialize the threads subsystem. */
42 __objc_init_thread_system(void)
44 /* Initialize the thread storage key */
45 if (thr_keycreate(&__objc_thread_data_key
, NULL
) == 0)
51 /* Close the threads subsystem. */
53 __objc_close_thread_system(void)
58 /* Backend thread functions */
60 /* Create a new thread of execution. */
62 __objc_thread_detach(void (*func
)(void *arg
), void *arg
)
64 objc_thread_t thread_id
;
65 thread_t new_thread_id
= 0;
67 if (thr_create(NULL
, 0, (void *)func
, arg
,
68 THR_DETACHED
| THR_NEW_LWP
,
70 thread_id
= *(objc_thread_t
*)&new_thread_id
;
77 /* Set the current thread's priority. */
79 __objc_thread_set_priority(int priority
)
85 case OBJC_THREAD_INTERACTIVE_PRIORITY
:
89 case OBJC_THREAD_BACKGROUND_PRIORITY
:
92 case OBJC_THREAD_LOW_PRIORITY
:
98 if (thr_setprio(thr_self(), sys_priority
) == 0)
104 /* Return the current thread's priority. */
106 __objc_thread_get_priority(void)
110 if (thr_getprio(thr_self(), &sys_priority
) == 0)
112 if (sys_priority
>= 250)
113 return OBJC_THREAD_INTERACTIVE_PRIORITY
;
114 else if (sys_priority
>= 150)
115 return OBJC_THREAD_BACKGROUND_PRIORITY
;
116 return OBJC_THREAD_LOW_PRIORITY
;
119 /* Couldn't get priority. */
123 /* Yield our process time to another thread. */
125 __objc_thread_yield(void)
130 /* Terminate the current thread. */
132 __objc_thread_exit(void)
134 /* exit the thread */
135 thr_exit(&__objc_thread_exit_status
);
137 /* Failed if we reached here */
141 /* Returns an integer value which uniquely describes a thread. */
143 __objc_thread_id(void)
145 return (objc_thread_t
)thr_self();
148 /* Sets the thread's local storage pointer. */
150 __objc_thread_set_data(void *value
)
152 if (thr_setspecific(__objc_thread_data_key
, value
) == 0)
158 /* Returns the thread's local storage pointer. */
160 __objc_thread_get_data(void)
164 if (thr_getspecific(__objc_thread_data_key
, &value
) == 0)
170 /* Backend mutex functions */
172 /* Allocate a mutex. */
174 __objc_mutex_allocate(objc_mutex_t mutex
)
176 if (mutex_init( (mutex_t
*)(&(mutex
->backend
)), USYNC_THREAD
, 0))
183 /* Deallocate a mutex. */
185 __objc_mutex_deallocate(objc_mutex_t mutex
)
187 mutex_destroy((mutex_t
*)(&(mutex
->backend
)));
191 /* Grab a lock on a mutex. */
193 __objc_mutex_lock(objc_mutex_t mutex
)
195 if (mutex_lock((mutex_t
*)(&(mutex
->backend
))) != 0)
201 /* Try to grab a lock on a mutex. */
203 __objc_mutex_trylock(objc_mutex_t mutex
)
205 if (mutex_trylock((mutex_t
*)(&(mutex
->backend
))) != 0)
211 /* Unlock the mutex */
213 __objc_mutex_unlock(objc_mutex_t mutex
)
215 if (mutex_unlock((mutex_t
*)(&(mutex
->backend
))) != 0)
221 /* Backend condition mutex functions */
223 /* Allocate a condition. */
225 __objc_condition_allocate(objc_condition_t condition
)
227 return cond_init((cond_t
*)(&(condition
->backend
)), USYNC_THREAD
, NULL
);
230 /* Deallocate a condition. */
232 __objc_condition_deallocate(objc_condition_t condition
)
234 return cond_destroy((cond_t
*)(&(condition
->backend
)));
237 /* Wait on the condition */
239 __objc_condition_wait(objc_condition_t condition
, objc_mutex_t mutex
)
241 return cond_wait((cond_t
*)(&(condition
->backend
)),
242 (mutex_t
*)(&(mutex
->backend
)));
245 /* Wake up all threads waiting on this condition. */
247 __objc_condition_broadcast(objc_condition_t condition
)
249 return cond_broadcast((cond_t
*)(&(condition
->backend
)));
252 /* Wake up one thread waiting on this condition. */
254 __objc_condition_signal(objc_condition_t condition
)
256 return cond_signal((cond_t
*)(&(condition
->backend
)));