| Commit | Line | Data |
|---|---|---|
| 17ea2221 MD |
1 | /* |
| 2 | * Copyright (c) 2001 Daniel Eischen <deischen@FreeBSD.org>. | |
| 3 | * All rights reserved. | |
| 4 | * | |
| 5 | * Redistribution and use in source and binary forms, with or without | |
| 6 | * modification, are permitted provided that the following conditions | |
| 7 | * are met: | |
| 8 | * 1. Redistributions of source code must retain the above copyright | |
| 9 | * notice, this list of conditions and the following disclaimer. | |
| 10 | * 2. Redistributions in binary form must reproduce the above copyright | |
| 11 | * notice, this list of conditions and the following disclaimer in the | |
| 12 | * documentation and/or other materials provided with the distribution. | |
| 13 | * | |
| 14 | * THIS SOFTWARE IS PROVIDED BY DANIEL EISCHEN AND CONTRIBUTORS ``AS IS'' | |
| 15 | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | |
| 16 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | |
| 17 | * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE | |
| 18 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | |
| 19 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS | |
| 20 | * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | |
| 21 | * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT | |
| 22 | * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY | |
| 23 | * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | |
| 24 | * SUCH DAMAGE. | |
| 25 | * | |
| ce0e08e2 | 26 | * $FreeBSD: src/lib/libc/gen/_pthread_stubs.c,v 1.5 2001/06/11 23:18:22 iedowse Exp $ |
| 19c7a913 | 27 | * $DragonFly: src/lib/libc/gen/_pthread_stubs.c,v 1.4 2005/05/09 12:43:40 davidxu Exp $ |
| 17ea2221 MD |
28 | */ |
| 29 | ||
| 82205bfb SS |
30 | #include <sys/cdefs.h> |
| 31 | #include <stdlib.h> | |
| 19c7a913 | 32 | |
| 17ea2221 MD |
33 | /* |
| 34 | * Weak symbols: All libc internal usage of these functions should | |
| 35 | * use the weak symbol versions (_pthread_XXX). If libpthread is | |
| 36 | * linked, it will override these functions with (non-weak) routines. | |
| 37 | * The _pthread_XXX functions are provided solely for internal libc | |
| 38 | * usage to avoid unwanted cancellation points and to differentiate | |
| 39 | * between application locks and libc locks (threads holding the | |
| 40 | * latter can't be allowed to exit/terminate). | |
| 41 | */ | |
| ce0e08e2 | 42 | |
| 82205bfb SS |
43 | #define WR(f, n) \ |
| 44 | __weak_reference(f, _ ## n); \ | |
| 45 | __weak_reference(f, n) | |
| 46 | ||
| 47 | ||
| 48 | WR(stub_zero, pthread_atfork); | |
| 49 | WR(stub_zero, pthread_attr_destroy); | |
| 50 | WR(stub_zero, pthread_attr_get_np); | |
| 51 | WR(stub_zero, pthread_attr_getdetachstate); | |
| 52 | WR(stub_zero, pthread_attr_getguardsize); | |
| 53 | WR(stub_zero, pthread_attr_getinheritsched); | |
| 54 | WR(stub_zero, pthread_attr_getschedparam); | |
| 55 | WR(stub_zero, pthread_attr_getschedpolicy); | |
| 56 | WR(stub_zero, pthread_attr_getscope); | |
| 57 | WR(stub_zero, pthread_attr_getstack); | |
| 58 | WR(stub_zero, pthread_attr_getstackaddr); | |
| 59 | WR(stub_zero, pthread_attr_getstacksize); | |
| 60 | WR(stub_zero, pthread_attr_init); | |
| 61 | WR(stub_zero, pthread_attr_setcreatesuspend_np); | |
| 62 | WR(stub_zero, pthread_attr_setdetachstate); | |
| 63 | WR(stub_zero, pthread_attr_setguardsize); | |
| 64 | WR(stub_zero, pthread_attr_setinheritsched); | |
| 65 | WR(stub_zero, pthread_attr_setschedparam); | |
| 66 | WR(stub_zero, pthread_attr_setschedpolicy); | |
| 67 | WR(stub_zero, pthread_attr_setscope); | |
| 68 | WR(stub_zero, pthread_attr_setstack); | |
| 69 | WR(stub_zero, pthread_attr_setstackaddr); | |
| 70 | WR(stub_zero, pthread_attr_setstacksize); | |
| 71 | WR(stub_zero, pthread_barrier_destroy); | |
| 72 | WR(stub_zero, pthread_barrier_init); | |
| 73 | WR(stub_zero, pthread_barrier_wait); | |
| 74 | WR(stub_zero, pthread_barrierattr_destroy); | |
| 75 | WR(stub_zero, pthread_barrierattr_getpshared); | |
| 76 | WR(stub_zero, pthread_barrierattr_init); | |
| 77 | WR(stub_zero, pthread_barrierattr_setpshared); | |
| 78 | WR(stub_zero, pthread_cancel); | |
| 79 | WR(stub_zero, pthread_cleanup_pop); | |
| 80 | WR(stub_zero, pthread_cleanup_push); | |
| 81 | WR(stub_zero, pthread_cond_broadcast); | |
| 82 | WR(stub_zero, pthread_cond_destroy); | |
| 83 | WR(stub_zero, pthread_cond_init); | |
| 84 | WR(stub_zero, pthread_cond_signal); | |
| 85 | WR(stub_zero, pthread_cond_timedwait); | |
| 86 | WR(stub_zero, pthread_cond_wait); | |
| 87 | WR(stub_zero, pthread_condattr_destroy); | |
| 88 | WR(stub_zero, pthread_condattr_getclock); | |
| 89 | WR(stub_zero, pthread_condattr_getpshared); | |
| 90 | WR(stub_zero, pthread_condattr_init); | |
| 91 | WR(stub_zero, pthread_condattr_setclock); | |
| 92 | WR(stub_zero, pthread_condattr_setpshared); | |
| 93 | WR(stub_zero, pthread_detach); | |
| 94 | WR(stub_true, pthread_equal); | |
| 95 | WR(stub_exit, pthread_exit); | |
| 96 | WR(stub_zero, pthread_getconcurrency); | |
| 97 | WR(stub_zero, pthread_getprio); | |
| 98 | WR(stub_zero, pthread_getschedparam); | |
| 99 | WR(stub_null, pthread_getspecific); | |
| 100 | WR(stub_zero, pthread_join); | |
| 101 | WR(stub_zero, pthread_key_create); | |
| 102 | WR(stub_zero, pthread_key_delete); | |
| 103 | WR(stub_zero, pthread_kill); | |
| 104 | WR(stub_main, pthread_main_np); | |
| 105 | WR(stub_zero, pthread_multi_np); | |
| 106 | WR(stub_zero, pthread_mutex_destroy); | |
| 107 | WR(stub_zero, pthread_mutex_getprioceiling); | |
| 108 | WR(stub_zero, pthread_mutex_init); | |
| 109 | WR(stub_zero, pthread_mutex_lock); | |
| 110 | WR(stub_zero, pthread_mutex_setprioceiling); | |
| 111 | WR(stub_zero, pthread_mutex_timedlock); | |
| 112 | WR(stub_zero, pthread_mutex_trylock); | |
| 113 | WR(stub_zero, pthread_mutex_unlock); | |
| 114 | WR(stub_zero, pthread_mutexattr_destroy); | |
| 115 | WR(stub_zero, pthread_mutexattr_getkind_np); | |
| 116 | WR(stub_zero, pthread_mutexattr_getprioceiling); | |
| 117 | WR(stub_zero, pthread_mutexattr_getprotocol); | |
| 118 | WR(stub_zero, pthread_mutexattr_getpshared); | |
| 119 | WR(stub_zero, pthread_mutexattr_gettype); | |
| 120 | WR(stub_zero, pthread_mutexattr_init); | |
| 121 | WR(stub_zero, pthread_mutexattr_setkind_np); | |
| 122 | WR(stub_zero, pthread_mutexattr_setprioceiling); | |
| 123 | WR(stub_zero, pthread_mutexattr_setprotocol); | |
| 124 | WR(stub_zero, pthread_mutexattr_setpshared); | |
| 125 | WR(stub_zero, pthread_mutexattr_settype); | |
| 126 | WR(stub_zero, pthread_once); | |
| 127 | WR(stub_zero, pthread_resume_all_np); | |
| 128 | WR(stub_zero, pthread_resume_np); | |
| 129 | WR(stub_zero, pthread_rwlock_destroy); | |
| 130 | WR(stub_zero, pthread_rwlock_init); | |
| 131 | WR(stub_zero, pthread_rwlock_rdlock); | |
| 132 | WR(stub_zero, pthread_rwlock_timedrdlock); | |
| 133 | WR(stub_zero, pthread_rwlock_timedwrlock); | |
| 134 | WR(stub_zero, pthread_rwlock_tryrdlock); | |
| 135 | WR(stub_zero, pthread_rwlock_trywrlock); | |
| 136 | WR(stub_zero, pthread_rwlock_unlock); | |
| 137 | WR(stub_zero, pthread_rwlock_wrlock); | |
| 138 | WR(stub_zero, pthread_rwlockattr_destroy); | |
| 139 | WR(stub_zero, pthread_rwlockattr_getpshared); | |
| 140 | WR(stub_zero, pthread_rwlockattr_init); | |
| 141 | WR(stub_zero, pthread_rwlockattr_setpshared); | |
| 142 | WR(stub_self, pthread_self); | |
| 143 | WR(stub_zero, pthread_set_name_np); | |
| 144 | WR(stub_zero, pthread_setcancelstate); | |
| 145 | WR(stub_zero, pthread_setcanceltype); | |
| 146 | WR(stub_zero, pthread_setconcurrency); | |
| 147 | WR(stub_zero, pthread_setprio); | |
| 148 | WR(stub_zero, pthread_setschedparam); | |
| 149 | WR(stub_zero, pthread_setspecific); | |
| 150 | WR(stub_zero, pthread_sigmask); | |
| 151 | WR(stub_zero, pthread_single_np); | |
| 152 | WR(stub_zero, pthread_suspend_all_np); | |
| 153 | WR(stub_zero, pthread_suspend_np); | |
| 154 | WR(stub_zero, pthread_switch_add_np); | |
| 155 | WR(stub_zero, pthread_switch_delete_np); | |
| 156 | WR(stub_zero, pthread_testcancel); | |
| 157 | WR(stub_zero, pthread_timedjoin_np); | |
| 158 | WR(stub_zero, pthread_yield); | |
| 159 | WR(stub_zero, sched_yield); | |
| 160 | WR(stub_zero, sem_close); | |
| 161 | WR(stub_zero, sem_destroy); | |
| 162 | WR(stub_zero, sem_getvalue); | |
| 163 | WR(stub_zero, sem_init); | |
| 164 | WR(stub_zero, sem_open); | |
| 165 | WR(stub_zero, sem_post); | |
| 166 | WR(stub_zero, sem_trywait); | |
| 167 | WR(stub_zero, sem_unlink); | |
| 168 | WR(stub_zero, sem_wait); | |
| 169 | ||
| 170 | ||
| 171 | static int __used | |
| 172 | stub_zero(void) | |
| 173 | { | |
| 174 | return (0); | |
| 175 | } | |
| 176 | ||
| 177 | static void * __used | |
| 178 | stub_null(void) | |
| 17ea2221 MD |
179 | { |
| 180 | return (NULL); | |
| 181 | } | |
| 182 | ||
| 82205bfb SS |
183 | static void * __used |
| 184 | stub_self(void) | |
| 17ea2221 | 185 | { |
| 82205bfb | 186 | static struct {} main_thread; |
| 17ea2221 | 187 | |
| 82205bfb | 188 | return (&main_thread); |
| 17ea2221 MD |
189 | } |
| 190 | ||
| 82205bfb SS |
191 | static int __used |
| 192 | stub_main(void) | |
| ce0e08e2 PA |
193 | { |
| 194 | return (-1); | |
| 195 | } | |
| 196 | ||
| 82205bfb SS |
197 | static int __used |
| 198 | stub_true(void) | |
| 17ea2221 | 199 | { |
| 82205bfb | 200 | return (1); |
| 17ea2221 MD |
201 | } |
| 202 | ||
| 82205bfb SS |
203 | static void __used |
| 204 | stub_exit(void) | |
| 17ea2221 | 205 | { |
| 82205bfb | 206 | exit(0); |
| ce0e08e2 | 207 | } |