1 2005-06-14 Alan Modra <amodra@bigpond.net.au>
3 * sysdeps/unix/sysv/linux/powerpc/powerpc32/sysdep-cancel.h (PSEUDO):
4 Invoke CGOTSETUP and CGOTRESTORE.
5 (CGOTSETUP, CGOTRESTORE): Define.
6 (SINGLE_THREAD_P): Add variant for new PLT/GOT layout.
7 * sysdeps/unix/sysv/linux/powerpc/powerpc32/vfork.S (__vfork): Avoid
8 bl into the GOT when HAVE_ASM_PPC_REL16.
10 2005-05-23 Roland McGrath <roland@redhat.com>
12 * sysdeps/arm, sysdeps/unix/sysv/linux/arm: Subdirectories moved to
15 2005-05-23 Jakub Jelinek <jakub@redhat.com>
17 * sysdeps/unix/sysv/linux/powerpc/powerpc32/sysdep-cancel.h
18 [IS_IN_librt] (CENABLE, CDISABLE): Use JUMPTARGET instead of
19 __librt_*_asynccancel@local.
21 2005-05-17 Alan Modra <amodra@bigpond.net.au>
23 * sysdeps/unix/sysv/linux/powerpc/powerpc32/sysdep-cancel.h: Delete
24 all occurrences of JUMPTARGET. Instead append @local to labels.
25 * sysdeps/unix/sysv/linux/powerpc/powerpc32/vfork.S: Likewise.
27 2005-05-19 Richard Henderson <rth@redhat.com>
29 * sysdeps/ia64/pspinlock.c (__pthread_spin_lock): Use
30 __sync_val_compare_and_swap, not explicit _si variant.
31 (__pthread_spin_trylock): Likewise.
33 2005-05-05 Daniel Jacobowitz <dan@codesourcery.com>
35 * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h: Remove explicit
36 .eh_frame section, use cfi_* directives.
38 2005-04-27 Jakub Jelinek <jakub@redhat.com>
40 * sysdeps/pthread/getcpuclockid.c: Include spinlock.h.
41 Fix a typo in kernel-posix-cpy-timers.h include name, use <> instead
43 (pthread_getcpuclockid): Fix 2 typos.
45 2005-04-27 Roland McGrath <roland@redhat.com>
47 * sysdeps/pthread/getcpuclockid.c (pthread_getcpuclockid)
48 [__NR_clock_getres]: Use kernel-supplied CPU clocks if available.
50 2005-03-31 Jakub Jelinek <jakub@redhat.com>
52 * sysdeps/unix/sysv/linux/x86_64/sysdep-cancel.h: Use
53 functionally equivalent, but shorter instructions.
55 2005-03-28 Daniel Jacobowitz <dan@codesourcery.com>
57 * sysdeps/mips/tls.h: New file.
58 * sysdeps/unix/sysv/linux/mips/vfork.S: New file.
60 2005-03-21 GOTO Masanori <gotom@debian.or.jp>
62 * linuxthreads/sysdeps/m68k/Makefile: Remove to delete
63 unneeded o-iterator thing.
65 2005-02-21 H.J. Lu <hongjiu.lu@intel.com>
67 * sysdeps/unix/sysv/linux/ia64/pt-initfini.c: Add local _init
70 2005-03-05 Ulrich Drepper <drepper@redhat.com>
72 * sysdeps/i386/Makefile (CFLAGS-pt-initfini.s): Unconditionally
75 2005-03-05 Roland McGrath <roland@redhat.com>
77 * sysdeps/i386/Makefile (CFLAGS-pt-initfini.s): Use $(cc-mtune).
79 2005-03-05 Jakub Jelinek <jakub@redhat.com>
81 * sysdeps/powerpc/tcb-offsets.sym (thread_offsetof): Rework for GCC 4.
83 2005-02-09 Daniel Jacobowitz <dan@codesourcery.com>
86 * descr.h (__pthread_find_self, thread_self): Mark as pure
89 2005-02-07 Jakub Jelinek <jakub@redhat.com>
92 * specific.c (pthread_key_delete): If pthread_create has not been
93 called yet, clear p_specific for the current thread.
94 * Makefile (tests): Add tst-tsd1.
95 * tst-tsd1.c: New test.
97 2005-01-08 Andreas Jaeger <aj@suse.de>
99 * pthread.c (init_one_static_tls): Adjust initialization of DTV
100 entry for static tls deallocation fix.
102 * sysdeps/alpha/tls.h (dtv_t): Change pointer type to be struct which
103 also contains information whether the memory pointed to is static
104 TLS or not, include <stdbool.h>.
105 * sysdeps/i386/tls.h: Likewise.
106 * sysdeps/ia64/tls.h: Likewise.
107 * sysdeps/powerpc/tls.h: Likewise.
108 * sysdeps/s390/tls.h: Likewise.
109 * sysdeps/sh/tls.h: Likewise.
110 * sysdeps/sparc/tls.h: Likewise.
111 * sysdeps/x86_64/tls.h: Likewise.
113 2004-12-21 Jakub Jelinek <jakub@redhat.com>
115 * Makefile (tests): Add tst-align.
116 * tst-align.c: New test.
117 * sysdeps/i386/Makefile (CFLAGS-tst-align.c): Add
118 -mpreferred-stack-boundary=4.
120 2004-12-12 Ulrich Drepper <drepper@redhat.com>
122 * internals.h: Include <stdbool.h> to match includes used in nptl.
124 2004-12-01 Jakub Jelinek <jakub@redhat.coM.
126 * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_CPUTIME,
127 _POSIX_THREAD_CPUTIME): Define to 0.
128 * sysdeps/pthread/timer_create.c (timer_create): Remove unused code
129 handling CLOCK_PROCESS_CPUTIME_ID and CLOCK_THREAD_CPUTIME_ID.
130 * sysdeps/pthread/timer_routines.c (__timer_signal_thread_pclk,
131 __timer_signal_thread_tclk): Remove.
132 (init_module): Remove their initialization.
133 (thread_cleanup): Remove their cleanup assertions.
134 * sysdeps/pthread/posix-timer.h (__timer_signal_thread_pclk,
135 __timer_signal_thread_tclk): Remove.
136 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Removed.
137 * sysdeps/unix/sysv/linux/ia64/bits/posix_opt.h: Removed.
138 * sysdeps/unix/sysv/linux/x86_64/bits/posix_opt.h: Removed.
139 * tst-clock1.c (do_test): Check for availability of CPU clock.
141 2004-11-18 Daniel Jacobowitz <dan@codesourcery.com>
143 * sysdeps/unix/sysv/linux/arm/sysdep-cancel.h: Update RETINSTR use.
144 * sysdeps/unix/sysv/linux/arm/vfork.S: Likewise.
146 2004-12-02 Roland McGrath <roland@redhat.com>
148 * Makefile (libpthread-nonshared): Variable removed.
149 ($(objpfx)libpthread_nonshared.a): Target removed.
150 ($(inst_libdir)/libpthread_nonshared.a): Likewise.
151 These are now handled by generic magic from
152 libpthread-static-only-routines being set.
154 2004-11-27 Ulrich Drepper <drepper@redhat.com>
156 * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_PRIORITIZED_IO,
157 _POSIX2_CHAR_TERM, _POSIX_THREAD_PRIO_INHERIT,
158 _POSIX_THREAD_PRIO_PROTECT): Define.
159 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
160 * sysdeps/unix/sysv/linux/ia64/bits/posix_opt.h: Likewise.
161 * sysdeps/unix/sysv/linux/x86_64/bits/posix_opt.h: Likewise.
163 2004-11-26 Jakub Jelinek <jakub@redhat.com>
165 * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_ADVISORY_INFO,
166 _POSIX_SPORADIC_SERVER, _POSIX_THREAD_SPORADIC_SERVER, _POSIX_TRACE,
167 _POSIX_TRACE_EVENT_FILTER, _POSIX_TRACE_INHERIT, _POSIX_TRACE_LOG,
168 _POSIX_TYPED_MEMORY_OBJECTS): Define.
169 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
170 * sysdeps/unix/sysv/linux/ia64/bits/posix_opt.h: Likewise.
171 * sysdeps/unix/sysv/linux/x86_64/bits/posix_opt.h: Likewise.
173 2004-11-05 Maciej W. Rozycki <macro@mips.com>
175 * sysdeps/mips/pspinlock.c: Include <sgidefs.h>. Use _ABIO32,
176 _ABIN32 and _ABI64 for ABI selection throughout.
177 * sysdeps/mips/pt-machine.h: Use _ABIO32, _ABIN32 and _ABI64 for
178 ABI selection throughout.
180 2004-10-18 Roland McGrath <roland@redhat.com>
183 * Makefile (linuxthreads-CPPFLAGS): New variable;
184 adds -DIS_IN_linuxthreads=1.
185 * sysdeps/i386/tls.h: Protect "useldt.h" with
186 [!IS_IN_linuxthreads && !DO_MODIFY_LDT].
187 * sysdeps/i386/i686/pt-machine.h: Revert last change.
189 2004-10-14 Jakub Jelinek <jakub@redhat.com>
191 * sysdeps/pthread/errno-loc.c: Don't undef #errno
192 if RTLD_PRIVATE_ERRNO.
194 2004-10-05 Dwayne Grant McConnell <dgm69@us.ibm.com>
196 * pthread.c: Mask restart signal during cancel signal handler.
198 2004-10-05 Jakub Jelinek <jakub@redhat.com>
200 * sysdeps/unix/sysv/linux/x86_64/bits/posix_opt.h (_POSIX_CPUTIME,
201 _POSIX_THREAD_CPUTIME): Define to 0.
203 2004-10-04 Ulrich Drepper <drepper@redhat.com>
205 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Set _POSIX_CPUTIME
206 and _POSIX_THREAD_CPUTIME to zero.
207 * sysdeps/unix/sysv/linux/ia64/bits/posix_opt.h: Likewise.
209 * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define
210 _POSIX_THREAD_PROCESS_SHARED and _POSIX_CLOCK_SELECTION as -1.
211 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
212 * sysdeps/unix/sysv/linux/ia64/bits/posix_opt.h: Likewise.
213 * sysdeps/unix/sysv/linux/x86_64/bits/posix_opt.h: Likewise.
215 2004-09-25 Roland McGrath <roland@redhat.com>
218 * sysdeps/i386/i686/pt-machine.h: Don't #include "../useldt.h" if
219 [_TLS_H], since sysdeps/i386/tls.h includes it after including us.
221 2004-09-24 Roland McGrath <roland@redhat.com>
224 * sysdeps/i386/tls.h: Move #include "useldt.h" outside
225 of [__ASSUME_LDT_WORKS > 0] test.
226 Reported by Carlos Velasco <carlos.velasco@newipnet.com>.
228 2004-09-21 Roland McGrath <roland@redhat.com>
230 * Versions: Add comment about linuxthreads' frozen ABI.
232 2004-09-20 Ulrich Drepper <drepper@redhat.com>
234 * Versions: Remove exports for pthread_set*id_np functions.
235 * sysdeps/pthread/pthread.h: Remove pthread_set*id_np prototypes
237 * Makefile: Don't build pthread_set*id code for now.
239 2004-09-19 Ulrich Drepper <drepper@redhat.com>
241 * sysdeps/pthread/pthread.h: Declare pthread_setgid_np,
242 pthread_setuid_np, pthread_setegid_np, pthread_seteuid_np,
243 pthread_setregid_np, pthread_setreuid_np, pthread_setresgid_np,
244 and pthread_setresuid_np.
245 * pthread_setgid_np.c: New file.
246 * pthread_setuid_np.c: New file.
247 * pthread_setegid_np.c: New file.
248 * pthread_seteuid_np.c: New file.
249 * pthread_setregid_np.c: New file.
250 * pthread_setreuid_np.c: New file.
251 * pthread_setresgid_np.c: New file.
252 * pthread_setresuid_np.c: New file.
253 * Versions [libpthread, GLIBC_2.3.4]: Add pthread_setgid_np,
254 pthread_setuid_np, pthread_setegid_np, pthread_seteuid_np,
255 pthread_setregid_np, pthread_setreuid_np, pthread_setresgid_np,
256 and pthread_setresuid_np.
257 * Makefile (libpthread-routines): Add pthread_setuid, pthread_seteuid,
258 pthread_setreuid, pthread_setresuid, pthread_setgid, pthread_setegid,
259 pthread_setregid, and pthread_setresgid.
261 2004-09-12 Ulrich Drepper <drepper@redhat.com>
263 * sysdeps/pthread/pthread.h: Make rwlock prototypes available also
265 * sysdeps/pthread/bits/pthreadtypes.h: Define rwlock types also
266 for __USE_XOPEN2K. [BZ #320]
268 2004-09-04 Jakub Jelinek <jakub@redhat.com>
270 * tst-cancel4.c (tf_waitid): Use WEXITED flag bit if available.
272 2004-09-07 Ulrich Drepper <drepper@redhat.com>
274 * sysdeps/pthread/pthread.h (pthread_once): Remove __THROW since
275 the initialization function might throw.
277 2004-08-30 Roland McGrath <roland@frob.com>
279 * Makefile (libpthread-abi-frozen): New variable.
281 2004-08-26 Roland McGrath <roland@redhat.com>
283 * configure.in: New file. If nptl add-on is also selected, barf if
284 explicit and elide ourselves if implicit.
285 * configure: Now generated.
287 2004-08-25 Richard Sandiford <rsandifo@redhat.com>
289 * sysdeps/unix/sysv/linux/mips/sysdep-cancel.h (CENABLE, CDISABLE,
290 __local_multiple_threads): Fix definitions for IS_IN_librt.
291 * sysdeps/unix/sysv/linux/mips/mips64/sysdep-cancel.h: Likewise.
293 2004-08-22 Andreas Schwab <schwab@suse.de>
295 * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h (PSEUDO) [IS_IN_librt]:
296 Save gp around CENABLE/CDISABLE calls.
298 2004-08-15 Roland McGrath <roland@frob.com>
300 * pthread_atfork.c: Update copyright terms including special exception
301 for these trivial files, which are statically linked into executables
302 that use dynamic linking for the significant library code.
304 2004-08-09 Jakub Jelinek <jakub@redhat.com>
306 * libc-tsd.c: Move resolv.h include before the #if.
307 (__res_maybe_init): New function. Add libc_hidden_def.
309 2004-08-02 Ulrich Drepper <drepper@redhat.com>
311 * linuxthreads.texi (Cleanup Handlers): Fix typo.
312 Reported by Bjoern Engelmann <bjengelmann@gmx.de>.
314 2004-07-23 Jakub Jelinek <jakub@redhat.com>
317 * sysdeps/pthread/pthread.h (pthread_getcpuclockid): Use __clockid_t
318 instead of clockid_t.
320 2004-07-21 Roland McGrath <roland@redhat.com>
322 * Makefile ($(objpfx)multidir.mk): Use $(make-target-directory).
324 2004-07-02 Roland McGrath <roland@redhat.com>
326 * configure: Don't exit.
328 2004-07-20 Alexandre Oliva <aoliva@redhat.com>
330 * sysdeps/mips/pt-machine.h: Use standard names for ABI macros,
332 * sysdeps/mips/atomicity.h: Likewise.
334 2004-07-19 Alexandre Oliva <aoliva@redhat.com>
336 * sysdeps/unix/sysv/linux/mips/Makefile (CFLAGS-pt-initfini.s):
337 Remove redundant override that missed -g0.
339 2004-07-14 Kaz Kojima <kkojima@rr.iij4u.or.jp>
341 * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h
342 (__local_multiple_threads): Define for librt.
343 (SINGLE_THREAD_P): Likewise.
345 2004-07-07 Jakub Jelinek <jakub@redhat.com>
347 * sysdeps/pthread/getcpuclockid.c (pthread_getcpuclockid): Allow
348 using other thread's clock.
349 * ptclock_gettime.c (__pthread_clock_gettime): Likewise.
350 * ptclock_settime.c (__pthread_clock_settime): Likewise.
351 * internals.h (__pthread_clock_gettime, __pthread_clock_settime):
353 Reported by Bernd Schmidt <bernds@redhat.com>.
354 * Makefile (librt-tests): Add tst-clock1.
355 * tst-clock1.c: New test.
357 * sysdeps/x86_64/Versions: New file.
358 * sysdeps/unix/sysv/linux/ia64/bits/posix_opt.h: New file.
359 * sysdeps/unix/sysv/linux/x86_64/bits/posix_opt.h: New file.
361 2004-04-16 Andreas Schwab <schwab@suse.de>
363 * sysdeps/ia64/tls.h (INIT_SYSINFO): Cast dl_sysinfo to void*.
365 2004-07-05 Jakub Jelinek <jakub@redhat.com>
367 * sysdeps/s390/pspinlock.c (__pthread_spin_lock,
368 __pthread_spin_trylock): Use constraint "m" instead of "0" for
370 * sysdeps/ia64/pt-machine.h (__compare_and_swap,
371 __compare_and_swap_with_release_semantic, testandset): Use
372 constraint "m" instead of "0" for futex.
374 2004-06-29 Kaz Kojima <kkojima@rr.iij4u.or.jp>
376 * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h (CENABLE): Fix
377 branch offset for a PLT entry.
378 (CDISABLE): Likewise.
380 2004-05-31 Andreas Jaeger <aj@suse.de>
382 * sysdeps/unix/sysv/linux/mips/Makefile (CFLAGS-pt-initfini.s):
383 Set to -fno-unit-at-a-time.
384 Patch by Dan Kegel <dank@kegel.com>.
386 2004-05-04 Jakub Jelinek <jakub@redhat.com>
388 * tst-stack1.c: Don't include mcheck.h.
389 (do_test): Make sure user defined stacks aren't reused,
390 don't free them at the end. [BZ #110]
392 2004-05-02 Jakub Jelinek <jakub@redhat.com>
394 * manager.c: Include not-cancel.h.
395 (__pthread_manager): Use read_not_cancel instead of __libc_read.
396 (pthread_start_thread, __pthread_manager_sighandler): Use
397 write_not_cancel instead of __libc_write.
398 (pthread_reap_children): Use waitpid_not_cancel instead of
400 * pthread.c: Include not-cancel.h.
401 (__pthread_initialize_minimal, __pthread_create_2_1,
402 pthread_onexit_process, __pthread_message): Use
403 write_not_cancel instead of __libc_write.
404 (__pthread_initialize_manager): Likewise. Use close_not_cancel
405 instead of __libc_close.
406 (__pthread_reset_main_thread): Use close_not_cancel instead of
408 * join.c: Include not-cancel.h.
409 (__pthread_do_exit, pthread_join, pthread_detach): Use
410 write_not_cancel instead of __libc_write.
411 * semaphore.c: Include not-cancel.h.
412 (__new_sem_post): Use write_not_cancel instead of __libc_write.
413 * specific.c: Include not-cancel.h.
414 (pthread_key_delete): Use write_not_cancel instead of __libc_write.
416 2004-05-01 Jakub Jelinek <jakub@redhat.com>
418 * Versions (libc): Add __on_exit and __libc_sigaction.
420 2004-04-28 Jakub Jelinek <jakub@redhat.com>
422 * semaphore.c (sem_timedwait): Return -1 and set errno instead of
423 returning error number [BZ #133]. Patch by <rmhaddad@yahoo.com>.
425 2004-04-22 SUGIOKA Toshinobu <sugioka@itonet.co.jp>
427 * sysdeps/unix/sysv/linux/sh/vfork.S: Fix wrong function pointer
428 reference in PIC case.
430 2004-04-20 Jakub Jelinek <jakub@redhat.com>
432 * oldsemaphore.c (SEM_VALUE_MAX): Remove.
434 2004-04-19 Kaz Kojima <kkojima@rr.iij4u.or.jp>
436 * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h (CENABLE): Define
437 for librt. Save the return value to a safe register.
438 (CDISABLE): Define for librt. Set the function argument correctly.
440 2004-04-18 Jakub Jelinek <jakub@redhat.com>
442 * sysdeps/unix/sysv/linux/s390/s390-32/sysdep-cancel.h
443 (PSEUDO_CANCEL): Define.
445 * sysdeps/unix/sysv/linux/s390/s390-64/sysdep-cancel.h (CENABLE,
446 CDISABLE): For librt, append @PLT.
448 2004-04-17 Jakub Jelinek <jakub@redhat.com>
450 * sysdeps/x86_64/tls.h [!__ASSEMBLER__]: Include tcb-offsets.h.
452 * sysdeps/pthread/timer_gettime.c (timer_gettime): For expired timer
453 return it_value { 0, 0 }.
454 * sysdeps/pthread/timer_create.c (timer_create): Handle SIGEV_NONE
456 * sysdeps/pthread/timer_routines.c (thread_expire_timer): Remove
457 assertion for SIGEV_NONE.
458 (thread_attr_compare): Compare all attributes, not just a partial
461 * sysdeps/unix/sysv/linux/mq_notify.c: Include stdlib.h.
463 2004-04-17 Ulrich Drepper <drepper@redhat.com>
465 * semaphore.h (SEM_VALUE_MAX): Just use a plain number.
467 2004-04-16 Ulrich Drepper <drepper@redhat.com>
469 * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h: Fix last patch.
471 2004-04-13 Jakub Jelinek <jakub@redhat.com>
473 * sysdeps/unix/sysv/linux/mq_notify.c: Shut up GCC warning.
475 2004-04-12 Ulrich Drepper <drepper@redhat.com>
477 * sysdeps/unix/sysv/linux/mq_notify.c: New file.
479 * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h (CENABLE): Define
481 (CDISABLE): Likewise.
483 2004-04-08 Jakub Jelinek <jakub@redhat.com>
485 * sysdeps/unix/sysv/linux/bits/local_lim.h (MQ_PRIO_MAX): Define.
486 * sysdeps/unix/sysv/linux/alpha/bits/local_lim.h (MQ_PRIO_MAX): Define.
487 * sysdeps/unix/sysv/linux/ia64/bits/local_lim.h (MQ_PRIO_MAX): Define.
488 * sysdeps/unix/sysv/linux/sparc/bits/local_lim.h (MQ_PRIO_MAX): Define.
489 * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_MESSAGE_PASSING):
491 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h
492 (_POSIX_MESSAGE_PASSING): Define.
494 2004-04-10 Andreas Jaeger <aj@suse.de>
496 * sysdeps/x86_64/pt-machine.h: Add used attribute to stack_pointer
497 to avoid warnings with GCC 3.5.
499 2004-04-09 Steven Munroe <sjmunroe@us.ibm.com>
501 * sysdeps/powerpc/tls.h (TLS_INIT_TP): Eliminate lvalue cast from
502 __thread_self assignment.
503 (THREAD_DTV): Replace __thread_register with __thread_self.
504 (INIT_THREAD_SELF): Eliminate lvalue cast from __thread_self
507 2004-04-08 Alexandre Oliva <aoliva@redhat.com>
509 * signals.c (pthread_sigmask): Don't ever block or mask
512 2004-03-11 Steven Munroe <sjmunroe@us.ibm.com>
514 * sysdeps/powerpc/tls.h: Remove __powerpc64__ conditional.
516 2004-03-23 Ulrich Drepper <drepper@redhat.com>
518 * sysdeps/ia64/pt-machine.h (BUSY_WAIT_NOP): Define.
519 * sysdeps/x86_64/pt-machine.h (BUSY_WAIT_NOP): Likewise.
521 2004-03-12 Ulrich Drepper <drepper@redhat.com>
523 * sysdeps/unix/sysv/linux/bits/local_lim.h: Add HOST_NAME_MAX.
524 * sysdeps/unix/sysv/linux/alpha/bits/local_lim.h: Likewise.
525 * sysdeps/unix/sysv/linux/ia64/bits/local_lim.h: Likewise.
526 * sysdeps/unix/sysv/linux/sparc/bits/local_lim.h: Likewise.
528 2004-03-08 Andreas Jaeger <aj@suse.de>
530 * sysdeps/i386/tls.h (TLS_DO_MODIFY_LDT_KERNEL_CHECK):
531 dl_osversion is readonly.
533 2004-03-07 Ulrich Drepper <drepper@redhat.com>
535 * sysdeps/i386/tls.h (INIT_SYSINFO): _dl_sysinfo is now in
537 * sysdeps/ia64/tls.h (INIT_SYSINFO): Likewise.
539 2004-02-20 Steven Munroe <sjmunroe@us.ibm.com>
541 * sysdeps/unix/sysv/linux/powerpc/ptlongjmp.c [SHARED]: Code only
542 valid for SHARED case. Correct spelling of __vmx_longjmp.
544 * sysdeps/powerpc/pspinlock.c: Move from here.
545 * sysdeps/powerpc/powerpc32/pspinlock.c: To here.
546 * sysdeps/powerpc/powerpc64/pspinlock.c: New file.
547 * sysdeps/powerpc/powerpc64/pt-machine.h: Define __compare_and_swap32
548 and __compare_and_swap32_with_release_semantics.
550 2004-02-20 Jakub Jelinek <jakub@redhat.com>
552 * Makefile (generated): Remove tst-stack1.mtrace and tst-stack1-mem.
553 (tests): Remove $(objpfx)tst-stack1-mem.
554 (tst-stack1-ENV): Remove.
555 ($(objpfx)tst-stack1-mem): Remove.
557 * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h
558 (__syscall_error_handler2): Call CDISABLE.
559 * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h
560 (__syscall_error_handler2): Call CDISABLE.
562 * sysdeps/unix/sysv/linux/ia64/dl-sysdep.h (DL_ARGV_NOT_RELRO): Define.
564 2004-02-10 Steven Munroe <sjmunroe@us.ibm.com>
566 * Makefile (libpthread-routines): Add ptcleanup.
567 * ptlongjmp.c: Removed.
568 * ptcleanup.c: Copied __pthread_cleanup_upto to here. New file.
569 * sysdeps/pthread/ptlongjmp.c: Copied longjmp to here. New file.
570 * sysdeps/unix/sysv/linux/powerpc/Versions: New file.
571 Version longjmp, siglongjmp for GLIBC_2.3.4.
572 * sysdeps/unix/sysv/linux/powerpc/ptlongjmp.c: New File.
574 2004-01-22 Andreas Jaeger <aj@suse.de>
576 * spinlock.c (__pthread_lock): Fix contraint to avoid warning.
577 (__pthread_release): Likewise.
579 2004-01-16 Richard Henderson <rth@redhat.com>
581 * attr.c: Include ldsodefs.h.
582 (pthread_getattr_np): Don't declare __libc_stack_end.
584 2004-01-09 Steven Munroe <sjmunroe@us.ibm.com>
586 * sysdeps/unix/sysv/linux/powerpc/powerpc32/sysdep-cancel.h
587 [!HAVE_TLS_SUPPORT]: Define SINGLE_THREAD_P using static
588 __lib*_multiple_threads.
589 * sysdeps/unix/sysv/linux/powerpc/powerpc64/sysdep-cancel.h
590 [!HAVE_TLS_SUPPORT]: Likewise.
592 2004-01-13 Roland McGrath <roland@redhat.com>
594 * sysdeps/powerpc/tcb-offsets.sym: Put -- separator line before any
597 2004-01-10 Andreas Jaeger <aj@suse.de>
599 * sysdeps/unix/sysv/linux/x86_64/vfork.S: Add cfi directives.
601 2004-01-01 Andreas Jaeger <aj@suse.de>
603 * Makefile (generated): Add missing files.
605 2003-12-31 Ulrich Drepper <drepper@redhat.com>
607 * attr.c (pthread_getattr_np): Make sure stack info returned for
608 main thread does not overlap with any other VMA.
609 Patch by Jakub Jelinek.
611 2003-12-29 Jakub Jelinek <jakub@redhat.com>
613 * sysdeps/ia64/tls.h: Include dl-sysdep.h.
614 (INIT_SYSINFO): Define.
615 (TLS_INIT_TP): Use it.
617 2003-12-28 Carlos O'Donell <carlos@baldric.uwo.ca>
619 * attr.c (pthread_getattr_np): Add _STACK_GROWS_UP case.
621 2003-12-26 Jakub Jelinek <jakub@redhat.com>
623 * sysdeps/pthread/pthread.h (pthread_setcancelstate,
624 pthread_setcanceltype, pthread_cancel, pthread_testcancel): Remove
626 * semaphore.h (sem_wait, sem_timedwait): Likewise.
628 2003-12-17 Jakub Jelinek <jakub@redhat.com>
630 * manager.c (pthread_free): Call _dl_deallocate_tls even for
632 * pthread.c (__pthread_initialize_manager): Call _dl_deallocate_tls
634 (pthread_onexit_process): Update comment.
635 * Makefile (tests): Add tst-stack1. Depend on $(objpfx)tst-stack1-mem.
636 (generated): Add tst-stack1.mtrace and tst-stack1-mem.
637 (tst-stack1-ENV): Set.
638 ($(objpfx)tst-stack1-mem): New.
639 * tst-stack1.c: New test.
641 2003-12-16 Steven Munroe <sjmunroe@us.ibm.com>
643 * sysdeps/powerpc/tcb-offsets.sym [!__powerpc64__]: Remove
644 conditional so MULTIPLE_THREADS_OFFSET is generated for both.
645 * sysdeps/powerpc/tls.h [!__powerpc64__]: Remove conditional
646 so TLS_MULTIPLE_THREADS_IN_TCB is generated for both.
647 * sysdeps/unix/sysv/linux/powerpc/powerpc64/sysdep-cancel.h:
650 2003-12-04 Steven Munroe <sjmunroe@us.ibm.com>
652 * sysdeps/unix/sysv/linux/powerpc/powerpc64/sysdep-cancel.h
653 (SINGLE_THREAD_P): Test using thread local p_multiple_threads field.
655 2003-12-10 David Mosberger <davidm@hpl.hp.com>
657 * sysdeps/unix/sysv/linux/ia64/pt-initfini.c: Update copyright
658 message. Add include of <stddef.h>.
659 (INIT_NEW_WAY): New macro.
660 (INIT_OLD_WAY): Likewise.
661 (_init): Add unwind directives. Invoke
662 __pthread_initialize_minimal() via INIT_NEW_WAY or INIT_OLD_WAY,
664 (_init_EPILOG_BEGINS): Add unwind-directives. Drop unused .regstk
666 (_fini): Add unwind directives. Drop unnecessary .align 16
667 directive (bundles are always 16-byte aligned).
668 (_fini_EPILOG_BEGINS): Add unwind-directives.
670 2003-11-19 David Mosberger <davidm@hpl.hp.com>
672 * sysdeps/unix/sysv/linux/ia64/dl-sysdep.h: New file.
674 2003-12-10 Andreas Jaeger <aj@suse.de>
675 Ruediger Oertel <ro@suse.de>
677 * sysdeps/alpha/elf/pt-initfini.c (__asm__): Remove extra .prologue.
679 2003-11-30 Andreas Jaeger <aj@suse.de>
681 * Makefile (CFLAGS-pt-initfini.s): Add $(fno_unit_at_a_time).
682 * sysdeps/unix/sysv/linux/x86_64/Makefile (CFLAGS-pt-initfini.s):
685 2003-11-04 Jakub Jelinek <jakub@redhat.com>
687 * signals.c (__pthread_sigaction): Set __sighandler[sig].old before
688 __libc_sigaction if it has been one of the special values before.
690 2003-10-06 Carlos O'Donell <carlos@baldric.uwo.ca>
692 * pthread.c (__pthread_self_stack): _STACK_GROWS_UP case added.
693 (__pthread_find_self): Likewise.
694 * manager.c (thread_segment): _STACK_GROWS_UP case added.
696 2003-10-10 Carlos O'Donell <carlos@baldric.uwo.ca>
698 * linuxthreads/sysdeps/unix/sysv/linux/hppa/malloc-machine.h: New file.
700 2003-10-10 Carlos O'Donell <carlos@baldric.uwo.ca>
702 * sysdeps/unix/sysv/linux/hppa/sysdep-cancel.h: New file.
704 2003-10-07 Jakub Jelinek <jakub@redhat.com>
706 * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h: Backout 2003-10-02
708 (SAVE_OLDTYPE_0): Fix a typo.
710 2003-10-02 Ulrich Drepper <drepper@redhat.com>
712 * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h (DOCARGS_1): Use
715 2003-10-02 Jakub Jelinek <jakub@redhat.com>
717 * Makefile (tests): Add tst-cancel8.
718 * tst-cancel8.c: New test.
720 2003-10-02 Ulrich Drepper <drepper@redhat.com>
722 * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h: Fix saving and
723 restoring of the old cancellation type.
725 2003-09-10 Chris Demetriou <cgd@broadcom.com>
727 * sysdeps/unix/sysv/linux/mips/mips64/sysdep-cancel.h: New file.
729 2003-09-30 Jakub Jelinek <jakub@redhat.com>
731 * sysdeps/pthread/malloc-machine.h [!__libc_maybe_call2] (mutex_init,
732 mutex_lock, mutex_trylock, mutex_unlock): Remove.
734 2003-09-27 Wolfram Gloger <wg@malloc.de>
736 * sysdeps/pthread/malloc-machine.h: New file.
738 2003-09-18 H.J. Lu <hongjiu.lu@intel.com>
740 * attr.c (__pthread_attr_init_2_1): Double __guardsize size
741 if NEED_SEPARATE_REGISTER_STACK is defined.
743 2003-09-22 Philip Blundell <philb@gnu.org>
745 * forward.c: Add _pthread_cleanup_push, _pthread_cleanup_pop.
746 * sysdeps/pthread/pthread-functions.h (struct pthread_functions):
748 * pthread.c (__pthread_elements): Initialise these new elements.
749 * sysdeps/pthread/bits/libc-lock.h (__libc_cleanup_push): Use
751 (__libc_cleanup_pop): Likewise.
753 2003-09-22 Jakub Jelinek <jakub@redhat.com>
755 * attr.c: Include stdlib.h.
757 2003-09-18 Jakub Jelinek <jakub@redhat.com>
759 * sysdeps/pthread/pthread.h (pthread_getattr_np): Clarify usage.
761 * tst-attr1.c: New test.
762 * Makefile (tests): Add tst-attr1.
764 2003-09-17 Philip Blundell <philb@gnu.org>
766 * sysdeps/unix/sysv/linux/arm/vfork.S: Branch to fork if
767 libpthread is loaded. Elide backwards compatibility code when not
770 2003-09-17 Jakub Jelinek <jakub@redhat.com>
772 * descr.h (manager_thread): Rename to...
773 (__pthread_manager_threadp): ... this.
774 * pthread.c (manager_thread): Define to __pthread_manager_threadp.
775 (__pthread_manager_threadp): New variable.
776 * internals.h (__manager_thread): Define to
777 __pthread_manager_threadp if USE_TLS.
779 2003-09-15 Jakub Jelinek <jakub@redhat.com>
781 * sysdeps/i386/Makefile (CFLAGS-cancel.c, CFLAGS-manager.c,
782 CFLAGS-pthread.c, CFLAGS-sighandler.c): Add
783 -mpreferred-stack-boundary=4.
785 2003-09-16 Ulrich Drepper <drepper@redhat.com>
787 * attr.c (pthread_getattr_np): Correctly fill in the stack-related
788 values for the initial thread.
790 2003-09-17 Jakub Jelinek <jakub@redhat.com>
792 * pthread.c (manager_thread): Remove static, add attribute_hidden.
793 (thread_self_stack): Rename to...
794 (__pthread_self_stack): ... this. Remove static.
795 (pthread_handle_sigcancel): Use check_thread_self ().
796 (pthread_handle_sigrestart): Likewise.
797 * sighandler.c (__pthread_sighandler, __pthread_sighandler_rt):
799 * descr.h (manager_thread): Declare.
800 * internals.h (__pthread_self_stack): New prototype.
801 (__manager_thread): Define.
802 (check_thread_self): New function.
804 2003-09-15 Jakub Jelinek <jakub@redhat.com>
806 * Makefile (CFLAGS-mutex.c): Add $(uses-callbacks).
807 (CFLAGS-sighandler.c): Change $(exceptions) into $(uses-callbacks).
809 2003-09-12 Jakub Jelinek <jakub@redhat.com>
811 * sysdeps/unix/sysv/linux/s390/bits/typesizes.h: New.
812 (__SSIZE_T_TYPE): Define to __SWORD_TYPE for gcc 2.95.x and
813 __SLONGWORD_TYPE otherwise.
815 2003-09-11 Steven Munroe <sjmunroe@us.ibm.com>
817 * sysdeps/powerpc/powerpc64/pt-machine.h [MEMORY_BARRIER]: Use lwsync.
818 [READ_MEMORY_BARRIER]: Define.
819 [WRITE_MEMORY_BARRIER]: Define.
821 2003-09-10 Jakub Jelinek <jakub@redhat.com>
823 * sysdeps/pthread/pthread-functions.h (struct pthread_functions): Move
824 ptr___pthread_cond_timedwait to the end of the structure to avoid
825 breaking Wine unnecessarily.
827 2003-09-08 Jakub Jelinek <jakub@redhat.com>
829 * sysdeps/unix/sysv/linux/s390/bits/typesizes.h: Remove.
831 2003-09-02 Jakub Jelinek <jakub@redhat.com>
833 * sysdeps/unix/sysv/linux/alpha/bits/local_lim.h: New file.
834 * sysdeps/unix/sysv/linux/alpha/Versions: New file.
835 * sysdeps/unix/sysv/linux/ia64/bits/local_lim.h: New file.
836 * sysdeps/unix/sysv/linux/ia64/Versions: New file.
837 * sysdeps/unix/sysv/linux/sparc/bits/local_lim.h: New file.
838 * sysdeps/unix/sysv/linux/sparc/Versions: New file.
839 * attr.c (__old_pthread_attr_setstacksize,
840 __old_pthread_attr_setstack): New functions.
841 (pthread_attr_setstacksize): If PTHREAD_STACK_MIN != 16384, export
842 as @@GLIBC_2.3.2 and also export compatibility @GLIBC_2.1.
843 (pthread_attr_setstack): If PTHREAD_STACK_MIN != 16384, export
844 as @@GLIBC_2.3.2 and also export compatibility @GLIBC_2.2.
845 * tststack.c: Include limits.h and sys/param.h.
846 (main): Set size to MAX (70 * 1024, PTHREAD_STACK_MIN).
848 * barrier.c (__pthread_barrierattr_getpshared): Always
849 return PTHREAD_PROCESS_PRIVATE.
850 (pthread_barrierattr_setpshared): Return EINVAL if pshared
851 is neither PTHREAD_PROCESS_PRIVATE nor PTHREAD_PROCESS_SHARED.
853 2003-09-02 Ulrich Drepper <drepper@redhat.com>
855 * sysdeps/unix/sysv/linux/i386/dl-sysdep.h
856 (DL_SYSINFO_IMPLEMENTATION): Add CFI and make sure the code ends
859 * barrier.c (pthread_barrierattr_setpshared): We don't handle
860 inter-process barriers.
862 2003-09-01 Jakub Jelinek <jakub@redhat.com>
864 * Makefile (tests): Add tst-tls1.
865 (module-names): Add tst-tls1mod{,a,b,c,d,e,f}.
866 ($(objpfx)tst-tls1mod{,a,b,c,d,e,f}.so-no-z-defs): Set to yes.
867 ($(objpfx)tst-tls1): New.
868 ($(objpfx)tst-tls2.out): Likewise.
869 (tests): Depend on $(objpfx)tst-tls2.out.
870 * tst-tls1.c: New test.
872 * tst-tls1mod.c: New.
873 * tst-tls1moda.c: New.
874 * tst-tls1modb.c: New.
875 * tst-tls1modc.c: New.
876 * tst-tls1modd.c: New.
877 * tst-tls1mode.c: New.
878 * tst-tls1modf.c: New.
879 * tst-tls2.sh: New test.
881 * internals.h (__pthread_cond_timedwait): New prototype.
882 * sysdeps/pthread/pthread-functions.h (struct pthread_functions): Add
883 ptr___pthread_cond_timedwait.
884 * pthread.c (__pthread_functions): Initialize them.
885 * forward.c (pthread_cond_timedwait@GLIBC_2.0,
886 pthread_cond_timedwait@@GLIBC_2.3.2): New forwards.
887 * Versions (libc): Export pthread_cond_timedwait@GLIBC_2.0,
888 pthread_cond_timedwait@@GLIBC_2.3.2.
890 2003-08-27 Ulrich Drepper <drepper@redhat.com>
892 * sysdeps/pthread/pthread.h: Don't mark pthread_exit,
893 pthread_join, pthread_cond_wait, and pthread_cond_timedwait with
894 __THROW to match NPTL.
896 2003-08-13 Ulrich Drepper <drepper@redhat.com>
898 * sysdeps/pthread/Makefile [subdir=rt] (CPPFLAGS): Add
899 -DBROKEN_THREAD_SIGNALS.
901 2003-08-11 Steven Munroe <sjmunroe@us.ibm.com>
903 * manager.c (pthread_start_thread) [!(USE_TLS && HAVE___THREAD)]:
904 Correct spelling of per thread resolver state.
906 2003-08-07 Jakub Jelinek <jakub@redhat.com>
908 * sysdeps/pthread/bits/libc-lock.h [_LIBC && SHARED]
909 (__rtld_lock_default_lock_recursive,
910 __rtld_lock_default_unlock_recursive): Define.
911 [_LIBC && SHARED] (__rtld_lock_lock_recursive,
912 __rtld_lock_unlock_recursive): Define using
913 GL(_dl_rtld_*lock_recursive).
914 * pthread.c (pthread_initialize): Initialize _dl_rtld_lock_recursive
915 and _dl_rtld_unlock_recursive. Lock GL(_dl_load_lock) the same
916 number of times as GL(_dl_load_lock) using non-mt implementation was
919 2003-07-31 Jakub Jelinek <jakub@redhat.com>
921 * sysdeps/pthread/bits/typesizes.h (__SSIZE_T_TYPE): Define.
922 * sysdeps/unix/sysv/linux/alpha/bits/typesizes.h (__SSIZE_T_TYPE):
924 * sysdeps/unix/sysv/linux/sparc/bits/typesizes.h (__SSIZE_T_TYPE):
926 * sysdeps/unix/sysv/linux/s390/bits/typesizes.h: New file.
928 * sysdeps/pthread/pthread.h (pthread_attr_setstackaddr,
929 pthread_attr_setstacksize): Change PTHREAD_STACK_SIZE to
930 PTHREAD_STACK_MIN in comments.
932 * sysdeps/alpha/pt-machine.h (PT_EI): Add
933 __attribute__((always_inline)).
934 * sysdeps/arm/pt-machine.h (PT_EI): Likewise.
935 * sysdeps/cris/pt-machine.h (PT_EI): Likewise.
936 * sysdeps/hppa/pt-machine.h (PT_EI): Likewise.
937 * sysdeps/i386/i686/pt-machine.h (PT_EI): Likewise.
938 * sysdeps/i386/pt-machine.h (PT_EI): Likewise.
939 * sysdeps/ia64/pt-machine.h (PT_EI): Likewise.
940 * sysdeps/m68k/pt-machine.h (PT_EI): Likewise.
941 * sysdeps/mips/pt-machine.h (PT_EI): Likewise.
942 * sysdeps/powerpc/powerpc32/pt-machine.h (PT_EI): Likewise.
943 * sysdeps/powerpc/powerpc64/pt-machine.h (PT_EI): Likewise.
944 * sysdeps/s390/s390-32/pt-machine.h (PT_EI): Likewise.
945 * sysdeps/s390/s390-64/pt-machine.h (PT_EI): Likewise.
946 * sysdeps/sh/pt-machine.h (PT_EI): Likewise.
947 * sysdeps/sparc/sparc32/pt-machine.h (PT_EI): Likewise.
948 * sysdeps/sparc/sparc64/pt-machine.h (PT_EI): Likewise.
949 * sysdeps/x86_64/pt-machine.h (PT_EI): Likewise.
950 * spinlock.h (__pthread_set_own_extricate_if): Likewise.
951 * sysdeps/ia64/tls.h (TLS_INIT_TP): Cast tcbp to __typeof
953 * Examples/ex13.c (main): Change res type to void * to avoid
955 * tst-cancel.c (cleanup, inner, tf1, tf2, tf3): Comment out.
957 2003-07-30 Jakub Jelinek <jakub@redhat.com>
959 * pthread.c (init_one_static_tls, __pthread_init_static_tls): New
961 (pthread_initialize): Initialize GL(dl_init_static_tls).
963 2003-06-19 Daniel Jacobowitz <drow@mvista.com>
965 * sysdeps/pthread/timer_create.c (timer_create): Call timer_delref
966 before __timer_dealloc.
967 * sysdeps/pthread/timer_routines.c (__timer_thread_find_matching):
968 Don't call list_unlink.
970 2003-07-29 Roland McGrath <roland@redhat.com>
972 * Makefile [$(build-shared) = yes] (tests): Depend on $(test-modules).
974 2003-07-25 Roland McGrath <roland@redhat.com>
976 * manager.c (pthread_start_thread): Fix typo in last change.
978 2003-07-14 Guido Guenther <agx@sigxcpu.org>
980 * sysdeps/unix/sysv/linux/mips/sysdep-cancel.h: Add IS_IN_librt,
981 use L() for local labels.
983 2003-07-22 Jakub Jelinek <jakub@redhat.com>
985 * descr.h (struct _pthread_descr_struct): Provide p_res member
986 even if USE_TLS && HAVE___THREAD.
987 * sysdeps/pthread/res-state.c (__res_state): Return __resp
989 * manager.c: Include resolv.h.
990 (pthread_start_thread): Initialize __resp.
991 * libc-tls-loc.c (__res_state): Return __resp.
992 * Makefile (tests): Add tst-_res1.
993 (modules-names, extra-objs, test-extras, test-modules): Add support
995 ($(objpfx)tst-_res1mod2.so): Depend on $(objpfx)tst-_res1mod1.so.
996 ($(objpfx)tst-_res1): Depend on $(objpfx)tst-_res1mod2.so and
998 * tst-_res1.c: New test.
999 * tst-_res1mod1.c: New test.
1000 * tst-_res1mod2.c: New test.
1002 2003-07-20 Ulrich Drepper <drepper@redhat.com>
1004 * sysdeps/pthread/bits/libc-lock.h: Define __libc_cleanup_push and
1007 * tst-cancel-wrappers.sh: lseek and llseek are no cancellation points.
1009 2003-07-14 Ulrich Drepper <drepper@redhat.com>
1011 * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h: Fix typo
1012 in test for compilation in libc.
1014 2003-07-04 Jakub Jelinek <jakub@redhat.com>
1016 * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h (PSEUDO): Use
1017 different symbol for the cancellation syscall wrapper and
1018 non-cancellation syscall wrapper.
1019 (PSEUDO_END): Define.
1021 2003-07-05 Richard Henderson <rth@redhat.com>
1023 * sysdeps/alpha/elf/pt-initfini.c: Avoid .ent/.end.
1025 2003-06-20 Kaz Kojima <kkojima@rr.iij4u.or.jp>
1027 * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h: Support cancellation
1030 2003-06-21 Andreas Schwab <schwab@suse.de>
1032 * sysdeps/unix/sysv/linux/m68k/sysdep-cancel.h: Support cancellation
1035 2003-06-20 Richard Henderson <rth@redhat.com>
1037 * sysdeps/unix/sysv/linux/alpha/Makefile (libpthread-routines):
1038 Remove ptw-osf_sigprocmask.
1040 2003-06-18 Jakub Jelinek <jakub@redhat.com>
1042 * internals.h (__librt_multiple_threads, __librt_enable_asynccancel,
1043 __librt_disable_asynccancel): Declare.
1044 (LIBC_CANCEL_ASYNC, LIBC_CANCEL_RESET, LIBC_CANCEL_HANDLED): Define
1046 * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h: Support cancellation
1048 * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h: Likewise.
1049 * sysdeps/unix/sysv/linux/s390/s390-32/sysdep-cancel.h: Likewise.
1050 * sysdeps/unix/sysv/linux/s390/s390-64/sysdep-cancel.h: Likewise.
1051 * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h: Likewise.
1052 * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h: Likewise.
1053 * sysdeps/unix/sysv/linux/x86_64/sysdep-cancel.h: Likewise.
1054 * sysdeps/unix/sysv/linux/powerpc/powerpc32/sysdep-cancel.h: Likewise.
1055 * sysdeps/unix/sysv/linux/powerpc/powerpc64/sysdep-cancel.h: Likewise.
1056 * sysdeps/x86_64/tcb-offsets.sym: New file.
1057 * sysdeps/x86_64/Makefile: New file.
1058 * sysdeps/x86_64/tls.h (tcbhead_t): Add multiple_threads.
1059 * Versions (libc): Export __librt_enable_asynccancel,
1060 __librt_disable_asynccancel and __librt_multiple_threads as
1062 * libc-cancellation.c (__librt_multiple_threads,
1063 __librt_enable_asynccancel, __librt_disable_asynccancel): New aliases.
1065 2003-06-12 Steven Munroe <sjmunroe@us.ibm.com>
1067 * sysdeps/unix/sysv/linux/powerpc/powerpc64/sysdep-cancel.h
1068 (SINGLE_THREAD_P): Replace @ got notation with @toc.
1070 2003-06-11 Ulrich Drepper <drepper@redhat.com>
1072 * sysdeps/powerpc/pspinlock.c (__pthread_spin_init): Fix
1073 initializer [PR libc/5052].
1075 2003-06-09 Andreas Schwab <schwab@suse.de>
1077 * Makefile: Move inclusion of ../Rules down after extra-objs is
1080 2003-06-06 Ulrich Drepper <drepper@redhat.com>
1082 * sysdeps/unix/sysv/linux/arm/sysdep-cancel.h: New sequences for
1083 5+ arg syscalls only needed for PIC.
1084 Patch by Ralph Siemsen <ralphs@netwinder.org>.
1086 2003-06-05 Richard Henderson <rth@redhat.com>
1088 * sysdeps/unix/sysv/linux/alpha/sysdep-cancel.h (PSEUDO): Use
1089 and require CFI assembler directives.
1090 * sysdeps/unix/sysv/linux/alpha/vfork.S: Likewise.
1092 2003-05-30 Andreas Jaeger <aj@suse.de>
1094 * sysdeps/unix/sysv/linux/x86_64/sysdep-cancel.h
1095 (SAVESTK_0): Add CFI directives.
1096 (SAVESTK_3): Likewise.
1097 (SAVESTK_5): Likewise.
1098 (RESTSTK_0): Likewise.
1099 (RESTSTK_3): Likewise.
1100 (RESTSTK_5): Likewise.
1102 2003-05-05 Ulrich Drepper <drepper@redhat.com>
1104 * sysdeps/i386/tls.h (TLS_DO_SET_THREAD_AREA): Add \n to error
1107 2003-05-04 Roland McGrath <roland@redhat.com>
1109 * Makefile ($(objpfx)../libc.so): New target.
1111 2003-04-26 Ulrich Drepper <drepper@redhat.com>
1113 * pthread.c (__pthread_initialize_manager): Remove one last
1114 p_multiple_threads call.
1116 2003-04-22 Jakub Jelinek <jakub@redhat.com>
1118 * pthread.c (__pthread_initialize_manager): Subtract
1119 TLS_PRE_TCB_SIZE bytes from tcbp to get to descr.
1120 * manager.c (pthread_handle_create): Subtract or add TLS_PRE_TCB_SIZE
1121 instead of sizeof (pthread_descr).
1122 (pthread_free): Add TLS_PRE_TCB_SIZE instead of sizeof (pthread_descr).
1123 * sysdeps/powerpc/tls.h (TLS_INIT_TCB_SIZE, TLS_TCB_SIZE): Define to 0.
1124 (TLS_INIT_TCB_ALIGN, TLS_TCB_ALIGN): Define to alignment of
1126 (TLS_PRE_TCB_SIZE): Increase to cover tcbhead_t preceeded by pad
1128 (INSTALL_DTV, GET_DTV, THREAD_DTV): tcbhead_t is immediately before
1130 (TLS_INIT_TP, THREAD_SELF, INIT_THREAD_SELF): Don't add TLS_TCB_SIZE
1132 (NO_TLS_OFFSET): Define.
1134 2003-04-22 Roland McGrath <roland@redhat.com>
1136 * Makeconfig (shared-thread-library): Reverse link order to work
1139 2003-04-20 Ulrich Drepper <drepper@redhat.com>
1141 * sysdeps/i386/useldt.h (DO_SET_THREAD_AREA): Make sure the
1142 compiler knows we use the ldt_entry variable and that the syscall
1143 modifies the memory.
1145 * internals.h: Split pthread_functions definition into...
1146 * sysdeps/pthread/pthread-functions.h: ...new file.
1148 * sysdeps/i386/useldt.h: Include <sysdep.h>.
1150 2003-04-13 Jakub Jelinek <jakub@redhat.com>
1152 * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h: Rename macros to
1153 match changes in NPTL sysdep-cancel.h.
1155 2003-04-11 Roland McGrath <roland@redhat.com>
1157 * Makefile (multidir): Don't set the variable here with $(shell ...).
1158 ($(objpfx)multidir.mk): New target, generated makefile; include that.
1159 (generated): Append it.
1161 2003-04-10 Jakub Jelinek <jakub@redhat.com>
1163 * Makefile (multidir, crti-objs, crtn-objs): New variables.
1164 (generated-dirs): Add pathname component of multidir.
1165 (omit-deps, extra-objs): Include $(multidir)/crt? as well.
1166 ($(objpfx)libpthread.so): Depend on $(multidir)/crt?.o as well.
1167 ($(objpfx)$(multidir), $(objpfx)$(multidir)/crti.o,
1168 $(objpfx)$(multidir)/crtn.o): New.
1169 * sysdeps/unix/sysv/linux/sparc/Makefile: Removed.
1170 * sysdeps/unix/sysv/linux/x86_64/Makefile (LDFLAGS-pthread.so,
1171 before-compile, generated): Don't generate and use specs.
1172 ($(objpfx)specs): Remove.
1174 2003-04-11 Martin Schwidefsky <schwidefsky@de.ibm.com>
1176 * sysdeps/s390/pspinlock.c (__pthread_spin_unlock): Fix asm contraints.
1178 2003-04-03 Ulrich Drepper <drepper@redhat.com>
1180 * sysdeps/unix/sysv/linux/arm/sysdep-cancel.h (PSEUDO): Add
1181 missing ; after ENTRY use [PR libc/4997].
1183 2003-04-03 Jakub Jelinek <jakub@redhat.com>
1185 * pthread.c (pthread_initialize): Unblock __pthread_sig_cancel
1186 in case the parent blocked it.
1188 2003-04-02 Jakub Jelinek <jakub@redhat.com>
1190 * Makefile (libpthread-routines): Add pthread_atfork.
1191 (libpthread-static-only-routines): Add pthread_atfork.
1193 2003-04-01 Jakub Jelinek <jakub@redhat.com>
1195 * pthread.c (__pthread_wait_for_restart_signal): Use
1196 __pthread_sigsuspend instead of sigsuspend.
1197 * internals.h (__pthread_sigsuspend): New prototype.
1198 * Makefile (libpthread-routines): Add pt-sigsuspend.
1199 (tests): Add tst-cancel7.
1200 * sysdeps/unix/sysv/linux/pt-sigsuspend.c: New file.
1201 * sysdeps/unix/sysv/linux/alpha/pt-sigsuspend.S: New file.
1202 * sysdeps/unix/sysv/linux/ia64/pt-sigsuspend.c: New file.
1203 * sysdeps/unix/sysv/linux/s390/s390-64/pt-sigsuspend.c: New file.
1204 * sysdeps/unix/sysv/linux/sparc/sparc64/pt-sigsuspend.c: New file.
1205 * sysdeps/unix/sysv/linux/x86_64/pt-sigsuspend.c: New file.
1206 * tst-cancel7.c: New test.
1208 2003-03-31 Alexandre Oliva <aoliva@redhat.com>
1210 * alloca_cutoff.c: Include internals.h.
1211 * sysdeps/pthread/errno-loc.c: Include linuxthreads/internals.h.
1212 * sysdeps/pthread/herrno-loc.c: Likewise.
1213 * sysdeps/pthread/res-state.c: Likewise.
1215 2003-03-25 Ulrich Drepper <drepper@redhat.com>
1217 * sysdeps/pthread/bits/typesizes.h: New file.
1218 * sysdeps/unix/sysv/linux/alpha/bits/typesizes.h: New file.
1219 * sysdeps/unix/sysv/linux/sparc/bits/typesizes.h: New file.
1221 2003-03-24 Daniel Jacobowitz <drow@mvista.com>
1223 * sysdeps/unix/sysv/linux/arm/sysdep-cancel.h
1224 (DOARGS_5, DOARGS_6, DOARGS_7): Rewritten.
1226 2003-03-22 Jakub Jelinek <jakub@redhat.com>
1228 * sysdeps/unix/sysv/linux/fork.c (__fork): Add libc_hidden_def.
1230 2003-03-21 Daniel Jacobowitz <drow@mvista.com>
1232 * sysdeps/unix/sysv/linux/arm/sysdep-cancel.h
1233 (SINGLE_THREAD_P_PIC): Use "reg" instead of "lr".
1235 2003-03-21 Jakub Jelinek <jakub@redhat.com>
1237 * sysdeps/i386/tls.h [__ASSUME_SET_THREAD_AREA_SYSCALL]
1238 (TLS_SETUP_GS_SEGMENT): Fix a typo.
1240 2003-03-19 Ulrich Drepper <drepper@redhat.com>
1242 * sysdeps/pthread/Makefile: Fix cut&paste error.
1244 2003-03-18 Roland McGrath <roland@redhat.com>
1246 * Versions (libpthread: GLIBC_2.2): Remove
1247 pthread_barrierattr_getpshared, never really existed.
1248 (libpthread: GLIBC_2.0): Move __pthread_initialize to ...
1249 (libpthread: GLIBC_PRIVATE): ... here.
1251 2003-03-14 Jakub Jelinek <jakub@redhat.com>
1253 * sysdeps/unix/sysv/linux/sparc/sparc64/Makefile: New file.
1254 * sysdeps/unix/sysv/linux/sparc/Makefile ($(objpfx)specs): Use full
1257 2003-03-14 Alexandre Oliva <aoliva@redhat.com>
1259 * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Don't .set
1261 * sysdeps/mips/pt-machine.h (__compare_and_swap): Likewise.
1262 Handle 64-bit longs on n64.
1264 2003-03-07 Jakub Jelinek <jakub@redhat.com>
1266 * sysdeps/ia64/pspinlock.c (__pthread_spin_lock,
1267 __pthread_spin_trylock): Rewritten.
1269 2003-03-06 Ulrich Drepper <drepper@redhat.com>
1271 * tst-cancel4.c (tf_sleep): Lower sleep time a bit to not upset
1274 2003-03-02 Ulrich Drepper <drepper@redhat.com>
1276 * sysdeps/pthread/timer_create.c (timer_create): Return correct
1277 error for CPU clocks.
1279 * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define
1280 _POSIX_MONOTONIC_CLOCK.
1281 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
1283 2003-03-01 Roland McGrath <roland@redhat.com>
1285 * sysdeps/powerpc/powerpc64/pt-machine.h
1286 (THREAD_GETMEM, THREAD_GETMEM_NC, THREAD_SETMEM, THREAD_SETMEM_NC):
1288 * sysdeps/powerpc/tls.h: Don't define those here.
1290 * sysdeps/powerpc/tls.h [! USE_TLS && !__powerpc64__]: Define
1291 tcbhead_t with multiple_threads member.
1292 [USE_TLS] (tcbhead_t): Define minimal one-word version.
1293 [USE_TLS && !__powerpc64__] (TLS_MULTIPLE_THREADS_IN_TCB): Define.
1294 * sysdeps/powerpc/tcb-offsets.sym [USE_TLS]: Use tls.h macros to
1295 derive thread register offset of p_multiple_threads member.
1297 * descr.h (struct _pthread_descr_struct) [!USE_TLS || !TLS_DTV_AT_TP]:
1298 Conditionalize p_header member on this.
1299 [TLS_MULTIPLE_THREADS_IN_TCB]: Add p_multiple_threads alternatively.
1300 * sysdeps/ia64/tls.h [USE_TLS] (TLS_MULTIPLE_THREADS_IN_TCB): Define.
1301 * sysdeps/sh/tls.h: Likewise.
1302 * sysdeps/ia64/tcb-offsets.sym [USE_TLS]: Use p_multiple_threads.
1303 * sysdeps/sh/tcb-offsets.sym: Likewise.
1304 * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h
1305 (SINGLE_THREAD_P): Likewise.
1306 * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h
1307 (SINGLE_THREAD_P): Likewise.
1308 * sysdeps/unix/sysv/linux/powerpc/powerpc32/sysdep-cancel.h
1309 (SINGLE_THREAD_P): Likewise.
1310 * pthread.c (__pthread_initialize_manager): Likewise.
1311 * manager.c (pthread_handle_create): Likewise.
1313 * sysdeps/powerpc/tls.h [HAVE_TLS_SUPPORT]: Define USE_TLS and all
1316 2003-01-31 Steven Munroe <sjmunroe@us.ibm.com>
1318 * sysdeps/unix/sysv/linux/powerpc/powerpc64/vfork.S [SHARED]:
1319 Conditionalize .toc section magic on this.
1321 2003-02-21 Roland McGrath <roland@redhat.com>
1323 * cancel.c (__pthread_perform_cleanup): Call __libc_thread_freeres
1324 instead of __rpc_thread_destroy.
1326 2003-02-21 Jakub Jelinek <jakub@redhat.com>
1328 * sysdeps/unix/sysv/linux/sparc/sparc64/vfork.S (__vfork): Call
1329 __fork instead of branching to it if BROKEN_SPARC_WDISP22.
1330 * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h (PSEUDO):
1332 * sysdeps/unix/sysv/linux/sparc/Makefile (specs): Add ./ prefix
1333 to crti.o and crtn.o.
1334 * sysdeps/unix/sysv/linux/x86_64/Makefile (specs): Likewise.
1336 2003-02-21 Roland McGrath <roland@redhat.com>
1338 * Makefile (install-lib-ldscripts): New variable.
1340 2003-02-20 Franz Sirl <Franz.Sirl-kernel@lauterbach.com>
1342 * sysdeps/unix/sysv/linux/powerpc/powerpc32/vfork.S: Avoid short
1343 interprocedure branches.
1345 2003-02-19 Ulrich Drepper <drepper@redhat.com>
1347 * specific.c (pthread_key_delete_helper): Don't use GETMEM, we
1348 need the target thread's lock.
1350 2003-02-17 Ulrich Drepper <drepper@redhat.com>
1352 * sysdeps/unix/sysv/linux/bits/local_lim.h: Define TTY_NAME_MAX
1355 2003-02-17 Kevin B. Hendricks <kevin.hendricks@sympatico.ca>
1356 Franz Sirl <Franz.Sirl-kernel@lauterbach.com>
1358 * sysdeps/powerpc/Makefile: Handle tcb-offsets.sym.
1359 * sysdeps/powerpc/tcb-offsets.sym: New file.
1360 * sysdeps/powerpc/tls.h: New file.
1361 * sysdeps/powerpc/powerpc32/pt-machine.h (FLOATING_STACKS): Define.
1362 (ARCH_STACK_MAX_SIZE): Define.
1363 (THREAD_SELF): Define.
1364 (INIT_THREAD_SELF): Define.
1365 (THREAD_GETMEM): Define.
1366 (THREAD_GETMEM_NC): Define.
1367 (THREAD_SETMEM): Define.
1368 (THREAD_SETMEM_NC): Define.
1369 (__thread_self): Declare.
1370 * sysdeps/unix/sysv/linux/powerpc/powerpc32/sysdep-cancel.h: Adjust
1371 for thread register.
1373 2003-02-14 Steven Munroe <sjmunroe@us.ibm.com>
1375 * sysdeps/unix/sysv/linux/powerpc/powerpc64/vfork.S (__vfork):
1376 Check pthread_create existance, not __pthread_fork.
1378 2003-02-12 Ulrich Drepper <drepper@redhat.com>
1380 * sysdeps/pthread/Makefile: Define CFLAGS-confstr.c.
1382 2003-02-10 Jakub Jelinek <jakub@redhat.com>
1384 * sysdeps/unix/sysv/linux/alpha/vfork.S (__vfork): Check
1385 pthread_create existance, not __pthread_fork.
1386 * sysdeps/unix/sysv/linux/i386/vfork.S (__vfork): Likewise.
1387 * sysdeps/unix/sysv/linux/ia64/vfork.S (__vfork): Likewise.
1388 * sysdeps/unix/sysv/linux/m68k/vfork.S (__vfork): Likewise.
1389 * sysdeps/unix/sysv/linux/powerpc/powerpc32/vfork.S (__vfork):
1391 * sysdeps/unix/sysv/linux/s390/s390-64/vfork.S (__vfork): Likewise.
1392 * sysdeps/unix/sysv/linux/x86_64/vfork.S (__vfork): Likewise.
1393 * sysdeps/unix/sysv/linux/sh/vfork.S (__vfork): Likewise.
1394 Add .weak pthread_create.
1395 * sysdeps/unix/sysv/linux/sparc/sparc32/vfork.S (__vfork): Fix a typo.
1396 Check pthread_create existance, not __pthread_fork.
1397 * sysdeps/unix/sysv/linux/sparc/sparc64/vfork.S (__vfork): Likewise.
1398 * sysdeps/unix/sysv/linux/s390/s390-32/vfork.S (__vfork): Branch to
1399 __fork whenever libpthread.so is loaded.
1401 2003-02-09 Andreas Jaeger <aj@suse.de>
1403 * sysdeps/unix/sysv/linux/x86_64/sysdep-cancel.h:
1404 Rework: %r9 is destroyed by functions so don't use it as
1405 temporary, align stack correctly, fix parameter for CDISABLE.
1407 2003-02-07 Kaz Kojima <kkojima@rr.iij4u.or.jp>
1409 * sysdeps/sh/Makefile: New file.
1410 * sysdeps/sh/tcb-offsets.sym: Likewise.
1411 * sysdeps/sh/tls.h: Don't include sysdep.h. Move include
1412 of linuxthreads/descr.h after the definition of THREAD_SELF.
1413 (tcbhead_t): Use IA64 type tcbhead_t for TLS case.
1414 (TLS_TCB_SIZE): Set size of tcbhead_t.
1415 (TLS_PRE_TCB_SIZE): Define.
1416 (INSTALL_NEW_DTV): Set dtv of tcbhead_t structure instead of
1417 a member of thread structure.
1418 (THREAD_DTV): Likewise.
1419 (TLS_INIT_TP_EXPENSIVE): Remove.
1420 (TLS_INIT_TP): Set gbr register only.
1422 (INIT_THREAD_SELF): Likewise.
1423 (NONTLS_INIT_TP): New.
1424 * sysdeps/unix/sysv/linux/sh/pt-initfini.c (__fpscr_values):
1426 * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h (PSEUDO): Add
1427 SYSCALL_INST_PAD macro after DO_CALL.
1428 (SINGLE_THREAD_P): Fix non-PIC and TLS case so to read the
1430 * sysdeps/unix/sysv/linux/sh/vfork.S (__vfork): Branch to __fork
1431 whenever libpthread.so is loaded.
1433 2003-02-08 Andreas Schwab <schwab@suse.de>
1435 * sysdeps/unix/sysv/linux/m68k/vfork.S: Branch to __fork whenever
1436 libpthread.so is loaded.
1438 2003-02-07 Ulrich Drepper <drepper@redhat.com>
1440 * sysdeps/unix/sysv/linux/i386/vfork.S: Make sure
1441 __ASSUME_VFORK_SYSCALL is not defined if the kernel headers have
1442 no __NR_vfork definition.
1444 2003-02-07 Jakub Jelinek <jakub@redhat.com>
1446 * tst-popen2.c: New test.
1447 * Makefile (tests): Add tst-popen2.
1448 * sysdeps/unix/sysv/linux/alpha/vfork.S (__vfork): Branch to __fork
1449 whenever libpthread.so is loaded.
1450 * sysdeps/unix/sysv/linux/i386/vfork.S (__vfork): Likewise.
1451 * sysdeps/unix/sysv/linux/ia64/vfork.S (__vfork): Likewise.
1452 * sysdeps/unix/sysv/linux/s390/s390-64/vfork.S (__vfork): Likewise.
1453 * sysdeps/unix/sysv/linux/powerpc/powerpc32/vfork.S (__vfork):
1455 * sysdeps/unix/sysv/linux/sparc/sparc32/vfork.S (__vfork): Likewise.
1456 * sysdeps/unix/sysv/linux/sparc/sparc64/vfork.S (__vfork): Likewise.
1457 * sysdeps/unix/sysv/linux/x86_64/vfork.S (__vfork): Likewise.
1459 2003-02-05 Ulrich Drepper <drepper@redhat.com>
1461 * sysdeps/pthread/bits/libc-lock.h (__libc_once): Set control
1462 variable for non-libpthread case to the same value the
1463 pthread_once function would use.
1465 2003-02-03 Jakub Jelinek <jakub@redhat.com>
1467 * sysdeps/unix/sysv/linux/sparc/sparc32/vfork.S (__vfork): If
1468 BROKEN_SPARC_WDISP22, handle SHARED the same way as non-SHARED.
1470 2003-02-04 Andreas Jaeger <aj@suse.de>
1472 * sysdeps/unix/sysv/linux/hppa/pt-initfini.c: Do not use
1475 2003-01-30 Jakub Jelinek <jakub@redhat.com>
1477 * sysdeps/s390/tls.h (TLS_INIT_TP): Return NULL, not 0.
1479 2003-01-30 Jakub Jelinek <jakub@redhat.com>
1481 * sysdeps/alpha/tls.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1482 THREAD_SETMEM, THREAD_SETMEM_NC): Avoid warnings about unused self
1484 * sysdeps/ia64/pt-machine.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1485 THREAD_SETMEM, THREAD_SETMEM_NC): Likewise.
1486 * sysdeps/s390/s390-32/pt-machine.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1487 THREAD_SETMEM, THREAD_SETMEM_NC): Likewise.
1488 * sysdeps/s390/s390-64/pt-machine.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1489 THREAD_SETMEM, THREAD_SETMEM_NC): Likewise.
1490 * sysdeps/sh/pt-machine.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1491 THREAD_SETMEM, THREAD_SETMEM_NC): Likewise.
1492 * sysdeps/sparc/sparc32/pt-machine.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1493 THREAD_SETMEM, THREAD_SETMEM_NC): Likewise.
1494 * sysdeps/sparc/sparc64/pt-machine.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1495 THREAD_SETMEM, THREAD_SETMEM_NC): Likewise.
1497 2003-01-27 Martin Schwidefsky <schwidefsky@de.ibm.com>
1499 * sysdeps/s390/s390-32/pt-machine.h (THREAD_SELF, INIT_THREAD_SELF):
1500 Define TLS versions.
1501 * sysdeps/s390/s390-64/pt-machine.h (THREAD_SELF, INIT_THREAD_SELF):
1503 * sysdeps/s390/tls.h [HAVE_TLS_SUPPORT] (USE_TLS, TLS_INIT_TCB_SIZE,
1504 TLS_INIT_TCB_ALIGN, TLS_TCB_SIZE, TLS_TCB_ALIGN, TLS_TCB_AT_TP,
1505 INSTALL_DTV, INSTALL_NEW_DTV, GET_DTV, TLS_INIT_TP, THREAD_DTV):
1507 * sysdeps/unix/sysv/linux/s390/s390-64/sysdep-cancel.h (PSEUDO): Use
1508 branch with 32 bit offset.
1509 * sysdeps/unix/sysv/linux/s390/s390-64/vfork.S: Likewise.
1511 2003-01-24 Jakub Jelinek <jakub@redhat.com>
1513 * sysdeps/sparc/sparc32/pt-machine.h (__thread_self): Change to %g7,
1514 as required by TLS ABI.
1515 * sysdeps/sparc/sparc64/pt-machine.h (__thread_self): Likewise.
1516 * sysdeps/sparc/tls.h [HAVE_TLS_SUPPORT] (USE_TLS, TLS_INIT_TCB_SIZE,
1517 TLS_INIT_TCB_ALIGN, TLS_TCB_SIZE, TLS_TCB_ALIGN, TLS_TCB_AT_TP,
1518 INSTALL_DTV, INSTALL_NEW_DTV, GET_DTV, TLS_INIT_TP, THREAD_DTV):
1520 [HAVE_TLS_SUPPORT]: Include descr.h and sysdep.h.
1521 * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h: Use %g7
1522 instead of %g6 for thread pointer.
1523 * sysdeps/unix/sysv/linux/sparc/sparc32/vfork.S: Likewise.
1524 * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h: Likewise.
1525 * sysdeps/unix/sysv/linux/sparc/sparc64/vfork.S: Likewise.
1527 2003-01-25 Guido Guenther <agx@sigxcpu.org>
1529 * sysdeps/unix/sysv/linux/mips/sysdep-cancel.h: New file.
1530 * sysdeps/unix/sysv/linux/mips/Makefile: New file.
1532 2003-01-20 Martin Schwidefsky <schwidefsky@de.ibm.com>
1534 * sysdeps/unix/sysv/linux/s390/s390-32/vfork.S: Avoid non pc relative
1535 reference to __fork.
1537 2003-01-17 Richard Henderson <rth@redhat.com>
1539 * sysdeps/alpha/tls.h (tcbhead_t): Clarify second member.
1540 (TLS_TCB_SIZE, TLS_TCB_ALIGN): Set for tcbhead_t.
1541 (TLS_PRE_TCB_SIZE): New.
1542 (TLS_INIT_TP, THREAD_SELF, INIT_THREAD_SELF): Update for
1543 new ia64-style thread pointer layout.
1544 (THREAD_GETMEM, THREAD_GETMEM_NC): New.
1545 (THREAD_SETMEM, THREAD_SETMEM_NC): New.
1546 * sysdeps/unix/sysv/linux/alpha/vfork.S: Don't tail-call to __fork
1549 2003-01-15 Jakub Jelinek <jakub@redhat.com>
1551 * sysdeps/ia64/tls.h (tcbhead_t): Use the TLS ABI required layout
1553 (NONTLS_INIT_TP): Revert last change.
1554 * sysdeps/ia64/tcb-offsets.sym (MULTIPLE_THREADS_OFFSET): Define to
1555 offsetof (tcbhead_t, multiple_threads) if USE_TLS not defined.
1557 2003-01-16 Jakub Jelinek <jakub@redhat.com>
1559 * pthread.c (_pthread_initialize_minimal): Use
1560 GL(dl_tls_dtv_slotinfo_list) != NULL to check whether TLS has
1561 been already initialized.
1563 2003-01-16 Jakub Jelinek <jakub@redhat.com>
1565 * sysdeps/i386/tls.h (INIT_SYSINFO): Initialize head->sysinfo even
1568 2003-01-15 Jakub Jelinek <jakub@redhat.com>
1570 * sysdeps/pthread/bits/libc-lock.h (__libc_lock_init,
1571 __libc_lock_init_recursive): Initialize fields directly.
1573 2003-01-15 Jakub Jelinek <jakub@redhat.com>
1575 * sysdeps/unix/sysv/linux/alpha/vfork.S (__vfork): Allow
1576 __fork to be far away from __vfork ifndef SHARED.
1577 * sysdeps/unix/sysv/linux/powerpc/powerpc32/vfork.S (__vfork):
1579 * sysdeps/unix/sysv/linux/sparc/sparc32/vfork.S (__vfork): Likewise.
1580 * sysdeps/unix/sysv/linux/sparc/sparc64/vfork.S (__vfork): Likewise.
1581 Add a missing instruction.
1582 * sysdeps/unix/sysv/linux/arm/vfork.S (__vfork): Conditionally
1583 branch to __fork even if __NR_vfork is not defined.
1585 2003-01-14 Ulrich Drepper <drepper@redhat.com>
1587 * tst-cancel-wrappers.sh: Allow .__*_asynccancel functions names
1590 2003-01-14 Steven Munroe <sjmunroe@us.ibm.com>
1592 * sysdeps/unix/sysv/linux/powerpc/powerpc64/vfork.S: New file.
1594 2003-01-14 Jakub Jelinek <jakub@redhat.com>
1596 * sysdeps/unix/sysv/linux/ia64/vfork.S (JUMPTARGET): Remove.
1598 2003-01-13 Martin Schwidefsky <schwidefsky@de.ibm.com>
1600 * sysdeps/unix/sysv/linux/s390/s390-32/pt-initfini.c: Avoid
1601 unterminated string literals.
1602 * sysdeps/unix/sysv/linux/s390/s390-64/pt-initfini.c: Likewise.
1604 2003-01-13 Martin Schwidefsky <schwidefsky@de.ibm.com>
1606 * sysdeps/unix/sysv/linux/s390/s390-32/sysdep-cancel.h
1607 (PSEUDO): Code reordering. Move CENABLE and CDISABLE literals from
1608 PSEUDO_END to PSEUDO.
1609 (PSEUDO_END): Remove.
1610 (SINGLE_THREAD_P): Save an instruction.
1611 * sysdeps/unix/sysv/linux/s390/s390-32/vfork.S (__vfork): Add missing
1612 parameter to SINGLE_THREAD_P call.
1613 * sysdeps/unix/sysv/linux/s390/s390-64/sysdep-cancel.h (PSEUDO):
1616 2003-01-10 Andreas Schwab <schwab@suse.de>
1618 * sysdeps/unix/sysv/linux/m68k/vfork.S: New file.
1620 2003-01-10 Martin Schwidefsky <schwidefsky@de.ibm.com>
1622 * sysdeps/unix/sysv/linux/s390/s390-32/sysdep-cancel.h (PSEUDO): Setup
1623 backchain in pseudo_cancel. Minor code improvements.
1624 * sysdeps/unix/sysv/linux/s390/s390-64/sysdep-cancel.h (PSEUDO):
1627 2003-01-10 Martin Schwidefsky <schwidefsky@de.ibm.com>
1629 * sysdeps/unix/sysv/linux/s390/s390-32/vfork.S: New file.
1630 * sysdeps/unix/sysv/linux/s390/s390-64/vfork.S: New file.
1632 2002-01-12 Franz Sirl <Franz.Sirl-kernel@lauterbach.com>
1634 * sysdeps/unix/sysv/linux/powerpc/powerpc32/vfork.S: New file.
1636 2002-01-09 Richard Henderson <rth@redhat.com>
1638 * sysdeps/unix/sysv/linux/alpha/sysdep-cancel.h: Assume only
1639 ret follows pseudo, and thus avoid branch-to-branch in cancel
1640 case. Use SYSCALL_ERROR_LABEL.
1642 2003-01-11 Philip Blundell <philb@gnu.org>
1644 * sysdeps/unix/sysv/linux/arm/vfork.S: New file.
1645 * sysdeps/unix/sysv/linux/arm/sysdep-cancel.h (PSEUDO_RET):
1646 Correctly unstack lr.
1647 (UNDOARGS_5): Fix ordering of pushes and pops.
1648 (SINGLE_THREAD_P_PIC): New.
1649 (SINGLE_THREAD_P_INT): New.
1650 (SINGLE_THREAD_P): Implement in terms of above. Restore lr if it
1652 (PSEUDO): Use SINGLE_THREAD_P_INT.
1654 2003-01-11 Kaz Kojima <kkojima@rr.iij4u.or.jp>
1656 * sysdeps/unix/sysv/linux/sh/vfork.S: New file.
1658 2003-01-11 Jakub Jelinek <jakub@redhat.com>
1660 * sysdeps/ia64/tls.h (tcbhead_t): Change into dtv_t *, void *.
1661 [HAVE_TLS_SUPPORT] (USE_TLS, TLS_INIT_TCB_SIZE, TLS_INIT_TCB_ALIGN,
1662 TLS_TCB_SIZE, TLS_PRE_TCB_SIZE, TLS_TCB_ALIGN, TLS_DTV_AT_TP,
1663 INSTALL_DTV, INSTALL_NEW_DTV, GET_DTV, TLS_INIT_TP, THREAD_SELF,
1664 INIT_THREAD_SELF): Define.
1665 [HAVE_TLS_SUPPORT]: Include descr.h.
1666 (NONTLS_INIT_TP): Point __thread_self at the end of dummy
1667 struct _pthread_descr_struct.
1668 * sysdeps/ia64/pt-machine.h (THREAD_GETMEM, THREAD_GETMEM_NC,
1669 THREAD_SETMEM, THREAD_SETMEM_NC): Define using THREAD_SELF,
1671 * sysdeps/ia64/tcb-offsets.sym (MULTIPLE_THREADS_OFFSET): Adjust
1673 * pthread.c (__pthread_initialize_minimal): Use tcbp, not self
1675 (__pthread_initialize_manager): Rename tcb to mgr.
1676 Use tcbp for TCB pointer, if TLS_DTV_AT_TP set mgr to sizeof (struct
1677 _pthread_descr) below tcbp, otherwise to tcbp.
1678 * manager.c (pthread_handle_create): If TLS_DTV_AT_TP, set
1679 new_thread to be below _dl_allocate_tls (). Adjust new_thread back
1680 before freeing. Fix clone arguments if report_events and USE_TLS.
1681 (pthread_free): Adjust th back before freeing.
1683 2003-01-10 Steven Munroe <sjmunroe@us.ibm.com>
1685 * sysdeps/unix/sysv/linux/powerpc/powerpc32/Makefile: Moved to ...
1686 * sysdeps/unix/sysv/linux/powerpc/Makefile: ...here.
1687 * sysdeps/unix/sysv/linux/powerpc/powerpc64/sysdep-cancel.h: New File.
1689 2003-01-09 Jakub Jelinek <jakub@redhat.com>
1691 * sysdeps/unix/sysv/linux/i386/vfork.S: New file.
1692 * sysdeps/unix/sysv/linux/ia64/vfork.S: New file.
1693 * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h
1694 [__ASSEMBLER__] (SINGLE_THREAD_P): Remove trailing ;;.
1695 * sysdeps/unix/sysv/linux/sparc/sparc32/vfork.S: New file.
1696 * sysdeps/unix/sysv/linux/sparc/sparc64/vfork.S: New file.
1697 * sysdeps/unix/sysv/linux/x86_64/vfork.S: New file.
1698 * sysdeps/unix/sysv/linux/alpha/vfork.S: New file.
1699 * tst-popen.c: New test.
1700 * Makefile (tests): Add tst-popen.
1702 2003-01-06 Jakub Jelinek <jakub@redhat.com>
1704 * sysdeps/unix/sysv/linux/sigwait.c (do_sigwait): Add
1705 INTERNAL_SYSCALL_DECL, add err argument to INTERNAL_SYSCALL* macros.
1707 2003-01-06 Jakub Jelinek <jakub@redhat.com>
1709 * sysdeps/unix/sysv/linux/alpha/sysdep-cancel.h (PSEUDO): Use
1710 PSEUDO_PREPARE_ARGS. Fix branch condition after SINGLE_THREAD_P.
1712 2003-01-06 Philip Blundell <philb@gnu.org>
1714 * sysdeps/unix/sysv/linux/arm/sysdep-cancel.h: New file.
1716 2003-01-06 Jakub Jelinek <jakub@redhat.com>
1718 * internals.h (LIBC_CANCEL_HANDLED): Define.
1719 * sysdeps/unix/sysv/linux/sigwait.c (LIBC_CANCEL_HANDLED): Add.
1720 * signals.c (LIBC_CANCEL_HANDLED): Add.
1721 * pt-system.c (LIBC_CANCEL_HANDLED): Add.
1722 * tst-cancel-wrappers.sh: Remove all exceptions.
1724 * sysdeps/unix/sysv/linux/alpha/Makefile: New file.
1726 2003-01-05 Andreas Schwab <schwab@suse.de>
1728 * sysdeps/m68k/Makefile: New file, use -fPIC for nonshared
1731 * sysdeps/unix/sysv/linux/m68k/sysdep-cancel.h (SINGLE_THREAD_P):
1733 (CENABLE): Likewise.
1734 (CDISABLE): Likewise.
1736 2003-01-05 Ulrich Drepper <drepper@redhat.com>
1738 * tst-cancel-wrappers.sh: Invoke gawk not awk since we use GNU awk
1739 features. Reported by Marijn Ros <marijn@mad.scientist.com>.
1741 * Makefile (libc.so-no-z-defs): Define to yes.
1743 2003-01-05 Kaz Kojima <kkojima@rr.iij4u.or.jp>
1745 * sysdeps/sh/tls.h: Include dl-sysdep.h and stdint.h.
1746 (tcbhead_t): Add multiple_threads member.
1747 (TLS_INIT_TP_EXPENSIVE): Define.
1748 * sysdeps/unix/sysv/linux/sh/pt-initfini.c: Don't use multi-line
1749 strings. Remove unused code.
1750 * sysdeps/unix/sysv/linux/sh/sysdep-cancel.h: New file.
1752 2003-01-04 Franz Sirl <Franz.Sirl-kernel@lauterbach.com>
1754 * sysdeps/unix/sysv/linux/powerpc/powerpc32/sysdep-cancel.h: New file.
1755 * sysdeps/unix/sysv/linux/powerpc/powerpc32/Makefile: New file.
1757 2003-01-04 Jakub Jelinek <jakub@redhat.com>
1759 * internals.h (LIBC_THREAD_GETMEM, LIBC_THREAD_SETMEM): Define
1760 even if NOT_IN_libc is defined.
1762 2003-01-05 Jakub Jelinek <jakub@redhat.com>
1764 * sysdeps/unix/sysv/linux/s390/s390-32/sysdep-cancel.h: New file.
1765 * sysdeps/unix/sysv/linux/s390/s390-64/sysdep-cancel.h: New file.
1766 * sysdeps/s390/Makefile: New file.
1767 * sysdeps/s390/tcb-offsets.sym: New file.
1768 * sysdeps/s390/tls.h: New file.
1770 2003-01-03 Richard Henderson <rth@redhat.com>
1772 * sysdeps/unix/sysv/linux/alpha/sysdep-cancel.h: New file.
1774 2003-01-03 Andreas Jaeger <aj@suse.de>
1776 * sysdeps/pthread/bits/libc-tsd.h: Declare weak_extern functions.
1778 2003-01-03 Jakub Jelinek <jakub@redhat.com>
1780 * Makefile ($(objpfx)libpthread.so): Depend on ld.so.
1782 2003-01-02 Ulrich Drepper <drepper@redhat.com>
1784 * tst-cancel-wrappers.sh: Exclude sigwait.c as well, it does not have
1787 2003-01-02 Jakub Jelinek <jakub@redhat.com>
1789 * internals.h (struct pthread_functions): Rename
1790 ptr_pthread_cond_* fields to ptr___pthread_cond_*.
1791 * pthread.c (pthread_functions): Adjust.
1792 * forward.c: Export both pthread_cond_*@@GLIBC_2.3.2 and
1793 pthread_cond_*@GLIBC_2.0 compatibility symbols.
1794 * Versions [libc] (GLIBC_2.3.2): Export pthread_cond_broadcast,
1795 pthread_cond_destroy, pthread_cond_init, pthread_cond_signal
1796 and pthread_cond_wait.
1798 * sysdeps/pthread/bits/pthreadtypes.h (__pthread_cond_align_t): New
1800 (pthread_cond_t): Add __align member, shorten __padding.
1801 * sysdeps/pthread/pthread.h (PHTREAD_COND_INITIALIZER): Initialize
1802 __padding and __align too.
1804 * sysdeps/pthread/bits/libc-lock.h (__libc_maybe_call2): Add
1806 * sysdeps/pthread/sigaction.c: New file.
1807 * sysdeps/unix/sysv/linux/raise.c: New file.
1808 * sysdeps/unix/sysv/linux/sigwait.c: New file.
1809 * sysdeps/unix/sysv/linux/fork.c (__pthread_fork): Protect
1810 weak_extern with #ifndef SHARED.
1811 * sysdeps/unix/sysv/linux/jmp-unwind.c (__pthread_cleanup_upto):
1813 * signals.c (__sigaction): Renamed to...
1814 (__pthread_sigaction): ... this.
1815 (__sigaction): New strong alias, #ifdef SHARED only.
1816 (sigaction): Protect with #ifdef SHARED.
1817 (sigwait): Renamed to...
1818 (__pthread_sigwait): ... this.
1819 (sigwait): New strong alias, #ifdef SHARED only.
1820 (raise): Renamed to...
1821 (__pthread_raise): ... this.
1822 (raise): New strong alias, #ifdef SHARED only.
1823 * internals.h (__pthread_sigaction, __pthread_sigwait,
1824 __pthread_raise): New prototypes.
1825 (struct pthread_functions): Add ptr_pthread_sigaction,
1826 ptr_pthread_sigwait, ptr_pthread_raise.
1827 * pthread.c (pthread_functions): Renamed to...
1828 (__pthread_functions): ... this. No longer static, no longer
1829 SHARED only. Initialize ptr_pthread_sigaction, ptr_pthread_sigwait
1830 and ptr_pthread_raise.
1831 [SHARED] (ptr_pthread_functions): Change to &__pthread_functions.
1832 * libc-cancellation.c (__pthread_thread_self): Remove weak_extern.
1833 * ptfork.c (__fork, __vfork): Protect with #ifdef SHARED.
1834 * ptlongjmp.c (siglongjmp, longjmp): Protect with #ifdef SHARED.
1836 * Makefile (tests, tests-static): Add tst-cancel-static.
1837 * tst-cancel-static.c: New test.
1839 2003-01-02 Jakub Jelinek <jakub@redhat.com>
1841 * Makefile (CFLAGS-pthread_atfork.c): Add -DNOT_IN_libc.
1843 2003-01-02 Ulrich Drepper <drepper@redhat.com>
1845 * sysdeps/pthread/bits/pthreadtypes.h (pthread_cond_t): Add padding.
1846 * condvar.c: Add symbol versioning. The compatibility versions
1847 are the same as the change in the interface does not effect this
1849 * Versions [libpthread]: Add definitions for new pthread_cond_*
1850 interfaces for version GLIBC_2.3.2.
1852 2002-12-31 Ulrich Drepper <drepper@redhat.com>
1854 * sysdeps/unix/sysv/linux/fork.h: Add libc_hidden_proto for
1856 * sysdeps/unix/sysv/linux/register-atfork.c: Add libc_hidden_def
1857 for __register_atfork.
1859 2002-12-31 Jakub Jelinek <jakub@redhat.com>
1861 * sysdeps/i386/i686/pt-machine.h: Use __ASSEMBLER__ instead of
1862 ASSEMBLER test macro.
1863 * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h: Likewise.
1864 * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h: Likewise.
1865 * sysdeps/unix/sysv/linux/m68k/sysdep-cancel.h: Likewise.
1866 * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h: Likewise.
1867 * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h: Likewise.
1868 * sysdeps/unix/sysv/linux/x86_64/sysdep-cancel.h: Likewise.
1870 * sysdeps/pthread/errno-loc.c (__errno_location): Add
1872 * sysdeps/pthread/herrno-loc.c (__h_errno_location): Likewise.
1873 * sysdeps/pthread/res-state.c (__res_state): Likewise.
1874 * sysdeps/unix/sysv/linux/allocrtsig.c (__libc_current_sigrtmin,
1875 __libc_current_sigrtmax): Likewise.
1876 * Versions [libc] (GLIBC_PRIVATE): Remove __libc_internal_tsd_get,
1877 __libc_internal_tsd_set, __libc_internal_tsd_address,
1878 __libc_alloca_cutoff.
1879 [libpthread] (GLIBC_PRIVATE): Remove __libc_internal_tsd_get,
1880 __libc_internal_tsd_set, __libc_internal_tsd_address.
1882 * sysdeps/pthread/list.h: Remove assert.h include.
1883 * sysdeps/unix/sysv/linux/fork.c: Include <fork.h>, not "fork.h".
1885 * sysdeps/pthread/list.h: New file.
1886 * sysdeps/unix/sysv/linux/jmp-unwind.c: New file.
1887 * sysdeps/unix/sysv/linux/fork.c: New file.
1888 * sysdeps/unix/sysv/linux/fork.h: New file.
1889 * sysdeps/unix/sysv/linux/ia64/fork.h: New file.
1890 * sysdeps/unix/sysv/linux/sparc/fork.h: New file.
1891 * sysdeps/unix/sysv/linux/register-atfork.c: New file.
1892 * sysdeps/unix/sysv/linux/unregister-atfork.c: New file.
1893 * sysdeps/unix/sysv/linux/Makefile: New file.
1894 * sysdeps/unix/sysv/linux/Versions: New file.
1895 * ptlongjmp.c (pthread_cleanup_upto): Rename to...
1896 (__pthread_cleanup_upto): ...this. Add targetframe argument,
1897 use it instead of currentframe. No longer static.
1898 (siglongjmp, longjmp): Remove pthread_cleanup_upto calls.
1899 * internals.h (__pthread_cleanup_upto, __pthread_fork): New prototypes.
1900 (struct pthread_functions): Add ptr_pthread_fork,
1901 ptr_pthread_cleanup_upto.
1902 * pthread.c (pthread_functions): Initialize ptr_pthread_fork and
1903 ptr_pthread_cleanup_upto.
1904 * ptfork.c: Include fork.h.
1905 (struct handler_list, struct handler_list_block): Remove.
1906 (pthread_atfork_lock, pthread_atfork_prepare, pthread_atfork_parent,
1907 pthread_atfork_child): Remove.
1908 (pthread_insert_list, __pthread_atfork, pthread_call_handlers): Remove.
1909 (__pthread_fork): New function.
1910 (__fork, __vfork): Call __libc_fork.
1911 * Makefile (libpthread-routines): Add old_pthread_atfork.
1912 (libpthread-nonshared): Add pthread_atfork.
1913 (others): Depend on $(objpfx)libpthread_nonshared.a.
1914 ($(objpfx)libpthread_nonshared.a): New rule.
1915 (install): Depend on $(inst_libdir)/libpthread.so.
1916 ($(inst_libdir)/libpthread.so, $(inst_libdir)/libpthread_nonshared.a):
1918 (tests): Depend on libpthread_nonshared.a too.
1919 * old_pthread_atfork.c: New file.
1920 * pthread_atfork.c: New file.
1921 * Makeconfig (shared-thread-library): Include libpthread_nonshared.a
1924 2002-12-30 Jakub Jelinek <jakub@redhat.com>
1926 * forward.c: Make all functions available by default again. It
1927 caused too much trouble.
1928 * internals.h (struct pthread_functions): Rename ptr_pthread_exit
1929 and ptr_pthread_attr_init_2_* to ptr___pthread_exit and
1930 ptr___pthread_attr_init_2_*.
1931 * pthread.c (pthread_functions): Adjust.
1933 2002-12-28 Jakub Jelinek <jakub@redhat.com>
1935 * libc_pthread_init.c (__libc_pthread_init): Remove
1936 MULTIPLE_THREADS_OFFSET check.
1937 * sysdeps/i386/tls.h: Include tcb-offsets.h in assembler.
1938 (SYSINFO_OFFSET): Remove.
1939 * sysdeps/i386/Makefile [csu] (gen-as-const-headers): Add
1941 * sysdeps/i386/tcb-offsets.sym: New file.
1942 * sysdeps/pthread/tcb-offsets.h: New file.
1943 * sysdeps/sparc/sparc32/tls.h: Removed.
1944 * sysdeps/sparc/sparc64/tls.h: Move...
1945 * sysdeps/sparc/tls.h: ...here. Include tcb-offsets.h in assembler.
1946 * sysdeps/sparc/Makefile: New file.
1947 * sysdeps/sparc/tcb-offsets.sym: New file.
1948 * sysdeps/ia64/tls.h: Include tcb-offsets.h in assembler.
1949 * sysdeps/ia64/Makefile: New file.
1950 * sysdeps/ia64/tcb-offsets.sym: New file.
1951 * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h
1952 (MULTIPLE_THREADS_OFFSET): Remove.
1953 Replace defined MULTIPLE_THREADS_OFFSET
1954 with defined FLOATING_STACKS && USE___THREAD.
1955 * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h
1956 (MULTIPLE_THREADS_OFFSET): Remove.
1957 * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h
1958 (MULTIPLE_THREADS_OFFSET): Remove.
1959 * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h
1960 (MULTIPLE_THREADS_OFFSET): Remove.
1961 * pthread.c (__pthread_initialize_manager): Remove
1962 MULTIPLE_THREADS_OFFSET cbeck.
1964 * tst-cancel-wrappers.sh: Add line continuations.
1966 2002-12-27 Jakub Jelinek <jakub@redhat.com>
1968 * sysdeps/pthread/bits/libc-tsd.h: Include linuxthreads/descr.h
1969 and bits/libc-lock.h.
1970 (__libc_internal_tsd_get, __libc_internal_tsd_set,
1971 __libc_internal_tsd_address): Remove.
1972 (__pthread_internal_tsd_address, __pthread_internal_tsd_get,
1973 __pthread_internal_tsd_set): New weak_externs.
1974 (__libc_tsd_address, __libc_tsd_get, __libc_tsd_set): Define
1975 using __libc_maybe_call2.
1976 (__libc_tsd_key_t): Move to ...
1977 * descr.h (__libc_tsd_key_t): ...here.
1978 Remove bits/libc-tsd.h include.
1979 * sysdeps/pthread/errno-loc.c: New file.
1980 * sysdeps/pthread/herrno-loc.c: New file.
1981 * sysdeps/pthread/res-state.c: New file.
1982 * libc-cancellation.c (THREAD_GETMEM, THREAD_SETMEM): Remove.
1983 (__libc_enable_asynccancel, __libc_disable_asynccancel): Use
1984 thread_self unconditionally. Use LIBC_THREAD_[SG]ETMEM instead
1985 of THREAD_[SG]ETMEM.
1986 * specific.c (libc_internal_tsd_set): Renamed to...
1987 __pthread_internal_tsd_set. Remove static.
1988 (libc_internal_tsd_get): Renamed to...
1989 __pthread_internal_tsd_get. Remove static.
1990 (libc_internal_tsd_address): Renamed to...
1991 __pthread_internal_tsd_address. Remove static.
1992 (__libc_internal_tsd_set, __libc_internal_tsd_get,
1993 __libc_internal_tsd_address, __libc_alloca_cutoff): Remove.
1994 * internals.h [!NOT_IN_libc] (LIBC_THREAD_GETMEM, LIBC_THREAD_SETMEM):
1996 (__pthread_internal_tsd_set, __pthread_internal_tsd_get,
1997 __pthread_internal_tsd_address): New prototypes.
1998 (struct pthread_functions): Add
1999 ptr_pthread_internal_tsd_([sg]et|address) fields.
2000 [!NOT_IN_libc && !FLOATING_STACKS] (thread_self): Define.
2001 * pthread.c (pthread_functions) [!USE_TLS && !HAVE___THREAD]:
2002 Initialize ptr_pthread_internal_tsd_([sg]et|address) fields.
2003 * Versions (libpthread): Remove __libc_alloca_cutoff@GLIBC_PRIVATE.
2004 * alloca_cutoff.c: New file.
2005 * no-tsd.c: Removed.
2006 * Makefile (routines): Remove no-tsd. Add alloca_cutoff.
2007 * pt-system.c (system): Remove cancellation handling.
2008 * tst-cancel-wrappers.sh: Allow pt-system.o* to not use the
2009 cancellation routines.
2011 * sysdeps/i386/tls.h: Include dl-sysdep.h and stdint.h.
2012 (tcbhead_t): Add sysinfo field.
2013 (SYSINFO_OFFSET, INIT_SYSINFO): Define.
2014 (TLS_INIT_TP): Use INIT_SYSINFO.
2015 * sysdeps/unix/sysv/linux/i386/dl-sysdep.h: New file.
2016 * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h
2017 (MULTIPLE_THREADS_OFFSET): Adjust.
2018 * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h
2019 (MULTIPLE_THREADS_OFFSET): Likewise.
2020 * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h
2021 (MULTIPLE_THREADS_OFFSET): Likewise.
2022 * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h
2023 (MULTIPLE_THREADS_OFFSET): Likewise.
2024 * descr.h: Include stdint.h.
2025 (struct _pthread_descr_struct): Add p_header.data.sysinfo field.
2027 2002-12-22 Jakub Jelinek <jakub@redhat.com>
2029 * libc_pthread_init.c: Include stdlib.h.
2030 * sysdeps/i386/tls.h (tcbhead_t): Add multiple_threads member.
2031 (TLS_INIT_TP_EXPENSIVE): Define.
2032 * sysdeps/pthread/bits/libc-lock.h (__libc_maybe_call,
2033 __libc_maybe_call2): In _LIBC check SHARED define.
2034 * sysdeps/ia64/tls.h: New file.
2035 * sysdeps/unix/sysv/linux/ia64/sysdep-cancel.h: New file.
2036 * sysdeps/unix/sysv/linux/ia64/Makefile: New file.
2037 * sysdeps/x86_64/tls.h (TLS_INIT_TP_EXPENSIVE): Define.
2038 * sysdeps/sparc/sparc32/tls.h: New file.
2039 * sysdeps/sparc/sparc64/tls.h: New file.
2040 * sysdeps/unix/sysv/linux/sparc/sparc32/sysdep-cancel.h: New file.
2041 * sysdeps/unix/sysv/linux/sparc/sparc64/sysdep-cancel.h: New file.
2042 * Makefile (tests): Add tst-cancel[1-6].
2043 (tests-reverse): Add tst-cancel5.
2044 Link libc.so before libpthread.so for tests-reverse.
2045 * tst-cancel1.c: New file.
2046 * tst-cancel2.c: New file.
2047 * tst-cancel3.c: New file.
2048 * tst-cancel4.c: New file.
2049 * tst-cancel5.c: New file.
2050 * tst-cancel6.c: New file.
2052 2002-12-27 Andreas Schwab <schwab@suse.de>
2054 * sysdeps/unix/sysv/linux/m68k/sysdep-cancel.h: New file.
2056 2002-12-22 Roland McGrath <roland@redhat.com>
2058 * Makefile (omit-deps): Add $(unix-syscalls:%=ptw-%).
2060 2002-12-21 Ulrich Drepper <drepper@redhat.com>
2062 * pthread.c (init_rtsigs): Remove incomplete __builtin_expect.
2063 Reported by Art Hass <ahaas@airmail.net>.
2065 2002-12-19 Jakub Jelinek <jakub@redhat.com>
2067 * forward.c (pthread_attr_init_2_0, pthread_attr_init_2_1):
2068 Use return 0 as 6th argument to FORWARD4.
2070 2002-12-18 Jakub Jelinek <jakub@redhat.com>
2072 * sysdeps/i386/useldt.h (FLOATING_STACKS, ARCH_STACK_MAX_SIZE): Only
2073 define if __ASSUME_LDT_WORKS > 0.
2074 * libc-cancellation.c (THREAD_GETMEM, THREAD_SETMEM): Redefine to
2075 struct member access if !FLOATING_STACKS.
2076 * sysdeps/pthread/flockfile.c (flockfile): Change into weak alias.
2078 2002-12-18 Jakub Jelinek <jakub@redhat.com>
2080 * internals.h (__pthread_thread_self): New prototype.
2081 (struct pthread_functions): Add ptr_pthread_thread_self field.
2082 * pthread.c (pthread_functions): Initialize ptr_pthread_thread_self.
2083 (__pthread_thread_self): New function.
2084 * libc-cancellation.c (__pthread_thread_self): Add weak_extern.
2085 (__libc_enable_asynccancel, __libc_disable_asynccancel): Don't
2086 use thread_self() directly if not FLOATING_STACKS.
2088 2002-12-18 Jakub Jelinek <jakub@redhat.com>
2090 * sysdeps/x86_64/pt-machine.h: Guard most of the header
2091 with #ifndef __ASSEMBLER__.
2092 * pthread.c (pthread_functions): Use SHLIB_COMPAT around
2093 pthread_attr_init_2_0 use.
2095 2002-12-17 Jakub Jelinek <jakub@redhat.com>
2097 * wrapsyscall.c: Removed.
2099 * Makefile (distribute): Add tst-cancel-wrappers.sh.
2100 (routines): Remove weaks. Add forward,
2101 libc_pthread_init, libc-cancellation.
2102 (shared-only-routines): Remove weaks. Add forward.
2103 (libpthread-routines): Remove wrapsyscall.
2104 Add ptw-write, ptw-read, ptw-close, ptw-fcntl, ptw-accept,
2105 ptw-connect, ptw-recv, ptw-recvfrom, ptw-recvmsg, ptw-send,
2106 ptw-sendmsg, ptw-sendto, ptw-fsync, ptw-lseek, ptw-lseek64,
2107 ptw-llseek, ptw-msync, ptw-nanosleep, ptw-open, ptw-open64,
2108 ptw-pause, ptw-pread, ptw-pread64, ptw-pwrite, ptw-pwrite64,
2109 ptw-tcdrain, ptw-wait, ptw-waitpid, pt-system, pt-allocrtsig.
2110 (libpthread-shared-only-routines): Add pt-allocrtsig.
2111 (tests): Depend on $(objpfx)tst-cancel-wrappers.out.
2112 ($(objpfx)tst-cancel-wrappers.out): New rule.
2113 * sysdeps/pthread/bits/libc-lock.h: Include linuxthreads/internals.h
2115 (__libc_maybe_call): In libpthread.* don't check for existance
2117 (__libc_maybe_call2): Define.
2118 (__libc_lock_init, __libc_lock_fini, __libc_lock_lock,
2119 __libc_lock_trylock, __libc_lock_unlock): Use it.
2120 * sysdeps/pthread/flockfile.c: New file.
2121 * sysdeps/pthread/ftrylockfile.c: New file.
2122 * sysdeps/pthread/funlockfile.c: New file.
2123 * sysdeps/unix/sysv/linux/i386/sysdep-cancel.h: New file.
2124 * sysdeps/unix/sysv/linux/x86_64/sysdep-cancel.h: New file.
2125 * sysdeps/unix/sysv/linux/allocrtsig.c: New file.
2126 * libc-cancellation.c: New file.
2127 * forward.c: New file.
2128 * libc_pthread_init.c: New file.
2129 * pt-system.c: New file.
2130 * pthread.c: Remove locale.h.
2131 (__pthread_manager_thread): Initialize multiple_threads.
2132 (__pthread_multiple_threads): Declare.
2133 (pthread_functions): New variable.
2134 (__pthread_initialize_minimal): Remove __uselocale call.
2135 Call __libc_pthread_init.
2136 (__pthread_initialize_manager): Initialize __pthread_multiple_threads,
2137 initial thread's multiple_threads and __libc_multiple_threads.
2138 Check MULTIPLE_THREADS_OFFSET value. Initialize manager thread's
2140 (pthread_setschedparam, pthread_getschedparam): Rename to __
2141 prefixed variants. Add strong_alias.
2142 (current_rtmin, current_rtmax, __libc_current_sigrtmin,
2143 __libc_current_sigrtmax, __libc_allocate_rtsig): Remove.
2144 (init_rtsigs): Use __libc_current_sigrtmin_private.
2145 (pthread_initialize): Only call init_rtsigs if
2146 !__ASSUME_REALTIME_SIGNALS.
2147 (__pthread_require_wrappers, __pthread_require_lockfile): Remove.
2148 * internals.h (__pthread_attr_destroy, __pthread_attr_setdetachstate,
2149 __pthread_attr_getdetachstate, __pthread_attr_setschedparam,
2150 __pthread_attr_getschedparam, __pthread_attr_setschedpolicy,
2151 __pthread_attr_getschedpolicy, __pthread_attr_setinheritsched,
2152 __pthread_attr_getinheritsched, __pthread_attr_setscope,
2153 __pthread_attr_getscope, __pthread_cond_init,
2154 __pthread_cond_destroy, __pthread_cond_wait,
2155 __pthread_cond_signal, __pthread_cond_broadcast,
2156 __pthread_condattr_init, __pthread_condattr_destroy,
2157 __pthread_equal, __pthread_getschedparam,
2158 __pthread_setschedparam, __pthread_setcancelstate,
2159 __pthread_setcanceltype, __pthread_enable_asynccancel,
2160 __libc_enable_asynccancel, __libc_pthread_init): New prototype.
2161 (__pthread_mutex_init, __pthread_mutex_destroy,
2162 __pthread_mutex_lock, __pthread_mutex_unlock,
2163 __pthread_mutex_trylock): Likewise.
2165 (struct pthread_functions): New type.
2166 (__libc_pthread_functions): New variable.
2167 (LIBC_CANCEL_ASYNC, LIBC_CANCEL_RESET): Define.
2168 * descr.h (struct _pthread_descr_struct): Add
2169 p_header.data.multiple_threads field.
2170 * manager.c (pthread_handle_create): Initialize multiple_threads.
2171 * cancel.c (__pthread_enable_asynccancel,
2172 __pthread_disable_asynccancel): New functions.
2173 (__pthread_provide_wrappers): Remove.
2174 (pthread_setcancelstate, pthread_setcanceltype): Rename to __
2175 prefixed variants. Add strong_alias.
2176 * condvar.c (pthread_cond_init, pthread_cond_destroy,
2177 pthread_cond_wait, pthread_cond_signal, pthread_cond_broadcast,
2178 pthread_condattr_init, pthread_condattr_destroy): Likewise.
2179 * join.c (pthread_exit): Likewise.
2180 * attr.c (pthread_attr_destroy, pthread_attr_setdetachstate,
2181 pthread_attr_getdetachstate, pthread_attr_setschedparam,
2182 pthread_attr_getschedparam, pthread_attr_setschedpolicy,
2183 pthread_attr_getschedpolicy, pthread_attr_setinheritsched,
2184 pthread_attr_getinheritsched, pthread_attr_setscope,
2185 pthread_attr_getscope): Likewise.
2186 * mutex.c (__pthread_mutex_init, __pthread_mutex_destroy,
2187 __pthread_mutex_lock, __pthread_mutex_unlock,
2188 __pthread_mutex_trylock): Add hidden_def.
2189 * Versions (libc): Add __libc_pthread_init,
2190 __libc_current_sigrtmin_private, __libc_current_sigrtmax_private,
2191 __libc_allocate_rtsig_private @@GLIBC_PRIVATE.
2192 * lockfile.c: Remove some USE_IN_LIBIO guards.
2193 (__pthread_provide_lockfile): Remove.
2194 * pt-allocrtsig.c: New file.
2195 * tst-cancel-wrappers.sh: New test.
2197 2002-12-15 Ulrich Drepper <drepper@redhat.com>
2199 * Versions [libpthread: GLIBC_2.3.2]: Remove creat, poll, pselect,
2200 readv, select, sigpause, sigsuspend, sigwaitinfo, waitid, writev.
2201 * wrapsyscall.c: Remove creat, poll, pselect, readv, select,
2202 sigpause, sigsuspend, sigwaitinfo, waitid, and writev wrappers.
2204 2002-12-10 Ulrich Drepper <drepper@redhat.com>
2206 * wrapsyscall.c (CANCELABLE_SYSCALL): Don't define function as
2207 weak. There is no reason for that.
2208 (CANCELABLE_SYSCALL_VA): Likewise.
2210 2002-12-09 Ulrich Drepper <drepper@redhat.com>
2212 * wrapsyscall.c: Add wrappers for creat, poll, pselect, readv, select,
2213 sigpause, __xpg_sigpause, sigsuspend, sigwaitinfo, waitid, and writev.
2214 * Versions: Export creat, poll, pselect, readv, select, sigpause,
2215 __xpg_sigpause, sigsuspend, sigwaitinfo, waitid, and writev from
2216 libpthread in version GLIBC_2.3.2.
2218 2002-12-06 Ulrich Drepper <drepper@redhat.com>
2220 * sysdeps/pthread/bits/libc-lock.h: Define __rtld_lock_* macros.
2222 2002-12-05 Roland McGrath <roland@redhat.com>
2224 * pthread.c (__pthread_initialize_minimal)
2225 [USE_TLS && SHARED && !USE___THREAD]: Initialize TLS and set up the
2226 TCB if the dynamic linker didn't do it at startup.
2228 * sysdeps/i386/tls.h (TLS_INIT_TP): Make it return zero or an error
2230 (TLS_DO_SET_THREAD_AREA, TLS_DO_MODIFY_LDT, TLS_SETUP_GS_SEGMENT):
2232 * sysdeps/x86_64/tls.h (TLS_INIT_TP): Likewise.
2233 * sysdeps/alpha/tls.h (TLS_INIT_TP): Likewise (always zero).
2235 2002-12-03 Roland McGrath <roland@redhat.com>
2237 * pthread.c (pthread_initialize) [SHARED]: Copy dl_error_tsd value
2238 from dynamic linker internal cell to new libc cell.
2240 2002-11-28 Roland McGrath <roland@redhat.com>
2242 * tst-context.c: #define IS_IN_libpthread around #include <tls.h>
2243 before other headers, so FLOATING_STACKS is not defined wrongly.
2245 * sysdeps/i386/tls.h [!IS_IN_libpthread]: Enable TLS support
2246 even if [! FLOATING_STACKS].
2247 (TLS_DO_MODIFY_LDT_KERNEL_CHECK): New macro.
2248 If not under [__ASSUME_LDT_WORKS > 0], then do a runtime check of
2249 dl_osversion >= 2.3.99 and fatal if not.
2250 (TLS_DO_MODIFY_LDT): Use it.
2252 2002-11-28 Ulrich Drepper <drepper@redhat.com>
2254 * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define macros which
2255 require it to 200112L. Remove _POSIX_POLL and _POSIX_SELECT.
2256 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
2258 2002-11-19 Ulrich Drepper <drepper@redhat.com>
2260 * Versions (libc: GLIBC_2.0): Remove names of functions which are
2261 not defined in libc.
2262 * Makefile (shared-only-routines): Add weaks.
2263 * weaks.c: Remove functions which are not exported from libc.so.
2265 2002-11-14 Roland McGrath <roland@redhat.com>
2267 * libc-tsd.c: New file.
2268 * Makefile (distribute): Add it.
2269 (libc-link.so): New variable.
2270 ($(objpfx)libpthread.so): Depend on that instead of libc.so file name.
2271 (libc-ok-for-link): New variable.
2272 [$(versioning) = yes]: Include $(common-objpfx)tls.make and define
2273 libc-ok-for-link to $(use-thread).
2274 [$(libc-ok-for-link) = no]
2275 (libc-link.so): Set to $(objpfx)libc.so, not $(common-objpfx)libc.so.
2276 ($(objpfx)libc_pic_lite.a,$(objpfx)libc_pic_lite.os, $(objpfx)libc.so):
2278 (generated): Append them.
2279 (extra-objs): Append libc-tsd.os.
2281 * libc-tls-loc.c: New file.
2282 * Makefile (libpthread-routines): Add it.
2284 2002-11-14 Andreas Schwab <schwab@suse.de>
2286 * sysdeps/unix/sysv/linux/ia64/pt-initfini.c: Fix unterminated
2289 2002-11-13 Roland McGrath <roland@redhat.com>
2291 * Examples/ex6.c (main): Improve error reporting.
2293 2002-11-04 Ulrich Drepper <drepper@redhat.com>
2295 * sysdeps/i386/Makefile: Compile pthread.c and sighandler.c with
2296 -fno-omit-frame-pointer. Patch by Andreas Steinmetz <ast@domdv.de>.
2298 * sysdeps/i386/useldt.h [PIC] (USETLS_LOAD_EBX): Use correct input
2300 (DO_SET_THREAD_AREA): Mark asm output specifiers correctly.
2302 2002-10-22 Jakub Jelinek <jakub@redhat.com>
2304 * manager.c (pthread_start_thread): Call __uselocale even
2305 if [! SHARED]. Patch by Leon Kanter <leon@geon.donetsk.ua>.
2307 2002-10-17 Roland McGrath <roland@redhat.com>
2309 * Makefile (unload): Don't link in libpthread.so.
2310 ($(objpfx)unload.out): Do depend on it.
2311 * unload.c (main): Improve error reporting.
2313 2002-10-09 Roland McGrath <roland@redhat.com>
2315 * sysdeps/pthread/bits/libc-lock.h (__libc_maybe_call): New macro.
2316 Under [__PIC__], call the function via the pointer fetched for
2317 comparison rather than a call by name that uses the PLT.
2318 (__libc_lock_init, __libc_rwlock_init, __libc_lock_fini)
2319 (__libc_rwlock_fini, __libc_lock_lock, __libc_rwlock_rdlock)
2320 (__libc_rwlock_wrlock, __libc_lock_trylock, __libc_rwlock_tryrdlock)
2321 (__libc_rwlock_trywrlock, __libc_lock_unlock, __libc_rwlock_unlock)
2322 (__libc_key_create, __libc_getspecific, __libc_setspecific)
2323 (__libc_atfork): Use it.
2325 * pthread.c [SHARED] (__libc_dl_error_tsd): New function.
2326 (pthread_initialize) [SHARED]: Set _dl_error_catch_tsd to that.
2327 * Versions (libc: GLIBC_PRIVATE): Add __libc_dl_error_tsd.
2328 (ld: GLIBC_PRIVATE): Set removed.
2330 2002-10-11 Ulrich Drepper <drepper@redhat.com>
2332 * sysdeps/unix/sysv/linux/execve.c: New file.
2334 2002-10-09 Jakub Jelinek <jakub@redhat.com>
2336 * no-tsd.c: Include stdlib.h.
2338 2002-10-07 Jakub Jelinek <jakub@redhat.com>
2340 * sysdeps/unix/sysv/linux/allocalim.h: New file.
2341 * descr.h (struct _pthread_descr_struct): Add p_alloca_cutoff
2343 * manager.c (__pthread_allocate_stack): Add out_stacksize argument.
2344 Pass stack size to caller.
2345 (pthread_handle_create): Set p_alloca_cutoff.
2346 * pthread.c (__pthread_initial_thread): Use C99 designated
2347 initializers. Set p_alloca_cutoff.
2348 (__pthread_manager_thread): Likewise.
2349 (__pthread_initialize_minimal) [USE_TLS]: Set p_alloca_cutoff
2351 (__pthread_init_max_stacksize): Possibly decrease p_alloca_cutoff
2353 (__pthread_initialize_manager) [USE_TLS]: Set p_alloca_cutoff
2355 * specific.c (__libc_alloca_cutoff): New function.
2356 * no-tsd.c (__libc_alloca_cutoff): New function.
2357 * Versions: Export __libc_alloca_cutoff@@GLIBC_PRIVATE from libc
2360 2002-10-02 Kaz Kojima <kkojima@rr.iij4u.or.jp>
2362 * sysdeps/sh/pt-machine.h: Make C code ifndef'ed with __ASSEMBLER__.
2363 * sysdeps/sh/tls.h: Likewise.
2364 * sysdeps/unix/sysv/linux/sh/smp.h: New file.
2366 2002-09-29 Jakub Jelinek <jakub@redhat.com>
2368 * sysdeps/pthread/tst-timer.c (main): Clear
2369 SIGEV2.sigev_notify_attributes.
2371 2002-09-29 Ulrich Drepper <drepper@redhat.com>
2373 * sysdeps/i386/useldt.h (DO_SET_THREAD_AREA): Don't use
2374 INLINE_SYSCALL for set_thread_area syscall.
2376 2002-09-28 Roland McGrath <roland@redhat.com>
2378 * pthread.c (__pthread_reset_main_thread) [FLOATING_STACKS]:
2379 Don't call setrlimit, since we did no prior bogon we need to undo.
2381 2002-09-27 Roland McGrath <roland@redhat.com>
2383 * sysdeps/x86_64/tls.h [__ASSEMBLER__]: Don't include <pt-machine.h>.
2385 2002-09-24 Roland McGrath <roland@redhat.com>
2387 * sysdeps/x86_64/tls.h: New file.
2389 2002-09-23 Roland McGrath <roland@redhat.com>
2391 * Examples/ex13.c (dump_mut): int -> size_t for counter.
2393 2002-09-18 Bruno Haible <bruno@clisp.org>
2395 * Examples/ex10.c (thread): Fail if pthread_mutex_timedlock() returns
2396 an unexpected error code.
2398 * internals.h (__pthread_message): Add const to first parameter type.
2399 * pthread.c (__pthread_message): Likewise.
2401 * sysdeps/unix/sysv/linux/configure: Moved to ../sysdeps/pthread.
2403 2002-09-17 Roland McGrath <roland@redhat.com>
2405 * sysdeps/i386/tls.h (TLS_DO_MODIFY_LDT, TLS_DO_SET_THREAD_AREA):
2406 Set the descriptor limit to the full 4GB, so %gs:OFFSET works for any
2407 offset (positive or negative) relative to the thread struct.
2408 * sysdeps/i386/useldt.h (DO_MODIFY_LDT, DO_SET_THREAD_AREA): Likewise.
2410 2002-09-12 Jakub Jelinek <jakub@redhat.com>
2412 * sysdeps/unix/sysv/linux/sparc/sparc64/Makefile: Move...
2413 * sysdeps/unix/sysv/linux/sparc/Makefile: ...here.
2414 Replace /usr/lib/crt[in].o with crt[in].o too.
2416 2002-09-11 Steven Munroe <sjmunroe@us.ibm.com>
2418 * sysdeps/powerpc/powerpc64/pt-machine.h: New file.
2420 2002-09-04 Bruno Haible <bruno@clisp.org>
2422 * pthread.c: Include <sys/time.h>.
2423 (is_smp_system): Move to sysdeps/unix/sysv/linux/smp.h.
2424 * sysdeps/unix/sysv/linux/smp.h: New file, extracted from pthread.c.
2425 * Makefile (distribute): Add smp.h to the list.
2427 2002-09-04 Bruno Haible <bruno@clisp.org>
2429 * sysdeps/alpha/pt-machine.h: Choose different include file location
2430 on non-Linux platforms.
2432 * wrapsyscall.c (PROMOTE_INTEGRAL_TYPE): New macro.
2433 (open, open64): Change va_arg argument type to the integral type to
2434 which mode_t promotes.
2436 * sysdeps/pthread/tst-timer.c (main): Don't assume anything about
2437 the structure of 'struct sigevent'.
2439 * errno.c (__errno_location, __h_errno_location, __res_state):
2440 Use prototype function definitions.
2442 2002-07-29 Steven Munroe <sjmunroe@us.ibm.com>
2444 * shlib-versions: Set libpthread version to 2.3 for powerpc64.
2445 * sysdeps/powerpc/pt-machine.h: moved to...
2446 * sysdeps/powerpc/powerpc32/pt-machine.h: ...here
2447 * sysdeps/powerpc/powerpc64/pt-machine.h: New file.
2449 2002-09-02 Roland McGrath <roland@redhat.com>
2451 * sysdeps/powerpc/Makefile (CFLAGS-pt-initfini.s): New variable.
2453 2002-09-01 Roland McGrath <roland@redhat.com>
2455 * sysdeps/pthread/bits/libc-tsd.h (enum __libc_tsd_key_t): Add new keys
2456 CTYPE_B, CTYPE_TOLOWER, CTYPE_TOUPPER.
2458 * sysdeps/pthread/bits/libc-tsd.h (__libc_tsd_address): New macro.
2459 (__libc_internal_tsd_address): Declare it.
2460 * Versions (libc, ld, libpthread: GLIBC_PRIVATE): Add
2461 __libc_internal_tsd_address.
2462 * specific.c (libc_internal_tsd_address): New function.
2463 (__libc_internal_tsd_address): New variable.
2464 * no-tsd.c (__libc_internal_tsd_address): New variable.
2466 2002-08-31 Ulrich Drepper <drepper@redhat.com>
2468 * Makefile: Don't use rule for crt%.o, spell it out as rules for
2471 2002-08-30 Roland McGrath <roland@redhat.com>
2473 * Makefile (extra-objs, omit-deps): Add crtn.
2474 ($(objpfx)libpthread.so): Depend on $(objpfx)crtn.o.
2475 ($(objpfx)libpthread.so: +postinit): Append $(objpfx)crtn.o.
2476 ($(objpfx)crtn.S): New target.
2477 ($(objpfx)crt%.o): Pattern rule replaces crti.o target.
2478 (generated): Add crtn.S.
2480 * sysdeps/unix/sysv/linux/x86_64/Makefile ($(objpfx)specs): Massage
2481 crtn.o pathname too.
2483 2002-08-30 Jakub Jelinek <jakub@redhat.com>
2485 * pthread.c (__pthread_initialize_minimal): Call __uselocale even
2488 2002-08-30 Roland McGrath <roland@redhat.com>
2490 * tst-static-locale.c: New file.
2491 * Makefile (tests, tests-static): Add it.
2493 2002-04-24 Steven Munroe <sjmunroe@us.ibm.com>
2495 * spinlock.c (__pthread_lock): Fix spurious wakeup
2496 handling. Don't clear lowest bit of list pointer as sign the thread
2497 is still on the wait list. Don't restart after spurious wakeup
2498 with spinning to get the lock.
2499 (__pthread_unlock): Take set lowest bit into account when handling
2500 pointer to list elements.
2501 Patch by Steve Munroe <sjmunroe@us.ibm.com>.
2503 2002-08-28 Roland McGrath <roland@redhat.com>
2505 * sysdeps/pthread/timer_routines.c (thread_func): Fix type in cast.
2507 2002-08-28 Jakub Jelinek <jakub@redhat.com>
2509 * sysdeps/unix/sysv/linux/hppa/aio_cancel.c: New file.
2510 * sysdeps/unix/sysv/linux/sparc/aio_cancel.c: New file.
2511 * sysdeps/unix/sysv/linux/alpha/aio_cancel.c: New file.
2513 2002-08-28 Ulrich Drepper <drepper@redhat.com>
2515 * sysdeps/pthread/timer_routines.c (thread_func): Change return
2516 type to void and add casts in use to avoid warnings with all gcc
2519 2002-08-08 Jakub Jelinek <jakub@redhat.com>
2521 * sysdeps/unix/sysv/linux/bits/local_lim.h (PTHREAD_THREADS_MAX):
2523 * manager.c (__pthread_handles): Remove.
2524 * pthandles.c: New file.
2525 * pthread.c (__pthread_initialize_minimal): Initialize
2526 __pthread_handles[0] and __pthread_handles[1].
2527 * Makefile (libpthread-routines): Add pthandles (must be last).
2529 2002-08-26 Brian Youmans <3diff@gnu.org>
2531 * Examples/ex10.c: Corrected version number in Lesser GPL copying
2532 permission notice from 2 to 2.1.
2533 * Examples/ex11.c: Likewise.
2534 * Examples/ex13.c: Likewise.
2535 * Examples/ex8.c: Likewise.
2536 * Examples/ex9.c: Likewise.
2537 * barrier.c: Likewise.
2538 * events.c: Likewise.
2539 * lockfile.c: Likewise.
2540 * no-tsd.c: Likewise.
2541 * pt-machine.c: Likewise.
2542 * ptclock_gettime.c: Likewise.
2543 * ptclock_settime.c: Likewise.
2544 * rwlock.c: Likewise.
2545 * sysdeps/alpha/pspinlock.c: Likewise.
2546 * sysdeps/alpha/pt-machine.h: Likewise.
2547 * sysdeps/arm/pspinlock.c: Likewise.
2548 * sysdeps/arm/pt-machine.h: Likewise.
2549 * sysdeps/cris/pspinlock.c: Likewise.
2550 * sysdeps/cris/pt-machine.h: Likewise.
2551 * sysdeps/hppa/pspinlock.c: Likewise.
2552 * sysdeps/hppa/pt-machine.h: Likewise.
2553 * sysdeps/i386/i686/pt-machine.h: Likewise.
2554 * sysdeps/i386/pspinlock.c: Likewise.
2555 * sysdeps/i386/pt-machine.h: Likewise.
2556 * sysdeps/i386/useldt.h: Likewise.
2557 * sysdeps/ia64/pspinlock.c: Likewise.
2558 * sysdeps/ia64/pt-machine.h: Likewise.
2559 * sysdeps/m68k/pspinlock.c: Likewise.
2560 * sysdeps/m68k/pt-machine.h: Likewise.
2561 * sysdeps/mips/pspinlock.c: Likewise.
2562 * sysdeps/mips/pt-machine.h: Likewise.
2563 * sysdeps/powerpc/pspinlock.c: Likewise.
2564 * sysdeps/powerpc/pt-machine.h: Likewise.
2565 * sysdeps/pthread/bits/initspin.h: Likewise.
2566 * sysdeps/pthread/bits/libc-lock.h: Likewise.
2567 * sysdeps/pthread/bits/libc-tsd.h: Likewise.
2568 * sysdeps/pthread/getcpuclockid.c: Likewise.
2569 * sysdeps/pthread/posix-timer.h: Likewise.
2570 * sysdeps/pthread/timer_create.c: Likewise.
2571 * sysdeps/pthread/timer_delete.c: Likewise.
2572 * sysdeps/pthread/timer_getoverr.c: Likewise.
2573 * sysdeps/pthread/timer_gettime.c: Likewise.
2574 * sysdeps/pthread/timer_routines.c: Likewise.
2575 * sysdeps/pthread/timer_settime.c: Likewise.
2576 * sysdeps/pthread/tst-timer.c: Likewise.
2577 * sysdeps/s390/pspinlock.c: Likewise.
2578 * sysdeps/s390/s390-32/pt-machine.h: Likewise.
2579 * sysdeps/s390/s390-64/pt-machine.h: Likewise.
2580 * sysdeps/sh/pspinlock.c: Likewise.
2581 * sysdeps/sh/pt-machine.h: Likewise.
2582 * sysdeps/sparc/sparc32/pspinlock.c: Likewise.
2583 * sysdeps/sparc/sparc32/pt-machine.h: Likewise.
2584 * sysdeps/sparc/sparc32/sparcv9/pspinlock.c: Likewise.
2585 * sysdeps/sparc/sparc64/pspinlock.c: Likewise.
2586 * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
2587 * sysdeps/unix/sysv/linux/bits/local_lim.h: Likewise.
2588 * sysdeps/unix/sysv/linux/bits/posix_opt.h: Likewise.
2589 * sysdeps/unix/sysv/linux/bits/sigthread.h: Likewise.
2590 * sysdeps/unix/sysv/linux/hppa/bits/initspin.h: Likewise.
2591 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
2592 * tststack.c: Likewise.
2593 * unload.c: Likewise.
2594 * weaks.c: Likewise.
2595 * wrapsyscall.c: Likewise.
2597 * sysdeps/pthread/pt-initfini.c: Changed copying
2598 permission notice to Lesser GPL from Library GPL, including the
2599 references in the special exception.
2600 * sysdeps/unix/sysv/linux/hppa/pt-initfini.c: Likewise.
2601 * sysdeps/unix/sysv/linux/ia64/pt-initfini.c: Likewise.
2602 * sysdeps/unix/sysv/linux/s390/s390-32/pt-initfini.c:
2604 * sysdeps/unix/sysv/linux/s390/s390-64/pt-initfini.c:
2606 * sysdeps/unix/sysv/linux/sh/pt-initfini.c: Likewise.
2608 2002-08-26 Ulrich Drepper <drepper@redhat.com>
2610 * Examples/ex10.c (thread): tv_nsec == 1000000000 is already
2611 overflow [PR libc/4244].
2613 2002-08-25 Ulrich Drepper <drepper@redhat.com>
2615 * sysdeps/pthread/timer_routines.c (thread_func): Make the
2616 compiler happy by adding a return statement which will never be
2619 * tst-context.c (main): Cast to long before casting to pointer.
2621 * Examples/ex17.c (main): Use correct format string.
2623 * Examples/ex9.c (thread): Remove incorrect return statement.
2625 2002-08-23 Ulrich Drepper <drepper@redhat.com>
2627 * pthread.c (__linuxthreads_version): New global constant.
2629 2002-08-23 Andreas Jaeger <aj@suse.de>
2631 * sysdeps/x86_64/pt-machine.h: Use %fs instead of %gs
2632 as thread specific register.
2633 (testandset): Fix inline asm.
2634 (THREAD_GETMEM): Fix inline asm.
2636 2002-08-22 Roland McGrath <roland@redhat.com>
2638 * sysdeps/i386/useldt.h (INIT_THREAD_SELF): Remove [HAVE_TLS_SUPPORT]
2640 (INIT_THREAD_SELF): Pass second arg to DO_SET_THREAD_AREA.
2641 (DO_SET_THREAD_AREA): Take second arg, pass to DO_SET_THREAD_AREA_REUSE
2642 macro. That chooses whether to reuse %gs value or let kernel set it.
2643 [USE_TLS] (DO_SET_THREAD_AREA_REUSE): New macro, always 1.
2644 [!USE_TLS] (DO_SET_THREAD_AREA_REUSE): New macro, true if arg is
2647 2002-08-21 Ulrich Drepper <drepper@redhat.com>
2649 * sysdeps/i386/tls.h (TLS_SETUP_GS_SEGMENT): Add new parameter
2650 also to the third definition of this macro.
2652 2002-06-17 Andreas Jaeger <aj@suse.de>
2654 * sysdeps/unix/sysv/linux/x86_64/Makefile (CFLAGS-pt-initfini.s):
2657 2002-08-20 Ulrich Drepper <drepper@redhat.com>
2659 * sysdeps/i386/useldt.h: Go back to using 16-bit instructions when
2660 loading/reading segment registers. Some old hardware doesn't
2661 handle the 32-bit instructions as expected.
2662 * sysdeps/i386/tls.h: Likewise.
2664 * sysdeps/i386/tls.h (TLS_DO_SET_THREAD_AREA): Second parameter is
2665 renamed to secondcall and use is negated.
2666 (TLS_SETUP_GS_SEGMENT): Likewise.
2667 (TLS_INIT_TP): Likewise.
2668 * sysdeps/sh/tls.h (TLS_INIT_TP): Second parameter is renamed to
2671 * sysdeps/i386/tls.h: Use 32-bit operations when handling segment
2672 registers. No need to mask upper 16 bits in this case.
2673 * sysdeps/i386/useldt.h: Likewise.
2674 (DO_SET_THREAD_AREA): We have to load %gs again even if the value
2675 is the same since the GDT content changed.
2677 * sysdeps/i386/tls.h (TLS_INIT_TP): Add new parameter and pass it on
2678 to TLS_SETUP_GS_SEGMENT.
2679 (TLS_SETUP_GS_SEGMENT): Add new parameter and pass it on to
2680 TLS_DO_SET_THREAD_AREA.
2681 (TLS_DO_SET_THREAD_AREA): If new parameter is zero determine
2682 entry number from %gs value.
2683 * sysdeps/sh/tls.h (TLS_INIT_TP): Add new parameter and simply
2686 * manager.c (pthread_handle_create): Pass NULL to _dl_allocate_tls.
2687 Pass true to _dl_deallocate_tls.
2688 (pthread_free): Likewise.
2689 * pthread.c (__pthread_initialize_manager): Likewise.
2691 2002-08-19 Ulrich Drepper <drepper@redhat.com>
2693 * sysdeps/i386/useldt.h (DO_SET_THREAD_AREA): Use correct shift when
2694 computing index from %gs value.
2696 2002-08-16 Roland McGrath <roland@redhat.com>
2698 * sysdeps/i386/tls.h (TLS_DO_SET_THREAD_AREA): Calculate segment
2699 register value from entry number properly.
2701 * sysdeps/i386/tls.h (TLS_DO_MODIFY_LDT): Rewrite asm to use %ebx
2702 optimally conditional on [__PIC__].
2703 (TLS_DO_SET_THREAD_AREA): New macro, implement inline syscall
2704 without touching errno, and use latest modify_ldt-like interface.
2705 (TLS_SETUP_GS_SEGMENT): Use that instead of INLINE_SYSCALL.
2706 * sysdeps/i386/useldt.h (DO_MODIFY_LDT): Set %gs in this macro.
2707 (DO_SET_THREAD_AREA): New macro, uses current syscall interface with
2708 existing %gs value as the segment to set.
2709 (INIT_THREAD_SELF): Rewritten using those. Use set_thread_area only
2710 under [HAVE_TLS_SUPPORT] so we can rely on the initialization done
2711 by the first thread's early TLS setup.
2713 2002-08-15 Roland McGrath <roland@redhat.com>
2715 * sysdeps/i386/tls.h (TLS_INIT_TP): Use statement expression and
2716 return a value as callers now expect.
2718 2002-08-11 Roland McGrath <roland@redhat.com>
2720 * pthread.c (__pthread_initialize_manager): Initialize
2721 p_header.data.tcb field of manager thread's descriptor.
2722 (__pthread_initialize_minimal): Don't initialize p_header.data.self
2723 field, already done by TLS_INIT_TP.
2725 * manager.c (pthread_handle_create): Move p_header field initializers
2728 2002-08-08 Ulrich Drepper <drepper@redhat.com>
2730 * sysdeps/i386/tls.h (TLS_DO_SET_THREAD_AREA): Removed.
2732 2002-08-07 Ulrich Drepper <drepper@redhat.com>
2734 * pthread.c (__linuxthreads_initial_report_events): New variable.
2735 (__pthread_initialize_manager): Use it to initialize p_report_events
2737 [TLS]: Store pointer to descriptor of manager in __pthread_handles.
2739 2002-08-07 Roland McGrath <roland@redhat.com>
2741 * sysdeps/i386/tls.h (TLS_DO_MODIFY_LDT): Add an extra argument with
2742 an "m" constraint to the asm so the compiler knows LDT_ENTRY was used.
2744 2002-08-02 Roland McGrath <roland@redhat.com>
2746 * sysdeps/pthread/bits/libc-tsd.h (enum __libc_tsd_key_t):
2747 Add _LIBC_TSD_KEY_LOCALE.
2748 * manager.c (pthread_start_thread) [!(USE_TLS && HAVE___THREAD)]:
2749 Call __uselocale to initialize our per-thread locale pointer to
2751 * pthread.c (__pthread_initialize_minimal): Likewise.
2753 * sysdeps/i386/tls.h (TLS_DO_SET_THREAD_AREA): Add missing \s.
2755 2002-08-02 Ulrich Drepper <drepper@redhat.com>
2757 * pthread.c: Declare _errno, _h_errno, and _res unless we use TLS
2760 * cancel.c (__pthread_perform_cleanup) [USE_TLS && HAVE___THREAD]:
2761 Don't use p_libc_specific element in thread descriptor.
2763 2002-07-30 Roland McGrath <roland@redhat.com>
2765 * sysdeps/pthread/bits/libc-tsd.h: Include <tls.h>.
2766 [USE_TLS && HAVE___THREAD]: Just include the sysdeps/generic file,
2767 which does the right thing when __thread support is available.
2768 * descr.h (struct _pthread_descr_struct) [USE_TLS && HAVE___THREAD]:
2769 Omit `p_libc_specific', `p_errnop', `p_errno', `p_h_errnop',
2770 `p_h_errno', `p_resp', and `p_res' members.
2771 * pthread.c (__pthread_initialize_minimal) [USE_TLS && HAVE___THREAD]:
2772 Don't initialize `p_errnop' and `p_h_errnop' members.
2773 (__pthread_reset_main_thread): Likewise.
2774 (__pthread_initialize_manager): Likewise.
2775 * manager.c (__pthread_manager, pthread_handle_create): Likewise.
2776 * pthread.c (pthread_initialize) [USE_TLS && HAVE___THREAD]:
2777 Don't initialize `p_resp' member.
2778 (__pthread_reset_main_thread): Likewise.
2779 * manager.c (pthread_handle_create): Likewise.
2780 * specific.c (libc_internal_tsd_set, libc_internal_tsd_get):
2781 Conditionalize these on [!(USE_TLS && HAVE___THREAD)].
2782 * no-tsd.c: Conditionalize contents on [!(USE_TLS && HAVE___THREAD)].
2783 * errno.c [USE_TLS && HAVE___THREAD]
2784 (__h_errno_location, __res_state): Don't define these at all.
2786 * sysdeps/i386/tls.h (INSTALL_DTV): Add parens around arguments!
2787 (INSTALL_NEW_DTV, GET_DTV): Likewise.
2788 * sysdeps/sh/tls.h (INSTALL_DTV, INSTALL_NEW_DTV, GET_DTV): Likewise.
2790 * weaks.c: Don't include <errno.h> here.
2792 2002-08-01 Roland McGrath <roland@redhat.com>
2794 * sysdeps/i386/tls.h (TLS_DO_MODIFY_LDT): New macro, broken out of
2796 (TLS_DO_SET_THREAD_AREA): New macro, uses thread_set_area syscall.
2797 (TLS_SETUP_GS_SEGMENT): New macro, try one or the other or both.
2798 (TLS_INIT_TP): Use that.
2800 2002-08-02 Jakub Jelinek <jakub@redhat.com>
2802 * sysdeps/i386/useldt.h (DO_MODIFY_LDT): Move from INIT_THREAD_SELF.
2803 (INIT_THREAD_SELF): Use sys_thread_area syscall instead if available.
2804 (FREE_THREAD): Avoid modify_ldt if using GDT.
2805 * sysdeps/i386/pspinlock.c (__have_no_set_thread_area): New variable.
2807 2002-07-25 Jakub Jelinek <jakub@redhat.com>
2809 * sysdeps/i386/tls.h: Use __ASSEMBLER__ test macro not ASSEMBLER.
2810 * sysdeps/i386/pt-machine.h: Likewise.
2811 * sysdeps/i386/useldt.h: Likewise.
2813 2002-07-22 Ulrich Drepper <drepper@redhat.com>
2815 * pthread.c (__pthread_initialize_minimal): If !SHARED and TLS
2816 call __libc_setup_tls first.
2817 * Makefile: Actually create tst-signal.out file when running the test.
2818 (tests): Add tststatic.
2819 * Examples/tststatic.c: New file.
2821 2002-07-19 Ulrich Drepper <drepper@redhat.com>
2823 * errno.c (__errno_location): Don't define unless !USE_TLS
2825 * sysdeps/i386/pt-machine.c: Protect C code with #ifndef ASSEMBLER.
2826 * sysdeps/i386/tls.h: Likewise.
2827 * sysdeps/i386/useldt.h: Likewise.
2828 * sysdeps/i386/i686/pt-machine.h: Likewise.
2830 2002-07-02 H.J. Lu <hjl@gnu.org>
2832 * sysdeps/mips/pspinlock.c: Don't include <sgidefs.h>. Always
2834 * sysdeps/mips/pt-machine.h: Likewise.
2836 2002-07-14 Ulrich Drepper <drepper@redhat.com>
2838 * manager.c (pthread_handle_create): Initialize self-reference in
2841 2002-07-01 Jakub Jelinek <jakub@redhat.com>
2843 * Examples/ex9.c (main): Remove unused th variable.
2845 2002-07-10 Ulrich Drepper <drepper@redhat.com>
2847 * wrapsyscall.c: Add __nanosleep alias.
2848 * Versions (GLIBC_2.2.6): Add __nanosleep.
2849 * bug-sleep.c: New file.
2850 * Makefile (tests): Add bug-sleep.
2852 2002-06-19 Steven Munroe <sjmunroe@vnet.ibm.com>
2854 * Examples/ex9.c (main): Use list of children and join them.
2855 (thread): Do not call exit.
2857 2002-06-20 Ulrich Drepper <drepper@redhat.com>
2859 * spinlock.c (wait_node_alloc): We cannot use compare-and-exchange.
2860 Unconditionally use the code using spinlock. Use __pthread_release
2862 (wait_node_free): Likewise.
2863 (__pthread_acquire, __pthread_release): Unconditionally define.
2865 2002-06-07 Jakub Jelinek <jakub@redhat.com>
2867 * sysdeps/ia64/pt-machine.h (MEMORY_BARRIER): Fix typo.
2869 2002-05-24 Ulrich Drepper <drepper@redhat.com>
2871 * sysdeps/ia64/pt-machine.h (MEMORY_BARRIER): Use __sync_synchronize.
2873 2002-05-21 Ulrich Drepper <drepper@redhat.com>
2875 * sysdeps/pthread/pthread.h (pthread_create): Rename first
2877 (pthread_cancel): Likewise.
2878 * internals.h (__pthread_create_2_1): Likewise.
2879 * sysdeps/unix/sysv/linux/bits/sigthread.h (pthread_kill): Likewise.
2881 2002-05-20 Ulrich Drepper <drepper@redhat.com>
2883 * sysdeps/alpha/pt-machine.c (THREAD_SELF): Remove clobber.
2884 Patch by Glen Nakamura <gen@flex.com>.
2886 2002-05-03 Ulrich Drepper <drepper@redhat.com>
2888 * signals.c: Move sighandler functions to...
2889 * sighandler.c: ...here. New file.
2890 * signals.c: Move signal handler related type definitions to...
2891 * internals.h: ...here. Add prototypes for signal handlers.
2892 * Makefile (libpthread-routines): Add sighandler.
2893 (CFLAGS-sighandler.c): Add $(exceptions).
2895 2002-04-30 Jakub Jelinek <jakub@redhat.com>
2897 * sysdeps/unix/sysv/linux/x86_64/Makefile: New file.
2899 2002-04-08 Ulrich Drepper <drepper@redhat.com>
2901 * sysdeps/pthread/timer_getoverr.c: Return real overrun.
2902 * sysdeps/pthread/posix-timer.h (struct timer_node): Add overrun_count.
2903 * sysdeps/pthread/timer_routines.c (thread_func): Schedule next timeout
2904 based on previous one and not on current time. Count overruns.
2905 Patch by Eric F. Sorton <eric@cctcorp.com>.
2907 * sysdeps/unix/sysv/linux/bits/local_lim.h: Add DELAYTIMER_MAX.
2909 2002-04-08 kaz Kojima <kkojima@rr.iij4u.or.jp>
2911 * sysdeps/sh/pt-machine.h: Define _PT_MACHINE_H
2912 if it isn't defined yet.
2913 (FLOATING_STACKS, ARCH_STACK_MAX_SIZE): Defined.
2914 (THREAD_GETMEM, THREAD_GETMEM_NC, THREAD_SETMEM, THREAD_SETMEM_NC):
2916 * sysdeps/sh/tls.h: New file.
2918 2002-04-08 Jakub Jelinek <jakub@redhat.com>
2920 * manager.c (__pthread_manager_event): Use self instead of arg
2921 for INIT_THREAD_SELF.
2922 * sysdeps/i386/useldt.h (INIT_THREAD_SELF): Use sizeof (struct
2923 _pthread_descr_struct) instead of sizeof (*descr).
2925 2002-04-05 Ulrich Drepper <drepper@redhat.com>
2927 * sysdeps/ia64/pt-machine.h: Protect against multiple inclusion.
2928 * sysdeps/alpha/pt-machine.h: Likewise.
2929 * sysdeps/arm/pt-machine.h: Likewise.
2930 * sysdeps/cris/pt-machine.h: Likewise.
2931 * sysdeps/hppa/pt-machine.h: Likewise.
2932 * sysdeps/m68k/pt-machine.h: Likewise.
2933 * sysdeps/mips/pt-machine.h: Likewise.
2934 * sysdeps/powerpc/pt-machine.h: Likewise.
2935 * sysdeps/s390/s390-32/pt-machine.h: Likewise.
2936 * sysdeps/s390/s390-64/pt-machine.h: Likewise.
2937 * sysdeps/sh/pt-machine.h: Likewise.
2938 * sysdeps/sparc/sparc32/pt-machine.h: Likewise.
2939 * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
2940 * sysdeps/x86_64/pt-machine.h: Likewise.
2942 2002-04-05 Jakub Jelinek <jakub@redhat.com>
2944 * man/pthread_mutexattr_init.man (pthread_mutexattr_settype): Document
2945 instead of pthread_mutexattr_setkind_np.
2946 (pthread_mutexattr_gettype): Similarly.
2947 * man/pthread_mutexattr_setkind_np.man: New.
2948 * man/Makefile (SOURCES): Add pthread_mutexattr_setkind_np.man.
2950 2002-04-02 Ulrich Drepper <drepper@redhat.com>
2952 * sysdeps/ia64/pt-machine.h (MEMORY_BARRIER): Define.
2954 2002-03-22 Jakub Jelinek <jakub@redhat.com>
2956 * sysdeps/mips/pt-machine.h (MEMORY_BARRIER): Remove.
2958 2002-03-22 Ulrich Drepper <drepper@redhat.com>
2960 * internals.h (MEMORY_BARRIER): Define as asm with memory as clobber.
2962 2002-03-17 Andreas Jaeger <aj@suse.de>
2964 * sysdeps/i386/pt-machine.h: Add testandset and __compare_and_swap
2966 * sysdeps/alpha/pt-machine.h: Likewise.
2967 * sysdeps/arm/pt-machine.h: Likewise.
2968 * sysdeps/cris/pt-machine.h: Likewise.
2969 * sysdeps/hppa/pt-machine.h: Likewise.
2970 * sysdeps/i386/i686/pt-machine.h: Likewise.
2971 * sysdeps/ia64/pt-machine.h: Likewise.
2972 * sysdeps/m68k/pt-machine.h: Likewise.
2973 * sysdeps/mips/pt-machine.h: Likewise.
2974 * sysdeps/powerpc/pt-machine.h: Likewise.
2975 * sysdeps/s390/s390-32/pt-machine.h: Likewise.
2976 * sysdeps/s390/s390-64/pt-machine.h: Likewise.
2977 * sysdeps/sh/pt-machine.h: Likewise.
2978 * sysdeps/sparc/sparc32/pt-machine.h: Likewise.
2979 * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
2980 * sysdeps/x86_64/pt-machine.h: Likewise.
2982 * internals.h: Move testandset and __compare_and_swap prototypes
2985 2002-03-03 Andreas Jaeger <aj@suse.de>
2987 * errno.c: Include resolv.h to avoid warning.
2989 2002-02-27 Ulrich Drepper <drepper@redhat.com>
2991 * pthread.c [USE_TLS] (thread_self_stack): Correct check for upper
2994 2002-02-23 Ulrich Drepper <drepper@redhat.com>
2996 * attr.c (pthread_getattr_np): Don't take thread descriptor size
2997 into account if USE_TLS.
2998 * manager.c (pthread_handle_create): Free TLS data structures if call
2999 failed. Pass correct stack to clone if USE_TLS.
3000 * sysdeps/i386/pt-machine.h: Handle multiple inclusion.
3001 * sysdeps/i386/i686/pt-machine.h: Likewise.
3002 * sysdeps/i386/tls.h: Unconditionally include <pt-machine.h>.
3004 * descr.h (struct _pthread_descr_struct): Update p_header for TLS.
3005 Add p_stackaddr element #if USE_TLS.
3006 * internals.c: Include <tls.h>.
3007 * manager.c: Integrate creating and handling of thread descriptor
3009 * pthread.c: Likewise.
3010 * sysdeps/i386/tls.h (tcbhead_t): Add self pointer.
3011 Include <linuxthreads/descr.h> only if TLS is really used.
3012 (GET_DTV): New macro.
3013 (TLS_INIT_TP): Initialize self pointer.
3015 2002-02-17 Andreas Schwab <schwab@suse.de>
3017 * signals.c (sigwait): Check for old sighandler being SIG_ERR,
3020 2002-02-12 Ulrich Drepper <drepper@redhat.com>
3022 * sysdeps/i386/tls.c (INSTALL_NEW_DTV): Define.
3023 (INSTALL_DTV): Adjust for being passed pointer to element with length.
3025 2002-02-08 Ulrich Drepper <drepper@redhat.com>
3027 * sysdeps/i386/tls.h (TLS_INIT_TP): Also initialize %gs.
3029 2002-02-08 Richard Henderson <rth@redhat.com>
3031 * sysdeps/alpha/elf/pt-initfini.c: Use \n\ for multiline string.
3033 2002-02-08 Ulrich Drepper <drepper@redhat.com>
3035 * sysdeps/i386/tls.h: TLS cannot be supported with FLOATING_STACKS
3038 2002-02-07 H.J. Lu <hjl@gnu.org>
3040 * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Silence the
3042 (__pthread_spin_lock): Remove ".set noreorder".
3043 * sysdeps/mips/pt-machine.h (__compare_and_swap): Liekwise.
3045 2002-02-05 H.J. Lu <hjl@gnu.org>
3047 * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Not use
3049 * sysdeps/mips/pt-machine.h (testandset): Likewise.
3050 (__compare_and_swap): Likewise.
3052 2002-02-07 Ulrich Drepper <drepper@redhat.com>
3054 * internals.h: Move declarations/definitions of
3055 __pthread_initial_thread_bos, __pthread_initial_thread,
3056 __pthread_manager_thread_bos, __pthread_manager_thread_tos,
3057 __pthread_manager_thread, __pthread_nonstandard_stacks, STACK_SIZE,
3058 CURRENT_STACK_FRAME, __pthread_find_self, and thread_self...
3060 * sysdeps/i386/tls.h: Add TLS definitions also for !FLOATING_STACKS.
3061 Define THREAD_GETMEM accordingly.
3063 2002-02-06 Ulrich Drepper <drepper@redhat.com>
3065 * sysdeps/i386/tls.h: Include <stddef.h> for size_t.
3067 * sysdeps/i386/tls.h: Define THREAD_DTV.
3069 2002-02-04 Ulrich Drepper <drepper@redhat.com>
3071 * internals.h: Move thread descriptor definition...
3072 * descr.h.: ...here. New file.
3073 * sysdeps/i386/tls.h: New file.
3075 2002-02-01 H.J. Lu <hjl@gnu.org>
3077 * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Use a
3078 different register in the delayed slot. Use branch likely.
3080 * sysdeps/mips/pt-machine.h (testandset): Call _test_and_set.
3081 (__compare_and_swap): Return 0 only when failed to compare. Use
3084 2002-02-01 Jakub Jelinek <jakub@redhat.com>
3086 * Versions (__libc_internal_tsd_get, __libc_internal_tsd_set,
3087 __pthread_kill_other_threads_np): Move to GLIBC_PRIVATE.
3088 * sysdeps/i386/i586/Versions: Move all symbols to GLIBC_PRIVATE.
3089 * sysdeps/i386/i686/Versions: Move all symbols to GLIBC_PRIVATE.
3090 * sysdeps/sparc/sparc32/sparcv9/Versions: New file.
3091 * sysdeps/sparc/sparc64/Versions: New file.
3092 * sysdeps/ia64/Versions: Move all symbols to GLIBC_PRIVATE.
3094 2002-01-31 Ulrich Drepper <drepper@redhat.com>
3096 * pthread.c: _dl_cpuclock_offset is not any longer a global variable
3097 in SHARED code, use GL(dl_cpuclock_offset).
3099 2002-01-28 Andreas Jaeger <aj@suse.de>
3101 * sysdeps/mips/pspinlock.c (__pthread_spin_init): Clear *LOCK to
3102 0. Patch by Machida Hiroyuki <machida@sm.sony.co.jp>.
3104 2002-01-16 Martin Schwidefsky <schwidefsky@de.ibm.com>
3106 * sysdeps/s390/s390-32/pt-machine.h (MEMORY_BARRIER): Define.
3107 (CURRENT_STACK_FRAME): Remove duplicate definition.
3108 * sysdeps/s390/s390-64/pt-machine.h: Likewise.
3110 2002-01-14 Martin Schwidefsky <schwidefsky@de.ibm.com>
3112 * Makefile (CFLAGS-tst-cancel.c): Add -fno-inline-functions to prevent
3115 2002-01-12 Andreas Schwab <schwab@suse.de>
3117 * Makefile (test-srcs): Add tst-signal.
3118 (tests): Run tst-signal.
3119 (distribute): Add tst-signal.sh.
3120 * tst-signal.c, tst-signal.sh: New files.
3122 2002-01-14 Andreas Jaeger <aj@suse.de>
3124 * sysdeps/x86_64/pt-machine.h (INIT_THREAD_SELF): Avoid warning.
3126 2002-01-11 Andreas Schwab <schwab@suse.de>
3128 * signals.c (sighandler): Initialize all elements to SIG_ERR.
3129 (__sigaction): Don't use value from sighandler if it is SIG_ERR.
3131 2002-01-06 Richard Henderson <rth@redhat.com>
3133 * sysdeps/alpha/elf/pt-initfini.c: New file.
3135 2001-12-29 Andreas Jaeger <aj@suse.de>
3137 * Examples/ex9.c: Add noreturn attribute for thread.
3138 * Examples/ex10.c: Likewise.
3139 * Examples/ex13.c (thread_start): Likewise.
3140 * Examples/ex15.c (worker): Likewise.
3142 * Examples/ex18.c: Include unistd.h for prototype of sleep.
3144 2001-12-14 Ulrich Drepper <drepper@redhat.com>
3146 * man/pthread_atfork.man: Adjust description of mutex handling
3147 after fork for current implementation.
3148 * linuxthreads.texi: Likewise [PR libc/2519].
3150 2001-12-13 Andreas Schwab <schwab@suse.de>
3152 * specific.c (pthread_key_delete): Don't contact the thread
3153 manager if no threads have been created yet.
3155 2001-12-12 NIIBE Yutaka <gniibe@m17n.org>
3157 * sysdeps/sh/pt-machine.h (INIT_THREAD_SELF): Added __volatile__
3158 qualifier to be safe.
3160 2001-11-30 Andreas Schwab <schwab@suse.de>
3162 * pthread.c (pthread_handle_sigcancel) [THREAD_SELF]: Double check
3163 that self is the manager thread, and initialize the thread
3165 (thread_self_stack) [THREAD_SELF]: New function to find self via
3167 * manager.c (pthread_handle_create): Don't block cancel signal any
3170 2001-11-29 Andreas Jaeger <aj@suse.de>
3172 * sysdeps/x86_64/pt-machine.h: Use %gs as thread specific register.
3174 (INIT_THREAD_SELF): New.
3175 (THREAD_GETMEM): New.
3177 (THREAD_SETMEM): New.
3178 (THREAD_SETMEM_NC): New.
3179 (FLOATING_STACKS): Define.
3180 (ARCH_STACK_MAX_SIZE): Define.
3182 2001-11-28 Kaz Kylheku <kaz@ashi.footprints.net>
3184 Bugfix to pthread_key_delete. It was iterating over the thread
3185 manager's linked list of threads, behind the thread manager's
3186 back causing a race. The fix is to have the manager iterate over
3187 the threads instead, using a new request type for doing so.
3188 * internals.h (struct pthread_request): New manager request type
3189 REQ_FOR_EACH_THREAD.
3190 * manager.c (pthread_for_each_thread): New function.
3191 (__pthread_manager): Handle new REQ_FOR_EACH_THREAD request.
3192 * specific.c (struct pthread_key_delete_helper_args): New type.
3193 (pthread_key_delete_helper): New static function.
3194 (pthread_key_delete): Use the new thread manager
3195 REQ_FOR_EACH_THREAD function to iterate over the threads and set
3196 the delete key slot to a null value in each thread.
3197 * Examples/ex18.c: New test.
3198 * Makefile (tests): Add ex18.
3200 2001-11-22 Wolfram Gloger <wg@malloc.de>
3202 * pthread.c (pthread_onexit_process): Don't call free
3203 after threads have been asynchronously terminated.
3205 * manager.c (pthread_handle_exit): Surround cancellation
3206 of threads with __flockfilelist()/__funlockfilelist().
3208 2001-11-26 Andreas Schwab <schwab@suse.de>
3210 * manager.c (pthread_handle_create): Start the child thread with
3211 the cancel signal blocked, so that it does not handle it before
3212 the thread register is set up. Save errno from failed clone call.
3214 2001-11-15 Ulrich Drepper <drepper@redhat.com>
3216 * sysdeps/i386/i686/Implies: Removed.
3217 * sysdeps/i386/i686/Versions: New file.
3219 2001-10-31 Andreas Jaeger <aj@suse.de>
3221 * sysdeps/x86_64/Makefile: Remove, we do not need it anymore.
3223 2001-10-05 Kevin Buettner <kevinb@cygnus.com>
3225 * pthread.c (__linuxthread_pthread_sizeof_descr): Change name
3226 to __linuxthreads_pthread_sizeof_descr to match name used by
3227 symbol_list_arr[LINUXTHREADS_PTHREAD_SIZEOF_DESCR] in
3228 linuxthreads_db/td_symbol_list.c.
3230 2001-09-22 Andreas Jaeger <aj@suse.de>
3232 * linuxthreads/tst-context.c: Avoid compile warning.
3234 2001-09-20 Andreas Jaeger <aj@suse.de>
3236 * shlib-versions: Add x86-64.
3238 2001-09-19 Andreas Jaeger <aj@suse.de>
3240 * sysdeps/x86_64/Makefile: New file.
3241 * sysdeps/x86_64/pspinlock.c: New file.
3242 * sysdeps/x86_64/pt-machine.h: New file.
3244 2001-09-12 Jakub Jelinek <jakub@redhat.com>
3246 * sysdeps/pthread/timer_delete.c (timer_delete): Thread may be NULL
3248 * sysdeps/pthread/timer_settime.c (timer_settime): Likewise.
3250 2001-09-11 Ulrich Drepper <drepper@redhat.com>
3251 Wolfram Gloger <wg@malloc.de>
3253 * join.c: Protect all communications from and to manager with
3255 * manager.c: Likewise.
3256 * pthread.c: Likewise.
3257 * smeaphore.c: Likewise.
3259 2001-08-29 Ulrich Drepper <drepper@redhat.com>
3261 * spinlock.c (__pthread_lock): Top max_count value with
3262 MAX_ADAPTIVE_SPIN_COUNT.
3263 * internals.h (MAX_ADAPTIVE_SPIN_COUNT): Define if not already done.
3265 * sysdeps/i386/i686/pt-machine.h (BUSY_WAIT_NOP): New macro to
3268 2001-08-27 Jakub Jelinek <jakub@redhat.com>
3270 * sysdeps/pthread/bits/libc-lock.h (__libc_rwlock_t): Only define to
3271 non-opaque type if __USE_UNIX98.
3273 2001-08-26 Jakub Jelinek <jakub@redhat.com>
3275 * sysdeps/pthread/bits/libc-lock.h (__libc_lock_t): Define
3276 non-opaque lock types also if _IO_MTSAFE_IO is defined.
3278 2001-08-23 Roland McGrath <roland@frob.com>
3280 * sysdeps/pthread/bits/libc-lock.h (__libc_cleanup_region_start): Take
3281 new first argument, skip the cleanup handler if it's zero.
3282 (_LIBC_LOCK_RECURSIVE_INITIALIZER): New macro.
3283 (__libc_lock_define_initialized_recursive): Use it.
3284 * sysdeps/pthread/bits/stdio-lock.h: File removed.
3285 The sysdeps/generic file from the main tree now suffices.
3287 2001-08-22 Roland McGrath <roland@frob.com>
3289 * sysdeps/pthread/bits/stdio-lock.h: Include <bits/libc-lock.h>
3290 instead of <pthread.h>.
3291 (_IO_lock_t): Define this typedef using __libc_lock_define_recursive.
3292 (_IO_lock_initializer): Add braces.
3293 (_IO_lock_lock): Use __libc_lock_lock_recursive.
3294 (_IO_lock_unlock): Use __libc_lock_unlock_recursive.
3296 * sysdeps/pthread/bits/libc-lock.h (__libc_lock_recursive_t): New type.
3297 (__libc_lock_define_initialized_recursive): Use it.
3298 (__libc_lock_init_recursive): Likewise.
3299 (__libc_lock_fini_recursive): Likewise.
3300 (__libc_lock_lock_recursive): Likewise.
3301 (__libc_lock_trylock_recursive): Likewise.
3302 (__libc_lock_unlock_recursive): Likewise.
3303 (__libc_lock_define_recursive): New macro.
3305 2001-08-14 Jakub Jelinek <jakub@redhat.com>
3307 * lockfile.c (__pthread_provide_lockfile): New variable.
3308 * pthread.c (__pthread_require_lockfile): New variable.
3309 * cancel.c (__pthread_require_lockfile): New variable.
3311 2001-07-31 Ulrich Drepper <drepper@redhat.com>
3313 * tst-context.c (threadfct): Initialize context before calling
3316 * Examples/ex17.c: Make sure test thread is around long enough.
3318 2001-07-26 kaz Kojima <kkojima@rr.iij4u.or.jp>
3320 * sysdeps/sh/pt-machine.h (THREAD_SELF, INIT_THREAD_SELF): Defined.
3322 2001-07-24 Ulrich Drepper <drepper@redhat.com>
3324 * tst-context.c (main): Print explanation before bailing out
3325 because context handling is not supported.
3327 2001-07-23 Ulrich Drepper <drepper@redhat.com>
3329 * Makefile (tests): Add tst-context.
3330 * tst-context.c: New file.
3332 * sysdeps/pthread/bits/stdio-lock.h: Define
3333 _IO_cleanup_region_start_noarg.
3335 2001-07-23 Jakub Jelinek <jakub@redhat.com>
3337 * sysdeps/alpha/pt-machine.h (FLOATING_STACKS): Define.
3338 (ARCH_STACK_MAX_SIZE): Define.
3339 * sysdeps/sparc/sparc32/pt-machine.h: Likewise.
3340 * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
3342 2001-07-19 Jakub Jelinek <jakub@redhat.com>
3344 * sysdeps/i386/useldt.h: Fix typo in ARCH_STACK_MAX_SIZE comment.
3346 * sysdeps/ia64/pt-machine.h (FLOATING_STACKS): Define.
3347 (ARCH_STACK_MAX_SIZE): Define.
3348 * manager.c (pthread_allocate_stack): Handle FLOATING_STACKS with
3349 NEED_SEPARATE_REGISTER_STACK.
3351 2001-07-16 Andreas Schwab <schwab@suse.de>
3353 * Makefile (before-compile): Don't add $(objpfx)crti.o.
3354 (omit-deps): Add crti.
3355 ($(objpfx)libpthread.so): Depend on $(objpfx)crti.o, but make sure
3356 it is filtered out of the link command.
3358 2001-07-16 Ulrich Drepper <drepper@redhat.com>
3360 * pthread.c (pthread_initialize): For FLOATING_STACKS don't bother
3361 to find the right value for __pthread_initial_thread_bos, it's not
3362 used. If not FLOATING_STACKS first run
3363 __pthread_init_max_stacksize.
3365 2001-06-16 H.J. Lu <hjl@gnu.org>
3367 * internals.h: Include <stackinfo.h>.
3369 * attr.c: Don't include <stackinfo.h> here.
3370 * cancel.c: Likewise.
3371 * manager.c: Likewise.
3372 * pthread.c: Likewise.
3373 * ptlongjmp.c: Likewise.
3375 2001-03-23 Matthew Wilcox <willy@ldl.fc.hp.com>
3377 * attr.c: Make _STACK_GROWS_UP work.
3378 * internals.h: Likewise.
3379 * manager.c: Likewise.
3380 * pthread.c: Likewise.
3382 2001-06-15 H.J. Lu <hjl@gnu.org>
3384 * pthread.c (__pthread_reset_main_thread): Fix a typo.
3386 2001-02-02 John S. Marvin <jsm@udlkern.fc.hp.com>
3388 * semaphore.h: Use struct _pthread_fastlock as an element of
3389 sem_t instead of an identical struct.
3390 * rwlock.c: Remove casts.
3391 * semaphore.c: Likewise.
3393 2001-04-30 Alan Modra <amodra@one.net.au>
3395 * sysdeps/unix/sysv/linux/hppa/pt-initfini.c: New.
3397 2001-05-25 Bruce Mitchener <bruce@cubik.org>
3399 * linuxthreads.texi: Spelling corrections.
3401 2001-05-25 Ulrich Drepper <drepper@redhat.com>
3403 * oldsemaphore.c (__old_sem_wait): Clear p_nextwaiting before
3404 returning successfully.
3405 Patch by Gene Cooperman <gene@ccs.neu.edu>.
3407 2001-05-24 Ulrich Drepper <drepper@redhat.com>
3409 * spinlock.c (__pthread_lock) [HAS_COMPARE_AND_SWAP]: Before doing any
3410 serious work try once whether the lock is uncontested.
3411 Remove duplicate reading of __status before loop.
3412 Change suggested by Hans Boehm <hans_boehm@hp.com>.
3414 * spinlock.h (__pthread_trylock): Remove need for oldstatus variable.
3415 (__pthread_alt_trylock): Likewise.
3417 2001-05-01 Kaz Kylheku <kaz@ashi.footprints.net>
3419 Memory barrier overhaul following line by line inspection.
3420 * mutex.c (pthread_once): Missing memory barriers added.
3421 * pthread.c (__pthread_wait_for_restart_signal,
3422 __pthread_timedsuspend_new, __pthread_restart_new): Added
3423 memory barriers ``just in case'' and for documentary value.
3424 * spinlock.c (__pthread_release): New inline function for releasing
3425 spinlock, to complement __pthread_acquire. Includes memory
3426 barrier prior to assignment to spinlock, and __asm __volatile
3427 dance to prevent reordering or optimization of the spinlock access.
3428 * spinlock.c (__pthread_unlock, __pthread_alt_lock,
3429 __pthread_alt_timedlock, __pthread_alt_unlock,
3430 __pthread_compare_and_swap): Updated to use new __pthread_release
3431 instead of updating spinlock directly.
3432 * spinlock.c (__pthread_lock, __pthread_unlock, wait_node_alloc,
3433 wait_node_free, wait_node_dequeue, __pthread_alt_lock,
3434 __pthread_alt_timedlock, __pthread_alt_unlock, __pthread_acquire):
3435 Memory barrier overhaul. Lots of missing memory barriers added,
3436 a couple needless ones removed.
3437 * spinlock.c (__pthread_compare_and_swap): testandset optimization
3438 removed, just calls __pthread_acquire, which has the new read
3439 barrier in it before its testandset.
3441 2001-05-20 Roland McGrath <roland@frob.com>
3443 * Makeconfig: New file, variables used to be in main libc Makeconfig.
3445 2001-05-09 Geoff Keating <geoffk@redhat.com>
3447 * sysdeps/powerpc/pt-machine.h
3448 (HAS_COMPARE_AND_SWAP_WITH_RELEASE_SEMANTICS): Define.
3449 (__compare_and_swap): Remove memory barriers.
3450 (__compare_and_swap_with_release_semantics): New function.
3452 2001-04-24 Andreas Jaeger <aj@suse.de>
3454 * wrapsyscall.c: send* and recv* return ssize_t.
3456 * sysdeps/pthread/timer_getoverr.c (timer_getoverrun): Unlock the
3457 mutex instead of double locking it.
3458 Reported by Pierre Artaud <partaud@sodatec.com>.
3460 2001-04-23 Ulrich Drepper <drepper@redhat.com>
3462 * sysdeps/pthread/getcpuclockid.c: Make function generic, test
3463 using #ifdef whether the clock is available.
3464 * sysdeps/unix/sysv/linux/i386/getcpuclockid.c: Removed.
3466 * sysdeps/ia64/Versions: New file.
3468 * sysdeps/unix/sysv/linux/ia64/pt-initfini.c (_init): We don't
3469 have to call __gmon_start__ in the libpthread DSO.
3470 * sysdeps/pthread/pt-initfini.c (_init): Likewise.
3472 * Makefile (libpthread-routines): Add ptclock_gettime and
3474 * internals.h: Don't use cpuclock-init.h definitions, use
3475 hp-timing.h definitions.
3476 * pthread.c: Likewise.
3477 * manager.c: Likewise.
3478 * ptclock_gettime.c: New file.
3479 * ptclock_settime.c: New file.
3480 * internals.h: Fix parameter type for __pthread_clock_gettime and
3481 __pthread_clock_settime.
3483 * sysdeps/i386/i586/ptclock_gettime.c: Removed.
3484 * sysdeps/i386/i586/ptclock_settime.c: Removed.
3485 * sysdeps/i386/i586/Makefile: Removed.
3487 2001-04-22 Ulrich Drepper <drepper@redhat.com>
3489 * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define _POSIX_ASYNCH_IO.
3490 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
3492 2001-04-21 Andreas Jaeger <aj@suse.de>
3494 * sysdeps/pthread/timer_routines.c (thread_func): Add noreturn
3495 attribute, remove statements that will never be executed.
3496 (thread_func): Remove mutex_unlock call since it's never executed.
3497 (thread_func): Fix comment as suggested by Jakub Jelinek.
3499 * manager.c (__pthread_manager): Add noreturn
3501 (pthread_start_thread): Likewise, remove return statement.
3502 (pthread_start_thread_event): Likewise.
3503 Add noreturn attribute for pthread_handle_exit.
3504 * weaks.c: Add noreturn attribute for pthread_exit.
3506 * internals.h: Add __pthread_clock_gettime and
3507 __pthread_clock_settime prototypes.
3509 2001-04-21 Ulrich Drepper <drepper@redhat.com>
3511 * internals.h: Include <cpuclock-init.h>.
3512 (struct _pthread_descr_struct): Add p_cpuclock_offset field if
3513 CPUCLOCK_VARDEF is defined.
3514 * pthread.c (__pthread_initialize_minimal): Initialize
3515 p_cpuclock_offset field for main thread if CPUCLOCK_INIT is defined.
3516 * manager.c (pthread_start_thread): Set p_cpuclock_offset field
3517 for new thread to current CPU clock value.
3519 * sysdeps/i386/useldt.h: Extend all the macros to handle 8-byte values.
3521 * sysdeps/i386/i586/Makefile: New file.
3522 * sysdeps/i386/i586/Versions: New file.
3523 * sysdeps/i386/i586/ptclock_gettime.c: New file.
3524 * sysdeps/i386/i586/ptclock_settime.c: New file.
3525 * sysdeps/i386/i686/Implies: New file.
3527 2001-04-18 Jakub Jelinek <jakub@redhat.com>
3529 * sysdeps/unix/sysv/linux/sparc/sparc64/Makefile: Put specs into
3530 $generated, not $postclean-generated.
3532 2001-04-18 Andreas Jaeger <aj@suse.de>
3534 * Makefile (otherlibs): Added.
3536 2001-04-18 Jakub Jelinek <jakub@redhat.com>
3538 * sysdeps/unix/sysv/linux/sparc/sparc64/Makefile: New file.
3540 2001-04-16 Ulrich Drepper <drepper@redhat.com>
3542 * signals.c (sigwait): NSIG is no signal number. Block all
3543 signals while in signal handler for signals in SET.
3544 Patch by Manfred Spraul <manfred@colorfullife.com>.
3546 2001-04-12 Ulrich Drepper <drepper@redhat.com>
3548 * tst-cancel.c: Disable most tests. Add new test where all
3549 cleanup handlers must run.
3550 * Makefile (tests): Add tst-cancel again.
3552 * cancel.c (__pthread_perform_cleanup): Correct condition for
3553 leaving cleanup loop early.
3555 * sysdeps/i386/Makefile: Make sure gcc uses a frame pointer for
3556 all the files which use CURRENT_STACK_FRAME.
3557 * sysdeps/i386/pt-machine.h (CURRENT_STACK_FRAME): Define using
3558 __builtin_frame_address.
3559 * sysdeps/i386/i686/pt-machine.h: Likewise.
3561 2001-04-11 Ulrich Drepper <drepper@redhat.com>
3563 * Makefile (tests): Comment out tst-cancel for now.
3565 * tst-cancel.c (main): Cleanup 4 is supposed to run. Create
3566 temporary file in object directory.
3567 * Makefile: Don't allow inlining when compiling tst-cancel.c.
3568 Pass $(objpfx) to tst-cancel.
3570 2001-04-11 David S. Miller <davem@redhat.com>
3572 * sysdeps/sparc/sparc32/pt-machine.h (stack_pointer): Advance
3573 up closer to user local variables so that new cleanup heuristics work.
3574 * sysdeps/sparc/sparc64/pt-machine.h (stack_pointer): Likewise.
3576 2001-04-11 Ulrich Drepper <drepper@redhat.com>
3578 * cancel.c (_pthread_cleanup_push): Catch invalid __prev buffer
3580 (_pthread_cleanup_push_defer): Likewise.
3582 * tst-cancel.c (main): Fix loop printing cleanup output.
3584 2001-04-10 kaz Kojima <kkojima@rr.iij4u.or.jp>
3586 * sysdeps/sh/pspinlock.c (__pthread_spin_lock): Fix a reverse
3588 (__pthread_spin_trylock): Likewise.
3589 * sysdeps/sh/pt-machine.h (testandset): Likewise.
3591 2001-04-10 Ulrich Drepper <drepper@redhat.com>
3593 * join.c (pthread_exit): Move code to new function __pthread_do_exit
3594 which takes an extra parameter with the current frame pointer.
3595 Call new function with CURRENT_STACK_FRAME.
3596 (__pthread_do_exit): New function. Call __pthread_perform_cleanup
3597 with the new parameter.
3598 (pthread_join): Call __pthread_do_exit instead of pthread_exit.
3599 * cancel.c (__pthread_perform_cleanup): Takes extra parameter. Use
3600 this parameter as the initial value the cleanup handler records are
3601 compared against. No active cleanup handler record must have an
3602 address lower than the previous one and the initial record must be
3603 above (below on PA) the frame address passed in.
3604 (pthread_setcancelstate): Call __pthread_do_exit instead of
3606 (pthread_setcanceltype): Likewise.
3607 (pthread_testcancel): Likewise.
3608 (_pthread_cleanup_pop_restore): Likewise.
3609 * condvar.c (pthread_cond_wait): Likewise.
3610 (pthread_cond_timedwait_relative): Likewise.
3611 * manager.c (pthread_start_thread): Likewise.
3612 * oldsemaphore.c (__old_sem_wait): Likewise.
3613 * pthread.c (pthread_handle_sigcancel): Likewise.
3614 * semaphore.c (__new_sem_wait): Likewise.
3615 (sem_timedwait): Likewise.
3616 * ptlongjmp.c (pthread_cleanup_upto): Also use current stack frame
3617 to limit the cleanup handlers which get run.
3618 * internals.h: Add prototype for __pthread_do_exit. Adjust prototype
3619 for __pthread_perform_cleanup.
3621 * Makefile (tests): Add tst-cancel.
3622 * tst-cancel.c: New file.
3624 2001-04-08 Hans-Peter Nilsson <hp@axis.com>
3626 * sysdeps/cris/pt-machine.h: New file.
3627 * sysdeps/cris/pspinlock.c: New file.
3629 2001-04-09 Hans-Peter Nilsson <hp@axis.com>
3631 * shlib-versions: Add case for Linux on CRIS.
3633 2001-03-26 Ulrich Drepper <drepper@redhat.com>
3635 * attr.c (pthread_getattr_np): Correct computation of stack size
3636 for machiens with register stack.
3638 * Examples/ex17.c (main): Correct detection of failed mmap call.
3640 2001-03-21 Jakub Jelinek <jakub@redhat.com>
3642 * pthread.c (__pthread_initialize_manager): Fix a typo.
3644 2001-03-21 Jakub Jelinek <jakub@redhat.com>
3646 * attr.c (__pthread_attr_setstack): Fix alignment check.
3647 (pthread_getattr_np): __stackaddr is top of stack, not bottom.
3648 * Makefile (tests): Add ex17 test.
3649 * Examples/ex17.c: New test.
3651 2001-03-20 Ulrich Drepper <drepper@redhat.com>
3653 * Makefile: Define -D_RPC_THREAD_SAFE_ for cancel.c.
3654 * cancel.c (__pthread_perform_cleanup): Call __rpc_thread_destroy.
3655 * sysdeps/pthread/bits/libc-tsd.h: Define _LIBC_TSD_KEY_VARS.
3657 2001-03-18 Ulrich Drepper <drepper@redhat.com>
3659 * Makefile: When generating DSO link with libc_nonshared.a.
3661 2001-02-26 Jakub Jelinek <jakub@redhat.com>
3663 * signals.c (pthread_sighandler): Use CALL_SIGHANDLER.
3665 2001-02-23 Jakub Jelinek <jakub@redhat.com>
3667 * internals.h (__pthread_init_max_stacksize): New prototype.
3668 * attr.c (__pthread_attr_setstacksize): Call
3669 __pthread_init_max_stacksize if not yet initialized.
3670 * pthread.c (__pthread_init_max_stacksize): New function.
3671 (__pthread_initialize_manager): Call it.
3672 Patch by <dtc@cmucl.cons.org>.
3674 2001-03-16 Ulrich Drepper <drepper@redhat.com>
3676 * attr.c (pthread_getattr_np): Fix __stacksize computation for IA-64.
3678 2001-03-13 Martin Schwidefsky <schwidefsky@de.ibm.com>
3680 * shlib-versions: Add rule for Linux on 64 bit S/390.
3681 * sysdeps/s390/s390-64/pt-machine.h: New file.
3682 * sysdeps/unix/sysv/linux/s390/s390-64/pt-initfini.c: New file.
3684 2001-03-13 Martin Schwidefsky <schwidefsky@de.ibm.com>
3686 * sysdeps/s390/pt-machine.h: Move to...
3687 * sysdeps/s390/s390-32/pt-machine.h: ...here.
3688 Add defines for FLOATING_STACK and ARCH_STACK_MAX_SIZE.
3690 2001-03-15 Ulrich Drepper <drepper@redhat.com>
3692 * Versions [libpthread] (GLIBC_2.2.3): Add pthread_getattr_np.
3693 * attr.c: Implement pthread_getattr_np.
3694 * sysdeps/pthread/pthread.h: Add prototype for pthread_getattr_np.
3695 * internals.h (struct _pthread_descr_struct): Add p_inheritsched.
3696 * manager.c (pthread_handle_create): Initialize p_inheritsched.
3698 2001-03-09 Martin Schwidefsky <schwidefsky@de.ibm.com>
3700 * sysdeps/unix/sysv/linux/s390/pt-initfini.c: Use 0x07 padding for
3703 2001-02-20 Hans Boehm <hans_boehm@hp.com>
3705 * manager.c (manager_mask): Removed static vesion. Now always local
3706 to __pthread_manager().
3707 (manager_mask_all): Removed completely.
3708 (__pthread_manager): Remove manager_mask_all initialization.
3709 (pthread_handle_create): Remove code to set and reset signal mask
3710 around __clone2() calls.
3712 2001-02-17 Jakub Jelinek <jakub@redhat.com>
3714 * spinlock.c (__pthread_lock): Force lock->__status to be read from
3715 memory on every spin.
3717 2001-02-10 Andreas Jaeger <aj@suse.de>
3719 * Makefile (extra-objs): New.
3721 2001-02-09 Jakub Jelinek <jakub@redhat.com>
3723 * sysdeps/pthread/pt-initfini.c (call_initialize_minimal): Add
3724 __pthread_initialize_minimal prototype.
3726 2001-02-08 kaz Kojima <kkojima@rr.iij4u.or.jp>
3728 * sysdeps/unix/sysv/linux/sh/pt-initfini.c: New file.
3730 2001-02-06 Martin Schwidefsky <schwidefsky@de.ibm.com>
3732 * sysdeps/unix/sysv/linux/s390/pt-initfini.c: New file.
3734 2001-02-06 Ulrich Drepper <drepper@redhat.com>
3736 * sysdeps/unix/sysv/linux/ia64/pt-initfini.c: First attempt to fix the
3737 broken code. Patch by Jes Sorensen.
3739 2001-02-06 Andreas Jaeger <aj@suse.de>
3741 * sysdeps/pthread/pthread.h: Move __pthread_initialize from here
3743 * internals.h: ...here.
3745 2001-02-05 Jes Sorensen <jes@linuxcare.com>
3747 * sysdeps/unix/sysv/linux/ia64/pt-initfini.c: New file.
3749 2001-02-02 Ulrich Drepper <drepper@redhat.com>
3751 * Versions: Remove __pthread_initialize_minimal.
3753 2001-02-01 Ulrich Drepper <drepper@redhat.com>
3755 * Makefile: Add rules to build crti.o and make it being used in
3756 building libpthread.so.
3757 * sysdeps/i386/Makefile: New file.
3758 * sysdeps/pthread/pt-initfini.c: New file.
3760 * pthread.c: Cleanups.
3762 2001-01-28 Andreas Jaeger <aj@suse.de>
3764 * oldsemaphore.c (__old_sem_init): Adjust for last change.
3765 * sysdeps/pthread/bits/libc-lock.h: Likewise.
3766 * spinlock.c: Likewise.
3768 2001-01-28 Ulrich Drepper <drepper@redhat.com>
3770 * sysdeps/pthread/bits/initspin.h: Make all names namespace clean.
3771 * sysdeps/unix/sysv/linux/hppa/bits/initspin.h: Likewise.
3772 * manager.c: Adjust for namespace cleanup in bits/initspin.h.
3773 * pthread.c: Likewise.
3774 * spinlock.h: Likewise.
3775 * sysdeps/pthread/pthread.h: Likewise.
3777 2001-01-26 Ulrich Drepper <drepper@redhat.com>
3779 * sysdeps/pthread/bits/pthreadtypes.h: Define pthread_attr_t also
3780 as struct __pthread_attr_s.
3782 * semaphore.h (sem_t): Cleanup namespace, rename status and
3785 2001-01-13 Jakub Jelinek <jakub@redhat.com>
3787 * pthread.c (pthread_onexit_process): Clear
3788 __pthread_manager_thread_bos after freeing it.
3789 * Makefile (tests): Add ex16.
3790 * Examples/ex16.c: New file.
3792 2001-01-11 Jakub Jelinek <jakub@redhat.com>
3794 * Makefile (CFLAGS-pthread.c): Pass -DHAVE_Z_NODELETE if ld supports
3796 * pthread.c (pthread_exit_process): Rename to...
3797 (pthread_onexit_process): ...this.
3798 (pthread_atexit_process, pthread_atexit_retcode): New.
3799 (pthread_initialize): Call __cxa_atexit instead of __cxa_on_exit
3800 and only if HAVE_Z_NODELETE is not defined.
3801 (__pthread_initialize_manager): Register pthread_atexit_retcode
3804 2001-01-11 Ulrich Drepper <drepper@redhat.com>
3806 * pthread.c (pthread_initialize): Use __cxs_on_exit not __cxa_atexit.
3808 2001-01-11 Jakub Jelinek <jakub@redhat.com>
3810 * Makefile (tests): Add ex15.
3811 * Examples/ex15.c: New test.
3813 2001-01-08 Ulrich Drepper <drepper@redhat.com>
3815 * pthread.c (pthread_exit_process): Free memory allocated for
3818 2000-12-31 Ulrich Drepper <drepper@redhat.com>
3820 * manager.c (pthread_alloca_stack): Remove MAP_FIXED from mmap calls.
3821 (pthread_free): Always unmap the stack. It's safe now that we don't
3822 use MAP_FIXED to allocate stacks.
3824 2000-12-31 Ulrich Drepper <drepper@redhat.com>
3826 * sysdeps/powerpc/pspinlock.c: Don't include pt-machine.h here.
3828 * manager.c (pthread_allocate_stack): Prepare for removal of MAP_FIXED.
3830 2000-11-15 Wolfram Gloger <wg@malloc.de>
3832 * manager.c (pthread_free): [!FLOATING_STACKS]: Only remap the
3833 stack to PROT_NONE, don't unmap it, avoiding collisions with malloc.
3835 2000-12-27 Andreas Jaeger <aj@suse.de>
3837 * Examples/ex13.c: Make local functions static.
3838 * ecmutex.c: Likewise.
3839 * joinrace.c: Likewise.
3840 * Examples/ex14.c: Likewise.
3842 * Examples/ex2.c: Make local functions static; reformat.
3843 * Examples/ex1.c: Likewise.
3844 * Examples/ex4.c: Likewise.
3845 * Examples/ex5.c: Likewise.
3846 * Examples/ex7.c: Likewise.
3848 * oldsemaphore.c: Add prototypes to shut up GCC.
3849 * pt-machine.c: Likewise.
3851 * weaks.c: Add prototype for pthread_exit.
3853 * internals.h: Add some prototypes, format prototypes and add
3855 Move __libc_waitpid prototype to include/sys/wait.h.
3857 * rwlock.c: Include <bits/libc-lock.h> for prototypes.
3858 * mutex.c: Likewise.
3859 * specific.c: Likewise.
3860 * ptfork.c: Likewise.
3862 * lockfile.c: Include internals.h to get prototypes.
3863 * events.c: Likewise.
3864 * sysdeps/alpha/pspinlock.c: Likewise.
3865 * sysdeps/arm/pspinlock.c: Likewise.
3866 * sysdeps/hppa/pspinlock.c: Likewise.
3867 * sysdeps/i386/pspinlock.c: Likewise.
3868 * sysdeps/ia64/pspinlock.c: Likewise.
3869 * sysdeps/m68k/pspinlock.c: Likewise.
3870 * sysdeps/mips/pspinlock.c: Likewise.
3871 * sysdeps/powerpc/pspinlock.c: Likewise.
3872 * sysdeps/s390/pspinlock.c: Likewise.
3873 * sysdeps/sh/pspinlock.c: Likewise.
3874 * sysdeps/sparc/sparc32/pspinlock.c: Likewise.
3875 * sysdeps/sparc/sparc32/sparcv9/pspinlock.c: Likewise.
3876 * sysdeps/sparc/sparc64/pspinlock.c: Likewise.
3878 2000-12-27 Ulrich Drepper <drepper@redhat.com>
3880 * attr.c (__pthread_attr_setstack): Fix setting of __stackaddr element.
3881 (__pthread_attr_getstack): Return correct address.
3882 Add warnings for using pthread_attr_getstackaddr and
3883 pthread_attr_setstackaddr.
3885 2000-12-26 Ulrich Drepper <drepper@redhat.com>
3887 * Examples/ex6.c (test_thread): Make static.
3888 * Examples/ex12.c (test_thread): Make static and add noreturn
3891 2000-12-18 Jes Sorensen <jes@linuxcare.com>
3893 * linuxthreads/sysdeps/ia64/pt-machine.h: __compare_and_swap
3894 and compare_and_swap_with_release_semantics returns int not long.
3896 2000-12-17 Andreas Jaeger <aj@suse.de>
3898 * sysdeps/s390/pt-machine.h (testandset): Use long int as return
3900 * sysdeps/arm/pt-machine.h (testandset): Likewise.
3901 * sysdeps/hppa/pt-machine.h (testandset): Likewise.
3902 * sysdeps/m68k/pt-machine.h (testandset): Likewise.
3903 * sysdeps/sh/pt-machine.h (testandset): Likewise.
3904 * sysdeps/sparc/sparc32/pt-machine.h (testandset): Likewise.
3905 * sysdeps/sparc/sparc64/pt-machine.h (testandset): Likewise.
3907 2000-12-17 Ulrich Drepper <drepper@redhat.com>
3909 * sysdeps/i386/pt-machine.h (testandset): Adjust for prototype change.
3910 * sysdeps/i386/i686/pt-machine.h (testandset): Likewise.
3912 2000-12-17 Andreas Jaeger <aj@suse.de>
3914 * internals.h: Add prototypes for testandset and
3915 __compare_and_swap to shut up gcc warnings.
3917 2000-12-06 Wolfram Gloger <wg@malloc.de>
3919 * join.c (pthread_detach): Allow case where the thread has already
3922 2000-12-05 Andreas Jaeger <aj@suse.de>
3924 * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Don't set mips2.
3925 * sysdeps/mips/pt-machine.h (testandset): Likewise.
3926 (__compare_and_swap): Likewise.
3927 Patches by Maciej W. Rozycki <macro@ds2.pg.gda.pl>.
3929 2000-11-20 Jakub Jelinek <jakub@redhat.com>
3931 * Examples/ex3.c (main): Cast int to long before casting to void *.
3932 (search): Cast void * to long, not int.
3933 * Examples/ex8.c (main, thread): Similarly.
3934 * Examples/ex11.c (main): Similarly.
3935 * Examples/ex14.c (worker, do_test): Similarly.
3936 * ecmutex.c (worker, do_test): Similarly.
3937 (nlocks): Cast to int.
3939 2000-11-08 Bruce Mitchener <bruce@cubik.org>
3941 * linuxthreads.texi: Add documentation for pthreads attributes
3942 guardsize, stackaddr, stacksize, and stack. Fix typo in previous
3943 patch. Document pthread_[sg]etconcurrency(). Mark
3944 pthread_mutexattr_[sg]ettype() as POSIX rather than GNU.
3946 2000-11-07 Ulrich Drepper <drepper@redhat.com>
3948 * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_MESSAGE_PASSING):
3950 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
3951 Reported by Christopher Yeoh <cyeoh@linuxcare.com.au>.
3953 2000-11-06 Ulrich Drepper <drepper@redhat.com>
3955 * cancel.c (pthread_cancel): Always set p_canceled, even if we are
3956 not doing it right now.
3957 Reported by Kaz Kylheku <kaz@ashi.footprints.net>.
3959 2000-10-30 Ulrich Drepper <drepper@redhat.com>
3961 * Examples/ex4.c (main): Don't use exit() to avoid warning with
3964 2000-10-29 Ulrich Drepper <drepper@redhat.com>
3966 * attr.c (__pthread_attr_setguardsize): Don't round guardsize
3967 here. Reported by Bruce Mitchener <bruce@cubik.org>.
3969 * linuxthreads.texi: Changes terminology to 'type' from 'kind' when
3970 discussing mutexes. (As per the Unix98 name for the API.)
3971 Changes documentation for pthread_mutexattr_setkind_np() and
3972 pthread_mutexattr_getkind_np() over to the Unix98 APIs for the
3973 same: pthread_mutexattr_settype() and pthread_mutexattr_gettype().
3974 Changes references to PTHREAD_MUTEXATTR_FAST_NP to
3975 PTHREAD_MUTEXATTR_ADAPTIVE_NP.
3976 Begins to introduce discussion of the ``timed'' mutex type. This
3977 discussion is currently incomplete.
3978 Patch by Bruce Mitchener <bruce@cubik.org>.
3980 2000-10-26 Kazumoto Kojima <kkojima@rr.iij4u.or.jp>
3981 Yutaka Niibe <gniibe@chroot.org>
3983 * sysdeps/sh/pt-machine.h (testandset): Since the operand of TAS.B
3984 has restrictions, use register.
3986 2000-10-23 Andreas Schwab <schwab@suse.de>
3988 * Examples/ex14.c (TIMEOUT): Override default timeout.
3990 2000-10-16 Ulrich Drepper <drepper@redhat.com>
3992 * specific.c: Protect tsd array modification in thread data
3993 structures by getting the thread lock in pthread_key_delete and
3994 __pthread_destroy_specifics.
3995 Patch by Wolfram Gloger <Wolfram.Gloger@dent.med.uni-muenchen.de>.
3997 2000-10-12 Alan Modra <alan@linuxcare.com.au>
3999 * sysdeps/pthread/bits/initspin.h: New file.
4000 * spinlock.h: Move LOCK_INITIALIZER definition to <bits/initspin.h>.
4001 (__pthread_init_lock): Initialize lock with LT_SPINLOCK_INIT.
4002 (__pthread_alt_init_lock): Likewise.
4003 (__pthread_alt_trylock): Release lock with LT_SPINLOCK_INIT.
4005 2000-10-12 David Huggins-Daines <dhd@linuxcare.com>
4007 * oldsemaphore.c (__old_sem_init): Release lock with
4008 LT_SPINLOCK_INIT, not zero.
4009 * spinlock.c (__pthread_unlock): Likewise.
4010 (__pthread_alt_lock): Likewise.
4011 (__pthread_alt_timedlock): Likewise.
4012 (__pthread_alt_unlock): Likewise.
4013 * sysdeps/pthread/bits/libc-lock.h: Initialize locks with
4014 LT_SPINLOCK_INIT if it is non-zero. Likewise for init-once flags.
4015 * sysdeps/pthread/pthread.h: Include bits/initspin.h. Use
4016 LT_SPINLOCK_INIT do initialize spinlocks not 0.
4018 2000-10-12 David Huggins-Daines <dhd@linuxcare.com>
4020 * shlib-versions: Add version definitions for hppa-linux.
4022 2000-10-12 Alan Modra <alan@linuxcare.com.au>
4024 * sysdeps/hppa/pspinlock.c: New file.
4025 * sysdeps/hppa/pt-machine.h: New file.
4026 * sysdeps/unix/sysv/linux/hppa/bits/initspin.h: New file.
4028 2000-10-05 Jakub Jelinek <jakub@redhat.com>
4030 * mutex.c (__pthread_mutex_destroy): Correct test of
4031 busy mutex for mutexes using alternate fastlocks.
4032 Patch by dtc@cmucl.cons.org.
4034 2000-09-28 Martin Schwidefsksy <schwidefsky@de.ibm.com>
4036 * sysdeps/s390/pt-machine.h: Make %a0 the thread register.
4038 2000-09-28 Ulrich Drepper <drepper@redhat.com>
4040 * mutex.c (__pthread_mutex_unlock): For PTHREAD_MUTEX_RECURSIVE_NP
4041 test for owner first.
4042 Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
4044 * cancel.c (pthread_cancel): Don't do anything if cancelation is
4047 2000-09-26 Ulrich Drepper <drepper@redhat.com>
4049 * spinlock.h (__pthread_set_own_extricate_if): Optimize a bit.
4050 Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
4052 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Remove
4053 _POSIX_MONOTONIC_CLOCK.
4055 * spinlock.h (__pthread_set_own_extricate_if): Add back locking
4058 2000-09-20 Andreas Jaeger <aj@suse.de>
4060 * pthread.c [!__ASSUME_REALTIME_SIGNALS]: Make inclusion of
4061 "testrtsig.h" conditional.
4063 2000-09-11 Ulrich Drepper <drepper@redhat.com>
4065 * sysdeps/pthread/pthread.h: Declare pthread_attr_getstack and
4066 pthread_attr_setstack.
4067 * Versions [libpthread] (GLIBC_2.2): Export pthread_attr_getstack and
4068 pthread_attr_setstack.
4069 * attr.c (pthread_attr_getstack, pthread_attr_setstack): New functions.
4071 2000-09-05 Ulrich Drepper <drepper@redhat.com>
4073 * Examples/ex14.c: New file.
4074 * Makefile (tests): Add ex14.
4076 * mutex.c (__pthread_mutex_unlock): Correct test for already unlocked
4077 mutex. Patch by dtc@cmucl.cons.org.
4079 * ecmutex.c: New file.
4080 * Makefile (tests): Add ecmutex.
4082 2000-09-04 H.J. Lu <hjl@gnu.org>
4084 * attr.c (__pthread_attr_setguardsize): Use page_roundup
4085 instead of roundup to round up to the page size.
4087 2000-09-03 Mark Kettenis <kettenis@gnu.org>
4089 * manager.c (pthread_exited): Correctly report event as TD_REAP
4090 instead of TD_DEATH. Fix comments.
4092 2000-09-03 Ulrich Drepper <drepper@redhat.com>
4094 * spinlock.h (testandset): Add cast to avoid warning.
4095 Patch by Franz Sirl <Franz.Sirl-kernel@lauterbach.com>.
4097 2000-09-02 Andreas Jaeger <aj@suse.de>
4099 * sysdeps/pthread/timer_routines.c: Include stdlib.h for abort
4102 2000-09-01 Ulrich Drepper <drepper@redhat.com>
4104 * sysdeps/pthread/bits/stdio-lock.h (_IO_cleanup_region_start):
4105 Fix typo in last patch (_mode -> _flags).
4107 * sysdeps/pthread/bits/stdio-lock.h (_IO_cleanup_region_start):
4108 Provide definition which respects _IO_USER_LOCK flag.
4110 2000-08-30 Ulrich Drepper <drepper@redhat.com>
4112 * manager.c (pthread_allocate_stack): Clear descriptor only if not
4115 2000-08-25 Ulrich Drepper <drepper@redhat.com>
4117 * Makefile: Add rules to build and run unload.
4118 * unload.c: New file.
4120 * pthread.c (pthread_exit_process): Move thread_self use inside `if'.
4122 * sysdeps/pthread/pthread.h
4123 (PTHREAD_ADAPTIVE_MUTEX_INITIALIZER_NP): Defined.
4124 (PTHREAD_ERRORCHECK_MUTEX_INITIALIZER_NP: Defined.
4126 2000-08-24 Andreas Jaeger <aj@suse.de>
4128 * Examples/ex13.c: Include <string.h> for strerror prototype and
4129 <stdlib.h> for abort prototype.
4130 (pthr_cond_signal_mutex): Rewrite to silence GCC.
4131 (thread_start): Remove unused variable err.
4132 (main): Silence GCC warnings.
4134 2000-08-22 Andreas Jaeger <aj@suse.de>
4136 * Examples/ex13.c: New test by Kurt Garloff <garloff@suse.de>.
4138 * Makefile (tests): Add ex13.
4140 2000-08-20 Ulrich Drepper <drepper@redhat.com>
4142 * semaphore.h: Add restrict where required by AGd4.
4143 * sysdeps/pthread/pthread.h: Likewise.
4144 * sysdeps/pthread/unix/sysv/linux/bits/sigthread.h: Likewise.
4146 2000-08-15 Ulrich Drepper <drepper@redhat.com>
4148 * Makefile (tests): Add ex12. Add rule to build it.
4149 * Examples/ex12.c: New file.
4151 2000-08-13 Ulrich Drepper <drepper@redhat.com>
4153 * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define _POSIX_SEMAPHORES
4154 even though the implementation is not quite complete (but it reports
4155 it). Define _POSIX_MESSAGE_PASSING to -1.
4156 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
4158 2000-08-12 Andreas Jaeger <aj@suse.de>
4160 * sysdeps/mips/pt-machine.h (testandset): Add .set mips2 for
4162 (__compare_and_swap): Likewise.
4163 * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Likewise.
4165 2000-08-10 Ulrich Drepper <drepper@redhat.com>
4167 * pthread.c (__pthread_initial_thread): Initialize p_errnop and
4168 p_h_errnop correctly and not to NULL.
4170 2000-08-05 Ulrich Drepper <drepper@redhat.com>
4172 * Banner: Bump version number to 0.9.
4174 2000-08-04 Ulrich Drepper <drepper@redhat.com>
4176 * Makefile (tests): Add tststack. Add rule to build the program.
4177 * tststack.c: New file.
4179 * internals.h: Declare __pthread_max_stacksize.
4180 * pthread.c (__pthread_max_stacksize): New variable.
4181 (__pthread_initialize_manager): Determine __pthread_initialize_manager
4183 * manager.c (thread_segment): Return always NULL if FLOATING_STACKS.
4184 (pthread_allocate_stack): Allow kernel to choose stack address if
4185 FLOATING_STACKS. This also handles variable-sized stacks.
4186 Always allocate stack and guardpage together. Use mprotect to
4187 change guardpage access.
4188 * sysdeps/i386/useldt.h: Define FLOATING_STACKS and
4189 ARCH_STACK_MAX_SIZE.
4191 * attr.c (__pthread_attr_setstacksize): Also test value against
4194 * manager.c (__pthread_nonstandard_stacks): Define only if
4195 THREAD_SELF is not defined.
4196 (pthread_allocate_stack): Always initialize gardaddr to a correct
4198 (pthread_handle_create): Unmap thread with one call.
4199 (pthread_free): Remove test for initial thread before removing stack.
4200 Unmap stack with one call.
4202 * pthread.c (__pthread_initial_thread): Initialize p_userstack to
4203 1 to avoid removing the stack.
4205 2000-07-27 Jes Sorensen <jes@linuxcare.com>
4207 * sysdeps/ia64/pspinlock.c (__pthread_spin_lock): Add
4208 load of spin lock to prime the cache before the atomic compare and
4209 exchange operation (cmpxchg4). This avoids the spinning on the
4210 cmpxchg4 instruction and reduces movement of the cache line back
4211 and forth between the processors (explanation by Asis K. Mallick
4212 from Intel). This basically makes the implementation operate the
4213 same as the Linux kernel implementation.
4215 * shlib-versions: Use GLIBC_2_2 for Linux/ia64.
4216 * sysdeps/ia64/pspinlock.c: New file.
4218 2000-08-03 Ulrich Drepper <drepper@redhat.com>
4220 * pthread.c: Move definition of __pthread_set_own_extricate_if...
4221 * spinlock.h: ...here. Remove locking.
4222 * internals.h: Remove __pthread_set_own_extricate_if prototype.
4224 * rwlock.c: Use THREAD_GETMEM And THREAD_SETMEM.
4225 (rwlock_rd_extricate_func): Don't determine self, let
4226 __pthread_lock do it.
4227 (rwlock_wr_extricate_func): Likewise.
4228 (rwlock_have_already): Optimize *pself handling a bit.
4230 * mutex.c: Use __builtin_expect.
4231 * pthread.c: Likewise.
4233 2000-08-02 Andreas Jaeger <aj@suse.de>
4235 * sysdeps/s390/pspinlock.c: New file.
4236 * sysdeps/s390/pt-machine.h: New file.
4237 Patches by Martin Schwidefsky <schwidefsky@de.ibm.com>.
4239 2000-07-12 Maciej W. Rozycki <macro@ds2.pg.gda.pl>
4241 * sysdeps/mips/pspinlock.c (__pthread_spin_lock): Implement for
4243 * sysdeps/mips/pt-machine.h (testandset): Likewise.
4245 2000-07-26 Andreas Jaeger <aj@suse.de>
4247 * pthread.c: Initialize p_sem_avail.
4249 2000-07-25 Ulrich Drepper <drepper@redhat.com>
4251 * internals.h (struct __pthread_descr_struct): Add p_sem_avail.
4252 * semaphore.c: Handle spurious wakeups.
4254 * sysdeps/pthread/pthread.h: Add back PTHREAD_MUTX_FAST_NP as an alias
4255 for PTHREAD_MUTEX_ADAPTIVE_NP for source code compatibility.
4257 * pthread.c (__pthread_set_own_extricate): Use THREAD_GETMEM.
4258 (__pthread_wait_for_restart): Likewise.
4260 * condvar.c (pthread_cond_wait): Also check whether thread is
4261 cancelable before aborting loop.
4262 (pthread_cond_timedwait): Likewise.
4264 * signals.c (pthread_sighandler): Remove special code to restrore
4266 (pthread_sighandler_t): Likewise.
4268 2000-07-25 Mark Kettenis <kettenis@gnu.org>
4270 * internals.h (__RES_PTHREAD_INTERNAL): Remove define.
4271 * pthread.c: Include <resolv.h>.
4272 (_res): Undefine. Add extern declaration.
4274 2000-07-24 Ulrich Drepper <drepper@redhat.com>
4276 * pthread.c (__pthread_initial_thread): Update initializer.
4277 (__pthread_manager_thread): Likewise.
4278 (pthread_initialize): Move setrlimit call to...
4279 (__pthread_initialize_manager): ...here.
4280 (__pthread_reset_main_thread): Reset also soft limit on stack size.
4282 * condvar.c: Handle spurious wakeups. [PR libc/1749].
4283 * internals.h (struct _pthread_descr_struct): Add p_condvar_avail.
4285 2000-07-21 Ulrich Drepper <drepper@redhat.com>
4287 * spinlock.h: If IMPLEMENT_TAS_WITH_CAS is defined use
4288 __compare_and_swap to define testandset.
4289 * sysdeps/powerpc/pt-machine.h: Add volatile to asms.
4290 Define IMPLEMENT_TAS_WITH_CAS.
4292 2000-07-20 Ulrich Drepper <drepper@redhat.com>
4294 * Makefile: Pass -z nodelete to linker for libpthread.so
4295 generation if it understand this option.
4297 2000-07-18 Mark Kettenis <kettenis@gnu.org>
4299 * manager.c (pthread_handle_create): Remove initialization of
4300 new_thread->p_res._sock.
4302 2000-07-19 Kaz Kylheku <kaz@ashi.footprints.net>
4304 Bugfixes to the variant of the code for machines with no compare
4307 * spinlock.c (__pthread_alt_lock, __pthread_alt_timedlock): Wait
4308 node was not being properly enqueued, due to failing to update
4309 the lock->__status field.
4311 * spinlock.c (__pthread_alt_timedlock): The oldstatus variable was
4312 being set inappropriately, causing the suspend function to be called
4313 with a null self pointer and crash.
4315 2000-07-18 Ulrich Drepper <drepper@redhat.com>
4317 * spinlock.h (__pthread_alt_trylock): Fix code used if no
4318 compare&swap is available.
4320 * spinlock.h (__pthread_trylock): Use __compare_and_swap, not
4323 * pthread.c (pthread_initialize): Don't use sysconf to determine
4324 whether the machine has more than one processor.
4326 * spinlock.c (__pthread_alt_timedlock): Add back one of the
4327 removed thread_self calls.
4329 2000-07-18 Kaz Kylheku <kaz@ashi.footprints.net>
4331 * spinlock.c (__pthread_alt_lock, __pthread_alt_timedlock): Changed
4332 __compare_and_swap to compare_and_swap in code which assumes
4333 compare swap is available.
4335 2000-07-18 Kaz Kylheku <kaz@ashi.footprints.net>
4337 * spinlock.c (__pthread_alt_lock, __pthread_alt_timedlock): Fixed
4338 bug whereby thr field of waitnode structure would not be correctly
4339 set unless a null self pointer is passed to the functions.
4340 Eliminated redundant calls to thread_self().
4342 2000-07-18 Jakub Jelinek <jakub@redhat.com>
4344 * pthread.c (__pthread_initialize_manager): Lock
4345 __pthread_manager_thread.p_lock before calling clone.
4347 2000-05-05 H.J. Lu <hjl@gnu.org>
4349 * sysdeps/ia64/pt-machine.h (__compare_and_swap): Change it to
4350 have acquire semantics.
4351 (__compare_and_swap_with_release_semantics): New inline
4353 (HAS_COMPARE_AND_SWAP_WITH_RELEASE_SEMANTICS): New macro.
4355 2000-01-28 Hans Boehm <hboehm@exch.hpl.hp.com>
4357 * manager.c: Fix the problem with signals at startup.
4358 Change the way that thread stacks are allocated on IA64.
4359 Clean up some of the guard page allocation stuff.
4361 1999-12-19 H.J. Lu <hjl@gnu.org>
4363 * internals.h (page_roundup): New.
4364 * attr.c (__pthread_attr_setguardsize); Use page_roundup
4366 * manager.c (pthread_allocate_stack): Make sure guardaddr is
4367 page aligned with page_roundup if NEED_SEPARATE_REGISTER_STACK
4370 1999-12-17 Hans Boehm <hboehm@exch.hpl.hp.com>
4372 * manager.c (pthread_allocate_stack): Unmap the stack top
4373 if failed to map the stack bottom.
4375 (pthread_free): Fix the guard page.
4377 * pthread.c (pthread_initialize): Set rlimit correctly for
4378 NEED_SEPARATE_REGISTER_STACK.
4380 1999-12-16 H.J. Lu <hjl@gnu.org>
4382 * pthread.c (__pthread_initialize_manager): Pass
4383 __pthread_manager_thread_bos instead of
4384 __pthread_manager_thread_tos to __clone2.
4386 1999-12-16 H.J. Lu <hjl@gnu.org>
4388 * manager.c (pthread_allocate_stack): Correct the calculation
4389 of "new_thread_bottom". Remove MAP_GROWSDOWN from mmap for
4392 1999-12-13 H.J. Lu <hjl@gnu.org>
4394 * sysdeps/ia64/pt-machine.h (__compare_and_swap): Added a stop
4395 bit after setting ar.ccv.
4397 1999-12-12 H.J. Lu <hjl@gnu.org>
4399 * manager.c (pthread_allocate_stack): Make the starting
4400 address of the stack bottom page aligned. FIXME: it may
4401 need changes in other places.
4402 (pthread_handle_create): Likewise.
4404 1999-12-11 Hans Boehm <hboehm@exch.hpl.hp.com>
4406 * manager.c (pthread_allocate_stack): Handle
4407 NEED_SEPARATE_REGISTER_STACK.
4408 (pthread_handle_create): Likewise.
4409 * pthread.c (__pthread_initialize_manager): Likewise.
4411 * sysdeps/ia64/pt-machine.h: Use r13 for thread pointer.
4413 1999-12-02 H.J. Lu <hjl@gnu.org>
4415 * sysdeps/ia64/pt-machine.h: New.
4417 2000-07-13 Ulrich Drepper <drepper@redhat.com>
4419 * wrapsyscall.c: Mark non-__ protected names as weak.
4422 2000-07-12 Bruno Haible <haible@clisp.cons.org>
4424 * Examples/ex8.c: Include <sys/wait.h>, not <wait.h>.
4426 2000-07-12 Ulrich Drepper <drepper@redhat.com>
4428 * spinlock.c: Fix code for TEST_FOR_COMPARE_AND_SWAP being defined.
4429 Add tests also to new alternative spinlock implementation.
4430 * spinlock.h: Likewise.
4431 Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
4433 2000-07-06 Ulrich Drepper <drepper@redhat.com>
4435 * Version: Export __sigaction.
4436 * signals.c: Define __sigaction alias. Use __libc_sigaction instead
4438 * pthread.c: Use __libc_sigaction instead of __sigaction.
4440 * condvar.c: Implement pthread_condattr_getpshared and
4441 pthread_condattr_setpshared.
4442 * mutex.c: Implement pthread_mutexattr_getpshared and
4443 pthread_mutexattr_setpshared.
4444 * Versions: Export new functions.
4445 * sysdeps/pthread/pthread.h: Add prototypes for new functions.
4447 * rwlock.c (pthread_rwlockattr_init): Use PTHREAD_PROCESS_PRIVATE.
4448 (pthread_rwlockattr_setpshared): Fail if PTHREAD_PROCESS_PRIVATE
4451 2000-07-04 Greg McGary <greg@mcgary.org>
4453 * sysdeps/pthread/bits/libc-lock.h: Remove BP_SYM from
4454 pragmas. Include bp-sym.h only if _LIBC.
4456 2000-07-04 Ulrich Drepper <drepper@redhat.com>
4458 * spinlock.c (__pthread_unlock): Properly place write barrier.
4459 Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
4461 2000-07-03 Ulrich Drepper <drepper@redhat.com>
4463 * spinlock.c: Replace fast spinlocks by adaptive spinlocks which are
4464 faster on SMP systems. No more emulation of compare&swap for adaptive
4466 * spinlock.h: Likewise.
4467 * sysdeps/pthread/pthread.h: Shuffle PTHREAD_MUTEX_* values around.
4468 Replace fast with adaptive mutex.
4469 * mutex.c: Rewrite for replacement of fast by adaptive mutex.
4470 * condvar.c: Likewise.
4471 * pthread.c: Define and initialize __pthread_smp_kernel variable.
4472 * internals.h: Declare __pthread_smp_kernel.
4473 * sysdeps/pthread/bits/pthreadtypes.h: Update comment of
4474 _pthread_fastlock structure.
4475 Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
4477 * pthread.c: Remove initialization to zero from global variables.
4479 2000-06-29 Jakub Jelinek <jakub@redhat.com>
4481 * shlib-versions: Make sparc64 GLIBC_2.2+ only.
4483 2000-06-28 Greg McGary <greg@mcgary.org>
4485 * weaks.c: Wrap BP_SYM () around weak extern declarations of
4486 pthread functions that have pointers in their return+arg signatures.
4488 2000-06-27 Greg McGary <greg@mcgary.org>
4490 * sysdeps/pthread/bits/libc-lock.h: Wrap BP_SYM () around weak
4491 extern declarations of pthread functions that have pointers in
4492 their return+arg signatures.
4494 2000-06-26 Ulrich Drepper <drepper@redhat.com>
4496 * Makefile (tests): Add ex11. Add rules to build it.
4497 * Examples/ex11.c: New file.
4498 * rwlock.c: Fix complete braindamaged previous try to implement
4501 * spinlock.c: Pretty print.
4503 2000-06-25 Ulrich Drepper <drepper@redhat.com>
4505 * Makefile (tests): Add ex10. Add rules to build it.
4506 * Versions [GLIBC_2.2] (libpthread): Add pthread_mutex_timedlock,
4507 pthread_rwlock_timedrdlock, and pthread_rwlock_timedwrlock.
4508 * condvar.c (pthread_cond_wait): Allow mutex of kind
4509 PTHREAD_MUTEX_TIMED_NP.
4510 (pthread_cond_timedwait_relative): Likewise.
4511 * mutex.c (__pthread_mutex_init): Default is PTHREAD_MUTEX_TIMED_NP.
4512 (__pthread_mutex_trylock): Use __pthread_alt_trylock for
4513 PTHREAD_MUTEX_ERRORCHECK_NP. Handle PTHREAD_MUTEX_TIMED_NP.
4514 (__pthread_mutex_lock): Use __pthread_alt_lock for
4515 PTHREAD_MUTEX_ERRORCHECK_NP. Handle PTHREAD_MUTEX_TIMED_NP.
4516 (__pthread_mutex_timedlock): New function.
4517 (__pthread_mutex_unlock): Use __pthread_alt_unlock for
4518 PTHREAD_MUTEX_ERRORCHECK_NP. Handle PTHREAD_MUTEX_TIMED_NP.
4519 (__pthread_mutexattr_init): Use PTHREAD_MUTEX_TIMED_NP.
4520 (__pthread_mutexattr_settype): Allow PTHREAD_MUTEX_TIMED_NP.
4521 * spinlock.c: Implement alternate fastlocks.
4522 * spinlock.h: Add prototypes.
4523 * Examples/ex10.c: New file.
4524 * sysdeps/pthread/pthread.h: Add prototypes for new functions.
4525 Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
4527 * rwlock.c (__pthread_rwlock_rdlock): Optimize loop a bit.
4528 (__pthread_rwlock_timedrdlock): New function.
4529 (__pthread_rwlock_timedwrlock): New function.
4530 Use laternate fastlock function everywhere.
4532 2000-06-21 Andreas Jaeger <aj@suse.de>
4534 * sysdeps/pthread/timer_routines.c: Include <string.h> for memset
4537 * join.c: Include <stdlib.h> for exit prototype.
4539 2000-06-20 Ulrich Drepper <drepper@redhat.com>
4541 * sysdeps/i386/useldt.h: Include <stdlib.h>.
4543 * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define _POSIX_BARRIERS.
4544 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
4546 * Makefile (libpthread-routines): Add barrier.
4547 (tests): Add ex9. Add rule to build ex9.
4548 * Versions: Export barrier functions.
4549 * barrier.c: New file.
4550 * Examples/ex9.c: New file.
4551 * sysdeps/pthread/pthread.h: Add barrier data types and declarations.
4552 * sysdeps/pthread/bits/pthreadtypes.h: Likewise.
4553 Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
4555 2000-06-19 H.J. Lu <hjl@gnu.org>
4557 * spinlock.h (HAS_COMPARE_AND_SWAP): Defined if
4558 HAS_COMPARE_AND_SWAP_WITH_RELEASE_SEMANTICS is defined.
4559 (compare_and_swap_with_release_semantics): New. Default to
4560 compare_and_swap if HAS_COMPARE_AND_SWAP_WITH_RELEASE_SEMANTICS
4563 * spinlock.c (__pthread_unlock): Call
4564 compare_and_swap_with_release_semantics () instead of
4565 compare_and_swap ().
4567 2000-06-19 Ulrich Drepper <drepper@redhat.com>
4569 * sysdeps/pthread/timer_create.c: Use _set_errno instead of assigning
4571 * sysdeps/pthread/timer_delete.c: Likewise.
4572 * sysdeps/pthread/timer_getoverr.c: Likewise.
4573 * sysdeps/pthread/timer_gettime.c: Likewise.
4574 * sysdeps/pthread/timer_settime.c: Likewise.
4576 2000-06-13 Kaz Kylheku <kaz@ashi.footprints.net>
4578 Timer nodes are now reference counted, and can be marked
4579 as deleted. This allows for the safe release of the global mutex
4580 in the middle without losing the timer being operated on.
4582 * sysdeps/pthread/posix-timer.h (struct timer_node): The inuse
4583 member is now an enum with three values, so that an intermediate
4584 state can be represented (deleted but not free for reuse yet).
4585 New refcount member added.
4586 * sysdeps/pthread/timer_routines.c: Likewise.
4588 * sysdeps/pthread/posix-timer.h (timer_addref, timer_delref,
4589 timer_valid): New inline functions added.
4591 * sysdeps/pthread/timer_gettime.c (timer_gettime): Function
4592 restructured, recursive deadlock bug fixed.
4594 * sysdeps/pthread/timer_gettime.c (timer_gettime): Uses new
4595 timer_addref to ensure that timer won't be deleted while mutex is not
4596 held. Also uses timer_invalid to perform validation of timer handle.
4597 * sysdeps/pthread/timer_settime.c (timer_settime): Likewise.
4598 * sysdeps/pthread/timer_getoverr.c (timer_getoverrun): Likewise.
4600 2000-06-14 Ulrich Drepper <drepper@redhat.com>
4602 * shlib-versions: Add entry for SH.
4603 Patch by Kaz Kojima <kkojima@rr.iij4u.or.jp>.
4605 2000-06-13 Kaz Kylheku <kaz@ashi.footprints.net>
4607 A few optimizations. Got rid of unnecessary wakeups of timer threads,
4608 tightened up some critical regions and micro-optimized some list
4611 * sysdeps/pthread/timer_routines.c (__timer_thread_queue_timer):
4612 Returns int value now to indicate whether timer was queued at head.
4613 * sysdeps/pthread/posix-timer.h: Likewise.
4614 * sysdeps/pthread/timer_settime.c (timer_settime): Takes advantage of
4615 new return value from __timer_thread_queue_timer to avoid waking
4616 up timer thread unnecessarily.
4618 * sysdeps/pthread/posix-timer.h (timer_id2ptr): No longer checks
4619 inuse flag, because this requires mutex to be held. Callers updated
4620 to do the check when they have the mutex.
4621 * sysdeps/pthread/timer_getoverr.c: Add check for inuse here.
4623 * sysdeps/pthread/timer_settime.c (timer_settime): Tighter critical
4624 regions: avoids making system calls while holding timer mutex, and
4625 a few computations were moved outside of the mutex as well.
4626 * sysdeps/pthread/timer_gettime.c (timer_gettime): Likewise.
4628 * sysdeps/pthread/posix-timer.h (list_unlink_ip): Function name changed
4629 to list_unlink_ip, meaning idempotent. Pointer manipulation
4630 changed to get better better code out of gcc.
4631 * sysdeps/pthread/timer_routines.c (list_unlink): Non-idempotent
4632 version of list_unlink added here.
4633 * sysdeps/pthread/timer_delete.c: Use appropriate list unlink
4634 function in all places: idempotent one for timers, non-idempotent
4635 one for thread nodes.
4636 * sysdeps/pthread/timer_settime: Likewise.
4637 * sysdeps/pthread/timer_routines.c: Likewise.
4639 2000-06-13 Ulrich Drepper <drepper@redhat.com>
4641 * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_TIMERS): Define.
4642 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
4644 * sysdeps/pthread/Makefile: Remove tests definition.
4646 2000-06-12 Kazumoto Kojima <kkojima@rr.iij4u.or.jp>
4647 Yutaka Niibe <gniibe@chroot.org>
4649 * sysdeps/sh/pspinlock.c: New file.
4650 * sysdeps/sh/pt-machine.h: New file.
4652 2000-06-12 Ulrich Drepper <drepper@redhat.com>
4654 * Makefile (tests): Add joinrace.
4656 * Examples/ex6.c: Test return value of pthread_join.
4658 2000-06-11 Geoff Keating <geoffk@cygnus.com>
4660 * sysdeps/powerpc/pspinlock.c (__pthread_spin_lock): Implement.
4661 (__pthread_spin_trylock): Implement.
4662 (__pthread_spin_unlock): Implement.
4663 (__pthread_spin_init): Implement.
4664 (__pthread_spin_destroy): Implement.
4666 2000-06-10 Ulrich Drepper <drepper@redhat.com>
4668 * sysdeps/pthread/timer_routines.c (list_append): Little fix to
4669 really append the entry.
4671 2000-06-10 Andreas Jaeger <aj@suse.de>
4673 * lockfile.c (__fresetlockfiles): Remove unused variable fp.
4675 2000-06-10 Kaz Kylheku <kaz@ashi.footprints.net>
4677 * sysdeps/pthread/timer_create.c: Thread matching now done on
4678 clock type as well as thread attributes.
4679 There are individual global signal-delivering threads for
4680 different clock types.
4681 * sysdeps/pthread/posix-timer.h: Likewise.
4682 * sysdeps/pthread/timer_routines.c: Likewise.
4684 * sysdeps/pthread/timer_routines.c: Thread allocation and
4685 deallocation function now remembers to put thread on active
4686 list and remove from active list.
4687 Thus now the feature of binding multiple timers
4688 to a single thread actually works.
4690 2000-06-10 Ulrich Drepper <drepper@redhat.com>
4692 * pthread.c (__pthread_create_2_1): Optimize a bit.
4694 * internals.h (invalid_handle): Also test for p_terminated != 0.
4695 (nonexisting_handle): New function. Same as old invalid_handle.
4696 * join.c (pthread_join): Use nonexisting_handle instead of
4697 invalid_handle to test for acceptable thread handle.
4698 * manager.c (pthread_handle_free): Likewise.
4699 * joinrace.c: New file.
4700 Reported by Permaine Cheung <pcheung@cygnus.com>.
4702 2000-06-08 Ulrich Drepper <drepper@redhat.com>
4704 * sysdeps/pthread/timer_routines.c (__timer_thread_queue_timer):
4705 Correct handling of matching variable.
4707 * sysdeps/pthread/tst-timer.c (main): Rewrite initializers to
4710 * sysdeps/pthread/timer_routines.c (__timer_thread_queue_timer):
4711 Be prepared for empty timer list.
4713 * sysdeps/pthread/timer_create.c (timer_create): Correct names of
4714 CPUTIME clock ID. Add support for thread clocks.
4716 * sysdeps/pthread/posix-timer.h (timer_ptr2id): Operands in
4717 subtraction were switched.
4719 * sysdeps/pthread/timer_routines.c (init_module): Use
4720 THREAD_MAXNODES threads.
4722 * sysdeps/pthread/posix-timer.h (struct timer_node): Add creator_pid.
4723 * sysdeps/pthread/timer_create.c: Fill in creator_pid.
4724 * sysdeps/pthread/timer_routines.c (thread_expire_timer): Send signal
4725 with sigqueueinfo is this system call is available.
4727 * sysdeps/pthread/timer_create.c (timer_create): Allow
4728 CLOCK_CPUTIME if _POSIX_CPUTIME is defined.
4730 * sysdeps/pthread/Makefile: New file. Add rules to build timer
4732 * sysdeps/unix/sysv/linux/bits/local_lim.h: Add TIMER_MAX.
4734 2000-06-04 Kaz Kylheku <kaz@ashi.footprints.net>
4736 * sysdeps/pthread/posix-timer.h: New file.
4737 * sysdeps/pthread/timer_create.c: New file.
4738 * sysdeps/pthread/timer_delete.c: New file.
4739 * sysdeps/pthread/timer_getoverr.c: New file.
4740 * sysdeps/pthread/timer_gettime.c: New file.
4741 * sysdeps/pthread/timer_routines.c: New file.
4742 * sysdeps/pthread/timer_settime.c: New file.
4743 * sysdeps/pthread/tst-timer.c: New file.
4745 2000-06-08 Ulrich Drepper <drepper@redhat.com>
4747 * sysdeps/unix/sysv/linux/bits/local_lim.h: Remove OPEN_MAX and
4748 LINK_MAX definitions if necessary.
4750 2000-06-04 Kaz Kylheku <kaz@ashi.footprints.net>
4752 Added missing fork time handling of global libio lock.
4754 * lockfile.c (__fresetlockfiles): Now also resets the list lock,
4755 not just the individual stream locks. Rewritten to use new
4756 iterator interface provided by libio rather than accessing
4759 * lockfile.c (__flockfilelist, _funlockfilelist): New functions
4760 which lock and unlock the stream list using the new interface
4762 * internals.h: Likewise.
4764 * ptfork.c (__fork): Now calls __flockfilelist before fork,
4765 and __funlockfilelist in the parent after the fork.
4766 Child still calls __fresetlockfiles as before.
4768 * linuxthreads.texi: Now explains what happens to streams at
4769 fork time. Also whole new section on forking and thread added.
4770 Definition of pthread_atfork moved out of Miscellaneous Functions
4771 to this new section.
4773 2000-06-04 Jakub Jelinek <jakub@redhat.com>
4775 * sysdeps/sparc/sparc32/sparcv9/pspinlock.c (__pthread_spin_lock):
4776 Add missing register.
4777 * sysdeps/sparc/sparc64/pspinlock.c (__pthread_spin_lock): Likewise.
4779 2000-06-02 Jakub Jelinek <jakub@redhat.com>
4781 * sysdeps/sparc/sparc32/pspinlock.c: Implement spinlocks.
4782 * sysdeps/sparc/sparc32/sparcv9/pspinlock.c: New.
4783 * sysdeps/sparc/sparc64/pspinlock.c: Implement spinlocks.
4785 2000-05-31 Andreas Jaeger <aj@suse.de>
4787 * sysdeps/mips/pspinlock.c: Implement spinlocks.
4789 2000-05-28 Ulrich Drepper <drepper@redhat.com>
4791 * spinlock.c (__pthread_lock): Remove ASSERT.
4793 * Makefile (tests): Add ex8.
4794 * Examples/ex8.c: New file.
4796 2000-05-12 Kaz Kylheku <kaz@ashi.footprints.net>
4798 Bugfix: The pthread_atfork mechanism now takes care of its
4799 own internal mutex at fork time.
4801 * ptfork.c (__fork): Revised so that the mutex is held across
4802 the fork operation and while the handlers are called, and so that
4803 the child resets the mutex.
4805 * linuxthreads.texi: Updated pthread_atfork documentation to make
4806 it clear that fork and pthread_atfork can't be reentered from
4807 atfork handlers, that pthread_atfork and fork are mutually atomic,
4808 and that the handlers are inherited by the child process.
4810 2000-05-24 Ulrich Drepper <drepper@redhat.com>
4812 * Makefile (libpthread-routines): Add pspinlock.
4813 * cancel.c: Rename __pthread_spin_unlock back to __pthread_unlock.
4814 Use struct _pthread_fastlock instead of pthread_spinlock_t.
4815 * condvar.c: Likewise.
4816 * internals.h: Likewise.
4818 * manager.c: Likewise.
4819 * mutex.c: Likewise.
4820 * pthread.c: Likewise.
4821 * rwlock.c: Likewise.
4822 * semaphore.c: Likewise.
4823 * signals.c: Likewise.
4824 * spinlock.h: Likewise.
4825 * spinlock.c: Likewise. Remove pthread_spin_lock functions.
4826 * sysdeps/alpha/pspinlock.c: New file.
4827 * sysdeps/arm/pspinlock.c: New file.
4828 * sysdeps/i386/pspinlock.c: New file.
4829 * sysdeps/m68k/pspinlock.c: New file.
4830 * sysdeps/mips/pspinlock.c: New file.
4831 * sysdeps/powerpc/pspinlock.c: New file.
4832 * sysdeps/sparc/sparc32/pspinlock.c: New file.
4833 * sysdeps/sparc/sparc64/pspinlock.c: New file.
4834 * sysdeps/pthread/bits/pthreadtypes.h: Remove pthread_spinlock_t
4835 back to _pthread_fastlock. Define new pthread_spinlock_t.
4837 2000-05-24 Andreas Jaeger <aj@suse.de>
4839 * sysdeps/i386/i686/pt-machine.h: Only use LDT on newer kernels.
4841 2000-05-21 Jakub Jelinek <jakub@redhat.com>
4843 * manager.c (pthread_handle_create): Initialize p_res._sock to -1.
4845 2000-05-13 Jakub Jelinek <jakub@redhat.com>
4847 * internals.h (__RES_PTHREAD_INTERNAL): Define.
4849 2000-05-06 Kaz Kylheku <kaz@ashi.footprints.net>
4851 * mutex.c (pthread_once): IN_PROGRESS state of pthread_once_t
4852 object state is represented with additional bits which distinguish
4853 whether that state was set up in the current process, or
4854 in an ancestor process. If that state was set in an ancestor,
4855 it means that a fork happened while thread was executing the init
4856 function. In that case, the state is reset to NEVER.
4857 * mutex.c (__pthread_once_fork_prepare): New function.
4858 (__pthread_once_fork_child): Likewise
4859 (__pthread_once_fork_parent): Likewise
4860 (__pthread_reset_pthread_once): Removed.
4861 * ptfork.c (__fork): Call new handlers in mutex.c.
4862 * internals.h: Declarations of new mutex.c functions added.
4863 Declaration of removed function deleted.
4864 * linuxthreads.texi: Updated documentation about pthread_once
4865 to clarify what happens under cancellation and forking.
4867 2000-05-06 Kaz Kylheku <kaz@ashi.footprints.net>
4869 * internals.h: New thread manager request type, REQ_KICK.
4870 * join.c (pthread_exit): main thread now calls exit() instead
4871 of _exit() in order to proper process cleanup.
4872 * manager.c (__pthread_manager): Do not terminate manager
4873 after unblocking main thread; wait for main thread's
4874 REQ_PROCESS_EXIT request instead.
4875 Also, added REQ_KICK case to handle new request; this just does
4877 * manager.c (pthread_exited): Do not terminate manager after
4878 unblocking main thread.
4879 * manager.c (__pthread_manager_sighandler): If the main thread
4880 is waiting for all other threads to die, send a REQ_KICK into
4881 the thread manager request pipe to get it to clean out the threads
4882 and unblock the main thread as soon as possible. This fixes
4883 the 2000 millisecond hang on shutdown bug.
4884 * Examples/ex7.c: New file, tests shutdown behavior when all threads
4885 including the main one call pthread_exit(), or implicitly do so.
4886 * Makefile (tests): Add ex7.
4888 2000-05-05 Andreas Jaeger <aj@suse.de>
4890 * sysdeps/unix/sysv/linux/i386/getcpuclockid.c
4891 (pthread_getcpuclockid): Correct test for ourselves.
4893 2000-05-05 Ulrich Drepper <drepper@redhat.com>
4895 * internals.h (struct _pthread_descr_struct): Reorganization.
4896 Allocate room for 16 pointers at head of the structure for future
4897 thread-local data handling. Move p_self member in this area.
4898 * manager.c (pthread_handle_create): Adjust use of p_self.
4899 * sysdeps/i386/useldt.h (THREAD_SELF): Likewise.
4900 * pthread.c (__pthread_initial_thread): Adjust initialization.
4901 (__pthread_manager_thread): Likewise.
4903 2000-04-29 Bruno Haible <haible@clisp.cons.org>
4905 * join.c (pthread_exit): Use THREAD_GETMEM_NC instead of THREAD_GETMEM
4906 for eventmask larger than 1 word.
4908 2000-04-27 Ulrich Drepper <drepper@redhat.com>
4910 * Versions [libpthread] (GLIBC_2.2): Add __pthread_initialize_minimal.
4911 * pthread.c (__pthread_initialize_minimal): New function. Perform
4912 minimal initialization.
4913 (pthread_initialize): Remove this code here.
4914 * sysdeps/i386/i686/pt-machine.h: Include "../useldt.h" again. We
4915 are working around the problem in glibc.
4917 2000-04-25 Ulrich Drepper <drepper@redhat.com>
4919 * sysdeps/i386/i686/pt-machine.h: Do not use "../useldt.h" for
4920 now. First gcc must be fixed (more concrete: libgcc).
4922 2000-04-24 Ulrich Drepper <drepper@redhat.com>
4924 * pthread.c: Remove special treatement for interrupt handlers on x86.
4925 * manager.c (pthread_free): Use FREE_THREAD not FREE_THREAD_SELF.
4926 * sysdeps/i386/useldt.h: Use "q" constraint instead of "r" where
4928 * sysdeps/i386/i686/pt-machine.h: Include "../useldt.h".
4930 2000-04-24 Mark Kettenis <kettenis@gnu.org>
4932 * join.c (pthread_exit): Set p_terminated after reporting the
4933 termination event instead of before.
4935 2000-04-20 Jakub Jelinek <jakub@redhat.com>
4937 * sysdeps/pthread/bits/libc-lock.h: Only declare __pthread_rwlock_*
4940 2000-04-18 Andreas Jaeger <aj@suse.de>
4942 * Versions: Use ld instead of ld.so.
4944 2000-04-18 Jakub Jelinek <jakub@redhat.com>
4946 * sysdeps/unix/sysv/linux/sparc/bits/sigcontext.h (struct sigcontext):
4947 Remove the typedef keyword.
4949 2000-04-18 Jakub Jelinek <jakub@redhat.com>
4951 * sysdeps/sparc/sparc64/pt-machine.h (MEMORY_BARRIER): Use membar,
4953 (READ_MEMORY_BARRIER): Define.
4954 * spinlock.c (__pthread_spin_unlock): Use READ_MEMORY_BARRIER, not
4956 * internals.h (READ_MEMORY_BARRIER): Define if not defined in sysdep
4959 2000-04-17 Ulrich Drepper <drepper@redhat.com>
4961 * sysdeps/unix/sysv/linux/i386/getcpuclockid.c
4962 (pthread_getcpuclockid): Don't compare thread_id with thread_self,
4963 use thread_handle().
4965 2000-04-16 Ulrich Drepper <drepper@redhat.com>
4967 * condvar.c (pthread_cond_timedwait_relative): Don't test for owner
4968 if fast mutex is used. Don't initialize `already_canceled' twice.
4969 Correctly test for return value of timedsuspend.
4971 * pthread.c: Correct long-time braino. We never set SA_SIGINFO and
4972 therefore don't need the _rt versions of the signal handlers.
4974 2000-04-15 Ulrich Drepper <drepper@redhat.com>
4976 * pthread.c (pthread_yield): New function.
4977 * sysdeps/pthread/pthread.h (pthread_yield): Add prototype.
4978 * Versions [libpthread] (GLIBC_2.2): Add pthread_yield.
4979 * internals.h: Declare __pthread_yield.
4981 * pthread.c (pthread_initialize): Avoid a bit more code if
4982 realtime signals are known to exist.
4984 * pthread.c: Is __ASSUME_REALTIME_SIGNALS then avoid generating code
4985 to dynamically detect RT signals and avoid generating compatibility
4986 functions with old kernel.
4987 * restart.h (restart) [__ASSUME_REALTIME_SIGNALS]: Use
4988 __pthread_restart_new directly.
4989 (suspend) [__ASSUME_REALTIME_SIGNALS]: Use
4990 __pthread_wait_for_restart_signal directly.
4991 (timedsuspend) [__ASSUME_REALTIME_SIGNALS]: Use
4992 __pthread_timedsuspend_new directly.
4994 2000-04-15 Ulrich Drepper <drepper@redhat.com>
4996 * condvar.c: Remove all the special code to handle cond_timedwait.
4997 Use timedsuspend instead.
4998 * internals.h: Declare __pthread_timedsuspend_old,
4999 __pthread_timedsuspend_new, and __pthread_timedsuspend.
5000 Remove declaration of __pthread_init_condvar.
5001 * pthread.c: Define __pthread_timedsuspend variable.
5002 (__pthread_timedsuspend_old): New function. Timed suspension
5003 implementation for old Linux kernels.
5004 (__pthread_timedsuspend_new): New function. Timed suspension
5005 implementation for new Linux kernels.
5006 * restart.h (timedsuspend): New function. Call appropriate
5007 suspension function through __pthread_timedsuspend.
5008 * semaphore.c (sem_timedwait): Use timedsuspend, don't duplicate
5010 Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
5012 * internals.h (WRITE_MEMORY_BARRIER): Define as MEMORY_BARRIER if
5014 * spinlock.c: Use WRITE_MEMORY_BARRIER instead of MEMORY_BARRIER
5016 * sysdeps/alpha/pt-machine.h: Define WRITE_MEMORY_BARRIER.
5017 * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
5019 * sysdeps/unix/sysv/linux/bits/posix_opt.h: Add _POSIX_SPAWN.
5020 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
5022 2000-04-14 Andreas Jaeger <aj@suse.de>
5024 * weaks.c: Fix typo.
5026 * shlib-versions (mips.*-.*-linux.*): Support only GLIBC 2.0 and
5027 2.2 for linuxthreads.
5029 2000-04-13 Ulrich Drepper <drepper@redhat.com>
5031 * sysdeps/unix/sysv/linux/i386/getcpuclockid.c
5032 (pthread_getcpuclockid): Fix typo.
5034 2000-04-12 Ulrich Drepper <drepper@redhat.com>
5036 * Makefile (libpthread-routines): Add getcpuclockid.
5037 * Versions [libpthread] (GLIBC_2.2): Add pthread_getcpuclockid.
5038 * sysdeps/pthread/getcpuclockid.c: New file.
5039 * sysdeps/unix/sysv/linux/i386/getcpuclockid.c: New file.
5040 * sysdeps/pthread/pthread.h: Add prototype for pthread_getcpuclockid.
5042 * sysdeps/unix/sysv/linux/bits/posix_opt.h (_POSIX_SPIN_LOCKS):
5044 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: Likewise.
5046 * sysdeps/pthread/pthread.h: Add prototypes for pthread_spin_init,
5047 pthread_spin_destroy, pthread_spin_lock, pthread_spin_trylock,
5048 and pthread_spin_unlock.
5049 * sysdeps/pthread/bits/pthreadtypes.h: Change struct _pthread_fastlock
5050 into pthread_spinlock_t. Change all uses.
5051 * spinlock.c: Implement pthread_spin_lock.
5052 Rename __pthread_unlock to __pthread_spin_unlock and define weak
5053 alias for real name.
5054 Define pthread_spin_trylock, pthread_spin_init, and
5055 pthread_spin_destroy.
5056 Change all uses of _pthread_fastlock to pthread_spinlock_t.
5057 * spinlock.h: Rename __pthread_unlock to __pthread_spin_unlock.
5058 Change all uses of _pthread_fastlock to pthread_spinlock_t.
5059 * Versions [libpthread] (GLIBC_2.2): Add pthread_spin_init,
5060 pthread_spin_destroy, pthread_spin_lock, pthread_spin_trylock,
5061 and pthread_spin_unlock.
5062 * cancel.c: Use __pthread_spin_unlock instead of __pthread_unlock.
5063 Change all uses of _pthread_fastlock to pthread_spinlock_t.
5064 * condvar.c: Likewise.
5065 * internals.h: Likewise.
5067 * manager.c: Likewise.
5068 * mutex.c: Likewise.
5069 * pthread.c: Likewise.
5070 * rwlock.c: Likewise.
5071 * semaphore.c: Likewise.
5072 * signals.c: Likewise.
5074 * sysdeps/unix/sysv/linux/bits/posix_opt.h: Add various new POSIX
5076 * sysdeps/unix/sysv/linux/i386/bits/posix_opt.h: New file.
5078 2000-04-11 Ulrich Drepper <drepper@redhat.com>
5080 * sysdeps/unix/sysv/linux/bits/posix_opt.h: Add
5081 _POSIX_SHARED_MEMORY_OBJECTS.
5083 2000-04-11 Andreas Jaeger <aj@suse.de>
5085 * sysdeps/mips/pt-machine.h (MEMORY_BARRIER): Define.
5086 (__compare_and_swap): Mark as modifying memory.
5088 2000-04-11 Geoff Keating <geoffk@cygnus.com>
5090 * sysdeps/powerpc/pt-machine.h (MEMORY_BARRIER): Don't be
5092 (__compare_and_swap): Replace other 'sync' with MEMORY_BARRIER.
5093 Don't have the 'asm' __volatile__.
5095 2000-04-11 Ulrich Drepper <drepper@redhat.com>
5097 * internals.h: Define MEMORY_BARRIER as empty if not defined already.
5098 * spinlock.c (__pthread_lock): Add memory barriers.
5099 (__pthread_unlock): Likewise.
5100 * sysdeps/alpha/pt-machine.h (MEMORY_BARRIER): Define using mb
5102 (RELEASE): Not needed anymore.
5103 (__compare_and_swap): Mark asm as modifying memory.
5104 * sysdeps/powerpc/pt-machine.h (sync): Remove. Replace with definition
5106 (__compare_and_swap): Use MEMORY_BARRIER instead of sync.
5107 * sysdeps/sparc/sparc32/pt-machine.h (RELEASE): Not needed anymore.
5108 (MEMORY_BARRIER): Define using stbar.
5109 * sysdeps/sparc/sparc64/pt-machine.h (MEMORY_BARRIER): Define using
5111 (__compare_and_swap): Use MEMORY_BARRIER to ensure ordering.
5112 Patch by Xavier Leroy <Xavier.Leroy@inria.fr> based on comments by
5113 Mike Burrows <m3b@pa.dec.com>.
5115 2000-04-09 Ulrich Drepper <drepper@redhat.com>
5117 * signals.c (sigaction): Fix return value for the case SIG is one
5118 of the signals the implementation uses.
5119 Patch by Xavier.Leroy@inria.fr.
5121 2000-04-01 Andreas Jaeger <aj@suse.de>
5123 * attr.c: Use shlib-compat macros.
5124 * oldsemaphore.c: Likewise.
5125 * pthread.c: Likewise.
5126 * weaks.c: Likewise.
5128 2000-03-26 Ulrich Drepper <drepper@redhat.com>
5130 * semaphore.c (sem_timedwait): New function.
5131 Patch by Carl Mailloux <carlm@oricom.ca>.
5132 * semaphore.h: Declare sem_timedwait.
5133 * Versions [libpthread] (GLIBC_2.2): Add sem_timedwait.
5135 2000-03-26 Roland McGrath <roland@baalperazim.frob.com>
5137 * sysdeps/pthread/Makefile: File removed.
5139 2000-03-23 Ulrich Drepper <drepper@redhat.com>
5141 * mutex.c (__pthread_reset_pthread_once): Reset once_masterlock.
5142 * internals.h (__pthread_reset_pthread_once): Add prototype.
5143 * ptfork.c (__fork): Call __pthread_reset_pthread_once.
5145 * manager.c (pthread_handle_create): Store ID of new thread before
5148 2000-03-21 Ulrich Drepper <drepper@redhat.com>
5150 * attr.c: Use new macros from shlib-compat.h to define versions.
5151 * oldsemaphore.c: Likewise.
5152 * semaphore.c: Likewise.
5153 * weaks.c: Likewise.
5155 * pthread.c: Update for new SHLIB_COMPAT definition.
5157 * manager.c (__pthread_manager): Unmask debug signal.
5159 * pthread.c (pthread_initialize): Test for address of __dso_handle
5160 being NULL, not value. Use __on_exit, not on_exit.
5161 Patch by Andreas Jaeger <aj@suse.de>.
5163 * pthread.c: Use new macros from shlib-compat.h to define versions.
5165 2000-03-19 Ulrich Drepper <drepper@redhat.com>
5167 * pthread.c (pthread_initialize): Instead of on_exit use
5168 __cxa_atexit if __dso_label is available to allow unloading the
5169 libpthread shared library.
5171 2000-03-16 Ulrich Drepper <drepper@redhat.com>
5173 * condvar.c: Make tests for ownership of mutex less strict.
5175 2000-03-14 Ulrich Drepper <drepper@redhat.com>
5177 * condvar.c (pthread_cond_wait): Check whether mutex is owned by
5178 current thread and return error if not.
5179 (pthread_cond_timedwait_relative_old): Likewise.
5180 (pthread_cond_timedwait_relative_new): Likewise.
5182 * mutex.c (__pthread_once): Handle cancelled init function correctly.
5183 (pthread_once_cancelhandler): New function.
5184 Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
5186 2000-03-14 Andreas Jaeger <aj@suse.de>
5188 * pthread.c (pthread_handle_sigcancel_rt): GS has been renamed to
5190 (pthread_handle_sigrestart_rt): Likewise.
5191 * signals.c (pthread_sighandler_rt): Likewise.
5193 2000-03-02 Andreas Jaeger <aj@suse.de>
5195 * sysdeps/pthread/bits/libc-lock.h: Fix typo.
5196 Reported by Sean Chen <sean.chen@turbolinux.com>.
5198 2000-02-28 Andreas Jaeger <aj@suse.de>
5200 * rwlock.c: Fix typo.
5202 2000-02-27 Ulrich Drepper <drepper@redhat.com>
5204 * rwlock.c: Define __* variants of the functions and make old names
5206 * Versions [GLIBC_2.2]: Export the __pthread_rwlock_* functions.
5207 * sysdeps/pthread/bits/libc-lock.h: Define __libc_rwlock_* macros.
5209 2000-02-25 Andreas Jaeger <aj@suse.de>
5211 * Versions: Export pread, __pread64, pread64, pwrite, __pwrite64,
5212 pwrite64, lseek64, open64, and __open64 with version 2.2.
5214 2000-02-22 Ulrich Drepper <drepper@redhat.com>
5216 * semaphore.h (SEM_FAILED): Use 0 not NULL.
5218 2000-02-14 Ulrich Drepper <drepper@redhat.com>
5220 * condvar.c (pthread_cond_timedwait_relative_old): Tight loop with
5221 nanosleep does not work either. Get absolute time inside the
5223 (pthread_cond_timedwait_relative_new): Likewise.
5224 Patch by Kaz Kylheku <kaz@ashi.footprints.net>.
5226 2000-02-13 Andreas Jaeger <aj@suse.de>
5228 * condvar.c (pthread_cond_timedwait_relative_new): Fix last patch.
5229 (pthread_cond_timedwait_relative_old): Likewise.
5231 2000-02-13 Ulrich Drepper <drepper@redhat.com>
5233 * condvar.c (pthread_cond_timedwait_relative_old): Undo last patch
5234 but keep the code around. A bug in the kernel prevent us from
5236 (pthread_cond_timedwait_relative_new): Likewise.
5237 (PR libc/1597 and libc/1598).
5239 2000-02-01 Kaz Kylheku <kaz@ashi.footprints.net>
5241 * condvar.c (pthread_cond_timedwait_relative_old): Do tight
5242 loop around nanosleep calls instead of around most of the function
5243 (pthread_cond_timedwait_relative_new): Likewise.
5244 body. Got rid of backwards goto and one local.
5246 2000-01-31 Ulrich Drepper <drepper@redhat.com>
5248 * condvar.c (pthread_cond_timedwait_relative_old): Recompute time
5249 before every nanosleep call to account for time spent in the rest
5251 (pthread_cond_timedwait_relative_new): Likewise.
5252 Patch by khendricks@ivey.uwo.ca (PR libc/1564).
5254 2000-01-29 Ulrich Drepper <drepper@redhat.com>
5256 * condvar.c (pthread_cond_timedwait_relative_old): Get remaining time
5257 from nanosleep call so that in case we restart we only wait for the
5259 (pthread_cond_timedwait_relative_new): Likewise.
5260 Patch by khendricks@ivey.uwo.ca (PR libc/1561).
5262 2000-01-18 Ulrich Drepper <drepper@cygnus.com>
5264 * manager.c (pthread_allocate_stack): Compute guard page address
5265 correctly. Patch by HJ Lu.
5267 * sysdeps/pthread/pthread.h: Define
5268 PTHREAD_RWLOCK_WRITER_NONRECURSIVE_INITIALIZER_NP.
5270 2000-01-16 Ulrich Drepper <drepper@cygnus.com>
5272 * rwlock.c (pthread_rwlock_unlock): Correct one more problem with
5273 preference handling.
5274 (pthread_rwlockattr_setkind_np): Allow
5275 PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP.
5276 Patches by Kaz Kylheku <kaz@ashi.footprints.net>.
5278 2000-01-12 Ulrich Drepper <drepper@cygnus.com>
5280 * internals.h (pthread_readlock_info): New structure.
5281 (_pthread_descr_struct): Add p_readlock_list, p_readlock_free, and
5282 p_untracked_readlock_count.
5283 * pthread.c (__pthread_initial_thread, pthread_manager_thread):
5284 Add initializers for new fields.
5285 * manager.c (pthread_free): Free read/write lock lists.
5286 * queue.h (queue_is_empty): New function.
5287 * rwlock.c: Implement requirements about when readers should get
5289 * sysdeps/pthread/pthread.h
5290 (PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP): New definition.
5291 * sysdeps/pthread/bits/pthreadtypes.h (struct _pthread_rwlock_t):
5292 Define this name as well.
5293 Patches by Kaz Kylheku <kaz@ashi.footprints.net>.
5295 2000-01-05 Ulrich Drepper <drepper@cygnus.com>
5297 * pthread.c (__pthread_initial_thread, pthread_manager_thread):
5298 Adjust initializers for struct _pthread_descr_struct change.
5299 * internals.h (struct _pthread_descr_struct): Move new elements to
5302 2000-01-03 Kaz Kylheku <kaz@ashi.footprints.net>
5304 Redesigned how cancellation unblocks a thread from internal
5305 cancellation points (sem_wait, pthread_join,
5306 pthread_cond_{wait,timedwait}).
5307 Cancellation won't eat a signal in any of these functions
5308 (*required* by POSIX and Single Unix Spec!).
5309 * condvar.c: Spontaneous wakeup on pthread_cond_timedwait won't eat a
5310 simultaneous condition variable signal (not required by POSIX
5311 or Single Unix Spec, but nice).
5312 * spinlock.c: __pthread_lock queues back any received restarts
5313 that don't belong to it instead of assuming ownership of lock
5314 upon any restart; fastlock can no longer be acquired by two threads
5316 * restart.h: Restarts queue even on kernels that don't have
5317 queued real time signals (2.0, early 2.1), thanks to atomic counter,
5318 avoiding a rare race condition in pthread_cond_timedwait.
5320 1999-12-31 Andreas Jaeger <aj@suse.de>
5322 * internals.h: Remove duplicate prototype declarations.
5324 * weaks.c: Remove __THROW from prototypes since the file is not
5325 compiled by a C++ compiler.
5326 * internals.h: Likewise.
5328 1999-12-30 Andreas Jaeger <aj@suse.de>
5330 * sysdeps/pthread/pthread.h: Move internal functions to...
5331 * sysdeps/pthread/bits/libc-lock.h: ...here.
5333 1999-12-29 Andreas Jaeger <aj@suse.de>
5335 * sysdeps/pthread/pthread.h: Fix typos, reformat comments.
5337 1999-12-28 Ulrich Drepper <drepper@cygnus.com>
5339 * sysdeps/alpha/pt-machine.h: Move stack_pointer definition to the
5342 * manager.c (__pthread_start): Add one more cast to prevent
5343 warning on 64bit machines.
5345 1999-12-21 Ulrich Drepper <drepper@cygnus.com>
5347 * manager.c (pthread_handle_create): Set p_pid of new thread
5348 before calling the callback function to report a new thread.
5350 1999-12-20 Andreas Jaeger <aj@suse.de>
5352 * pthread.c (pthread_initialize): Move getrlimit call after
5355 1999-12-18 Ulrich Drepper <drepper@cygnus.com>
5357 * Versions: Export pread, __pread64, pread64, pwrite, __pwrite64,
5358 pwrite64, lseek64, open64, and __open64.
5359 * wrapsyscall.c: Define pread, __pread64, pread64, pwrite, __pwrite64,
5360 pwrite64, lseek64, open64, and __open64.
5362 * manager.c (pthread_allocate_stack): Correct computation of
5363 new_thread_bottom. Correct handling of stack size and when the
5364 rlimit method to guard for stack growth is used.
5365 * pthread.c (pthread_initialize): Stack limit must be STACK_SIZE
5366 minus one pagesize (not two).
5368 1999-12-03 Andreas Jaeger <aj@suse.de>
5370 * Versions: Add __res_state with version GLIBC_2.2.
5372 * errno.c (__res_state): New function to return thread specific
5375 * pthread.c (pthread_initialize): Initialize p_resp.
5376 (__pthread_reset_main_thread): Also set p_resp.
5378 * manager.c (pthread_handle_create): Initialize p_resp.
5380 * internals.h: Add thread specific resolver state.
5381 Based on patches by Adam D. Bradley <artdodge@cs.bu.edu>.
5383 1999-12-01 Ulrich Drepper <drepper@cygnus.com>
5385 * sysdeps/i386/pt-machine.h: Move stack_pointer definition to the
5387 * sysdeps/i386/i686/pt-machine.h: Likewise.
5388 Patches by Alan Modra <alan@SPRI.Levels.UniSA.Edu.Au>.
5390 1999-11-23 Ulrich Drepper <drepper@cygnus.com>
5392 * manager.c (pthread_start_thread_event): Initialize p_pid already
5395 1999-11-22 Ulrich Drepper <drepper@cygnus.com>
5397 * internals.h: Add prototype for __pthread_manager_event.
5398 * manager.c (__pthread_manager_event): New function.
5399 (pthread_start_thread_event): Correct computation of self.
5400 Use INIT_THREAD_SELF.
5401 * pthread.c (__pthread_manager_thread): Initialize p_lock.
5402 (__pthread_initialize_manager): Respect event flags also for creation
5403 of the manager thread.
5405 1999-11-08 Ulrich Drepper <drepper@cygnus.com>
5407 * pthread.c (__pthread_initialize_manager): Initialize
5408 __pthread_manager_thread.p_tid.
5410 1999-11-02 Ulrich Drepper <drepper@cygnus.com>
5412 * internals.h: Declare __pthread_last_event.
5413 * manager.c: Define __pthread_last_event.
5414 (pthread_handle_create): Set __pthread_last_event.
5415 (pthread_exited): Likewise.
5416 * join.c (pthread_exit): Likewise.
5418 * Makefile (libpthread-routines): Add events.
5419 * events.c: New file.
5420 * internals.h: Protect against multiple inclusion.
5421 Include thread_dbP.h header.
5422 (struct _pthread_descr_struct): Add new fields p_report_events and
5424 Declare event reporting functions.
5425 * join.c (pthread_exit): Signal event if this is wanted.
5426 * manager.c (__pthread_threads_events): New variable.
5427 (pthread_handle_create): Take new parameters with event information.
5428 Signal TD_CREATE event if wanted.
5429 (__pthread_manager): Adjust pthread_handle_create call.
5430 (pthread_start_thread_event): New function. Block until manager is
5431 finished and then call pthread_start_thread.
5432 (pthread_exited): Signal TD_REAP event if wanted.
5434 1999-10-26 Ulrich Drepper <drepper@cygnus.com>
5436 * restart.h (suspend_with_cancellation): Rewrite as a macro.
5438 * condvar.c (pthread_cond_timedwait_relative): Don't mark as inline.
5440 1999-10-25 Andreas Jaeger <aj@suse.de>
5442 * internals.h: Remove K&R compatibility.
5443 * no-tsd.c: Likewise.
5444 * semaphore.h: Likewise.
5445 * signals.c: Likewise.
5446 * sysdeps/pthread/bits/libc-tsd.h: Likewise.
5447 * sysdeps/unix/sysv/linux/bits/sigthread.h: Likewise.
5448 * weaks.c: Likewise.
5450 1999-10-21 Xavier Leroy <Xavier.Leroy@inria.fr>
5452 * pthread.c: For i386, wrap pthread_handle_sigrestart and
5453 pthread_handle_sigcancel with functions that restore %gs from the
5454 signal context. For each signal handling function, two wrappers
5455 are required, one for a non-RT signal and one for a RT signal.
5456 * signal.c: For i386, add code to restore %gs from the signal
5457 context in pthread_sighandler and pthread_sighandler_rt.
5459 1999-10-17 Ulrich Drepper <drepper@cygnus.com>
5461 * internals.h (PTHREAD_START_ARGS_INITIALIZER): Add cast.
5463 1999-10-14 Ulrich Drepper <drepper@cygnus.com>
5465 * pthread.c (__pthread_initial_thread): Pass argument to
5466 PTHREAD_START_ARGS_INITIALIZER.
5467 (__pthread_manager_thread): Likewise.
5469 * internals.h (PTHREAD_START_ARGS_INITIALIZER): Add parameter to
5470 initialize function.
5472 * manager.c (pthread_handle_create): Remove p_startfct initialization.
5474 * internals.h (_pthread_descr_struct): We don't need p_startfct field.
5476 1999-10-12 Ulrich Drepper <drepper@cygnus.com>
5478 * internals.h: Correct return types for __libc_read and __libc_write.
5480 1999-10-09 Andreas Jaeger <aj@suse.de>
5482 * internals.h: Add __new_sem_post to get prototype in
5483 manager.c; include semaphore.h for needed types.
5485 1999-10-08 Ulrich Drepper <drepper@cygnus.com>
5487 * manager.c (__pthread_manager) [REQ_POST]: Use __new_sem_post
5488 directly instead of calling sem_post which should not be necessary
5489 but is faster and might help in some case to work around problems.
5490 Patch by khendricks@ivey.uwo.ca [libc/1382].
5492 1999-10-08 Andreas Schwab <schwab@suse.de>
5494 * sysdeps/pthread/Subdirs: New file.
5497 1999-10-07 Ulrich Drepper <drepper@cygnus.com>
5499 * Implies: New file.
5500 * internals.h (struct _pthread_descr_struct): Add p_startfct.
5501 * manager.c (pthread_handle_create): Initialize p_startfct.
5502 * pthread.c: Define __linuxthread_pthread_sizeof_descr variable.
5504 1999-09-25 Ulrich Drepper <drepper@cygnus.com>
5506 * manager.c (__linuxthreads_pthread_threads_max): New variable.
5507 * specific.c (__linuxthreads_pthread_keys_max): New variable.
5508 (__linuxthreads_pthread_key_2ndlevel_size): New variable.
5510 * condvar.c (pthread_cond_timedwait_relative): Never return with
5511 EINTR. Patch by Andreas Schwab.
5513 1999-09-19 Ulrich Drepper <drepper@cygnus.com>
5515 * signals.c (sigaction): Correct last patch. Don't select
5516 pthread_sighandler_rt based on the signal number but instead of
5517 the SA_SIGINFO flag.
5519 1999-09-23 Ulrich Drepper <drepper@cygnus.com>
5521 * specific.c: Move definitions of struct pthread_key_struct and
5522 destr_function to ...
5523 * internals.h: ...here.
5525 1999-09-18 Ulrich Drepper <drepper@cygnus.com>
5527 * pthread.c (pthread_handle_sigrestart_rt): New function. Use
5528 this instead of pthread_handle_sigrestart if the signal is an RT
5531 * signals.c: Handle passing through of sighandler arguments also
5532 for real-time signals.
5534 1999-09-03 Andreas Schwab <schwab@suse.de>
5536 * ptfork.c (__fork): Renamed from fork and use __libc_fork. Add
5538 (__vfork): New function, alias vfork.
5539 * Versions: Export __fork, vfork, and __vfork in libpthread.
5541 1999-08-23 Andreas Schwab <schwab@suse.de>
5543 * signals.c (pthread_sighandler): Add SIGCONTEXT_EXTRA_ARGS to
5544 call to signal handler.
5546 1999-08-20 Ulrich Drepper <drepper@cygnus.com>
5548 * pthread.c (__pthread_reset_main_thread): Undo last change.
5549 (__pthread_kill_other_threads_np): Reset signal handlers for the
5550 signals we used in the thread implementation here.
5552 1999-08-19 Ulrich Drepper <drepper@cygnus.com>
5554 * pthread.c (__pthread_reset_main_thread): Reset signal handlers
5555 for the signals we used in the thread implementation [PR libc/1234].
5557 * Versions: Export __pthread_kill_other_threads_np from libpthread
5560 * signals.c: Pass sigcontext through wrapper to the user function.
5562 1999-08-01 Ulrich Drepper <drepper@cygnus.com>
5564 * Versions [ld.so] (GLIBC_2.0): Export __libc_internal_tsd_get and
5565 __libc_internal_tsd_set.
5567 1999-07-29 Andreas Jaeger <aj@arthur.rhein-neckar.de>
5569 * manager.c: Remove inclusion of <linux/tasks.h> since it's not
5572 1999-07-16 Andreas Jaeger <aj@arthur.rhein-neckar.de>
5574 * internals.h: Align _pthread_descr_struct to 32 bytes.
5575 Reported by Tim Hockin <thockin@cobaltnet.com>, close PR
5578 1999-07-09 Ulrich Drepper <drepper@cygnus.com>
5580 * oldsemaphore.c (sem_compare_and_swap): Fix use of compare and
5583 1999-07-09 Cristian Gafton <gafton@redhat.com>
5585 * Makefile (libpthread-routines): Add oldsemaphore routine.
5586 * Versions: Add sem_destroy, sem_getvalue, sem_init, sem_post,
5587 sem_trywait, and sem_wait to GLIBC_2.1.
5588 * oldsemaphore.c: New file.
5589 * semaphore.c: Add default_symbol_versions for the changed functions.
5590 (__new_sem_init): Rename from sem_init.
5591 (__new_sem_post): Rename from sem_post.
5592 (__new_sem_wait): Rename from sem_wait.
5593 (__new_sem_trywait): Rename from sem_trywait.
5594 (__new_sem_getvalue): Rename from sem_getvalue.
5595 (__new_sem_destroy): Rename from sem_destroy.
5597 1999-06-23 Robey Pointer <robey@netscape.com>
5599 * internals.h: Added p_nextlock entry to separate queueing for a
5600 lock from queueing for a CV (sometimes a thread queues on a lock
5601 to serialize removing itself from a CV queue).
5602 * pthread.c: Added p_nextlock to initializers.
5603 * spinlock.c: Changed to use p_nextlock instead of p_nextwaiting.
5605 1999-07-09 Ulrich Drepper <drepper@cygnus.com>
5607 * manager.c (pthread_handle_create): Free mmap region after stack
5608 if clone failed. Patch by Kaz Kylheku <kaz@ashi.FootPrints.net>.
5610 1999-05-23 Andreas Jaeger <aj@arthur.rhein-neckar.de>
5612 * man/pthread_cond_init.man: Correct example.
5613 Reported by Tomas Berndtsson <tomas@nocrew.org>.
5615 * linuxthreads.texi (Condition Variables): Likewise.
5617 1999-05-18 Jakub Jelinek <jj@ultra.linux.cz>
5619 * sysdeps/sparc/sparc64/pt-machine.h (__compare_and_swap): Use
5620 casx not cas, also successful casx returns the old value in rd
5621 and not the new value.
5623 1999-05-16 Xavier Leroy <Xavier.Leroy@inria.fr>
5625 * manager.c: If pthread_create() is given a NULL attribute
5626 and the thread manager runs with a realtime policy, set the
5627 scheduling policy of the newly created thread back to SCHED_OTHER.
5628 * manager.c: If the PTHREAD_INHERIT_SCHED attribute is given,
5629 initialize the schedpolicy field of new_thread->p_start_args
5630 to that of the calling thread.
5632 1999-04-29 Ulrich Drepper <drepper@cygnus.com>
5634 * sysdeps/sparc/sparc64/pt-machine.h (__compare_and_swap): cas
5635 instruction does not allow memory element to use offset.
5637 1999-04-28 Ulrich Drepper <drepper@cygnus.com>
5639 * manager.c (pthread_allocate_stack): Optimize initialization of new
5642 * sysdeps/pthread/bits/libc-lock.h (__libc_lock_define_initialized):
5643 Don't use initializer since it is all zeroes.
5644 (__libc_once_define): Likewise.
5646 1999-04-16 Andreas Jaeger <aj@arthur.rhein-neckar.de>
5648 * sysdeps/arm/Implies: Removed since cmpxchg/no-cmpxchg
5649 doesn't exist anymore.
5650 * sysdeps/i386/Implies: Likewise.
5651 * sysdeps/m68k/Implies: Likewise.
5652 * sysdeps/mips/Implies: Likewise.
5653 * sysdeps/powerpc/Implies: Likewise.
5654 * sysdeps/sparc/sparc32/Implies: Likewise.
5655 * sysdeps/sparc/sparc64/Implies: Likewise.
5657 1999-04-15 Ulrich Drepper <drepper@cygnus.com>
5659 * sysdeps/alpha/bits/semaphore.h: Removed.
5660 * sysdeps/powerpc/bits/semaphore.h: Removed.
5661 * sysdeps/pthread/cmpxchg/bits/semaphore.h: Removed.
5662 * sysdeps/pthread/no-cmpxchg/bits/semaphore.h: Removed.
5663 * Makefile (headers): Remove bits/semaphore.h.
5665 * semaphore.h: Define _pthread_descr if necessary.
5666 Don't include limits.h. Define SEM_VALUE_MAX directly.
5668 (sem_t): Protect element names with leading __.
5669 Add declarations for sem_close, sem_open, and sem_unlink.
5670 * semaphore.c: Adjust all functions for new element names.
5671 Define sem_close, sem_open, and sem_unlink.
5672 * Versions (libthread): Add sem_close, sem_open, and sem_unlink for
5674 * sysdeps/pthread/bits/pthreadtypes.h: Define _pthread_descr only if
5677 1999-03-16 H.J. Lu <hjl@gnu.org>
5679 * specific.c (pthread_key_delete): Check th->p_terminated to see
5680 if the thread is running.
5682 * Versions (__libc_internal_tsd_get, __libc_internal_tsd_set):
5683 Added to GLIBC_2.0 for libc.so.
5685 1999-02-12 H.J. Lu <hjl@gnu.org>
5687 * Versions (__libc_current_sigrtmin, __libc_current_sigrtmax,
5688 __libc_allocate_rtsig): Added to GLIBC_2.1.
5690 * internals.h (DEFAULT_SIG_RESTART): Removed.
5691 (DEFAULT_SIG_CANCEL): Removed.
5693 * pthread.c (init_rtsigs, __libc_current_sigrtmin,
5694 __libc_current_sigrtmax, __libc_allocate_rtsig): New functions.
5695 (__pthread_sig_restart, __pthread_sig_cancel,
5696 __pthread_sig_debug): Initialized.
5697 (pthread_initialize): Call init_rtsigs () to initialize
5700 1999-02-03 H.J. Lu <hjl@gnu.org>
5702 * manager.c (__pthread_manager): Do block __pthread_sig_debug.
5703 Don't restart the thread which sent REQ_DEBUG.
5704 (pthread_start_thread): Check if __pthread_sig_debug > 0
5707 * pthread.c (__pthread_initialize_manager): Suspend ourself
5708 after sending __pthread_sig_debug to gdb instead of
5709 __pthread_sig_cancel.
5711 1999-01-24 H.J. Lu <hjl@gnu.org>
5713 * manager.c (__pthread_manager): Delete __pthread_sig_debug
5714 from mask if __pthread_sig_debug > 0.
5715 (pthread_handle_create): Increment __pthread_handles_num.
5717 * manager.c (pthread_handle_create): Don't pass CLONE_PTRACE to clone.
5718 * pthread.c (__pthread_initialize_manager): Likewise.
5720 * pthread.c (pthread_initialize): Use __libc_allocate_rtsig (1)
5721 instead of __libc_allocate_rtsig (2).
5722 (__pthread_initialize_manager): Send __pthread_sig_debug to gdb
5723 instead of __pthread_sig_cancel.
5724 (pthread_handle_sigdebug): Fix comments.
5726 1999-01-21 Ulrich Drepper <drepper@cygnus.com>
5728 * manager.c (pthread_allocate_stack): Set
5729 __pthread_nonstandard_stacks if user-specified stack is used.
5731 1999-01-16 Ulrich Drepper <drepper@cygnus.com>
5733 * sysdeps/unix/sysv/linux/bits/posix_opt.h: Add _LFS_ASYNCHRONOUS_IO,
5734 _LFS_LARGEFILE, _LFS64_LARGEFILE, and _LFS64_STDIO from Unix98.
5736 1999-01-07 Xavier Leroy <Xavier.Leroy@inria.fr>
5738 * pthread.c: Use a third signal __pthread_sig_debug distinct
5739 from __pthread_sig_cancel to notify gdb when a thread is
5741 * manager.c: Likewise.
5742 * internals.h: Likewise.
5743 * signals.c: The implementation of sigwait(s) assumed that
5744 all signals in s have signal handlers already attached.
5745 This is not required by the standard, so make it work
5746 also if some of the signals have no handlers.
5748 1999-01-05 Andreas Schwab <schwab@issan.cs.uni-dortmund.de>
5750 * linuxthreads.texi: Remove pointers from first @node. Move old
5751 @node spec inside comment.
5753 1998-12-31 Ulrich Drepper <drepper@cygnus.com>
5755 * sysdeps/pthread/bits/stdio-lock.h: Define _IO_lock_lock and
5758 1998-12-29 Ulrich Drepper <drepper@cygnus.com>
5760 * semaphore.c (sem_trywait): Don't forget to unlock the semaphore
5761 lock. Patch by Bernd Schmidt <crux@pool.informatik.rwth-aachen.de>.
5763 1998-12-21 Ulrich Drepper <drepper@cygnus.com>
5765 * manager.c: Threads now send __pthread_sig_cancel on termination.
5766 Change clone call and signal masks.
5767 * thread.c (pthread_handle_sigrestart): Remove special code for
5769 (pthread_handle_sigcancel): In manager thread call
5770 __pthread_manager_sighandler.
5771 * sysdeps/i386/pt-machine.h (__compare_and_swap): Add memory clobber.
5772 * sysdeps/i386/i686/pt-machine.h: Likewise.
5773 Patches by Xavier Leroy.
5775 1998-12-14 Ulrich Drepper <drepper@cygnus.com>
5777 * spinlock.c (__pthread_unlock): Don't crash if called for an
5778 untaken mutex. Reported by Ruslan V. Brushkoff <rus@Snif.Te.Net.UA>.
5780 * Examples/ex6.c: Unbuffer stdout and reduce sleep time to reduce
5783 1998-12-13 Ulrich Drepper <drepper@cygnus.com>
5785 * Examples/ex3.c: Wait until all threads are started before
5786 searching for the number to avoid race condition on very fast
5789 1998-12-08 Andreas Jaeger <aj@arthur.rhein-neckar.de>
5791 * sysdeps/pthread/pthread.h: Remove __pthread_setcanceltype
5792 declaration since it's not needed.
5794 * sysdeps/pthread/pthread.h: Move internal functions to ...
5795 * internals.h: ...here.
5797 1998-12-02 H.J. Lu <hjl@gnu.org>
5799 * pthread.c (__pthread_sig_restart): Initiliaze to 0 if
5800 SIGRTMIN is defined.
5801 (__pthread_sig_cancel): Likewise.
5803 1998-12-01 Andreas Jaeger <aj@arthur.rhein-neckar.de>
5805 * wrapsyscall.c: Include <sys/mman.h> for msync,
5806 <stdlib.h> for system and <termios.h> for tcdrain prototype.
5807 Correct msync declaration.
5809 1998-11-29 Roland McGrath <roland@baalperazim.frob.com>
5811 * sysdeps/pthread/bits/libc-tsd.h (__libc_tsd_define, __libc_tsd_get,
5812 __libc_tsd_set): New macros for new interface.
5813 * no-tsd.c: New file, provide uninitialized defns of
5814 __libc_internal_tsd_get and __libc_internal_tsd_set.
5815 * Makefile (routines): Add no-tsd.
5817 1998-10-12 Roland McGrath <roland@baalperazim.frob.com>
5819 * internals.h: Include <bits/libc-tsd.h>, not <bits/libc-lock.h>.
5820 * sysdeps/pthread/bits/libc-lock.h (__libc_internal_tsd_get,
5821 __libc_internal_tsd_set): Move decls to ...
5822 * sysdeps/pthread/bits/libc-tsd.h: New file for __libc_internal_tsd_*
5825 * sysdeps/pthread/bits/libc-lock.h (__libc_internal_tsd_get,
5826 __libc_internal_tsd_set): Make these pointers to functions, not
5827 functions; remove #pragma weak decls for them.
5828 * specific.c (__libc_internal_tsd_get, __libc_internal_tsd_set):
5829 Define static functions and initialized pointers to them.
5831 1998-11-18 Ulrich Drepper <drepper@cygnus.com>
5833 * Makefile (CFLAGS-mutex.c): Define as -D__NO_WEAK_PTHREAD_ALIASES.
5834 (CFLAGS-specific.c): Likewise.
5835 (CFLAGS-pthread.c): Likewise.
5836 (CFLAGS-ptfork.c): Likewise.
5837 (CFLAGS-cancel.c): Likewise.
5838 * sysdeps/pthread/bits/libc-lock.h: Don't mark __pthread_* functions
5839 as weak references if __NO_WEAK_PTHREAD_ALIASES is defined.
5841 * mutex.c (pthread_mutex_init): Define as strong symbol.
5842 (pthread_mutex_destroy): Likewise.
5843 (pthread_mutex_trylock): Likewise.
5844 (pthread_mutex_lock): Likewise.
5845 (pthread_mutex_unlock): Likewise.
5846 (pthread_mutexattr_init): Likewise.
5847 (pthread_mutexattr_destroy): Likewise.
5848 (pthread_once): Likewise.
5849 * ptfork.c (pthread_atfork): Likewise.
5850 * specific.c (pthread_key_create): Likewise.
5851 (pthread_setspecific): Likewise.
5852 (pthread_getspecific): Likewise.
5854 1998-11-15 Andreas Schwab <schwab@issan.cs.uni-dortmund.de>
5856 * linuxthreads.texi: Fix punctuation after xref.
5858 1998-11-10 H.J. Lu <hjl@gnu.org>
5860 * sysdeps/unix/sysv/linux/bits/local_lim.h: Undefine NR_OPEN
5861 if it is defined in <linux/limits.h>.
5863 1998-10-29 14:28 Ulrich Drepper <drepper@cygnus.com>
5865 * spinlock.h (__pthread_trylock): Define inline.
5866 (__pthread_lock): Add extra parameter to declaration. Declare
5867 using internal_function.
5868 (__pthread_unlock): Declare using internal_function.
5869 * spinlock.c (__pthread_lock): Add new parameter. Use it instead
5870 of local variable self. Avoid recomputing self. Define using
5872 (__pthread_trylock): Remove.
5873 (__pthread_unlock): Define using internal_function.
5874 * cancel.c: Adjust for __pthread_lock interface change. Use already
5875 computed self value is possible.
5876 * condvar.c: Likewise.
5878 * manager.c: Likewise.
5879 * mutex.c: Likewise.
5880 * pthread.c: Likewise.
5881 * rwlock.c: Likewise.
5882 * semaphore.c: Likewise.
5883 * signals.c: Likewise.
5885 1998-10-27 13:46 Ulrich Drepper <drepper@cygnus.com>
5887 * sysdeps/pthread/pthread.h (struct _pthread_cleanup_buffer): Prepend
5888 __ to field names of the struct.
5889 * sysdeps/pthread/bits/pthreadtypes.h (struct _pthread_fastlock):
5891 (pthread_attr_t): Likewise.
5892 (pthread_cond_t): Likewise.
5893 (pthread_condattr_t): Likewise.
5894 (pthread_mutex_t): Likewise.
5895 (pthread_mutexattr_t): Likewise.
5896 (pthread_rwlock_t): Likewise.
5897 (pthread_rwlockattr_t): Likewise.
5898 * attr.c: Adjust for pthread.h and pthreadtypes.h change.
5899 * cancel.c: Likewise.
5900 * condvar.c: Likewise.
5901 * manager.c: Likewise.
5902 * mutex.c: Likewise.
5903 * pthread.c: Likewise.
5904 * ptlongjmp.c: Likewise.
5905 * rwlock.c: Likewise.
5906 * spinlock.c: Likewise.
5908 1998-10-09 Ulrich Drepper <drepper@cygnus.com>
5910 * sysdeps/i386/pt-machine.h (get_eflags, set_eflags): Mark these
5913 * sysdeps/i386/i686/pt-machine.h: Remove unused inline
5916 * Makefile (libpthread-routines): Add pt-machine.
5917 * pt-machine.c: New file.
5918 * sysdeps/alpha/pt-machine.h: Define PT_EI as extern inline is not
5919 yet defined. Use PT_EI in extern inline definitions.
5920 * sysdeps/arm/pt-machine.h: Likewise.
5921 * sysdeps/i386/pt-machine.h: Likewise.
5922 * sysdeps/i386/i686/pt-machine.h: Likewise.
5923 * sysdeps/m68k/pt-machine.h: Likewise.
5924 * sysdeps/mips/pt-machine.h: Likewise.
5925 * sysdeps/powerpc/pt-machine.h: Likewise.
5926 * sysdeps/sparc/sparc32/pt-machine.h: Likewise.
5927 * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
5929 1998-10-02 Andreas Jaeger <aj@arthur.rhein-neckar.de>
5931 * semaphore.h: Include <sys/types.h> so that _pthread_descr
5934 1998-09-15 David S. Miller <davem@pierdol.cobaltmicro.com>
5936 * sysdeps/sparc/sparc32/pt-machine.h (INIT_THREAD_SELF): Add nr
5938 * sysdeps/sparc/sparc64/pt-machine.h (INIT_THREAD_SELF): Likewise.
5940 1998-09-12 14:24 -0400 Zack Weinberg <zack@rabi.phys.columbia.edu>
5942 * sysdeps/unix/sysv/linux/bits/sigthread.h: Add multiple inclusion
5945 1998-09-02 11:08 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
5947 * signals.c (sigaction): Check that sig is less than NSIG to avoid
5948 array index overflow.
5950 1998-09-06 10:56 Ulrich Drepper <drepper@cygnus.com>
5952 * sysdeps/pthread/semaphore.h: New file.
5954 1998-09-06 09:08 Ulrich Drepper <drepper@cygnus.com>
5956 * sysdeps/pthread/bits/libc-lock.h (enum __libc_tsd_key_t): Add
5957 _LIBC_TSD_KEY_DL_ERROR.
5959 1998-08-31 Ulrich Drepper <drepper@cygnus.com>
5961 * sysdeps/i386/i686/pt-machine.h (testandset): Add memory clobber.
5962 * sysdeps/i386/pt-machine.h: Likewise.
5963 Suggested by Roland McGrath.
5965 1998-08-28 13:58 Ulrich Drepper <drepper@cygnus.com>
5967 * internals.h: Also define THREAD_GETMEM_NC and THREAD_SETMEM_NC to
5968 access thread data with non-constant offsets.
5969 * specific.c: Use THREAD_GETMEM_NC and THREAD_SETMEM_NC where
5972 * sysdeps/i386/useldt.h: Fix typo. Add THREAD_GETMEM_NC and
5973 THREAD_SETMEM_NC definitions.
5975 * sysdeps/sparc/sparc32/pt-machine.h: Define THREAD_GETMEM_NC and
5977 * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
5979 1998-08-26 15:46 Ulrich Drepper <drepper@cygnus.com>
5981 * internals.h: Define THREAD_GETMEM and THREAD_SETMEM to default if
5982 not already defined.
5983 (struct _pthread_descr_struct): Add p_self and p_nr field.
5984 * manager.c (__pthread_handles): Define second element to point
5986 (__pthread_handles_num): Initialize to 2.
5987 (__pthread_manager): Use INIT_THREAD_SELF with two arguments.
5988 (pthread_start_thread): Likewise.
5989 (pthread_handle_create): Start search for free slot at entry 2.
5990 Initialize new fields p_self and p_nr.
5991 Call __clone with CLONE_PTRACE if available.
5992 (pthread_free): Call FREE_THREAD_SELF if available.
5993 * pthread.c (__pthread_initial_thread): Initialize new fields.
5994 (__pthread_manager_thread): Likewise.
5995 (__pthread_initialize_manager): Call __clone with CLONE_PTRACE.
5997 * cancel.c: Use THREAD_GETMEM and THREAD_SETMEM to access the
5998 elements of the thread descriptor.
5999 * condvar.c: Likewise.
6000 * errno.c: Likewise.
6002 * manager.c: Likewise.
6003 * pthread.c: Likewise.
6004 * ptlongjmp.c: Likewise.
6005 * semaphore.c: Likewise.
6006 * signals.c: Likewise.
6007 * specific.c: Likewise.
6008 * spinlock.c: Likewise.
6010 * sysdeps/alpha/pt-machine.h (INIT_THREAD_SELF): Add extra parameter.
6012 * sysdeps/i386/useldt.h: New file.
6013 * sysdeps/i386/i686/pt-machine.h: Show how to use this file.
6015 * sysdeps/sparc/sparc32/pt-machine.h: Define THREAD_GETMEM and
6016 THREAD_SETMEM using __thread_self.
6017 * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
6019 1998-08-24 Geoff Keating <geoffk@ozemail.com.au>
6021 * spinlock.c (__pthread_lock): Reset p_nextwaiting to NULL if it
6022 turned out that we didn't need to queue after all.
6024 1998-08-22 Geoff Keating <geoffk@ozemail.com.au>
6026 * sysdeps/powerpc/pt-machine.h: Remove testandset, it's not used
6027 and wastes space; correct types.
6029 1998-08-08 11:18 H.J. Lu <hjl@gnu.org>
6031 * signals.c (sigaction): Handle NULL argument.
6033 1998-08-04 Ulrich Drepper <drepper@cygnus.com>
6035 * sysdeps/unix/sysv/linux/bits/sigthread.h: Use __sigset_t instead
6038 1998-08-02 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
6040 * Makefile (linuxthreads-version): Extract correct number from
6043 1998-07-29 Xavier Leroy <Xavier.Leroy@inria.fr>
6045 * Banner: Bump version number to 0.8
6046 * FAQ.html: Many updates, in particular w.r.t. debugging.
6047 * manager.c: Support for non-default stacksize for
6048 LinuxThreads-allocated stacks;
6049 don't use guard pages for stacks with default size, rely on
6050 rlimit(RLIMIT_STACK) instead (it's cheaper).
6052 * cancel.c: Use __pthread_sig_cancel and __pthread_sig_restart
6053 everywhere instead of PTHREAD_SIG_CANCEL and PTHREAD_SIG_RESTART.
6054 * condvar.c: Likewise.
6055 * internals.h: Likewise.
6056 * restart.h: Likewise.
6057 * signals.c: Likewise.
6058 * pthread.c: Likewise; set rlimit(RLIMIT_STACK) as we need it.
6060 1998-07-23 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
6062 * weaks.c: Define pthread_mutexattr_[sg]ettype instead of
6063 __pthread_mutexattr_[sg]ettype. Add more weak aliases.
6064 * Versions: Put __pthread_mutexattr_settype under version
6065 GLIBC_2.0. Don't export __pthread_mutexattr_setkind_np and
6066 __pthread_mutexattr_gettype.
6068 1998-07-23 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
6070 * sysdeps/pthread/bits/libc-lock.h: Make
6071 __pthread_mutexattr_settype weak. Don't make
6072 __pthread_mutexattr_setkind_np weak.
6074 1998-07-16 10:52 Ulrich Drepper <drepper@cygnus.com>
6076 * manager.c (pthread_handle_create): Check whether sched_setscheduler
6077 call can succeed here.
6079 * mutex.c: Define __pthread_mutexattr_settype and make
6080 __pthread_mutexattr_setkind_np an alias.
6081 Likewise for __pthread_mutexattr_gettype.
6083 1998-07-15 11:00 -0400 Zack Weinberg <zack@rabi.phys.columbia.edu>
6085 * attr.c (pthread_attr_setschedpolicy): Don't check whether caller
6088 1998-07-14 19:38 Ulrich Drepper <drepper@cygnus.com>
6090 * sysdeps/pthread/bits/libc-lock.h: Define __libc_cleanup_end.
6092 1998-07-11 Andreas Jaeger <aj@arthur.rhein-neckar.de>
6094 * Examples/ex6.c: Include <unistd.h> for usleep.
6096 1998-06-13 11:04 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
6098 * Examples/ex4.c (main): Use exit, not pthread_exit.
6100 1998-07-09 13:39 Ulrich Drepper <drepper@cygnus.com>
6102 * Versions: Add __pthread_mutexattr_gettype and
6103 __pthread_mutexattr_settype.
6104 * lockfile.c: Use __pthread_mutexattr_settype instead of
6105 __pthread_mutexattr_setkind_np.
6106 * mutex.c: Define __pthread_mutexattr_gettype and
6107 __pthread_mutexattr_settype.
6109 * sysdeps/pthread/pthread.h: Declare __pthread_mutexattr_gettype and
6110 __pthread_mutexattr_settype.
6111 * sysdeps/pthread/bits/libc-lock.h (__libc_lock_init_recursive):
6112 Use __pthread_mutexattr_settype.
6114 1998-07-08 22:26 Ulrich Drepper <drepper@cygnus.com>
6116 * Versions: Add pthread_mutexattr_gettype, pthread_mutexattr_settype.
6117 * mutex.c: Define weak alias pthread_mutexattr_gettype and
6118 pthread_mutexattr_settype.
6119 * sysdeps/pthread/pthread.h: Declare these functions.
6120 Move pthread_sigmask and pthread_kill declaration in separate header.
6121 * sysdeps/unix/sysv/linux/bits/sigthread.h: New file.
6123 1998-07-07 15:20 Ulrich Drepper <drepper@cygnus.com>
6125 * Makefile: Add rules to compile and run tests.
6126 * Examples/ex1.c: Little changes to fix warnings.
6127 * Examples/ex2.c: Likewise.
6128 * Examples/ex3.c: Likewise.
6129 * Examples/ex4.c: Likewise.
6130 * Examples/ex5.c: Likewise.
6131 * Examples/ex6.c: New file.
6133 1998-07-05 11:54 Ulrich Drepper <drepper@cygnus.com>
6135 * Versions: Add pthread_attr_init to GLIBC_2.1 version in libc.
6137 1998-07-01 Andreas Jaeger <aj@arthur.rhein-neckar.de>
6139 * attr.c: Include <string.h>.
6141 1998-06-30 11:47 Ulrich Drepper <drepper@cygnus.com>
6143 * attr.c: Include errno.h. Use memcpy to copy sched_param.
6144 * internals.h: Include limits.h.
6145 * manager.c: Use memcpy to copy sched_param.
6146 * ptfork.c: Include errno.h.
6147 * pthread.c: Likewise.
6148 * semaphore.c: Likewise.
6149 * specific.c: Likewise.
6150 * spinlock.h: Likewise.
6151 * sysdeps/pthread/pthread.h: Include only allowed headers. Move
6152 type definition to ...
6153 * sysdeps/pthread/bits/pthreadtypes.h: ...here. New file.
6155 1998-06-29 12:34 Ulrich Drepper <drepper@cygnus.com>
6157 * sysdeps/pthread/pthread.h: Use __PMT not __P for function pointers.
6159 * sysdeps/pthread/pthread.h: Define various PTHREAD_* symbols also
6160 as macros as demanded in POSIX.1, Annex C.
6162 1998-06-29 12:29 Ulrich Drepper <drepper@cygnus.com>
6164 * internals.h (struct pthread_request): For free use pthread_t
6165 instead of pthread_descr.
6166 * join.c (pthread_join): Pass thread_id, not th to manager.
6167 (pthread_detach): Likewise.
6168 * manager.c (__pthread_manager): Except thread ID in FREE_REQ case.
6169 (pthread_exited): Remove detached queue code.
6170 (pthread_handle_free): Expect thread ID parameter and use it to
6171 validate the thread decsriptor. Don't use detached queue.
6172 Patches by Xavier Leroy.
6174 1998-06-27 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
6176 * libpthread.map: Export accept, longjmp, sigaction, siglongjmp,
6177 _IO_flockfile, _IO_ftrylockfile, _IO_funlockfile,
6178 __pthread_atfork, __pthread_key_create, __pthread_once.
6179 * internals.h: Doc fix.
6180 * pthread.c (__pthread_initialize): Define again.
6182 1998-06-26 Ulrich Drepper <drepper@cygnus.com>
6184 * manager.c (pthread_exited): If thread is not detached put it on
6186 (pthread_handle_free): If thread is not on list with living threads
6187 search on list with detached threads.
6189 * sysdeps/pthread/pthread.h (PTHREAD_RWLOCK_INITIALIZER): Correct
6190 for new definition of pthread_rwlock_t.
6192 * spinlock.c: Correct test whether to compile
6193 __pthread_compare_and_swap or not.
6195 1998-06-25 19:27 Ulrich Drepper <drepper@cygnus.com>
6197 * attr.c: Finish user stack support. Change locking code to be safe
6198 in situations with different priorities.
6199 * cancel.c: Likewise.
6200 * condvar.c: Likewise.
6201 * internals.h: Likewise.
6203 * manager.c: Likewise.
6204 * mutex.c: Likewise.
6205 * pthread.c: Likewise.
6206 * ptlongjmp.c: Likewise.
6207 * queue.h: Likewise.
6208 * rwlock.c: Likewise.
6209 * semaphore.c: Likewise.
6210 * semaphore.h: Likewise.
6211 * signals.c: Likewise.
6212 * spinlock.c: Likewise.
6213 * spinlock.h: Likewise.
6214 * sysdeps/pthread/pthread.h: Likewise.
6215 Patches by Xavier Leroy.
6217 * sysdeps/i386/i686/pt-machine.h: New file.
6219 1998-06-25 Ulrich Drepper <drepper@cygnus.com>
6221 * sysdeps/pthread/pthread.h: Make [sg]et_stacksize and
6222 [sg]et_stackaddr prototypes always available.
6224 * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define
6225 _POSIX_THREAD_ATTR_STACKSIZE and _POSIX_THREAD_ATTR_STACKADDR.
6227 1998-06-24 Ulrich Drepper <drepper@cygnus.com>
6229 * manager.c (pthread_free): Undo patch from 980430.
6230 Reported by David Wragg <dpw@doc.ic.ac.uk>.
6232 1998-06-09 15:07 Ulrich Drepper <drepper@cygnus.com>
6234 * manager.c: Define __pthread_manager_adjust_prio and use it to
6235 increase priority when needed.
6236 * internals.h: Add prototype for __pthread_manager_adjust_prio.
6237 * mutex.c: Optimize mutexes to wake up only one thread.
6238 * pthread.c: Move PID of manager for global variable in structure
6240 Patches by Xavier Leroy.
6242 1998-06-07 13:47 Ulrich Drepper <drepper@cygnus.com>
6244 * sysdeps/pthread/bits/libc-lock.h: Optimize cleanup handlers a bit.
6246 1998-06-03 Andreas Jaeger <aj@arthur.rhein-neckar.de>
6248 * attr.c: Correct typo.
6250 1998-05-01 Ulrich Drepper <drepper@cygnus.com>
6252 * manager.c (pthread_free): Unmap guard before the stack.
6253 Patch by Matthias Urlichs.
6255 1998-04-30 Ulrich Drepper <drepper@cygnus.com>
6257 * manager.c (pthread_free): Detect already free child.
6258 Patch by Xavier Leroy, reported by Matthias Urlichs.
6260 1998-04-23 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
6262 * Makefile (linuxthreads-version): Renamed back from
6265 1998-04-21 Ulrich Drepper <drepper@cygnus.com>
6267 * ptlongjmp.c: Add prototypes for __libc_siglongjmp and
6270 1998-04-20 14:55 Ulrich Drepper <drepper@cygnus.com>
6272 * Makefile (libpthread-routines): Add ptlongjmp and spinlock.
6273 * internals.h: Add definitions for new spinlock implementation.
6274 * ptlongjmp.c: New file.
6275 * spinlock.c: New file.
6276 * spinlock.h (acquire): Don't reschedule using __sched_yield, use
6277 new function __pthread_acquire to prevent deadlocks with thread
6278 with different priorities.
6279 Patches by Xavier Leroy <Xavier.Leroy@inria.fr>.
6281 1998-03-16 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
6283 * manager.c (__pthread_manager): Reduce first argument to select
6284 to include just the needed file descriptor.
6286 1998-03-17 00:06 Ulrich Drepper <drepper@cygnus.com>
6288 * manager.c: Fix last patch which caused core dumps.
6290 * pthread.c: Correctly handle missing SIGRTMIN.
6292 1998-03-15 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
6294 * libpthread.map: Add __libc_internal_tsd_get and
6295 __libc_internal_tsd_set. Add missing cancelable functions. Export
6296 libc internal versions of the cancelable functions.
6298 1998-03-13 16:51 Ulrich Drepper <drepper@cygnus.com>
6300 * weaks.c: Define pthread_attr_init as GLIBC_2.0 and GLIBC_2.1.
6302 1998-03-13 00:46 Ulrich Drepper <drepper@cygnus.com>
6304 * attr.c: Implement pthread_attr_[gs]etguardsize,
6305 pthread_attr_[gs]setstackaddr, pthread_attr_[gs]etstacksize.
6306 Change pthread_attr_init to have two interfaces.
6307 * internals.h (struct _pthread_descr_struct): Add new fields for
6309 * libpthread.map: Add names in GLIBC_2.1 section.
6310 * manager.c (pthread_handle_create): Implement guardsize and
6312 (pthread_free): Likewise.
6313 * pthread.c (pthread_create): Add new interface for changed
6315 * sysdeps/pthread/pthread.h: Add prototypes for new functions.
6316 * sysdeps/unix/sysv/linux/bits/local_lim.h: Add definition of
6319 1998-03-11 00:42 Wolfram Gloger <wmglo@dent.med.uni-muenchen.de>
6321 * manager.c: Enable resetting of the thread scheduling policy
6322 to SCHED_OTHER when the parent thread has a different one.
6324 1998-02-01 13:51 Ulrich Drepper <drepper@cygnus.com>
6326 * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define
6327 _POSIX_ASYNCHRONOUS_IO.
6329 * sysdeps/pthread/pthread.h: Define bits for Unix98 variants of
6331 * mutex.c: Implement new mutex types.
6333 * internals.h: Include <signal.h>.
6335 * libpthread.map: Add __erno_location and __h_errno_location.
6337 * errno.c: Return pointer to variable actually in use. This might
6338 not be the one in the thread structure.
6339 * internals.h (struct _pthread_descr_struct): Add new fields p_errnop
6341 * manager.c (__pthread_manager): Set p_errnop and p_h_errnop member
6342 of manager thread structure.
6343 (pthread_handle_create): Set p_errnop and p_h_errnop members for new
6345 * pthread.c: Adapt initializer for thread structures.
6346 (__pthread_initial_thread): Set p_errnop and p_h_errnop member.
6347 (__pthread_reset_main_thread): Reset p_errnop and p_h_errnop of
6348 current thread to global variables.
6350 1998-01-31 17:27 Ulrich Drepper <drepper@cygnus.com>
6352 * rwlock.c: New file.
6353 * Makefile (libpthread-routines): Add rwlock.
6354 * sysdeps/pthread/pthread.h: Define data structures and declare
6356 * libpthread.map: Add new functions.
6358 1997-12-18 13:50 Philip Blundell <pb@nexus.co.uk>
6360 * sysdeps/arm/pt-machine.h: New file; add ARM support.
6361 * sysdeps/arm/Implies: likewise.
6362 * README: Document it.
6364 1997-12-13 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
6366 * signals.c: Remove unneeded initializer for sigwaited, saving a
6369 1997-04-11 01:18 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
6371 * semaphore.c (sem_init): Set sem_spinlock only if available.
6373 1997-12-04 01:48 Ulrich Drepper <drepper@cygnus.com>
6375 * mutex.c: Implement PTHREAD_MUTEX_CHECKERROR.
6376 * sysdeps/pthread/pthread.h: Define PTHREAD_MUTEX_CHECKERROR.
6378 * Makefile: Update from LinuxThreads 0.7.
6379 * internals.h. Likewise.
6380 * manager.c: Likewise.
6381 * mutex.c: Likewise.
6382 * pthread.c: Likewise.
6383 * signals.c: Likewise.
6384 * specific.c: Likewise.
6385 * Examples/ex3.c: Likewise.
6387 1997-11-20 18:13 Ulrich Drepper <drepper@cygnus.com>
6389 * pthread.c (__pthread_reset_main_thread): Close pipe only if still
6392 1997-10-29 05:38 Ulrich Drepper <drepper@cygnus.com>
6394 * wrapsyscall.c: Add socket functions which are also cancelation
6397 1997-10-19 21:40 Wolfram Gloger <wg@wolfram.dent.med.uni-muenchen.de>
6399 * specific.c (__libc_internal_tsd_set, __libc_internal_tsd_get):
6400 New functions for fast thread specific data within libc.
6402 * internals.h: Add new array p_libc_specific to struct
6403 _pthread_descr_struct.
6405 * sysdeps/pthread/bits/libc-lock.h: Declare new functions.
6407 1997-10-13 05:39 Ulrich Drepper <drepper@cygnus.com>
6409 * semaphore.h: Add __BEGIN_DECLS/__END_DECLS.
6410 Reported by Ralf Corsepius <corsepiu@faw.uni-ulm.de>.
6412 1997-08-29 03:05 Ulrich Drepper <drepper@cygnus.com>
6414 * internals.h (struct _pthread_descr_struct): Add definitions for
6415 two-level specific key handling.
6416 * manager.c (pthread_handle_create): Initialize specific memory array.
6417 * specific.c: Implement two-level key handling.
6418 * weaks.c: Don't provide dummy key handling.
6419 * sysdeps/pthread/bits/libc-lock.h: Typedef __libc_lock_t (no #define).
6420 Add definition of __libc_key_t.
6421 * sysdeps/unix/sysv/linux/bits/local_lim.h: Define PTHREAD_KEYS_MAX
6423 Add definition of _POSIX_THREAD_DESTRUCTOR_ITERATIONS and
6424 PTHREAD_DESTRUCTOR_ITERATIONS.
6426 * manager.c (pthread_handle_create): Compare mmap result with
6429 * ptfork.c: Rename to __pthread_atfork and make old name a weak alias.
6430 * sysdeps/pthread/bits/pthread.h: Add prototype for __pthread_atfork.
6432 1997-08-22 19:04 Richard Henderson <rth@cygnus.com>
6434 sysdeps/sparc -> sysdeps/sparc/sparc32
6435 sysdeps/sparc64 -> sysdeps/sparc/sparc64
6437 * internals.h: Change definition of THREAD_SELF to be an expression,
6438 not a statement that did a return.
6439 * sysdeps/alpha/pt-machine.h (THREAD_SELF): Update accordingly.
6440 * sysdeps/sparc/sparc32/pt-machine.h (THREAD_SELF, INIT_THREAD_SELF):
6441 Follow Solaris and use a "system reserved" register (%g6) to hold
6442 the thread descriptor.
6443 * sysdeps/sparc/sparc64/pt-machine.h: Likewise.
6445 1997-08-03 00:09 Ulrich Drepper <drepper@cygnus.com>
6447 * mutex.c: Correct pthread_once. Patch by Xavier Leroy.
6448 * sysdeps/pthread/pthread.h: Add prototype for __pthread_once.
6449 * sysdeps/pthread/bits/pthread.h: Add macros for __libc_once.
6451 * semaphore.c: Include spinlock.h only when needed.
6453 * specific.c (__pthread_setsepcific, __pthread_getspecific): Reject
6454 keys for entries not in use.
6456 * weaks.c: Implement key handling functions for real.
6458 1997-06-29 01:04 Richard Henderson <richard@gnu.ai.mit.edu>
6460 Initial sparc64-linux support:
6461 * sysdeps/sparc64/Implies: New file.
6462 * sysdeps/sparc64/pt-machine.h: Likewise.
6464 1997-06-29 00:48 Ulrich Drepper <drepper@cygnus.com>
6466 * semaphore.c: Include spinlock.h at correct place.
6469 1997-06-13 10:06 Richard Henderson <rth@tamu.edu>
6471 The Great Bit File Move:
6472 * sysdeps/alpha/semaphorebits.h: -> .../bits/semaphore.h.
6473 * sysdeps/powerpc/semaphorebits.h: Likewise.
6474 * sysdeps/pthread/cmpxchg/semaphorebits.h: Likewise.
6475 * sysdeps/pthread/no-cmpxchg/semaphorebits.h: Likewise.
6476 * sysdeps/pthread/libc-lock.h: -> bits/
6477 * sysdeps/pthread/stdio-lock.h: Likewise.
6478 * sysdeps/unix/sysv/linux/local_lim.h: Likewise.
6479 * sysdeps/unix/sysv/linux/posix_opt.h: Likewise.
6480 * semaphore.h: Likewise.
6481 * sysdeps/pthread/pthread.h: Likewise.
6483 * lockfile.c: <foo.h> -> <bits/foo.h>.
6484 * semaphore.h: Likewise.
6486 * Makefile: (headers): foo.h -> bits/foo.h.
6487 * sysdeps/pthread/Makefile: Likewise.
6489 1997-04-11 01:18 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
6491 * semaphore.c (sem_init): Set sem_spinlock only if available.
6493 * sysdeps/m68k/pt-machine.h (testandset, __compare_and_swap): Fix
6496 1997-04-09 03:00 Ulrich Drepper <drepper@cygnus.com>
6498 Update from LinuxThreads 0.6.
6500 * attr.c (pthread_attr_getdetachstate): Use __sched_get_priority_max
6501 and __sched_get_priority_min instead of names without `__'.
6503 * manager.c: Rewrite large parts to implement opaque pthread_t.
6505 * cancel.c: Adapt for opaque pthread_t type.
6506 * condvar.c: Likewise.
6507 * errno.c: Likewise.
6509 * mutex.c: Likewise.
6510 * pthread.c: Likewise.
6511 * signals.c: Likewise.
6512 * specific.c: Likewise.
6513 * restart.h: Likewise.
6514 * queue.h: Likewise.
6515 * Examples/ex3.c: Likewise.
6516 * Examples/ex4.c: Likewise.
6517 * sysdeps/pthread/pthread.h: Likewise.
6519 * pthread.c: Accumulate time for all threads in thread manager.
6521 * semaphore.c: Implement fallback implementation for architectures
6522 sometimes missing compare-exchange operations.
6524 * cancel.c (pthread_cancel): Validate handle argument.
6525 * join.c (pthread_join): Likewise.
6526 (pthread_detach): Likewise.
6527 * signals.c (pthread_kill): Likewise.
6529 * spinlock.h (acquire): Use __sched_yield not sched_yield.
6531 * queue.h (enqueue): Enqueue thread according to priority.
6533 * internals.c (struct pthread_start_args): New struct for passing
6534 args to cloning function.
6535 (struct _pthread): Rename to _pthread_descr_struct and adapt for
6538 * Examples/Makefile (clean): Pass -f option to rm.
6540 * sysdeps/i386/pt-machine.h: Add check for compare-exchange instruction
6541 and define TEST_FOR_COMPARE_AND_SWAP.
6542 * sysdeps/i386/i486/pt-machine.h: Removed.
6544 * sysdeps/unix/sysv/linux/local_lim.h (PTHREAD_THREADS_MAX): Increase
6547 1997-04-04 16:38 Ulrich Drepper <drepper@cygnus.com>
6549 * restart.h (suspend): Clear p_signal before suspending.
6550 (suspend_with_cancellation): Likewise.
6551 Patch by Xavier Leroy <Xavier.Leroy@inria.fr>.
6553 * weaks.c: Make __pthread_key_create return 1.
6554 * sysdeps/pthread/libc-lock.h: Define __libc_key_create,
6555 __libc_getspecific, __libc_setspecific, and __libc_key_t.
6556 * sysdeps/pthread/stdio-lock.h: Don't care for implementation not
6559 1997-03-19 15:13 Miguel de Icaza <miguel@nuclecu.unam.mx>
6561 * sysdeps/sparc/pt-machine (RELEASE): Fix.
6563 1997-03-01 07:55 Geoff Keating <geoffk@ozemail.com.au>
6565 * sysdeps/powerpc/Implies: Added.
6566 * sysdeps/powerpc/pt-machine.h: Added.
6567 * sysdeps/powerpc/semaphorebits.h: Added.
6569 1997-01-22 01:22 Ulrich Drepper <drepper@cygnus.com>
6571 * pthread.c (__pthread_initial_thread): Correct
6573 (__pthread_manager_thread): Likewise.
6574 Reported by Andreas Jaeger.
6576 1997-01-18 22:15 Richard Henderson <rth@tamu.edu>
6578 Since sigset_t no longer fits in a register, we can't pass in the
6579 thread's initial mask so easily. Take this opportunity to simplify
6580 the clone implementation by only accepting a single void* argument.
6582 * manager.c (__pthread_manager): Put thread vitals in the thread
6583 struct instead of as arguments through clone.
6584 (pthread_start_thread): Look for them there.
6585 * internals.h (struct _pthread): Add p_initial_fn,
6586 p_initial_fn_arg, p_initial_mask. Fix __pthread_manager proto.
6587 * pthread.c (pthread_initialize_manager): Revise clone invocation.