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