2004-11-18 Alexandre Oliva <aoliva@redhat.com>
[glibc.git] / linuxthreads / ChangeLog
blob7b04bc5bc084333a2a527a9b94b88fbe8c2750e7
1 2005-01-08  Andreas Jaeger  <aj@suse.de>
3         * pthread.c (init_one_static_tls): Adjust initialization of DTV
4         entry for static tls deallocation fix.
6         * sysdeps/alpha/tls.h (dtv_t): Change pointer type to be struct which
7         also contains information whether the memory pointed to is static
8         TLS or not, include <stdbool.h>.
9         * sysdeps/i386/tls.h: Likewise.
10         * sysdeps/ia64/tls.h: Likewise.
11         * sysdeps/powerpc/tls.h: Likewise.
12         * sysdeps/s390/tls.h: Likewise.
13         * sysdeps/sh/tls.h: Likewise.
14         * sysdeps/sparc/tls.h: Likewise.
15         * sysdeps/x86_64/tls.h: Likewise.
17 2004-12-21  Jakub Jelinek  <jakub@redhat.com>
19         * Makefile (tests): Add tst-align.
20         * tst-align.c: New test.
21         * sysdeps/i386/Makefile (CFLAGS-tst-align.c): Add
22         -mpreferred-stack-boundary=4.
24 2004-12-12  Ulrich Drepper  <drepper@redhat.com>
26         * internals.h: Include <stdbool.h> to match includes used in nptl.
28 2004-12-01  Jakub Jelinek  <jakub@redhat.coM.
30         * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_CPUTIME,
31         _POSIX_THREAD_CPUTIME): Define to 0.
32         * sysdeps/pthread/timer_create.c (timer_create): Remove unused code
33         handling CLOCK_PROCESS_CPUTIME_ID and CLOCK_THREAD_CPUTIME_ID.
34         * sysdeps/pthread/timer_routines.c (__timer_signal_thread_pclk,
35         __timer_signal_thread_tclk): Remove.
36         (init_module): Remove their initialization.
37         (thread_cleanup): Remove their cleanup assertions.
38         * sysdeps/pthread/posix-timer.h (__timer_signal_thread_pclk,
39         __timer_signal_thread_tclk): Remove.
40         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Removed.
41         * sysdeps/unix/sysv/linux/ia64/bits/posix_opt.h: Removed.
42         * sysdeps/unix/sysv/linux/x86_64/bits/posix_opt.h: Removed.
43         * tst-clock1.c (do_test): Check for availability of CPU clock.
45 2004-11-18  Daniel Jacobowitz  <dan@codesourcery.com>
47         * sysdeps/unix/sysv/linux/arm/sysdep-cancel.h: Update RETINSTR use.
48         * sysdeps/unix/sysv/linux/arm/vfork.S: Likewise.
50 2004-12-02  Roland McGrath  <roland@redhat.com>
52         * Makefile (libpthread-nonshared): Variable removed.
53         ($(objpfx)libpthread_nonshared.a): Target removed.
54         ($(inst_libdir)/libpthread_nonshared.a): Likewise.
55         These are now handled by generic magic from
56         libpthread-static-only-routines being set.
58 2004-11-27  Ulrich Drepper  <drepper@redhat.com>
60         * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_PRIORITIZED_IO,
61         _POSIX2_CHAR_TERM, _POSIX_THREAD_PRIO_INHERIT,
62         _POSIX_THREAD_PRIO_PROTECT): Define.
63         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
64         * sysdeps/unix/sysv/linux/ia64/bits/posix_opt.h: Likewise.
65         * sysdeps/unix/sysv/linux/x86_64/bits/posix_opt.h: Likewise.
67 2004-11-26  Jakub Jelinek  <jakub@redhat.com>
69         * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_ADVISORY_INFO,
70         _POSIX_SPORADIC_SERVER, _POSIX_THREAD_SPORADIC_SERVER, _POSIX_TRACE,
71         _POSIX_TRACE_EVENT_FILTER, _POSIX_TRACE_INHERIT, _POSIX_TRACE_LOG,
72         _POSIX_TYPED_MEMORY_OBJECTS): Define.
73         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
74         * sysdeps/unix/sysv/linux/ia64/bits/posix_opt.h: Likewise.
75         * sysdeps/unix/sysv/linux/x86_64/bits/posix_opt.h: Likewise.
77 2004-11-05  Maciej W. Rozycki  <macro@mips.com>
79         * sysdeps/mips/pspinlock.c: Include <sgidefs.h>.  Use _ABIO32,
80         _ABIN32 and _ABI64 for ABI selection throughout.
81         * sysdeps/mips/pt-machine.h: Use _ABIO32, _ABIN32 and _ABI64 for
82         ABI selection throughout.
84 2004-10-18  Roland McGrath  <roland@redhat.com>
86         [BZ #406]
87         * Makefile (linuxthreads-CPPFLAGS): New variable;
88         adds -DIS_IN_linuxthreads=1.
89         * sysdeps/i386/tls.h: Protect "useldt.h" with
90         [!IS_IN_linuxthreads && !DO_MODIFY_LDT].
91         * sysdeps/i386/i686/pt-machine.h: Revert last change.
93 2004-10-14  Jakub Jelinek  <jakub@redhat.com>
95         * sysdeps/pthread/errno-loc.c: Don't undef #errno
96         if RTLD_PRIVATE_ERRNO.
98 2004-10-05  Dwayne Grant McConnell  <dgm69@us.ibm.com>
100         * pthread.c: Mask restart signal during cancel signal handler.
102 2004-10-05  Jakub Jelinek  <jakub@redhat.com>
104         * sysdeps/unix/sysv/linux/x86_64/bits/posix_opt.h (_POSIX_CPUTIME,
105         _POSIX_THREAD_CPUTIME): Define to 0.
107 2004-10-04  Ulrich Drepper  <drepper@redhat.com>
109         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Set _POSIX_CPUTIME
110         and _POSIX_THREAD_CPUTIME to zero.
111         * sysdeps/unix/sysv/linux/ia64/bits/posix_opt.h: Likewise.
113         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define
114         _POSIX_THREAD_PROCESS_SHARED and _POSIX_CLOCK_SELECTION as -1.
115         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
116         * sysdeps/unix/sysv/linux/ia64/bits/posix_opt.h: Likewise.
117         * sysdeps/unix/sysv/linux/x86_64/bits/posix_opt.h: Likewise.
119 2004-09-25  Roland McGrath  <roland@redhat.com>
121         [BZ #406]
122         * sysdeps/i386/i686/pt-machine.h: Don't #include "../useldt.h" if
123         [_TLS_H], since sysdeps/i386/tls.h includes it after including us.
125 2004-09-24  Roland McGrath  <roland@redhat.com>
127         [BZ #406]
128         * sysdeps/i386/tls.h: Move #include "useldt.h" outside
129         of [__ASSUME_LDT_WORKS > 0] test.
130         Reported by Carlos Velasco <carlos.velasco@newipnet.com>.
132 2004-09-21  Roland McGrath  <roland@redhat.com>
134         * Versions: Add comment about linuxthreads' frozen ABI.
136 2004-09-20  Ulrich Drepper  <drepper@redhat.com>
138         * Versions: Remove exports for pthread_set*id_np functions.
139         * sysdeps/pthread/pthread.h: Remove pthread_set*id_np prototypes
140         for now.
141         * Makefile: Don't build pthread_set*id code for now.
143 2004-09-19  Ulrich Drepper  <drepper@redhat.com>
145         * sysdeps/pthread/pthread.h: Declare pthread_setgid_np,
146         pthread_setuid_np, pthread_setegid_np, pthread_seteuid_np,
147         pthread_setregid_np, pthread_setreuid_np, pthread_setresgid_np,
148         and pthread_setresuid_np.
149         * pthread_setgid_np.c: New file.
150         * pthread_setuid_np.c: New file.
151         * pthread_setegid_np.c: New file.
152         * pthread_seteuid_np.c: New file.
153         * pthread_setregid_np.c: New file.
154         * pthread_setreuid_np.c: New file.
155         * pthread_setresgid_np.c: New file.
156         * pthread_setresuid_np.c: New file.
157         * Versions [libpthread, GLIBC_2.3.4]: Add pthread_setgid_np,
158         pthread_setuid_np, pthread_setegid_np, pthread_seteuid_np,
159         pthread_setregid_np, pthread_setreuid_np, pthread_setresgid_np,
160         and pthread_setresuid_np.
161         * Makefile (libpthread-routines): Add pthread_setuid, pthread_seteuid,
162         pthread_setreuid, pthread_setresuid, pthread_setgid, pthread_setegid,
163         pthread_setregid, and pthread_setresgid.
165 2004-09-12  Ulrich Drepper  <drepper@redhat.com>
167         * sysdeps/pthread/pthread.h: Make rwlock prototypes available also
168         for __USE_XOPEN2K.
169         * sysdeps/pthread/bits/pthreadtypes.h: Define rwlock types also
170         for __USE_XOPEN2K.  [BZ #320]
172 2004-09-04  Jakub Jelinek  <jakub@redhat.com>
174         * tst-cancel4.c (tf_waitid): Use WEXITED flag bit if available.
176 2004-09-07  Ulrich Drepper  <drepper@redhat.com>
178         * sysdeps/pthread/pthread.h (pthread_once): Remove __THROW since
179         the initialization function might throw.
181 2004-08-30  Roland McGrath  <roland@frob.com>
183         * Makefile (libpthread-abi-frozen): New variable.
185 2004-08-26  Roland McGrath  <roland@redhat.com>
187         * configure.in: New file.  If nptl add-on is also selected, barf if
188         explicit and elide ourselves if implicit.
189         * configure: Now generated.
191 2004-08-25  Richard Sandiford  <rsandifo@redhat.com>
193         * sysdeps/unix/sysv/linux/mips/sysdep-cancel.h (CENABLE, CDISABLE,
194         __local_multiple_threads): Fix definitions for IS_IN_librt.
195         * sysdeps/unix/sysv/linux/mips/mips64/sysdep-cancel.h: Likewise.
197 2004-08-22  Andreas Schwab  <schwab@suse.de>
199         * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h (PSEUDO) [IS_IN_librt]:
200         Save gp around CENABLE/CDISABLE calls.
202 2004-08-15  Roland McGrath  <roland@frob.com>
204         * pthread_atfork.c: Update copyright terms including special exception
205         for these trivial files, which are statically linked into executables
206         that use dynamic linking for the significant library code.
208 2004-08-09  Jakub Jelinek  <jakub@redhat.com>
210         * libc-tsd.c: Move resolv.h include before the #if.
211         (__res_maybe_init): New function.  Add libc_hidden_def.
213 2004-08-02  Ulrich Drepper  <drepper@redhat.com>
215         * linuxthreads.texi (Cleanup Handlers): Fix typo.
216         Reported by Bjoern Engelmann <bjengelmann@gmx.de>.
218 2004-07-23  Jakub Jelinek  <jakub@redhat.com>
220         [BZ #284]
221         * sysdeps/pthread/pthread.h (pthread_getcpuclockid): Use __clockid_t
222         instead of clockid_t.
224 2004-07-21  Roland McGrath  <roland@redhat.com>
226         * Makefile ($(objpfx)multidir.mk): Use $(make-target-directory).
228 2004-07-02  Roland McGrath  <roland@redhat.com>
230         * configure: Don't exit.
232 2004-07-20  Alexandre Oliva  <aoliva@redhat.com>
234         * sysdeps/mips/pt-machine.h: Use standard names for ABI macros,
235         include sgidefs.h.
236         * sysdeps/mips/atomicity.h: Likewise.
238 2004-07-19  Alexandre Oliva  <aoliva@redhat.com>
240         * sysdeps/unix/sysv/linux/mips/Makefile (CFLAGS-pt-initfini.s):
241         Remove redundant override that missed -g0.
243 2004-07-14  Kaz Kojima  <kkojima@rr.iij4u.or.jp>
245         * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h
246         (__local_multiple_threads): Define for librt.
247         (SINGLE_THREAD_P): Likewise.
249 2004-07-07  Jakub Jelinek  <jakub@redhat.com>
251         * sysdeps/pthread/getcpuclockid.c (pthread_getcpuclockid): Allow
252         using other thread's clock.
253         * ptclock_gettime.c (__pthread_clock_gettime): Likewise.
254         * ptclock_settime.c (__pthread_clock_settime): Likewise.
255         * internals.h (__pthread_clock_gettime, __pthread_clock_settime):
256         Remove prototypes.
257         Reported by Bernd Schmidt <bernds@redhat.com>.
258         * Makefile (librt-tests): Add tst-clock1.
259         * tst-clock1.c: New test.
261         * sysdeps/x86_64/Versions: New file.
262         * sysdeps/unix/sysv/linux/ia64/bits/posix_opt.h: New file.
263         * sysdeps/unix/sysv/linux/x86_64/bits/posix_opt.h: New file.
265 2004-04-16  Andreas Schwab  <schwab@suse.de>
267         * sysdeps/ia64/tls.h (INIT_SYSINFO): Cast dl_sysinfo to void*.
269 2004-07-05  Jakub Jelinek  <jakub@redhat.com>
271         * sysdeps/s390/pspinlock.c (__pthread_spin_lock,
272         __pthread_spin_trylock): Use constraint "m" instead of "0" for
273         futex.
274         * sysdeps/ia64/pt-machine.h (__compare_and_swap,
275         __compare_and_swap_with_release_semantic, testandset): Use
276         constraint "m" instead of "0" for futex.
278 2004-06-29  Kaz Kojima  <kkojima@rr.iij4u.or.jp>
280         * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h (CENABLE): Fix
281         branch offset for a PLT entry.
282         (CDISABLE): Likewise.
284 2004-05-31  Andreas Jaeger  <aj@suse.de>
286         * sysdeps/unix/sysv/linux/mips/Makefile (CFLAGS-pt-initfini.s):
287         Set to -fno-unit-at-a-time.
288         Patch by Dan Kegel <dank@kegel.com>.
290 2004-05-04  Jakub Jelinek  <jakub@redhat.com>
292         * tst-stack1.c: Don't include mcheck.h.
293         (do_test): Make sure user defined stacks aren't reused,
294         don't free them at the end.  [BZ #110]
296 2004-05-02  Jakub Jelinek  <jakub@redhat.com>
298         * manager.c: Include not-cancel.h.
299         (__pthread_manager): Use read_not_cancel instead of __libc_read.
300         (pthread_start_thread, __pthread_manager_sighandler): Use
301         write_not_cancel instead of __libc_write.
302         (pthread_reap_children): Use waitpid_not_cancel instead of
303         __libc_waitpid.
304         * pthread.c: Include not-cancel.h.
305         (__pthread_initialize_minimal, __pthread_create_2_1,
306         pthread_onexit_process, __pthread_message): Use
307         write_not_cancel instead of __libc_write.
308         (__pthread_initialize_manager): Likewise.  Use close_not_cancel
309         instead of __libc_close.
310         (__pthread_reset_main_thread): Use close_not_cancel instead of
311         __libc_close.
312         * join.c: Include not-cancel.h.
313         (__pthread_do_exit, pthread_join, pthread_detach): Use
314         write_not_cancel instead of __libc_write.
315         * semaphore.c: Include not-cancel.h.
316         (__new_sem_post): Use write_not_cancel instead of __libc_write.
317         * specific.c: Include not-cancel.h.
318         (pthread_key_delete): Use write_not_cancel instead of __libc_write.
320 2004-05-01  Jakub Jelinek  <jakub@redhat.com>
322         * Versions (libc): Add __on_exit and __libc_sigaction.
324 2004-04-28  Jakub Jelinek  <jakub@redhat.com>
326         * semaphore.c (sem_timedwait): Return -1 and set errno instead of
327         returning error number [BZ #133].  Patch by <rmhaddad@yahoo.com>.
329 2004-04-22  SUGIOKA Toshinobu  <sugioka@itonet.co.jp>
331         * sysdeps/unix/sysv/linux/sh/vfork.S: Fix wrong function pointer
332         reference in PIC case.
334 2004-04-20  Jakub Jelinek  <jakub@redhat.com>
336         * oldsemaphore.c (SEM_VALUE_MAX): Remove.
338 2004-04-19  Kaz Kojima  <kkojima@rr.iij4u.or.jp>
340         * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h (CENABLE): Define
341         for librt.  Save the return value to a safe register.
342         (CDISABLE): Define for librt.  Set the function argument correctly.
344 2004-04-18  Jakub Jelinek  <jakub@redhat.com>
346         * sysdeps/unix/sysv/linux/s390/s390-32/sysdep-cancel.h
347         (PSEUDO_CANCEL): Define.
348         (PSEUDO): Use it.
349         * sysdeps/unix/sysv/linux/s390/s390-64/sysdep-cancel.h (CENABLE,
350         CDISABLE): For librt, append @PLT.
352 2004-04-17  Jakub Jelinek  <jakub@redhat.com>
354         * sysdeps/x86_64/tls.h [!__ASSEMBLER__]: Include tcb-offsets.h.
356         * sysdeps/pthread/timer_gettime.c (timer_gettime): For expired timer
357         return it_value { 0, 0 }.
358         * sysdeps/pthread/timer_create.c (timer_create): Handle SIGEV_NONE
359         like SIGEV_SIGNAL.
360         * sysdeps/pthread/timer_routines.c (thread_expire_timer): Remove
361         assertion for SIGEV_NONE.
362         (thread_attr_compare): Compare all attributes, not just a partial
363         subset.
365         * sysdeps/unix/sysv/linux/mq_notify.c: Include stdlib.h.
367 2004-04-17  Ulrich Drepper  <drepper@redhat.com>
369         * semaphore.h (SEM_VALUE_MAX): Just use a plain number.
371 2004-04-16  Ulrich Drepper  <drepper@redhat.com>
373         * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h: Fix last patch.
375 2004-04-13  Jakub Jelinek  <jakub@redhat.com>
377         * sysdeps/unix/sysv/linux/mq_notify.c: Shut up GCC warning.
379 2004-04-12  Ulrich Drepper  <drepper@redhat.com>
381         * sysdeps/unix/sysv/linux/mq_notify.c: New file.
383         * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h (CENABLE): Define
384         for librt.
385         (CDISABLE): Likewise.
387 2004-04-08  Jakub Jelinek  <jakub@redhat.com>
389         * sysdeps/unix/sysv/linux/bits/local_lim.h (MQ_PRIO_MAX): Define.
390         * sysdeps/unix/sysv/linux/alpha/bits/local_lim.h (MQ_PRIO_MAX): Define.
391         * sysdeps/unix/sysv/linux/ia64/bits/local_lim.h (MQ_PRIO_MAX): Define.
392         * sysdeps/unix/sysv/linux/sparc/bits/local_lim.h (MQ_PRIO_MAX): Define.
393         * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_MESSAGE_PASSING):
394         Define.
395         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h
396         (_POSIX_MESSAGE_PASSING): Define.
398 2004-04-10  Andreas Jaeger  <aj@suse.de>
400         * sysdeps/x86_64/pt-machine.h: Add used attribute to stack_pointer
401         to avoid warnings with GCC 3.5.
403 2004-04-09  Steven Munroe  <sjmunroe@us.ibm.com>
405         * sysdeps/powerpc/tls.h (TLS_INIT_TP): Eliminate lvalue cast from
406         __thread_self assignment.
407         (THREAD_DTV): Replace __thread_register with __thread_self.
408         (INIT_THREAD_SELF): Eliminate lvalue cast from __thread_self
409         assignment.
411 2004-04-08  Alexandre Oliva  <aoliva@redhat.com>
413         * signals.c (pthread_sigmask): Don't ever block or mask
414         __pthread_sig_debug.
416 2004-03-11  Steven Munroe  <sjmunroe@us.ibm.com>
418         * sysdeps/powerpc/tls.h: Remove __powerpc64__ conditional.
420 2004-03-23  Ulrich Drepper  <drepper@redhat.com>
422         * sysdeps/ia64/pt-machine.h (BUSY_WAIT_NOP): Define.
423         * sysdeps/x86_64/pt-machine.h (BUSY_WAIT_NOP): Likewise.
425 2004-03-12  Ulrich Drepper  <drepper@redhat.com>
427         * sysdeps/unix/sysv/linux/bits/local_lim.h: Add HOST_NAME_MAX.
428         * sysdeps/unix/sysv/linux/alpha/bits/local_lim.h: Likewise.
429         * sysdeps/unix/sysv/linux/ia64/bits/local_lim.h: Likewise.
430         * sysdeps/unix/sysv/linux/sparc/bits/local_lim.h: Likewise.
432 2004-03-08  Andreas Jaeger  <aj@suse.de>
434         * sysdeps/i386/tls.h (TLS_DO_MODIFY_LDT_KERNEL_CHECK):
435         dl_osversion is readonly.
437 2004-03-07  Ulrich Drepper  <drepper@redhat.com>
439         * sysdeps/i386/tls.h (INIT_SYSINFO): _dl_sysinfo is now in
440         _rtlf_global_ro.
441         * sysdeps/ia64/tls.h (INIT_SYSINFO): Likewise.
443 2004-02-20  Steven Munroe  <sjmunroe@us.ibm.com>
445         * sysdeps/unix/sysv/linux/powerpc/ptlongjmp.c [SHARED]: Code only
446         valid for SHARED case.  Correct spelling of __vmx_longjmp.
448         * sysdeps/powerpc/pspinlock.c: Move from here.
449         * sysdeps/powerpc/powerpc32/pspinlock.c: To here.
450         * sysdeps/powerpc/powerpc64/pspinlock.c: New file.
451         * sysdeps/powerpc/powerpc64/pt-machine.h: Define __compare_and_swap32
452         and __compare_and_swap32_with_release_semantics.
454 2004-02-20  Jakub Jelinek  <jakub@redhat.com>
456         * Makefile (generated): Remove tst-stack1.mtrace and tst-stack1-mem.
457         (tests): Remove $(objpfx)tst-stack1-mem.
458         (tst-stack1-ENV): Remove.
459         ($(objpfx)tst-stack1-mem): Remove.
461         * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h
462         (__syscall_error_handler2): Call CDISABLE.
463         * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h
464         (__syscall_error_handler2): Call CDISABLE.
466         * sysdeps/unix/sysv/linux/ia64/dl-sysdep.h (DL_ARGV_NOT_RELRO): Define.
468 2004-02-10  Steven Munroe  <sjmunroe@us.ibm.com>
470         * Makefile (libpthread-routines): Add ptcleanup.
471         * ptlongjmp.c: Removed.
472         * ptcleanup.c: Copied __pthread_cleanup_upto to here. New file.
473         * sysdeps/pthread/ptlongjmp.c: Copied longjmp to here. New file.
474         * sysdeps/unix/sysv/linux/powerpc/Versions: New file.
475         Version longjmp, siglongjmp for GLIBC_2.3.4.
476         * sysdeps/unix/sysv/linux/powerpc/ptlongjmp.c: New File.
478 2004-01-22  Andreas Jaeger  <aj@suse.de>
480         * spinlock.c (__pthread_lock): Fix contraint to avoid warning.
481         (__pthread_release): Likewise.
483 2004-01-16  Richard Henderson  <rth@redhat.com>
485         * attr.c: Include ldsodefs.h.
486         (pthread_getattr_np): Don't declare __libc_stack_end.
488 2004-01-09  Steven Munroe  <sjmunroe@us.ibm.com>
490         * sysdeps/unix/sysv/linux/powerpc/powerpc32/sysdep-cancel.h
491         [!HAVE_TLS_SUPPORT]: Define SINGLE_THREAD_P using static
492         __lib*_multiple_threads.
493         * sysdeps/unix/sysv/linux/powerpc/powerpc64/sysdep-cancel.h
494         [!HAVE_TLS_SUPPORT]: Likewise.
496 2004-01-13  Roland McGrath  <roland@redhat.com>
498         * sysdeps/powerpc/tcb-offsets.sym: Put -- separator line before any
499         conditionals.
501 2004-01-10  Andreas Jaeger  <aj@suse.de>
503         * sysdeps/unix/sysv/linux/x86_64/vfork.S: Add cfi directives.
505 2004-01-01  Andreas Jaeger  <aj@suse.de>
507         * Makefile (generated): Add missing files.
509 2003-12-31  Ulrich Drepper  <drepper@redhat.com>
511         * attr.c (pthread_getattr_np): Make sure stack info returned for
512         main thread does not overlap with any other VMA.
513         Patch by Jakub Jelinek.
515 2003-12-29  Jakub Jelinek  <jakub@redhat.com>
517         * sysdeps/ia64/tls.h: Include dl-sysdep.h.
518         (INIT_SYSINFO): Define.
519         (TLS_INIT_TP): Use it.
521 2003-12-28  Carlos O'Donell  <carlos@baldric.uwo.ca>
523         * attr.c (pthread_getattr_np): Add _STACK_GROWS_UP case.
525 2003-12-26  Jakub Jelinek  <jakub@redhat.com>
527         * sysdeps/pthread/pthread.h (pthread_setcancelstate,
528         pthread_setcanceltype, pthread_cancel, pthread_testcancel): Remove
529         __THROW.
530         * semaphore.h (sem_wait, sem_timedwait): Likewise.
532 2003-12-17  Jakub Jelinek  <jakub@redhat.com>
534         * manager.c (pthread_free): Call _dl_deallocate_tls even for
535         p_userstack threads.
536         * pthread.c (__pthread_initialize_manager): Call _dl_deallocate_tls
537         on error.
538         (pthread_onexit_process): Update comment.
539         * Makefile (tests): Add tst-stack1.  Depend on $(objpfx)tst-stack1-mem.
540         (generated): Add tst-stack1.mtrace and tst-stack1-mem.
541         (tst-stack1-ENV): Set.
542         ($(objpfx)tst-stack1-mem): New.
543         * tst-stack1.c: New test.
545 2003-12-16  Steven Munroe  <sjmunroe@us.ibm.com>
547         * sysdeps/powerpc/tcb-offsets.sym [!__powerpc64__]: Remove
548         conditional so MULTIPLE_THREADS_OFFSET is generated for both.
549         * sysdeps/powerpc/tls.h [!__powerpc64__]: Remove conditional
550         so TLS_MULTIPLE_THREADS_IN_TCB is generated for both.
551         * sysdeps/unix/sysv/linux/powerpc/powerpc64/sysdep-cancel.h:
552         Include tls.h.
554 2003-12-04  Steven Munroe  <sjmunroe@us.ibm.com>
556         * sysdeps/unix/sysv/linux/powerpc/powerpc64/sysdep-cancel.h
557         (SINGLE_THREAD_P): Test using thread local p_multiple_threads field.
559 2003-12-10  David Mosberger  <davidm@hpl.hp.com>
561         * sysdeps/unix/sysv/linux/ia64/pt-initfini.c: Update copyright
562         message.  Add include of <stddef.h>.
563         (INIT_NEW_WAY): New macro.
564         (INIT_OLD_WAY): Likewise.
565         (_init): Add unwind directives.  Invoke
566         __pthread_initialize_minimal() via INIT_NEW_WAY or INIT_OLD_WAY,
567         respectively.
568         (_init_EPILOG_BEGINS): Add unwind-directives.  Drop unused .regstk
569         directive.
570         (_fini): Add unwind directives.  Drop unnecessary .align 16
571         directive (bundles are always 16-byte aligned).
572         (_fini_EPILOG_BEGINS): Add unwind-directives.
574 2003-11-19  David Mosberger  <davidm@hpl.hp.com>
576         * sysdeps/unix/sysv/linux/ia64/dl-sysdep.h: New file.
578 2003-12-10  Andreas Jaeger  <aj@suse.de>
579             Ruediger Oertel  <ro@suse.de>
581         * sysdeps/alpha/elf/pt-initfini.c (__asm__): Remove extra .prologue.
583 2003-11-30  Andreas Jaeger  <aj@suse.de>
585         * Makefile (CFLAGS-pt-initfini.s): Add $(fno_unit_at_a_time).
586         * sysdeps/unix/sysv/linux/x86_64/Makefile (CFLAGS-pt-initfini.s):
587         Likewise.
589 2003-11-04  Jakub Jelinek  <jakub@redhat.com>
591         * signals.c (__pthread_sigaction): Set __sighandler[sig].old before
592         __libc_sigaction if it has been one of the special values before.
594 2003-10-06  Carlos O'Donell <carlos@baldric.uwo.ca>
596         * pthread.c (__pthread_self_stack): _STACK_GROWS_UP case added.
597         (__pthread_find_self): Likewise.
598         * manager.c (thread_segment): _STACK_GROWS_UP case added.
600 2003-10-10  Carlos O'Donell  <carlos@baldric.uwo.ca>
602         * linuxthreads/sysdeps/unix/sysv/linux/hppa/malloc-machine.h: New file.
604 2003-10-10  Carlos O'Donell  <carlos@baldric.uwo.ca>
606         * sysdeps/unix/sysv/linux/hppa/sysdep-cancel.h: New file.
608 2003-10-07  Jakub Jelinek  <jakub@redhat.com>
610         * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h: Backout 2003-10-02
611         changes.
612         (SAVE_OLDTYPE_0): Fix a typo.
614 2003-10-02  Ulrich Drepper  <drepper@redhat.com>
616         * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h (DOCARGS_1): Use
617         correct offset.
619 2003-10-02  Jakub Jelinek  <jakub@redhat.com>
621         * Makefile (tests): Add tst-cancel8.
622         * tst-cancel8.c: New test.
624 2003-10-02  Ulrich Drepper  <drepper@redhat.com>
626         * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h: Fix saving and
627         restoring of the old cancellation type.
629 2003-09-10  Chris Demetriou  <cgd@broadcom.com>
631         * sysdeps/unix/sysv/linux/mips/mips64/sysdep-cancel.h: New file.
633 2003-09-30  Jakub Jelinek  <jakub@redhat.com>
635         * sysdeps/pthread/malloc-machine.h [!__libc_maybe_call2] (mutex_init,
636         mutex_lock, mutex_trylock, mutex_unlock): Remove.
638 2003-09-27  Wolfram Gloger  <wg@malloc.de>
640         * sysdeps/pthread/malloc-machine.h: New file.
642 2003-09-18  H.J. Lu  <hongjiu.lu@intel.com>
644         * attr.c (__pthread_attr_init_2_1): Double __guardsize size
645         if NEED_SEPARATE_REGISTER_STACK is defined.
647 2003-09-22  Philip Blundell  <philb@gnu.org>
649         * forward.c: Add _pthread_cleanup_push, _pthread_cleanup_pop.
650         * sysdeps/pthread/pthread-functions.h (struct pthread_functions):
651         Likewise.
652         * pthread.c (__pthread_elements): Initialise these new elements.
653         * sysdeps/pthread/bits/libc-lock.h (__libc_cleanup_push): Use
654         __libc_maybe_call.
655         (__libc_cleanup_pop): Likewise.
657 2003-09-22  Jakub Jelinek  <jakub@redhat.com>
659         * attr.c: Include stdlib.h.
661 2003-09-18  Jakub Jelinek  <jakub@redhat.com>
663         * sysdeps/pthread/pthread.h (pthread_getattr_np): Clarify usage.
665         * tst-attr1.c: New test.
666         * Makefile (tests): Add tst-attr1.
668 2003-09-17  Philip Blundell  <philb@gnu.org>
670         * sysdeps/unix/sysv/linux/arm/vfork.S: Branch to fork if
671         libpthread is loaded.  Elide backwards compatibility code when not
672         required.
674 2003-09-17  Jakub Jelinek  <jakub@redhat.com>
676         * descr.h (manager_thread): Rename to...
677         (__pthread_manager_threadp): ... this.
678         * pthread.c (manager_thread): Define to __pthread_manager_threadp.
679         (__pthread_manager_threadp): New variable.
680         * internals.h (__manager_thread): Define to
681         __pthread_manager_threadp if USE_TLS.
683 2003-09-15  Jakub Jelinek  <jakub@redhat.com>
685         * sysdeps/i386/Makefile (CFLAGS-cancel.c, CFLAGS-manager.c,
686         CFLAGS-pthread.c, CFLAGS-sighandler.c): Add
687         -mpreferred-stack-boundary=4.
689 2003-09-16  Ulrich Drepper  <drepper@redhat.com>
691         * attr.c (pthread_getattr_np): Correctly fill in the stack-related
692         values for the initial thread.
694 2003-09-17  Jakub Jelinek  <jakub@redhat.com>
696         * pthread.c (manager_thread): Remove static, add attribute_hidden.
697         (thread_self_stack): Rename to...
698         (__pthread_self_stack): ... this.  Remove static.
699         (pthread_handle_sigcancel): Use check_thread_self ().
700         (pthread_handle_sigrestart): Likewise.
701         * sighandler.c (__pthread_sighandler, __pthread_sighandler_rt):
702         Likewise.
703         * descr.h (manager_thread): Declare.
704         * internals.h (__pthread_self_stack): New prototype.
705         (__manager_thread): Define.
706         (check_thread_self): New function.
708 2003-09-15  Jakub Jelinek  <jakub@redhat.com>
710         * Makefile (CFLAGS-mutex.c): Add $(uses-callbacks).
711         (CFLAGS-sighandler.c): Change $(exceptions) into $(uses-callbacks).
713 2003-09-12  Jakub Jelinek  <jakub@redhat.com>
715         * sysdeps/unix/sysv/linux/s390/bits/typesizes.h: New.
716         (__SSIZE_T_TYPE): Define to __SWORD_TYPE for gcc 2.95.x and
717         __SLONGWORD_TYPE otherwise.
719 2003-09-11  Steven Munroe  <sjmunroe@us.ibm.com>
721         * sysdeps/powerpc/powerpc64/pt-machine.h [MEMORY_BARRIER]: Use lwsync.
722         [READ_MEMORY_BARRIER]: Define.
723         [WRITE_MEMORY_BARRIER]: Define.
725 2003-09-10  Jakub Jelinek  <jakub@redhat.com>
727         * sysdeps/pthread/pthread-functions.h (struct pthread_functions): Move
728         ptr___pthread_cond_timedwait to the end of the structure to avoid
729         breaking Wine unnecessarily.
731 2003-09-08  Jakub Jelinek  <jakub@redhat.com>
733         * sysdeps/unix/sysv/linux/s390/bits/typesizes.h: Remove.
735 2003-09-02  Jakub Jelinek  <jakub@redhat.com>
737         * sysdeps/unix/sysv/linux/alpha/bits/local_lim.h: New file.
738         * sysdeps/unix/sysv/linux/alpha/Versions: New file.
739         * sysdeps/unix/sysv/linux/ia64/bits/local_lim.h: New file.
740         * sysdeps/unix/sysv/linux/ia64/Versions: New file.
741         * sysdeps/unix/sysv/linux/sparc/bits/local_lim.h: New file.
742         * sysdeps/unix/sysv/linux/sparc/Versions: New file.
743         * attr.c (__old_pthread_attr_setstacksize,
744         __old_pthread_attr_setstack): New functions.
745         (pthread_attr_setstacksize): If PTHREAD_STACK_MIN != 16384, export
746         as @@GLIBC_2.3.2 and also export compatibility @GLIBC_2.1.
747         (pthread_attr_setstack): If PTHREAD_STACK_MIN != 16384, export
748         as @@GLIBC_2.3.2 and also export compatibility @GLIBC_2.2.
749         * tststack.c: Include limits.h and sys/param.h.
750         (main): Set size to MAX (70 * 1024, PTHREAD_STACK_MIN).
752         * barrier.c (__pthread_barrierattr_getpshared): Always
753         return PTHREAD_PROCESS_PRIVATE.
754         (pthread_barrierattr_setpshared): Return EINVAL if pshared
755         is neither PTHREAD_PROCESS_PRIVATE nor PTHREAD_PROCESS_SHARED.
757 2003-09-02  Ulrich Drepper  <drepper@redhat.com>
759         * sysdeps/unix/sysv/linux/i386/dl-sysdep.h
760         (DL_SYSINFO_IMPLEMENTATION): Add CFI and make sure the code ends
761         up in .text.
763         * barrier.c (pthread_barrierattr_setpshared): We don't handle
764         inter-process barriers.
766 2003-09-01  Jakub Jelinek  <jakub@redhat.com>
768         * Makefile (tests): Add tst-tls1.
769         (module-names): Add tst-tls1mod{,a,b,c,d,e,f}.
770         ($(objpfx)tst-tls1mod{,a,b,c,d,e,f}.so-no-z-defs): Set to yes.
771         ($(objpfx)tst-tls1): New.
772         ($(objpfx)tst-tls2.out): Likewise.
773         (tests): Depend on $(objpfx)tst-tls2.out.
774         * tst-tls1.c: New test.
775         * tst-tls1.h: New.
776         * tst-tls1mod.c: New.
777         * tst-tls1moda.c: New.
778         * tst-tls1modb.c: New.
779         * tst-tls1modc.c: New.
780         * tst-tls1modd.c: New.
781         * tst-tls1mode.c: New.
782         * tst-tls1modf.c: New.
783         * tst-tls2.sh: New test.
785         * internals.h (__pthread_cond_timedwait): New prototype.
786         * sysdeps/pthread/pthread-functions.h (struct pthread_functions): Add
787         ptr___pthread_cond_timedwait.
788         * pthread.c (__pthread_functions): Initialize them.
789         * forward.c (pthread_cond_timedwait@GLIBC_2.0,
790         pthread_cond_timedwait@@GLIBC_2.3.2): New forwards.
791         * Versions (libc): Export pthread_cond_timedwait@GLIBC_2.0,
792         pthread_cond_timedwait@@GLIBC_2.3.2.
794 2003-08-27  Ulrich Drepper  <drepper@redhat.com>
796         * sysdeps/pthread/pthread.h: Don't mark pthread_exit,
797         pthread_join, pthread_cond_wait, and pthread_cond_timedwait with
798         __THROW to match NPTL.
800 2003-08-13  Ulrich Drepper  <drepper@redhat.com>
802         * sysdeps/pthread/Makefile [subdir=rt] (CPPFLAGS): Add
803         -DBROKEN_THREAD_SIGNALS.
805 2003-08-11  Steven Munroe  <sjmunroe@us.ibm.com>
807         * manager.c (pthread_start_thread) [!(USE_TLS && HAVE___THREAD)]:
808         Correct spelling of per thread resolver state.
810 2003-08-07  Jakub Jelinek  <jakub@redhat.com>
812         * sysdeps/pthread/bits/libc-lock.h [_LIBC && SHARED]
813         (__rtld_lock_default_lock_recursive,
814         __rtld_lock_default_unlock_recursive): Define.
815         [_LIBC && SHARED] (__rtld_lock_lock_recursive,
816         __rtld_lock_unlock_recursive): Define using
817         GL(_dl_rtld_*lock_recursive).
818         * pthread.c (pthread_initialize): Initialize _dl_rtld_lock_recursive
819         and _dl_rtld_unlock_recursive.  Lock GL(_dl_load_lock) the same
820         number of times as GL(_dl_load_lock) using non-mt implementation was
821         nested.
823 2003-07-31  Jakub Jelinek  <jakub@redhat.com>
825         * sysdeps/pthread/bits/typesizes.h (__SSIZE_T_TYPE): Define.
826         * sysdeps/unix/sysv/linux/alpha/bits/typesizes.h (__SSIZE_T_TYPE):
827         Likewise.
828         * sysdeps/unix/sysv/linux/sparc/bits/typesizes.h (__SSIZE_T_TYPE):
829         Likewise.
830         * sysdeps/unix/sysv/linux/s390/bits/typesizes.h: New file.
832         * sysdeps/pthread/pthread.h (pthread_attr_setstackaddr,
833         pthread_attr_setstacksize): Change PTHREAD_STACK_SIZE to
834         PTHREAD_STACK_MIN in comments.
836         * sysdeps/alpha/pt-machine.h (PT_EI): Add
837         __attribute__((always_inline)).
838         * sysdeps/arm/pt-machine.h (PT_EI): Likewise.
839         * sysdeps/cris/pt-machine.h (PT_EI): Likewise.
840         * sysdeps/hppa/pt-machine.h (PT_EI): Likewise.
841         * sysdeps/i386/i686/pt-machine.h (PT_EI): Likewise.
842         * sysdeps/i386/pt-machine.h (PT_EI): Likewise.
843         * sysdeps/ia64/pt-machine.h (PT_EI): Likewise.
844         * sysdeps/m68k/pt-machine.h (PT_EI): Likewise.
845         * sysdeps/mips/pt-machine.h (PT_EI): Likewise.
846         * sysdeps/powerpc/powerpc32/pt-machine.h (PT_EI): Likewise.
847         * sysdeps/powerpc/powerpc64/pt-machine.h (PT_EI): Likewise.
848         * sysdeps/s390/s390-32/pt-machine.h (PT_EI): Likewise.
849         * sysdeps/s390/s390-64/pt-machine.h (PT_EI): Likewise.
850         * sysdeps/sh/pt-machine.h (PT_EI): Likewise.
851         * sysdeps/sparc/sparc32/pt-machine.h (PT_EI): Likewise.
852         * sysdeps/sparc/sparc64/pt-machine.h (PT_EI): Likewise.
853         * sysdeps/x86_64/pt-machine.h (PT_EI): Likewise.
854         * spinlock.h (__pthread_set_own_extricate_if): Likewise.
855         * sysdeps/ia64/tls.h (TLS_INIT_TP): Cast tcbp to __typeof
856         (__thread_self).
857         * Examples/ex13.c (main): Change res type to void * to avoid
858         warnings.
859         * tst-cancel.c (cleanup, inner, tf1, tf2, tf3): Comment out.
861 2003-07-30  Jakub Jelinek  <jakub@redhat.com>
863         * pthread.c (init_one_static_tls, __pthread_init_static_tls): New
864         functions.
865         (pthread_initialize): Initialize GL(dl_init_static_tls).
867 2003-06-19  Daniel Jacobowitz  <drow@mvista.com>
869         * sysdeps/pthread/timer_create.c (timer_create): Call timer_delref
870         before __timer_dealloc.
871         * sysdeps/pthread/timer_routines.c (__timer_thread_find_matching):
872         Don't call list_unlink.
874 2003-07-29  Roland McGrath  <roland@redhat.com>
876         * Makefile [$(build-shared) = yes] (tests): Depend on $(test-modules).
878 2003-07-25  Roland McGrath  <roland@redhat.com>
880         * manager.c (pthread_start_thread): Fix typo in last change.
882 2003-07-14  Guido Guenther  <agx@sigxcpu.org>
884         * sysdeps/unix/sysv/linux/mips/sysdep-cancel.h: Add IS_IN_librt,
885         use L() for local labels.
887 2003-07-22  Jakub Jelinek  <jakub@redhat.com>
889         * descr.h (struct _pthread_descr_struct): Provide p_res member
890         even if USE_TLS && HAVE___THREAD.
891         * sysdeps/pthread/res-state.c (__res_state): Return __resp
892         if USE___THREAD.
893         * manager.c: Include resolv.h.
894         (pthread_start_thread): Initialize __resp.
895         * libc-tls-loc.c (__res_state): Return __resp.
896         * Makefile (tests): Add tst-_res1.
897         (modules-names, extra-objs, test-extras, test-modules): Add support
898         for test modules.
899         ($(objpfx)tst-_res1mod2.so): Depend on $(objpfx)tst-_res1mod1.so.
900         ($(objpfx)tst-_res1): Depend on $(objpfx)tst-_res1mod2.so and
901         -lpthread.
902         * tst-_res1.c: New test.
903         * tst-_res1mod1.c: New test.
904         * tst-_res1mod2.c: New test.
906 2003-07-20  Ulrich Drepper  <drepper@redhat.com>
908         * sysdeps/pthread/bits/libc-lock.h: Define __libc_cleanup_push and
909         __libc_cleanup_pop.
911         * tst-cancel-wrappers.sh: lseek and llseek are no cancellation points.
913 2003-07-14  Ulrich Drepper  <drepper@redhat.com>
915         * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h: Fix typo
916         in test for compilation in libc.
918 2003-07-04  Jakub Jelinek  <jakub@redhat.com>
920         * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h (PSEUDO): Use
921         different symbol for the cancellation syscall wrapper and
922         non-cancellation syscall wrapper.
923         (PSEUDO_END): Define.
925 2003-07-05  Richard Henderson  <rth@redhat.com>
927         * sysdeps/alpha/elf/pt-initfini.c: Avoid .ent/.end.
929 2003-06-20  Kaz Kojima  <kkojima@rr.iij4u.or.jp>
931         * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h: Support cancellation
932         in librt.
934 2003-06-21  Andreas Schwab  <schwab@suse.de>
936         * sysdeps/unix/sysv/linux/m68k/sysdep-cancel.h: Support cancellation
937         in librt.
939 2003-06-20  Richard Henderson  <rth@redhat.com>
941         * sysdeps/unix/sysv/linux/alpha/Makefile (libpthread-routines):
942         Remove ptw-osf_sigprocmask.
944 2003-06-18  Jakub Jelinek  <jakub@redhat.com>
946         * internals.h (__librt_multiple_threads, __librt_enable_asynccancel,
947         __librt_disable_asynccancel): Declare.
948         (LIBC_CANCEL_ASYNC, LIBC_CANCEL_RESET, LIBC_CANCEL_HANDLED): Define
949         for IS_IN_librt.
950         * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h: Support cancellation
951         in librt.
952         * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h: Likewise.
953         * sysdeps/unix/sysv/linux/s390/s390-32/sysdep-cancel.h: Likewise.
954         * sysdeps/unix/sysv/linux/s390/s390-64/sysdep-cancel.h: Likewise.
955         * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h: Likewise.
956         * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h: Likewise.
957         * sysdeps/unix/sysv/linux/x86_64/sysdep-cancel.h: Likewise.
958         * sysdeps/unix/sysv/linux/powerpc/powerpc32/sysdep-cancel.h: Likewise.
959         * sysdeps/unix/sysv/linux/powerpc/powerpc64/sysdep-cancel.h: Likewise.
960         * sysdeps/x86_64/tcb-offsets.sym: New file.
961         * sysdeps/x86_64/Makefile: New file.
962         * sysdeps/x86_64/tls.h (tcbhead_t): Add multiple_threads.
963         * Versions (libc): Export __librt_enable_asynccancel,
964         __librt_disable_asynccancel and __librt_multiple_threads as
965         GLIBC_PRIVATE.
966         * libc-cancellation.c (__librt_multiple_threads,
967         __librt_enable_asynccancel, __librt_disable_asynccancel): New aliases.
969 2003-06-12  Steven Munroe  <sjmunroe@us.ibm.com>
971         * sysdeps/unix/sysv/linux/powerpc/powerpc64/sysdep-cancel.h
972         (SINGLE_THREAD_P): Replace @ got notation with @toc.
974 2003-06-11  Ulrich Drepper  <drepper@redhat.com>
976         * sysdeps/powerpc/pspinlock.c (__pthread_spin_init): Fix
977         initializer [PR libc/5052].
979 2003-06-09  Andreas Schwab  <schwab@suse.de>
981         * Makefile: Move inclusion of ../Rules down after extra-objs is
982         fully known.
984 2003-06-06  Ulrich Drepper  <drepper@redhat.com>
986         * sysdeps/unix/sysv/linux/arm/sysdep-cancel.h: New sequences for
987         5+ arg syscalls only needed for PIC.
988         Patch by Ralph Siemsen <ralphs@netwinder.org>.
990 2003-06-05  Richard Henderson  <rth@redhat.com>
992         * sysdeps/unix/sysv/linux/alpha/sysdep-cancel.h (PSEUDO): Use
993         and require CFI assembler directives.
994         * sysdeps/unix/sysv/linux/alpha/vfork.S: Likewise.
996 2003-05-30  Andreas Jaeger  <aj@suse.de>
998         * sysdeps/unix/sysv/linux/x86_64/sysdep-cancel.h
999         (SAVESTK_0): Add CFI directives.
1000         (SAVESTK_3): Likewise.
1001         (SAVESTK_5): Likewise.
1002         (RESTSTK_0): Likewise.
1003         (RESTSTK_3): Likewise.
1004         (RESTSTK_5): Likewise.
1006 2003-05-05  Ulrich Drepper  <drepper@redhat.com>
1008         * sysdeps/i386/tls.h (TLS_DO_SET_THREAD_AREA): Add \n to error
1009         messages.
1011 2003-05-04  Roland McGrath  <roland@redhat.com>
1013         * Makefile ($(objpfx)../libc.so): New target.
1015 2003-04-26  Ulrich Drepper  <drepper@redhat.com>
1017         * pthread.c (__pthread_initialize_manager): Remove one last
1018         p_multiple_threads call.
1020 2003-04-22  Jakub Jelinek  <jakub@redhat.com>
1022         * pthread.c (__pthread_initialize_manager): Subtract
1023         TLS_PRE_TCB_SIZE bytes from tcbp to get to descr.
1024         * manager.c (pthread_handle_create): Subtract or add TLS_PRE_TCB_SIZE
1025         instead of sizeof (pthread_descr).
1026         (pthread_free): Add TLS_PRE_TCB_SIZE instead of sizeof (pthread_descr).
1027         * sysdeps/powerpc/tls.h (TLS_INIT_TCB_SIZE, TLS_TCB_SIZE): Define to 0.
1028         (TLS_INIT_TCB_ALIGN, TLS_TCB_ALIGN): Define to alignment of
1029         pthread_descr.
1030         (TLS_PRE_TCB_SIZE): Increase to cover tcbhead_t preceeded by pad
1031         to TLS_TCB_ALIGN.
1032         (INSTALL_DTV, GET_DTV, THREAD_DTV): tcbhead_t is immediately before
1033         tcbp.
1034         (TLS_INIT_TP, THREAD_SELF, INIT_THREAD_SELF): Don't add TLS_TCB_SIZE
1035         unneccessarily.
1036         (NO_TLS_OFFSET): Define.
1038 2003-04-22  Roland McGrath  <roland@redhat.com>
1040         * Makeconfig (shared-thread-library): Reverse link order to work
1041         around linker bug.
1043 2003-04-20  Ulrich Drepper  <drepper@redhat.com>
1045         * sysdeps/i386/useldt.h (DO_SET_THREAD_AREA): Make sure the
1046         compiler knows we use the ldt_entry variable and that the syscall
1047         modifies the memory.
1049         * internals.h: Split pthread_functions definition into...
1050         * sysdeps/pthread/pthread-functions.h: ...new file.
1052         * sysdeps/i386/useldt.h: Include <sysdep.h>.
1054 2003-04-13  Jakub Jelinek  <jakub@redhat.com>
1056         * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h: Rename macros to
1057         match changes in NPTL sysdep-cancel.h.
1059 2003-04-11  Roland McGrath  <roland@redhat.com>
1061         * Makefile (multidir): Don't set the variable here with $(shell ...).
1062         ($(objpfx)multidir.mk): New target, generated makefile; include that.
1063         (generated): Append it.
1065 2003-04-10  Jakub Jelinek  <jakub@redhat.com>
1067         * Makefile (multidir, crti-objs, crtn-objs): New variables.
1068         (generated-dirs): Add pathname component of multidir.
1069         (omit-deps, extra-objs): Include $(multidir)/crt? as well.
1070         ($(objpfx)libpthread.so): Depend on $(multidir)/crt?.o as well.
1071         ($(objpfx)$(multidir), $(objpfx)$(multidir)/crti.o,
1072         $(objpfx)$(multidir)/crtn.o): New.
1073         * sysdeps/unix/sysv/linux/sparc/Makefile: Removed.
1074         * sysdeps/unix/sysv/linux/x86_64/Makefile (LDFLAGS-pthread.so,
1075         before-compile, generated): Don't generate and use specs.
1076         ($(objpfx)specs): Remove.
1078 2003-04-11  Martin Schwidefsky  <schwidefsky@de.ibm.com>
1080         * sysdeps/s390/pspinlock.c (__pthread_spin_unlock): Fix asm contraints.
1082 2003-04-03  Ulrich Drepper  <drepper@redhat.com>
1084         * sysdeps/unix/sysv/linux/arm/sysdep-cancel.h (PSEUDO): Add
1085         missing ; after ENTRY use [PR libc/4997].
1087 2003-04-03  Jakub Jelinek  <jakub@redhat.com>
1089         * pthread.c (pthread_initialize): Unblock __pthread_sig_cancel
1090         in case the parent blocked it.
1092 2003-04-02  Jakub Jelinek  <jakub@redhat.com>
1094         * Makefile (libpthread-routines): Add pthread_atfork.
1095         (libpthread-static-only-routines): Add pthread_atfork.
1097 2003-04-01  Jakub Jelinek  <jakub@redhat.com>
1099         * pthread.c (__pthread_wait_for_restart_signal): Use
1100         __pthread_sigsuspend instead of sigsuspend.
1101         * internals.h (__pthread_sigsuspend): New prototype.
1102         * Makefile (libpthread-routines): Add pt-sigsuspend.
1103         (tests): Add tst-cancel7.
1104         * sysdeps/unix/sysv/linux/pt-sigsuspend.c: New file.
1105         * sysdeps/unix/sysv/linux/alpha/pt-sigsuspend.S: New file.
1106         * sysdeps/unix/sysv/linux/ia64/pt-sigsuspend.c: New file.
1107         * sysdeps/unix/sysv/linux/s390/s390-64/pt-sigsuspend.c: New file.
1108         * sysdeps/unix/sysv/linux/sparc/sparc64/pt-sigsuspend.c: New file.
1109         * sysdeps/unix/sysv/linux/x86_64/pt-sigsuspend.c: New file.
1110         * tst-cancel7.c: New test.
1112 2003-03-31  Alexandre Oliva  <aoliva@redhat.com>
1114         * alloca_cutoff.c: Include internals.h.
1115         * sysdeps/pthread/errno-loc.c: Include linuxthreads/internals.h.
1116         * sysdeps/pthread/herrno-loc.c: Likewise.
1117         * sysdeps/pthread/res-state.c: Likewise.
1119 2003-03-25  Ulrich Drepper  <drepper@redhat.com>
1121         * sysdeps/pthread/bits/typesizes.h: New file.
1122         * sysdeps/unix/sysv/linux/alpha/bits/typesizes.h: New file.
1123         * sysdeps/unix/sysv/linux/sparc/bits/typesizes.h: New file.
1125 2003-03-24  Daniel Jacobowitz  <drow@mvista.com>
1127         * sysdeps/unix/sysv/linux/arm/sysdep-cancel.h
1128         (DOARGS_5, DOARGS_6, DOARGS_7): Rewritten.
1130 2003-03-22  Jakub Jelinek  <jakub@redhat.com>
1132         * sysdeps/unix/sysv/linux/fork.c (__fork): Add libc_hidden_def.
1134 2003-03-21  Daniel Jacobowitz  <drow@mvista.com>
1136         * sysdeps/unix/sysv/linux/arm/sysdep-cancel.h
1137         (SINGLE_THREAD_P_PIC): Use "reg" instead of "lr".
1139 2003-03-21  Jakub Jelinek  <jakub@redhat.com>
1141         * sysdeps/i386/tls.h [__ASSUME_SET_THREAD_AREA_SYSCALL]
1142         (TLS_SETUP_GS_SEGMENT): Fix a typo.
1144 2003-03-19  Ulrich Drepper  <drepper@redhat.com>
1146         * sysdeps/pthread/Makefile: Fix cut&paste error.
1148 2003-03-18  Roland McGrath  <roland@redhat.com>
1150         * Versions (libpthread: GLIBC_2.2): Remove
1151         pthread_barrierattr_getpshared, never really existed.
1152         (libpthread: GLIBC_2.0): Move __pthread_initialize to ...
1153         (libpthread: GLIBC_PRIVATE): ... here.
1155 2003-03-14  Jakub Jelinek  <jakub@redhat.com>
1157         * sysdeps/unix/sysv/linux/sparc/sparc64/Makefile: New file.
1158         * sysdeps/unix/sysv/linux/sparc/Makefile ($(objpfx)specs): Use full
1159         path for crt[in].o.
1161 2003-03-14  Alexandre Oliva  <aoliva@redhat.com>
1163         * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Don't .set
1164         mips2 on new abi.
1165         * sysdeps/mips/pt-machine.h (__compare_and_swap): Likewise.
1166         Handle 64-bit longs on n64.
1168 2003-03-07  Jakub Jelinek  <jakub@redhat.com>
1170         * sysdeps/ia64/pspinlock.c (__pthread_spin_lock,
1171         __pthread_spin_trylock): Rewritten.
1173 2003-03-06  Ulrich Drepper  <drepper@redhat.com>
1175         * tst-cancel4.c (tf_sleep): Lower sleep time a bit to not upset
1176         recent kernels.
1178 2003-03-02  Ulrich Drepper  <drepper@redhat.com>
1180         * sysdeps/pthread/timer_create.c (timer_create): Return correct
1181         error for CPU clocks.
1183         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define
1184         _POSIX_MONOTONIC_CLOCK.
1185         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
1187 2003-03-01  Roland McGrath  <roland@redhat.com>
1189         * sysdeps/powerpc/powerpc64/pt-machine.h
1190         (THREAD_GETMEM, THREAD_GETMEM_NC, THREAD_SETMEM, THREAD_SETMEM_NC):
1191         New macros.
1192         * sysdeps/powerpc/tls.h: Don't define those here.
1194         * sysdeps/powerpc/tls.h [! USE_TLS && !__powerpc64__]: Define
1195         tcbhead_t with multiple_threads member.
1196         [USE_TLS] (tcbhead_t): Define minimal one-word version.
1197         [USE_TLS && !__powerpc64__] (TLS_MULTIPLE_THREADS_IN_TCB): Define.
1198         * sysdeps/powerpc/tcb-offsets.sym [USE_TLS]: Use tls.h macros to
1199         derive thread register offset of p_multiple_threads member.
1201         * descr.h (struct _pthread_descr_struct) [!USE_TLS || !TLS_DTV_AT_TP]:
1202         Conditionalize p_header member on this.
1203         [TLS_MULTIPLE_THREADS_IN_TCB]: Add p_multiple_threads alternatively.
1204         * sysdeps/ia64/tls.h [USE_TLS] (TLS_MULTIPLE_THREADS_IN_TCB): Define.
1205         * sysdeps/sh/tls.h: Likewise.
1206         * sysdeps/ia64/tcb-offsets.sym [USE_TLS]: Use p_multiple_threads.
1207         * sysdeps/sh/tcb-offsets.sym: Likewise.
1208         * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h
1209         (SINGLE_THREAD_P): Likewise.
1210         * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h
1211         (SINGLE_THREAD_P): Likewise.
1212         * sysdeps/unix/sysv/linux/powerpc/powerpc32/sysdep-cancel.h
1213         (SINGLE_THREAD_P): Likewise.
1214         * pthread.c (__pthread_initialize_manager): Likewise.
1215         * manager.c (pthread_handle_create): Likewise.
1217         * sysdeps/powerpc/tls.h [HAVE_TLS_SUPPORT]: Define USE_TLS and all
1218         related macros.
1220 2003-01-31  Steven Munroe  <sjmunroe@us.ibm.com>
1222         * sysdeps/unix/sysv/linux/powerpc/powerpc64/vfork.S [SHARED]:
1223         Conditionalize .toc section magic on this.
1225 2003-02-21  Roland McGrath  <roland@redhat.com>
1227         * cancel.c (__pthread_perform_cleanup): Call __libc_thread_freeres
1228         instead of __rpc_thread_destroy.
1230 2003-02-21  Jakub Jelinek  <jakub@redhat.com>
1232         * sysdeps/unix/sysv/linux/sparc/sparc64/vfork.S (__vfork): Call
1233         __fork instead of branching to it if BROKEN_SPARC_WDISP22.
1234         * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h (PSEUDO):
1235         Fix typo.
1236         * sysdeps/unix/sysv/linux/sparc/Makefile (specs): Add ./ prefix
1237         to crti.o and crtn.o.
1238         * sysdeps/unix/sysv/linux/x86_64/Makefile (specs): Likewise.
1240 2003-02-21  Roland McGrath  <roland@redhat.com>
1242         * Makefile (install-lib-ldscripts): New variable.
1244 2003-02-20  Franz Sirl  <Franz.Sirl-kernel@lauterbach.com>
1246         * sysdeps/unix/sysv/linux/powerpc/powerpc32/vfork.S: Avoid short
1247         interprocedure branches.
1249 2003-02-19  Ulrich Drepper  <drepper@redhat.com>
1251         * specific.c (pthread_key_delete_helper): Don't use GETMEM, we
1252         need the target thread's lock.
1254 2003-02-17  Ulrich Drepper  <drepper@redhat.com>
1256         * sysdeps/unix/sysv/linux/bits/local_lim.h: Define TTY_NAME_MAX
1257         and LOGIN_NAME_MAX.
1259 2003-02-17  Kevin B. Hendricks  <kevin.hendricks@sympatico.ca>
1260             Franz Sirl  <Franz.Sirl-kernel@lauterbach.com>
1262         * sysdeps/powerpc/Makefile: Handle tcb-offsets.sym.
1263         * sysdeps/powerpc/tcb-offsets.sym: New file.
1264         * sysdeps/powerpc/tls.h: New file.
1265         * sysdeps/powerpc/powerpc32/pt-machine.h (FLOATING_STACKS): Define.
1266         (ARCH_STACK_MAX_SIZE): Define.
1267         (THREAD_SELF): Define.
1268         (INIT_THREAD_SELF): Define.
1269         (THREAD_GETMEM): Define.
1270         (THREAD_GETMEM_NC): Define.
1271         (THREAD_SETMEM): Define.
1272         (THREAD_SETMEM_NC): Define.
1273         (__thread_self): Declare.
1274         * sysdeps/unix/sysv/linux/powerpc/powerpc32/sysdep-cancel.h: Adjust
1275         for thread register.
1277 2003-02-14  Steven Munroe  <sjmunroe@us.ibm.com>
1279         * sysdeps/unix/sysv/linux/powerpc/powerpc64/vfork.S (__vfork):
1280         Check pthread_create existance, not __pthread_fork.
1282 2003-02-12  Ulrich Drepper  <drepper@redhat.com>
1284         * sysdeps/pthread/Makefile: Define CFLAGS-confstr.c.
1286 2003-02-10  Jakub Jelinek  <jakub@redhat.com>
1288         * sysdeps/unix/sysv/linux/alpha/vfork.S (__vfork): Check
1289         pthread_create existance, not __pthread_fork.
1290         * sysdeps/unix/sysv/linux/i386/vfork.S (__vfork): Likewise.
1291         * sysdeps/unix/sysv/linux/ia64/vfork.S (__vfork): Likewise.
1292         * sysdeps/unix/sysv/linux/m68k/vfork.S (__vfork): Likewise.
1293         * sysdeps/unix/sysv/linux/powerpc/powerpc32/vfork.S (__vfork):
1294         Likewise.
1295         * sysdeps/unix/sysv/linux/s390/s390-64/vfork.S (__vfork): Likewise.
1296         * sysdeps/unix/sysv/linux/x86_64/vfork.S (__vfork): Likewise.
1297         * sysdeps/unix/sysv/linux/sh/vfork.S (__vfork): Likewise.
1298         Add .weak pthread_create.
1299         * sysdeps/unix/sysv/linux/sparc/sparc32/vfork.S (__vfork): Fix a typo.
1300         Check pthread_create existance, not __pthread_fork.
1301         * sysdeps/unix/sysv/linux/sparc/sparc64/vfork.S (__vfork): Likewise.
1302         * sysdeps/unix/sysv/linux/s390/s390-32/vfork.S (__vfork): Branch to
1303         __fork whenever libpthread.so is loaded.
1305 2003-02-09  Andreas Jaeger  <aj@suse.de>
1307         * sysdeps/unix/sysv/linux/x86_64/sysdep-cancel.h:
1308         Rework: %r9 is destroyed by functions so don't use it as
1309         temporary, align stack correctly, fix parameter for CDISABLE.
1311 2003-02-07  Kaz Kojima  <kkojima@rr.iij4u.or.jp>
1313         * sysdeps/sh/Makefile: New file.
1314         * sysdeps/sh/tcb-offsets.sym: Likewise.
1315         * sysdeps/sh/tls.h: Don't include sysdep.h. Move include
1316         of linuxthreads/descr.h after the definition of THREAD_SELF.
1317         (tcbhead_t): Use IA64 type tcbhead_t for TLS case.
1318         (TLS_TCB_SIZE): Set size of tcbhead_t.
1319         (TLS_PRE_TCB_SIZE): Define.
1320         (INSTALL_NEW_DTV): Set dtv of tcbhead_t structure instead of
1321         a member of thread structure.
1322         (THREAD_DTV): Likewise.
1323         (TLS_INIT_TP_EXPENSIVE): Remove.
1324         (TLS_INIT_TP): Set gbr register only.
1325         (THREAD_SELF): New.
1326         (INIT_THREAD_SELF): Likewise.
1327         (NONTLS_INIT_TP): New.
1328         * sysdeps/unix/sysv/linux/sh/pt-initfini.c (__fpscr_values):
1329         Remove.
1330         * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h (PSEUDO): Add
1331         SYSCALL_INST_PAD macro after DO_CALL.
1332         (SINGLE_THREAD_P): Fix non-PIC and TLS case so to read the
1333         correct variable.
1334         * sysdeps/unix/sysv/linux/sh/vfork.S (__vfork): Branch to __fork
1335         whenever libpthread.so is loaded.
1337 2003-02-08  Andreas Schwab  <schwab@suse.de>
1339         * sysdeps/unix/sysv/linux/m68k/vfork.S: Branch to __fork whenever
1340         libpthread.so is loaded.
1342 2003-02-07  Ulrich Drepper  <drepper@redhat.com>
1344         * sysdeps/unix/sysv/linux/i386/vfork.S: Make sure
1345         __ASSUME_VFORK_SYSCALL is not defined if the kernel headers have
1346         no __NR_vfork definition.
1348 2003-02-07  Jakub Jelinek  <jakub@redhat.com>
1350         * tst-popen2.c: New test.
1351         * Makefile (tests): Add tst-popen2.
1352         * sysdeps/unix/sysv/linux/alpha/vfork.S (__vfork): Branch to __fork
1353         whenever libpthread.so is loaded.
1354         * sysdeps/unix/sysv/linux/i386/vfork.S (__vfork): Likewise.
1355         * sysdeps/unix/sysv/linux/ia64/vfork.S (__vfork): Likewise.
1356         * sysdeps/unix/sysv/linux/s390/s390-64/vfork.S (__vfork): Likewise.
1357         * sysdeps/unix/sysv/linux/powerpc/powerpc32/vfork.S (__vfork):
1358         Likewise.
1359         * sysdeps/unix/sysv/linux/sparc/sparc32/vfork.S (__vfork): Likewise.
1360         * sysdeps/unix/sysv/linux/sparc/sparc64/vfork.S (__vfork): Likewise.
1361         * sysdeps/unix/sysv/linux/x86_64/vfork.S (__vfork): Likewise.
1363 2003-02-05  Ulrich Drepper  <drepper@redhat.com>
1365         * sysdeps/pthread/bits/libc-lock.h (__libc_once): Set control
1366         variable for non-libpthread case to the same value the
1367         pthread_once function would use.
1369 2003-02-03  Jakub Jelinek  <jakub@redhat.com>
1371         * sysdeps/unix/sysv/linux/sparc/sparc32/vfork.S (__vfork): If
1372         BROKEN_SPARC_WDISP22, handle SHARED the same way as non-SHARED.
1374 2003-02-04  Andreas Jaeger  <aj@suse.de>
1376         * sysdeps/unix/sysv/linux/hppa/pt-initfini.c: Do not use
1377         multi-line strings.
1379 2003-01-30  Jakub Jelinek  <jakub@redhat.com>
1381         * sysdeps/s390/tls.h (TLS_INIT_TP): Return NULL, not 0.
1383 2003-01-30  Jakub Jelinek  <jakub@redhat.com>
1385         * sysdeps/alpha/tls.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1386         THREAD_SETMEM, THREAD_SETMEM_NC): Avoid warnings about unused self
1387         variable.
1388         * sysdeps/ia64/pt-machine.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1389         THREAD_SETMEM, THREAD_SETMEM_NC): Likewise.
1390         * sysdeps/s390/s390-32/pt-machine.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1391         THREAD_SETMEM, THREAD_SETMEM_NC): Likewise.
1392         * sysdeps/s390/s390-64/pt-machine.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1393         THREAD_SETMEM, THREAD_SETMEM_NC): Likewise.
1394         * sysdeps/sh/pt-machine.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1395         THREAD_SETMEM, THREAD_SETMEM_NC): Likewise.
1396         * sysdeps/sparc/sparc32/pt-machine.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1397         THREAD_SETMEM, THREAD_SETMEM_NC): Likewise.
1398         * sysdeps/sparc/sparc64/pt-machine.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1399         THREAD_SETMEM, THREAD_SETMEM_NC): Likewise.
1401 2003-01-27  Martin Schwidefsky  <schwidefsky@de.ibm.com>
1403         * sysdeps/s390/s390-32/pt-machine.h (THREAD_SELF, INIT_THREAD_SELF):
1404         Define TLS versions.
1405         * sysdeps/s390/s390-64/pt-machine.h (THREAD_SELF, INIT_THREAD_SELF):
1406         Likewise.
1407         * sysdeps/s390/tls.h [HAVE_TLS_SUPPORT] (USE_TLS, TLS_INIT_TCB_SIZE,
1408         TLS_INIT_TCB_ALIGN, TLS_TCB_SIZE, TLS_TCB_ALIGN, TLS_TCB_AT_TP,
1409         INSTALL_DTV, INSTALL_NEW_DTV, GET_DTV, TLS_INIT_TP, THREAD_DTV):
1410         Define.
1411         * sysdeps/unix/sysv/linux/s390/s390-64/sysdep-cancel.h (PSEUDO): Use
1412         branch with 32 bit offset.
1413         * sysdeps/unix/sysv/linux/s390/s390-64/vfork.S: Likewise.
1415 2003-01-24  Jakub Jelinek  <jakub@redhat.com>
1417         * sysdeps/sparc/sparc32/pt-machine.h (__thread_self): Change to %g7,
1418         as required by TLS ABI.
1419         * sysdeps/sparc/sparc64/pt-machine.h (__thread_self): Likewise.
1420         * sysdeps/sparc/tls.h [HAVE_TLS_SUPPORT] (USE_TLS, TLS_INIT_TCB_SIZE,
1421         TLS_INIT_TCB_ALIGN, TLS_TCB_SIZE, TLS_TCB_ALIGN, TLS_TCB_AT_TP,
1422         INSTALL_DTV, INSTALL_NEW_DTV, GET_DTV, TLS_INIT_TP, THREAD_DTV):
1423         Define.
1424         [HAVE_TLS_SUPPORT]: Include descr.h and sysdep.h.
1425         * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h: Use %g7
1426         instead of %g6 for thread pointer.
1427         * sysdeps/unix/sysv/linux/sparc/sparc32/vfork.S: Likewise.
1428         * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h: Likewise.
1429         * sysdeps/unix/sysv/linux/sparc/sparc64/vfork.S: Likewise.
1431 2003-01-25  Guido Guenther  <agx@sigxcpu.org>
1433         * sysdeps/unix/sysv/linux/mips/sysdep-cancel.h: New file.
1434         * sysdeps/unix/sysv/linux/mips/Makefile: New file.
1436 2003-01-20  Martin Schwidefsky  <schwidefsky@de.ibm.com>
1438         * sysdeps/unix/sysv/linux/s390/s390-32/vfork.S: Avoid non pc relative
1439         reference to __fork.
1441 2003-01-17  Richard Henderson  <rth@redhat.com>
1443         * sysdeps/alpha/tls.h (tcbhead_t): Clarify second member.
1444         (TLS_TCB_SIZE, TLS_TCB_ALIGN): Set for tcbhead_t.
1445         (TLS_PRE_TCB_SIZE): New.
1446         (TLS_INIT_TP, THREAD_SELF, INIT_THREAD_SELF): Update for
1447         new ia64-style thread pointer layout.
1448         (THREAD_GETMEM, THREAD_GETMEM_NC): New.
1449         (THREAD_SETMEM, THREAD_SETMEM_NC): New.
1450         * sysdeps/unix/sysv/linux/alpha/vfork.S: Don't tail-call to __fork
1451         if !SHARED.
1453 2003-01-15  Jakub Jelinek  <jakub@redhat.com>
1455         * sysdeps/ia64/tls.h (tcbhead_t): Use the TLS ABI required layout
1456         if USE_TLS only.
1457         (NONTLS_INIT_TP): Revert last change.
1458         * sysdeps/ia64/tcb-offsets.sym (MULTIPLE_THREADS_OFFSET): Define to
1459         offsetof (tcbhead_t, multiple_threads) if USE_TLS not defined.
1461 2003-01-16  Jakub Jelinek  <jakub@redhat.com>
1463         * pthread.c (_pthread_initialize_minimal): Use
1464         GL(dl_tls_dtv_slotinfo_list) != NULL to check whether TLS has
1465         been already initialized.
1467 2003-01-16  Jakub Jelinek  <jakub@redhat.com>
1469         * sysdeps/i386/tls.h (INIT_SYSINFO): Initialize head->sysinfo even
1470         if not SHARED.
1472 2003-01-15  Jakub Jelinek  <jakub@redhat.com>
1474         * sysdeps/pthread/bits/libc-lock.h (__libc_lock_init,
1475         __libc_lock_init_recursive): Initialize fields directly.
1477 2003-01-15  Jakub Jelinek  <jakub@redhat.com>
1479         * sysdeps/unix/sysv/linux/alpha/vfork.S (__vfork): Allow
1480         __fork to be far away from __vfork ifndef SHARED.
1481         * sysdeps/unix/sysv/linux/powerpc/powerpc32/vfork.S (__vfork):
1482         Likewise.
1483         * sysdeps/unix/sysv/linux/sparc/sparc32/vfork.S (__vfork): Likewise.
1484         * sysdeps/unix/sysv/linux/sparc/sparc64/vfork.S (__vfork): Likewise.
1485         Add a missing instruction.
1486         * sysdeps/unix/sysv/linux/arm/vfork.S (__vfork): Conditionally
1487         branch to __fork even if __NR_vfork is not defined.
1489 2003-01-14  Ulrich Drepper  <drepper@redhat.com>
1491         * tst-cancel-wrappers.sh: Allow .__*_asynccancel functions names
1492         as well.
1494 2003-01-14  Steven Munroe  <sjmunroe@us.ibm.com>
1496         * sysdeps/unix/sysv/linux/powerpc/powerpc64/vfork.S: New file.
1498 2003-01-14  Jakub Jelinek  <jakub@redhat.com>
1500         * sysdeps/unix/sysv/linux/ia64/vfork.S (JUMPTARGET): Remove.
1502 2003-01-13  Martin Schwidefsky  <schwidefsky@de.ibm.com>
1504         * sysdeps/unix/sysv/linux/s390/s390-32/pt-initfini.c: Avoid
1505         unterminated string literals.
1506         * sysdeps/unix/sysv/linux/s390/s390-64/pt-initfini.c: Likewise.
1508 2003-01-13  Martin Schwidefsky  <schwidefsky@de.ibm.com>
1510         * sysdeps/unix/sysv/linux/s390/s390-32/sysdep-cancel.h
1511         (PSEUDO): Code reordering.  Move CENABLE and CDISABLE literals from
1512         PSEUDO_END to PSEUDO.
1513         (PSEUDO_END): Remove.
1514         (SINGLE_THREAD_P): Save an instruction.
1515         * sysdeps/unix/sysv/linux/s390/s390-32/vfork.S (__vfork): Add missing
1516         parameter to SINGLE_THREAD_P call.
1517         * sysdeps/unix/sysv/linux/s390/s390-64/sysdep-cancel.h (PSEUDO):
1518         Code reordering.
1520 2003-01-10  Andreas Schwab  <schwab@suse.de>
1522         * sysdeps/unix/sysv/linux/m68k/vfork.S: New file.
1524 2003-01-10  Martin Schwidefsky  <schwidefsky@de.ibm.com>
1526         * sysdeps/unix/sysv/linux/s390/s390-32/sysdep-cancel.h (PSEUDO): Setup
1527         backchain in pseudo_cancel.  Minor code improvements.
1528         * sysdeps/unix/sysv/linux/s390/s390-64/sysdep-cancel.h (PSEUDO):
1529         Likewise.
1531 2003-01-10  Martin Schwidefsky  <schwidefsky@de.ibm.com>
1533         * sysdeps/unix/sysv/linux/s390/s390-32/vfork.S: New file.
1534         * sysdeps/unix/sysv/linux/s390/s390-64/vfork.S: New file.
1536 2002-01-12  Franz Sirl  <Franz.Sirl-kernel@lauterbach.com>
1538         * sysdeps/unix/sysv/linux/powerpc/powerpc32/vfork.S: New file.
1540 2002-01-09  Richard Henderson  <rth@redhat.com>
1542         * sysdeps/unix/sysv/linux/alpha/sysdep-cancel.h: Assume only
1543         ret follows pseudo, and thus avoid branch-to-branch in cancel
1544         case.  Use SYSCALL_ERROR_LABEL.
1546 2003-01-11  Philip Blundell  <philb@gnu.org>
1548         * sysdeps/unix/sysv/linux/arm/vfork.S: New file.
1549         * sysdeps/unix/sysv/linux/arm/sysdep-cancel.h (PSEUDO_RET):
1550         Correctly unstack lr.
1551         (UNDOARGS_5): Fix ordering of pushes and pops.
1552         (SINGLE_THREAD_P_PIC): New.
1553         (SINGLE_THREAD_P_INT): New.
1554         (SINGLE_THREAD_P): Implement in terms of above.  Restore lr if it
1555         was stacked.
1556         (PSEUDO): Use SINGLE_THREAD_P_INT.
1558 2003-01-11  Kaz Kojima  <kkojima@rr.iij4u.or.jp>
1560         * sysdeps/unix/sysv/linux/sh/vfork.S: New file.
1562 2003-01-11  Jakub Jelinek  <jakub@redhat.com>
1564         * sysdeps/ia64/tls.h (tcbhead_t): Change into dtv_t *, void *.
1565         [HAVE_TLS_SUPPORT] (USE_TLS, TLS_INIT_TCB_SIZE, TLS_INIT_TCB_ALIGN,
1566         TLS_TCB_SIZE, TLS_PRE_TCB_SIZE, TLS_TCB_ALIGN, TLS_DTV_AT_TP,
1567         INSTALL_DTV, INSTALL_NEW_DTV, GET_DTV, TLS_INIT_TP, THREAD_SELF,
1568         INIT_THREAD_SELF): Define.
1569         [HAVE_TLS_SUPPORT]: Include descr.h.
1570         (NONTLS_INIT_TP): Point __thread_self at the end of dummy
1571         struct _pthread_descr_struct.
1572         * sysdeps/ia64/pt-machine.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1573         THREAD_SETMEM, THREAD_SETMEM_NC): Define using THREAD_SELF,
1574         not __thread_self.
1575         * sysdeps/ia64/tcb-offsets.sym (MULTIPLE_THREADS_OFFSET): Adjust
1576         computation.
1577         * pthread.c (__pthread_initialize_minimal): Use tcbp, not self
1578         for TCB pointer.
1579         (__pthread_initialize_manager): Rename tcb to mgr.
1580         Use tcbp for TCB pointer, if TLS_DTV_AT_TP set mgr to sizeof (struct
1581         _pthread_descr) below tcbp, otherwise to tcbp.
1582         * manager.c (pthread_handle_create): If TLS_DTV_AT_TP, set
1583         new_thread to be below _dl_allocate_tls ().  Adjust new_thread back
1584         before freeing.  Fix clone arguments if report_events and USE_TLS.
1585         (pthread_free): Adjust th back before freeing.
1587 2003-01-10  Steven Munroe  <sjmunroe@us.ibm.com>
1589         * sysdeps/unix/sysv/linux/powerpc/powerpc32/Makefile: Moved to ...
1590         * sysdeps/unix/sysv/linux/powerpc/Makefile: ...here.
1591         * sysdeps/unix/sysv/linux/powerpc/powerpc64/sysdep-cancel.h: New File.
1593 2003-01-09  Jakub Jelinek  <jakub@redhat.com>
1595         * sysdeps/unix/sysv/linux/i386/vfork.S: New file.
1596         * sysdeps/unix/sysv/linux/ia64/vfork.S: New file.
1597         * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h
1598         [__ASSEMBLER__] (SINGLE_THREAD_P): Remove trailing ;;.
1599         * sysdeps/unix/sysv/linux/sparc/sparc32/vfork.S: New file.
1600         * sysdeps/unix/sysv/linux/sparc/sparc64/vfork.S: New file.
1601         * sysdeps/unix/sysv/linux/x86_64/vfork.S: New file.
1602         * sysdeps/unix/sysv/linux/alpha/vfork.S: New file.
1603         * tst-popen.c: New test.
1604         * Makefile (tests): Add tst-popen.
1606 2003-01-06  Jakub Jelinek  <jakub@redhat.com>
1608         * sysdeps/unix/sysv/linux/sigwait.c (do_sigwait): Add
1609         INTERNAL_SYSCALL_DECL, add err argument to INTERNAL_SYSCALL* macros.
1611 2003-01-06  Jakub Jelinek  <jakub@redhat.com>
1613         * sysdeps/unix/sysv/linux/alpha/sysdep-cancel.h (PSEUDO): Use
1614         PSEUDO_PREPARE_ARGS.  Fix branch condition after SINGLE_THREAD_P.
1616 2003-01-06  Philip Blundell  <philb@gnu.org>
1618         * sysdeps/unix/sysv/linux/arm/sysdep-cancel.h: New file.
1620 2003-01-06  Jakub Jelinek  <jakub@redhat.com>
1622         * internals.h (LIBC_CANCEL_HANDLED): Define.
1623         * sysdeps/unix/sysv/linux/sigwait.c (LIBC_CANCEL_HANDLED): Add.
1624         * signals.c (LIBC_CANCEL_HANDLED): Add.
1625         * pt-system.c (LIBC_CANCEL_HANDLED): Add.
1626         * tst-cancel-wrappers.sh: Remove all exceptions.
1628         * sysdeps/unix/sysv/linux/alpha/Makefile: New file.
1630 2003-01-05  Andreas Schwab  <schwab@suse.de>
1632         * sysdeps/m68k/Makefile: New file, use -fPIC for nonshared
1633         objects.
1635         * sysdeps/unix/sysv/linux/m68k/sysdep-cancel.h (SINGLE_THREAD_P):
1636         Fix for PIC.
1637         (CENABLE): Likewise.
1638         (CDISABLE): Likewise.
1640 2003-01-05  Ulrich Drepper  <drepper@redhat.com>
1642         * tst-cancel-wrappers.sh: Invoke gawk not awk since we use GNU awk
1643         features.  Reported by Marijn Ros <marijn@mad.scientist.com>.
1645         * Makefile (libc.so-no-z-defs): Define to yes.
1647 2003-01-05  Kaz Kojima  <kkojima@rr.iij4u.or.jp>
1649         * sysdeps/sh/tls.h: Include dl-sysdep.h and stdint.h.
1650         (tcbhead_t): Add multiple_threads member.
1651         (TLS_INIT_TP_EXPENSIVE): Define.
1652         * sysdeps/unix/sysv/linux/sh/pt-initfini.c: Don't use multi-line
1653         strings.  Remove unused code.
1654         * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h: New file.
1656 2003-01-04  Franz Sirl  <Franz.Sirl-kernel@lauterbach.com>
1658         * sysdeps/unix/sysv/linux/powerpc/powerpc32/sysdep-cancel.h: New file.
1659         * sysdeps/unix/sysv/linux/powerpc/powerpc32/Makefile: New file.
1661 2003-01-04  Jakub Jelinek  <jakub@redhat.com>
1663         * internals.h (LIBC_THREAD_GETMEM, LIBC_THREAD_SETMEM): Define
1664         even if NOT_IN_libc is defined.
1666 2003-01-05  Jakub Jelinek  <jakub@redhat.com>
1668         * sysdeps/unix/sysv/linux/s390/s390-32/sysdep-cancel.h: New file.
1669         * sysdeps/unix/sysv/linux/s390/s390-64/sysdep-cancel.h: New file.
1670         * sysdeps/s390/Makefile: New file.
1671         * sysdeps/s390/tcb-offsets.sym: New file.
1672         * sysdeps/s390/tls.h: New file.
1674 2003-01-03  Richard Henderson  <rth@redhat.com>
1676         * sysdeps/unix/sysv/linux/alpha/sysdep-cancel.h: New file.
1678 2003-01-03  Andreas Jaeger  <aj@suse.de>
1680         * sysdeps/pthread/bits/libc-tsd.h: Declare weak_extern functions.
1682 2003-01-03  Jakub Jelinek  <jakub@redhat.com>
1684         * Makefile ($(objpfx)libpthread.so): Depend on ld.so.
1686 2003-01-02  Ulrich Drepper  <drepper@redhat.com>
1688         * tst-cancel-wrappers.sh: Exclude sigwait.c as well, it does not have
1689         cancellation tests.
1691 2003-01-02  Jakub Jelinek  <jakub@redhat.com>
1693         * internals.h (struct pthread_functions): Rename
1694         ptr_pthread_cond_* fields to ptr___pthread_cond_*.
1695         * pthread.c (pthread_functions): Adjust.
1696         * forward.c: Export both pthread_cond_*@@GLIBC_2.3.2 and
1697         pthread_cond_*@GLIBC_2.0 compatibility symbols.
1698         * Versions [libc] (GLIBC_2.3.2): Export pthread_cond_broadcast,
1699         pthread_cond_destroy, pthread_cond_init, pthread_cond_signal
1700         and pthread_cond_wait.
1702         * sysdeps/pthread/bits/pthreadtypes.h (__pthread_cond_align_t): New
1703         type.
1704         (pthread_cond_t): Add __align member, shorten __padding.
1705         * sysdeps/pthread/pthread.h (PHTREAD_COND_INITIALIZER): Initialize
1706         __padding and __align too.
1708         * sysdeps/pthread/bits/libc-lock.h (__libc_maybe_call2): Add
1709         __builtin_expect.
1710         * sysdeps/pthread/sigaction.c: New file.
1711         * sysdeps/unix/sysv/linux/raise.c: New file.
1712         * sysdeps/unix/sysv/linux/sigwait.c: New file.
1713         * sysdeps/unix/sysv/linux/fork.c (__pthread_fork): Protect
1714         weak_extern with #ifndef SHARED.
1715         * sysdeps/unix/sysv/linux/jmp-unwind.c (__pthread_cleanup_upto):
1716         Likewise.
1717         * signals.c (__sigaction): Renamed to...
1718         (__pthread_sigaction): ... this.
1719         (__sigaction): New strong alias, #ifdef SHARED only.
1720         (sigaction): Protect with #ifdef SHARED.
1721         (sigwait): Renamed to...
1722         (__pthread_sigwait): ... this.
1723         (sigwait): New strong alias, #ifdef SHARED only.
1724         (raise): Renamed to...
1725         (__pthread_raise): ... this.
1726         (raise): New strong alias, #ifdef SHARED only.
1727         * internals.h (__pthread_sigaction, __pthread_sigwait,
1728         __pthread_raise): New prototypes.
1729         (struct pthread_functions): Add ptr_pthread_sigaction,
1730         ptr_pthread_sigwait, ptr_pthread_raise.
1731         * pthread.c (pthread_functions): Renamed to...
1732         (__pthread_functions): ... this.  No longer static, no longer
1733         SHARED only.  Initialize ptr_pthread_sigaction, ptr_pthread_sigwait
1734         and ptr_pthread_raise.
1735         [SHARED] (ptr_pthread_functions): Change to &__pthread_functions.
1736         * libc-cancellation.c (__pthread_thread_self): Remove weak_extern.
1737         * ptfork.c (__fork, __vfork): Protect with #ifdef SHARED.
1738         * ptlongjmp.c (siglongjmp, longjmp): Protect with #ifdef SHARED.
1740         * Makefile (tests, tests-static): Add tst-cancel-static.
1741         * tst-cancel-static.c: New test.
1743 2003-01-02  Jakub Jelinek  <jakub@redhat.com>
1745         * Makefile (CFLAGS-pthread_atfork.c): Add -DNOT_IN_libc.
1747 2003-01-02  Ulrich Drepper  <drepper@redhat.com>
1749         * sysdeps/pthread/bits/pthreadtypes.h (pthread_cond_t): Add padding.
1750         * condvar.c: Add symbol versioning.  The compatibility versions
1751         are the same as the change in the interface does not effect this
1752         implementation.
1753         * Versions [libpthread]: Add definitions for new pthread_cond_*
1754         interfaces for version GLIBC_2.3.2.
1756 2002-12-31  Ulrich Drepper  <drepper@redhat.com>
1758         * sysdeps/unix/sysv/linux/fork.h: Add libc_hidden_proto for
1759         __register_atfork.
1760         * sysdeps/unix/sysv/linux/register-atfork.c: Add libc_hidden_def
1761         for __register_atfork.
1763 2002-12-31  Jakub Jelinek  <jakub@redhat.com>
1765         * sysdeps/i386/i686/pt-machine.h: Use __ASSEMBLER__ instead of
1766         ASSEMBLER test macro.
1767         * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h: Likewise.
1768         * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h: Likewise.
1769         * sysdeps/unix/sysv/linux/m68k/sysdep-cancel.h: Likewise.
1770         * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h: Likewise.
1771         * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h: Likewise.
1772         * sysdeps/unix/sysv/linux/x86_64/sysdep-cancel.h: Likewise.
1774         * sysdeps/pthread/errno-loc.c (__errno_location): Add
1775         libc_hidden_def.
1776         * sysdeps/pthread/herrno-loc.c (__h_errno_location): Likewise.
1777         * sysdeps/pthread/res-state.c (__res_state): Likewise.
1778         * sysdeps/unix/sysv/linux/allocrtsig.c (__libc_current_sigrtmin,
1779         __libc_current_sigrtmax): Likewise.
1780         * Versions [libc] (GLIBC_PRIVATE): Remove __libc_internal_tsd_get,
1781         __libc_internal_tsd_set, __libc_internal_tsd_address,
1782         __libc_alloca_cutoff.
1783         [libpthread] (GLIBC_PRIVATE): Remove __libc_internal_tsd_get,
1784         __libc_internal_tsd_set, __libc_internal_tsd_address.
1786         * sysdeps/pthread/list.h: Remove assert.h include.
1787         * sysdeps/unix/sysv/linux/fork.c: Include <fork.h>, not "fork.h".
1789         * sysdeps/pthread/list.h: New file.
1790         * sysdeps/unix/sysv/linux/jmp-unwind.c: New file.
1791         * sysdeps/unix/sysv/linux/fork.c: New file.
1792         * sysdeps/unix/sysv/linux/fork.h: New file.
1793         * sysdeps/unix/sysv/linux/ia64/fork.h: New file.
1794         * sysdeps/unix/sysv/linux/sparc/fork.h: New file.
1795         * sysdeps/unix/sysv/linux/register-atfork.c: New file.
1796         * sysdeps/unix/sysv/linux/unregister-atfork.c: New file.
1797         * sysdeps/unix/sysv/linux/Makefile: New file.
1798         * sysdeps/unix/sysv/linux/Versions: New file.
1799         * ptlongjmp.c (pthread_cleanup_upto): Rename to...
1800         (__pthread_cleanup_upto): ...this. Add targetframe argument,
1801         use it instead of currentframe.  No longer static.
1802         (siglongjmp, longjmp): Remove pthread_cleanup_upto calls.
1803         * internals.h (__pthread_cleanup_upto, __pthread_fork): New prototypes.
1804         (struct pthread_functions): Add ptr_pthread_fork,
1805         ptr_pthread_cleanup_upto.
1806         * pthread.c (pthread_functions): Initialize ptr_pthread_fork and
1807         ptr_pthread_cleanup_upto.
1808         * ptfork.c: Include fork.h.
1809         (struct handler_list, struct handler_list_block): Remove.
1810         (pthread_atfork_lock, pthread_atfork_prepare, pthread_atfork_parent,
1811         pthread_atfork_child): Remove.
1812         (pthread_insert_list, __pthread_atfork, pthread_call_handlers): Remove.
1813         (__pthread_fork): New function.
1814         (__fork, __vfork): Call __libc_fork.
1815         * Makefile (libpthread-routines): Add old_pthread_atfork.
1816         (libpthread-nonshared): Add pthread_atfork.
1817         (others): Depend on $(objpfx)libpthread_nonshared.a.
1818         ($(objpfx)libpthread_nonshared.a): New rule.
1819         (install): Depend on $(inst_libdir)/libpthread.so.
1820         ($(inst_libdir)/libpthread.so, $(inst_libdir)/libpthread_nonshared.a):
1821         New rules.
1822         (tests): Depend on libpthread_nonshared.a too.
1823         * old_pthread_atfork.c: New file.
1824         * pthread_atfork.c: New file.
1825         * Makeconfig (shared-thread-library): Include libpthread_nonshared.a
1826         too.
1828 2002-12-30  Jakub Jelinek  <jakub@redhat.com>
1830         * forward.c: Make all functions available by default again.  It
1831         caused too much trouble.
1832         * internals.h (struct pthread_functions): Rename ptr_pthread_exit
1833         and ptr_pthread_attr_init_2_* to ptr___pthread_exit and
1834         ptr___pthread_attr_init_2_*.
1835         * pthread.c (pthread_functions): Adjust.
1837 2002-12-28  Jakub Jelinek  <jakub@redhat.com>
1839         * libc_pthread_init.c (__libc_pthread_init): Remove
1840         MULTIPLE_THREADS_OFFSET check.
1841         * sysdeps/i386/tls.h: Include tcb-offsets.h in assembler.
1842         (SYSINFO_OFFSET): Remove.
1843         * sysdeps/i386/Makefile [csu] (gen-as-const-headers): Add
1844         tcb-offsets.sym.
1845         * sysdeps/i386/tcb-offsets.sym: New file.
1846         * sysdeps/pthread/tcb-offsets.h: New file.
1847         * sysdeps/sparc/sparc32/tls.h: Removed.
1848         * sysdeps/sparc/sparc64/tls.h: Move...
1849         * sysdeps/sparc/tls.h: ...here.  Include tcb-offsets.h in assembler.
1850         * sysdeps/sparc/Makefile: New file.
1851         * sysdeps/sparc/tcb-offsets.sym: New file.
1852         * sysdeps/ia64/tls.h: Include tcb-offsets.h in assembler.
1853         * sysdeps/ia64/Makefile: New file.
1854         * sysdeps/ia64/tcb-offsets.sym: New file.
1855         * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h
1856         (MULTIPLE_THREADS_OFFSET): Remove.
1857         Replace defined MULTIPLE_THREADS_OFFSET
1858         with defined FLOATING_STACKS && USE___THREAD.
1859         * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h
1860         (MULTIPLE_THREADS_OFFSET): Remove.
1861         * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h
1862         (MULTIPLE_THREADS_OFFSET): Remove.
1863         * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h
1864         (MULTIPLE_THREADS_OFFSET): Remove.
1865         * pthread.c (__pthread_initialize_manager): Remove
1866         MULTIPLE_THREADS_OFFSET cbeck.
1868         * tst-cancel-wrappers.sh: Add line continuations.
1870 2002-12-27  Jakub Jelinek  <jakub@redhat.com>
1872         * sysdeps/pthread/bits/libc-tsd.h: Include linuxthreads/descr.h
1873         and bits/libc-lock.h.
1874         (__libc_internal_tsd_get, __libc_internal_tsd_set,
1875         __libc_internal_tsd_address): Remove.
1876         (__pthread_internal_tsd_address, __pthread_internal_tsd_get,
1877         __pthread_internal_tsd_set): New weak_externs.
1878         (__libc_tsd_address, __libc_tsd_get, __libc_tsd_set): Define
1879         using __libc_maybe_call2.
1880         (__libc_tsd_key_t): Move to ...
1881         * descr.h (__libc_tsd_key_t): ...here.
1882         Remove bits/libc-tsd.h include.
1883         * sysdeps/pthread/errno-loc.c: New file.
1884         * sysdeps/pthread/herrno-loc.c: New file.
1885         * sysdeps/pthread/res-state.c: New file.
1886         * libc-cancellation.c (THREAD_GETMEM, THREAD_SETMEM): Remove.
1887         (__libc_enable_asynccancel, __libc_disable_asynccancel): Use
1888         thread_self unconditionally.  Use LIBC_THREAD_[SG]ETMEM instead
1889         of THREAD_[SG]ETMEM.
1890         * specific.c (libc_internal_tsd_set): Renamed to...
1891         __pthread_internal_tsd_set.  Remove static.
1892         (libc_internal_tsd_get): Renamed to...
1893         __pthread_internal_tsd_get.  Remove static.
1894         (libc_internal_tsd_address): Renamed to...
1895         __pthread_internal_tsd_address.  Remove static.
1896         (__libc_internal_tsd_set, __libc_internal_tsd_get,
1897         __libc_internal_tsd_address, __libc_alloca_cutoff): Remove.
1898         * internals.h [!NOT_IN_libc] (LIBC_THREAD_GETMEM, LIBC_THREAD_SETMEM):
1899         Define.
1900         (__pthread_internal_tsd_set, __pthread_internal_tsd_get,
1901         __pthread_internal_tsd_address): New prototypes.
1902         (struct pthread_functions): Add
1903         ptr_pthread_internal_tsd_([sg]et|address) fields.
1904         [!NOT_IN_libc && !FLOATING_STACKS] (thread_self): Define.
1905         * pthread.c (pthread_functions) [!USE_TLS && !HAVE___THREAD]:
1906         Initialize ptr_pthread_internal_tsd_([sg]et|address) fields.
1907         * Versions (libpthread): Remove __libc_alloca_cutoff@GLIBC_PRIVATE.
1908         * alloca_cutoff.c: New file.
1909         * no-tsd.c: Removed.
1910         * Makefile (routines): Remove no-tsd.  Add alloca_cutoff.
1911         * pt-system.c (system): Remove cancellation handling.
1912         * tst-cancel-wrappers.sh: Allow pt-system.o* to not use the
1913         cancellation routines.
1915         * sysdeps/i386/tls.h: Include dl-sysdep.h and stdint.h.
1916         (tcbhead_t): Add sysinfo field.
1917         (SYSINFO_OFFSET, INIT_SYSINFO): Define.
1918         (TLS_INIT_TP): Use INIT_SYSINFO.
1919         * sysdeps/unix/sysv/linux/i386/dl-sysdep.h: New file.
1920         * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h
1921         (MULTIPLE_THREADS_OFFSET): Adjust.
1922         * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h
1923         (MULTIPLE_THREADS_OFFSET): Likewise.
1924         * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h
1925         (MULTIPLE_THREADS_OFFSET): Likewise.
1926         * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h
1927         (MULTIPLE_THREADS_OFFSET): Likewise.
1928         * descr.h: Include stdint.h.
1929         (struct _pthread_descr_struct): Add p_header.data.sysinfo field.
1931 2002-12-22  Jakub Jelinek  <jakub@redhat.com>
1933         * libc_pthread_init.c: Include stdlib.h.
1934         * sysdeps/i386/tls.h (tcbhead_t): Add multiple_threads member.
1935         (TLS_INIT_TP_EXPENSIVE): Define.
1936         * sysdeps/pthread/bits/libc-lock.h (__libc_maybe_call,
1937         __libc_maybe_call2): In _LIBC check SHARED define.
1938         * sysdeps/ia64/tls.h: New file.
1939         * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h: New file.
1940         * sysdeps/unix/sysv/linux/ia64/Makefile: New file.
1941         * sysdeps/x86_64/tls.h (TLS_INIT_TP_EXPENSIVE): Define.
1942         * sysdeps/sparc/sparc32/tls.h: New file.
1943         * sysdeps/sparc/sparc64/tls.h: New file.
1944         * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h: New file.
1945         * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h: New file.
1946         * Makefile (tests): Add tst-cancel[1-6].
1947         (tests-reverse): Add tst-cancel5.
1948         Link libc.so before libpthread.so for tests-reverse.
1949         * tst-cancel1.c: New file.
1950         * tst-cancel2.c: New file.
1951         * tst-cancel3.c: New file.
1952         * tst-cancel4.c: New file.
1953         * tst-cancel5.c: New file.
1954         * tst-cancel6.c: New file.
1956 2002-12-27  Andreas Schwab  <schwab@suse.de>
1958         * sysdeps/unix/sysv/linux/m68k/sysdep-cancel.h: New file.
1960 2002-12-22  Roland McGrath  <roland@redhat.com>
1962         * Makefile (omit-deps): Add $(unix-syscalls:%=ptw-%).
1964 2002-12-21  Ulrich Drepper  <drepper@redhat.com>
1966         * pthread.c (init_rtsigs): Remove incomplete __builtin_expect.
1967         Reported by Art Hass <ahaas@airmail.net>.
1969 2002-12-19  Jakub Jelinek  <jakub@redhat.com>
1971         * forward.c (pthread_attr_init_2_0, pthread_attr_init_2_1):
1972         Use return 0 as 6th argument to FORWARD4.
1974 2002-12-18  Jakub Jelinek  <jakub@redhat.com>
1976         * sysdeps/i386/useldt.h (FLOATING_STACKS, ARCH_STACK_MAX_SIZE): Only
1977         define if __ASSUME_LDT_WORKS > 0.
1978         * libc-cancellation.c (THREAD_GETMEM, THREAD_SETMEM): Redefine to
1979         struct member access if !FLOATING_STACKS.
1980         * sysdeps/pthread/flockfile.c (flockfile): Change into weak alias.
1982 2002-12-18  Jakub Jelinek  <jakub@redhat.com>
1984         * internals.h (__pthread_thread_self): New prototype.
1985         (struct pthread_functions): Add ptr_pthread_thread_self field.
1986         * pthread.c (pthread_functions): Initialize ptr_pthread_thread_self.
1987         (__pthread_thread_self): New function.
1988         * libc-cancellation.c (__pthread_thread_self): Add weak_extern.
1989         (__libc_enable_asynccancel, __libc_disable_asynccancel): Don't
1990         use thread_self() directly if not FLOATING_STACKS.
1992 2002-12-18  Jakub Jelinek  <jakub@redhat.com>
1994         * sysdeps/x86_64/pt-machine.h: Guard most of the header
1995         with #ifndef __ASSEMBLER__.
1996         * pthread.c (pthread_functions): Use SHLIB_COMPAT around
1997         pthread_attr_init_2_0 use.
1999 2002-12-17  Jakub Jelinek  <jakub@redhat.com>
2001         * wrapsyscall.c: Removed.
2002         * weaks.c: Removed.
2003         * Makefile (distribute): Add tst-cancel-wrappers.sh.
2004         (routines): Remove weaks.  Add forward,
2005         libc_pthread_init, libc-cancellation.
2006         (shared-only-routines): Remove weaks.  Add forward.
2007         (libpthread-routines): Remove wrapsyscall.
2008         Add ptw-write, ptw-read, ptw-close, ptw-fcntl, ptw-accept,
2009         ptw-connect, ptw-recv, ptw-recvfrom, ptw-recvmsg, ptw-send,
2010         ptw-sendmsg, ptw-sendto, ptw-fsync, ptw-lseek, ptw-lseek64,
2011         ptw-llseek, ptw-msync, ptw-nanosleep, ptw-open, ptw-open64,
2012         ptw-pause, ptw-pread, ptw-pread64, ptw-pwrite, ptw-pwrite64,
2013         ptw-tcdrain, ptw-wait, ptw-waitpid, pt-system, pt-allocrtsig.
2014         (libpthread-shared-only-routines): Add pt-allocrtsig.
2015         (tests): Depend on $(objpfx)tst-cancel-wrappers.out.
2016         ($(objpfx)tst-cancel-wrappers.out): New rule.
2017         * sysdeps/pthread/bits/libc-lock.h: Include linuxthreads/internals.h
2018         if in libc.
2019         (__libc_maybe_call): In libpthread.* don't check for existance
2020         of the function.
2021         (__libc_maybe_call2): Define.
2022         (__libc_lock_init, __libc_lock_fini, __libc_lock_lock,
2023         __libc_lock_trylock, __libc_lock_unlock): Use it.
2024         * sysdeps/pthread/flockfile.c: New file.
2025         * sysdeps/pthread/ftrylockfile.c: New file.
2026         * sysdeps/pthread/funlockfile.c: New file.
2027         * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h: New file.
2028         * sysdeps/unix/sysv/linux/x86_64/sysdep-cancel.h: New file.
2029         * sysdeps/unix/sysv/linux/allocrtsig.c: New file.
2030         * libc-cancellation.c: New file.
2031         * forward.c: New file.
2032         * libc_pthread_init.c: New file.
2033         * pt-system.c: New file.
2034         * pthread.c: Remove locale.h.
2035         (__pthread_manager_thread): Initialize multiple_threads.
2036         (__pthread_multiple_threads): Declare.
2037         (pthread_functions): New variable.
2038         (__pthread_initialize_minimal): Remove __uselocale call.
2039         Call __libc_pthread_init.
2040         (__pthread_initialize_manager): Initialize __pthread_multiple_threads,
2041         initial thread's multiple_threads and __libc_multiple_threads.
2042         Check MULTIPLE_THREADS_OFFSET value. Initialize manager thread's
2043         multiple_threads.
2044         (pthread_setschedparam, pthread_getschedparam): Rename to __
2045         prefixed variants.  Add strong_alias.
2046         (current_rtmin, current_rtmax, __libc_current_sigrtmin,
2047         __libc_current_sigrtmax, __libc_allocate_rtsig): Remove.
2048         (init_rtsigs): Use __libc_current_sigrtmin_private.
2049         (pthread_initialize): Only call init_rtsigs if
2050         !__ASSUME_REALTIME_SIGNALS.
2051         (__pthread_require_wrappers, __pthread_require_lockfile): Remove.
2052         * internals.h (__pthread_attr_destroy, __pthread_attr_setdetachstate,
2053         __pthread_attr_getdetachstate, __pthread_attr_setschedparam,
2054         __pthread_attr_getschedparam, __pthread_attr_setschedpolicy,
2055         __pthread_attr_getschedpolicy, __pthread_attr_setinheritsched,
2056         __pthread_attr_getinheritsched, __pthread_attr_setscope,
2057         __pthread_attr_getscope, __pthread_cond_init,
2058         __pthread_cond_destroy, __pthread_cond_wait,
2059         __pthread_cond_signal, __pthread_cond_broadcast,
2060         __pthread_condattr_init, __pthread_condattr_destroy,
2061         __pthread_equal, __pthread_getschedparam,
2062         __pthread_setschedparam, __pthread_setcancelstate,
2063         __pthread_setcanceltype, __pthread_enable_asynccancel,
2064         __libc_enable_asynccancel, __libc_pthread_init): New prototype.
2065         (__pthread_mutex_init, __pthread_mutex_destroy,
2066         __pthread_mutex_lock, __pthread_mutex_unlock,
2067         __pthread_mutex_trylock): Likewise.
2068         Add hidden_proto.
2069         (struct pthread_functions): New type.
2070         (__libc_pthread_functions): New variable.
2071         (LIBC_CANCEL_ASYNC, LIBC_CANCEL_RESET): Define.
2072         * descr.h (struct _pthread_descr_struct): Add
2073         p_header.data.multiple_threads field.
2074         * manager.c (pthread_handle_create): Initialize multiple_threads.
2075         * cancel.c (__pthread_enable_asynccancel,
2076         __pthread_disable_asynccancel): New functions.
2077         (__pthread_provide_wrappers): Remove.
2078         (pthread_setcancelstate, pthread_setcanceltype): Rename to __
2079         prefixed variants.  Add strong_alias.
2080         * condvar.c (pthread_cond_init, pthread_cond_destroy,
2081         pthread_cond_wait, pthread_cond_signal, pthread_cond_broadcast,
2082         pthread_condattr_init, pthread_condattr_destroy): Likewise.
2083         * join.c (pthread_exit): Likewise.
2084         * attr.c (pthread_attr_destroy, pthread_attr_setdetachstate,
2085         pthread_attr_getdetachstate, pthread_attr_setschedparam,
2086         pthread_attr_getschedparam, pthread_attr_setschedpolicy,
2087         pthread_attr_getschedpolicy, pthread_attr_setinheritsched,
2088         pthread_attr_getinheritsched, pthread_attr_setscope,
2089         pthread_attr_getscope): Likewise.
2090         * mutex.c (__pthread_mutex_init, __pthread_mutex_destroy,
2091         __pthread_mutex_lock, __pthread_mutex_unlock,
2092         __pthread_mutex_trylock): Add hidden_def.
2093         * Versions (libc): Add __libc_pthread_init,
2094         __libc_current_sigrtmin_private, __libc_current_sigrtmax_private,
2095         __libc_allocate_rtsig_private @@GLIBC_PRIVATE.
2096         * lockfile.c: Remove some USE_IN_LIBIO guards.
2097         (__pthread_provide_lockfile): Remove.
2098         * pt-allocrtsig.c: New file.
2099         * tst-cancel-wrappers.sh: New test.
2101 2002-12-15  Ulrich Drepper  <drepper@redhat.com>
2103         * Versions [libpthread: GLIBC_2.3.2]: Remove creat, poll, pselect,
2104         readv, select, sigpause, sigsuspend, sigwaitinfo, waitid, writev.
2105         * wrapsyscall.c: Remove creat, poll, pselect, readv, select,
2106         sigpause, sigsuspend, sigwaitinfo, waitid, and writev wrappers.
2108 2002-12-10  Ulrich Drepper  <drepper@redhat.com>
2110         * wrapsyscall.c (CANCELABLE_SYSCALL): Don't define function as
2111         weak.  There is no reason for that.
2112         (CANCELABLE_SYSCALL_VA): Likewise.
2114 2002-12-09  Ulrich Drepper  <drepper@redhat.com>
2116         * wrapsyscall.c: Add wrappers for creat, poll, pselect, readv, select,
2117         sigpause, __xpg_sigpause, sigsuspend, sigwaitinfo, waitid, and writev.
2118         * Versions: Export creat, poll, pselect, readv, select, sigpause,
2119         __xpg_sigpause, sigsuspend, sigwaitinfo, waitid, and writev from
2120         libpthread in version GLIBC_2.3.2.
2122 2002-12-06  Ulrich Drepper  <drepper@redhat.com>
2124         * sysdeps/pthread/bits/libc-lock.h: Define __rtld_lock_* macros.
2126 2002-12-05  Roland McGrath  <roland@redhat.com>
2128         * pthread.c (__pthread_initialize_minimal)
2129         [USE_TLS && SHARED && !USE___THREAD]: Initialize TLS and set up the
2130         TCB if the dynamic linker didn't do it at startup.
2132         * sysdeps/i386/tls.h (TLS_INIT_TP): Make it return zero or an error
2133         string.
2134         (TLS_DO_SET_THREAD_AREA, TLS_DO_MODIFY_LDT, TLS_SETUP_GS_SEGMENT):
2135         Submacros updated.
2136         * sysdeps/x86_64/tls.h (TLS_INIT_TP): Likewise.
2137         * sysdeps/alpha/tls.h (TLS_INIT_TP): Likewise (always zero).
2139 2002-12-03  Roland McGrath  <roland@redhat.com>
2141         * pthread.c (pthread_initialize) [SHARED]: Copy dl_error_tsd value
2142         from dynamic linker internal cell to new libc cell.
2144 2002-11-28  Roland McGrath  <roland@redhat.com>
2146         * tst-context.c: #define IS_IN_libpthread around #include <tls.h>
2147         before other headers, so FLOATING_STACKS is not defined wrongly.
2149         * sysdeps/i386/tls.h [!IS_IN_libpthread]: Enable TLS support
2150         even if [! FLOATING_STACKS].
2151         (TLS_DO_MODIFY_LDT_KERNEL_CHECK): New macro.
2152         If not under [__ASSUME_LDT_WORKS > 0], then do a runtime check of
2153         dl_osversion >= 2.3.99 and fatal if not.
2154         (TLS_DO_MODIFY_LDT): Use it.
2156 2002-11-28  Ulrich Drepper  <drepper@redhat.com>
2158         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define macros which
2159         require it to 200112L.  Remove _POSIX_POLL and _POSIX_SELECT.
2160         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
2162 2002-11-19  Ulrich Drepper  <drepper@redhat.com>
2164         * Versions (libc: GLIBC_2.0): Remove names of functions which are
2165         not defined in libc.
2166         * Makefile (shared-only-routines): Add weaks.
2167         * weaks.c: Remove functions which are not exported from libc.so.
2169 2002-11-14  Roland McGrath  <roland@redhat.com>
2171         * libc-tsd.c: New file.
2172         * Makefile (distribute): Add it.
2173         (libc-link.so): New variable.
2174         ($(objpfx)libpthread.so): Depend on that instead of libc.so file name.
2175         (libc-ok-for-link): New variable.
2176         [$(versioning) = yes]: Include $(common-objpfx)tls.make and define
2177         libc-ok-for-link to $(use-thread).
2178         [$(libc-ok-for-link) = no]
2179         (libc-link.so): Set to $(objpfx)libc.so, not $(common-objpfx)libc.so.
2180         ($(objpfx)libc_pic_lite.a,$(objpfx)libc_pic_lite.os, $(objpfx)libc.so):
2181         New targets.
2182         (generated): Append them.
2183         (extra-objs): Append libc-tsd.os.
2185         * libc-tls-loc.c: New file.
2186         * Makefile (libpthread-routines): Add it.
2188 2002-11-14  Andreas Schwab  <schwab@suse.de>
2190         * sysdeps/unix/sysv/linux/ia64/pt-initfini.c: Fix unterminated
2191         string.
2193 2002-11-13  Roland McGrath  <roland@redhat.com>
2195         * Examples/ex6.c (main): Improve error reporting.
2197 2002-11-04  Ulrich Drepper  <drepper@redhat.com>
2199         * sysdeps/i386/Makefile: Compile pthread.c and sighandler.c with
2200         -fno-omit-frame-pointer.  Patch by Andreas Steinmetz <ast@domdv.de>.
2202         * sysdeps/i386/useldt.h [PIC] (USETLS_LOAD_EBX): Use correct input
2203         register number.
2204         (DO_SET_THREAD_AREA): Mark asm output specifiers correctly.
2206 2002-10-22  Jakub Jelinek  <jakub@redhat.com>
2208         * manager.c (pthread_start_thread): Call __uselocale even
2209         if [! SHARED].  Patch by Leon Kanter <leon@geon.donetsk.ua>.
2211 2002-10-17  Roland McGrath  <roland@redhat.com>
2213         * Makefile (unload): Don't link in libpthread.so.
2214         ($(objpfx)unload.out): Do depend on it.
2215         * unload.c (main): Improve error reporting.
2217 2002-10-09  Roland McGrath  <roland@redhat.com>
2219         * sysdeps/pthread/bits/libc-lock.h (__libc_maybe_call): New macro.
2220         Under [__PIC__], call the function via the pointer fetched for
2221         comparison rather than a call by name that uses the PLT.
2222         (__libc_lock_init, __libc_rwlock_init, __libc_lock_fini)
2223         (__libc_rwlock_fini, __libc_lock_lock, __libc_rwlock_rdlock)
2224         (__libc_rwlock_wrlock, __libc_lock_trylock, __libc_rwlock_tryrdlock)
2225         (__libc_rwlock_trywrlock, __libc_lock_unlock, __libc_rwlock_unlock)
2226         (__libc_key_create, __libc_getspecific, __libc_setspecific)
2227         (__libc_atfork): Use it.
2229         * pthread.c [SHARED] (__libc_dl_error_tsd): New function.
2230         (pthread_initialize) [SHARED]: Set _dl_error_catch_tsd to that.
2231         * Versions (libc: GLIBC_PRIVATE): Add __libc_dl_error_tsd.
2232         (ld: GLIBC_PRIVATE): Set removed.
2234 2002-10-11  Ulrich Drepper  <drepper@redhat.com>
2236         * sysdeps/unix/sysv/linux/execve.c: New file.
2238 2002-10-09  Jakub Jelinek  <jakub@redhat.com>
2240         * no-tsd.c: Include stdlib.h.
2242 2002-10-07  Jakub Jelinek  <jakub@redhat.com>
2244         * sysdeps/unix/sysv/linux/allocalim.h: New file.
2245         * descr.h (struct _pthread_descr_struct): Add p_alloca_cutoff
2246         field.
2247         * manager.c (__pthread_allocate_stack): Add out_stacksize argument.
2248         Pass stack size to caller.
2249         (pthread_handle_create): Set p_alloca_cutoff.
2250         * pthread.c (__pthread_initial_thread): Use C99 designated
2251         initializers.  Set p_alloca_cutoff.
2252         (__pthread_manager_thread): Likewise.
2253         (__pthread_initialize_minimal) [USE_TLS]: Set p_alloca_cutoff
2254         for initial thread.
2255         (__pthread_init_max_stacksize): Possibly decrease p_alloca_cutoff
2256         for initial thread.
2257         (__pthread_initialize_manager) [USE_TLS]: Set p_alloca_cutoff
2258         for manager thread.
2259         * specific.c (__libc_alloca_cutoff): New function.
2260         * no-tsd.c (__libc_alloca_cutoff): New function.
2261         * Versions: Export __libc_alloca_cutoff@@GLIBC_PRIVATE from libc
2262         and libpthread.
2264 2002-10-02  Kaz Kojima  <kkojima@rr.iij4u.or.jp>
2266         * sysdeps/sh/pt-machine.h: Make C code ifndef'ed with __ASSEMBLER__.
2267         * sysdeps/sh/tls.h: Likewise.
2268         * sysdeps/unix/sysv/linux/sh/smp.h: New file.
2270 2002-09-29  Jakub Jelinek  <jakub@redhat.com>
2272         * sysdeps/pthread/tst-timer.c (main): Clear
2273         SIGEV2.sigev_notify_attributes.
2275 2002-09-29  Ulrich Drepper  <drepper@redhat.com>
2277         * sysdeps/i386/useldt.h (DO_SET_THREAD_AREA): Don't use
2278         INLINE_SYSCALL for set_thread_area syscall.
2280 2002-09-28  Roland McGrath  <roland@redhat.com>
2282         * pthread.c (__pthread_reset_main_thread) [FLOATING_STACKS]:
2283         Don't call setrlimit, since we did no prior bogon we need to undo.
2285 2002-09-27  Roland McGrath  <roland@redhat.com>
2287         * sysdeps/x86_64/tls.h [__ASSEMBLER__]: Don't include <pt-machine.h>.
2289 2002-09-24  Roland McGrath  <roland@redhat.com>
2291         * sysdeps/x86_64/tls.h: New file.
2293 2002-09-23  Roland McGrath  <roland@redhat.com>
2295         * Examples/ex13.c (dump_mut): int -> size_t for counter.
2297 2002-09-18  Bruno Haible  <bruno@clisp.org>
2299         * Examples/ex10.c (thread): Fail if pthread_mutex_timedlock() returns
2300         an unexpected error code.
2302         * internals.h (__pthread_message): Add const to first parameter type.
2303         * pthread.c (__pthread_message): Likewise.
2305         * sysdeps/unix/sysv/linux/configure: Moved to ../sysdeps/pthread.
2307 2002-09-17  Roland McGrath  <roland@redhat.com>
2309         * sysdeps/i386/tls.h (TLS_DO_MODIFY_LDT, TLS_DO_SET_THREAD_AREA):
2310         Set the descriptor limit to the full 4GB, so %gs:OFFSET works for any
2311         offset (positive or negative) relative to the thread struct.
2312         * sysdeps/i386/useldt.h (DO_MODIFY_LDT, DO_SET_THREAD_AREA): Likewise.
2314 2002-09-12  Jakub Jelinek  <jakub@redhat.com>
2316         * sysdeps/unix/sysv/linux/sparc/sparc64/Makefile: Move...
2317         * sysdeps/unix/sysv/linux/sparc/Makefile: ...here.
2318         Replace /usr/lib/crt[in].o with crt[in].o too.
2320 2002-09-11  Steven Munroe  <sjmunroe@us.ibm.com>
2322         * sysdeps/powerpc/powerpc64/pt-machine.h: New file.
2324 2002-09-04  Bruno Haible  <bruno@clisp.org>
2326         * pthread.c: Include <sys/time.h>.
2327         (is_smp_system): Move to sysdeps/unix/sysv/linux/smp.h.
2328         * sysdeps/unix/sysv/linux/smp.h: New file, extracted from pthread.c.
2329         * Makefile (distribute): Add smp.h to the list.
2331 2002-09-04  Bruno Haible  <bruno@clisp.org>
2333         * sysdeps/alpha/pt-machine.h: Choose different include file location
2334         on non-Linux platforms.
2336         * wrapsyscall.c (PROMOTE_INTEGRAL_TYPE): New macro.
2337         (open, open64): Change va_arg argument type to the integral type to
2338         which mode_t promotes.
2340         * sysdeps/pthread/tst-timer.c (main): Don't assume anything about
2341         the structure of 'struct sigevent'.
2343         * errno.c (__errno_location, __h_errno_location, __res_state):
2344         Use prototype function definitions.
2346 2002-07-29  Steven Munroe  <sjmunroe@us.ibm.com>
2348         * shlib-versions: Set libpthread version to 2.3 for powerpc64.
2349         * sysdeps/powerpc/pt-machine.h: moved to...
2350         * sysdeps/powerpc/powerpc32/pt-machine.h: ...here
2351         * sysdeps/powerpc/powerpc64/pt-machine.h: New file.
2353 2002-09-02  Roland McGrath  <roland@redhat.com>
2355         * sysdeps/powerpc/Makefile (CFLAGS-pt-initfini.s): New variable.
2357 2002-09-01  Roland McGrath  <roland@redhat.com>
2359         * sysdeps/pthread/bits/libc-tsd.h (enum __libc_tsd_key_t): Add new keys
2360         CTYPE_B, CTYPE_TOLOWER, CTYPE_TOUPPER.
2362         * sysdeps/pthread/bits/libc-tsd.h (__libc_tsd_address): New macro.
2363         (__libc_internal_tsd_address): Declare it.
2364         * Versions (libc, ld, libpthread: GLIBC_PRIVATE): Add
2365         __libc_internal_tsd_address.
2366         * specific.c (libc_internal_tsd_address): New function.
2367         (__libc_internal_tsd_address): New variable.
2368         * no-tsd.c (__libc_internal_tsd_address): New variable.
2370 2002-08-31  Ulrich Drepper  <drepper@redhat.com>
2372         * Makefile: Don't use rule for crt%.o, spell it out as rules for
2373         crti.o and crtn.o.
2375 2002-08-30  Roland McGrath  <roland@redhat.com>
2377         * Makefile (extra-objs, omit-deps): Add crtn.
2378         ($(objpfx)libpthread.so): Depend on $(objpfx)crtn.o.
2379         ($(objpfx)libpthread.so: +postinit): Append $(objpfx)crtn.o.
2380         ($(objpfx)crtn.S): New target.
2381         ($(objpfx)crt%.o): Pattern rule replaces crti.o target.
2382         (generated): Add crtn.S.
2384         * sysdeps/unix/sysv/linux/x86_64/Makefile ($(objpfx)specs): Massage
2385         crtn.o pathname too.
2387 2002-08-30  Jakub Jelinek  <jakub@redhat.com>
2389         * pthread.c (__pthread_initialize_minimal): Call __uselocale even
2390         if [! SHARED].
2392 2002-08-30  Roland McGrath  <roland@redhat.com>
2394         * tst-static-locale.c: New file.
2395         * Makefile (tests, tests-static): Add it.
2397 2002-04-24  Steven Munroe  <sjmunroe@us.ibm.com>
2399         * spinlock.c (__pthread_lock): Fix spurious wakeup
2400         handling.  Don't clear lowest bit of list pointer as sign the thread
2401         is still on the wait list.  Don't restart after spurious wakeup
2402         with spinning to get the lock.
2403         (__pthread_unlock): Take set lowest bit into account when handling
2404         pointer to list elements.
2405         Patch by Steve Munroe <sjmunroe@us.ibm.com>.
2407 2002-08-28  Roland McGrath  <roland@redhat.com>
2409         * sysdeps/pthread/timer_routines.c (thread_func): Fix type in cast.
2411 2002-08-28  Jakub Jelinek  <jakub@redhat.com>
2413         * sysdeps/unix/sysv/linux/hppa/aio_cancel.c: New file.
2414         * sysdeps/unix/sysv/linux/sparc/aio_cancel.c: New file.
2415         * sysdeps/unix/sysv/linux/alpha/aio_cancel.c: New file.
2417 2002-08-28  Ulrich Drepper  <drepper@redhat.com>
2419         * sysdeps/pthread/timer_routines.c (thread_func): Change return
2420         type to void and add casts in use to avoid warnings with all gcc
2421         versions.
2423 2002-08-08  Jakub Jelinek  <jakub@redhat.com>
2425         * sysdeps/unix/sysv/linux/bits/local_lim.h (PTHREAD_THREADS_MAX):
2426         Bump to 16384.
2427         * manager.c (__pthread_handles): Remove.
2428         * pthandles.c: New file.
2429         * pthread.c (__pthread_initialize_minimal): Initialize
2430         __pthread_handles[0] and __pthread_handles[1].
2431         * Makefile (libpthread-routines): Add pthandles (must be last).
2433 2002-08-26  Brian Youmans  <3diff@gnu.org>
2435         * Examples/ex10.c: Corrected version number in Lesser GPL copying
2436         permission notice from 2 to 2.1.
2437         * Examples/ex11.c: Likewise.
2438         * Examples/ex13.c: Likewise.
2439         * Examples/ex8.c: Likewise.
2440         * Examples/ex9.c: Likewise.
2441         * barrier.c: Likewise.
2442         * events.c: Likewise.
2443         * lockfile.c: Likewise.
2444         * no-tsd.c: Likewise.
2445         * pt-machine.c: Likewise.
2446         * ptclock_gettime.c: Likewise.
2447         * ptclock_settime.c: Likewise.
2448         * rwlock.c: Likewise.
2449         * sysdeps/alpha/pspinlock.c: Likewise.
2450         * sysdeps/alpha/pt-machine.h: Likewise.
2451         * sysdeps/arm/pspinlock.c: Likewise.
2452         * sysdeps/arm/pt-machine.h: Likewise.
2453         * sysdeps/cris/pspinlock.c: Likewise.
2454         * sysdeps/cris/pt-machine.h: Likewise.
2455         * sysdeps/hppa/pspinlock.c: Likewise.
2456         * sysdeps/hppa/pt-machine.h: Likewise.
2457         * sysdeps/i386/i686/pt-machine.h: Likewise.
2458         * sysdeps/i386/pspinlock.c: Likewise.
2459         * sysdeps/i386/pt-machine.h: Likewise.
2460         * sysdeps/i386/useldt.h: Likewise.
2461         * sysdeps/ia64/pspinlock.c: Likewise.
2462         * sysdeps/ia64/pt-machine.h: Likewise.
2463         * sysdeps/m68k/pspinlock.c: Likewise.
2464         * sysdeps/m68k/pt-machine.h: Likewise.
2465         * sysdeps/mips/pspinlock.c: Likewise.
2466         * sysdeps/mips/pt-machine.h: Likewise.
2467         * sysdeps/powerpc/pspinlock.c: Likewise.
2468         * sysdeps/powerpc/pt-machine.h: Likewise.
2469         * sysdeps/pthread/bits/initspin.h: Likewise.
2470         * sysdeps/pthread/bits/libc-lock.h: Likewise.
2471         * sysdeps/pthread/bits/libc-tsd.h: Likewise.
2472         * sysdeps/pthread/getcpuclockid.c: Likewise.
2473         * sysdeps/pthread/posix-timer.h: Likewise.
2474         * sysdeps/pthread/timer_create.c: Likewise.
2475         * sysdeps/pthread/timer_delete.c: Likewise.
2476         * sysdeps/pthread/timer_getoverr.c: Likewise.
2477         * sysdeps/pthread/timer_gettime.c: Likewise.
2478         * sysdeps/pthread/timer_routines.c: Likewise.
2479         * sysdeps/pthread/timer_settime.c: Likewise.
2480         * sysdeps/pthread/tst-timer.c: Likewise.
2481         * sysdeps/s390/pspinlock.c: Likewise.
2482         * sysdeps/s390/s390-32/pt-machine.h: Likewise.
2483         * sysdeps/s390/s390-64/pt-machine.h: Likewise.
2484         * sysdeps/sh/pspinlock.c: Likewise.
2485         * sysdeps/sh/pt-machine.h: Likewise.
2486         * sysdeps/sparc/sparc32/pspinlock.c: Likewise.
2487         * sysdeps/sparc/sparc32/pt-machine.h: Likewise.
2488         * sysdeps/sparc/sparc32/sparcv9/pspinlock.c: Likewise.
2489         * sysdeps/sparc/sparc64/pspinlock.c: Likewise.
2490         * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
2491         * sysdeps/unix/sysv/linux/bits/local_lim.h: Likewise.
2492         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Likewise.
2493         * sysdeps/unix/sysv/linux/bits/sigthread.h: Likewise.
2494         * sysdeps/unix/sysv/linux/hppa/bits/initspin.h: Likewise.
2495         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
2496         * tststack.c: Likewise.
2497         * unload.c: Likewise.
2498         * weaks.c: Likewise.
2499         * wrapsyscall.c: Likewise.
2501         * sysdeps/pthread/pt-initfini.c: Changed copying
2502         permission notice to Lesser GPL from Library GPL, including the
2503         references in the special exception.
2504         * sysdeps/unix/sysv/linux/hppa/pt-initfini.c: Likewise.
2505         * sysdeps/unix/sysv/linux/ia64/pt-initfini.c: Likewise.
2506         * sysdeps/unix/sysv/linux/s390/s390-32/pt-initfini.c:
2507         Likewise.
2508         * sysdeps/unix/sysv/linux/s390/s390-64/pt-initfini.c:
2509         Likewise.
2510         * sysdeps/unix/sysv/linux/sh/pt-initfini.c: Likewise.
2512 2002-08-26  Ulrich Drepper  <drepper@redhat.com>
2514         * Examples/ex10.c (thread): tv_nsec == 1000000000 is already
2515         overflow [PR libc/4244].
2517 2002-08-25  Ulrich Drepper  <drepper@redhat.com>
2519         * sysdeps/pthread/timer_routines.c (thread_func): Make the
2520         compiler happy by adding a return statement which will never be
2521         reached.
2523         * tst-context.c (main): Cast to long before casting to pointer.
2525         * Examples/ex17.c (main): Use correct format string.
2527         * Examples/ex9.c (thread): Remove incorrect return statement.
2529 2002-08-23  Ulrich Drepper  <drepper@redhat.com>
2531         * pthread.c (__linuxthreads_version): New global constant.
2533 2002-08-23  Andreas Jaeger  <aj@suse.de>
2535         * sysdeps/x86_64/pt-machine.h: Use %fs instead of %gs
2536         as thread specific register.
2537         (testandset): Fix inline asm.
2538         (THREAD_GETMEM): Fix inline asm.
2540 2002-08-22  Roland McGrath  <roland@redhat.com>
2542         * sysdeps/i386/useldt.h (INIT_THREAD_SELF): Remove [HAVE_TLS_SUPPORT]
2543         conditional.
2544         (INIT_THREAD_SELF): Pass second arg to DO_SET_THREAD_AREA.
2545         (DO_SET_THREAD_AREA): Take second arg, pass to DO_SET_THREAD_AREA_REUSE
2546         macro.  That chooses whether to reuse %gs value or let kernel set it.
2547         [USE_TLS] (DO_SET_THREAD_AREA_REUSE): New macro, always 1.
2548         [!USE_TLS] (DO_SET_THREAD_AREA_REUSE): New macro, true if arg is
2549         not constant 0.
2551 2002-08-21  Ulrich Drepper  <drepper@redhat.com>
2553         * sysdeps/i386/tls.h (TLS_SETUP_GS_SEGMENT): Add new parameter
2554         also to the third definition of this macro.
2556 2002-06-17  Andreas Jaeger  <aj@suse.de>
2558         * sysdeps/unix/sysv/linux/x86_64/Makefile (CFLAGS-pt-initfini.s):
2559         Set it.
2561 2002-08-20  Ulrich Drepper  <drepper@redhat.com>
2563         * sysdeps/i386/useldt.h: Go back to using 16-bit instructions when
2564         loading/reading segment registers.  Some old hardware doesn't
2565         handle the 32-bit instructions as expected.
2566         * sysdeps/i386/tls.h: Likewise.
2568         * sysdeps/i386/tls.h (TLS_DO_SET_THREAD_AREA): Second parameter is
2569         renamed to secondcall and use is negated.
2570         (TLS_SETUP_GS_SEGMENT): Likewise.
2571         (TLS_INIT_TP): Likewise.
2572         * sysdeps/sh/tls.h (TLS_INIT_TP): Second parameter is renamed to
2573         secondcall.
2575         * sysdeps/i386/tls.h: Use 32-bit operations when handling segment
2576         registers.  No need to mask upper 16 bits in this case.
2577         * sysdeps/i386/useldt.h: Likewise.
2578         (DO_SET_THREAD_AREA): We have to load %gs again even if the value
2579         is the same since the GDT content changed.
2581         * sysdeps/i386/tls.h (TLS_INIT_TP): Add new parameter and pass it on
2582         to TLS_SETUP_GS_SEGMENT.
2583         (TLS_SETUP_GS_SEGMENT): Add new parameter and pass it on to
2584         TLS_DO_SET_THREAD_AREA.
2585         (TLS_DO_SET_THREAD_AREA): If new parameter is zero determine
2586         entry number from %gs value.
2587         * sysdeps/sh/tls.h (TLS_INIT_TP): Add new parameter and simply
2588         ignore it.
2590         * manager.c (pthread_handle_create): Pass NULL to _dl_allocate_tls.
2591         Pass true to _dl_deallocate_tls.
2592         (pthread_free): Likewise.
2593         * pthread.c (__pthread_initialize_manager): Likewise.
2595 2002-08-19  Ulrich Drepper  <drepper@redhat.com>
2597         * sysdeps/i386/useldt.h (DO_SET_THREAD_AREA): Use correct shift when
2598         computing index from %gs value.
2600 2002-08-16  Roland McGrath  <roland@redhat.com>
2602         * sysdeps/i386/tls.h (TLS_DO_SET_THREAD_AREA): Calculate segment
2603         register value from entry number properly.
2605         * sysdeps/i386/tls.h (TLS_DO_MODIFY_LDT): Rewrite asm to use %ebx
2606         optimally conditional on [__PIC__].
2607         (TLS_DO_SET_THREAD_AREA): New macro, implement inline syscall
2608         without touching errno, and use latest modify_ldt-like interface.
2609         (TLS_SETUP_GS_SEGMENT): Use that instead of INLINE_SYSCALL.
2610         * sysdeps/i386/useldt.h (DO_MODIFY_LDT): Set %gs in this macro.
2611         (DO_SET_THREAD_AREA): New macro, uses current syscall interface with
2612         existing %gs value as the segment to set.
2613         (INIT_THREAD_SELF): Rewritten using those.  Use set_thread_area only
2614         under [HAVE_TLS_SUPPORT] so we can rely on the initialization done
2615         by the first thread's early TLS setup.
2617 2002-08-15  Roland McGrath  <roland@redhat.com>
2619         * sysdeps/i386/tls.h (TLS_INIT_TP): Use statement expression and
2620         return a value as callers now expect.
2622 2002-08-11  Roland McGrath  <roland@redhat.com>
2624         * pthread.c (__pthread_initialize_manager): Initialize
2625         p_header.data.tcb field of manager thread's descriptor.
2626         (__pthread_initialize_minimal): Don't initialize p_header.data.self
2627         field, already done by TLS_INIT_TP.
2629         * manager.c (pthread_handle_create): Move p_header field initializers
2630         together.
2632 2002-08-08  Ulrich Drepper  <drepper@redhat.com>
2634         * sysdeps/i386/tls.h (TLS_DO_SET_THREAD_AREA): Removed.
2636 2002-08-07  Ulrich Drepper  <drepper@redhat.com>
2638         * pthread.c (__linuxthreads_initial_report_events): New variable.
2639         (__pthread_initialize_manager): Use it to initialize p_report_events
2640         of initial thread.
2641         [TLS]: Store pointer to descriptor of manager in __pthread_handles.
2643 2002-08-07  Roland McGrath  <roland@redhat.com>
2645         * sysdeps/i386/tls.h (TLS_DO_MODIFY_LDT): Add an extra argument with
2646         an "m" constraint to the asm so the compiler knows LDT_ENTRY was used.
2648 2002-08-02  Roland McGrath  <roland@redhat.com>
2650         * sysdeps/pthread/bits/libc-tsd.h (enum __libc_tsd_key_t):
2651         Add _LIBC_TSD_KEY_LOCALE.
2652         * manager.c (pthread_start_thread) [!(USE_TLS && HAVE___THREAD)]:
2653         Call __uselocale to initialize our per-thread locale pointer to
2654         the global one.
2655         * pthread.c (__pthread_initialize_minimal): Likewise.
2657         * sysdeps/i386/tls.h (TLS_DO_SET_THREAD_AREA): Add missing \s.
2659 2002-08-02  Ulrich Drepper  <drepper@redhat.com>
2661         * pthread.c: Declare _errno, _h_errno, and _res unless we use TLS
2662         internally.
2664         * cancel.c (__pthread_perform_cleanup) [USE_TLS && HAVE___THREAD]:
2665         Don't use p_libc_specific element in thread descriptor.
2667 2002-07-30  Roland McGrath  <roland@redhat.com>
2669         * sysdeps/pthread/bits/libc-tsd.h: Include <tls.h>.
2670         [USE_TLS && HAVE___THREAD]: Just include the sysdeps/generic file,
2671         which does the right thing when __thread support is available.
2672         * descr.h (struct _pthread_descr_struct) [USE_TLS && HAVE___THREAD]:
2673         Omit `p_libc_specific', `p_errnop', `p_errno', `p_h_errnop',
2674         `p_h_errno', `p_resp', and `p_res' members.
2675         * pthread.c (__pthread_initialize_minimal) [USE_TLS && HAVE___THREAD]:
2676         Don't initialize `p_errnop' and `p_h_errnop' members.
2677         (__pthread_reset_main_thread): Likewise.
2678         (__pthread_initialize_manager): Likewise.
2679         * manager.c (__pthread_manager, pthread_handle_create): Likewise.
2680         * pthread.c (pthread_initialize) [USE_TLS && HAVE___THREAD]:
2681         Don't initialize `p_resp' member.
2682         (__pthread_reset_main_thread): Likewise.
2683         * manager.c (pthread_handle_create): Likewise.
2684         * specific.c (libc_internal_tsd_set, libc_internal_tsd_get):
2685         Conditionalize these on [!(USE_TLS && HAVE___THREAD)].
2686         * no-tsd.c: Conditionalize contents on [!(USE_TLS && HAVE___THREAD)].
2687         * errno.c [USE_TLS && HAVE___THREAD]
2688         (__h_errno_location, __res_state): Don't define these at all.
2690         * sysdeps/i386/tls.h (INSTALL_DTV): Add parens around arguments!
2691         (INSTALL_NEW_DTV, GET_DTV): Likewise.
2692         * sysdeps/sh/tls.h (INSTALL_DTV, INSTALL_NEW_DTV, GET_DTV): Likewise.
2694         * weaks.c: Don't include <errno.h> here.
2696 2002-08-01  Roland McGrath  <roland@redhat.com>
2698         * sysdeps/i386/tls.h (TLS_DO_MODIFY_LDT): New macro, broken out of
2699         TLS_INIT_TP.
2700         (TLS_DO_SET_THREAD_AREA): New macro, uses thread_set_area syscall.
2701         (TLS_SETUP_GS_SEGMENT): New macro, try one or the other or both.
2702         (TLS_INIT_TP): Use that.
2704 2002-08-02  Jakub Jelinek  <jakub@redhat.com>
2706         * sysdeps/i386/useldt.h (DO_MODIFY_LDT): Move from INIT_THREAD_SELF.
2707         (INIT_THREAD_SELF): Use sys_thread_area syscall instead if available.
2708         (FREE_THREAD): Avoid modify_ldt if using GDT.
2709         * sysdeps/i386/pspinlock.c (__have_no_set_thread_area): New variable.
2711 2002-07-25  Jakub Jelinek  <jakub@redhat.com>
2713         * sysdeps/i386/tls.h: Use __ASSEMBLER__ test macro not ASSEMBLER.
2714         * sysdeps/i386/pt-machine.h: Likewise.
2715         * sysdeps/i386/useldt.h: Likewise.
2717 2002-07-22  Ulrich Drepper  <drepper@redhat.com>
2719         * pthread.c (__pthread_initialize_minimal): If !SHARED and TLS
2720         call __libc_setup_tls first.
2721         * Makefile: Actually create tst-signal.out file when running the test.
2722         (tests): Add tststatic.
2723         * Examples/tststatic.c: New file.
2725 2002-07-19  Ulrich Drepper  <drepper@redhat.com>
2727         * errno.c (__errno_location): Don't define unless !USE_TLS
2728         || !HAVE___THREAD.
2729         * sysdeps/i386/pt-machine.c: Protect C code with #ifndef ASSEMBLER.
2730         * sysdeps/i386/tls.h: Likewise.
2731         * sysdeps/i386/useldt.h: Likewise.
2732         * sysdeps/i386/i686/pt-machine.h: Likewise.
2734 2002-07-02  H.J. Lu  <hjl@gnu.org>
2736         * sysdeps/mips/pspinlock.c: Don't include <sgidefs.h>.  Always
2737         use ll/sc.
2738         * sysdeps/mips/pt-machine.h: Likewise.
2740 2002-07-14  Ulrich Drepper  <drepper@redhat.com>
2742         * manager.c (pthread_handle_create): Initialize self-reference in
2743         descriptor.
2745 2002-07-01  Jakub Jelinek  <jakub@redhat.com>
2747         * Examples/ex9.c (main): Remove unused th variable.
2749 2002-07-10  Ulrich Drepper  <drepper@redhat.com>
2751         * wrapsyscall.c: Add __nanosleep alias.
2752         * Versions (GLIBC_2.2.6): Add __nanosleep.
2753         * bug-sleep.c: New file.
2754         * Makefile (tests): Add bug-sleep.
2756 2002-06-19  Steven Munroe  <sjmunroe@vnet.ibm.com>
2758         * Examples/ex9.c (main):  Use list of children and join them.
2759         (thread): Do not call exit.
2761 2002-06-20  Ulrich Drepper  <drepper@redhat.com>
2763         * spinlock.c (wait_node_alloc): We cannot use compare-and-exchange.
2764         Unconditionally use the code using spinlock.  Use __pthread_release
2765         to free a spinlock.
2766         (wait_node_free): Likewise.
2767         (__pthread_acquire, __pthread_release): Unconditionally define.
2769 2002-06-07  Jakub Jelinek  <jakub@redhat.com>
2771         * sysdeps/ia64/pt-machine.h (MEMORY_BARRIER): Fix typo.
2773 2002-05-24  Ulrich Drepper  <drepper@redhat.com>
2775         * sysdeps/ia64/pt-machine.h (MEMORY_BARRIER): Use __sync_synchronize.
2777 2002-05-21  Ulrich Drepper  <drepper@redhat.com>
2779         * sysdeps/pthread/pthread.h (pthread_create): Rename first
2780         parameter.
2781         (pthread_cancel): Likewise.
2782         * internals.h (__pthread_create_2_1): Likewise.
2783         * sysdeps/unix/sysv/linux/bits/sigthread.h (pthread_kill): Likewise.
2785 2002-05-20  Ulrich Drepper  <drepper@redhat.com>
2787         * sysdeps/alpha/pt-machine.c (THREAD_SELF): Remove clobber.
2788         Patch by Glen Nakamura <gen@flex.com>.
2790 2002-05-03  Ulrich Drepper  <drepper@redhat.com>
2792         * signals.c: Move sighandler functions to...
2793         * sighandler.c: ...here.  New file.
2794         * signals.c: Move signal handler related type definitions to...
2795         * internals.h: ...here.  Add prototypes for signal handlers.
2796         * Makefile (libpthread-routines): Add sighandler.
2797         (CFLAGS-sighandler.c): Add $(exceptions).
2799 2002-04-30  Jakub Jelinek  <jakub@redhat.com>
2801         * sysdeps/unix/sysv/linux/x86_64/Makefile: New file.
2803 2002-04-08  Ulrich Drepper  <drepper@redhat.com>
2805         * sysdeps/pthread/timer_getoverr.c: Return real overrun.
2806         * sysdeps/pthread/posix-timer.h (struct timer_node): Add overrun_count.
2807         * sysdeps/pthread/timer_routines.c (thread_func): Schedule next timeout
2808         based on previous one and not on current time.  Count overruns.
2809         Patch by Eric F. Sorton <eric@cctcorp.com>.
2811         * sysdeps/unix/sysv/linux/bits/local_lim.h: Add DELAYTIMER_MAX.
2813 2002-04-08  kaz Kojima  <kkojima@rr.iij4u.or.jp>
2815         * sysdeps/sh/pt-machine.h: Define _PT_MACHINE_H
2816         if it isn't defined yet.
2817         (FLOATING_STACKS, ARCH_STACK_MAX_SIZE): Defined.
2818         (THREAD_GETMEM, THREAD_GETMEM_NC, THREAD_SETMEM, THREAD_SETMEM_NC):
2819         Likewise.
2820         * sysdeps/sh/tls.h: New file.
2822 2002-04-08  Jakub Jelinek  <jakub@redhat.com>
2824         * manager.c (__pthread_manager_event): Use self instead of arg
2825         for INIT_THREAD_SELF.
2826         * sysdeps/i386/useldt.h (INIT_THREAD_SELF): Use sizeof (struct
2827         _pthread_descr_struct) instead of sizeof (*descr).
2829 2002-04-05  Ulrich Drepper  <drepper@redhat.com>
2831         * sysdeps/ia64/pt-machine.h: Protect against multiple inclusion.
2832         * sysdeps/alpha/pt-machine.h: Likewise.
2833         * sysdeps/arm/pt-machine.h: Likewise.
2834         * sysdeps/cris/pt-machine.h: Likewise.
2835         * sysdeps/hppa/pt-machine.h: Likewise.
2836         * sysdeps/m68k/pt-machine.h: Likewise.
2837         * sysdeps/mips/pt-machine.h: Likewise.
2838         * sysdeps/powerpc/pt-machine.h: Likewise.
2839         * sysdeps/s390/s390-32/pt-machine.h: Likewise.
2840         * sysdeps/s390/s390-64/pt-machine.h: Likewise.
2841         * sysdeps/sh/pt-machine.h: Likewise.
2842         * sysdeps/sparc/sparc32/pt-machine.h: Likewise.
2843         * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
2844         * sysdeps/x86_64/pt-machine.h: Likewise.
2846 2002-04-05  Jakub Jelinek  <jakub@redhat.com>
2848         * man/pthread_mutexattr_init.man (pthread_mutexattr_settype): Document
2849         instead of pthread_mutexattr_setkind_np.
2850         (pthread_mutexattr_gettype): Similarly.
2851         * man/pthread_mutexattr_setkind_np.man: New.
2852         * man/Makefile (SOURCES): Add pthread_mutexattr_setkind_np.man.
2854 2002-04-02  Ulrich Drepper  <drepper@redhat.com>
2856         * sysdeps/ia64/pt-machine.h (MEMORY_BARRIER): Define.
2858 2002-03-22  Jakub Jelinek  <jakub@redhat.com>
2860         * sysdeps/mips/pt-machine.h (MEMORY_BARRIER): Remove.
2862 2002-03-22  Ulrich Drepper  <drepper@redhat.com>
2864         * internals.h (MEMORY_BARRIER): Define as asm with memory as clobber.
2866 2002-03-17  Andreas Jaeger  <aj@suse.de>
2868         * sysdeps/i386/pt-machine.h: Add testandset and __compare_and_swap
2869         prototpyes.
2870         * sysdeps/alpha/pt-machine.h: Likewise.
2871         * sysdeps/arm/pt-machine.h: Likewise.
2872         * sysdeps/cris/pt-machine.h: Likewise.
2873         * sysdeps/hppa/pt-machine.h: Likewise.
2874         * sysdeps/i386/i686/pt-machine.h: Likewise.
2875         * sysdeps/ia64/pt-machine.h: Likewise.
2876         * sysdeps/m68k/pt-machine.h: Likewise.
2877         * sysdeps/mips/pt-machine.h: Likewise.
2878         * sysdeps/powerpc/pt-machine.h: Likewise.
2879         * sysdeps/s390/s390-32/pt-machine.h: Likewise.
2880         * sysdeps/s390/s390-64/pt-machine.h: Likewise.
2881         * sysdeps/sh/pt-machine.h: Likewise.
2882         * sysdeps/sparc/sparc32/pt-machine.h: Likewise.
2883         * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
2884         * sysdeps/x86_64/pt-machine.h: Likewise.
2886         * internals.h: Move testandset and __compare_and_swap prototypes
2887         to pt-machine.h.
2889 2002-03-03  Andreas Jaeger  <aj@suse.de>
2891         * errno.c: Include resolv.h to avoid warning.
2893 2002-02-27  Ulrich Drepper  <drepper@redhat.com>
2895         * pthread.c [USE_TLS] (thread_self_stack): Correct check for upper
2896         stack limit.
2898 2002-02-23  Ulrich Drepper  <drepper@redhat.com>
2900         * attr.c (pthread_getattr_np): Don't take thread descriptor size
2901         into account if USE_TLS.
2902         * manager.c (pthread_handle_create): Free TLS data structures if call
2903         failed.  Pass correct stack to clone if USE_TLS.
2904         * sysdeps/i386/pt-machine.h: Handle multiple inclusion.
2905         * sysdeps/i386/i686/pt-machine.h: Likewise.
2906         * sysdeps/i386/tls.h: Unconditionally include <pt-machine.h>.
2908         * descr.h (struct _pthread_descr_struct): Update p_header for TLS.
2909         Add p_stackaddr element #if USE_TLS.
2910         * internals.c: Include <tls.h>.
2911         * manager.c: Integrate creating and handling of thread descriptor
2912         for TLS.
2913         * pthread.c: Likewise.
2914         * sysdeps/i386/tls.h (tcbhead_t): Add self pointer.
2915         Include <linuxthreads/descr.h> only if TLS is really used.
2916         (GET_DTV): New macro.
2917         (TLS_INIT_TP): Initialize self pointer.
2919 2002-02-17  Andreas Schwab  <schwab@suse.de>
2921         * signals.c (sigwait): Check for old sighandler being SIG_ERR,
2922         not NULL.
2924 2002-02-12  Ulrich Drepper  <drepper@redhat.com>
2926         * sysdeps/i386/tls.c (INSTALL_NEW_DTV): Define.
2927         (INSTALL_DTV): Adjust for being passed pointer to element with length.
2929 2002-02-08  Ulrich Drepper  <drepper@redhat.com>
2931         * sysdeps/i386/tls.h (TLS_INIT_TP): Also initialize %gs.
2933 2002-02-08  Richard Henderson  <rth@redhat.com>
2935         * sysdeps/alpha/elf/pt-initfini.c: Use \n\ for multiline string.
2937 2002-02-08  Ulrich Drepper  <drepper@redhat.com>
2939         * sysdeps/i386/tls.h: TLS cannot be supported with FLOATING_STACKS
2940         after all.
2942 2002-02-07  H.J. Lu  <hjl@gnu.org>
2944         * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Silence the
2945         gcc warning.
2946         (__pthread_spin_lock): Remove ".set noreorder".
2947         * sysdeps/mips/pt-machine.h (__compare_and_swap): Liekwise.
2949 2002-02-05  H.J. Lu  <hjl@gnu.org>
2951         * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Not use
2952         branch likely.
2953         * sysdeps/mips/pt-machine.h (testandset): Likewise.
2954         (__compare_and_swap): Likewise.
2956 2002-02-07  Ulrich Drepper  <drepper@redhat.com>
2958         * internals.h: Move declarations/definitions of
2959         __pthread_initial_thread_bos, __pthread_initial_thread,
2960         __pthread_manager_thread_bos, __pthread_manager_thread_tos,
2961         __pthread_manager_thread, __pthread_nonstandard_stacks, STACK_SIZE,
2962         CURRENT_STACK_FRAME, __pthread_find_self, and thread_self...
2963         * descr.h: ...here.
2964         * sysdeps/i386/tls.h: Add TLS definitions also for !FLOATING_STACKS.
2965         Define THREAD_GETMEM accordingly.
2967 2002-02-06  Ulrich Drepper  <drepper@redhat.com>
2969         * sysdeps/i386/tls.h: Include <stddef.h> for size_t.
2971         * sysdeps/i386/tls.h: Define THREAD_DTV.
2973 2002-02-04  Ulrich Drepper  <drepper@redhat.com>
2975         * internals.h: Move thread descriptor definition...
2976         * descr.h.: ...here.  New file.
2977         * sysdeps/i386/tls.h: New file.
2979 2002-02-01  H.J. Lu  <hjl@gnu.org>
2981         * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Use a
2982         different register in the delayed slot.  Use branch likely.
2984         * sysdeps/mips/pt-machine.h (testandset): Call _test_and_set.
2985         (__compare_and_swap): Return 0 only when failed to compare. Use
2986         branch likely.
2988 2002-02-01  Jakub Jelinek  <jakub@redhat.com>
2990         * Versions (__libc_internal_tsd_get, __libc_internal_tsd_set,
2991         __pthread_kill_other_threads_np): Move to GLIBC_PRIVATE.
2992         * sysdeps/i386/i586/Versions: Move all symbols to GLIBC_PRIVATE.
2993         * sysdeps/i386/i686/Versions: Move all symbols to GLIBC_PRIVATE.
2994         * sysdeps/sparc/sparc32/sparcv9/Versions: New file.
2995         * sysdeps/sparc/sparc64/Versions: New file.
2996         * sysdeps/ia64/Versions: Move all symbols to GLIBC_PRIVATE.
2998 2002-01-31  Ulrich Drepper  <drepper@redhat.com>
3000         * pthread.c: _dl_cpuclock_offset is not any longer a global variable
3001         in SHARED code, use GL(dl_cpuclock_offset).
3003 2002-01-28  Andreas Jaeger  <aj@suse.de>
3005         * sysdeps/mips/pspinlock.c (__pthread_spin_init): Clear *LOCK to
3006         0. Patch by Machida Hiroyuki <machida@sm.sony.co.jp>.
3008 2002-01-16  Martin Schwidefsky  <schwidefsky@de.ibm.com>
3010         * sysdeps/s390/s390-32/pt-machine.h (MEMORY_BARRIER): Define.
3011         (CURRENT_STACK_FRAME): Remove duplicate definition.
3012         * sysdeps/s390/s390-64/pt-machine.h: Likewise.
3014 2002-01-14  Martin Schwidefsky  <schwidefsky@de.ibm.com>
3016         * Makefile (CFLAGS-tst-cancel.c): Add -fno-inline-functions to prevent
3017         automatic inline.
3019 2002-01-12  Andreas Schwab  <schwab@suse.de>
3021         * Makefile (test-srcs): Add tst-signal.
3022         (tests): Run tst-signal.
3023         (distribute): Add tst-signal.sh.
3024         * tst-signal.c, tst-signal.sh: New files.
3026 2002-01-14  Andreas Jaeger  <aj@suse.de>
3028         * sysdeps/x86_64/pt-machine.h (INIT_THREAD_SELF): Avoid warning.
3030 2002-01-11  Andreas Schwab  <schwab@suse.de>
3032         * signals.c (sighandler): Initialize all elements to SIG_ERR.
3033         (__sigaction): Don't use value from sighandler if it is SIG_ERR.
3035 2002-01-06  Richard Henderson  <rth@redhat.com>
3037         * sysdeps/alpha/elf/pt-initfini.c: New file.
3039 2001-12-29  Andreas Jaeger  <aj@suse.de>
3041         * Examples/ex9.c: Add noreturn attribute for thread.
3042         * Examples/ex10.c: Likewise.
3043         * Examples/ex13.c (thread_start): Likewise.
3044         * Examples/ex15.c (worker): Likewise.
3046         * Examples/ex18.c: Include unistd.h for prototype of sleep.
3048 2001-12-14  Ulrich Drepper  <drepper@redhat.com>
3050         * man/pthread_atfork.man: Adjust description of mutex handling
3051         after fork for current implementation.
3052         * linuxthreads.texi: Likewise [PR libc/2519].
3054 2001-12-13  Andreas Schwab  <schwab@suse.de>
3056         * specific.c (pthread_key_delete): Don't contact the thread
3057         manager if no threads have been created yet.
3059 2001-12-12  NIIBE Yutaka  <gniibe@m17n.org>
3061         * sysdeps/sh/pt-machine.h (INIT_THREAD_SELF): Added __volatile__
3062         qualifier to be safe.
3064 2001-11-30  Andreas Schwab  <schwab@suse.de>
3066         * pthread.c (pthread_handle_sigcancel) [THREAD_SELF]: Double check
3067         that self is the manager thread, and initialize the thread
3068         register if not.
3069         (thread_self_stack) [THREAD_SELF]: New function to find self via
3070         stack pointer.
3071         * manager.c (pthread_handle_create): Don't block cancel signal any
3072         more.
3074 2001-11-29  Andreas Jaeger  <aj@suse.de>
3076         * sysdeps/x86_64/pt-machine.h: Use %gs as thread specific register.
3077         (THREAD_SELF): New.
3078         (INIT_THREAD_SELF): New.
3079         (THREAD_GETMEM): New.
3080         (THREAD_GETMEM_NC):
3081         (THREAD_SETMEM): New.
3082         (THREAD_SETMEM_NC): New.
3083         (FLOATING_STACKS): Define.
3084         (ARCH_STACK_MAX_SIZE): Define.
3086 2001-11-28  Kaz Kylheku  <kaz@ashi.footprints.net>
3088         Bugfix to pthread_key_delete. It was iterating over the thread
3089         manager's linked list of threads, behind the thread manager's
3090         back causing a race. The fix is to have the manager iterate over
3091         the threads instead, using a new request type for doing so.
3092         * internals.h (struct pthread_request): New manager request type
3093         REQ_FOR_EACH_THREAD.
3094         * manager.c (pthread_for_each_thread): New function.
3095         (__pthread_manager): Handle new REQ_FOR_EACH_THREAD request.
3096         * specific.c (struct pthread_key_delete_helper_args): New type.
3097         (pthread_key_delete_helper): New static function.
3098         (pthread_key_delete): Use the new thread manager
3099         REQ_FOR_EACH_THREAD function to iterate over the threads and set
3100         the delete key slot to a null value in each thread.
3101         * Examples/ex18.c: New test.
3102         * Makefile (tests): Add ex18.
3104 2001-11-22  Wolfram Gloger  <wg@malloc.de>
3106         * pthread.c (pthread_onexit_process): Don't call free
3107         after threads have been asynchronously terminated.
3109         * manager.c (pthread_handle_exit): Surround cancellation
3110         of threads with __flockfilelist()/__funlockfilelist().
3112 2001-11-26  Andreas Schwab  <schwab@suse.de>
3114         * manager.c (pthread_handle_create): Start the child thread with
3115         the cancel signal blocked, so that it does not handle it before
3116         the thread register is set up.  Save errno from failed clone call.
3118 2001-11-15  Ulrich Drepper  <drepper@redhat.com>
3120         * sysdeps/i386/i686/Implies: Removed.
3121         * sysdeps/i386/i686/Versions: New file.
3123 2001-10-31  Andreas Jaeger  <aj@suse.de>
3125         * sysdeps/x86_64/Makefile: Remove, we do not need it anymore.
3127 2001-10-05  Kevin Buettner  <kevinb@cygnus.com>
3129         * pthread.c (__linuxthread_pthread_sizeof_descr): Change name
3130         to __linuxthreads_pthread_sizeof_descr to match name used by
3131         symbol_list_arr[LINUXTHREADS_PTHREAD_SIZEOF_DESCR] in
3132         linuxthreads_db/td_symbol_list.c.
3134 2001-09-22  Andreas Jaeger  <aj@suse.de>
3136         * linuxthreads/tst-context.c: Avoid compile warning.
3138 2001-09-20  Andreas Jaeger  <aj@suse.de>
3140         * shlib-versions: Add x86-64.
3142 2001-09-19  Andreas Jaeger  <aj@suse.de>
3144         * sysdeps/x86_64/Makefile: New file.
3145         * sysdeps/x86_64/pspinlock.c: New file.
3146         * sysdeps/x86_64/pt-machine.h: New file.
3148 2001-09-12  Jakub Jelinek  <jakub@redhat.com>
3150         * sysdeps/pthread/timer_delete.c (timer_delete): Thread may be NULL
3151         for SIGEV_NONE.
3152         * sysdeps/pthread/timer_settime.c (timer_settime): Likewise.
3154 2001-09-11  Ulrich Drepper  <drepper@redhat.com>
3155             Wolfram Gloger <wg@malloc.de>
3157         * join.c: Protect all communications from and to manager with
3158         TEMP_FAILURE_RETRY.
3159         * manager.c: Likewise.
3160         * pthread.c: Likewise.
3161         * smeaphore.c: Likewise.
3163 2001-08-29  Ulrich Drepper  <drepper@redhat.com>
3165         * spinlock.c (__pthread_lock): Top max_count value with
3166         MAX_ADAPTIVE_SPIN_COUNT.
3167         * internals.h (MAX_ADAPTIVE_SPIN_COUNT): Define if not already done.
3169         * sysdeps/i386/i686/pt-machine.h (BUSY_WAIT_NOP): New macro to
3170         help P4.
3172 2001-08-27  Jakub Jelinek  <jakub@redhat.com>
3174         * sysdeps/pthread/bits/libc-lock.h (__libc_rwlock_t): Only define to
3175         non-opaque type if __USE_UNIX98.
3177 2001-08-26  Jakub Jelinek  <jakub@redhat.com>
3179         * sysdeps/pthread/bits/libc-lock.h (__libc_lock_t): Define
3180         non-opaque lock types also if _IO_MTSAFE_IO is defined.
3182 2001-08-23  Roland McGrath  <roland@frob.com>
3184         * sysdeps/pthread/bits/libc-lock.h (__libc_cleanup_region_start): Take
3185         new first argument, skip the cleanup handler if it's zero.
3186         (_LIBC_LOCK_RECURSIVE_INITIALIZER): New macro.
3187         (__libc_lock_define_initialized_recursive): Use it.
3188         * sysdeps/pthread/bits/stdio-lock.h: File removed.
3189         The sysdeps/generic file from the main tree now suffices.
3191 2001-08-22  Roland McGrath  <roland@frob.com>
3193         * sysdeps/pthread/bits/stdio-lock.h: Include <bits/libc-lock.h>
3194         instead of <pthread.h>.
3195         (_IO_lock_t): Define this typedef using __libc_lock_define_recursive.
3196         (_IO_lock_initializer): Add braces.
3197         (_IO_lock_lock): Use __libc_lock_lock_recursive.
3198         (_IO_lock_unlock): Use __libc_lock_unlock_recursive.
3200         * sysdeps/pthread/bits/libc-lock.h (__libc_lock_recursive_t): New type.
3201         (__libc_lock_define_initialized_recursive): Use it.
3202         (__libc_lock_init_recursive): Likewise.
3203         (__libc_lock_fini_recursive): Likewise.
3204         (__libc_lock_lock_recursive): Likewise.
3205         (__libc_lock_trylock_recursive): Likewise.
3206         (__libc_lock_unlock_recursive): Likewise.
3207         (__libc_lock_define_recursive): New macro.
3209 2001-08-14  Jakub Jelinek  <jakub@redhat.com>
3211         * lockfile.c (__pthread_provide_lockfile): New variable.
3212         * pthread.c (__pthread_require_lockfile): New variable.
3213         * cancel.c (__pthread_require_lockfile): New variable.
3215 2001-07-31  Ulrich Drepper  <drepper@redhat.com>
3217         * tst-context.c (threadfct): Initialize context before calling
3218         makecontext.
3220         * Examples/ex17.c: Make sure test thread is around long enough.
3222 2001-07-26  kaz Kojima  <kkojima@rr.iij4u.or.jp>
3224         * sysdeps/sh/pt-machine.h (THREAD_SELF, INIT_THREAD_SELF): Defined.
3226 2001-07-24  Ulrich Drepper  <drepper@redhat.com>
3228         * tst-context.c (main): Print explanation before bailing out
3229         because context handling is not supported.
3231 2001-07-23  Ulrich Drepper  <drepper@redhat.com>
3233         * Makefile (tests): Add tst-context.
3234         * tst-context.c: New file.
3236         * sysdeps/pthread/bits/stdio-lock.h: Define
3237         _IO_cleanup_region_start_noarg.
3239 2001-07-23  Jakub Jelinek  <jakub@redhat.com>
3241         * sysdeps/alpha/pt-machine.h (FLOATING_STACKS): Define.
3242         (ARCH_STACK_MAX_SIZE): Define.
3243         * sysdeps/sparc/sparc32/pt-machine.h: Likewise.
3244         * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
3246 2001-07-19  Jakub Jelinek  <jakub@redhat.com>
3248         * sysdeps/i386/useldt.h: Fix typo in ARCH_STACK_MAX_SIZE comment.
3250         * sysdeps/ia64/pt-machine.h (FLOATING_STACKS): Define.
3251         (ARCH_STACK_MAX_SIZE): Define.
3252         * manager.c (pthread_allocate_stack): Handle FLOATING_STACKS with
3253         NEED_SEPARATE_REGISTER_STACK.
3255 2001-07-16  Andreas Schwab  <schwab@suse.de>
3257         * Makefile (before-compile): Don't add $(objpfx)crti.o.
3258         (omit-deps): Add crti.
3259         ($(objpfx)libpthread.so): Depend on $(objpfx)crti.o, but make sure
3260         it is filtered out of the link command.
3262 2001-07-16  Ulrich Drepper  <drepper@redhat.com>
3264         * pthread.c (pthread_initialize): For FLOATING_STACKS don't bother
3265         to find the right value for __pthread_initial_thread_bos, it's not
3266         used.  If not FLOATING_STACKS first run
3267         __pthread_init_max_stacksize.
3269 2001-06-16  H.J. Lu  <hjl@gnu.org>
3271         * internals.h: Include <stackinfo.h>.
3273         * attr.c: Don't include <stackinfo.h> here.
3274         * cancel.c: Likewise.
3275         * manager.c: Likewise.
3276         * pthread.c: Likewise.
3277         * ptlongjmp.c: Likewise.
3279 2001-03-23  Matthew Wilcox  <willy@ldl.fc.hp.com>
3281         * attr.c: Make _STACK_GROWS_UP work.
3282         * internals.h: Likewise.
3283         * manager.c: Likewise.
3284         * pthread.c: Likewise.
3286 2001-06-15  H.J. Lu  <hjl@gnu.org>
3288         * pthread.c (__pthread_reset_main_thread): Fix a typo.
3290 2001-02-02  John S. Marvin  <jsm@udlkern.fc.hp.com>
3292         * semaphore.h: Use struct _pthread_fastlock as an element of
3293         sem_t instead of an identical struct.
3294         * rwlock.c: Remove casts.
3295         * semaphore.c: Likewise.
3297 2001-04-30  Alan Modra  <amodra@one.net.au>
3299         * sysdeps/unix/sysv/linux/hppa/pt-initfini.c: New.
3301 2001-05-25  Bruce Mitchener  <bruce@cubik.org>
3303         * linuxthreads.texi: Spelling corrections.
3305 2001-05-25  Ulrich Drepper  <drepper@redhat.com>
3307         * oldsemaphore.c (__old_sem_wait): Clear p_nextwaiting before
3308         returning successfully.
3309         Patch by Gene Cooperman <gene@ccs.neu.edu>.
3311 2001-05-24  Ulrich Drepper  <drepper@redhat.com>
3313         * spinlock.c (__pthread_lock) [HAS_COMPARE_AND_SWAP]: Before doing any
3314         serious work try once whether the lock is uncontested.
3315         Remove duplicate reading of __status before loop.
3316         Change suggested by Hans Boehm <hans_boehm@hp.com>.
3318         * spinlock.h (__pthread_trylock): Remove need for oldstatus variable.
3319         (__pthread_alt_trylock): Likewise.
3321 2001-05-01  Kaz Kylheku  <kaz@ashi.footprints.net>
3323         Memory barrier overhaul following line by line inspection.
3324         * mutex.c (pthread_once): Missing memory barriers added.
3325         * pthread.c (__pthread_wait_for_restart_signal,
3326         __pthread_timedsuspend_new, __pthread_restart_new): Added
3327         memory barriers ``just in case'' and for documentary value.
3328         * spinlock.c (__pthread_release): New inline function for releasing
3329         spinlock, to complement __pthread_acquire.  Includes memory
3330         barrier prior to assignment to spinlock, and __asm __volatile
3331         dance to prevent reordering or optimization of the spinlock access.
3332         * spinlock.c (__pthread_unlock, __pthread_alt_lock,
3333         __pthread_alt_timedlock, __pthread_alt_unlock,
3334         __pthread_compare_and_swap): Updated to use new __pthread_release
3335         instead of updating spinlock directly.
3336         * spinlock.c (__pthread_lock, __pthread_unlock, wait_node_alloc,
3337         wait_node_free, wait_node_dequeue, __pthread_alt_lock,
3338         __pthread_alt_timedlock, __pthread_alt_unlock, __pthread_acquire):
3339         Memory barrier overhaul.  Lots of missing memory barriers added,
3340         a couple needless ones removed.
3341         * spinlock.c (__pthread_compare_and_swap): testandset optimization
3342         removed, just calls __pthread_acquire, which has the new read
3343         barrier in it before its testandset.
3345 2001-05-20  Roland McGrath  <roland@frob.com>
3347         * Makeconfig: New file, variables used to be in main libc Makeconfig.
3349 2001-05-09  Geoff Keating  <geoffk@redhat.com>
3351         * sysdeps/powerpc/pt-machine.h
3352         (HAS_COMPARE_AND_SWAP_WITH_RELEASE_SEMANTICS): Define.
3353         (__compare_and_swap): Remove memory barriers.
3354         (__compare_and_swap_with_release_semantics): New function.
3356 2001-04-24  Andreas Jaeger  <aj@suse.de>
3358         * wrapsyscall.c: send* and recv* return ssize_t.
3360         * sysdeps/pthread/timer_getoverr.c (timer_getoverrun): Unlock the
3361         mutex instead of double locking it.
3362         Reported by Pierre Artaud <partaud@sodatec.com>.
3364 2001-04-23  Ulrich Drepper  <drepper@redhat.com>
3366         * sysdeps/pthread/getcpuclockid.c: Make function generic, test
3367         using #ifdef whether the clock is available.
3368         * sysdeps/unix/sysv/linux/i386/getcpuclockid.c: Removed.
3370         * sysdeps/ia64/Versions: New file.
3372         * sysdeps/unix/sysv/linux/ia64/pt-initfini.c (_init): We don't
3373         have to call __gmon_start__ in the libpthread DSO.
3374         * sysdeps/pthread/pt-initfini.c (_init): Likewise.
3376         * Makefile (libpthread-routines): Add ptclock_gettime and
3377         ptclock_settime.
3378         * internals.h: Don't use cpuclock-init.h definitions, use
3379         hp-timing.h definitions.
3380         * pthread.c: Likewise.
3381         * manager.c: Likewise.
3382         * ptclock_gettime.c: New file.
3383         * ptclock_settime.c: New file.
3384         * internals.h: Fix parameter type for __pthread_clock_gettime and
3385         __pthread_clock_settime.
3387         * sysdeps/i386/i586/ptclock_gettime.c: Removed.
3388         * sysdeps/i386/i586/ptclock_settime.c: Removed.
3389         * sysdeps/i386/i586/Makefile: Removed.
3391 2001-04-22  Ulrich Drepper  <drepper@redhat.com>
3393         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define _POSIX_ASYNCH_IO.
3394         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
3396 2001-04-21  Andreas Jaeger  <aj@suse.de>
3398         * sysdeps/pthread/timer_routines.c (thread_func): Add noreturn
3399         attribute, remove statements that will never be executed.
3400         (thread_func): Remove mutex_unlock call since it's never executed.
3401         (thread_func): Fix comment as suggested by Jakub Jelinek.
3403         * manager.c (__pthread_manager): Add noreturn
3404         attribute.
3405         (pthread_start_thread): Likewise, remove return statement.
3406         (pthread_start_thread_event): Likewise.
3407         Add noreturn attribute for pthread_handle_exit.
3408         * weaks.c: Add noreturn attribute for pthread_exit.
3410         * internals.h: Add __pthread_clock_gettime and
3411         __pthread_clock_settime prototypes.
3413 2001-04-21  Ulrich Drepper  <drepper@redhat.com>
3415         * internals.h: Include <cpuclock-init.h>.
3416         (struct _pthread_descr_struct): Add p_cpuclock_offset field if
3417         CPUCLOCK_VARDEF is defined.
3418         * pthread.c (__pthread_initialize_minimal): Initialize
3419         p_cpuclock_offset field for main thread if CPUCLOCK_INIT is defined.
3420         * manager.c (pthread_start_thread): Set p_cpuclock_offset field
3421         for new thread to current CPU clock value.
3423         * sysdeps/i386/useldt.h: Extend all the macros to handle 8-byte values.
3425         * sysdeps/i386/i586/Makefile: New file.
3426         * sysdeps/i386/i586/Versions: New file.
3427         * sysdeps/i386/i586/ptclock_gettime.c: New file.
3428         * sysdeps/i386/i586/ptclock_settime.c: New file.
3429         * sysdeps/i386/i686/Implies: New file.
3431 2001-04-18  Jakub Jelinek  <jakub@redhat.com>
3433         * sysdeps/unix/sysv/linux/sparc/sparc64/Makefile: Put specs into
3434         $generated, not $postclean-generated.
3436 2001-04-18  Andreas Jaeger  <aj@suse.de>
3438         * Makefile (otherlibs): Added.
3440 2001-04-18  Jakub Jelinek  <jakub@redhat.com>
3442         * sysdeps/unix/sysv/linux/sparc/sparc64/Makefile: New file.
3444 2001-04-16  Ulrich Drepper  <drepper@redhat.com>
3446         * signals.c (sigwait): NSIG is no signal number.  Block all
3447         signals while in signal handler for signals in SET.
3448         Patch by Manfred Spraul <manfred@colorfullife.com>.
3450 2001-04-12  Ulrich Drepper  <drepper@redhat.com>
3452         * tst-cancel.c: Disable most tests.  Add new test where all
3453         cleanup handlers must run.
3454         * Makefile (tests): Add tst-cancel again.
3456         * cancel.c (__pthread_perform_cleanup): Correct condition for
3457         leaving cleanup loop early.
3459         * sysdeps/i386/Makefile: Make sure gcc uses a frame pointer for
3460         all the files which use CURRENT_STACK_FRAME.
3461         * sysdeps/i386/pt-machine.h (CURRENT_STACK_FRAME): Define using
3462         __builtin_frame_address.
3463         * sysdeps/i386/i686/pt-machine.h: Likewise.
3465 2001-04-11  Ulrich Drepper  <drepper@redhat.com>
3467         * Makefile (tests): Comment out tst-cancel for now.
3469         * tst-cancel.c (main): Cleanup 4 is supposed to run.  Create
3470         temporary file in object directory.
3471         * Makefile: Don't allow inlining when compiling tst-cancel.c.
3472         Pass $(objpfx) to tst-cancel.
3474 2001-04-11  David S. Miller  <davem@redhat.com>
3476         * sysdeps/sparc/sparc32/pt-machine.h (stack_pointer): Advance
3477         up closer to user local variables so that new cleanup heuristics work.
3478         * sysdeps/sparc/sparc64/pt-machine.h (stack_pointer): Likewise.
3480 2001-04-11  Ulrich Drepper  <drepper@redhat.com>
3482         * cancel.c (_pthread_cleanup_push): Catch invalid __prev buffer
3483         and remove it.
3484         (_pthread_cleanup_push_defer): Likewise.
3486         * tst-cancel.c (main): Fix loop printing cleanup output.
3488 2001-04-10  kaz Kojima  <kkojima@rr.iij4u.or.jp>
3490         * sysdeps/sh/pspinlock.c (__pthread_spin_lock): Fix a reverse
3491         test.
3492         (__pthread_spin_trylock): Likewise.
3493         * sysdeps/sh/pt-machine.h (testandset): Likewise.
3495 2001-04-10  Ulrich Drepper  <drepper@redhat.com>
3497         * join.c (pthread_exit): Move code to new function __pthread_do_exit
3498         which takes an extra parameter with the current frame pointer.
3499         Call new function with CURRENT_STACK_FRAME.
3500         (__pthread_do_exit): New function.  Call __pthread_perform_cleanup
3501         with the new parameter.
3502         (pthread_join): Call __pthread_do_exit instead of pthread_exit.
3503         * cancel.c (__pthread_perform_cleanup): Takes extra parameter.  Use
3504         this parameter as the initial value the cleanup handler records are
3505         compared against.  No active cleanup handler record must have an
3506         address lower than the previous one and the initial record must be
3507         above (below on PA) the frame address passed in.
3508         (pthread_setcancelstate): Call __pthread_do_exit instead of
3509         pthread_exit.
3510         (pthread_setcanceltype): Likewise.
3511         (pthread_testcancel): Likewise.
3512         (_pthread_cleanup_pop_restore): Likewise.
3513         * condvar.c (pthread_cond_wait): Likewise.
3514         (pthread_cond_timedwait_relative): Likewise.
3515         * manager.c (pthread_start_thread): Likewise.
3516         * oldsemaphore.c (__old_sem_wait): Likewise.
3517         * pthread.c (pthread_handle_sigcancel): Likewise.
3518         * semaphore.c (__new_sem_wait): Likewise.
3519         (sem_timedwait): Likewise.
3520         * ptlongjmp.c (pthread_cleanup_upto): Also use current stack frame
3521         to limit the cleanup handlers which get run.
3522         * internals.h: Add prototype for __pthread_do_exit.  Adjust prototype
3523         for __pthread_perform_cleanup.
3525         * Makefile (tests): Add tst-cancel.
3526         * tst-cancel.c: New file.
3528 2001-04-08  Hans-Peter Nilsson  <hp@axis.com>
3530         * sysdeps/cris/pt-machine.h: New file.
3531         * sysdeps/cris/pspinlock.c: New file.
3533 2001-04-09  Hans-Peter Nilsson  <hp@axis.com>
3535         * shlib-versions: Add case for Linux on CRIS.
3537 2001-03-26  Ulrich Drepper  <drepper@redhat.com>
3539         * attr.c (pthread_getattr_np): Correct computation of stack size
3540         for machiens with register stack.
3542         * Examples/ex17.c (main): Correct detection of failed mmap call.
3544 2001-03-21  Jakub Jelinek  <jakub@redhat.com>
3546         * pthread.c (__pthread_initialize_manager): Fix a typo.
3548 2001-03-21  Jakub Jelinek  <jakub@redhat.com>
3550         * attr.c (__pthread_attr_setstack): Fix alignment check.
3551         (pthread_getattr_np): __stackaddr is top of stack, not bottom.
3552         * Makefile (tests): Add ex17 test.
3553         * Examples/ex17.c: New test.
3555 2001-03-20  Ulrich Drepper  <drepper@redhat.com>
3557         * Makefile: Define -D_RPC_THREAD_SAFE_ for cancel.c.
3558         * cancel.c (__pthread_perform_cleanup): Call __rpc_thread_destroy.
3559         * sysdeps/pthread/bits/libc-tsd.h: Define _LIBC_TSD_KEY_VARS.
3561 2001-03-18  Ulrich Drepper  <drepper@redhat.com>
3563         * Makefile: When generating DSO link with libc_nonshared.a.
3565 2001-02-26  Jakub Jelinek  <jakub@redhat.com>
3567         * signals.c (pthread_sighandler): Use CALL_SIGHANDLER.
3569 2001-02-23  Jakub Jelinek  <jakub@redhat.com>
3571         * internals.h (__pthread_init_max_stacksize): New prototype.
3572         * attr.c (__pthread_attr_setstacksize): Call
3573         __pthread_init_max_stacksize if not yet initialized.
3574         * pthread.c (__pthread_init_max_stacksize): New function.
3575         (__pthread_initialize_manager): Call it.
3576         Patch by <dtc@cmucl.cons.org>.
3578 2001-03-16  Ulrich Drepper  <drepper@redhat.com>
3580         * attr.c (pthread_getattr_np): Fix __stacksize computation for IA-64.
3582 2001-03-13  Martin Schwidefsky  <schwidefsky@de.ibm.com>
3584         * shlib-versions: Add rule for Linux on 64 bit S/390.
3585         * sysdeps/s390/s390-64/pt-machine.h: New file.
3586         * sysdeps/unix/sysv/linux/s390/s390-64/pt-initfini.c: New file.
3588 2001-03-13  Martin Schwidefsky  <schwidefsky@de.ibm.com>
3590         * sysdeps/s390/pt-machine.h: Move to...
3591         * sysdeps/s390/s390-32/pt-machine.h: ...here.
3592         Add defines for FLOATING_STACK and ARCH_STACK_MAX_SIZE.
3594 2001-03-15  Ulrich Drepper  <drepper@redhat.com>
3596         * Versions [libpthread] (GLIBC_2.2.3): Add pthread_getattr_np.
3597         * attr.c: Implement pthread_getattr_np.
3598         * sysdeps/pthread/pthread.h: Add prototype for pthread_getattr_np.
3599         * internals.h (struct _pthread_descr_struct): Add p_inheritsched.
3600         * manager.c (pthread_handle_create): Initialize p_inheritsched.
3602 2001-03-09  Martin Schwidefsky  <schwidefsky@de.ibm.com>
3604         * sysdeps/unix/sysv/linux/s390/pt-initfini.c: Use 0x07 padding for
3605         code alignment.
3607 2001-02-20  Hans Boehm  <hans_boehm@hp.com>
3609         * manager.c (manager_mask): Removed static vesion.  Now always local
3610         to __pthread_manager().
3611         (manager_mask_all): Removed completely.
3612         (__pthread_manager): Remove manager_mask_all initialization.
3613         (pthread_handle_create): Remove code to set and reset signal mask
3614         around __clone2() calls.
3616 2001-02-17  Jakub Jelinek  <jakub@redhat.com>
3618         * spinlock.c (__pthread_lock): Force lock->__status to be read from
3619         memory on every spin.
3621 2001-02-10  Andreas Jaeger  <aj@suse.de>
3623         * Makefile (extra-objs): New.
3625 2001-02-09  Jakub Jelinek  <jakub@redhat.com>
3627         * sysdeps/pthread/pt-initfini.c (call_initialize_minimal): Add
3628         __pthread_initialize_minimal prototype.
3630 2001-02-08  kaz Kojima  <kkojima@rr.iij4u.or.jp>
3632         * sysdeps/unix/sysv/linux/sh/pt-initfini.c: New file.
3634 2001-02-06  Martin Schwidefsky  <schwidefsky@de.ibm.com>
3636         * sysdeps/unix/sysv/linux/s390/pt-initfini.c: New file.
3638 2001-02-06  Ulrich Drepper  <drepper@redhat.com>
3640         * sysdeps/unix/sysv/linux/ia64/pt-initfini.c: First attempt to fix the
3641         broken code.  Patch by Jes Sorensen.
3643 2001-02-06  Andreas Jaeger  <aj@suse.de>
3645         * sysdeps/pthread/pthread.h: Move __pthread_initialize from here
3646         to...
3647         * internals.h: ...here.
3649 2001-02-05  Jes Sorensen  <jes@linuxcare.com>
3651         * sysdeps/unix/sysv/linux/ia64/pt-initfini.c: New file.
3653 2001-02-02  Ulrich Drepper  <drepper@redhat.com>
3655         * Versions: Remove __pthread_initialize_minimal.
3657 2001-02-01  Ulrich Drepper  <drepper@redhat.com>
3659         * Makefile: Add rules to build crti.o and make it being used in
3660         building libpthread.so.
3661         * sysdeps/i386/Makefile: New file.
3662         * sysdeps/pthread/pt-initfini.c: New file.
3664         * pthread.c: Cleanups.
3666 2001-01-28  Andreas Jaeger  <aj@suse.de>
3668         * oldsemaphore.c (__old_sem_init): Adjust for last change.
3669         * sysdeps/pthread/bits/libc-lock.h: Likewise.
3670         * spinlock.c: Likewise.
3672 2001-01-28  Ulrich Drepper  <drepper@redhat.com>
3674         * sysdeps/pthread/bits/initspin.h: Make all names namespace clean.
3675         * sysdeps/unix/sysv/linux/hppa/bits/initspin.h: Likewise.
3676         * manager.c: Adjust for namespace cleanup in bits/initspin.h.
3677         * pthread.c: Likewise.
3678         * spinlock.h: Likewise.
3679         * sysdeps/pthread/pthread.h: Likewise.
3681 2001-01-26  Ulrich Drepper  <drepper@redhat.com>
3683         * sysdeps/pthread/bits/pthreadtypes.h: Define pthread_attr_t also
3684         as struct __pthread_attr_s.
3686         * semaphore.h (sem_t): Cleanup namespace, rename status and
3687         spinlock elements.
3689 2001-01-13  Jakub Jelinek  <jakub@redhat.com>
3691         * pthread.c (pthread_onexit_process): Clear
3692         __pthread_manager_thread_bos after freeing it.
3693         * Makefile (tests): Add ex16.
3694         * Examples/ex16.c: New file.
3696 2001-01-11  Jakub Jelinek  <jakub@redhat.com>
3698         * Makefile (CFLAGS-pthread.c): Pass -DHAVE_Z_NODELETE if ld supports
3699         -z nodelete.
3700         * pthread.c (pthread_exit_process): Rename to...
3701         (pthread_onexit_process): ...this.
3702         (pthread_atexit_process, pthread_atexit_retcode): New.
3703         (pthread_initialize): Call __cxa_atexit instead of __cxa_on_exit
3704         and only if HAVE_Z_NODELETE is not defined.
3705         (__pthread_initialize_manager): Register pthread_atexit_retcode
3706         with __cxa_atexit.
3708 2001-01-11  Ulrich Drepper  <drepper@redhat.com>
3710         * pthread.c (pthread_initialize): Use __cxs_on_exit not __cxa_atexit.
3712 2001-01-11  Jakub Jelinek  <jakub@redhat.com>
3714         * Makefile (tests): Add ex15.
3715         * Examples/ex15.c: New test.
3717 2001-01-08  Ulrich Drepper  <drepper@redhat.com>
3719         * pthread.c (pthread_exit_process): Free memory allocated for
3720         manager stack.
3722 2000-12-31  Ulrich Drepper  <drepper@redhat.com>
3724         * manager.c (pthread_alloca_stack): Remove MAP_FIXED from mmap calls.
3725         (pthread_free): Always unmap the stack.  It's safe now that we don't
3726         use MAP_FIXED to allocate stacks.
3728 2000-12-31  Ulrich Drepper  <drepper@redhat.com>
3730         * sysdeps/powerpc/pspinlock.c: Don't include pt-machine.h here.
3732         * manager.c (pthread_allocate_stack): Prepare for removal of MAP_FIXED.
3734 2000-11-15  Wolfram Gloger  <wg@malloc.de>
3736         * manager.c (pthread_free): [!FLOATING_STACKS]: Only remap the
3737         stack to PROT_NONE, don't unmap it, avoiding collisions with malloc.
3739 2000-12-27  Andreas Jaeger  <aj@suse.de>
3741         * Examples/ex13.c: Make local functions static.
3742         * ecmutex.c: Likewise.
3743         * joinrace.c: Likewise.
3744         * Examples/ex14.c: Likewise.
3746         * Examples/ex2.c: Make local functions static; reformat.
3747         * Examples/ex1.c: Likewise.
3748         * Examples/ex4.c: Likewise.
3749         * Examples/ex5.c: Likewise.
3750         * Examples/ex7.c: Likewise.
3752         * oldsemaphore.c: Add prototypes to shut up GCC.
3753         * pt-machine.c: Likewise.
3755         * weaks.c: Add prototype for pthread_exit.
3757         * internals.h: Add some prototypes, format prototypes and add
3758         missing externs.
3759         Move __libc_waitpid prototype to include/sys/wait.h.
3761         * rwlock.c: Include <bits/libc-lock.h> for prototypes.
3762         * mutex.c: Likewise.
3763         * specific.c: Likewise.
3764         * ptfork.c: Likewise.
3766         * lockfile.c: Include internals.h to get prototypes.
3767         * events.c: Likewise.
3768         * sysdeps/alpha/pspinlock.c: Likewise.
3769         * sysdeps/arm/pspinlock.c: Likewise.
3770         * sysdeps/hppa/pspinlock.c: Likewise.
3771         * sysdeps/i386/pspinlock.c: Likewise.
3772         * sysdeps/ia64/pspinlock.c: Likewise.
3773         * sysdeps/m68k/pspinlock.c: Likewise.
3774         * sysdeps/mips/pspinlock.c: Likewise.
3775         * sysdeps/powerpc/pspinlock.c: Likewise.
3776         * sysdeps/s390/pspinlock.c: Likewise.
3777         * sysdeps/sh/pspinlock.c: Likewise.
3778         * sysdeps/sparc/sparc32/pspinlock.c: Likewise.
3779         * sysdeps/sparc/sparc32/sparcv9/pspinlock.c: Likewise.
3780         * sysdeps/sparc/sparc64/pspinlock.c: Likewise.
3782 2000-12-27  Ulrich Drepper  <drepper@redhat.com>
3784         * attr.c (__pthread_attr_setstack): Fix setting of __stackaddr element.
3785         (__pthread_attr_getstack): Return correct address.
3786         Add warnings for using pthread_attr_getstackaddr and
3787         pthread_attr_setstackaddr.
3789 2000-12-26  Ulrich Drepper  <drepper@redhat.com>
3791         * Examples/ex6.c (test_thread): Make static.
3792         * Examples/ex12.c (test_thread): Make static and add noreturn
3793         attribute.
3795 2000-12-18  Jes Sorensen  <jes@linuxcare.com>
3797         * linuxthreads/sysdeps/ia64/pt-machine.h: __compare_and_swap
3798         and compare_and_swap_with_release_semantics returns int not long.
3800 2000-12-17  Andreas Jaeger  <aj@suse.de>
3802         * sysdeps/s390/pt-machine.h (testandset): Use long int as return
3803         value.
3804         * sysdeps/arm/pt-machine.h (testandset): Likewise.
3805         * sysdeps/hppa/pt-machine.h (testandset): Likewise.
3806         * sysdeps/m68k/pt-machine.h (testandset): Likewise.
3807         * sysdeps/sh/pt-machine.h (testandset): Likewise.
3808         * sysdeps/sparc/sparc32/pt-machine.h (testandset): Likewise.
3809         * sysdeps/sparc/sparc64/pt-machine.h (testandset): Likewise.
3811 2000-12-17  Ulrich Drepper  <drepper@redhat.com>
3813         * sysdeps/i386/pt-machine.h (testandset): Adjust for prototype change.
3814         * sysdeps/i386/i686/pt-machine.h (testandset): Likewise.
3816 2000-12-17  Andreas Jaeger  <aj@suse.de>
3818         * internals.h: Add prototypes for testandset and
3819         __compare_and_swap to shut up gcc warnings.
3821 2000-12-06  Wolfram Gloger  <wg@malloc.de>
3823         * join.c (pthread_detach): Allow case where the thread has already
3824         terminated.
3826 2000-12-05  Andreas Jaeger  <aj@suse.de>
3828         * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Don't set mips2.
3829         * sysdeps/mips/pt-machine.h (testandset): Likewise.
3830         (__compare_and_swap): Likewise.
3831         Patches by Maciej W. Rozycki <macro@ds2.pg.gda.pl>.
3833 2000-11-20  Jakub Jelinek  <jakub@redhat.com>
3835         * Examples/ex3.c (main): Cast int to long before casting to void *.
3836         (search): Cast void * to long, not int.
3837         * Examples/ex8.c (main, thread): Similarly.
3838         * Examples/ex11.c (main): Similarly.
3839         * Examples/ex14.c (worker, do_test): Similarly.
3840         * ecmutex.c (worker, do_test): Similarly.
3841         (nlocks): Cast to int.
3843 2000-11-08  Bruce Mitchener  <bruce@cubik.org>
3845         * linuxthreads.texi:  Add documentation for pthreads attributes
3846         guardsize, stackaddr, stacksize, and stack.  Fix typo in previous
3847         patch.  Document pthread_[sg]etconcurrency().  Mark
3848         pthread_mutexattr_[sg]ettype() as POSIX rather than GNU.
3850 2000-11-07  Ulrich Drepper  <drepper@redhat.com>
3852         * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_MESSAGE_PASSING):
3853         Don't define it.
3854         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
3855         Reported by Christopher Yeoh <cyeoh@linuxcare.com.au>.
3857 2000-11-06  Ulrich Drepper  <drepper@redhat.com>
3859         * cancel.c (pthread_cancel): Always set p_canceled, even if we are
3860         not doing it right now.
3861         Reported by Kaz Kylheku <kaz@ashi.footprints.net>.
3863 2000-10-30  Ulrich Drepper  <drepper@redhat.com>
3865         * Examples/ex4.c (main): Don't use exit() to avoid warning with
3866         broken compilers.
3868 2000-10-29  Ulrich Drepper  <drepper@redhat.com>
3870         * attr.c (__pthread_attr_setguardsize): Don't round guardsize
3871         here.  Reported by Bruce Mitchener <bruce@cubik.org>.
3873         * linuxthreads.texi: Changes terminology to 'type' from 'kind' when
3874         discussing mutexes. (As per the Unix98 name for the API.)
3875         Changes documentation for pthread_mutexattr_setkind_np() and
3876         pthread_mutexattr_getkind_np() over to the Unix98 APIs for the
3877         same: pthread_mutexattr_settype() and pthread_mutexattr_gettype().
3878         Changes references to PTHREAD_MUTEXATTR_FAST_NP to
3879         PTHREAD_MUTEXATTR_ADAPTIVE_NP.
3880         Begins to introduce discussion of the ``timed'' mutex type.  This
3881         discussion is currently incomplete.
3882         Patch by Bruce Mitchener <bruce@cubik.org>.
3884 2000-10-26  Kazumoto Kojima  <kkojima@rr.iij4u.or.jp>
3885             Yutaka Niibe  <gniibe@chroot.org>
3887         * sysdeps/sh/pt-machine.h (testandset): Since the operand of TAS.B
3888         has restrictions, use register.
3890 2000-10-23  Andreas Schwab  <schwab@suse.de>
3892         * Examples/ex14.c (TIMEOUT): Override default timeout.
3894 2000-10-16  Ulrich Drepper  <drepper@redhat.com>
3896         * specific.c: Protect tsd array modification in thread data
3897         structures by getting the thread lock in pthread_key_delete and
3898         __pthread_destroy_specifics.
3899         Patch by Wolfram Gloger <Wolfram.Gloger@dent.med.uni-muenchen.de>.
3901 2000-10-12  Alan Modra <alan@linuxcare.com.au>
3903         * sysdeps/pthread/bits/initspin.h: New file.
3904         * spinlock.h: Move LOCK_INITIALIZER definition to <bits/initspin.h>.
3905         (__pthread_init_lock): Initialize lock with LT_SPINLOCK_INIT.
3906         (__pthread_alt_init_lock): Likewise.
3907         (__pthread_alt_trylock): Release lock with LT_SPINLOCK_INIT.
3909 2000-10-12  David Huggins-Daines  <dhd@linuxcare.com>
3911         * oldsemaphore.c (__old_sem_init): Release lock with
3912         LT_SPINLOCK_INIT, not zero.
3913         * spinlock.c (__pthread_unlock): Likewise.
3914         (__pthread_alt_lock): Likewise.
3915         (__pthread_alt_timedlock): Likewise.
3916         (__pthread_alt_unlock): Likewise.
3917         * sysdeps/pthread/bits/libc-lock.h: Initialize locks with
3918         LT_SPINLOCK_INIT if it is non-zero.  Likewise for init-once flags.
3919         * sysdeps/pthread/pthread.h: Include bits/initspin.h.  Use
3920         LT_SPINLOCK_INIT do initialize spinlocks not 0.
3922 2000-10-12  David Huggins-Daines <dhd@linuxcare.com>
3924         * shlib-versions: Add version definitions for hppa-linux.
3926 2000-10-12  Alan Modra <alan@linuxcare.com.au>
3928         * sysdeps/hppa/pspinlock.c: New file.
3929         * sysdeps/hppa/pt-machine.h: New file.
3930         * sysdeps/unix/sysv/linux/hppa/bits/initspin.h: New file.
3932 2000-10-05  Jakub Jelinek  <jakub@redhat.com>
3934         * mutex.c (__pthread_mutex_destroy): Correct test of
3935         busy mutex for mutexes using alternate fastlocks.
3936         Patch by dtc@cmucl.cons.org.
3938 2000-09-28  Martin Schwidefsksy    <schwidefsky@de.ibm.com>
3940         * sysdeps/s390/pt-machine.h: Make %a0 the thread register.
3942 2000-09-28  Ulrich Drepper  <drepper@redhat.com>
3944         * mutex.c (__pthread_mutex_unlock): For PTHREAD_MUTEX_RECURSIVE_NP
3945         test for owner first.
3946         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
3948         * cancel.c (pthread_cancel): Don't do anything if cancelation is
3949         disabled.
3951 2000-09-26  Ulrich Drepper  <drepper@redhat.com>
3953         * spinlock.h (__pthread_set_own_extricate_if): Optimize a bit.
3954         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
3956         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Remove
3957         _POSIX_MONOTONIC_CLOCK.
3959         * spinlock.h (__pthread_set_own_extricate_if): Add back locking
3960         and explain why.
3962 2000-09-20  Andreas Jaeger  <aj@suse.de>
3964         * pthread.c [!__ASSUME_REALTIME_SIGNALS]: Make inclusion of
3965         "testrtsig.h" conditional.
3967 2000-09-11  Ulrich Drepper  <drepper@redhat.com>
3969         * sysdeps/pthread/pthread.h: Declare pthread_attr_getstack and
3970         pthread_attr_setstack.
3971         * Versions [libpthread] (GLIBC_2.2): Export pthread_attr_getstack and
3972         pthread_attr_setstack.
3973         * attr.c (pthread_attr_getstack, pthread_attr_setstack): New functions.
3975 2000-09-05  Ulrich Drepper  <drepper@redhat.com>
3977         * Examples/ex14.c: New file.
3978         * Makefile (tests): Add ex14.
3980         * mutex.c (__pthread_mutex_unlock): Correct test for already unlocked
3981         mutex.  Patch by dtc@cmucl.cons.org.
3983         * ecmutex.c: New file.
3984         * Makefile (tests): Add ecmutex.
3986 2000-09-04  H.J. Lu  <hjl@gnu.org>
3988         * attr.c (__pthread_attr_setguardsize): Use page_roundup
3989         instead of roundup to round up to the page size.
3991 2000-09-03  Mark Kettenis  <kettenis@gnu.org>
3993         * manager.c (pthread_exited): Correctly report event as TD_REAP
3994         instead of TD_DEATH.  Fix comments.
3996 2000-09-03  Ulrich Drepper  <drepper@redhat.com>
3998         * spinlock.h (testandset): Add cast to avoid warning.
3999         Patch by Franz Sirl <Franz.Sirl-kernel@lauterbach.com>.
4001 2000-09-02  Andreas Jaeger  <aj@suse.de>
4003         * sysdeps/pthread/timer_routines.c: Include stdlib.h for abort
4004         prototype.
4006 2000-09-01  Ulrich Drepper  <drepper@redhat.com>
4008         * sysdeps/pthread/bits/stdio-lock.h (_IO_cleanup_region_start):
4009         Fix typo in last patch (_mode -> _flags).
4011         * sysdeps/pthread/bits/stdio-lock.h (_IO_cleanup_region_start):
4012         Provide definition which respects _IO_USER_LOCK flag.
4014 2000-08-30  Ulrich Drepper  <drepper@redhat.com>
4016         * manager.c (pthread_allocate_stack): Clear descriptor only if not
4017         mmaped.
4019 2000-08-25  Ulrich Drepper  <drepper@redhat.com>
4021         * Makefile: Add rules to build and run unload.
4022         * unload.c: New file.
4024         * pthread.c (pthread_exit_process): Move thread_self use inside `if'.
4026         * sysdeps/pthread/pthread.h
4027         (PTHREAD_ADAPTIVE_MUTEX_INITIALIZER_NP): Defined.
4028         (PTHREAD_ERRORCHECK_MUTEX_INITIALIZER_NP: Defined.
4030 2000-08-24  Andreas Jaeger  <aj@suse.de>
4032         * Examples/ex13.c: Include <string.h> for strerror prototype and
4033         <stdlib.h> for abort prototype.
4034         (pthr_cond_signal_mutex): Rewrite to silence GCC.
4035         (thread_start): Remove unused variable err.
4036         (main): Silence GCC warnings.
4038 2000-08-22  Andreas Jaeger  <aj@suse.de>
4040         * Examples/ex13.c: New test by Kurt Garloff <garloff@suse.de>.
4042         * Makefile (tests): Add ex13.
4044 2000-08-20  Ulrich Drepper  <drepper@redhat.com>
4046         * semaphore.h: Add restrict where required by AGd4.
4047         * sysdeps/pthread/pthread.h: Likewise.
4048         * sysdeps/pthread/unix/sysv/linux/bits/sigthread.h: Likewise.
4050 2000-08-15  Ulrich Drepper  <drepper@redhat.com>
4052         * Makefile (tests): Add ex12.  Add rule to build it.
4053         * Examples/ex12.c: New file.
4055 2000-08-13  Ulrich Drepper  <drepper@redhat.com>
4057         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define _POSIX_SEMAPHORES
4058         even though the implementation is not quite complete (but it reports
4059         it).  Define _POSIX_MESSAGE_PASSING to -1.
4060         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
4062 2000-08-12  Andreas Jaeger  <aj@suse.de>
4064         * sysdeps/mips/pt-machine.h (testandset): Add .set mips2 for
4065         assembler.
4066         (__compare_and_swap): Likewise.
4067         * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Likewise.
4069 2000-08-10  Ulrich Drepper  <drepper@redhat.com>
4071         * pthread.c (__pthread_initial_thread): Initialize p_errnop and
4072         p_h_errnop correctly and not to NULL.
4074 2000-08-05  Ulrich Drepper  <drepper@redhat.com>
4076         * Banner: Bump version number to 0.9.
4078 2000-08-04  Ulrich Drepper  <drepper@redhat.com>
4080         * Makefile (tests): Add tststack.  Add rule to build the program.
4081         * tststack.c: New file.
4083         * internals.h: Declare __pthread_max_stacksize.
4084         * pthread.c (__pthread_max_stacksize): New variable.
4085         (__pthread_initialize_manager): Determine __pthread_initialize_manager
4086         value.
4087         * manager.c (thread_segment): Return always NULL if FLOATING_STACKS.
4088         (pthread_allocate_stack): Allow kernel to choose stack address if
4089         FLOATING_STACKS.  This also handles variable-sized stacks.
4090         Always allocate stack and guardpage together.  Use mprotect to
4091         change guardpage access.
4092         * sysdeps/i386/useldt.h: Define FLOATING_STACKS and
4093         ARCH_STACK_MAX_SIZE.
4095         * attr.c (__pthread_attr_setstacksize): Also test value against
4096         upper limit.
4098         * manager.c (__pthread_nonstandard_stacks): Define only if
4099         THREAD_SELF is not defined.
4100         (pthread_allocate_stack): Always initialize gardaddr to a correct
4101         value.
4102         (pthread_handle_create): Unmap thread with one call.
4103         (pthread_free): Remove test for initial thread before removing stack.
4104         Unmap stack with one call.
4106         * pthread.c (__pthread_initial_thread): Initialize p_userstack to
4107         1 to avoid removing the stack.
4109 2000-07-27  Jes Sorensen  <jes@linuxcare.com>
4111         * sysdeps/ia64/pspinlock.c (__pthread_spin_lock): Add
4112         load of spin lock to prime the cache before the atomic compare and
4113         exchange operation (cmpxchg4). This avoids the spinning on the
4114         cmpxchg4 instruction and reduces movement of the cache line back
4115         and forth between the processors (explanation by Asis K. Mallick
4116         from Intel). This basically makes the implementation operate the
4117         same as the Linux kernel implementation.
4119         * shlib-versions: Use GLIBC_2_2 for Linux/ia64.
4120         * sysdeps/ia64/pspinlock.c: New file.
4122 2000-08-03  Ulrich Drepper  <drepper@redhat.com>
4124         * pthread.c: Move definition of __pthread_set_own_extricate_if...
4125         * spinlock.h: ...here.  Remove locking.
4126         * internals.h: Remove __pthread_set_own_extricate_if prototype.
4128         * rwlock.c: Use THREAD_GETMEM And THREAD_SETMEM.
4129         (rwlock_rd_extricate_func): Don't determine self, let
4130         __pthread_lock do it.
4131         (rwlock_wr_extricate_func): Likewise.
4132         (rwlock_have_already): Optimize *pself handling a bit.
4134         * mutex.c: Use __builtin_expect.
4135         * pthread.c: Likewise.
4137 2000-08-02  Andreas Jaeger  <aj@suse.de>
4139         * sysdeps/s390/pspinlock.c: New file.
4140         * sysdeps/s390/pt-machine.h: New file.
4141         Patches by Martin Schwidefsky <schwidefsky@de.ibm.com>.
4143 2000-07-12  Maciej W. Rozycki  <macro@ds2.pg.gda.pl>
4145         * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Implement for
4146         R3K.
4147         * sysdeps/mips/pt-machine.h (testandset): Likewise.
4149 2000-07-26  Andreas Jaeger  <aj@suse.de>
4151         * pthread.c: Initialize p_sem_avail.
4153 2000-07-25  Ulrich Drepper  <drepper@redhat.com>
4155         * internals.h (struct __pthread_descr_struct): Add p_sem_avail.
4156         * semaphore.c: Handle spurious wakeups.
4158         * sysdeps/pthread/pthread.h: Add back PTHREAD_MUTX_FAST_NP as an alias
4159         for PTHREAD_MUTEX_ADAPTIVE_NP for source code compatibility.
4161         * pthread.c (__pthread_set_own_extricate): Use THREAD_GETMEM.
4162         (__pthread_wait_for_restart): Likewise.
4164         * condvar.c (pthread_cond_wait): Also check whether thread is
4165         cancelable before aborting loop.
4166         (pthread_cond_timedwait): Likewise.
4168         * signals.c (pthread_sighandler): Remove special code to restrore
4169         %gs on x86.
4170         (pthread_sighandler_t): Likewise.
4172 2000-07-25  Mark Kettenis  <kettenis@gnu.org>
4174         * internals.h (__RES_PTHREAD_INTERNAL): Remove define.
4175         * pthread.c: Include <resolv.h>.
4176         (_res): Undefine.  Add extern declaration.
4178 2000-07-24  Ulrich Drepper  <drepper@redhat.com>
4180         * pthread.c (__pthread_initial_thread): Update initializer.
4181         (__pthread_manager_thread): Likewise.
4182         (pthread_initialize): Move setrlimit call to...
4183         (__pthread_initialize_manager): ...here.
4184         (__pthread_reset_main_thread): Reset also soft limit on stack size.
4186         * condvar.c: Handle spurious wakeups.  [PR libc/1749].
4187         * internals.h (struct _pthread_descr_struct): Add p_condvar_avail.
4189 2000-07-21  Ulrich Drepper  <drepper@redhat.com>
4191         * spinlock.h: If IMPLEMENT_TAS_WITH_CAS is defined use
4192         __compare_and_swap to define testandset.
4193         * sysdeps/powerpc/pt-machine.h: Add volatile to asms.
4194         Define IMPLEMENT_TAS_WITH_CAS.
4196 2000-07-20  Ulrich Drepper  <drepper@redhat.com>
4198         * Makefile: Pass -z nodelete to linker for libpthread.so
4199         generation if it understand this option.
4201 2000-07-18  Mark Kettenis  <kettenis@gnu.org>
4203         * manager.c (pthread_handle_create): Remove initialization of
4204         new_thread->p_res._sock.
4206 2000-07-19  Kaz Kylheku  <kaz@ashi.footprints.net>
4208         Bugfixes to the variant of the code for machines with no compare
4209         and swap.
4211         * spinlock.c (__pthread_alt_lock, __pthread_alt_timedlock): Wait
4212         node was not being properly enqueued, due to failing to update
4213         the lock->__status field.
4215         * spinlock.c (__pthread_alt_timedlock): The oldstatus variable was
4216         being set inappropriately, causing the suspend function to be called
4217         with a null self pointer and crash.
4219 2000-07-18  Ulrich Drepper  <drepper@redhat.com>
4221         * spinlock.h (__pthread_alt_trylock): Fix code used if no
4222         compare&swap is available.
4224         * spinlock.h (__pthread_trylock): Use __compare_and_swap, not
4225         compare_and_swap.
4227         * pthread.c (pthread_initialize): Don't use sysconf to determine
4228         whether the machine has more than one processor.
4230         * spinlock.c (__pthread_alt_timedlock): Add back one of the
4231         removed thread_self calls.
4233 2000-07-18  Kaz Kylheku  <kaz@ashi.footprints.net>
4235         * spinlock.c (__pthread_alt_lock, __pthread_alt_timedlock): Changed
4236         __compare_and_swap to compare_and_swap in code which assumes
4237         compare swap is available.
4239 2000-07-18  Kaz Kylheku  <kaz@ashi.footprints.net>
4241         * spinlock.c (__pthread_alt_lock, __pthread_alt_timedlock): Fixed
4242         bug whereby thr field of waitnode structure would not be correctly
4243         set unless a null self pointer is passed to the functions.
4244         Eliminated redundant calls to thread_self().
4246 2000-07-18  Jakub Jelinek  <jakub@redhat.com>
4248         * pthread.c (__pthread_initialize_manager): Lock
4249         __pthread_manager_thread.p_lock before calling clone.
4251 2000-05-05  H.J. Lu  <hjl@gnu.org>
4253         * sysdeps/ia64/pt-machine.h (__compare_and_swap): Change it to
4254         have acquire semantics.
4255         (__compare_and_swap_with_release_semantics): New inline
4256         function.
4257         (HAS_COMPARE_AND_SWAP_WITH_RELEASE_SEMANTICS): New macro.
4259 2000-01-28  Hans Boehm  <hboehm@exch.hpl.hp.com>
4261         * manager.c: Fix the problem with signals at startup.
4262         Change the way that thread stacks are allocated on IA64.
4263         Clean up some of the guard page allocation stuff.
4265 1999-12-19  H.J. Lu  <hjl@gnu.org>
4267         * internals.h (page_roundup): New.
4268         * attr.c (__pthread_attr_setguardsize); Use page_roundup
4269         instead of roundup.
4270         * manager.c (pthread_allocate_stack): Make sure guardaddr is
4271         page aligned with page_roundup if NEED_SEPARATE_REGISTER_STACK
4272         is define.
4274 1999-12-17  Hans Boehm  <hboehm@exch.hpl.hp.com>
4276         * manager.c (pthread_allocate_stack): Unmap the stack top
4277         if failed to map the stack bottom.
4278         Fix the guard page.
4279         (pthread_free): Fix the guard page.
4281         * pthread.c (pthread_initialize): Set rlimit correctly for
4282         NEED_SEPARATE_REGISTER_STACK.
4284 1999-12-16  H.J. Lu  <hjl@gnu.org>
4286         * pthread.c (__pthread_initialize_manager): Pass
4287         __pthread_manager_thread_bos instead of
4288         __pthread_manager_thread_tos to __clone2.
4290 1999-12-16  H.J. Lu  <hjl@gnu.org>
4292         * manager.c (pthread_allocate_stack): Correct the calculation
4293         of "new_thread_bottom". Remove MAP_GROWSDOWN from mmap for
4294         stack bottom.
4296 1999-12-13  H.J. Lu  <hjl@gnu.org>
4298         * sysdeps/ia64/pt-machine.h (__compare_and_swap): Added a stop
4299         bit after setting ar.ccv.
4301 1999-12-12  H.J. Lu  <hjl@gnu.org>
4303         * manager.c (pthread_allocate_stack): Make the starting
4304         address of the stack bottom page aligned. FIXME: it may
4305         need changes in other places.
4306         (pthread_handle_create): Likewise.
4308 1999-12-11  Hans Boehm  <hboehm@exch.hpl.hp.com>
4310         * manager.c (pthread_allocate_stack): Handle
4311         NEED_SEPARATE_REGISTER_STACK.
4312         (pthread_handle_create): Likewise.
4313         * pthread.c (__pthread_initialize_manager): Likewise.
4315         * sysdeps/ia64/pt-machine.h: Use r13 for thread pointer.
4317 1999-12-02  H.J. Lu  <hjl@gnu.org>
4319         * sysdeps/ia64/pt-machine.h: New.
4321 2000-07-13  Ulrich Drepper  <drepper@redhat.com>
4323         * wrapsyscall.c: Mark non-__ protected names as weak.
4324         PR libc/1466.
4326 2000-07-12  Bruno Haible  <haible@clisp.cons.org>
4328         * Examples/ex8.c: Include <sys/wait.h>, not <wait.h>.
4330 2000-07-12  Ulrich Drepper  <drepper@redhat.com>
4332         * spinlock.c: Fix code for TEST_FOR_COMPARE_AND_SWAP being defined.
4333         Add tests also to new alternative spinlock implementation.
4334         * spinlock.h: Likewise.
4335         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
4337 2000-07-06  Ulrich Drepper  <drepper@redhat.com>
4339         * Version: Export __sigaction.
4340         * signals.c: Define __sigaction alias.  Use __libc_sigaction instead
4341         of __sigaction.
4342         * pthread.c: Use __libc_sigaction instead of __sigaction.
4344         * condvar.c: Implement pthread_condattr_getpshared and
4345         pthread_condattr_setpshared.
4346         * mutex.c: Implement pthread_mutexattr_getpshared and
4347          pthread_mutexattr_setpshared.
4348         * Versions: Export new functions.
4349         * sysdeps/pthread/pthread.h: Add prototypes for new functions.
4351         * rwlock.c (pthread_rwlockattr_init): Use PTHREAD_PROCESS_PRIVATE.
4352         (pthread_rwlockattr_setpshared): Fail if PTHREAD_PROCESS_PRIVATE
4353         is not selected.
4355 2000-07-04  Greg McGary  <greg@mcgary.org>
4357         * sysdeps/pthread/bits/libc-lock.h: Remove BP_SYM from
4358         pragmas.  Include bp-sym.h only if _LIBC.
4360 2000-07-04  Ulrich Drepper  <drepper@redhat.com>
4362         * spinlock.c (__pthread_unlock): Properly place write barrier.
4363         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
4365 2000-07-03  Ulrich Drepper  <drepper@redhat.com>
4367         * spinlock.c: Replace fast spinlocks by adaptive spinlocks which are
4368         faster on SMP systems.  No more emulation of compare&swap for adaptive
4369         spinlocks.
4370         * spinlock.h: Likewise.
4371         * sysdeps/pthread/pthread.h: Shuffle PTHREAD_MUTEX_* values around.
4372         Replace fast with adaptive mutex.
4373         * mutex.c: Rewrite for replacement of fast by adaptive mutex.
4374         * condvar.c: Likewise.
4375         * pthread.c: Define and initialize __pthread_smp_kernel variable.
4376         * internals.h: Declare __pthread_smp_kernel.
4377         * sysdeps/pthread/bits/pthreadtypes.h: Update comment of
4378         _pthread_fastlock structure.
4379         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
4381         * pthread.c: Remove initialization to zero from global variables.
4383 2000-06-29  Jakub Jelinek  <jakub@redhat.com>
4385         * shlib-versions: Make sparc64 GLIBC_2.2+ only.
4387 2000-06-28  Greg McGary  <greg@mcgary.org>
4389         * weaks.c: Wrap BP_SYM () around weak extern declarations of
4390         pthread functions that have pointers in their return+arg signatures.
4392 2000-06-27  Greg McGary  <greg@mcgary.org>
4394         * sysdeps/pthread/bits/libc-lock.h: Wrap BP_SYM () around weak
4395         extern declarations of pthread functions that have pointers in
4396         their return+arg signatures.
4398 2000-06-26  Ulrich Drepper  <drepper@redhat.com>
4400         * Makefile (tests): Add ex11.  Add rules to build it.
4401         * Examples/ex11.c: New file.
4402         * rwlock.c: Fix complete braindamaged previous try to implement
4403         timedout functions.
4405         * spinlock.c: Pretty print.
4407 2000-06-25  Ulrich Drepper  <drepper@redhat.com>
4409         * Makefile (tests): Add ex10.  Add rules to build it.
4410         * Versions [GLIBC_2.2] (libpthread): Add pthread_mutex_timedlock,
4411         pthread_rwlock_timedrdlock, and pthread_rwlock_timedwrlock.
4412         * condvar.c (pthread_cond_wait): Allow mutex of kind
4413         PTHREAD_MUTEX_TIMED_NP.
4414         (pthread_cond_timedwait_relative): Likewise.
4415         * mutex.c (__pthread_mutex_init): Default is PTHREAD_MUTEX_TIMED_NP.
4416         (__pthread_mutex_trylock): Use __pthread_alt_trylock for
4417         PTHREAD_MUTEX_ERRORCHECK_NP.  Handle PTHREAD_MUTEX_TIMED_NP.
4418         (__pthread_mutex_lock): Use __pthread_alt_lock for
4419         PTHREAD_MUTEX_ERRORCHECK_NP.  Handle PTHREAD_MUTEX_TIMED_NP.
4420         (__pthread_mutex_timedlock): New function.
4421         (__pthread_mutex_unlock): Use __pthread_alt_unlock for
4422         PTHREAD_MUTEX_ERRORCHECK_NP.  Handle PTHREAD_MUTEX_TIMED_NP.
4423         (__pthread_mutexattr_init): Use PTHREAD_MUTEX_TIMED_NP.
4424         (__pthread_mutexattr_settype): Allow PTHREAD_MUTEX_TIMED_NP.
4425         * spinlock.c: Implement alternate fastlocks.
4426         * spinlock.h: Add prototypes.
4427         * Examples/ex10.c: New file.
4428         * sysdeps/pthread/pthread.h: Add prototypes for new functions.
4429         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
4431         * rwlock.c (__pthread_rwlock_rdlock): Optimize loop a bit.
4432         (__pthread_rwlock_timedrdlock): New function.
4433         (__pthread_rwlock_timedwrlock): New function.
4434         Use laternate fastlock function everywhere.
4436 2000-06-21  Andreas Jaeger  <aj@suse.de>
4438         * sysdeps/pthread/timer_routines.c: Include <string.h> for memset
4439         prototype.
4441         * join.c: Include <stdlib.h> for exit prototype.
4443 2000-06-20  Ulrich Drepper  <drepper@redhat.com>
4445         * sysdeps/i386/useldt.h: Include <stdlib.h>.
4447         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define _POSIX_BARRIERS.
4448         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
4450         * Makefile (libpthread-routines): Add barrier.
4451         (tests): Add ex9.  Add rule to build ex9.
4452         * Versions: Export barrier functions.
4453         * barrier.c: New file.
4454         * Examples/ex9.c: New file.
4455         * sysdeps/pthread/pthread.h: Add barrier data types and declarations.
4456         * sysdeps/pthread/bits/pthreadtypes.h: Likewise.
4457         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
4459 2000-06-19  H.J. Lu  <hjl@gnu.org>
4461         * spinlock.h (HAS_COMPARE_AND_SWAP): Defined if
4462         HAS_COMPARE_AND_SWAP_WITH_RELEASE_SEMANTICS is defined.
4463         (compare_and_swap_with_release_semantics): New. Default to
4464         compare_and_swap if HAS_COMPARE_AND_SWAP_WITH_RELEASE_SEMANTICS
4465         is not defined.
4467         * spinlock.c (__pthread_unlock): Call
4468         compare_and_swap_with_release_semantics () instead of
4469         compare_and_swap ().
4471 2000-06-19  Ulrich Drepper  <drepper@redhat.com>
4473         * sysdeps/pthread/timer_create.c: Use _set_errno instead of assigning
4474         to errno directly.
4475         * sysdeps/pthread/timer_delete.c: Likewise.
4476         * sysdeps/pthread/timer_getoverr.c: Likewise.
4477         * sysdeps/pthread/timer_gettime.c: Likewise.
4478         * sysdeps/pthread/timer_settime.c: Likewise.
4480 2000-06-13  Kaz Kylheku  <kaz@ashi.footprints.net>
4482         Timer nodes are now reference counted, and can be marked
4483         as deleted. This allows for the safe release of the global mutex
4484         in the middle without losing the timer being operated on.
4486         * sysdeps/pthread/posix-timer.h (struct timer_node):  The inuse
4487         member is now an enum with three values, so that an intermediate
4488         state can be represented (deleted but not free for reuse yet).
4489         New refcount member added.
4490         * sysdeps/pthread/timer_routines.c: Likewise.
4492         * sysdeps/pthread/posix-timer.h (timer_addref, timer_delref,
4493         timer_valid): New inline functions added.
4495         * sysdeps/pthread/timer_gettime.c (timer_gettime): Function
4496         restructured, recursive deadlock bug fixed.
4498         * sysdeps/pthread/timer_gettime.c (timer_gettime): Uses new
4499         timer_addref to ensure that timer won't be deleted while mutex is not
4500         held. Also uses timer_invalid to perform validation of timer handle.
4501         * sysdeps/pthread/timer_settime.c (timer_settime): Likewise.
4502         * sysdeps/pthread/timer_getoverr.c (timer_getoverrun): Likewise.
4504 2000-06-14  Ulrich Drepper  <drepper@redhat.com>
4506         * shlib-versions: Add entry for SH.
4507         Patch by Kaz Kojima <kkojima@rr.iij4u.or.jp>.
4509 2000-06-13  Kaz Kylheku  <kaz@ashi.footprints.net>
4511         A few optimizations.  Got rid of unnecessary wakeups of timer threads,
4512         tightened up some critical regions and micro-optimized some list
4513         manipulation code.
4515         * sysdeps/pthread/timer_routines.c (__timer_thread_queue_timer):
4516         Returns int value now to indicate whether timer was queued at head.
4517         * sysdeps/pthread/posix-timer.h: Likewise.
4518         * sysdeps/pthread/timer_settime.c (timer_settime): Takes advantage of
4519         new return value from __timer_thread_queue_timer to avoid waking
4520         up timer thread unnecessarily.
4522         * sysdeps/pthread/posix-timer.h (timer_id2ptr): No longer checks
4523         inuse flag, because this requires mutex to be held.  Callers updated
4524         to do the check when they have the mutex.
4525         * sysdeps/pthread/timer_getoverr.c: Add check for inuse here.
4527         * sysdeps/pthread/timer_settime.c (timer_settime): Tighter critical
4528         regions: avoids making system calls while holding timer mutex, and
4529         a few computations were moved outside of the mutex as well.
4530         * sysdeps/pthread/timer_gettime.c (timer_gettime): Likewise.
4532         * sysdeps/pthread/posix-timer.h (list_unlink_ip): Function name changed
4533         to list_unlink_ip, meaning idempotent.  Pointer manipulation
4534         changed to get better better code out of gcc.
4535         * sysdeps/pthread/timer_routines.c (list_unlink): Non-idempotent
4536         version of list_unlink added here.
4537         * sysdeps/pthread/timer_delete.c: Use appropriate list unlink
4538         function in all places: idempotent one for timers, non-idempotent
4539         one for thread nodes.
4540         * sysdeps/pthread/timer_settime: Likewise.
4541         * sysdeps/pthread/timer_routines.c: Likewise.
4543 2000-06-13  Ulrich Drepper  <drepper@redhat.com>
4545         * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_TIMERS): Define.
4546         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
4548         * sysdeps/pthread/Makefile: Remove tests definition.
4550 2000-06-12  Kazumoto Kojima  <kkojima@rr.iij4u.or.jp>
4551             Yutaka Niibe  <gniibe@chroot.org>
4553         * sysdeps/sh/pspinlock.c: New file.
4554         * sysdeps/sh/pt-machine.h: New file.
4556 2000-06-12  Ulrich Drepper  <drepper@redhat.com>
4558         * Makefile (tests): Add joinrace.
4560         * Examples/ex6.c: Test return value of pthread_join.
4562 2000-06-11  Geoff Keating  <geoffk@cygnus.com>
4564         * sysdeps/powerpc/pspinlock.c (__pthread_spin_lock): Implement.
4565         (__pthread_spin_trylock): Implement.
4566         (__pthread_spin_unlock): Implement.
4567         (__pthread_spin_init): Implement.
4568         (__pthread_spin_destroy): Implement.
4570 2000-06-10  Ulrich Drepper  <drepper@redhat.com>
4572         * sysdeps/pthread/timer_routines.c (list_append): Little fix to
4573         really append the entry.
4575 2000-06-10  Andreas Jaeger  <aj@suse.de>
4577         * lockfile.c (__fresetlockfiles): Remove unused variable fp.
4579 2000-06-10  Kaz Kylheku  <kaz@ashi.footprints.net>
4581         * sysdeps/pthread/timer_create.c: Thread matching now done on
4582         clock type as well as thread attributes.
4583         There are individual global signal-delivering threads for
4584         different clock types.
4585         * sysdeps/pthread/posix-timer.h: Likewise.
4586         * sysdeps/pthread/timer_routines.c: Likewise.
4588         * sysdeps/pthread/timer_routines.c: Thread allocation and
4589         deallocation function now remembers to put thread on active
4590         list and remove from active list.
4591         Thus now the feature of binding multiple timers
4592         to a single thread actually works.
4594 2000-06-10  Ulrich Drepper  <drepper@redhat.com>
4596         * pthread.c (__pthread_create_2_1): Optimize a bit.
4598         * internals.h (invalid_handle): Also test for p_terminated != 0.
4599         (nonexisting_handle): New function.  Same as old invalid_handle.
4600         * join.c (pthread_join): Use nonexisting_handle instead of
4601         invalid_handle to test for acceptable thread handle.
4602         * manager.c (pthread_handle_free): Likewise.
4603         * joinrace.c: New file.
4604         Reported by Permaine Cheung <pcheung@cygnus.com>.
4606 2000-06-08  Ulrich Drepper  <drepper@redhat.com>
4608         * sysdeps/pthread/timer_routines.c (__timer_thread_queue_timer):
4609         Correct handling of matching variable.
4611         * sysdeps/pthread/tst-timer.c (main): Rewrite initializers to
4612         avoid warnings.
4614         * sysdeps/pthread/timer_routines.c (__timer_thread_queue_timer):
4615         Be prepared for empty timer list.
4617         * sysdeps/pthread/timer_create.c (timer_create): Correct names of
4618         CPUTIME clock ID.  Add support for thread clocks.
4620         * sysdeps/pthread/posix-timer.h (timer_ptr2id): Operands in
4621         subtraction were switched.
4623         * sysdeps/pthread/timer_routines.c (init_module): Use
4624         THREAD_MAXNODES threads.
4626         * sysdeps/pthread/posix-timer.h (struct timer_node): Add creator_pid.
4627         * sysdeps/pthread/timer_create.c: Fill in creator_pid.
4628         * sysdeps/pthread/timer_routines.c (thread_expire_timer): Send signal
4629         with sigqueueinfo is this system call is available.
4631         * sysdeps/pthread/timer_create.c (timer_create): Allow
4632         CLOCK_CPUTIME if _POSIX_CPUTIME is defined.
4634         * sysdeps/pthread/Makefile: New file.  Add rules to build timer
4635         functionality.
4636         * sysdeps/unix/sysv/linux/bits/local_lim.h: Add TIMER_MAX.
4638 2000-06-04  Kaz Kylheku  <kaz@ashi.footprints.net>
4640         * sysdeps/pthread/posix-timer.h: New file.
4641         * sysdeps/pthread/timer_create.c: New file.
4642         * sysdeps/pthread/timer_delete.c: New file.
4643         * sysdeps/pthread/timer_getoverr.c: New file.
4644         * sysdeps/pthread/timer_gettime.c: New file.
4645         * sysdeps/pthread/timer_routines.c: New file.
4646         * sysdeps/pthread/timer_settime.c: New file.
4647         * sysdeps/pthread/tst-timer.c: New file.
4649 2000-06-08  Ulrich Drepper  <drepper@redhat.com>
4651         * sysdeps/unix/sysv/linux/bits/local_lim.h: Remove OPEN_MAX and
4652         LINK_MAX definitions if necessary.
4654 2000-06-04  Kaz Kylheku  <kaz@ashi.footprints.net>
4656         Added missing fork time handling of global libio lock.
4658         * lockfile.c (__fresetlockfiles): Now also resets the list lock,
4659         not just the individual stream locks. Rewritten to use new
4660         iterator interface provided by libio rather than accessing
4661         global variable.
4663         * lockfile.c (__flockfilelist, _funlockfilelist): New functions
4664         which lock and unlock the stream list using the new interface
4665         provied by libio.
4666         * internals.h: Likewise.
4668         * ptfork.c (__fork): Now calls __flockfilelist before fork,
4669         and __funlockfilelist in the parent after the fork.
4670         Child still calls __fresetlockfiles as before.
4672         * linuxthreads.texi: Now explains what happens to streams at
4673         fork time. Also whole new section on forking and thread added.
4674         Definition of pthread_atfork moved out of Miscellaneous Functions
4675         to this new section.
4677 2000-06-04  Jakub Jelinek  <jakub@redhat.com>
4679         * sysdeps/sparc/sparc32/sparcv9/pspinlock.c (__pthread_spin_lock):
4680         Add missing register.
4681         * sysdeps/sparc/sparc64/pspinlock.c (__pthread_spin_lock): Likewise.
4683 2000-06-02  Jakub Jelinek  <jakub@redhat.com>
4685         * sysdeps/sparc/sparc32/pspinlock.c: Implement spinlocks.
4686         * sysdeps/sparc/sparc32/sparcv9/pspinlock.c: New.
4687         * sysdeps/sparc/sparc64/pspinlock.c: Implement spinlocks.
4689 2000-05-31  Andreas Jaeger  <aj@suse.de>
4691         * sysdeps/mips/pspinlock.c: Implement spinlocks.
4693 2000-05-28  Ulrich Drepper  <drepper@redhat.com>
4695         * spinlock.c (__pthread_lock): Remove ASSERT.
4697         * Makefile (tests): Add ex8.
4698         * Examples/ex8.c: New file.
4700 2000-05-12  Kaz Kylheku  <kaz@ashi.footprints.net>
4702         Bugfix: The pthread_atfork mechanism now takes care of its
4703         own internal mutex at fork time.
4705         * ptfork.c (__fork): Revised so that the mutex is held across
4706         the fork operation and while the handlers are called, and so that
4707         the child resets the mutex.
4709         * linuxthreads.texi: Updated pthread_atfork documentation to make
4710         it clear that fork and pthread_atfork can't be reentered from
4711         atfork handlers, that pthread_atfork and fork are mutually atomic,
4712         and that the handlers are inherited by the child process.
4714 2000-05-24  Ulrich Drepper  <drepper@redhat.com>
4716         * Makefile (libpthread-routines): Add pspinlock.
4717         * cancel.c: Rename __pthread_spin_unlock back to __pthread_unlock.
4718         Use struct _pthread_fastlock instead of pthread_spinlock_t.
4719         * condvar.c: Likewise.
4720         * internals.h: Likewise.
4721         * join.c: Likewise.
4722         * manager.c: Likewise.
4723         * mutex.c: Likewise.
4724         * pthread.c: Likewise.
4725         * rwlock.c: Likewise.
4726         * semaphore.c: Likewise.
4727         * signals.c: Likewise.
4728         * spinlock.h: Likewise.
4729         * spinlock.c: Likewise.  Remove pthread_spin_lock functions.
4730         * sysdeps/alpha/pspinlock.c: New file.
4731         * sysdeps/arm/pspinlock.c: New file.
4732         * sysdeps/i386/pspinlock.c: New file.
4733         * sysdeps/m68k/pspinlock.c: New file.
4734         * sysdeps/mips/pspinlock.c: New file.
4735         * sysdeps/powerpc/pspinlock.c: New file.
4736         * sysdeps/sparc/sparc32/pspinlock.c: New file.
4737         * sysdeps/sparc/sparc64/pspinlock.c: New file.
4738         * sysdeps/pthread/bits/pthreadtypes.h: Remove pthread_spinlock_t
4739         back to _pthread_fastlock.  Define new pthread_spinlock_t.
4741 2000-05-24  Andreas Jaeger  <aj@suse.de>
4743         * sysdeps/i386/i686/pt-machine.h: Only use LDT on newer kernels.
4745 2000-05-21  Jakub Jelinek  <jakub@redhat.com>
4747         * manager.c (pthread_handle_create): Initialize p_res._sock to -1.
4749 2000-05-13  Jakub Jelinek  <jakub@redhat.com>
4751         * internals.h (__RES_PTHREAD_INTERNAL): Define.
4753 2000-05-06  Kaz Kylheku  <kaz@ashi.footprints.net>
4755         * mutex.c (pthread_once): IN_PROGRESS state of pthread_once_t
4756         object state is represented with additional bits which distinguish
4757         whether that state was set up in the current process, or
4758         in an ancestor process. If that state was set in an ancestor,
4759         it means that a fork happened while thread was executing the init
4760         function. In that case, the state is reset to NEVER.
4761         * mutex.c (__pthread_once_fork_prepare): New function.
4762         (__pthread_once_fork_child): Likewise
4763         (__pthread_once_fork_parent): Likewise
4764         (__pthread_reset_pthread_once): Removed.
4765         * ptfork.c (__fork): Call new handlers in mutex.c.
4766         * internals.h: Declarations of new mutex.c functions added.
4767         Declaration of removed function deleted.
4768         * linuxthreads.texi: Updated documentation about pthread_once
4769         to clarify what happens under cancellation and forking.
4771 2000-05-06  Kaz Kylheku  <kaz@ashi.footprints.net>
4773         * internals.h: New thread manager request type, REQ_KICK.
4774         * join.c (pthread_exit): main thread now calls exit() instead
4775         of _exit() in order to proper process cleanup.
4776         * manager.c (__pthread_manager): Do not terminate manager
4777         after unblocking main thread; wait for main thread's
4778         REQ_PROCESS_EXIT request instead.
4779         Also, added REQ_KICK case to handle new request; this just does
4780         nothing.
4781         * manager.c (pthread_exited): Do not terminate manager after
4782         unblocking main thread.
4783         * manager.c (__pthread_manager_sighandler): If the main thread
4784         is waiting for all other threads to die, send a REQ_KICK into
4785         the thread manager request pipe to get it to clean out the threads
4786         and unblock the main thread as soon as possible. This fixes
4787         the 2000 millisecond hang on shutdown bug.
4788         * Examples/ex7.c: New file, tests shutdown behavior when all threads
4789         including the main one call pthread_exit(), or implicitly do so.
4790         * Makefile (tests): Add ex7.
4792 2000-05-05  Andreas Jaeger  <aj@suse.de>
4794         * sysdeps/unix/sysv/linux/i386/getcpuclockid.c
4795         (pthread_getcpuclockid): Correct test for ourselves.
4797 2000-05-05  Ulrich Drepper  <drepper@redhat.com>
4799         * internals.h (struct _pthread_descr_struct): Reorganization.
4800         Allocate room for 16 pointers at head of the structure for future
4801         thread-local data handling.  Move p_self member in this area.
4802         * manager.c (pthread_handle_create): Adjust use of p_self.
4803         * sysdeps/i386/useldt.h (THREAD_SELF): Likewise.
4804         * pthread.c (__pthread_initial_thread): Adjust initialization.
4805         (__pthread_manager_thread): Likewise.
4807 2000-04-29  Bruno Haible  <haible@clisp.cons.org>
4809         * join.c (pthread_exit): Use THREAD_GETMEM_NC instead of THREAD_GETMEM
4810         for eventmask larger than 1 word.
4812 2000-04-27  Ulrich Drepper  <drepper@redhat.com>
4814         * Versions [libpthread] (GLIBC_2.2): Add __pthread_initialize_minimal.
4815         * pthread.c (__pthread_initialize_minimal): New function.  Perform
4816         minimal initialization.
4817         (pthread_initialize): Remove this code here.
4818         * sysdeps/i386/i686/pt-machine.h: Include "../useldt.h" again.  We
4819         are working around the problem in glibc.
4821 2000-04-25  Ulrich Drepper  <drepper@redhat.com>
4823         * sysdeps/i386/i686/pt-machine.h: Do not use "../useldt.h" for
4824         now.  First gcc must be fixed (more concrete: libgcc).
4826 2000-04-24  Ulrich Drepper  <drepper@redhat.com>
4828         * pthread.c: Remove special treatement for interrupt handlers on x86.
4829         * manager.c (pthread_free): Use FREE_THREAD not FREE_THREAD_SELF.
4830         * sysdeps/i386/useldt.h: Use "q" constraint instead of "r" where
4831         necessary.
4832         * sysdeps/i386/i686/pt-machine.h: Include "../useldt.h".
4834 2000-04-24  Mark Kettenis  <kettenis@gnu.org>
4836         * join.c (pthread_exit): Set p_terminated after reporting the
4837         termination event instead of before.
4839 2000-04-20  Jakub Jelinek  <jakub@redhat.com>
4841         * sysdeps/pthread/bits/libc-lock.h: Only declare __pthread_rwlock_*
4842         if __USE_UNIX98.
4844 2000-04-18  Andreas Jaeger  <aj@suse.de>
4846         * Versions: Use ld instead of ld.so.
4848 2000-04-18  Jakub Jelinek  <jakub@redhat.com>
4850         * sysdeps/unix/sysv/linux/sparc/bits/sigcontext.h (struct sigcontext):
4851         Remove the typedef keyword.
4853 2000-04-18  Jakub Jelinek  <jakub@redhat.com>
4855         * sysdeps/sparc/sparc64/pt-machine.h (MEMORY_BARRIER): Use membar,
4856         not stbar.
4857         (READ_MEMORY_BARRIER): Define.
4858         * spinlock.c (__pthread_spin_unlock): Use READ_MEMORY_BARRIER, not
4859         MEMORY_BARRIER.
4860         * internals.h (READ_MEMORY_BARRIER): Define if not defined in sysdep
4861         headers.
4863 2000-04-17  Ulrich Drepper  <drepper@redhat.com>
4865         * sysdeps/unix/sysv/linux/i386/getcpuclockid.c
4866         (pthread_getcpuclockid): Don't compare thread_id with thread_self,
4867         use thread_handle().
4869 2000-04-16  Ulrich Drepper  <drepper@redhat.com>
4871         * condvar.c (pthread_cond_timedwait_relative): Don't test for owner
4872         if fast mutex is used.  Don't initialize `already_canceled' twice.
4873         Correctly test for return value of timedsuspend.
4875         * pthread.c: Correct long-time braino.  We never set SA_SIGINFO and
4876         therefore don't need the _rt versions of the signal handlers.
4878 2000-04-15  Ulrich Drepper  <drepper@redhat.com>
4880         * pthread.c (pthread_yield): New function.
4881         * sysdeps/pthread/pthread.h (pthread_yield): Add prototype.
4882         * Versions [libpthread] (GLIBC_2.2): Add pthread_yield.
4883         * internals.h: Declare __pthread_yield.
4885         * pthread.c (pthread_initialize): Avoid a bit more code if
4886         realtime signals are known to exist.
4888         * pthread.c: Is __ASSUME_REALTIME_SIGNALS then avoid generating code
4889         to dynamically detect RT signals and avoid generating compatibility
4890         functions with old kernel.
4891         * restart.h (restart) [__ASSUME_REALTIME_SIGNALS]: Use
4892         __pthread_restart_new directly.
4893         (suspend) [__ASSUME_REALTIME_SIGNALS]: Use
4894         __pthread_wait_for_restart_signal directly.
4895         (timedsuspend) [__ASSUME_REALTIME_SIGNALS]: Use
4896         __pthread_timedsuspend_new directly.
4898 2000-04-15  Ulrich Drepper  <drepper@redhat.com>
4900         * condvar.c: Remove all the special code to handle cond_timedwait.
4901         Use timedsuspend instead.
4902         * internals.h: Declare __pthread_timedsuspend_old,
4903         __pthread_timedsuspend_new, and __pthread_timedsuspend.
4904         Remove declaration of __pthread_init_condvar.
4905         * pthread.c: Define __pthread_timedsuspend variable.
4906         (__pthread_timedsuspend_old): New function.  Timed suspension
4907         implementation for old Linux kernels.
4908         (__pthread_timedsuspend_new): New function.  Timed suspension
4909         implementation for new Linux kernels.
4910         * restart.h (timedsuspend): New function.  Call appropriate
4911         suspension function through __pthread_timedsuspend.
4912         * semaphore.c (sem_timedwait): Use timedsuspend, don't duplicate
4913         the code.
4914         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
4916         * internals.h (WRITE_MEMORY_BARRIER): Define as MEMORY_BARRIER if
4917         undefined.
4918         * spinlock.c: Use WRITE_MEMORY_BARRIER instead of MEMORY_BARRIER
4919         where possible.
4920         * sysdeps/alpha/pt-machine.h: Define WRITE_MEMORY_BARRIER.
4921         * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
4923         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Add _POSIX_SPAWN.
4924         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
4926 2000-04-14  Andreas Jaeger  <aj@suse.de>
4928         * weaks.c: Fix typo.
4930         * shlib-versions (mips.*-.*-linux.*): Support only GLIBC 2.0 and
4931         2.2 for linuxthreads.
4933 2000-04-13  Ulrich Drepper  <drepper@redhat.com>
4935         * sysdeps/unix/sysv/linux/i386/getcpuclockid.c
4936         (pthread_getcpuclockid): Fix typo.
4938 2000-04-12  Ulrich Drepper  <drepper@redhat.com>
4940         * Makefile (libpthread-routines): Add getcpuclockid.
4941         * Versions [libpthread] (GLIBC_2.2): Add pthread_getcpuclockid.
4942         * sysdeps/pthread/getcpuclockid.c: New file.
4943         * sysdeps/unix/sysv/linux/i386/getcpuclockid.c: New file.
4944         * sysdeps/pthread/pthread.h: Add prototype for pthread_getcpuclockid.
4946         * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_SPIN_LOCKS):
4947         Defined.
4948         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
4950         * sysdeps/pthread/pthread.h: Add prototypes for pthread_spin_init,
4951         pthread_spin_destroy, pthread_spin_lock, pthread_spin_trylock,
4952         and pthread_spin_unlock.
4953         * sysdeps/pthread/bits/pthreadtypes.h: Change struct _pthread_fastlock
4954         into pthread_spinlock_t.  Change all uses.
4955         * spinlock.c: Implement pthread_spin_lock.
4956         Rename __pthread_unlock to __pthread_spin_unlock and define weak
4957         alias for real name.
4958         Define pthread_spin_trylock, pthread_spin_init, and
4959         pthread_spin_destroy.
4960         Change all uses of _pthread_fastlock to pthread_spinlock_t.
4961         * spinlock.h: Rename __pthread_unlock to __pthread_spin_unlock.
4962         Change all uses of _pthread_fastlock to pthread_spinlock_t.
4963         * Versions [libpthread] (GLIBC_2.2): Add pthread_spin_init,
4964         pthread_spin_destroy, pthread_spin_lock, pthread_spin_trylock,
4965         and pthread_spin_unlock.
4966         * cancel.c: Use __pthread_spin_unlock instead of __pthread_unlock.
4967         Change all uses of _pthread_fastlock to pthread_spinlock_t.
4968         * condvar.c: Likewise.
4969         * internals.h: Likewise.
4970         * join.c: Likewise.
4971         * manager.c: Likewise.
4972         * mutex.c: Likewise.
4973         * pthread.c: Likewise.
4974         * rwlock.c: Likewise.
4975         * semaphore.c: Likewise.
4976         * signals.c: Likewise.
4978         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Add various new POSIX
4979         macros.
4980         * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: New file.
4982 2000-04-11  Ulrich Drepper  <drepper@redhat.com>
4984         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Add
4985         _POSIX_SHARED_MEMORY_OBJECTS.
4987 2000-04-11  Andreas Jaeger  <aj@suse.de>
4989         * sysdeps/mips/pt-machine.h (MEMORY_BARRIER): Define.
4990         (__compare_and_swap): Mark as modifying memory.
4992 2000-04-11  Geoff Keating  <geoffk@cygnus.com>
4994         * sysdeps/powerpc/pt-machine.h (MEMORY_BARRIER): Don't be
4995         __volatile__.
4996         (__compare_and_swap): Replace other 'sync' with MEMORY_BARRIER.
4997         Don't have the 'asm' __volatile__.
4999 2000-04-11  Ulrich Drepper  <drepper@redhat.com>
5001         * internals.h: Define MEMORY_BARRIER as empty if not defined already.
5002         * spinlock.c (__pthread_lock): Add memory barriers.
5003         (__pthread_unlock): Likewise.
5004         * sysdeps/alpha/pt-machine.h (MEMORY_BARRIER): Define using mb
5005         instruction.
5006         (RELEASE): Not needed anymore.
5007         (__compare_and_swap): Mark asm as modifying memory.
5008         * sysdeps/powerpc/pt-machine.h (sync): Remove.  Replace with definition
5009         of MEMORY_BARRIER.
5010         (__compare_and_swap): Use MEMORY_BARRIER instead of sync.
5011         * sysdeps/sparc/sparc32/pt-machine.h (RELEASE): Not needed anymore.
5012         (MEMORY_BARRIER): Define using stbar.
5013         * sysdeps/sparc/sparc64/pt-machine.h (MEMORY_BARRIER): Define using
5014         stbar.
5015         (__compare_and_swap): Use MEMORY_BARRIER to ensure ordering.
5016         Patch by Xavier Leroy <Xavier.Leroy@inria.fr> based on comments by
5017         Mike Burrows <m3b@pa.dec.com>.
5019 2000-04-09  Ulrich Drepper  <drepper@redhat.com>
5021         * signals.c (sigaction): Fix return value for the case SIG is one
5022         of the signals the implementation uses.
5023         Patch by Xavier.Leroy@inria.fr.
5025 2000-04-01  Andreas Jaeger  <aj@suse.de>
5027         * attr.c: Use shlib-compat macros.
5028         * oldsemaphore.c: Likewise.
5029         * pthread.c: Likewise.
5030         * weaks.c: Likewise.
5032 2000-03-26  Ulrich Drepper  <drepper@redhat.com>
5034         * semaphore.c (sem_timedwait): New function.
5035         Patch by Carl Mailloux <carlm@oricom.ca>.
5036         * semaphore.h: Declare sem_timedwait.
5037         * Versions [libpthread] (GLIBC_2.2): Add sem_timedwait.
5039 2000-03-26  Roland McGrath  <roland@baalperazim.frob.com>
5041         * sysdeps/pthread/Makefile: File removed.
5043 2000-03-23  Ulrich Drepper  <drepper@redhat.com>
5045         * mutex.c (__pthread_reset_pthread_once): Reset once_masterlock.
5046         * internals.h (__pthread_reset_pthread_once): Add prototype.
5047         * ptfork.c (__fork): Call __pthread_reset_pthread_once.
5049         * manager.c (pthread_handle_create): Store ID of new thread before
5050         clone call.
5052 2000-03-21  Ulrich Drepper  <drepper@redhat.com>
5054         * attr.c: Use new macros from shlib-compat.h to define versions.
5055         * oldsemaphore.c: Likewise.
5056         * semaphore.c: Likewise.
5057         * weaks.c: Likewise.
5059         * pthread.c: Update for new SHLIB_COMPAT definition.
5061         * manager.c (__pthread_manager): Unmask debug signal.
5063         * pthread.c (pthread_initialize): Test for address of __dso_handle
5064         being NULL, not value.  Use __on_exit, not on_exit.
5065         Patch by Andreas Jaeger <aj@suse.de>.
5067         * pthread.c: Use new macros from shlib-compat.h to define versions.
5069 2000-03-19  Ulrich Drepper  <drepper@redhat.com>
5071         * pthread.c (pthread_initialize): Instead of on_exit use
5072         __cxa_atexit if __dso_label is available to allow unloading the
5073         libpthread shared library.
5075 2000-03-16  Ulrich Drepper  <drepper@redhat.com>
5077         * condvar.c: Make tests for ownership of mutex less strict.
5079 2000-03-14  Ulrich Drepper  <drepper@redhat.com>
5081         * condvar.c (pthread_cond_wait): Check whether mutex is owned by
5082         current thread and return error if not.
5083         (pthread_cond_timedwait_relative_old): Likewise.
5084         (pthread_cond_timedwait_relative_new): Likewise.
5086         * mutex.c (__pthread_once): Handle cancelled init function correctly.
5087         (pthread_once_cancelhandler): New function.
5088         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
5090 2000-03-14  Andreas Jaeger  <aj@suse.de>
5092         * pthread.c (pthread_handle_sigcancel_rt): GS has been renamed to
5093         REG_GS.
5094         (pthread_handle_sigrestart_rt): Likewise.
5095         * signals.c (pthread_sighandler_rt): Likewise.
5097 2000-03-02  Andreas Jaeger  <aj@suse.de>
5099         * sysdeps/pthread/bits/libc-lock.h: Fix typo.
5100         Reported by Sean Chen <sean.chen@turbolinux.com>.
5102 2000-02-28  Andreas Jaeger  <aj@suse.de>
5104         * rwlock.c: Fix typo.
5106 2000-02-27  Ulrich Drepper  <drepper@redhat.com>
5108         * rwlock.c: Define __* variants of the functions and make old names
5109         aliases.
5110         * Versions [GLIBC_2.2]: Export the __pthread_rwlock_* functions.
5111         * sysdeps/pthread/bits/libc-lock.h: Define __libc_rwlock_* macros.
5113 2000-02-25  Andreas Jaeger  <aj@suse.de>
5115         * Versions: Export pread, __pread64, pread64, pwrite, __pwrite64,
5116         pwrite64, lseek64, open64, and __open64 with version 2.2.
5118 2000-02-22  Ulrich Drepper  <drepper@redhat.com>
5120         * semaphore.h (SEM_FAILED): Use 0 not NULL.
5122 2000-02-14  Ulrich Drepper  <drepper@redhat.com>
5124         * condvar.c (pthread_cond_timedwait_relative_old): Tight loop with
5125         nanosleep does not work either.  Get absolute time inside the
5126         loop.
5127         (pthread_cond_timedwait_relative_new): Likewise.
5128         Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
5130 2000-02-13  Andreas Jaeger  <aj@suse.de>
5132         * condvar.c (pthread_cond_timedwait_relative_new): Fix last patch.
5133         (pthread_cond_timedwait_relative_old): Likewise.
5135 2000-02-13  Ulrich Drepper  <drepper@redhat.com>
5137         * condvar.c (pthread_cond_timedwait_relative_old): Undo last patch
5138         but keep the code around.  A bug in the kernel prevent us from
5139         using the code.
5140         (pthread_cond_timedwait_relative_new): Likewise.
5141         (PR libc/1597 and libc/1598).
5143 2000-02-01  Kaz Kylheku  <kaz@ashi.footprints.net>
5145         * condvar.c (pthread_cond_timedwait_relative_old): Do tight
5146         loop around nanosleep calls instead of around most of the function
5147         (pthread_cond_timedwait_relative_new): Likewise.
5148         body.  Got rid of backwards goto and one local.
5150 2000-01-31  Ulrich Drepper  <drepper@redhat.com>
5152         * condvar.c (pthread_cond_timedwait_relative_old): Recompute time
5153         before every nanosleep call to account for time spent in the rest
5154         of the function.
5155         (pthread_cond_timedwait_relative_new): Likewise.
5156         Patch by khendricks@ivey.uwo.ca (PR libc/1564).
5158 2000-01-29  Ulrich Drepper  <drepper@redhat.com>
5160         * condvar.c (pthread_cond_timedwait_relative_old): Get remaining time
5161         from nanosleep call so that in case we restart we only wait for the
5162         remaining time.
5163         (pthread_cond_timedwait_relative_new): Likewise.
5164         Patch by khendricks@ivey.uwo.ca (PR libc/1561).
5166 2000-01-18  Ulrich Drepper  <drepper@cygnus.com>
5168         * manager.c (pthread_allocate_stack): Compute guard page address
5169         correctly.  Patch by HJ Lu.
5171         * sysdeps/pthread/pthread.h: Define
5172         PTHREAD_RWLOCK_WRITER_NONRECURSIVE_INITIALIZER_NP.
5174 2000-01-16  Ulrich Drepper  <drepper@cygnus.com>
5176         * rwlock.c (pthread_rwlock_unlock): Correct one more problem with
5177         preference handling.
5178         (pthread_rwlockattr_setkind_np): Allow
5179         PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP.
5180         Patches by Kaz Kylheku <kaz@ashi.footprints.net>.
5182 2000-01-12  Ulrich Drepper  <drepper@cygnus.com>
5184         * internals.h (pthread_readlock_info): New structure.
5185         (_pthread_descr_struct): Add p_readlock_list, p_readlock_free, and
5186         p_untracked_readlock_count.
5187         * pthread.c (__pthread_initial_thread, pthread_manager_thread):
5188         Add initializers for new fields.
5189         * manager.c (pthread_free): Free read/write lock lists.
5190         * queue.h (queue_is_empty): New function.
5191         * rwlock.c: Implement requirements about when readers should get
5192         locks assigned.
5193         * sysdeps/pthread/pthread.h
5194         (PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP): New definition.
5195         * sysdeps/pthread/bits/pthreadtypes.h (struct _pthread_rwlock_t):
5196         Define this name as well.
5197         Patches by Kaz Kylheku <kaz@ashi.footprints.net>.
5199 2000-01-05  Ulrich Drepper  <drepper@cygnus.com>
5201         * pthread.c (__pthread_initial_thread, pthread_manager_thread):
5202         Adjust initializers for struct _pthread_descr_struct change.
5203         * internals.h (struct _pthread_descr_struct): Move new elements to
5204         the end.
5206 2000-01-03  Kaz Kylheku  <kaz@ashi.footprints.net>
5208         Redesigned how cancellation unblocks a thread from internal
5209         cancellation points (sem_wait, pthread_join,
5210         pthread_cond_{wait,timedwait}).
5211         Cancellation won't eat a signal in any of these functions
5212         (*required* by POSIX and Single Unix Spec!).
5213         * condvar.c: Spontaneous wakeup on pthread_cond_timedwait won't eat a
5214         simultaneous condition variable signal (not required by POSIX
5215         or Single Unix Spec, but nice).
5216         * spinlock.c: __pthread_lock queues back any received restarts
5217         that don't belong to it instead of assuming ownership of lock
5218         upon any restart; fastlock can no longer be acquired by two threads
5219         simultaneously.
5220         * restart.h: Restarts queue even on kernels that don't have
5221         queued real time signals (2.0, early 2.1), thanks to atomic counter,
5222         avoiding a rare race condition in pthread_cond_timedwait.
5224 1999-12-31  Andreas Jaeger  <aj@suse.de>
5226         * internals.h: Remove duplicate prototype declarations.
5228         * weaks.c: Remove __THROW from prototypes since the file is not
5229         compiled by a C++ compiler.
5230         * internals.h: Likewise.
5232 1999-12-30  Andreas Jaeger  <aj@suse.de>
5234         * sysdeps/pthread/pthread.h: Move internal functions to...
5235         * sysdeps/pthread/bits/libc-lock.h: ...here.
5237 1999-12-29  Andreas Jaeger  <aj@suse.de>
5239         * sysdeps/pthread/pthread.h: Fix typos, reformat comments.
5241 1999-12-28  Ulrich Drepper  <drepper@cygnus.com>
5243         * sysdeps/alpha/pt-machine.h: Move stack_pointer definition to the
5244         beginning.
5246         * manager.c (__pthread_start): Add one more cast to prevent
5247         warning on 64bit machines.
5249 1999-12-21  Ulrich Drepper  <drepper@cygnus.com>
5251         * manager.c (pthread_handle_create): Set p_pid of new thread
5252         before calling the callback function to report a new thread.
5254 1999-12-20  Andreas Jaeger  <aj@suse.de>
5256         * pthread.c (pthread_initialize): Move getrlimit call after
5257         setting of errno.
5259 1999-12-18  Ulrich Drepper  <drepper@cygnus.com>
5261         * Versions: Export pread, __pread64, pread64, pwrite, __pwrite64,
5262         pwrite64, lseek64, open64, and __open64.
5263         * wrapsyscall.c: Define pread, __pread64, pread64, pwrite, __pwrite64,
5264         pwrite64, lseek64, open64, and __open64.
5266         * manager.c (pthread_allocate_stack): Correct computation of
5267         new_thread_bottom.  Correct handling of stack size and when the
5268         rlimit method to guard for stack growth is used.
5269         * pthread.c (pthread_initialize): Stack limit must be STACK_SIZE
5270         minus one pagesize (not two).
5272 1999-12-03  Andreas Jaeger  <aj@suse.de>
5274         * Versions: Add __res_state with version GLIBC_2.2.
5276         * errno.c (__res_state): New function to return thread specific
5277         resolver state.
5279         * pthread.c (pthread_initialize): Initialize p_resp.
5280         (__pthread_reset_main_thread): Also set p_resp.
5282         * manager.c (pthread_handle_create): Initialize p_resp.
5284         * internals.h: Add thread specific resolver state.
5285         Based on patches by Adam D. Bradley <artdodge@cs.bu.edu>.
5287 1999-12-01  Ulrich Drepper  <drepper@cygnus.com>
5289         * sysdeps/i386/pt-machine.h: Move stack_pointer definition to the
5290         beginning.
5291         * sysdeps/i386/i686/pt-machine.h: Likewise.
5292         Patches by Alan Modra <alan@SPRI.Levels.UniSA.Edu.Au>.
5294 1999-11-23  Ulrich Drepper  <drepper@cygnus.com>
5296         * manager.c (pthread_start_thread_event): Initialize p_pid already
5297         here.
5299 1999-11-22  Ulrich Drepper  <drepper@cygnus.com>
5301         * internals.h: Add prototype for __pthread_manager_event.
5302         * manager.c (__pthread_manager_event): New function.
5303         (pthread_start_thread_event): Correct computation of self.
5304         Use INIT_THREAD_SELF.
5305         * pthread.c (__pthread_manager_thread): Initialize p_lock.
5306         (__pthread_initialize_manager): Respect event flags also for creation
5307         of the manager thread.
5309 1999-11-08  Ulrich Drepper  <drepper@cygnus.com>
5311         * pthread.c (__pthread_initialize_manager): Initialize
5312         __pthread_manager_thread.p_tid.
5314 1999-11-02  Ulrich Drepper  <drepper@cygnus.com>
5316         * internals.h: Declare __pthread_last_event.
5317         * manager.c: Define __pthread_last_event.
5318         (pthread_handle_create): Set __pthread_last_event.
5319         (pthread_exited): Likewise.
5320         * join.c (pthread_exit): Likewise.
5322         * Makefile (libpthread-routines): Add events.
5323         * events.c: New file.
5324         * internals.h: Protect against multiple inclusion.
5325         Include thread_dbP.h header.
5326         (struct _pthread_descr_struct): Add new fields p_report_events and
5327         p_eventbuf.
5328         Declare event reporting functions.
5329         * join.c (pthread_exit): Signal event if this is wanted.
5330         * manager.c (__pthread_threads_events): New variable.
5331         (pthread_handle_create): Take new parameters with event information.
5332         Signal TD_CREATE event if wanted.
5333         (__pthread_manager): Adjust pthread_handle_create call.
5334         (pthread_start_thread_event): New function.  Block until manager is
5335         finished and then call pthread_start_thread.
5336         (pthread_exited): Signal TD_REAP event if wanted.
5338 1999-10-26  Ulrich Drepper  <drepper@cygnus.com>
5340         * restart.h (suspend_with_cancellation): Rewrite as a macro.
5342         * condvar.c (pthread_cond_timedwait_relative): Don't mark as inline.
5344 1999-10-25  Andreas Jaeger  <aj@suse.de>
5346         * internals.h: Remove K&R compatibility.
5347         * no-tsd.c: Likewise.
5348         * semaphore.h: Likewise.
5349         * signals.c: Likewise.
5350         * sysdeps/pthread/bits/libc-tsd.h: Likewise.
5351         * sysdeps/unix/sysv/linux/bits/sigthread.h: Likewise.
5352         * weaks.c: Likewise.
5354 1999-10-21  Xavier Leroy  <Xavier.Leroy@inria.fr>
5356         * pthread.c: For i386, wrap pthread_handle_sigrestart and
5357         pthread_handle_sigcancel with functions that restore %gs from the
5358         signal context.  For each signal handling function, two wrappers
5359         are required, one for a non-RT signal and one for a RT signal.
5360         * signal.c: For i386, add code to restore %gs from the signal
5361         context in pthread_sighandler and pthread_sighandler_rt.
5363 1999-10-17  Ulrich Drepper  <drepper@cygnus.com>
5365         * internals.h (PTHREAD_START_ARGS_INITIALIZER): Add cast.
5367 1999-10-14  Ulrich Drepper  <drepper@cygnus.com>
5369         * pthread.c (__pthread_initial_thread): Pass argument to
5370         PTHREAD_START_ARGS_INITIALIZER.
5371         (__pthread_manager_thread): Likewise.
5373         * internals.h (PTHREAD_START_ARGS_INITIALIZER): Add parameter to
5374         initialize function.
5376         * manager.c (pthread_handle_create): Remove p_startfct initialization.
5378         * internals.h (_pthread_descr_struct): We don't need p_startfct field.
5380 1999-10-12  Ulrich Drepper  <drepper@cygnus.com>
5382         * internals.h: Correct return types for __libc_read and __libc_write.
5384 1999-10-09  Andreas Jaeger  <aj@suse.de>
5386         * internals.h: Add __new_sem_post to get prototype in
5387         manager.c; include semaphore.h for needed types.
5389 1999-10-08  Ulrich Drepper  <drepper@cygnus.com>
5391         * manager.c (__pthread_manager) [REQ_POST]: Use __new_sem_post
5392         directly instead of calling sem_post which should not be necessary
5393         but is faster and might help in some case to work around problems.
5394         Patch by khendricks@ivey.uwo.ca [libc/1382].
5396 1999-10-08  Andreas Schwab  <schwab@suse.de>
5398         * sysdeps/pthread/Subdirs: New file.
5399         * Implies: Removed.
5401 1999-10-07  Ulrich Drepper  <drepper@cygnus.com>
5403         * Implies: New file.
5404         * internals.h (struct _pthread_descr_struct): Add p_startfct.
5405         * manager.c (pthread_handle_create): Initialize p_startfct.
5406         * pthread.c: Define __linuxthread_pthread_sizeof_descr variable.
5408 1999-09-25  Ulrich Drepper  <drepper@cygnus.com>
5410         * manager.c (__linuxthreads_pthread_threads_max): New variable.
5411         * specific.c (__linuxthreads_pthread_keys_max): New variable.
5412         (__linuxthreads_pthread_key_2ndlevel_size): New variable.
5414         * condvar.c (pthread_cond_timedwait_relative): Never return with
5415         EINTR.  Patch by Andreas Schwab.
5417 1999-09-19  Ulrich Drepper  <drepper@cygnus.com>
5419         * signals.c (sigaction): Correct last patch.  Don't select
5420         pthread_sighandler_rt based on the signal number but instead of
5421         the SA_SIGINFO flag.
5423 1999-09-23  Ulrich Drepper  <drepper@cygnus.com>
5425         * specific.c: Move definitions of struct pthread_key_struct and
5426         destr_function to ...
5427         * internals.h: ...here.
5429 1999-09-18  Ulrich Drepper  <drepper@cygnus.com>
5431         * pthread.c (pthread_handle_sigrestart_rt): New function.  Use
5432         this instead of pthread_handle_sigrestart if the signal is an RT
5433         signal.
5435         * signals.c: Handle passing through of sighandler arguments also
5436         for real-time signals.
5438 1999-09-03  Andreas Schwab  <schwab@suse.de>
5440         * ptfork.c (__fork): Renamed from fork and use __libc_fork.  Add
5441         fork as weak alias.
5442         (__vfork): New function, alias vfork.
5443         * Versions: Export __fork, vfork, and __vfork in libpthread.
5445 1999-08-23  Andreas Schwab  <schwab@suse.de>
5447         * signals.c (pthread_sighandler): Add SIGCONTEXT_EXTRA_ARGS to
5448         call to signal handler.
5450 1999-08-20  Ulrich Drepper  <drepper@cygnus.com>
5452         * pthread.c (__pthread_reset_main_thread): Undo last change.
5453         (__pthread_kill_other_threads_np): Reset signal handlers for the
5454         signals we used in the thread implementation here.
5456 1999-08-19  Ulrich Drepper  <drepper@cygnus.com>
5458         * pthread.c (__pthread_reset_main_thread): Reset signal handlers
5459         for the signals we used in the thread implementation [PR libc/1234].
5461         * Versions: Export __pthread_kill_other_threads_np from libpthread
5462         for GLIBC_2.1.2.
5464         * signals.c: Pass sigcontext through wrapper to the user function.
5466 1999-08-01  Ulrich Drepper  <drepper@cygnus.com>
5468         * Versions [ld.so] (GLIBC_2.0): Export __libc_internal_tsd_get and
5469         __libc_internal_tsd_set.
5471 1999-07-29  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
5473         * manager.c: Remove inclusion of <linux/tasks.h> since it's not
5474         needed anymore.
5476 1999-07-16  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
5478         * internals.h: Align _pthread_descr_struct to 32 bytes.
5479         Reported by Tim Hockin <thockin@cobaltnet.com>, close PR
5480         libc/1206.
5482 1999-07-09  Ulrich Drepper  <drepper@cygnus.com>
5484         * oldsemaphore.c (sem_compare_and_swap): Fix use of compare and
5485         swap function.
5487 1999-07-09  Cristian Gafton  <gafton@redhat.com>
5489         * Makefile (libpthread-routines): Add oldsemaphore routine.
5490         * Versions: Add sem_destroy, sem_getvalue, sem_init, sem_post,
5491         sem_trywait, and sem_wait to GLIBC_2.1.
5492         * oldsemaphore.c: New file.
5493         * semaphore.c: Add default_symbol_versions for the changed functions.
5494         (__new_sem_init): Rename from sem_init.
5495         (__new_sem_post): Rename from sem_post.
5496         (__new_sem_wait): Rename from sem_wait.
5497         (__new_sem_trywait): Rename from sem_trywait.
5498         (__new_sem_getvalue): Rename from sem_getvalue.
5499         (__new_sem_destroy): Rename from sem_destroy.
5501 1999-06-23  Robey Pointer  <robey@netscape.com>
5503         * internals.h: Added p_nextlock entry to separate queueing for a
5504         lock from queueing for a CV (sometimes a thread queues on a lock
5505         to serialize removing itself from a CV queue).
5506         * pthread.c: Added p_nextlock to initializers.
5507         * spinlock.c: Changed to use p_nextlock instead of p_nextwaiting.
5509 1999-07-09  Ulrich Drepper  <drepper@cygnus.com>
5511         * manager.c (pthread_handle_create): Free mmap region after stack
5512         if clone failed.  Patch by Kaz Kylheku <kaz@ashi.FootPrints.net>.
5514 1999-05-23  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
5516         * man/pthread_cond_init.man: Correct example.
5517         Reported by Tomas Berndtsson <tomas@nocrew.org>.
5519         * linuxthreads.texi (Condition Variables): Likewise.
5521 1999-05-18  Jakub Jelinek  <jj@ultra.linux.cz>
5523         * sysdeps/sparc/sparc64/pt-machine.h (__compare_and_swap): Use
5524         casx not cas, also successful casx returns the old value in rd
5525         and not the new value.
5527 1999-05-16  Xavier Leroy  <Xavier.Leroy@inria.fr>
5529         * manager.c: If pthread_create() is given a NULL attribute
5530         and the thread manager runs with a realtime policy, set the
5531         scheduling policy of the newly created thread back to SCHED_OTHER.
5532         * manager.c: If the PTHREAD_INHERIT_SCHED attribute is given,
5533         initialize the schedpolicy field of new_thread->p_start_args
5534         to that of the calling thread.
5536 1999-04-29  Ulrich Drepper  <drepper@cygnus.com>
5538         * sysdeps/sparc/sparc64/pt-machine.h (__compare_and_swap): cas
5539         instruction does not allow memory element to use offset.
5541 1999-04-28  Ulrich Drepper  <drepper@cygnus.com>
5543         * manager.c (pthread_allocate_stack): Optimize initialization of new
5544         thread descriptor.
5546         * sysdeps/pthread/bits/libc-lock.h (__libc_lock_define_initialized):
5547         Don't use initializer since it is all zeroes.
5548         (__libc_once_define): Likewise.
5550 1999-04-16  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
5552         * sysdeps/arm/Implies: Removed since cmpxchg/no-cmpxchg
5553         doesn't exist anymore.
5554         * sysdeps/i386/Implies: Likewise.
5555         * sysdeps/m68k/Implies: Likewise.
5556         * sysdeps/mips/Implies: Likewise.
5557         * sysdeps/powerpc/Implies: Likewise.
5558         * sysdeps/sparc/sparc32/Implies: Likewise.
5559         * sysdeps/sparc/sparc64/Implies: Likewise.
5561 1999-04-15  Ulrich Drepper  <drepper@cygnus.com>
5563         * sysdeps/alpha/bits/semaphore.h: Removed.
5564         * sysdeps/powerpc/bits/semaphore.h: Removed.
5565         * sysdeps/pthread/cmpxchg/bits/semaphore.h: Removed.
5566         * sysdeps/pthread/no-cmpxchg/bits/semaphore.h: Removed.
5567         * Makefile (headers): Remove bits/semaphore.h.
5569         * semaphore.h: Define _pthread_descr if necessary.
5570         Don't include limits.h.  Define SEM_VALUE_MAX directly.
5571         Define SEM_FAILED.
5572         (sem_t): Protect element names with leading __.
5573         Add declarations for sem_close, sem_open, and sem_unlink.
5574         * semaphore.c: Adjust all functions for new element names.
5575         Define sem_close, sem_open, and sem_unlink.
5576         * Versions (libthread): Add sem_close, sem_open, and sem_unlink for
5577         GLIBC_2.1.1.
5578         * sysdeps/pthread/bits/pthreadtypes.h: Define _pthread_descr only if
5579         necessary.
5581 1999-03-16  H.J. Lu  <hjl@gnu.org>
5583         * specific.c (pthread_key_delete): Check th->p_terminated to see
5584         if the thread is running.
5586         * Versions (__libc_internal_tsd_get, __libc_internal_tsd_set):
5587         Added to GLIBC_2.0 for libc.so.
5589 1999-02-12  H.J. Lu  <hjl@gnu.org>
5591         * Versions (__libc_current_sigrtmin, __libc_current_sigrtmax,
5592         __libc_allocate_rtsig): Added to GLIBC_2.1.
5594         * internals.h (DEFAULT_SIG_RESTART): Removed.
5595         (DEFAULT_SIG_CANCEL): Removed.
5597         * pthread.c (init_rtsigs, __libc_current_sigrtmin,
5598         __libc_current_sigrtmax, __libc_allocate_rtsig): New functions.
5599         (__pthread_sig_restart, __pthread_sig_cancel,
5600         __pthread_sig_debug): Initialized.
5601         (pthread_initialize): Call init_rtsigs () to initialize
5602         real-time signals.
5604 1999-02-03  H.J. Lu  <hjl@gnu.org>
5606         * manager.c (__pthread_manager): Do block __pthread_sig_debug.
5607         Don't restart the thread which sent REQ_DEBUG.
5608         (pthread_start_thread): Check if __pthread_sig_debug > 0
5609         before debugging.
5611         * pthread.c (__pthread_initialize_manager): Suspend ourself
5612         after sending __pthread_sig_debug to gdb instead of
5613         __pthread_sig_cancel.
5615 1999-01-24  H.J. Lu  <hjl@gnu.org>
5617         * manager.c (__pthread_manager): Delete __pthread_sig_debug
5618         from mask if __pthread_sig_debug > 0.
5619         (pthread_handle_create): Increment __pthread_handles_num.
5621         * manager.c (pthread_handle_create): Don't pass CLONE_PTRACE to clone.
5622         * pthread.c (__pthread_initialize_manager): Likewise.
5624         * pthread.c (pthread_initialize): Use __libc_allocate_rtsig (1)
5625         instead of __libc_allocate_rtsig (2).
5626         (__pthread_initialize_manager): Send __pthread_sig_debug to gdb
5627         instead of __pthread_sig_cancel.
5628         (pthread_handle_sigdebug): Fix comments.
5630 1999-01-21  Ulrich Drepper  <drepper@cygnus.com>
5632         * manager.c (pthread_allocate_stack): Set
5633         __pthread_nonstandard_stacks if user-specified stack is used.
5635 1999-01-16  Ulrich Drepper  <drepper@cygnus.com>
5637         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Add _LFS_ASYNCHRONOUS_IO,
5638         _LFS_LARGEFILE, _LFS64_LARGEFILE, and _LFS64_STDIO from Unix98.
5640 1999-01-07  Xavier Leroy  <Xavier.Leroy@inria.fr>
5642         * pthread.c: Use a third signal __pthread_sig_debug distinct
5643         from __pthread_sig_cancel to notify gdb when a thread is
5644         created
5645         * manager.c: Likewise.
5646         * internals.h: Likewise.
5647         * signals.c: The implementation of sigwait(s) assumed that
5648         all signals in s have signal handlers already attached.
5649         This is not required by the standard, so make it work
5650         also if some of the signals have no handlers.
5652 1999-01-05  Andreas Schwab  <schwab@issan.cs.uni-dortmund.de>
5654         * linuxthreads.texi: Remove pointers from first @node.  Move old
5655         @node spec inside comment.
5657 1998-12-31  Ulrich Drepper  <drepper@cygnus.com>
5659         * sysdeps/pthread/bits/stdio-lock.h: Define _IO_lock_lock and
5660         _IO_lock_unlock.
5662 1998-12-29  Ulrich Drepper  <drepper@cygnus.com>
5664         * semaphore.c (sem_trywait): Don't forget to unlock the semaphore
5665         lock.  Patch by Bernd Schmidt <crux@pool.informatik.rwth-aachen.de>.
5667 1998-12-21  Ulrich Drepper  <drepper@cygnus.com>
5669         * manager.c: Threads now send __pthread_sig_cancel on termination.
5670         Change clone call and signal masks.
5671         * thread.c (pthread_handle_sigrestart): Remove special code for
5672         manager.
5673         (pthread_handle_sigcancel): In manager thread call
5674         __pthread_manager_sighandler.
5675         * sysdeps/i386/pt-machine.h (__compare_and_swap): Add memory clobber.
5676         * sysdeps/i386/i686/pt-machine.h: Likewise.
5677         Patches by Xavier Leroy.
5679 1998-12-14  Ulrich Drepper  <drepper@cygnus.com>
5681         * spinlock.c (__pthread_unlock): Don't crash if called for an
5682         untaken mutex.  Reported by Ruslan V. Brushkoff <rus@Snif.Te.Net.UA>.
5684         * Examples/ex6.c: Unbuffer stdout and reduce sleep time to reduce
5685         overall runtime.
5687 1998-12-13  Ulrich Drepper  <drepper@cygnus.com>
5689         * Examples/ex3.c: Wait until all threads are started before
5690         searching for the number to avoid race condition on very fast
5691         systems.
5693 1998-12-08  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
5695         * sysdeps/pthread/pthread.h: Remove __pthread_setcanceltype
5696         declaration since it's not needed.
5698         * sysdeps/pthread/pthread.h: Move internal functions to ...
5699         * internals.h: ...here.
5701 1998-12-02  H.J. Lu  <hjl@gnu.org>
5703         * pthread.c (__pthread_sig_restart): Initiliaze to 0 if
5704         SIGRTMIN is defined.
5705         (__pthread_sig_cancel): Likewise.
5707 1998-12-01  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
5709         * wrapsyscall.c: Include <sys/mman.h> for msync,
5710         <stdlib.h> for system and <termios.h> for tcdrain prototype.
5711         Correct msync declaration.
5713 1998-11-29  Roland McGrath  <roland@baalperazim.frob.com>
5715         * sysdeps/pthread/bits/libc-tsd.h (__libc_tsd_define, __libc_tsd_get,
5716         __libc_tsd_set): New macros for new interface.
5717         * no-tsd.c: New file, provide uninitialized defns of
5718         __libc_internal_tsd_get and __libc_internal_tsd_set.
5719         * Makefile (routines): Add no-tsd.
5721 1998-10-12  Roland McGrath  <roland@baalperazim.frob.com>
5723         * internals.h: Include <bits/libc-tsd.h>, not <bits/libc-lock.h>.
5724         * sysdeps/pthread/bits/libc-lock.h (__libc_internal_tsd_get,
5725         __libc_internal_tsd_set): Move decls to ...
5726         * sysdeps/pthread/bits/libc-tsd.h: New file for __libc_internal_tsd_*
5727         declarations.
5729         * sysdeps/pthread/bits/libc-lock.h (__libc_internal_tsd_get,
5730         __libc_internal_tsd_set): Make these pointers to functions, not
5731         functions; remove #pragma weak decls for them.
5732         * specific.c (__libc_internal_tsd_get, __libc_internal_tsd_set):
5733         Define static functions and initialized pointers to them.
5735 1998-11-18  Ulrich Drepper  <drepper@cygnus.com>
5737         * Makefile (CFLAGS-mutex.c): Define as -D__NO_WEAK_PTHREAD_ALIASES.
5738         (CFLAGS-specific.c): Likewise.
5739         (CFLAGS-pthread.c): Likewise.
5740         (CFLAGS-ptfork.c): Likewise.
5741         (CFLAGS-cancel.c): Likewise.
5742         * sysdeps/pthread/bits/libc-lock.h: Don't mark __pthread_* functions
5743         as weak references if __NO_WEAK_PTHREAD_ALIASES is defined.
5745         * mutex.c (pthread_mutex_init): Define as strong symbol.
5746         (pthread_mutex_destroy): Likewise.
5747         (pthread_mutex_trylock): Likewise.
5748         (pthread_mutex_lock): Likewise.
5749         (pthread_mutex_unlock): Likewise.
5750         (pthread_mutexattr_init): Likewise.
5751         (pthread_mutexattr_destroy): Likewise.
5752         (pthread_once): Likewise.
5753         * ptfork.c (pthread_atfork): Likewise.
5754         * specific.c (pthread_key_create): Likewise.
5755         (pthread_setspecific): Likewise.
5756         (pthread_getspecific): Likewise.
5758 1998-11-15  Andreas Schwab  <schwab@issan.cs.uni-dortmund.de>
5760         * linuxthreads.texi: Fix punctuation after xref.
5762 1998-11-10  H.J. Lu  <hjl@gnu.org>
5764         * sysdeps/unix/sysv/linux/bits/local_lim.h: Undefine NR_OPEN
5765         if it is defined in <linux/limits.h>.
5767 1998-10-29 14:28  Ulrich Drepper  <drepper@cygnus.com>
5769         * spinlock.h (__pthread_trylock): Define inline.
5770         (__pthread_lock): Add extra parameter to declaration.  Declare
5771         using internal_function.
5772         (__pthread_unlock): Declare using internal_function.
5773         * spinlock.c (__pthread_lock): Add new parameter.  Use it instead
5774         of local variable self.  Avoid recomputing self.  Define using
5775         internal_function.
5776         (__pthread_trylock): Remove.
5777         (__pthread_unlock): Define using internal_function.
5778         * cancel.c: Adjust for __pthread_lock interface change.  Use already
5779         computed self value is possible.
5780         * condvar.c: Likewise.
5781         * join.c: Likewise.
5782         * manager.c: Likewise.
5783         * mutex.c: Likewise.
5784         * pthread.c: Likewise.
5785         * rwlock.c: Likewise.
5786         * semaphore.c: Likewise.
5787         * signals.c: Likewise.
5789 1998-10-27 13:46  Ulrich Drepper  <drepper@cygnus.com>
5791         * sysdeps/pthread/pthread.h (struct _pthread_cleanup_buffer): Prepend
5792         __ to field names of the struct.
5793         * sysdeps/pthread/bits/pthreadtypes.h (struct _pthread_fastlock):
5794         Likewise.
5795         (pthread_attr_t): Likewise.
5796         (pthread_cond_t): Likewise.
5797         (pthread_condattr_t): Likewise.
5798         (pthread_mutex_t): Likewise.
5799         (pthread_mutexattr_t): Likewise.
5800         (pthread_rwlock_t): Likewise.
5801         (pthread_rwlockattr_t): Likewise.
5802         * attr.c: Adjust for pthread.h and pthreadtypes.h change.
5803         * cancel.c: Likewise.
5804         * condvar.c: Likewise.
5805         * manager.c: Likewise.
5806         * mutex.c: Likewise.
5807         * pthread.c: Likewise.
5808         * ptlongjmp.c: Likewise.
5809         * rwlock.c: Likewise.
5810         * spinlock.c: Likewise.
5812 1998-10-09  Ulrich Drepper  <drepper@cygnus.com>
5814         * sysdeps/i386/pt-machine.h (get_eflags, set_eflags): Mark these
5815         also with PT_EI.
5817         * sysdeps/i386/i686/pt-machine.h: Remove unused inline
5818         definitions.
5820         * Makefile (libpthread-routines): Add pt-machine.
5821         * pt-machine.c: New file.
5822         * sysdeps/alpha/pt-machine.h: Define PT_EI as extern inline is not
5823         yet defined.  Use PT_EI in extern inline definitions.
5824         * sysdeps/arm/pt-machine.h: Likewise.
5825         * sysdeps/i386/pt-machine.h: Likewise.
5826         * sysdeps/i386/i686/pt-machine.h: Likewise.
5827         * sysdeps/m68k/pt-machine.h: Likewise.
5828         * sysdeps/mips/pt-machine.h: Likewise.
5829         * sysdeps/powerpc/pt-machine.h: Likewise.
5830         * sysdeps/sparc/sparc32/pt-machine.h: Likewise.
5831         * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
5833 1998-10-02  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
5835         * semaphore.h: Include <sys/types.h> so that _pthread_descr
5836         is declared.
5838 1998-09-15  David S. Miller  <davem@pierdol.cobaltmicro.com>
5840         * sysdeps/sparc/sparc32/pt-machine.h (INIT_THREAD_SELF): Add nr
5841         argument.
5842         * sysdeps/sparc/sparc64/pt-machine.h (INIT_THREAD_SELF): Likewise.
5844 1998-09-12 14:24 -0400  Zack Weinberg  <zack@rabi.phys.columbia.edu>
5846         * sysdeps/unix/sysv/linux/bits/sigthread.h: Add multiple inclusion
5847         guard.
5849 1998-09-02 11:08  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
5851         * signals.c (sigaction): Check that sig is less than NSIG to avoid
5852         array index overflow.
5854 1998-09-06 10:56  Ulrich Drepper  <drepper@cygnus.com>
5856         * sysdeps/pthread/semaphore.h: New file.
5858 1998-09-06 09:08  Ulrich Drepper  <drepper@cygnus.com>
5860         * sysdeps/pthread/bits/libc-lock.h (enum __libc_tsd_key_t): Add
5861         _LIBC_TSD_KEY_DL_ERROR.
5863 1998-08-31  Ulrich Drepper  <drepper@cygnus.com>
5865         * sysdeps/i386/i686/pt-machine.h (testandset): Add memory clobber.
5866         * sysdeps/i386/pt-machine.h: Likewise.
5867         Suggested by Roland McGrath.
5869 1998-08-28 13:58  Ulrich Drepper  <drepper@cygnus.com>
5871         * internals.h: Also define THREAD_GETMEM_NC and THREAD_SETMEM_NC to
5872         access thread data with non-constant offsets.
5873         * specific.c: Use THREAD_GETMEM_NC and THREAD_SETMEM_NC where
5874         necessary.
5876         * sysdeps/i386/useldt.h: Fix typo.  Add THREAD_GETMEM_NC and
5877         THREAD_SETMEM_NC definitions.
5879         * sysdeps/sparc/sparc32/pt-machine.h: Define THREAD_GETMEM_NC and
5880         THREAD_SETMEM_NC.
5881         * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
5883 1998-08-26 15:46  Ulrich Drepper  <drepper@cygnus.com>
5885         * internals.h: Define THREAD_GETMEM and THREAD_SETMEM to default if
5886         not already defined.
5887         (struct _pthread_descr_struct): Add p_self and p_nr field.
5888         * manager.c (__pthread_handles): Define second element to point
5889         to manager thread.
5890         (__pthread_handles_num): Initialize to 2.
5891         (__pthread_manager): Use INIT_THREAD_SELF with two arguments.
5892         (pthread_start_thread): Likewise.
5893         (pthread_handle_create): Start search for free slot at entry 2.
5894         Initialize new fields p_self and p_nr.
5895         Call __clone with CLONE_PTRACE if available.
5896         (pthread_free): Call FREE_THREAD_SELF if available.
5897         * pthread.c (__pthread_initial_thread): Initialize new fields.
5898         (__pthread_manager_thread): Likewise.
5899         (__pthread_initialize_manager): Call __clone with CLONE_PTRACE.
5901         * cancel.c: Use THREAD_GETMEM and THREAD_SETMEM to access the
5902         elements of the thread descriptor.
5903         * condvar.c: Likewise.
5904         * errno.c: Likewise.
5905         * join.c: Likewise.
5906         * manager.c: Likewise.
5907         * pthread.c: Likewise.
5908         * ptlongjmp.c: Likewise.
5909         * semaphore.c: Likewise.
5910         * signals.c: Likewise.
5911         * specific.c: Likewise.
5912         * spinlock.c: Likewise.
5914         * sysdeps/alpha/pt-machine.h (INIT_THREAD_SELF): Add extra parameter.
5916         * sysdeps/i386/useldt.h: New file.
5917         * sysdeps/i386/i686/pt-machine.h: Show how to use this file.
5919         * sysdeps/sparc/sparc32/pt-machine.h: Define THREAD_GETMEM and
5920         THREAD_SETMEM using __thread_self.
5921         * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
5923 1998-08-24  Geoff Keating  <geoffk@ozemail.com.au>
5925         * spinlock.c (__pthread_lock): Reset p_nextwaiting to NULL if it
5926         turned out that we didn't need to queue after all.
5928 1998-08-22  Geoff Keating  <geoffk@ozemail.com.au>
5930         * sysdeps/powerpc/pt-machine.h: Remove testandset, it's not used
5931         and wastes space; correct types.
5933 1998-08-08 11:18  H.J. Lu  <hjl@gnu.org>
5935         * signals.c (sigaction): Handle NULL argument.
5937 1998-08-04  Ulrich Drepper  <drepper@cygnus.com>
5939         * sysdeps/unix/sysv/linux/bits/sigthread.h: Use __sigset_t instead
5940         of sigset_t.
5942 1998-08-02  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
5944         * Makefile (linuxthreads-version): Extract correct number from
5945         Banner.
5947 1998-07-29  Xavier Leroy  <Xavier.Leroy@inria.fr>
5949         * Banner: Bump version number to 0.8
5950         * FAQ.html: Many updates, in particular w.r.t. debugging.
5951         * manager.c: Support for non-default stacksize for
5952         LinuxThreads-allocated stacks;
5953         don't use guard pages for stacks with default size, rely on
5954         rlimit(RLIMIT_STACK) instead (it's cheaper).
5955         * attr.c: Likewise.
5956         * cancel.c: Use __pthread_sig_cancel and __pthread_sig_restart
5957         everywhere instead of PTHREAD_SIG_CANCEL and PTHREAD_SIG_RESTART.
5958         * condvar.c: Likewise.
5959         * internals.h: Likewise.
5960         * restart.h: Likewise.
5961         * signals.c: Likewise.
5962         * pthread.c: Likewise; set rlimit(RLIMIT_STACK) as we need it.
5964 1998-07-23  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
5966         * weaks.c: Define pthread_mutexattr_[sg]ettype instead of
5967         __pthread_mutexattr_[sg]ettype.  Add more weak aliases.
5968         * Versions: Put __pthread_mutexattr_settype under version
5969         GLIBC_2.0.  Don't export __pthread_mutexattr_setkind_np and
5970         __pthread_mutexattr_gettype.
5972 1998-07-23  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
5974         * sysdeps/pthread/bits/libc-lock.h: Make
5975         __pthread_mutexattr_settype weak.  Don't make
5976         __pthread_mutexattr_setkind_np weak.
5978 1998-07-16 10:52  Ulrich Drepper  <drepper@cygnus.com>
5980         * manager.c (pthread_handle_create): Check whether sched_setscheduler
5981         call can succeed here.
5983         * mutex.c: Define __pthread_mutexattr_settype and make
5984         __pthread_mutexattr_setkind_np an alias.
5985         Likewise for __pthread_mutexattr_gettype.
5987 1998-07-15 11:00 -0400  Zack Weinberg  <zack@rabi.phys.columbia.edu>
5989         * attr.c (pthread_attr_setschedpolicy): Don't check whether caller
5990         is root.
5992 1998-07-14 19:38  Ulrich Drepper  <drepper@cygnus.com>
5994         * sysdeps/pthread/bits/libc-lock.h: Define __libc_cleanup_end.
5996 1998-07-11  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
5998         * Examples/ex6.c: Include <unistd.h> for usleep.
6000 1998-06-13 11:04  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
6002         * Examples/ex4.c (main): Use exit, not pthread_exit.
6004 1998-07-09 13:39  Ulrich Drepper  <drepper@cygnus.com>
6006         * Versions: Add __pthread_mutexattr_gettype and
6007         __pthread_mutexattr_settype.
6008         * lockfile.c: Use __pthread_mutexattr_settype instead of
6009         __pthread_mutexattr_setkind_np.
6010         * mutex.c: Define __pthread_mutexattr_gettype and
6011         __pthread_mutexattr_settype.
6012         * weak.c: Likewise.
6013         * sysdeps/pthread/pthread.h: Declare __pthread_mutexattr_gettype and
6014         __pthread_mutexattr_settype.
6015         * sysdeps/pthread/bits/libc-lock.h (__libc_lock_init_recursive):
6016         Use __pthread_mutexattr_settype.
6018 1998-07-08 22:26  Ulrich Drepper  <drepper@cygnus.com>
6020         * Versions: Add pthread_mutexattr_gettype, pthread_mutexattr_settype.
6021         * mutex.c: Define weak alias pthread_mutexattr_gettype and
6022         pthread_mutexattr_settype.
6023         * sysdeps/pthread/pthread.h: Declare these functions.
6024         Move pthread_sigmask and pthread_kill declaration in separate header.
6025         * sysdeps/unix/sysv/linux/bits/sigthread.h: New file.
6027 1998-07-07 15:20  Ulrich Drepper  <drepper@cygnus.com>
6029         * Makefile: Add rules to compile and run tests.
6030         * Examples/ex1.c: Little changes to fix warnings.
6031         * Examples/ex2.c: Likewise.
6032         * Examples/ex3.c: Likewise.
6033         * Examples/ex4.c: Likewise.
6034         * Examples/ex5.c: Likewise.
6035         * Examples/ex6.c: New file.
6037 1998-07-05 11:54  Ulrich Drepper  <drepper@cygnus.com>
6039         * Versions: Add pthread_attr_init to GLIBC_2.1 version in libc.
6041 1998-07-01  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
6043         * attr.c: Include <string.h>.
6045 1998-06-30 11:47  Ulrich Drepper  <drepper@cygnus.com>
6047         * attr.c: Include errno.h.  Use memcpy to copy sched_param.
6048         * internals.h: Include limits.h.
6049         * manager.c: Use memcpy to copy sched_param.
6050         * ptfork.c: Include errno.h.
6051         * pthread.c: Likewise.
6052         * semaphore.c: Likewise.
6053         * specific.c: Likewise.
6054         * spinlock.h: Likewise.
6055         * sysdeps/pthread/pthread.h: Include only allowed headers.  Move
6056         type definition to ...
6057         * sysdeps/pthread/bits/pthreadtypes.h: ...here.  New file.
6059 1998-06-29 12:34  Ulrich Drepper  <drepper@cygnus.com>
6061         * sysdeps/pthread/pthread.h: Use __PMT not __P for function pointers.
6063         * sysdeps/pthread/pthread.h: Define various PTHREAD_* symbols also
6064         as macros as demanded in POSIX.1, Annex C.
6066 1998-06-29 12:29  Ulrich Drepper  <drepper@cygnus.com>
6068         * internals.h (struct pthread_request): For free use pthread_t
6069         instead of pthread_descr.
6070         * join.c (pthread_join): Pass thread_id, not th to manager.
6071         (pthread_detach): Likewise.
6072         * manager.c (__pthread_manager): Except thread ID in FREE_REQ case.
6073         (pthread_exited): Remove detached queue code.
6074         (pthread_handle_free): Expect thread ID parameter and use it to
6075         validate the thread decsriptor.  Don't use detached queue.
6076         Patches by Xavier Leroy.
6078 1998-06-27  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
6080         * libpthread.map: Export accept, longjmp, sigaction, siglongjmp,
6081         _IO_flockfile, _IO_ftrylockfile, _IO_funlockfile,
6082         __pthread_atfork, __pthread_key_create, __pthread_once.
6083         * internals.h: Doc fix.
6084         * pthread.c (__pthread_initialize): Define again.
6086 1998-06-26  Ulrich Drepper  <drepper@cygnus.com>
6088         * manager.c (pthread_exited): If thread is not detached put it on
6089         special list.
6090         (pthread_handle_free): If thread is not on list with living threads
6091         search on list with detached threads.
6093         * sysdeps/pthread/pthread.h (PTHREAD_RWLOCK_INITIALIZER): Correct
6094         for new definition of pthread_rwlock_t.
6096         * spinlock.c: Correct test whether to compile
6097         __pthread_compare_and_swap or not.
6099 1998-06-25 19:27  Ulrich Drepper  <drepper@cygnus.com>
6101         * attr.c: Finish user stack support.  Change locking code to be safe
6102         in situations with different priorities.
6103         * cancel.c: Likewise.
6104         * condvar.c: Likewise.
6105         * internals.h: Likewise.
6106         * join.c: Likewise.
6107         * manager.c: Likewise.
6108         * mutex.c: Likewise.
6109         * pthread.c: Likewise.
6110         * ptlongjmp.c: Likewise.
6111         * queue.h: Likewise.
6112         * rwlock.c: Likewise.
6113         * semaphore.c: Likewise.
6114         * semaphore.h: Likewise.
6115         * signals.c: Likewise.
6116         * spinlock.c: Likewise.
6117         * spinlock.h: Likewise.
6118         * sysdeps/pthread/pthread.h: Likewise.
6119         Patches by Xavier Leroy.
6121         * sysdeps/i386/i686/pt-machine.h: New file.
6123 1998-06-25  Ulrich Drepper  <drepper@cygnus.com>
6125         * sysdeps/pthread/pthread.h: Make [sg]et_stacksize and
6126         [sg]et_stackaddr prototypes always available.
6128         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define
6129         _POSIX_THREAD_ATTR_STACKSIZE and _POSIX_THREAD_ATTR_STACKADDR.
6131 1998-06-24  Ulrich Drepper  <drepper@cygnus.com>
6133         * manager.c (pthread_free): Undo patch from 980430.
6134         Reported by David Wragg <dpw@doc.ic.ac.uk>.
6136 1998-06-09 15:07  Ulrich Drepper  <drepper@cygnus.com>
6138         * manager.c: Define __pthread_manager_adjust_prio and use it to
6139         increase priority when needed.
6140         * internals.h: Add prototype for __pthread_manager_adjust_prio.
6141         * mutex.c: Optimize mutexes to wake up only one thread.
6142         * pthread.c: Move PID of manager for global variable in structure
6143         element.
6144         Patches by Xavier Leroy.
6146 1998-06-07 13:47  Ulrich Drepper  <drepper@cygnus.com>
6148         * sysdeps/pthread/bits/libc-lock.h: Optimize cleanup handlers a bit.
6150 1998-06-03  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
6152         * attr.c: Correct typo.
6154 1998-05-01  Ulrich Drepper  <drepper@cygnus.com>
6156         * manager.c (pthread_free): Unmap guard before the stack.
6157         Patch by Matthias Urlichs.
6159 1998-04-30  Ulrich Drepper  <drepper@cygnus.com>
6161         * manager.c (pthread_free): Detect already free child.
6162         Patch by Xavier Leroy, reported by Matthias Urlichs.
6164 1998-04-23  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
6166         * Makefile (linuxthreads-version): Renamed back from
6167         libpthread-version.
6169 1998-04-21  Ulrich Drepper  <drepper@cygnus.com>
6171         * ptlongjmp.c: Add prototypes for __libc_siglongjmp and
6172         __libc_longjmp.
6174 1998-04-20 14:55  Ulrich Drepper  <drepper@cygnus.com>
6176         * Makefile (libpthread-routines): Add ptlongjmp and spinlock.
6177         * internals.h: Add definitions for new spinlock implementation.
6178         * ptlongjmp.c: New file.
6179         * spinlock.c: New file.
6180         * spinlock.h (acquire): Don't reschedule using __sched_yield, use
6181         new function __pthread_acquire to prevent deadlocks with thread
6182         with different priorities.
6183         Patches by Xavier Leroy <Xavier.Leroy@inria.fr>.
6185 1998-03-16  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
6187         * manager.c (__pthread_manager): Reduce first argument to select
6188         to include just the needed file descriptor.
6190 1998-03-17 00:06  Ulrich Drepper  <drepper@cygnus.com>
6192         * manager.c: Fix last patch which caused core dumps.
6194         * pthread.c: Correctly handle missing SIGRTMIN.
6196 1998-03-15  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
6198         * libpthread.map: Add __libc_internal_tsd_get and
6199         __libc_internal_tsd_set.  Add missing cancelable functions. Export
6200         libc internal versions of the cancelable functions.
6202 1998-03-13 16:51  Ulrich Drepper  <drepper@cygnus.com>
6204         * weaks.c: Define pthread_attr_init as GLIBC_2.0 and GLIBC_2.1.
6206 1998-03-13 00:46  Ulrich Drepper  <drepper@cygnus.com>
6208         * attr.c: Implement pthread_attr_[gs]etguardsize,
6209         pthread_attr_[gs]setstackaddr, pthread_attr_[gs]etstacksize.
6210         Change pthread_attr_init to have two interfaces.
6211         * internals.h (struct _pthread_descr_struct): Add new fields for
6212         above functions.
6213         * libpthread.map: Add names in GLIBC_2.1 section.
6214         * manager.c (pthread_handle_create): Implement guardsize and
6215         user stack.
6216         (pthread_free): Likewise.
6217         * pthread.c (pthread_create): Add new interface for changed
6218         pthread_attr_t.
6219         * sysdeps/pthread/pthread.h: Add prototypes for new functions.
6220         * sysdeps/unix/sysv/linux/bits/local_lim.h: Add definition of
6221         PTHREAD_STACK_MIN.
6223 1998-03-11 00:42  Wolfram Gloger  <wmglo@dent.med.uni-muenchen.de>
6225         * manager.c: Enable resetting of the thread scheduling policy
6226         to SCHED_OTHER when the parent thread has a different one.
6228 1998-02-01 13:51  Ulrich Drepper  <drepper@cygnus.com>
6230         * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define
6231         _POSIX_ASYNCHRONOUS_IO.
6233         * sysdeps/pthread/pthread.h: Define bits for Unix98 variants of
6234         mutexes.
6235         * mutex.c: Implement new mutex types.
6237         * internals.h: Include <signal.h>.
6239         * libpthread.map: Add __erno_location and __h_errno_location.
6241         * errno.c: Return pointer to variable actually in use.  This might
6242         not be the one in the thread structure.
6243         * internals.h (struct _pthread_descr_struct): Add new fields p_errnop
6244         and p_h_errnop.
6245         * manager.c (__pthread_manager): Set p_errnop and p_h_errnop member
6246         of manager thread structure.
6247         (pthread_handle_create): Set p_errnop and p_h_errnop members for new
6248         thread.
6249         * pthread.c: Adapt initializer for thread structures.
6250         (__pthread_initial_thread): Set p_errnop and p_h_errnop member.
6251         (__pthread_reset_main_thread): Reset p_errnop and p_h_errnop of
6252         current thread to global variables.
6254 1998-01-31 17:27  Ulrich Drepper  <drepper@cygnus.com>
6256         * rwlock.c: New file.
6257         * Makefile (libpthread-routines): Add rwlock.
6258         * sysdeps/pthread/pthread.h: Define data structures and declare
6259         functions.
6260         * libpthread.map: Add new functions.
6262 1997-12-18 13:50  Philip Blundell  <pb@nexus.co.uk>
6264         * sysdeps/arm/pt-machine.h: New file; add ARM support.
6265         * sysdeps/arm/Implies: likewise.
6266         * README: Document it.
6268 1997-12-13  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
6270         * signals.c: Remove unneeded initializer for sigwaited, saving a
6271         warning.
6273 1997-04-11 01:18  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
6275         * semaphore.c (sem_init): Set sem_spinlock only if available.
6277 1997-12-04 01:48  Ulrich Drepper  <drepper@cygnus.com>
6279         * mutex.c: Implement PTHREAD_MUTEX_CHECKERROR.
6280         * sysdeps/pthread/pthread.h: Define PTHREAD_MUTEX_CHECKERROR.
6282         * Makefile: Update from LinuxThreads 0.7.
6283         * internals.h. Likewise.
6284         * manager.c: Likewise.
6285         * mutex.c: Likewise.
6286         * pthread.c: Likewise.
6287         * signals.c: Likewise.
6288         * specific.c: Likewise.
6289         * Examples/ex3.c: Likewise.
6291 1997-11-20 18:13  Ulrich Drepper  <drepper@cygnus.com>
6293         * pthread.c (__pthread_reset_main_thread): Close pipe only if still
6294         open.
6296 1997-10-29 05:38  Ulrich Drepper  <drepper@cygnus.com>
6298         * wrapsyscall.c: Add socket functions which are also cancelation
6299         points.
6301 1997-10-19 21:40  Wolfram Gloger  <wg@wolfram.dent.med.uni-muenchen.de>
6303         * specific.c (__libc_internal_tsd_set, __libc_internal_tsd_get):
6304         New functions for fast thread specific data within libc.
6306         * internals.h: Add new array p_libc_specific to struct
6307         _pthread_descr_struct.
6309         * sysdeps/pthread/bits/libc-lock.h: Declare new functions.
6311 1997-10-13 05:39  Ulrich Drepper  <drepper@cygnus.com>
6313         * semaphore.h: Add __BEGIN_DECLS/__END_DECLS.
6314         Reported by Ralf Corsepius <corsepiu@faw.uni-ulm.de>.
6316 1997-08-29 03:05  Ulrich Drepper  <drepper@cygnus.com>
6318         * internals.h (struct _pthread_descr_struct): Add definitions for
6319         two-level specific key handling.
6320         * manager.c (pthread_handle_create): Initialize specific memory array.
6321         * specific.c: Implement two-level key handling.
6322         * weaks.c: Don't provide dummy key handling.
6323         * sysdeps/pthread/bits/libc-lock.h: Typedef __libc_lock_t (no #define).
6324         Add definition of __libc_key_t.
6325         * sysdeps/unix/sysv/linux/bits/local_lim.h: Define PTHREAD_KEYS_MAX
6326         as 1024.
6327         Add definition of _POSIX_THREAD_DESTRUCTOR_ITERATIONS and
6328         PTHREAD_DESTRUCTOR_ITERATIONS.
6330         * manager.c (pthread_handle_create): Compare mmap result with
6331         MAP_FAILED.
6333         * ptfork.c: Rename to __pthread_atfork and make old name a weak alias.
6334         * sysdeps/pthread/bits/pthread.h: Add prototype for __pthread_atfork.
6336 1997-08-22 19:04  Richard Henderson  <rth@cygnus.com>
6338         sysdeps/sparc -> sysdeps/sparc/sparc32
6339         sysdeps/sparc64 -> sysdeps/sparc/sparc64
6341         * internals.h: Change definition of THREAD_SELF to be an expression,
6342         not a statement that did a return.
6343         * sysdeps/alpha/pt-machine.h (THREAD_SELF): Update accordingly.
6344         * sysdeps/sparc/sparc32/pt-machine.h (THREAD_SELF, INIT_THREAD_SELF):
6345         Follow Solaris and use a "system reserved" register (%g6) to hold
6346         the thread descriptor.
6347         * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
6349 1997-08-03 00:09  Ulrich Drepper  <drepper@cygnus.com>
6351         * mutex.c: Correct pthread_once.  Patch by Xavier Leroy.
6352         * sysdeps/pthread/pthread.h: Add prototype for __pthread_once.
6353         * sysdeps/pthread/bits/pthread.h: Add macros for __libc_once.
6355         * semaphore.c: Include spinlock.h only when needed.
6357         * specific.c (__pthread_setsepcific, __pthread_getspecific): Reject
6358         keys for entries not in use.
6360         * weaks.c: Implement key handling functions for real.
6362 1997-06-29  01:04  Richard Henderson  <richard@gnu.ai.mit.edu>
6364         Initial sparc64-linux support:
6365         * sysdeps/sparc64/Implies: New file.
6366         * sysdeps/sparc64/pt-machine.h: Likewise.
6368 1997-06-29 00:48  Ulrich Drepper  <drepper@cygnus.com>
6370         * semaphore.c: Include spinlock.h at correct place.
6371         Patch by HJ Lu.
6373 1997-06-13 10:06  Richard Henderson  <rth@tamu.edu>
6375         The Great Bit File Move:
6376         * sysdeps/alpha/semaphorebits.h: -> .../bits/semaphore.h.
6377         * sysdeps/powerpc/semaphorebits.h: Likewise.
6378         * sysdeps/pthread/cmpxchg/semaphorebits.h: Likewise.
6379         * sysdeps/pthread/no-cmpxchg/semaphorebits.h: Likewise.
6380         * sysdeps/pthread/libc-lock.h: -> bits/
6381         * sysdeps/pthread/stdio-lock.h: Likewise.
6382         * sysdeps/unix/sysv/linux/local_lim.h: Likewise.
6383         * sysdeps/unix/sysv/linux/posix_opt.h: Likewise.
6384         * semaphore.h: Likewise.
6385         * sysdeps/pthread/pthread.h: Likewise.
6387         * lockfile.c: <foo.h> -> <bits/foo.h>.
6388         * semaphore.h: Likewise.
6390         * Makefile: (headers): foo.h -> bits/foo.h.
6391         * sysdeps/pthread/Makefile: Likewise.
6393 1997-04-11 01:18  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
6395         * semaphore.c (sem_init): Set sem_spinlock only if available.
6397         * sysdeps/m68k/pt-machine.h (testandset, __compare_and_swap): Fix
6398         asm constraints.
6400 1997-04-09 03:00  Ulrich Drepper  <drepper@cygnus.com>
6402         Update from LinuxThreads 0.6.
6404         * attr.c (pthread_attr_getdetachstate): Use __sched_get_priority_max
6405         and __sched_get_priority_min instead of names without `__'.
6407         * manager.c: Rewrite large parts to implement opaque pthread_t.
6409         * cancel.c: Adapt for opaque pthread_t type.
6410         * condvar.c: Likewise.
6411         * errno.c: Likewise.
6412         * join.c: Likewise.
6413         * mutex.c: Likewise.
6414         * pthread.c: Likewise.
6415         * signals.c: Likewise.
6416         * specific.c: Likewise.
6417         * restart.h: Likewise.
6418         * queue.h: Likewise.
6419         * Examples/ex3.c: Likewise.
6420         * Examples/ex4.c: Likewise.
6421         * sysdeps/pthread/pthread.h: Likewise.
6423         * pthread.c: Accumulate time for all threads in thread manager.
6425         * semaphore.c: Implement fallback implementation for architectures
6426         sometimes missing compare-exchange operations.
6428         * cancel.c (pthread_cancel): Validate handle argument.
6429         * join.c (pthread_join): Likewise.
6430         (pthread_detach): Likewise.
6431         * signals.c (pthread_kill): Likewise.
6433         * spinlock.h (acquire): Use __sched_yield not sched_yield.
6435         * queue.h (enqueue): Enqueue thread according to priority.
6437         * internals.c (struct pthread_start_args): New struct for passing
6438         args to cloning function.
6439         (struct _pthread): Rename to _pthread_descr_struct and adapt for
6440         opaque pthread_t.
6442         * Examples/Makefile (clean): Pass -f option to rm.
6444         * sysdeps/i386/pt-machine.h: Add check for compare-exchange instruction
6445         and define TEST_FOR_COMPARE_AND_SWAP.
6446         * sysdeps/i386/i486/pt-machine.h: Removed.
6448         * sysdeps/unix/sysv/linux/local_lim.h (PTHREAD_THREADS_MAX): Increase
6449         to 1024.
6451 1997-04-04 16:38  Ulrich Drepper  <drepper@cygnus.com>
6453         * restart.h (suspend): Clear p_signal before suspending.
6454         (suspend_with_cancellation): Likewise.
6455         Patch by Xavier Leroy <Xavier.Leroy@inria.fr>.
6457         * weaks.c: Make __pthread_key_create return 1.
6458         * sysdeps/pthread/libc-lock.h: Define __libc_key_create,
6459         __libc_getspecific, __libc_setspecific, and __libc_key_t.
6460         * sysdeps/pthread/stdio-lock.h: Don't care for implementation not
6461         using libio.
6463 1997-03-19 15:13  Miguel de Icaza  <miguel@nuclecu.unam.mx>
6465         * sysdeps/sparc/pt-machine (RELEASE): Fix.
6467 1997-03-01 07:55  Geoff Keating  <geoffk@ozemail.com.au>
6469         * sysdeps/powerpc/Implies: Added.
6470         * sysdeps/powerpc/pt-machine.h: Added.
6471         * sysdeps/powerpc/semaphorebits.h: Added.
6473 1997-01-22 01:22  Ulrich Drepper  <drepper@cygnus.com>
6475         * pthread.c (__pthread_initial_thread): Correct
6476         initializer.
6477         (__pthread_manager_thread): Likewise.
6478         Reported by Andreas Jaeger.
6480 1997-01-18 22:15  Richard Henderson  <rth@tamu.edu>
6482         Since sigset_t no longer fits in a register, we can't pass in the
6483         thread's initial mask so easily.  Take this opportunity to simplify
6484         the clone implementation by only accepting a single void* argument.
6486         * manager.c (__pthread_manager): Put thread vitals in the thread
6487         struct instead of as arguments through clone.
6488         (pthread_start_thread): Look for them there.
6489         * internals.h (struct _pthread): Add p_initial_fn,
6490         p_initial_fn_arg, p_initial_mask.  Fix __pthread_manager proto.
6491         * pthread.c (pthread_initialize_manager): Revise clone invocation.