Update.
[kopensolaris-gnu/glibc.git] / linuxthreads / ChangeLog
1 2001-02-01  Ulrich Drepper  <drepper@redhat.com>
2
3         * Makefile: Add rules to build crti.o and make it being used in
4         building libpthread.so.
5         * sysdeps/i386/Makefile: New file.
6         * sysdeps/pthread/pt-initfini.c: New file.
7
8         * pthread.c: Cleanups.
9
10 2001-01-28  Andreas Jaeger  <aj@suse.de>
11
12         * oldsemaphore.c (__old_sem_init): Adjust for last change.
13         * sysdeps/pthread/bits/libc-lock.h: Likewise.
14         * spinlock.c: Likewise.
15
16 2001-01-28  Ulrich Drepper  <drepper@redhat.com>
17
18         * sysdeps/pthread/bits/initspin.h: Make all names namespace clean.
19         * sysdeps/unix/sysv/linux/hppa/bits/initspin.h: Likewise.
20         * manager.c: Adjust for namespace cleanup in bits/initspin.h.
21         * pthread.c: Likewise.
22         * spinlock.h: Likewise.
23         * sysdeps/pthread/pthread.h: Likewise.
24
25 2001-01-26  Ulrich Drepper  <drepper@redhat.com>
26
27         * sysdeps/pthread/bits/pthreadtypes.h: Define pthread_attr_t also
28         as struct __pthread_attr_s.
29
30         * semaphore.h (sem_t): Cleanup namespace, rename status and
31         spinlock elements.
32
33 2001-01-13  Jakub Jelinek  <jakub@redhat.com>
34
35         * pthread.c (pthread_onexit_process): Clear
36         __pthread_manager_thread_bos after freeing it.
37         * Makefile (tests): Add ex16.
38         * Examples/ex16.c: New file.
39
40 2001-01-11  Jakub Jelinek  <jakub@redhat.com>
41
42         * Makefile (CFLAGS-pthread.c): Pass -DHAVE_Z_NODELETE if ld supports
43         -z nodelete.
44         * pthread.c (pthread_exit_process): Rename to...
45         (pthread_onexit_process): ...this.
46         (pthread_atexit_process, pthread_atexit_retcode): New.
47         (pthread_initialize): Call __cxa_atexit instead of __cxa_on_exit
48         and only if HAVE_Z_NODELETE is not defined.
49         (__pthread_initialize_manager): Register pthread_atexit_retcode
50         with __cxa_atexit.
51
52 2001-01-11  Ulrich Drepper  <drepper@redhat.com>
53
54         * pthread.c (pthread_initialize): Use __cxs_on_exit not __cxa_atexit.
55
56 2001-01-11  Jakub Jelinek  <jakub@redhat.com>
57
58         * Makefile (tests): Add ex15.
59         * Examples/ex15.c: New test.
60
61 2001-01-08  Ulrich Drepper  <drepper@redhat.com>
62
63         * pthread.c (pthread_exit_process): Free memory allocated for
64         manager stack.
65
66 2000-12-31  Ulrich Drepper  <drepper@redhat.com>
67
68         * manager.c (pthread_alloca_stack): Remove MAP_FIXED from mmap calls.
69         (pthread_free): Always unmap the stack.  It's safe now that we don't
70         use MAP_FIXED to allocate stacks.
71
72 2000-12-31  Ulrich Drepper  <drepper@redhat.com>
73
74         * sysdeps/powerpc/pspinlock.c: Don't include pt-machine.h here.
75
76         * manager.c (pthread_allocate_stack): Prepare for removal of MAP_FIXED.
77
78 2000-11-15  Wolfram Gloger  <wg@malloc.de>
79
80         * manager.c (pthread_free): [!FLOATING_STACKS]: Only remap the
81         stack to PROT_NONE, don't unmap it, avoiding collisions with malloc.
82
83 2000-12-27  Andreas Jaeger  <aj@suse.de>
84
85         * Examples/ex13.c: Make local functions static.
86         * ecmutex.c: Likewise.
87         * joinrace.c: Likewise.
88         * Examples/ex14.c: Likewise.
89
90         * Examples/ex2.c: Make local functions static; reformat.
91         * Examples/ex1.c: Likewise.
92         * Examples/ex4.c: Likewise.
93         * Examples/ex5.c: Likewise.
94         * Examples/ex7.c: Likewise.
95
96         * oldsemaphore.c: Add prototypes to shut up GCC.
97         * pt-machine.c: Likewise.
98
99         * weaks.c: Add prototype for pthread_exit.
100
101         * internals.h: Add some prototypes, format prototypes and add
102         missing externs.
103         Move __libc_waitpid prototype to include/sys/wait.h.
104
105         * rwlock.c: Include <bits/libc-lock.h> for prototypes.
106         * mutex.c: Likewise.
107         * specific.c: Likewise.
108         * ptfork.c: Likewise.
109
110         * lockfile.c: Include internals.h to get prototypes.
111         * events.c: Likewise.
112         * sysdeps/alpha/pspinlock.c: Likewise.
113         * sysdeps/arm/pspinlock.c: Likewise.
114         * sysdeps/hppa/pspinlock.c: Likewise.
115         * sysdeps/i386/pspinlock.c: Likewise.
116         * sysdeps/ia64/pspinlock.c: Likewise.
117         * sysdeps/m68k/pspinlock.c: Likewise.
118         * sysdeps/mips/pspinlock.c: Likewise.
119         * sysdeps/powerpc/pspinlock.c: Likewise.
120         * sysdeps/s390/pspinlock.c: Likewise.
121         * sysdeps/sh/pspinlock.c: Likewise.
122         * sysdeps/sparc/sparc32/pspinlock.c: Likewise.
123         * sysdeps/sparc/sparc32/sparcv9/pspinlock.c: Likewise.
124         * sysdeps/sparc/sparc64/pspinlock.c: Likewise.
125
126 2000-12-27  Ulrich Drepper  <drepper@redhat.com>
127
128         * attr.c (__pthread_attr_setstack): Fix setting of __stackaddr element.
129         (__pthread_attr_getstack): Return correct address.
130         Add warnings for using pthread_attr_getstackaddr and
131         pthread_attr_setstackaddr.
132
133 2000-12-26  Ulrich Drepper  <drepper@redhat.com>
134
135         * Examples/ex6.c (test_thread): Make static.
136         * Examples/ex12.c (test_thread): Make static and add noreturn
137         attribute.
138
139 2000-12-18  Jes Sorensen  <jes@linuxcare.com>
140
141         * linuxthreads/sysdeps/ia64/pt-machine.h: __compare_and_swap
142         and compare_and_swap_with_release_semantics returns int not long.
143
144 2000-12-17  Andreas Jaeger  <aj@suse.de>
145
146         * sysdeps/s390/pt-machine.h (testandset): Use long int as return
147         value.
148         * sysdeps/arm/pt-machine.h (testandset): Likewise.
149         * sysdeps/hppa/pt-machine.h (testandset): Likewise.
150         * sysdeps/m68k/pt-machine.h (testandset): Likewise.
151         * sysdeps/sh/pt-machine.h (testandset): Likewise.
152         * sysdeps/sparc/sparc32/pt-machine.h (testandset): Likewise.
153         * sysdeps/sparc/sparc64/pt-machine.h (testandset): Likewise.
154
155 2000-12-17  Ulrich Drepper  <drepper@redhat.com>
156
157         * sysdeps/i386/pt-machine.h (testandset): Adjust for prototype change.
158         * sysdeps/i386/i686/pt-machine.h (testandset): Likewise.
159
160 2000-12-17  Andreas Jaeger  <aj@suse.de>
161
162         * internals.h: Add prototypes for testandset and
163         __compare_and_swap to shut up gcc warnings.
164
165 2000-12-06  Wolfram Gloger  <wg@malloc.de>
166
167         * join.c (pthread_detach): Allow case where the thread has already
168         terminated.
169
170 2000-12-05  Andreas Jaeger  <aj@suse.de>
171
172         * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Don't set mips2.
173         * sysdeps/mips/pt-machine.h (testandset): Likewise.
174         (__compare_and_swap): Likewise.
175         Patches by Maciej W. Rozycki <macro@ds2.pg.gda.pl>.
176
177 2000-11-20  Jakub Jelinek  <jakub@redhat.com>
178
179         * Examples/ex3.c (main): Cast int to long before casting to void *.
180         (search): Cast void * to long, not int.
181         * Examples/ex8.c (main, thread): Similarly.
182         * Examples/ex11.c (main): Similarly.
183         * Examples/ex14.c (worker, do_test): Similarly.
184         * ecmutex.c (worker, do_test): Similarly.
185         (nlocks): Cast to int.
186
187 2000-11-08  Bruce Mitchener  <bruce@cubik.org>
188
189         * linuxthreads.texi:  Add documentation for pthreads attributes
190         guardsize, stackaddr, stacksize, and stack.  Fix typo in previous
191         patch.  Document pthread_[sg]etconcurrency().  Mark
192         pthread_mutexattr_[sg]ettype() as POSIX rather than GNU.
193
194 2000-11-07  Ulrich Drepper  <drepper@redhat.com>
195
196         * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_MESSAGE_PASSING):
197         Don't define it.
198         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
199         Reported by Christopher Yeoh <cyeoh@linuxcare.com.au>.
200
201 2000-11-06  Ulrich Drepper  <drepper@redhat.com>
202
203         * cancel.c (pthread_cancel): Always set p_canceled, even if we are
204         not doing it right now.
205         Reported by Kaz Kylheku <kaz@ashi.footprints.net>.
206
207 2000-10-30  Ulrich Drepper  <drepper@redhat.com>
208
209         * Examples/ex4.c (main): Don't use exit() to avoid warning with
210         broken compilers.
211
212 2000-10-29  Ulrich Drepper  <drepper@redhat.com>
213
214         * attr.c (__pthread_attr_setguardsize): Don't round guardsize
215         here.  Reported by Bruce Mitchener <bruce@cubik.org>.
216
217         * linuxthreads.texi: Changes terminology to 'type' from 'kind' when
218         discussing mutexes. (As per the Unix98 name for the API.)
219         Changes documentation for pthread_mutexattr_setkind_np() and
220         pthread_mutexattr_getkind_np() over to the Unix98 APIs for the
221         same: pthread_mutexattr_settype() and pthread_mutexattr_gettype().
222         Changes references to PTHREAD_MUTEXATTR_FAST_NP to
223         PTHREAD_MUTEXATTR_ADAPTIVE_NP.
224         Begins to introduce discussion of the ``timed'' mutex type.  This
225         discussion is currently incomplete.
226         Patch by Bruce Mitchener <bruce@cubik.org>.
227
228 2000-10-26  Kazumoto Kojima  <kkojima@rr.iij4u.or.jp>
229             Yutaka Niibe  <gniibe@chroot.org>
230
231         * sysdeps/sh/pt-machine.h (testandset): Since the operand of TAS.B
232         has restrictions, use register.
233
234 2000-10-23  Andreas Schwab  <schwab@suse.de>
235
236         * Examples/ex14.c (TIMEOUT): Override default timeout.
237
238 2000-10-16  Ulrich Drepper  <drepper@redhat.com>
239
240         * specific.c: Protect tsd array modification in thread data
241         structures by getting the thread lock in pthread_key_delete and
242         __pthread_destroy_specifics.
243         Patch by Wolfram Gloger <Wolfram.Gloger@dent.med.uni-muenchen.de>.
244
245 2000-10-12  Alan Modra <alan@linuxcare.com.au>
246
247         * sysdeps/pthread/bits/initspin.h: New file.
248         * spinlock.h: Move LOCK_INITIALIZER definition to <bits/initspin.h>.
249         (__pthread_init_lock): Initialize lock with LT_SPINLOCK_INIT.
250         (__pthread_alt_init_lock): Likewise.
251         (__pthread_alt_trylock): Release lock with LT_SPINLOCK_INIT.
252
253 2000-10-12  David Huggins-Daines  <dhd@linuxcare.com>
254
255         * oldsemaphore.c (__old_sem_init): Release lock with
256         LT_SPINLOCK_INIT, not zero.
257         * spinlock.c (__pthread_unlock): Likewise.
258         (__pthread_alt_lock): Likewise.
259         (__pthread_alt_timedlock): Likewise.
260         (__pthread_alt_unlock): Likewise.
261         * sysdeps/pthread/bits/libc-lock.h: Initialize locks with
262         LT_SPINLOCK_INIT if it is non-zero.  Likewise for init-once flags.
263         * sysdeps/pthread/pthread.h: Include bits/initspin.h.  Use
264         LT_SPINLOCK_INIT do initialize spinlocks not 0.
265
266 2000-10-12  David Huggins-Daines <dhd@linuxcare.com>
267
268         * shlib-versions: Add version definitions for hppa-linux.
269
270 2000-10-12  Alan Modra <alan@linuxcare.com.au>
271
272         * sysdeps/hppa/pspinlock.c: New file.
273         * sysdeps/hppa/pt-machine.h: New file.
274         * sysdeps/unix/sysv/linux/hppa/bits/initspin.h: New file.
275
276 2000-10-05  Jakub Jelinek  <jakub@redhat.com>
277
278         * mutex.c (__pthread_mutex_destroy): Correct test of
279         busy mutex for mutexes using alternate fastlocks.
280         Patch by dtc@cmucl.cons.org.
281
282 2000-09-28  Martin Schwidefsksy    <schwidefsky@de.ibm.com>
283
284         * sysdeps/s390/pt-machine.h: Make %a0 the thread register.
285
286 2000-09-28  Ulrich Drepper  <drepper@redhat.com>
287
288         * mutex.c (__pthread_mutex_unlock): For PTHREAD_MUTEX_RECURSIVE_NP
289         test for owner first.
290         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
291
292         * cancel.c (pthread_cancel): Don't do anything if cancelation is
293         disabled.
294
295 2000-09-26  Ulrich Drepper  <drepper@redhat.com>
296
297         * spinlock.h (__pthread_set_own_extricate_if): Optimize a bit.
298         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
299
300         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Remove
301         _POSIX_MONOTONIC_CLOCK.
302
303         * spinlock.h (__pthread_set_own_extricate_if): Add back locking
304         and explain why.
305
306 2000-09-20  Andreas Jaeger  <aj@suse.de>
307
308         * pthread.c [!__ASSUME_REALTIME_SIGNALS]: Make inclusion of
309         "testrtsig.h" conditional.
310
311 2000-09-11  Ulrich Drepper  <drepper@redhat.com>
312
313         * sysdeps/pthread/pthread.h: Declare pthread_attr_getstack and
314         pthread_attr_setstack.
315         * Versions [libpthread] (GLIBC_2.2): Export pthread_attr_getstack and
316         pthread_attr_setstack.
317         * attr.c (pthread_attr_getstack, pthread_attr_setstack): New functions.
318
319 2000-09-05  Ulrich Drepper  <drepper@redhat.com>
320
321         * Examples/ex14.c: New file.
322         * Makefile (tests): Add ex14.
323
324         * mutex.c (__pthread_mutex_unlock): Correct test for already unlocked
325         mutex.  Patch by dtc@cmucl.cons.org.
326
327         * ecmutex.c: New file.
328         * Makefile (tests): Add ecmutex.
329
330 2000-09-04  H.J. Lu  <hjl@gnu.org>
331
332         * attr.c (__pthread_attr_setguardsize): Use page_roundup
333         instead of roundup to round up to the page size.
334
335 2000-09-03  Mark Kettenis  <kettenis@gnu.org>
336
337         * manager.c (pthread_exited): Correctly report event as TD_REAP
338         instead of TD_DEATH.  Fix comments.
339
340 2000-09-03  Ulrich Drepper  <drepper@redhat.com>
341
342         * spinlock.h (testandset): Add cast to avoid warning.
343         Patch by Franz Sirl <Franz.Sirl-kernel@lauterbach.com>.
344
345 2000-09-02  Andreas Jaeger  <aj@suse.de>
346
347         * sysdeps/pthread/timer_routines.c: Include stdlib.h for abort
348         prototype.
349
350 2000-09-01  Ulrich Drepper  <drepper@redhat.com>
351
352         * sysdeps/pthread/bits/stdio-lock.h (_IO_cleanup_region_start):
353         Fix typo in last patch (_mode -> _flags).
354
355         * sysdeps/pthread/bits/stdio-lock.h (_IO_cleanup_region_start):
356         Provide definition which respects _IO_USER_LOCK flag.
357
358 2000-08-30  Ulrich Drepper  <drepper@redhat.com>
359
360         * manager.c (pthread_allocate_stack): Clear descriptor only if not
361         mmaped.
362
363 2000-08-25  Ulrich Drepper  <drepper@redhat.com>
364
365         * Makefile: Add rules to build and run unload.
366         * unload.c: New file.
367
368         * pthread.c (pthread_exit_process): Move thread_self use inside `if'.
369
370         * sysdeps/pthread/pthread.h
371         (PTHREAD_ADAPTIVE_MUTEX_INITIALIZER_NP): Defined.
372         (PTHREAD_ERRORCHECK_MUTEX_INITIALIZER_NP: Defined.
373
374 2000-08-24  Andreas Jaeger  <aj@suse.de>
375
376         * Examples/ex13.c: Include <string.h> for strerror prototype and
377         <stdlib.h> for abort prototype.
378         (pthr_cond_signal_mutex): Rewrite to silence GCC.
379         (thread_start): Remove unused variable err.
380         (main): Silence GCC warnings.
381
382 2000-08-22  Andreas Jaeger  <aj@suse.de>
383
384         * Examples/ex13.c: New test by Kurt Garloff <garloff@suse.de>.
385
386         * Makefile (tests): Add ex13.
387
388 2000-08-20  Ulrich Drepper  <drepper@redhat.com>
389
390         * semaphore.h: Add restrict where required by AGd4.
391         * sysdeps/pthread/pthread.h: Likewise.
392         * sysdeps/pthread/unix/sysv/linux/bits/sigthread.h: Likewise.
393
394 2000-08-15  Ulrich Drepper  <drepper@redhat.com>
395
396         * Makefile (tests): Add ex12.  Add rule to build it.
397         * Examples/ex12.c: New file.
398
399 2000-08-13  Ulrich Drepper  <drepper@redhat.com>
400
401         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define _POSIX_SEMAPHORES
402         even though the implementation is not quite complete (but it reports
403         it).  Define _POSIX_MESSAGE_PASSING to -1.
404         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
405
406 2000-08-12  Andreas Jaeger  <aj@suse.de>
407
408         * sysdeps/mips/pt-machine.h (testandset): Add .set mips2 for
409         assembler.
410         (__compare_and_swap): Likewise.
411         * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Likewise.
412
413 2000-08-10  Ulrich Drepper  <drepper@redhat.com>
414
415         * pthread.c (__pthread_initial_thread): Initialize p_errnop and
416         p_h_errnop correctly and not to NULL.
417
418 2000-08-05  Ulrich Drepper  <drepper@redhat.com>
419
420         * Banner: Bump version number to 0.9.
421
422 2000-08-04  Ulrich Drepper  <drepper@redhat.com>
423
424         * Makefile (tests): Add tststack.  Add rule to build the program.
425         * tststack.c: New file.
426
427         * internals.h: Declare __pthread_max_stacksize.
428         * pthread.c (__pthread_max_stacksize): New variable.
429         (__pthread_initialize_manager): Determine __pthread_initialize_manager
430         value.
431         * manager.c (thread_segment): Return always NULL if FLOATING_STACKS.
432         (pthread_allocate_stack): Allow kernel to choose stack address if
433         FLOATING_STACKS.  This also handles variable-sized stacks.
434         Always allocate stack and guardpage together.  Use mprotect to
435         change guardpage access.
436         * sysdeps/i386/useldt.h: Define FLOATING_STACKS and
437         ARCH_STACK_MAX_SIZE.
438
439         * attr.c (__pthread_attr_setstacksize): Also test value against
440         upper limit.
441
442         * manager.c (__pthread_nonstandard_stacks): Define only if
443         THREAD_SELF is not defined.
444         (pthread_allocate_stack): Always initialize gardaddr to a correct
445         value.
446         (pthread_handle_create): Unmap thread with one call.
447         (pthread_free): Remove test for initial thread before removing stack.
448         Unmap stack with one call.
449
450         * pthread.c (__pthread_initial_thread): Initialize p_userstack to
451         1 to avoid removing the stack.
452
453 2000-07-27  Jes Sorensen  <jes@linuxcare.com>
454
455         * sysdeps/ia64/pspinlock.c (__pthread_spin_lock): Add
456         load of spin lock to prime the cache before the atomic compare and
457         exchange operation (cmpxchg4). This avoids the spinning on the
458         cmpxchg4 instruction and reduces movement of the cache line back
459         and forth between the processors (explanation by Asis K. Mallick
460         from Intel). This basically makes the implementation operate the
461         same as the Linux kernel implementation.
462
463         * shlib-versions: Use GLIBC_2_2 for Linux/ia64.
464         * sysdeps/ia64/pspinlock.c: New file.
465
466 2000-08-03  Ulrich Drepper  <drepper@redhat.com>
467
468         * pthread.c: Move definition of __pthread_set_own_extricate_if...
469         * spinlock.h: ...here.  Remove locking.
470         * internals.h: Remove __pthread_set_own_extricate_if prototype.
471
472         * rwlock.c: Use THREAD_GETMEM And THREAD_SETMEM.
473         (rwlock_rd_extricate_func): Don't determine self, let
474         __pthread_lock do it.
475         (rwlock_wr_extricate_func): Likewise.
476         (rwlock_have_already): Optimize *pself handling a bit.
477
478         * mutex.c: Use __builtin_expect.
479         * pthread.c: Likewise.
480
481 2000-08-02  Andreas Jaeger  <aj@suse.de>
482
483         * sysdeps/s390/pspinlock.c: New file.
484         * sysdeps/s390/pt-machine.h: New file.
485         Patches by Martin Schwidefsky <schwidefsky@de.ibm.com>.
486
487 2000-07-12  Maciej W. Rozycki  <macro@ds2.pg.gda.pl>
488
489         * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Implement for
490         R3K.
491         * sysdeps/mips/pt-machine.h (testandset): Likewise.
492
493 2000-07-26  Andreas Jaeger  <aj@suse.de>
494
495         * pthread.c: Initialize p_sem_avail.
496
497 2000-07-25  Ulrich Drepper  <drepper@redhat.com>
498
499         * internals.h (struct __pthread_descr_struct): Add p_sem_avail.
500         * semaphore.c: Handle spurious wakeups.
501
502         * sysdeps/pthread/pthread.h: Add back PTHREAD_MUTX_FAST_NP as an alias
503         for PTHREAD_MUTEX_ADAPTIVE_NP for source code compatibility.
504
505         * pthread.c (__pthread_set_own_extricate): Use THREAD_GETMEM.
506         (__pthread_wait_for_restart): Likewise.
507
508         * condvar.c (pthread_cond_wait): Also check whether thread is
509         cancelable before aborting loop.
510         (pthread_cond_timedwait): Likewise.
511
512         * signals.c (pthread_sighandler): Remove special code to restrore
513         %gs on x86.
514         (pthread_sighandler_t): Likewise.
515
516 2000-07-25  Mark Kettenis  <kettenis@gnu.org>
517
518         * internals.h (__RES_PTHREAD_INTERNAL): Remove define.
519         * pthread.c: Include <resolv.h>.
520         (_res): Undefine.  Add extern declaration.
521
522 2000-07-24  Ulrich Drepper  <drepper@redhat.com>
523
524         * pthread.c (__pthread_initial_thread): Update initializer.
525         (__pthread_manager_thread): Likewise.
526         (pthread_initialize): Move setrlimit call to...
527         (__pthread_initialize_manager): ...here.
528         (__pthread_reset_main_thread): Reset also soft limit on stack size.
529
530         * condvar.c: Handle spurious wakeups.  [PR libc/1749].
531         * internals.h (struct _pthread_descr_struct): Add p_condvar_avail.
532
533 2000-07-21  Ulrich Drepper  <drepper@redhat.com>
534
535         * spinlock.h: If IMPLEMENT_TAS_WITH_CAS is defined use
536         __compare_and_swap to define testandset.
537         * sysdeps/powerpc/pt-machine.h: Add volatile to asms.
538         Define IMPLEMENT_TAS_WITH_CAS.
539
540 2000-07-20  Ulrich Drepper  <drepper@redhat.com>
541
542         * Makefile: Pass -z nodelete to linker for libpthread.so
543         generation if it understand this option.
544
545 2000-07-18  Mark Kettenis  <kettenis@gnu.org>
546
547         * manager.c (pthread_handle_create): Remove initialization of
548         new_thread->p_res._sock.
549
550 2000-07-19  Kaz Kylheku  <kaz@ashi.footprints.net>
551
552         Bugfixes to the variant of the code for machines with no compare
553         and swap.
554
555         * spinlock.c (__pthread_alt_lock, __pthread_alt_timedlock): Wait
556         node was not being properly enqueued, due to failing to update
557         the lock->__status field.
558
559         * spinlock.c (__pthread_alt_timedlock): The oldstatus variable was
560         being set inappropriately, causing the suspend function to be called
561         with a null self pointer and crash.
562
563 2000-07-18  Ulrich Drepper  <drepper@redhat.com>
564
565         * spinlock.h (__pthread_alt_trylock): Fix code used if no
566         compare&swap is available.
567
568         * spinlock.h (__pthread_trylock): Use __compare_and_swap, not
569         compare_and_swap.
570
571         * pthread.c (pthread_initialize): Don't use sysconf to determine
572         whether the machine has more than one processor.
573
574         * spinlock.c (__pthread_alt_timedlock): Add back one of the
575         removed thread_self calls.
576
577 2000-07-18  Kaz Kylheku  <kaz@ashi.footprints.net>
578
579         * spinlock.c (__pthread_alt_lock, __pthread_alt_timedlock): Changed
580         __compare_and_swap to compare_and_swap in code which assumes
581         compare swap is available.
582
583 2000-07-18  Kaz Kylheku  <kaz@ashi.footprints.net>
584
585         * spinlock.c (__pthread_alt_lock, __pthread_alt_timedlock): Fixed
586         bug whereby thr field of waitnode structure would not be correctly
587         set unless a null self pointer is passed to the functions.
588         Eliminated redundant calls to thread_self().
589
590 2000-07-18  Jakub Jelinek  <jakub@redhat.com>
591
592         * pthread.c (__pthread_initialize_manager): Lock
593         __pthread_manager_thread.p_lock before calling clone.
594
595 2000-05-05  H.J. Lu  <hjl@gnu.org>
596
597         * sysdeps/ia64/pt-machine.h (__compare_and_swap): Change it to
598         have acquire semantics.
599         (__compare_and_swap_with_release_semantics): New inline
600         function.
601         (HAS_COMPARE_AND_SWAP_WITH_RELEASE_SEMANTICS): New macro.
602
603 2000-01-28  Hans Boehm  <hboehm@exch.hpl.hp.com>
604
605         * manager.c: Fix the problem with signals at startup.
606         Change the way that thread stacks are allocated on IA64.
607         Clean up some of the guard page allocation stuff.
608
609 1999-12-19  H.J. Lu  <hjl@gnu.org>
610
611         * internals.h (page_roundup): New.
612         * attr.c (__pthread_attr_setguardsize); Use page_roundup
613         instead of roundup.
614         * manager.c (pthread_allocate_stack): Make sure guardaddr is
615         page aligned with page_roundup if NEED_SEPARATE_REGISTER_STACK
616         is define.
617
618 1999-12-17  Hans Boehm  <hboehm@exch.hpl.hp.com>
619
620         * manager.c (pthread_allocate_stack): Unmap the stack top
621         if failed to map the stack bottom.
622         Fix the guard page.
623         (pthread_free): Fix the guard page.
624
625         * pthread.c (pthread_initialize): Set rlimit correctly for
626         NEED_SEPARATE_REGISTER_STACK.
627
628 1999-12-16  H.J. Lu  <hjl@gnu.org>
629
630         * pthread.c (__pthread_initialize_manager): Pass
631         __pthread_manager_thread_bos instead of
632         __pthread_manager_thread_tos to __clone2.
633
634 1999-12-16  H.J. Lu  <hjl@gnu.org>
635
636         * manager.c (pthread_allocate_stack): Correct the calculation
637         of "new_thread_bottom". Remove MAP_GROWSDOWN from mmap for
638         stack bottom.
639
640 1999-12-13  H.J. Lu  <hjl@gnu.org>
641
642         * sysdeps/ia64/pt-machine.h (__compare_and_swap): Added a stop
643         bit after setting ar.ccv.
644
645 1999-12-12  H.J. Lu  <hjl@gnu.org>
646
647         * manager.c (pthread_allocate_stack): Make the starting
648         address of the stack bottom page aligned. FIXME: it may
649         need changes in other places.
650         (pthread_handle_create): Likewise.
651
652 1999-12-11  Hans Boehm  <hboehm@exch.hpl.hp.com>
653
654         * manager.c (pthread_allocate_stack): Handle
655         NEED_SEPARATE_REGISTER_STACK.
656         (pthread_handle_create): Likewise.
657         * pthread.c (__pthread_initialize_manager): Likewise.
658
659         * sysdeps/ia64/pt-machine.h: Use r13 for thread pointer.
660
661 1999-12-02  H.J. Lu  <hjl@gnu.org>
662
663         * sysdeps/ia64/pt-machine.h: New.
664
665 2000-07-13  Ulrich Drepper  <drepper@redhat.com>
666
667         * wrapsyscall.c: Mark non-__ protected names as weak.
668         PR libc/1466.
669
670 2000-07-12  Bruno Haible  <haible@clisp.cons.org>
671
672         * Examples/ex8.c: Include <sys/wait.h>, not <wait.h>.
673
674 2000-07-12  Ulrich Drepper  <drepper@redhat.com>
675
676         * spinlock.c: Fix code for TEST_FOR_COMPARE_AND_SWAP being defined.
677         Add tests also to new alternative spinlock implementation.
678         * spinlock.h: Likewise.
679         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
680
681 2000-07-06  Ulrich Drepper  <drepper@redhat.com>
682
683         * Version: Export __sigaction.
684         * signals.c: Define __sigaction alias.  Use __libc_sigaction instead
685         of __sigaction.
686         * pthread.c: Use __libc_sigaction instead of __sigaction.
687
688         * condvar.c: Implement pthread_condattr_getpshared and
689         pthread_condattr_setpshared.
690         * mutex.c: Implement pthread_mutexattr_getpshared and
691          pthread_mutexattr_setpshared.
692         * Versions: Export new functions.
693         * sysdeps/pthread/pthread.h: Add prototypes for new functions.
694
695         * rwlock.c (pthread_rwlockattr_init): Use PTHREAD_PROCESS_PRIVATE.
696         (pthread_rwlockattr_setpshared): Fail if PTHREAD_PROCESS_PRIVATE
697         is not selected.
698
699 2000-07-04  Greg McGary  <greg@mcgary.org>
700
701         * sysdeps/pthread/bits/libc-lock.h: Remove BP_SYM from
702         pragmas.  Include bp-sym.h only if _LIBC.
703
704 2000-07-04  Ulrich Drepper  <drepper@redhat.com>
705
706         * spinlock.c (__pthread_unlock): Properly place write barrier.
707         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
708
709 2000-07-03  Ulrich Drepper  <drepper@redhat.com>
710
711         * spinlock.c: Replace fast spinlocks by adaptive spinlocks which are
712         faster on SMP systems.  No more emulation of compare&swap for adaptive
713         spinlocks.
714         * spinlock.h: Likewise.
715         * sysdeps/pthread/pthread.h: Shuffle PTHREAD_MUTEX_* values around.
716         Replace fast with adaptive mutex.
717         * mutex.c: Rewrite for replacement of fast by adaptive mutex.
718         * condvar.c: Likewise.
719         * pthread.c: Define and initialize __pthread_smp_kernel variable.
720         * internals.h: Declare __pthread_smp_kernel.
721         * sysdeps/pthread/bits/pthreadtypes.h: Update comment of
722         _pthread_fastlock structure.
723         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
724
725         * pthread.c: Remove initialization to zero from global variables.
726
727 2000-06-29  Jakub Jelinek  <jakub@redhat.com>
728
729         * shlib-versions: Make sparc64 GLIBC_2.2+ only.
730
731 2000-06-28  Greg McGary  <greg@mcgary.org>
732
733         * weaks.c: Wrap BP_SYM () around weak extern declarations of
734         pthread functions that have pointers in their return+arg signatures.
735
736 2000-06-27  Greg McGary  <greg@mcgary.org>
737
738         * sysdeps/pthread/bits/libc-lock.h: Wrap BP_SYM () around weak
739         extern declarations of pthread functions that have pointers in
740         their return+arg signatures.
741
742 2000-06-26  Ulrich Drepper  <drepper@redhat.com>
743
744         * Makefile (tests): Add ex11.  Add rules to build it.
745         * Examples/ex11.c: New file.
746         * rwlock.c: Fix complete braindamaged previous try to implement
747         timedout functions.
748
749         * spinlock.c: Pretty print.
750
751 2000-06-25  Ulrich Drepper  <drepper@redhat.com>
752
753         * Makefile (tests): Add ex10.  Add rules to build it.
754         * Versions [GLIBC_2.2] (libpthread): Add pthread_mutex_timedlock,
755         pthread_rwlock_timedrdlock, and pthread_rwlock_timedwrlock.
756         * condvar.c (pthread_cond_wait): Allow mutex of kind
757         PTHREAD_MUTEX_TIMED_NP.
758         (pthread_cond_timedwait_relative): Likewise.
759         * mutex.c (__pthread_mutex_init): Default is PTHREAD_MUTEX_TIMED_NP.
760         (__pthread_mutex_trylock): Use __pthread_alt_trylock for
761         PTHREAD_MUTEX_ERRORCHECK_NP.  Handle PTHREAD_MUTEX_TIMED_NP.
762         (__pthread_mutex_lock): Use __pthread_alt_lock for
763         PTHREAD_MUTEX_ERRORCHECK_NP.  Handle PTHREAD_MUTEX_TIMED_NP.
764         (__pthread_mutex_timedlock): New function.
765         (__pthread_mutex_unlock): Use __pthread_alt_unlock for
766         PTHREAD_MUTEX_ERRORCHECK_NP.  Handle PTHREAD_MUTEX_TIMED_NP.
767         (__pthread_mutexattr_init): Use PTHREAD_MUTEX_TIMED_NP.
768         (__pthread_mutexattr_settype): Allow PTHREAD_MUTEX_TIMED_NP.
769         * spinlock.c: Implement alternate fastlocks.
770         * spinlock.h: Add prototypes.
771         * Examples/ex10.c: New file.
772         * sysdeps/pthread/pthread.h: Add prototypes for new functions.
773         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
774
775         * rwlock.c (__pthread_rwlock_rdlock): Optimize loop a bit.
776         (__pthread_rwlock_timedrdlock): New function.
777         (__pthread_rwlock_timedwrlock): New function.
778         Use laternate fastlock function everywhere.
779
780 2000-06-21  Andreas Jaeger  <aj@suse.de>
781
782         * sysdeps/pthread/timer_routines.c: Include <string.h> for memset
783         prototype.
784
785         * join.c: Include <stdlib.h> for exit prototype.
786
787 2000-06-20  Ulrich Drepper  <drepper@redhat.com>
788
789         * sysdeps/i386/useldt.h: Include <stdlib.h>.
790
791         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define _POSIX_BARRIERS.
792         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
793
794         * Makefile (libpthread-routines): Add barrier.
795         (tests): Add ex9.  Add rule to build ex9.
796         * Versions: Export barrier functions.
797         * barrier.c: New file.
798         * Examples/ex9.c: New file.
799         * sysdeps/pthread/pthread.h: Add barrier data types and declarations.
800         * sysdeps/pthread/bits/pthreadtypes.h: Likewise.
801         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
802
803 2000-06-19  H.J. Lu  <hjl@gnu.org>
804
805         * spinlock.h (HAS_COMPARE_AND_SWAP): Defined if
806         HAS_COMPARE_AND_SWAP_WITH_RELEASE_SEMANTICS is defined.
807         (compare_and_swap_with_release_semantics): New. Default to
808         compare_and_swap if HAS_COMPARE_AND_SWAP_WITH_RELEASE_SEMANTICS
809         is not defined.
810
811         * spinlock.c (__pthread_unlock): Call
812         compare_and_swap_with_release_semantics () instead of
813         compare_and_swap ().
814
815 2000-06-19  Ulrich Drepper  <drepper@redhat.com>
816
817         * sysdeps/pthread/timer_create.c: Use _set_errno instead of assigning
818         to errno directly.
819         * sysdeps/pthread/timer_delete.c: Likewise.
820         * sysdeps/pthread/timer_getoverr.c: Likewise.
821         * sysdeps/pthread/timer_gettime.c: Likewise.
822         * sysdeps/pthread/timer_settime.c: Likewise.
823
824 2000-06-13  Kaz Kylheku  <kaz@ashi.footprints.net>
825
826         Timer nodes are now reference counted, and can be marked
827         as deleted. This allows for the safe release of the global mutex
828         in the middle without losing the timer being operated on.
829
830         * sysdeps/pthread/posix-timer.h (struct timer_node):  The inuse
831         member is now an enum with three values, so that an intermediate
832         state can be represented (deleted but not free for reuse yet).
833         New refcount member added.
834         * sysdeps/pthread/timer_routines.c: Likewise.
835
836         * sysdeps/pthread/posix-timer.h (timer_addref, timer_delref,
837         timer_valid): New inline functions added.
838
839         * sysdeps/pthread/timer_gettime.c (timer_gettime): Function
840         restructured, recursive deadlock bug fixed.
841
842         * sysdeps/pthread/timer_gettime.c (timer_gettime): Uses new
843         timer_addref to ensure that timer won't be deleted while mutex is not
844         held. Also uses timer_invalid to perform validation of timer handle.
845         * sysdeps/pthread/timer_settime.c (timer_settime): Likewise.
846         * sysdeps/pthread/timer_getoverr.c (timer_getoverrun): Likewise.
847
848 2000-06-14  Ulrich Drepper  <drepper@redhat.com>
849
850         * shlib-versions: Add entry for SH.
851         Patch by Kaz Kojima <kkojima@rr.iij4u.or.jp>.
852
853 2000-06-13  Kaz Kylheku  <kaz@ashi.footprints.net>
854
855         A few optimizations.  Got rid of unnecessary wakeups of timer threads,
856         tightened up some critical regions and micro-optimized some list
857         manipulation code.
858
859         * sysdeps/pthread/timer_routines.c (__timer_thread_queue_timer):
860         Returns int value now to indicate whether timer was queued at head.
861         * sysdeps/pthread/posix-timer.h: Likewise.
862         * sysdeps/pthread/timer_settime.c (timer_settime): Takes advantage of
863         new return value from __timer_thread_queue_timer to avoid waking
864         up timer thread unnecessarily.
865
866         * sysdeps/pthread/posix-timer.h (timer_id2ptr): No longer checks
867         inuse flag, because this requires mutex to be held.  Callers updated
868         to do the check when they have the mutex.
869         * sysdeps/pthread/timer_getoverr.c: Add check for inuse here.
870
871         * sysdeps/pthread/timer_settime.c (timer_settime): Tighter critical
872         regions: avoids making system calls while holding timer mutex, and
873         a few computations were moved outside of the mutex as well.
874         * sysdeps/pthread/timer_gettime.c (timer_gettime): Likewise.
875
876         * sysdeps/pthread/posix-timer.h (list_unlink_ip): Function name changed
877         to list_unlink_ip, meaning idempotent.  Pointer manipulation
878         changed to get better better code out of gcc.
879         * sysdeps/pthread/timer_routines.c (list_unlink): Non-idempotent
880         version of list_unlink added here.
881         * sysdeps/pthread/timer_delete.c: Use appropriate list unlink
882         function in all places: idempotent one for timers, non-idempotent
883         one for thread nodes.
884         * sysdeps/pthread/timer_settime: Likewise.
885         * sysdeps/pthread/timer_routines.c: Likewise.
886
887 2000-06-13  Ulrich Drepper  <drepper@redhat.com>
888
889         * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_TIMERS): Define.
890         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
891
892         * sysdeps/pthread/Makefile: Remove tests definition.
893
894 2000-06-12  Kazumoto Kojima  <kkojima@rr.iij4u.or.jp>
895             Yutaka Niibe  <gniibe@chroot.org>
896
897         * sysdeps/sh/pspinlock.c: New file.
898         * sysdeps/sh/pt-machine.h: New file.
899
900 2000-06-12  Ulrich Drepper  <drepper@redhat.com>
901
902         * Makefile (tests): Add joinrace.
903
904         * Examples/ex6.c: Test return value of pthread_join.
905
906 2000-06-11  Geoff Keating  <geoffk@cygnus.com>
907
908         * sysdeps/powerpc/pspinlock.c (__pthread_spin_lock): Implement.
909         (__pthread_spin_trylock): Implement.
910         (__pthread_spin_unlock): Implement.
911         (__pthread_spin_init): Implement.
912         (__pthread_spin_destroy): Implement.
913
914 2000-06-10  Ulrich Drepper  <drepper@redhat.com>
915
916         * sysdeps/pthread/timer_routines.c (list_append): Little fix to
917         really append the entry.
918
919 2000-06-10  Andreas Jaeger  <aj@suse.de>
920
921         * lockfile.c (__fresetlockfiles): Remove unused variable fp.
922
923 2000-06-10  Kaz Kylheku  <kaz@ashi.footprints.net>
924
925         * sysdeps/pthread/timer_create.c: Thread matching now done on
926         clock type as well as thread attributes.
927         There are individual global signal-delivering threads for
928         different clock types.
929         * sysdeps/pthread/posix-timer.h: Likewise.
930         * sysdeps/pthread/timer_routines.c: Likewise.
931
932         * sysdeps/pthread/timer_routines.c: Thread allocation and
933         deallocation function now remembers to put thread on active
934         list and remove from active list.
935         Thus now the feature of binding multiple timers
936         to a single thread actually works.
937
938 2000-06-10  Ulrich Drepper  <drepper@redhat.com>
939
940         * pthread.c (__pthread_create_2_1): Optimize a bit.
941
942         * internals.h (invalid_handle): Also test for p_terminated != 0.
943         (nonexisting_handle): New function.  Same as old invalid_handle.
944         * join.c (pthread_join): Use nonexisting_handle instead of
945         invalid_handle to test for acceptable thread handle.
946         * manager.c (pthread_handle_free): Likewise.
947         * joinrace.c: New file.
948         Reported by Permaine Cheung <pcheung@cygnus.com>.
949
950 2000-06-08  Ulrich Drepper  <drepper@redhat.com>
951
952         * sysdeps/pthread/timer_routines.c (__timer_thread_queue_timer):
953         Correct handling of matching variable.
954
955         * sysdeps/pthread/tst-timer.c (main): Rewrite initializers to
956         avoid warnings.
957
958         * sysdeps/pthread/timer_routines.c (__timer_thread_queue_timer):
959         Be prepared for empty timer list.
960
961         * sysdeps/pthread/timer_create.c (timer_create): Correct names of
962         CPUTIME clock ID.  Add support for thread clocks.
963
964         * sysdeps/pthread/posix-timer.h (timer_ptr2id): Operands in
965         subtraction were switched.
966
967         * sysdeps/pthread/timer_routines.c (init_module): Use
968         THREAD_MAXNODES threads.
969
970         * sysdeps/pthread/posix-timer.h (struct timer_node): Add creator_pid.
971         * sysdeps/pthread/timer_create.c: Fill in creator_pid.
972         * sysdeps/pthread/timer_routines.c (thread_expire_timer): Send signal
973         with sigqueueinfo is this system call is available.
974
975         * sysdeps/pthread/timer_create.c (timer_create): Allow
976         CLOCK_CPUTIME if _POSIX_CPUTIME is defined.
977
978         * sysdeps/pthread/Makefile: New file.  Add rules to build timer
979         functionality.
980         * sysdeps/unix/sysv/linux/bits/local_lim.h: Add TIMER_MAX.
981
982 2000-06-04  Kaz Kylheku  <kaz@ashi.footprints.net>
983
984         * sysdeps/pthread/posix-timer.h: New file.
985         * sysdeps/pthread/timer_create.c: New file.
986         * sysdeps/pthread/timer_delete.c: New file.
987         * sysdeps/pthread/timer_getoverr.c: New file.
988         * sysdeps/pthread/timer_gettime.c: New file.
989         * sysdeps/pthread/timer_routines.c: New file.
990         * sysdeps/pthread/timer_settime.c: New file.
991         * sysdeps/pthread/tst-timer.c: New file.
992
993 2000-06-08  Ulrich Drepper  <drepper@redhat.com>
994
995         * sysdeps/unix/sysv/linux/bits/local_lim.h: Remove OPEN_MAX and
996         LINK_MAX definitions if necessary.
997
998 2000-06-04  Kaz Kylheku  <kaz@ashi.footprints.net>
999
1000         Added missing fork time handling of global libio lock.
1001
1002         * lockfile.c (__fresetlockfiles): Now also resets the list lock,
1003         not just the individual stream locks. Rewritten to use new
1004         iterator interface provided by libio rather than accessing
1005         global variable.
1006
1007         * lockfile.c (__flockfilelist, _funlockfilelist): New functions
1008         which lock and unlock the stream list using the new interface
1009         provied by libio.
1010         * internals.h: Likewise.
1011
1012         * ptfork.c (__fork): Now calls __flockfilelist before fork,
1013         and __funlockfilelist in the parent after the fork.
1014         Child still calls __fresetlockfiles as before.
1015
1016         * linuxthreads.texi: Now explains what happens to streams at
1017         fork time. Also whole new section on forking and thread added.
1018         Definition of pthread_atfork moved out of Miscellaneous Functions
1019         to this new section.
1020
1021 2000-06-04  Jakub Jelinek  <jakub@redhat.com>
1022
1023         * sysdeps/sparc/sparc32/sparcv9/pspinlock.c (__pthread_spin_lock):
1024         Add missing register.
1025         * sysdeps/sparc/sparc64/pspinlock.c (__pthread_spin_lock): Likewise.
1026
1027 2000-06-02  Jakub Jelinek  <jakub@redhat.com>
1028
1029         * sysdeps/sparc/sparc32/pspinlock.c: Implement spinlocks.
1030         * sysdeps/sparc/sparc32/sparcv9/pspinlock.c: New.
1031         * sysdeps/sparc/sparc64/pspinlock.c: Implement spinlocks.
1032
1033 2000-05-31  Andreas Jaeger  <aj@suse.de>
1034
1035         * sysdeps/mips/pspinlock.c: Implement spinlocks.
1036
1037 2000-05-28  Ulrich Drepper  <drepper@redhat.com>
1038
1039         * spinlock.c (__pthread_lock): Remove ASSERT.
1040
1041         * Makefile (tests): Add ex8.
1042         * Examples/ex8.c: New file.
1043
1044 2000-05-12  Kaz Kylheku  <kaz@ashi.footprints.net>
1045
1046         Bugfix: The pthread_atfork mechanism now takes care of its
1047         own internal mutex at fork time.
1048
1049         * ptfork.c (__fork): Revised so that the mutex is held across
1050         the fork operation and while the handlers are called, and so that
1051         the child resets the mutex.
1052
1053         * linuxthreads.texi: Updated pthread_atfork documentation to make
1054         it clear that fork and pthread_atfork can't be reentered from
1055         atfork handlers, that pthread_atfork and fork are mutually atomic,
1056         and that the handlers are inherited by the child process.
1057
1058 2000-05-24  Ulrich Drepper  <drepper@redhat.com>
1059
1060         * Makefile (libpthread-routines): Add pspinlock.
1061         * cancel.c: Rename __pthread_spin_unlock back to __pthread_unlock.
1062         Use struct _pthread_fastlock instead of pthread_spinlock_t.
1063         * condvar.c: Likewise.
1064         * internals.h: Likewise.
1065         * join.c: Likewise.
1066         * manager.c: Likewise.
1067         * mutex.c: Likewise.
1068         * pthread.c: Likewise.
1069         * rwlock.c: Likewise.
1070         * semaphore.c: Likewise.
1071         * signals.c: Likewise.
1072         * spinlock.h: Likewise.
1073         * spinlock.c: Likewise.  Remove pthread_spin_lock functions.
1074         * sysdeps/alpha/pspinlock.c: New file.
1075         * sysdeps/arm/pspinlock.c: New file.
1076         * sysdeps/i386/pspinlock.c: New file.
1077         * sysdeps/m68k/pspinlock.c: New file.
1078         * sysdeps/mips/pspinlock.c: New file.
1079         * sysdeps/powerpc/pspinlock.c: New file.
1080         * sysdeps/sparc/sparc32/pspinlock.c: New file.
1081         * sysdeps/sparc/sparc64/pspinlock.c: New file.
1082         * sysdeps/pthread/bits/pthreadtypes.h: Remove pthread_spinlock_t
1083         back to _pthread_fastlock.  Define new pthread_spinlock_t.
1084
1085 2000-05-24  Andreas Jaeger  <aj@suse.de>
1086
1087         * sysdeps/i386/i686/pt-machine.h: Only use LDT on newer kernels.
1088
1089 2000-05-21  Jakub Jelinek  <jakub@redhat.com>
1090
1091         * manager.c (pthread_handle_create): Initialize p_res._sock to -1.
1092
1093 2000-05-13  Jakub Jelinek  <jakub@redhat.com>
1094
1095         * internals.h (__RES_PTHREAD_INTERNAL): Define.
1096
1097 2000-05-06  Kaz Kylheku  <kaz@ashi.footprints.net>
1098
1099         * mutex.c (pthread_once): IN_PROGRESS state of pthread_once_t
1100         object state is represented with additional bits which distinguish
1101         whether that state was set up in the current process, or
1102         in an ancestor process. If that state was set in an ancestor,
1103         it means that a fork happened while thread was executing the init
1104         function. In that case, the state is reset to NEVER.
1105         * mutex.c (__pthread_once_fork_prepare): New function.
1106         (__pthread_once_fork_child): Likewise
1107         (__pthread_once_fork_parent): Likewise
1108         (__pthread_reset_pthread_once): Removed.
1109         * ptfork.c (__fork): Call new handlers in mutex.c.
1110         * internals.h: Declarations of new mutex.c functions added.
1111         Declaration of removed function deleted.
1112         * linuxthreads.texi: Updated documentation about pthread_once
1113         to clarify what happens under cancellation and forking.
1114
1115 2000-05-06  Kaz Kylheku  <kaz@ashi.footprints.net>
1116
1117         * internals.h: New thread manager request type, REQ_KICK.
1118         * join.c (pthread_exit): main thread now calls exit() instead
1119         of _exit() in order to proper process cleanup.
1120         * manager.c (__pthread_manager): Do not terminate manager
1121         after unblocking main thread; wait for main thread's
1122         REQ_PROCESS_EXIT request instead.
1123         Also, added REQ_KICK case to handle new request; this just does
1124         nothing.
1125         * manager.c (pthread_exited): Do not terminate manager after
1126         unblocking main thread.
1127         * manager.c (__pthread_manager_sighandler): If the main thread
1128         is waiting for all other threads to die, send a REQ_KICK into
1129         the thread manager request pipe to get it to clean out the threads
1130         and unblock the main thread as soon as possible. This fixes
1131         the 2000 millisecond hang on shutdown bug.
1132         * Examples/ex7.c: New file, tests shutdown behavior when all threads
1133         including the main one call pthread_exit(), or implicitly do so.
1134         * Makefile (tests): Add ex7.
1135
1136 2000-05-05  Andreas Jaeger  <aj@suse.de>
1137
1138         * sysdeps/unix/sysv/linux/i386/getcpuclockid.c
1139         (pthread_getcpuclockid): Correct test for ourselves.
1140
1141 2000-05-05  Ulrich Drepper  <drepper@redhat.com>
1142
1143         * internals.h (struct _pthread_descr_struct): Reorganization.
1144         Allocate room for 16 pointers at head of the structure for future
1145         thread-local data handling.  Move p_self member in this area.
1146         * manager.c (pthread_handle_create): Adjust use of p_self.
1147         * sysdeps/i386/useldt.h (THREAD_SELF): Likewise.
1148         * pthread.c (__pthread_initial_thread): Adjust initialization.
1149         (__pthread_manager_thread): Likewise.
1150
1151 2000-04-29  Bruno Haible  <haible@clisp.cons.org>
1152
1153         * join.c (pthread_exit): Use THREAD_GETMEM_NC instead of THREAD_GETMEM
1154         for eventmask larger than 1 word.
1155
1156 2000-04-27  Ulrich Drepper  <drepper@redhat.com>
1157
1158         * Versions [libpthread] (GLIBC_2.2): Add __pthread_initialize_minimal.
1159         * pthread.c (__pthread_initialize_minimal): New function.  Perform
1160         minimal initialization.
1161         (pthread_initialize): Remove this code here.
1162         * sysdeps/i386/i686/pt-machine.h: Include "../useldt.h" again.  We
1163         are working around the problem in glibc.
1164
1165 2000-04-25  Ulrich Drepper  <drepper@redhat.com>
1166
1167         * sysdeps/i386/i686/pt-machine.h: Do not use "../useldt.h" for
1168         now.  First gcc must be fixed (more concrete: libgcc).
1169
1170 2000-04-24  Ulrich Drepper  <drepper@redhat.com>
1171
1172         * pthread.c: Remove special treatement for interrupt handlers on x86.
1173         * manager.c (pthread_free): Use FREE_THREAD not FREE_THREAD_SELF.
1174         * sysdeps/i386/useldt.h: Use "q" constraint instead of "r" where
1175         necessary.
1176         * sysdeps/i386/i686/pt-machine.h: Include "../useldt.h".
1177
1178 2000-04-24  Mark Kettenis  <kettenis@gnu.org>
1179
1180         * join.c (pthread_exit): Set p_terminated after reporting the
1181         termination event instead of before.
1182
1183 2000-04-20  Jakub Jelinek  <jakub@redhat.com>
1184
1185         * sysdeps/pthread/bits/libc-lock.h: Only declare __pthread_rwlock_*
1186         if __USE_UNIX98.
1187
1188 2000-04-18  Andreas Jaeger  <aj@suse.de>
1189
1190         * Versions: Use ld instead of ld.so.
1191
1192 2000-04-18  Jakub Jelinek  <jakub@redhat.com>
1193
1194         * sysdeps/unix/sysv/linux/sparc/bits/sigcontext.h (struct sigcontext):
1195         Remove the typedef keyword.
1196
1197 2000-04-18  Jakub Jelinek  <jakub@redhat.com>
1198
1199         * sysdeps/sparc/sparc64/pt-machine.h (MEMORY_BARRIER): Use membar,
1200         not stbar.
1201         (READ_MEMORY_BARRIER): Define.
1202         * spinlock.c (__pthread_spin_unlock): Use READ_MEMORY_BARRIER, not
1203         MEMORY_BARRIER.
1204         * internals.h (READ_MEMORY_BARRIER): Define if not defined in sysdep
1205         headers.
1206
1207 2000-04-17  Ulrich Drepper  <drepper@redhat.com>
1208
1209         * sysdeps/unix/sysv/linux/i386/getcpuclockid.c
1210         (pthread_getcpuclockid): Don't compare thread_id with thread_self,
1211         use thread_handle().
1212
1213 2000-04-16  Ulrich Drepper  <drepper@redhat.com>
1214
1215         * condvar.c (pthread_cond_timedwait_relative): Don't test for owner
1216         if fast mutex is used.  Don't initialize `already_canceled' twice.
1217         Correctly test for return value of timedsuspend.
1218
1219         * pthread.c: Correct long-time braino.  We never set SA_SIGINFO and
1220         therefore don't need the _rt versions of the signal handlers.
1221
1222 2000-04-15  Ulrich Drepper  <drepper@redhat.com>
1223
1224         * pthread.c (pthread_yield): New function.
1225         * sysdeps/pthread/pthread.h (pthread_yield): Add prototype.
1226         * Versions [libpthread] (GLIBC_2.2): Add pthread_yield.
1227         * internals.h: Declare __pthread_yield.
1228
1229         * pthread.c (pthread_initialize): Avoid a bit more code if
1230         realtime signals are known to exist.
1231
1232         * pthread.c: Is __ASSUME_REALTIME_SIGNALS then avoid generating code
1233         to dynamically detect RT signals and avoid generating compatibility
1234         functions with old kernel.
1235         * restart.h (restart) [__ASSUME_REALTIME_SIGNALS]: Use
1236         __pthread_restart_new directly.
1237         (suspend) [__ASSUME_REALTIME_SIGNALS]: Use
1238         __pthread_wait_for_restart_signal directly.
1239         (timedsuspend) [__ASSUME_REALTIME_SIGNALS]: Use
1240         __pthread_timedsuspend_new directly.
1241
1242 2000-04-15  Ulrich Drepper  <drepper@redhat.com>
1243
1244         * condvar.c: Remove all the special code to handle cond_timedwait.
1245         Use timedsuspend instead.
1246         * internals.h: Declare __pthread_timedsuspend_old,
1247         __pthread_timedsuspend_new, and __pthread_timedsuspend.
1248         Remove declaration of __pthread_init_condvar.
1249         * pthread.c: Define __pthread_timedsuspend variable.
1250         (__pthread_timedsuspend_old): New function.  Timed suspension
1251         implementation for old Linux kernels.
1252         (__pthread_timedsuspend_new): New function.  Timed suspension
1253         implementation for new Linux kernels.
1254         * restart.h (timedsuspend): New function.  Call appropriate
1255         suspension function through __pthread_timedsuspend.
1256         * semaphore.c (sem_timedwait): Use timedsuspend, don't duplicate
1257         the code.
1258         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
1259
1260         * internals.h (WRITE_MEMORY_BARRIER): Define as MEMORY_BARRIER if
1261         undefined.
1262         * spinlock.c: Use WRITE_MEMORY_BARRIER instead of MEMORY_BARRIER
1263         where possible.
1264         * sysdeps/alpha/pt-machine.h: Define WRITE_MEMORY_BARRIER.
1265         * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
1266
1267         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Add _POSIX_SPAWN.
1268         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
1269
1270 2000-04-14  Andreas Jaeger  <aj@suse.de>
1271
1272         * weaks.c: Fix typo.
1273
1274         * shlib-versions (mips.*-.*-linux.*): Support only GLIBC 2.0 and
1275         2.2 for linuxthreads.
1276
1277 2000-04-13  Ulrich Drepper  <drepper@redhat.com>
1278
1279         * sysdeps/unix/sysv/linux/i386/getcpuclockid.c
1280         (pthread_getcpuclockid): Fix typo.
1281
1282 2000-04-12  Ulrich Drepper  <drepper@redhat.com>
1283
1284         * Makefile (libpthread-routines): Add getcpuclockid.
1285         * Versions [libpthread] (GLIBC_2.2): Add pthread_getcpuclockid.
1286         * sysdeps/pthread/getcpuclockid.c: New file.
1287         * sysdeps/unix/sysv/linux/i386/getcpuclockid.c: New file.
1288         * sysdeps/pthread/pthread.h: Add prototype for pthread_getcpuclockid.
1289
1290         * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_SPIN_LOCKS):
1291         Defined.
1292         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
1293
1294         * sysdeps/pthread/pthread.h: Add prototypes for pthread_spin_init,
1295         pthread_spin_destroy, pthread_spin_lock, pthread_spin_trylock,
1296         and pthread_spin_unlock.
1297         * sysdeps/pthread/bits/pthreadtypes.h: Change struct _pthread_fastlock
1298         into pthread_spinlock_t.  Change all uses.
1299         * spinlock.c: Implement pthread_spin_lock.
1300         Rename __pthread_unlock to __pthread_spin_unlock and define weak
1301         alias for real name.
1302         Define pthread_spin_trylock, pthread_spin_init, and
1303         pthread_spin_destroy.
1304         Change all uses of _pthread_fastlock to pthread_spinlock_t.
1305         * spinlock.h: Rename __pthread_unlock to __pthread_spin_unlock.
1306         Change all uses of _pthread_fastlock to pthread_spinlock_t.
1307         * Versions [libpthread] (GLIBC_2.2): Add pthread_spin_init,
1308         pthread_spin_destroy, pthread_spin_lock, pthread_spin_trylock,
1309         and pthread_spin_unlock.
1310         * cancel.c: Use __pthread_spin_unlock instead of __pthread_unlock.
1311         Change all uses of _pthread_fastlock to pthread_spinlock_t.
1312         * condvar.c: Likewise.
1313         * internals.h: Likewise.
1314         * join.c: Likewise.
1315         * manager.c: Likewise.
1316         * mutex.c: Likewise.
1317         * pthread.c: Likewise.
1318         * rwlock.c: Likewise.
1319         * semaphore.c: Likewise.
1320         * signals.c: Likewise.
1321
1322         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Add various new POSIX
1323         macros.
1324         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: New file.
1325
1326 2000-04-11  Ulrich Drepper  <drepper@redhat.com>
1327
1328         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Add
1329         _POSIX_SHARED_MEMORY_OBJECTS.
1330
1331 2000-04-11  Andreas Jaeger  <aj@suse.de>
1332
1333         * sysdeps/mips/pt-machine.h (MEMORY_BARRIER): Define.
1334         (__compare_and_swap): Mark as modifying memory.
1335
1336 2000-04-11  Geoff Keating  <geoffk@cygnus.com>
1337
1338         * sysdeps/powerpc/pt-machine.h (MEMORY_BARRIER): Don't be
1339         __volatile__.
1340         (__compare_and_swap): Replace other 'sync' with MEMORY_BARRIER.
1341         Don't have the 'asm' __volatile__.
1342
1343 2000-04-11  Ulrich Drepper  <drepper@redhat.com>
1344
1345         * internals.h: Define MEMORY_BARRIER as empty if not defined already.
1346         * spinlock.c (__pthread_lock): Add memory barriers.
1347         (__pthread_unlock): Likewise.
1348         * sysdeps/alpha/pt-machine.h (MEMORY_BARRIER): Define using mb
1349         instruction.
1350         (RELEASE): Not needed anymore.
1351         (__compare_and_swap): Mark asm as modifying memory.
1352         * sysdeps/powerpc/pt-machine.h (sync): Remove.  Replace with definition
1353         of MEMORY_BARRIER.
1354         (__compare_and_swap): Use MEMORY_BARRIER instead of sync.
1355         * sysdeps/sparc/sparc32/pt-machine.h (RELEASE): Not needed anymore.
1356         (MEMORY_BARRIER): Define using stbar.
1357         * sysdeps/sparc/sparc64/pt-machine.h (MEMORY_BARRIER): Define using
1358         stbar.
1359         (__compare_and_swap): Use MEMORY_BARRIER to ensure ordering.
1360         Patch by Xavier Leroy <Xavier.Leroy@inria.fr> based on comments by
1361         Mike Burrows <m3b@pa.dec.com>.
1362
1363 2000-04-09  Ulrich Drepper  <drepper@redhat.com>
1364
1365         * signals.c (sigaction): Fix return value for the case SIG is one
1366         of the signals the implementation uses.
1367         Patch by Xavier.Leroy@inria.fr.
1368
1369 2000-04-01  Andreas Jaeger  <aj@suse.de>
1370
1371         * attr.c: Use shlib-compat macros.
1372         * oldsemaphore.c: Likewise.
1373         * pthread.c: Likewise.
1374         * weaks.c: Likewise.
1375
1376 2000-03-26  Ulrich Drepper  <drepper@redhat.com>
1377
1378         * semaphore.c (sem_timedwait): New function.
1379         Patch by Carl Mailloux <carlm@oricom.ca>.
1380         * semaphore.h: Declare sem_timedwait.
1381         * Versions [libpthread] (GLIBC_2.2): Add sem_timedwait.
1382
1383 2000-03-26  Roland McGrath  <roland@baalperazim.frob.com>
1384
1385         * sysdeps/pthread/Makefile: File removed.
1386
1387 2000-03-23  Ulrich Drepper  <drepper@redhat.com>
1388
1389         * mutex.c (__pthread_reset_pthread_once): Reset once_masterlock.
1390         * internals.h (__pthread_reset_pthread_once): Add prototype.
1391         * ptfork.c (__fork): Call __pthread_reset_pthread_once.
1392
1393         * manager.c (pthread_handle_create): Store ID of new thread before
1394         clone call.
1395
1396 2000-03-21  Ulrich Drepper  <drepper@redhat.com>
1397
1398         * attr.c: Use new macros from shlib-compat.h to define versions.
1399         * oldsemaphore.c: Likewise.
1400         * semaphore.c: Likewise.
1401         * weaks.c: Likewise.
1402
1403         * pthread.c: Update for new SHLIB_COMPAT definition.
1404
1405         * manager.c (__pthread_manager): Unmask debug signal.
1406
1407         * pthread.c (pthread_initialize): Test for address of __dso_handle
1408         being NULL, not value.  Use __on_exit, not on_exit.
1409         Patch by Andreas Jaeger <aj@suse.de>.
1410
1411         * pthread.c: Use new macros from shlib-compat.h to define versions.
1412
1413 2000-03-19  Ulrich Drepper  <drepper@redhat.com>
1414
1415         * pthread.c (pthread_initialize): Instead of on_exit use
1416         __cxa_atexit if __dso_label is available to allow unloading the
1417         libpthread shared library.
1418
1419 2000-03-16  Ulrich Drepper  <drepper@redhat.com>
1420
1421         * condvar.c: Make tests for ownership of mutex less strict.
1422
1423 2000-03-14  Ulrich Drepper  <drepper@redhat.com>
1424
1425         * condvar.c (pthread_cond_wait): Check whether mutex is owned by
1426         current thread and return error if not.
1427         (pthread_cond_timedwait_relative_old): Likewise.
1428         (pthread_cond_timedwait_relative_new): Likewise.
1429
1430         * mutex.c (__pthread_once): Handle cancelled init function correctly.
1431         (pthread_once_cancelhandler): New function.
1432         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
1433
1434 2000-03-14  Andreas Jaeger  <aj@suse.de>
1435
1436         * pthread.c (pthread_handle_sigcancel_rt): GS has been renamed to
1437         REG_GS.
1438         (pthread_handle_sigrestart_rt): Likewise.
1439         * signals.c (pthread_sighandler_rt): Likewise.
1440
1441 2000-03-02  Andreas Jaeger  <aj@suse.de>
1442
1443         * sysdeps/pthread/bits/libc-lock.h: Fix typo.
1444         Reported by Sean Chen <sean.chen@turbolinux.com>.
1445
1446 2000-02-28  Andreas Jaeger  <aj@suse.de>
1447
1448         * rwlock.c: Fix typo.
1449
1450 2000-02-27  Ulrich Drepper  <drepper@redhat.com>
1451
1452         * rwlock.c: Define __* variants of the functions and make old names
1453         aliases.
1454         * Versions [GLIBC_2.2]: Export the __pthread_rwlock_* functions.
1455         * sysdeps/pthread/bits/libc-lock.h: Define __libc_rwlock_* macros.
1456
1457 2000-02-25  Andreas Jaeger  <aj@suse.de>
1458
1459         * Versions: Export pread, __pread64, pread64, pwrite, __pwrite64,
1460         pwrite64, lseek64, open64, and __open64 with version 2.2.
1461
1462 2000-02-22  Ulrich Drepper  <drepper@redhat.com>
1463
1464         * semaphore.h (SEM_FAILED): Use 0 not NULL.
1465
1466 2000-02-14  Ulrich Drepper  <drepper@redhat.com>
1467
1468         * condvar.c (pthread_cond_timedwait_relative_old): Tight loop with
1469         nanosleep does not work either.  Get absolute time inside the
1470         loop.
1471         (pthread_cond_timedwait_relative_new): Likewise.
1472         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
1473
1474 2000-02-13  Andreas Jaeger  <aj@suse.de>
1475
1476         * condvar.c (pthread_cond_timedwait_relative_new): Fix last patch.
1477         (pthread_cond_timedwait_relative_old): Likewise.
1478
1479 2000-02-13  Ulrich Drepper  <drepper@redhat.com>
1480
1481         * condvar.c (pthread_cond_timedwait_relative_old): Undo last patch
1482         but keep the code around.  A bug in the kernel prevent us from
1483         using the code.
1484         (pthread_cond_timedwait_relative_new): Likewise.
1485         (PR libc/1597 and libc/1598).
1486
1487 2000-02-01  Kaz Kylheku  <kaz@ashi.footprints.net>
1488
1489         * condvar.c (pthread_cond_timedwait_relative_old): Do tight
1490         loop around nanosleep calls instead of around most of the function
1491         (pthread_cond_timedwait_relative_new): Likewise.
1492         body.  Got rid of backwards goto and one local.
1493
1494 2000-01-31  Ulrich Drepper  <drepper@redhat.com>
1495
1496         * condvar.c (pthread_cond_timedwait_relative_old): Recompute time
1497         before every nanosleep call to account for time spent in the rest
1498         of the function.
1499         (pthread_cond_timedwait_relative_new): Likewise.
1500         Patch by khendricks@ivey.uwo.ca (PR libc/1564).
1501
1502 2000-01-29  Ulrich Drepper  <drepper@redhat.com>
1503
1504         * condvar.c (pthread_cond_timedwait_relative_old): Get remaining time
1505         from nanosleep call so that in case we restart we only wait for the
1506         remaining time.
1507         (pthread_cond_timedwait_relative_new): Likewise.
1508         Patch by khendricks@ivey.uwo.ca (PR libc/1561).
1509
1510 2000-01-18  Ulrich Drepper  <drepper@cygnus.com>
1511
1512         * manager.c (pthread_allocate_stack): Compute guard page address
1513         correctly.  Patch by HJ Lu.
1514
1515         * sysdeps/pthread/pthread.h: Define
1516         PTHREAD_RWLOCK_WRITER_NONRECURSIVE_INITIALIZER_NP.
1517
1518 2000-01-16  Ulrich Drepper  <drepper@cygnus.com>
1519
1520         * rwlock.c (pthread_rwlock_unlock): Correct one more problem with
1521         preference handling.
1522         (pthread_rwlockattr_setkind_np): Allow
1523         PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP.
1524         Patches by Kaz Kylheku <kaz@ashi.footprints.net>.
1525
1526 2000-01-12  Ulrich Drepper  <drepper@cygnus.com>
1527
1528         * internals.h (pthread_readlock_info): New structure.
1529         (_pthread_descr_struct): Add p_readlock_list, p_readlock_free, and
1530         p_untracked_readlock_count.
1531         * pthread.c (__pthread_initial_thread, pthread_manager_thread):
1532         Add initializers for new fields.
1533         * manager.c (pthread_free): Free read/write lock lists.
1534         * queue.h (queue_is_empty): New function.
1535         * rwlock.c: Implement requirements about when readers should get
1536         locks assigned.
1537         * sysdeps/pthread/pthread.h
1538         (PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP): New definition.
1539         * sysdeps/pthread/bits/pthreadtypes.h (struct _pthread_rwlock_t):
1540         Define this name as well.
1541         Patches by Kaz Kylheku <kaz@ashi.footprints.net>.
1542
1543 2000-01-05  Ulrich Drepper  <drepper@cygnus.com>
1544
1545         * pthread.c (__pthread_initial_thread, pthread_manager_thread):
1546         Adjust initializers for struct _pthread_descr_struct change.
1547         * internals.h (struct _pthread_descr_struct): Move new elements to
1548         the end.
1549
1550 2000-01-03  Kaz Kylheku  <kaz@ashi.footprints.net>
1551
1552         Redesigned how cancellation unblocks a thread from internal
1553         cancellation points (sem_wait, pthread_join,
1554         pthread_cond_{wait,timedwait}).
1555         Cancellation won't eat a signal in any of these functions
1556         (*required* by POSIX and Single Unix Spec!).
1557         * condvar.c: Spontaneous wakeup on pthread_cond_timedwait won't eat a
1558         simultaneous condition variable signal (not required by POSIX
1559         or Single Unix Spec, but nice).
1560         * spinlock.c: __pthread_lock queues back any received restarts
1561         that don't belong to it instead of assuming ownership of lock
1562         upon any restart; fastlock can no longer be acquired by two threads
1563         simultaneously.
1564         * restart.h: Restarts queue even on kernels that don't have
1565         queued real time signals (2.0, early 2.1), thanks to atomic counter,
1566         avoiding a rare race condition in pthread_cond_timedwait.
1567
1568 1999-12-31  Andreas Jaeger  <aj@suse.de>
1569
1570         * internals.h: Remove duplicate prototype declarations.
1571
1572         * weaks.c: Remove __THROW from prototypes since the file is not
1573         compiled by a C++ compiler.
1574         * internals.h: Likewise.
1575
1576 1999-12-30  Andreas Jaeger  <aj@suse.de>
1577
1578         * sysdeps/pthread/pthread.h: Move internal functions to...
1579         * sysdeps/pthread/bits/libc-lock.h: ...here.
1580
1581 1999-12-29  Andreas Jaeger  <aj@suse.de>
1582
1583         * sysdeps/pthread/pthread.h: Fix typos, reformat comments.
1584
1585 1999-12-28  Ulrich Drepper  <drepper@cygnus.com>
1586
1587         * sysdeps/alpha/pt-machine.h: Move stack_pointer definition to the
1588         beginning.
1589
1590         * manager.c (__pthread_start): Add one more cast to prevent
1591         warning on 64bit machines.
1592
1593 1999-12-21  Ulrich Drepper  <drepper@cygnus.com>
1594
1595         * manager.c (pthread_handle_create): Set p_pid of new thread
1596         before calling the callback function to report a new thread.
1597
1598 1999-12-20  Andreas Jaeger  <aj@suse.de>
1599
1600         * pthread.c (pthread_initialize): Move getrlimit call after
1601         setting of errno.
1602
1603 1999-12-18  Ulrich Drepper  <drepper@cygnus.com>
1604
1605         * Versions: Export pread, __pread64, pread64, pwrite, __pwrite64,
1606         pwrite64, lseek64, open64, and __open64.
1607         * wrapsyscall.c: Define pread, __pread64, pread64, pwrite, __pwrite64,
1608         pwrite64, lseek64, open64, and __open64.
1609
1610         * manager.c (pthread_allocate_stack): Correct computation of
1611         new_thread_bottom.  Correct handling of stack size and when the
1612         rlimit method to guard for stack growth is used.
1613         * pthread.c (pthread_initialize): Stack limit must be STACK_SIZE
1614         minus one pagesize (not two).
1615
1616 1999-12-03  Andreas Jaeger  <aj@suse.de>
1617
1618         * Versions: Add __res_state with version GLIBC_2.2.
1619
1620         * errno.c (__res_state): New function to return thread specific
1621         resolver state.
1622
1623         * pthread.c (pthread_initialize): Initialize p_resp.
1624         (__pthread_reset_main_thread): Also set p_resp.
1625
1626         * manager.c (pthread_handle_create): Initialize p_resp.
1627
1628         * internals.h: Add thread specific resolver state.
1629         Based on patches by Adam D. Bradley <artdodge@cs.bu.edu>.
1630
1631 1999-12-01  Ulrich Drepper  <drepper@cygnus.com>
1632
1633         * sysdeps/i386/pt-machine.h: Move stack_pointer definition to the
1634         beginning.
1635         * sysdeps/i386/i686/pt-machine.h: Likewise.
1636         Patches by Alan Modra <alan@SPRI.Levels.UniSA.Edu.Au>.
1637
1638 1999-11-23  Ulrich Drepper  <drepper@cygnus.com>
1639
1640         * manager.c (pthread_start_thread_event): Initialize p_pid already
1641         here.
1642
1643 1999-11-22  Ulrich Drepper  <drepper@cygnus.com>
1644
1645         * internals.h: Add prototype for __pthread_manager_event.
1646         * manager.c (__pthread_manager_event): New function.
1647         (pthread_start_thread_event): Correct computation of self.
1648         Use INIT_THREAD_SELF.
1649         * pthread.c (__pthread_manager_thread): Initialize p_lock.
1650         (__pthread_initialize_manager): Respect event flags also for creation
1651         of the manager thread.
1652
1653 1999-11-08  Ulrich Drepper  <drepper@cygnus.com>
1654
1655         * pthread.c (__pthread_initialize_manager): Initialize
1656         __pthread_manager_thread.p_tid.
1657
1658 1999-11-02  Ulrich Drepper  <drepper@cygnus.com>
1659
1660         * internals.h: Declare __pthread_last_event.
1661         * manager.c: Define __pthread_last_event.
1662         (pthread_handle_create): Set __pthread_last_event.
1663         (pthread_exited): Likewise.
1664         * join.c (pthread_exit): Likewise.
1665
1666         * Makefile (libpthread-routines): Add events.
1667         * events.c: New file.
1668         * internals.h: Protect against multiple inclusion.
1669         Include thread_dbP.h header.
1670         (struct _pthread_descr_struct): Add new fields p_report_events and
1671         p_eventbuf.
1672         Declare event reporting functions.
1673         * join.c (pthread_exit): Signal event if this is wanted.
1674         * manager.c (__pthread_threads_events): New variable.
1675         (pthread_handle_create): Take new parameters with event information.
1676         Signal TD_CREATE event if wanted.
1677         (__pthread_manager): Adjust pthread_handle_create call.
1678         (pthread_start_thread_event): New function.  Block until manager is
1679         finished and then call pthread_start_thread.
1680         (pthread_exited): Signal TD_REAP event if wanted.
1681
1682 1999-10-26  Ulrich Drepper  <drepper@cygnus.com>
1683
1684         * restart.h (suspend_with_cancellation): Rewrite as a macro.
1685
1686         * condvar.c (pthread_cond_timedwait_relative): Don't mark as inline.
1687
1688 1999-10-25  Andreas Jaeger  <aj@suse.de>
1689
1690         * internals.h: Remove K&R compatibility.
1691         * no-tsd.c: Likewise.
1692         * semaphore.h: Likewise.
1693         * signals.c: Likewise.
1694         * sysdeps/pthread/bits/libc-tsd.h: Likewise.
1695         * sysdeps/unix/sysv/linux/bits/sigthread.h: Likewise.
1696         * weaks.c: Likewise.
1697
1698 1999-10-21  Xavier Leroy  <Xavier.Leroy@inria.fr>
1699
1700         * pthread.c: For i386, wrap pthread_handle_sigrestart and
1701         pthread_handle_sigcancel with functions that restore %gs from the
1702         signal context.  For each signal handling function, two wrappers
1703         are required, one for a non-RT signal and one for a RT signal.
1704         * signal.c: For i386, add code to restore %gs from the signal
1705         context in pthread_sighandler and pthread_sighandler_rt.
1706
1707 1999-10-17  Ulrich Drepper  <drepper@cygnus.com>
1708
1709         * internals.h (PTHREAD_START_ARGS_INITIALIZER): Add cast.
1710
1711 1999-10-14  Ulrich Drepper  <drepper@cygnus.com>
1712
1713         * pthread.c (__pthread_initial_thread): Pass argument to
1714         PTHREAD_START_ARGS_INITIALIZER.
1715         (__pthread_manager_thread): Likewise.
1716
1717         * internals.h (PTHREAD_START_ARGS_INITIALIZER): Add parameter to
1718         initialize function.
1719
1720         * manager.c (pthread_handle_create): Remove p_startfct initialization.
1721
1722         * internals.h (_pthread_descr_struct): We don't need p_startfct field.
1723
1724 1999-10-12  Ulrich Drepper  <drepper@cygnus.com>
1725
1726         * internals.h: Correct return types for __libc_read and __libc_write.
1727
1728 1999-10-09  Andreas Jaeger  <aj@suse.de>
1729
1730         * internals.h: Add __new_sem_post to get prototype in
1731         manager.c; include semaphore.h for needed types.
1732
1733 1999-10-08  Ulrich Drepper  <drepper@cygnus.com>
1734
1735         * manager.c (__pthread_manager) [REQ_POST]: Use __new_sem_post
1736         directly instead of calling sem_post which should not be necessary
1737         but is faster and might help in some case to work around problems.
1738         Patch by khendricks@ivey.uwo.ca [libc/1382].
1739
1740 1999-10-08  Andreas Schwab  <schwab@suse.de>
1741
1742         * sysdeps/pthread/Subdirs: New file.
1743         * Implies: Removed.
1744
1745 1999-10-07  Ulrich Drepper  <drepper@cygnus.com>
1746
1747         * Implies: New file.
1748         * internals.h (struct _pthread_descr_struct): Add p_startfct.
1749         * manager.c (pthread_handle_create): Initialize p_startfct.
1750         * pthread.c: Define __linuxthread_pthread_sizeof_descr variable.
1751
1752 1999-09-25  Ulrich Drepper  <drepper@cygnus.com>
1753
1754         * manager.c (__linuxthreads_pthread_threads_max): New variable.
1755         * specific.c (__linuxthreads_pthread_keys_max): New variable.
1756         (__linuxthreads_pthread_key_2ndlevel_size): New variable.
1757
1758         * condvar.c (pthread_cond_timedwait_relative): Never return with
1759         EINTR.  Patch by Andreas Schwab.
1760
1761 1999-09-19  Ulrich Drepper  <drepper@cygnus.com>
1762
1763         * signals.c (sigaction): Correct last patch.  Don't select
1764         pthread_sighandler_rt based on the signal number but instead of
1765         the SA_SIGINFO flag.
1766
1767 1999-09-23  Ulrich Drepper  <drepper@cygnus.com>
1768
1769         * specific.c: Move definitions of struct pthread_key_struct and
1770         destr_function to ...
1771         * internals.h: ...here.
1772
1773 1999-09-18  Ulrich Drepper  <drepper@cygnus.com>
1774
1775         * pthread.c (pthread_handle_sigrestart_rt): New function.  Use
1776         this instead of pthread_handle_sigrestart if the signal is an RT
1777         signal.
1778
1779         * signals.c: Handle passing through of sighandler arguments also
1780         for real-time signals.
1781
1782 1999-09-03  Andreas Schwab  <schwab@suse.de>
1783
1784         * ptfork.c (__fork): Renamed from fork and use __libc_fork.  Add
1785         fork as weak alias.
1786         (__vfork): New function, alias vfork.
1787         * Versions: Export __fork, vfork, and __vfork in libpthread.
1788
1789 1999-08-23  Andreas Schwab  <schwab@suse.de>
1790
1791         * signals.c (pthread_sighandler): Add SIGCONTEXT_EXTRA_ARGS to
1792         call to signal handler.
1793
1794 1999-08-20  Ulrich Drepper  <drepper@cygnus.com>
1795
1796         * pthread.c (__pthread_reset_main_thread): Undo last change.
1797         (__pthread_kill_other_threads_np): Reset signal handlers for the
1798         signals we used in the thread implementation here.
1799
1800 1999-08-19  Ulrich Drepper  <drepper@cygnus.com>
1801
1802         * pthread.c (__pthread_reset_main_thread): Reset signal handlers
1803         for the signals we used in the thread implementation [PR libc/1234].
1804
1805         * Versions: Export __pthread_kill_other_threads_np from libpthread
1806         for GLIBC_2.1.2.
1807
1808         * signals.c: Pass sigcontext through wrapper to the user function.
1809
1810 1999-08-01  Ulrich Drepper  <drepper@cygnus.com>
1811
1812         * Versions [ld.so] (GLIBC_2.0): Export __libc_internal_tsd_get and
1813         __libc_internal_tsd_set.
1814
1815 1999-07-29  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
1816
1817         * manager.c: Remove inclusion of <linux/tasks.h> since it's not
1818         needed anymore.
1819
1820 1999-07-16  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
1821
1822         * internals.h: Align _pthread_descr_struct to 32 bytes.
1823         Reported by Tim Hockin <thockin@cobaltnet.com>, close PR
1824         libc/1206.
1825
1826 1999-07-09  Ulrich Drepper  <drepper@cygnus.com>
1827
1828         * oldsemaphore.c (sem_compare_and_swap): Fix use of compare and
1829         swap function.
1830
1831 1999-07-09  Cristian Gafton  <gafton@redhat.com>
1832
1833         * Makefile (libpthread-routines): Add oldsemaphore routine.
1834         * Versions: Add sem_destroy, sem_getvalue, sem_init, sem_post,
1835         sem_trywait, and sem_wait to GLIBC_2.1.
1836         * oldsemaphore.c: New file.
1837         * semaphore.c: Add default_symbol_versions for the changed functions.
1838         (__new_sem_init): Rename from sem_init.
1839         (__new_sem_post): Rename from sem_post.
1840         (__new_sem_wait): Rename from sem_wait.
1841         (__new_sem_trywait): Rename from sem_trywait.
1842         (__new_sem_getvalue): Rename from sem_getvalue.
1843         (__new_sem_destroy): Rename from sem_destroy.
1844
1845 1999-06-23  Robey Pointer  <robey@netscape.com>
1846
1847         * internals.h: Added p_nextlock entry to separate queueing for a
1848         lock from queueing for a CV (sometimes a thread queues on a lock
1849         to serialize removing itself from a CV queue).
1850         * pthread.c: Added p_nextlock to initializers.
1851         * spinlock.c: Changed to use p_nextlock instead of p_nextwaiting.
1852
1853 1999-07-09  Ulrich Drepper  <drepper@cygnus.com>
1854
1855         * manager.c (pthread_handle_create): Free mmap region after stack
1856         if clone failed.  Patch by Kaz Kylheku <kaz@ashi.FootPrints.net>.
1857
1858 1999-05-23  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
1859
1860         * man/pthread_cond_init.man: Correct example.
1861         Reported by Tomas Berndtsson <tomas@nocrew.org>.
1862
1863         * linuxthreads.texi (Condition Variables): Likewise.
1864
1865 1999-05-18  Jakub Jelinek  <jj@ultra.linux.cz>
1866
1867         * sysdeps/sparc/sparc64/pt-machine.h (__compare_and_swap): Use
1868         casx not cas, also successful casx returns the old value in rd
1869         and not the new value.
1870
1871 1999-05-16  Xavier Leroy  <Xavier.Leroy@inria.fr>
1872
1873         * manager.c: If pthread_create() is given a NULL attribute
1874         and the thread manager runs with a realtime policy, set the
1875         scheduling policy of the newly created thread back to SCHED_OTHER.
1876         * manager.c: If the PTHREAD_INHERIT_SCHED attribute is given,
1877         initialize the schedpolicy field of new_thread->p_start_args
1878         to that of the calling thread.
1879
1880 1999-04-29  Ulrich Drepper  <drepper@cygnus.com>
1881
1882         * sysdeps/sparc/sparc64/pt-machine.h (__compare_and_swap): cas
1883         instruction does not allow memory element to use offset.
1884
1885 1999-04-28  Ulrich Drepper  <drepper@cygnus.com>
1886
1887         * manager.c (pthread_allocate_stack): Optimize initialization of new
1888         thread descriptor.
1889
1890         * sysdeps/pthread/bits/libc-lock.h (__libc_lock_define_initialized):
1891         Don't use initializer since it is all zeroes.
1892         (__libc_once_define): Likewise.
1893
1894 1999-04-16  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
1895
1896         * sysdeps/arm/Implies: Removed since cmpxchg/no-cmpxchg
1897         doesn't exist anymore.
1898         * sysdeps/i386/Implies: Likewise.
1899         * sysdeps/m68k/Implies: Likewise.
1900         * sysdeps/mips/Implies: Likewise.
1901         * sysdeps/powerpc/Implies: Likewise.
1902         * sysdeps/sparc/sparc32/Implies: Likewise.
1903         * sysdeps/sparc/sparc64/Implies: Likewise.
1904
1905 1999-04-15  Ulrich Drepper  <drepper@cygnus.com>
1906
1907         * sysdeps/alpha/bits/semaphore.h: Removed.
1908         * sysdeps/powerpc/bits/semaphore.h: Removed.
1909         * sysdeps/pthread/cmpxchg/bits/semaphore.h: Removed.
1910         * sysdeps/pthread/no-cmpxchg/bits/semaphore.h: Removed.
1911         * Makefile (headers): Remove bits/semaphore.h.
1912
1913         * semaphore.h: Define _pthread_descr if necessary.
1914         Don't include limits.h.  Define SEM_VALUE_MAX directly.
1915         Define SEM_FAILED.
1916         (sem_t): Protect element names with leading __.
1917         Add declarations for sem_close, sem_open, and sem_unlink.
1918         * semaphore.c: Adjust all functions for new element names.
1919         Define sem_close, sem_open, and sem_unlink.
1920         * Versions (libthread): Add sem_close, sem_open, and sem_unlink for
1921         GLIBC_2.1.1.
1922         * sysdeps/pthread/bits/pthreadtypes.h: Define _pthread_descr only if
1923         necessary.
1924
1925 1999-03-16  H.J. Lu  <hjl@gnu.org>
1926
1927         * specific.c (pthread_key_delete): Check th->p_terminated to see
1928         if the thread is running.
1929
1930         * Versions (__libc_internal_tsd_get, __libc_internal_tsd_set):
1931         Added to GLIBC_2.0 for libc.so.
1932
1933 1999-02-12  H.J. Lu  <hjl@gnu.org>
1934
1935         * Versions (__libc_current_sigrtmin, __libc_current_sigrtmax,
1936         __libc_allocate_rtsig): Added to GLIBC_2.1.
1937
1938         * internals.h (DEFAULT_SIG_RESTART): Removed.
1939         (DEFAULT_SIG_CANCEL): Removed.
1940
1941         * pthread.c (init_rtsigs, __libc_current_sigrtmin,
1942         __libc_current_sigrtmax, __libc_allocate_rtsig): New functions.
1943         (__pthread_sig_restart, __pthread_sig_cancel,
1944         __pthread_sig_debug): Initialized.
1945         (pthread_initialize): Call init_rtsigs () to initialize
1946         real-time signals.
1947
1948 1999-02-03  H.J. Lu  <hjl@gnu.org>
1949
1950         * manager.c (__pthread_manager): Do block __pthread_sig_debug.
1951         Don't restart the thread which sent REQ_DEBUG.
1952         (pthread_start_thread): Check if __pthread_sig_debug > 0
1953         before debugging.
1954
1955         * pthread.c (__pthread_initialize_manager): Suspend ourself
1956         after sending __pthread_sig_debug to gdb instead of
1957         __pthread_sig_cancel.
1958
1959 1999-01-24  H.J. Lu  <hjl@gnu.org>
1960
1961         * manager.c (__pthread_manager): Delete __pthread_sig_debug
1962         from mask if __pthread_sig_debug > 0.
1963         (pthread_handle_create): Increment __pthread_handles_num.
1964
1965         * manager.c (pthread_handle_create): Don't pass CLONE_PTRACE to clone.
1966         * pthread.c (__pthread_initialize_manager): Likewise.
1967
1968         * pthread.c (pthread_initialize): Use __libc_allocate_rtsig (1)
1969         instead of __libc_allocate_rtsig (2).
1970         (__pthread_initialize_manager): Send __pthread_sig_debug to gdb
1971         instead of __pthread_sig_cancel.
1972         (pthread_handle_sigdebug): Fix comments.
1973
1974 1999-01-21  Ulrich Drepper  <drepper@cygnus.com>
1975
1976         * manager.c (pthread_allocate_stack): Set
1977         __pthread_nonstandard_stacks if user-specified stack is used.
1978
1979 1999-01-16  Ulrich Drepper  <drepper@cygnus.com>
1980
1981         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Add _LFS_ASYNCHRONOUS_IO,
1982         _LFS_LARGEFILE, _LFS64_LARGEFILE, and _LFS64_STDIO from Unix98.
1983
1984 1999-01-07  Xavier Leroy  <Xavier.Leroy@inria.fr>
1985
1986         * pthread.c: Use a third signal __pthread_sig_debug distinct
1987         from __pthread_sig_cancel to notify gdb when a thread is
1988         created
1989         * manager.c: Likewise.
1990         * internals.h: Likewise.
1991         * signals.c: The implementation of sigwait(s) assumed that
1992         all signals in s have signal handlers already attached.
1993         This is not required by the standard, so make it work
1994         also if some of the signals have no handlers.
1995
1996 1999-01-05  Andreas Schwab  <schwab@issan.cs.uni-dortmund.de>
1997
1998         * linuxthreads.texi: Remove pointers from first @node.  Move old
1999         @node spec inside comment.
2000
2001 1998-12-31  Ulrich Drepper  <drepper@cygnus.com>
2002
2003         * sysdeps/pthread/bits/stdio-lock.h: Define _IO_lock_lock and
2004         _IO_lock_unlock.
2005
2006 1998-12-29  Ulrich Drepper  <drepper@cygnus.com>
2007
2008         * semaphore.c (sem_trywait): Don't forget to unlock the semaphore
2009         lock.  Patch by Bernd Schmidt <crux@pool.informatik.rwth-aachen.de>.
2010
2011 1998-12-21  Ulrich Drepper  <drepper@cygnus.com>
2012
2013         * manager.c: Threads now send __pthread_sig_cancel on termination.
2014         Change clone call and signal masks.
2015         * thread.c (pthread_handle_sigrestart): Remove special code for
2016         manager.
2017         (pthread_handle_sigcancel): In manager thread call
2018         __pthread_manager_sighandler.
2019         * sysdeps/i386/pt-machine.h (__compare_and_swap): Add memory clobber.
2020         * sysdeps/i386/i686/pt-machine.h: Likewise.
2021         Patches by Xavier Leroy.
2022
2023 1998-12-14  Ulrich Drepper  <drepper@cygnus.com>
2024
2025         * spinlock.c (__pthread_unlock): Don't crash if called for an
2026         untaken mutex.  Reported by Ruslan V. Brushkoff <rus@Snif.Te.Net.UA>.
2027
2028         * Examples/ex6.c: Unbuffer stdout and reduce sleep time to reduce
2029         overall runtime.
2030
2031 1998-12-13  Ulrich Drepper  <drepper@cygnus.com>
2032
2033         * Examples/ex3.c: Wait until all threads are started before
2034         searching for the number to avoid race condition on very fast
2035         systems.
2036
2037 1998-12-08  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
2038
2039         * sysdeps/pthread/pthread.h: Remove __pthread_setcanceltype
2040         declaration since it's not needed.
2041
2042         * sysdeps/pthread/pthread.h: Move internal functions to ...
2043         * internals.h: ...here.
2044
2045 1998-12-02  H.J. Lu  <hjl@gnu.org>
2046
2047         * pthread.c (__pthread_sig_restart): Initiliaze to 0 if
2048         SIGRTMIN is defined.
2049         (__pthread_sig_cancel): Likewise.
2050
2051 1998-12-01  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
2052
2053         * wrapsyscall.c: Include <sys/mman.h> for msync,
2054         <stdlib.h> for system and <termios.h> for tcdrain prototype.
2055         Correct msync declaration.
2056
2057 1998-11-29  Roland McGrath  <roland@baalperazim.frob.com>
2058
2059         * sysdeps/pthread/bits/libc-tsd.h (__libc_tsd_define, __libc_tsd_get,
2060         __libc_tsd_set): New macros for new interface.
2061         * no-tsd.c: New file, provide uninitialized defns of
2062         __libc_internal_tsd_get and __libc_internal_tsd_set.
2063         * Makefile (routines): Add no-tsd.
2064
2065 1998-10-12  Roland McGrath  <roland@baalperazim.frob.com>
2066
2067         * internals.h: Include <bits/libc-tsd.h>, not <bits/libc-lock.h>.
2068         * sysdeps/pthread/bits/libc-lock.h (__libc_internal_tsd_get,
2069         __libc_internal_tsd_set): Move decls to ...
2070         * sysdeps/pthread/bits/libc-tsd.h: New file for __libc_internal_tsd_*
2071         declarations.
2072
2073         * sysdeps/pthread/bits/libc-lock.h (__libc_internal_tsd_get,
2074         __libc_internal_tsd_set): Make these pointers to functions, not
2075         functions; remove #pragma weak decls for them.
2076         * specific.c (__libc_internal_tsd_get, __libc_internal_tsd_set):
2077         Define static functions and initialized pointers to them.
2078
2079 1998-11-18  Ulrich Drepper  <drepper@cygnus.com>
2080
2081         * Makefile (CFLAGS-mutex.c): Define as -D__NO_WEAK_PTHREAD_ALIASES.
2082         (CFLAGS-specific.c): Likewise.
2083         (CFLAGS-pthread.c): Likewise.
2084         (CFLAGS-ptfork.c): Likewise.
2085         (CFLAGS-cancel.c): Likewise.
2086         * sysdeps/pthread/bits/libc-lock.h: Don't mark __pthread_* functions
2087         as weak references if __NO_WEAK_PTHREAD_ALIASES is defined.
2088
2089         * mutex.c (pthread_mutex_init): Define as strong symbol.
2090         (pthread_mutex_destroy): Likewise.
2091         (pthread_mutex_trylock): Likewise.
2092         (pthread_mutex_lock): Likewise.
2093         (pthread_mutex_unlock): Likewise.
2094         (pthread_mutexattr_init): Likewise.
2095         (pthread_mutexattr_destroy): Likewise.
2096         (pthread_once): Likewise.
2097         * ptfork.c (pthread_atfork): Likewise.
2098         * specific.c (pthread_key_create): Likewise.
2099         (pthread_setspecific): Likewise.
2100         (pthread_getspecific): Likewise.
2101
2102 1998-11-15  Andreas Schwab  <schwab@issan.cs.uni-dortmund.de>
2103
2104         * linuxthreads.texi: Fix punctuation after xref.
2105
2106 1998-11-10  H.J. Lu  <hjl@gnu.org>
2107
2108         * sysdeps/unix/sysv/linux/bits/local_lim.h: Undefine NR_OPEN
2109         if it is defined in <linux/limits.h>.
2110
2111 1998-10-29 14:28  Ulrich Drepper  <drepper@cygnus.com>
2112
2113         * spinlock.h (__pthread_trylock): Define inline.
2114         (__pthread_lock): Add extra parameter to declaration.  Declare
2115         using internal_function.
2116         (__pthread_unlock): Declare using internal_function.
2117         * spinlock.c (__pthread_lock): Add new parameter.  Use it instead
2118         of local variable self.  Avoid recomputing self.  Define using
2119         internal_function.
2120         (__pthread_trylock): Remove.
2121         (__pthread_unlock): Define using internal_function.
2122         * cancel.c: Adjust for __pthread_lock interface change.  Use already
2123         computed self value is possible.
2124         * condvar.c: Likewise.
2125         * join.c: Likewise.
2126         * manager.c: Likewise.
2127         * mutex.c: Likewise.
2128         * pthread.c: Likewise.
2129         * rwlock.c: Likewise.
2130         * semaphore.c: Likewise.
2131         * signals.c: Likewise.
2132
2133 1998-10-27 13:46  Ulrich Drepper  <drepper@cygnus.com>
2134
2135         * sysdeps/pthread/pthread.h (struct _pthread_cleanup_buffer): Prepend
2136         __ to field names of the struct.
2137         * sysdeps/pthread/bits/pthreadtypes.h (struct _pthread_fastlock):
2138         Likewise.
2139         (pthread_attr_t): Likewise.
2140         (pthread_cond_t): Likewise.
2141         (pthread_condattr_t): Likewise.
2142         (pthread_mutex_t): Likewise.
2143         (pthread_mutexattr_t): Likewise.
2144         (pthread_rwlock_t): Likewise.
2145         (pthread_rwlockattr_t): Likewise.
2146         * attr.c: Adjust for pthread.h and pthreadtypes.h change.
2147         * cancel.c: Likewise.
2148         * condvar.c: Likewise.
2149         * manager.c: Likewise.
2150         * mutex.c: Likewise.
2151         * pthread.c: Likewise.
2152         * ptlongjmp.c: Likewise.
2153         * rwlock.c: Likewise.
2154         * spinlock.c: Likewise.
2155
2156 1998-10-09  Ulrich Drepper  <drepper@cygnus.com>
2157
2158         * sysdeps/i386/pt-machine.h (get_eflags, set_eflags): Mark these
2159         also with PT_EI.
2160
2161         * sysdeps/i386/i686/pt-machine.h: Remove unused inline
2162         definitions.
2163
2164         * Makefile (libpthread-routines): Add pt-machine.
2165         * pt-machine.c: New file.
2166         * sysdeps/alpha/pt-machine.h: Define PT_EI as extern inline is not
2167         yet defined.  Use PT_EI in extern inline definitions.
2168         * sysdeps/arm/pt-machine.h: Likewise.
2169         * sysdeps/i386/pt-machine.h: Likewise.
2170         * sysdeps/i386/i686/pt-machine.h: Likewise.
2171         * sysdeps/m68k/pt-machine.h: Likewise.
2172         * sysdeps/mips/pt-machine.h: Likewise.
2173         * sysdeps/powerpc/pt-machine.h: Likewise.
2174         * sysdeps/sparc/sparc32/pt-machine.h: Likewise.
2175         * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
2176
2177 1998-10-02  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
2178
2179         * semaphore.h: Include <sys/types.h> so that _pthread_descr
2180         is declared.
2181
2182 1998-09-15  David S. Miller  <davem@pierdol.cobaltmicro.com>
2183
2184         * sysdeps/sparc/sparc32/pt-machine.h (INIT_THREAD_SELF): Add nr
2185         argument.
2186         * sysdeps/sparc/sparc64/pt-machine.h (INIT_THREAD_SELF): Likewise.
2187
2188 1998-09-12 14:24 -0400  Zack Weinberg  <zack@rabi.phys.columbia.edu>
2189
2190         * sysdeps/unix/sysv/linux/bits/sigthread.h: Add multiple inclusion
2191         guard.
2192
2193 1998-09-02 11:08  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
2194
2195         * signals.c (sigaction): Check that sig is less than NSIG to avoid
2196         array index overflow.
2197
2198 1998-09-06 10:56  Ulrich Drepper  <drepper@cygnus.com>
2199
2200         * sysdeps/pthread/semaphore.h: New file.
2201
2202 1998-09-06 09:08  Ulrich Drepper  <drepper@cygnus.com>
2203
2204         * sysdeps/pthread/bits/libc-lock.h (enum __libc_tsd_key_t): Add
2205         _LIBC_TSD_KEY_DL_ERROR.
2206
2207 1998-08-31  Ulrich Drepper  <drepper@cygnus.com>
2208
2209         * sysdeps/i386/i686/pt-machine.h (testandset): Add memory clobber.
2210         * sysdeps/i386/pt-machine.h: Likewise.
2211         Suggested by Roland McGrath.
2212
2213 1998-08-28 13:58  Ulrich Drepper  <drepper@cygnus.com>
2214
2215         * internals.h: Also define THREAD_GETMEM_NC and THREAD_SETMEM_NC to
2216         access thread data with non-constant offsets.
2217         * specific.c: Use THREAD_GETMEM_NC and THREAD_SETMEM_NC where
2218         necessary.
2219
2220         * sysdeps/i386/useldt.h: Fix typo.  Add THREAD_GETMEM_NC and
2221         THREAD_SETMEM_NC definitions.
2222
2223         * sysdeps/sparc/sparc32/pt-machine.h: Define THREAD_GETMEM_NC and
2224         THREAD_SETMEM_NC.
2225         * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
2226
2227 1998-08-26 15:46  Ulrich Drepper  <drepper@cygnus.com>
2228
2229         * internals.h: Define THREAD_GETMEM and THREAD_SETMEM to default if
2230         not already defined.
2231         (struct _pthread_descr_struct): Add p_self and p_nr field.
2232         * manager.c (__pthread_handles): Define second element to point
2233         to manager thread.
2234         (__pthread_handles_num): Initialize to 2.
2235         (__pthread_manager): Use INIT_THREAD_SELF with two arguments.
2236         (pthread_start_thread): Likewise.
2237         (pthread_handle_create): Start search for free slot at entry 2.
2238         Initialize new fields p_self and p_nr.
2239         Call __clone with CLONE_PTRACE if available.
2240         (pthread_free): Call FREE_THREAD_SELF if available.
2241         * pthread.c (__pthread_initial_thread): Initialize new fields.
2242         (__pthread_manager_thread): Likewise.
2243         (__pthread_initialize_manager): Call __clone with CLONE_PTRACE.
2244
2245         * cancel.c: Use THREAD_GETMEM and THREAD_SETMEM to access the
2246         elements of the thread descriptor.
2247         * condvar.c: Likewise.
2248         * errno.c: Likewise.
2249         * join.c: Likewise.
2250         * manager.c: Likewise.
2251         * pthread.c: Likewise.
2252         * ptlongjmp.c: Likewise.
2253         * semaphore.c: Likewise.
2254         * signals.c: Likewise.
2255         * specific.c: Likewise.
2256         * spinlock.c: Likewise.
2257
2258         * sysdeps/alpha/pt-machine.h (INIT_THREAD_SELF): Add extra parameter.
2259
2260         * sysdeps/i386/useldt.h: New file.
2261         * sysdeps/i386/i686/pt-machine.h: Show how to use this file.
2262
2263         * sysdeps/sparc/sparc32/pt-machine.h: Define THREAD_GETMEM and
2264         THREAD_SETMEM using __thread_self.
2265         * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
2266
2267 1998-08-24  Geoff Keating  <geoffk@ozemail.com.au>
2268
2269         * spinlock.c (__pthread_lock): Reset p_nextwaiting to NULL if it
2270         turned out that we didn't need to queue after all.
2271
2272 1998-08-22  Geoff Keating  <geoffk@ozemail.com.au>
2273
2274         * sysdeps/powerpc/pt-machine.h: Remove testandset, it's not used
2275         and wastes space; correct types.
2276
2277 1998-08-08 11:18  H.J. Lu  <hjl@gnu.org>
2278
2279         * signals.c (sigaction): Handle NULL argument.
2280
2281 1998-08-04  Ulrich Drepper  <drepper@cygnus.com>
2282
2283         * sysdeps/unix/sysv/linux/bits/sigthread.h: Use __sigset_t instead
2284         of sigset_t.
2285
2286 1998-08-02  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
2287
2288         * Makefile (linuxthreads-version): Extract correct number from
2289         Banner.
2290
2291 1998-07-29  Xavier Leroy  <Xavier.Leroy@inria.fr>
2292
2293         * Banner: Bump version number to 0.8
2294         * FAQ.html: Many updates, in particular w.r.t. debugging.
2295         * manager.c: Support for non-default stacksize for
2296         LinuxThreads-allocated stacks;
2297         don't use guard pages for stacks with default size, rely on
2298         rlimit(RLIMIT_STACK) instead (it's cheaper).
2299         * attr.c: Likewise.
2300         * cancel.c: Use __pthread_sig_cancel and __pthread_sig_restart
2301         everywhere instead of PTHREAD_SIG_CANCEL and PTHREAD_SIG_RESTART.
2302         * condvar.c: Likewise.
2303         * internals.h: Likewise.
2304         * restart.h: Likewise.
2305         * signals.c: Likewise.
2306         * pthread.c: Likewise; set rlimit(RLIMIT_STACK) as we need it.
2307
2308 1998-07-23  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
2309
2310         * weaks.c: Define pthread_mutexattr_[sg]ettype instead of
2311         __pthread_mutexattr_[sg]ettype.  Add more weak aliases.
2312         * Versions: Put __pthread_mutexattr_settype under version
2313         GLIBC_2.0.  Don't export __pthread_mutexattr_setkind_np and
2314         __pthread_mutexattr_gettype.
2315
2316 1998-07-23  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
2317
2318         * sysdeps/pthread/bits/libc-lock.h: Make
2319         __pthread_mutexattr_settype weak.  Don't make
2320         __pthread_mutexattr_setkind_np weak.
2321
2322 1998-07-16 10:52  Ulrich Drepper  <drepper@cygnus.com>
2323
2324         * manager.c (pthread_handle_create): Check whether sched_setscheduler
2325         call can succeed here.
2326
2327         * mutex.c: Define __pthread_mutexattr_settype and make
2328         __pthread_mutexattr_setkind_np an alias.
2329         Likewise for __pthread_mutexattr_gettype.
2330
2331 1998-07-15 11:00 -0400  Zack Weinberg  <zack@rabi.phys.columbia.edu>
2332
2333         * attr.c (pthread_attr_setschedpolicy): Don't check whether caller
2334         is root.
2335
2336 1998-07-14 19:38  Ulrich Drepper  <drepper@cygnus.com>
2337
2338         * sysdeps/pthread/bits/libc-lock.h: Define __libc_cleanup_end.
2339
2340 1998-07-11  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
2341
2342         * Examples/ex6.c: Include <unistd.h> for usleep.
2343
2344 1998-06-13 11:04  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
2345
2346         * Examples/ex4.c (main): Use exit, not pthread_exit.
2347
2348 1998-07-09 13:39  Ulrich Drepper  <drepper@cygnus.com>
2349
2350         * Versions: Add __pthread_mutexattr_gettype and
2351         __pthread_mutexattr_settype.
2352         * lockfile.c: Use __pthread_mutexattr_settype instead of
2353         __pthread_mutexattr_setkind_np.
2354         * mutex.c: Define __pthread_mutexattr_gettype and
2355         __pthread_mutexattr_settype.
2356         * weak.c: Likewise.
2357         * sysdeps/pthread/pthread.h: Declare __pthread_mutexattr_gettype and
2358         __pthread_mutexattr_settype.
2359         * sysdeps/pthread/bits/libc-lock.h (__libc_lock_init_recursive):
2360         Use __pthread_mutexattr_settype.
2361
2362 1998-07-08 22:26  Ulrich Drepper  <drepper@cygnus.com>
2363
2364         * Versions: Add pthread_mutexattr_gettype, pthread_mutexattr_settype.
2365         * mutex.c: Define weak alias pthread_mutexattr_gettype and
2366         pthread_mutexattr_settype.
2367         * sysdeps/pthread/pthread.h: Declare these functions.
2368         Move pthread_sigmask and pthread_kill declaration in separate header.
2369         * sysdeps/unix/sysv/linux/bits/sigthread.h: New file.
2370
2371 1998-07-07 15:20  Ulrich Drepper  <drepper@cygnus.com>
2372
2373         * Makefile: Add rules to compile and run tests.
2374         * Examples/ex1.c: Little changes to fix warnings.
2375         * Examples/ex2.c: Likewise.
2376         * Examples/ex3.c: Likewise.
2377         * Examples/ex4.c: Likewise.
2378         * Examples/ex5.c: Likewise.
2379         * Examples/ex6.c: New file.
2380
2381 1998-07-05 11:54  Ulrich Drepper  <drepper@cygnus.com>
2382
2383         * Versions: Add pthread_attr_init to GLIBC_2.1 version in libc.
2384
2385 1998-07-01  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
2386
2387         * attr.c: Include <string.h>.
2388
2389 1998-06-30 11:47  Ulrich Drepper  <drepper@cygnus.com>
2390
2391         * attr.c: Include errno.h.  Use memcpy to copy sched_param.
2392         * internals.h: Include limits.h.
2393         * manager.c: Use memcpy to copy sched_param.
2394         * ptfork.c: Include errno.h.
2395         * pthread.c: Likewise.
2396         * semaphore.c: Likewise.
2397         * specific.c: Likewise.
2398         * spinlock.h: Likewise.
2399         * sysdeps/pthread/pthread.h: Include only allowed headers.  Move
2400         type definition to ...
2401         * sysdeps/pthread/bits/pthreadtypes.h: ...here.  New file.
2402
2403 1998-06-29 12:34  Ulrich Drepper  <drepper@cygnus.com>
2404
2405         * sysdeps/pthread/pthread.h: Use __PMT not __P for function pointers.
2406
2407         * sysdeps/pthread/pthread.h: Define various PTHREAD_* symbols also
2408         as macros as demanded in POSIX.1, Annex C.
2409
2410 1998-06-29 12:29  Ulrich Drepper  <drepper@cygnus.com>
2411
2412         * internals.h (struct pthread_request): For free use pthread_t
2413         instead of pthread_descr.
2414         * join.c (pthread_join): Pass thread_id, not th to manager.
2415         (pthread_detach): Likewise.
2416         * manager.c (__pthread_manager): Except thread ID in FREE_REQ case.
2417         (pthread_exited): Remove detached queue code.
2418         (pthread_handle_free): Expect thread ID parameter and use it to
2419         validate the thread decsriptor.  Don't use detached queue.
2420         Patches by Xavier Leroy.
2421
2422 1998-06-27  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
2423
2424         * libpthread.map: Export accept, longjmp, sigaction, siglongjmp,
2425         _IO_flockfile, _IO_ftrylockfile, _IO_funlockfile,
2426         __pthread_atfork, __pthread_key_create, __pthread_once.
2427         * internals.h: Doc fix.
2428         * pthread.c (__pthread_initialize): Define again.
2429
2430 1998-06-26  Ulrich Drepper  <drepper@cygnus.com>
2431
2432         * manager.c (pthread_exited): If thread is not detached put it on
2433         special list.
2434         (pthread_handle_free): If thread is not on list with living threads
2435         search on list with detached threads.
2436
2437         * sysdeps/pthread/pthread.h (PTHREAD_RWLOCK_INITIALIZER): Correct
2438         for new definition of pthread_rwlock_t.
2439
2440         * spinlock.c: Correct test whether to compile
2441         __pthread_compare_and_swap or not.
2442
2443 1998-06-25 19:27  Ulrich Drepper  <drepper@cygnus.com>
2444
2445         * attr.c: Finish user stack support.  Change locking code to be safe
2446         in situations with different priorities.
2447         * cancel.c: Likewise.
2448         * condvar.c: Likewise.
2449         * internals.h: Likewise.
2450         * join.c: Likewise.
2451         * manager.c: Likewise.
2452         * mutex.c: Likewise.
2453         * pthread.c: Likewise.
2454         * ptlongjmp.c: Likewise.
2455         * queue.h: Likewise.
2456         * rwlock.c: Likewise.
2457         * semaphore.c: Likewise.
2458         * semaphore.h: Likewise.
2459         * signals.c: Likewise.
2460         * spinlock.c: Likewise.
2461         * spinlock.h: Likewise.
2462         * sysdeps/pthread/pthread.h: Likewise.
2463         Patches by Xavier Leroy.
2464
2465         * sysdeps/i386/i686/pt-machine.h: New file.
2466
2467 1998-06-25  Ulrich Drepper  <drepper@cygnus.com>
2468
2469         * sysdeps/pthread/pthread.h: Make [sg]et_stacksize and
2470         [sg]et_stackaddr prototypes always available.
2471
2472         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define
2473         _POSIX_THREAD_ATTR_STACKSIZE and _POSIX_THREAD_ATTR_STACKADDR.
2474
2475 1998-06-24  Ulrich Drepper  <drepper@cygnus.com>
2476
2477         * manager.c (pthread_free): Undo patch from 980430.
2478         Reported by David Wragg <dpw@doc.ic.ac.uk>.
2479
2480 1998-06-09 15:07  Ulrich Drepper  <drepper@cygnus.com>
2481
2482         * manager.c: Define __pthread_manager_adjust_prio and use it to
2483         increase priority when needed.
2484         * internals.h: Add prototype for __pthread_manager_adjust_prio.
2485         * mutex.c: Optimize mutexes to wake up only one thread.
2486         * pthread.c: Move PID of manager for global variable in structure
2487         element.
2488         Patches by Xavier Leroy.
2489
2490 1998-06-07 13:47  Ulrich Drepper  <drepper@cygnus.com>
2491
2492         * sysdeps/pthread/bits/libc-lock.h: Optimize cleanup handlers a bit.
2493
2494 1998-06-03  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
2495
2496         * attr.c: Correct typo.
2497
2498 1998-05-01  Ulrich Drepper  <drepper@cygnus.com>
2499
2500         * manager.c (pthread_free): Unmap guard before the stack.
2501         Patch by Matthias Urlichs.
2502
2503 1998-04-30  Ulrich Drepper  <drepper@cygnus.com>
2504
2505         * manager.c (pthread_free): Detect already free child.
2506         Patch by Xavier Leroy, reported by Matthias Urlichs.
2507
2508 1998-04-23  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
2509
2510         * Makefile (linuxthreads-version): Renamed back from
2511         libpthread-version.
2512
2513 1998-04-21  Ulrich Drepper  <drepper@cygnus.com>
2514
2515         * ptlongjmp.c: Add prototypes for __libc_siglongjmp and
2516         __libc_longjmp.
2517
2518 1998-04-20 14:55  Ulrich Drepper  <drepper@cygnus.com>
2519
2520         * Makefile (libpthread-routines): Add ptlongjmp and spinlock.
2521         * internals.h: Add definitions for new spinlock implementation.
2522         * ptlongjmp.c: New file.
2523         * spinlock.c: New file.
2524         * spinlock.h (acquire): Don't reschedule using __sched_yield, use
2525         new function __pthread_acquire to prevent deadlocks with thread
2526         with different priorities.
2527         Patches by Xavier Leroy <Xavier.Leroy@inria.fr>.
2528
2529 1998-03-16  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
2530
2531         * manager.c (__pthread_manager): Reduce first argument to select
2532         to include just the needed file descriptor.
2533
2534 1998-03-17 00:06  Ulrich Drepper  <drepper@cygnus.com>
2535
2536         * manager.c: Fix last patch which caused core dumps.
2537
2538         * pthread.c: Correctly handle missing SIGRTMIN.
2539
2540 1998-03-15  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
2541
2542         * libpthread.map: Add __libc_internal_tsd_get and
2543         __libc_internal_tsd_set.  Add missing cancelable functions. Export
2544         libc internal versions of the cancelable functions.
2545
2546 1998-03-13 16:51  Ulrich Drepper  <drepper@cygnus.com>
2547
2548         * weaks.c: Define pthread_attr_init as GLIBC_2.0 and GLIBC_2.1.
2549
2550 1998-03-13 00:46  Ulrich Drepper  <drepper@cygnus.com>
2551
2552         * attr.c: Implement pthread_attr_[gs]etguardsize,
2553         pthread_attr_[gs]setstackaddr, pthread_attr_[gs]etstacksize.
2554         Change pthread_attr_init to have two interfaces.
2555         * internals.h (struct _pthread_descr_struct): Add new fields for
2556         above functions.
2557         * libpthread.map: Add names in GLIBC_2.1 section.
2558         * manager.c (pthread_handle_create): Implement guardsize and
2559         user stack.
2560         (pthread_free): Likewise.
2561         * pthread.c (pthread_create): Add new interface for changed
2562         pthread_attr_t.
2563         * sysdeps/pthread/pthread.h: Add prototypes for new functions.
2564         * sysdeps/unix/sysv/linux/bits/local_lim.h: Add definition of
2565         PTHREAD_STACK_MIN.
2566
2567 1998-03-11 00:42  Wolfram Gloger  <wmglo@dent.med.uni-muenchen.de>
2568
2569         * manager.c: Enable resetting of the thread scheduling policy
2570         to SCHED_OTHER when the parent thread has a different one.
2571
2572 1998-02-01 13:51  Ulrich Drepper  <drepper@cygnus.com>
2573
2574         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define
2575         _POSIX_ASYNCHRONOUS_IO.
2576
2577         * sysdeps/pthread/pthread.h: Define bits for Unix98 variants of
2578         mutexes.
2579         * mutex.c: Implement new mutex types.
2580
2581         * internals.h: Include <signal.h>.
2582
2583         * libpthread.map: Add __erno_location and __h_errno_location.
2584
2585         * errno.c: Return pointer to variable actually in use.  This might
2586         not be the one in the thread structure.
2587         * internals.h (struct _pthread_descr_struct): Add new fields p_errnop
2588         and p_h_errnop.
2589         * manager.c (__pthread_manager): Set p_errnop and p_h_errnop member
2590         of manager thread structure.
2591         (pthread_handle_create): Set p_errnop and p_h_errnop members for new
2592         thread.
2593         * pthread.c: Adapt initializer for thread structures.
2594         (__pthread_initial_thread): Set p_errnop and p_h_errnop member.
2595         (__pthread_reset_main_thread): Reset p_errnop and p_h_errnop of
2596         current thread to global variables.
2597
2598 1998-01-31 17:27  Ulrich Drepper  <drepper@cygnus.com>
2599
2600         * rwlock.c: New file.
2601         * Makefile (libpthread-routines): Add rwlock.
2602         * sysdeps/pthread/pthread.h: Define data structures and declare
2603         functions.
2604         * libpthread.map: Add new functions.
2605
2606 1997-12-18 13:50  Philip Blundell  <pb@nexus.co.uk>
2607
2608         * sysdeps/arm/pt-machine.h: New file; add ARM support.
2609         * sysdeps/arm/Implies: likewise.
2610         * README: Document it.
2611
2612 1997-12-13  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
2613
2614         * signals.c: Remove unneeded initializer for sigwaited, saving a
2615         warning.
2616
2617 1997-04-11 01:18  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
2618
2619         * semaphore.c (sem_init): Set sem_spinlock only if available.
2620
2621 1997-12-04 01:48  Ulrich Drepper  <drepper@cygnus.com>
2622
2623         * mutex.c: Implement PTHREAD_MUTEX_CHECKERROR.
2624         * sysdeps/pthread/pthread.h: Define PTHREAD_MUTEX_CHECKERROR.
2625
2626         * Makefile: Update from LinuxThreads 0.7.
2627         * internals.h. Likewise.
2628         * manager.c: Likewise.
2629         * mutex.c: Likewise.
2630         * pthread.c: Likewise.
2631         * signals.c: Likewise.
2632         * specific.c: Likewise.
2633         * Examples/ex3.c: Likewise.
2634
2635 1997-11-20 18:13  Ulrich Drepper  <drepper@cygnus.com>
2636
2637         * pthread.c (__pthread_reset_main_thread): Close pipe only if still
2638         open.
2639
2640 1997-10-29 05:38  Ulrich Drepper  <drepper@cygnus.com>
2641
2642         * wrapsyscall.c: Add socket functions which are also cancelation
2643         points.
2644
2645 1997-10-19 21:40  Wolfram Gloger  <wg@wolfram.dent.med.uni-muenchen.de>
2646
2647         * specific.c (__libc_internal_tsd_set, __libc_internal_tsd_get):
2648         New functions for fast thread specific data within libc.
2649
2650         * internals.h: Add new array p_libc_specific to struct
2651         _pthread_descr_struct.
2652
2653         * sysdeps/pthread/bits/libc-lock.h: Declare new functions.
2654
2655 1997-10-13 05:39  Ulrich Drepper  <drepper@cygnus.com>
2656
2657         * semaphore.h: Add __BEGIN_DECLS/__END_DECLS.
2658         Reported by Ralf Corsepius <corsepiu@faw.uni-ulm.de>.
2659
2660 1997-08-29 03:05  Ulrich Drepper  <drepper@cygnus.com>
2661
2662         * internals.h (struct _pthread_descr_struct): Add definitions for
2663         two-level specific key handling.
2664         * manager.c (pthread_handle_create): Initialize specific memory array.
2665         * specific.c: Implement two-level key handling.
2666         * weaks.c: Don't provide dummy key handling.
2667         * sysdeps/pthread/bits/libc-lock.h: Typedef __libc_lock_t (no #define).
2668         Add definition of __libc_key_t.
2669         * sysdeps/unix/sysv/linux/bits/local_lim.h: Define PTHREAD_KEYS_MAX
2670         as 1024.
2671         Add definition of _POSIX_THREAD_DESTRUCTOR_ITERATIONS and
2672         PTHREAD_DESTRUCTOR_ITERATIONS.
2673
2674         * manager.c (pthread_handle_create): Compare mmap result with
2675         MAP_FAILED.
2676
2677         * ptfork.c: Rename to __pthread_atfork and make old name a weak alias.
2678         * sysdeps/pthread/bits/pthread.h: Add prototype for __pthread_atfork.
2679
2680 1997-08-22 19:04  Richard Henderson  <rth@cygnus.com>
2681
2682         sysdeps/sparc -> sysdeps/sparc/sparc32
2683         sysdeps/sparc64 -> sysdeps/sparc/sparc64
2684
2685         * internals.h: Change definition of THREAD_SELF to be an expression,
2686         not a statement that did a return.
2687         * sysdeps/alpha/pt-machine.h (THREAD_SELF): Update accordingly.
2688         * sysdeps/sparc/sparc32/pt-machine.h (THREAD_SELF, INIT_THREAD_SELF):
2689         Follow Solaris and use a "system reserved" register (%g6) to hold
2690         the thread descriptor.
2691         * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
2692
2693 1997-08-03 00:09  Ulrich Drepper  <drepper@cygnus.com>
2694
2695         * mutex.c: Correct pthread_once.  Patch by Xavier Leroy.
2696         * sysdeps/pthread/pthread.h: Add prototype for __pthread_once.
2697         * sysdeps/pthread/bits/pthread.h: Add macros for __libc_once.
2698
2699         * semaphore.c: Include spinlock.h only when needed.
2700
2701         * specific.c (__pthread_setsepcific, __pthread_getspecific): Reject
2702         keys for entries not in use.
2703
2704         * weaks.c: Implement key handling functions for real.
2705
2706 1997-06-29  01:04  Richard Henderson  <richard@gnu.ai.mit.edu>
2707
2708         Initial sparc64-linux support:
2709         * sysdeps/sparc64/Implies: New file.
2710         * sysdeps/sparc64/pt-machine.h: Likewise.
2711
2712 1997-06-29 00:48  Ulrich Drepper  <drepper@cygnus.com>
2713
2714         * semaphore.c: Include spinlock.h at correct place.
2715         Patch by HJ Lu.
2716
2717 1997-06-13 10:06  Richard Henderson  <rth@tamu.edu>
2718
2719         The Great Bit File Move:
2720         * sysdeps/alpha/semaphorebits.h: -> .../bits/semaphore.h.
2721         * sysdeps/powerpc/semaphorebits.h: Likewise.
2722         * sysdeps/pthread/cmpxchg/semaphorebits.h: Likewise.
2723         * sysdeps/pthread/no-cmpxchg/semaphorebits.h: Likewise.
2724         * sysdeps/pthread/libc-lock.h: -> bits/
2725         * sysdeps/pthread/stdio-lock.h: Likewise.
2726         * sysdeps/unix/sysv/linux/local_lim.h: Likewise.
2727         * sysdeps/unix/sysv/linux/posix_opt.h: Likewise.
2728         * semaphore.h: Likewise.
2729         * sysdeps/pthread/pthread.h: Likewise.
2730
2731         * lockfile.c: <foo.h> -> <bits/foo.h>.
2732         * semaphore.h: Likewise.
2733
2734         * Makefile: (headers): foo.h -> bits/foo.h.
2735         * sysdeps/pthread/Makefile: Likewise.
2736
2737 1997-04-11 01:18  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
2738
2739         * semaphore.c (sem_init): Set sem_spinlock only if available.
2740
2741         * sysdeps/m68k/pt-machine.h (testandset, __compare_and_swap): Fix
2742         asm constraints.
2743
2744 1997-04-09 03:00  Ulrich Drepper  <drepper@cygnus.com>
2745
2746         Update from LinuxThreads 0.6.
2747
2748         * attr.c (pthread_attr_getdetachstate): Use __sched_get_priority_max
2749         and __sched_get_priority_min instead of names without `__'.
2750
2751         * manager.c: Rewrite large parts to implement opaque pthread_t.
2752
2753         * cancel.c: Adapt for opaque pthread_t type.
2754         * condvar.c: Likewise.
2755         * errno.c: Likewise.
2756         * join.c: Likewise.
2757         * mutex.c: Likewise.
2758         * pthread.c: Likewise.
2759         * signals.c: Likewise.
2760         * specific.c: Likewise.
2761         * restart.h: Likewise.
2762         * queue.h: Likewise.
2763         * Examples/ex3.c: Likewise.
2764         * Examples/ex4.c: Likewise.
2765         * sysdeps/pthread/pthread.h: Likewise.
2766
2767         * pthread.c: Accumulate time for all threads in thread manager.
2768
2769         * semaphore.c: Implement fallback implementation for architectures
2770         sometimes missing compare-exchange operations.
2771
2772         * cancel.c (pthread_cancel): Validate handle argument.
2773         * join.c (pthread_join): Likewise.
2774         (pthread_detach): Likewise.
2775         * signals.c (pthread_kill): Likewise.
2776
2777         * spinlock.h (acquire): Use __sched_yield not sched_yield.
2778
2779         * queue.h (enqueue): Enqueue thread according to priority.
2780
2781         * internals.c (struct pthread_start_args): New struct for passing
2782         args to cloning function.
2783         (struct _pthread): Rename to _pthread_descr_struct and adapt for
2784         opaque pthread_t.
2785
2786         * Examples/Makefile (clean): Pass -f option to rm.
2787
2788         * sysdeps/i386/pt-machine.h: Add check for compare-exchange instruction
2789         and define TEST_FOR_COMPARE_AND_SWAP.
2790         * sysdeps/i386/i486/pt-machine.h: Removed.
2791
2792         * sysdeps/unix/sysv/linux/local_lim.h (PTHREAD_THREADS_MAX): Increase
2793         to 1024.
2794
2795 1997-04-04 16:38  Ulrich Drepper  <drepper@cygnus.com>
2796
2797         * restart.h (suspend): Clear p_signal before suspending.
2798         (suspend_with_cancellation): Likewise.
2799         Patch by Xavier Leroy <Xavier.Leroy@inria.fr>.
2800
2801         * weaks.c: Make __pthread_key_create return 1.
2802         * sysdeps/pthread/libc-lock.h: Define __libc_key_create,
2803         __libc_getspecific, __libc_setspecific, and __libc_key_t.
2804         * sysdeps/pthread/stdio-lock.h: Don't care for implementation not
2805         using libio.
2806
2807 1997-03-19 15:13  Miguel de Icaza  <miguel@nuclecu.unam.mx>
2808
2809         * sysdeps/sparc/pt-machine (RELEASE): Fix.
2810
2811 1997-03-01 07:55  Geoff Keating  <geoffk@ozemail.com.au>
2812
2813         * sysdeps/powerpc/Implies: Added.
2814         * sysdeps/powerpc/pt-machine.h: Added.
2815         * sysdeps/powerpc/semaphorebits.h: Added.
2816
2817 1997-01-22 01:22  Ulrich Drepper  <drepper@cygnus.com>
2818
2819         * pthread.c (__pthread_initial_thread): Correct
2820         initializer.
2821         (__pthread_manager_thread): Likewise.
2822         Reported by Andreas Jaeger.
2823
2824 1997-01-18 22:15  Richard Henderson  <rth@tamu.edu>
2825
2826         Since sigset_t no longer fits in a register, we can't pass in the
2827         thread's initial mask so easily.  Take this opportunity to simplify
2828         the clone implementation by only accepting a single void* argument.
2829
2830         * manager.c (__pthread_manager): Put thread vitals in the thread
2831         struct instead of as arguments through clone.
2832         (pthread_start_thread): Look for them there.
2833         * internals.h (struct _pthread): Add p_initial_fn,
2834         p_initial_fn_arg, p_initial_mask.  Fix __pthread_manager proto.
2835         * pthread.c (pthread_initialize_manager): Revise clone invocation.