| Commit message (Collapse) | Author | Age | Files | Lines |
| |
|
|
|
|
|
|
|
| |
return EINVAL if thread was detached.
Approved by: re (kensmith)
Notes:
svn path=/releng/6.2/; revision=165476
|
| |
|
|
|
|
|
| |
make signal(SIGINFO, handler) work for libpthread.
Notes:
svn path=/stable/6/; revision=159877
|
| |
|
|
|
|
|
|
| |
pthread.map 1.18
thread/thr_symbols.c 1.4
Notes:
svn path=/stable/6/; revision=158852
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Only catch SIGINFO (for dumping thread states) when LIBPTHREAD_DEBUG
is defined in the environment.
Modify the code path of the ifdef NOTYET part of _kse_single_thread():
o Don't reinitialise the atfork() handler list in the child. We
are meant to call the child handler, and on subsequent fork()s
should call all three functions as normal.
o Don't reinitialise the thread specific keyed data in the
child after a fork. Applications may require this for context.
o Reinitialise curthread->tlflags after removing ourselves from
(and reinitialising) the various internal thread lists.
o Reinitialise __malloc_lock in the child after fork() (to balance
our explicitly taking the lock prior to the fork()).
With these changes, it is possible to enable the NOTYET code in
thr_kern.c to allow the use of non-async-safe functions after
fork()ing from a threaded program.
Eliminate a race condition in timed waits (cv, mutex, and sleeps).
Don't forget to initialize a tailq before using it.
For the ``#ifdef NOTYET'' code that allows calling non-async-safe
functions in the child after a fork() from a threaded process,
use __sys_setprocmask() rather than setprocmask() to keep our
signal handling sane. Without this fix, signals are essentially
ignored in said child and things such as protection violations
result in an endless busy loop.
Allocate a thread's tcb last so it is easier to handle failures to
malloc() siginfo.
Include needed headers that were obtained through <pthread.h>. Sort headers
while here.
amd64
-----
Fix a race condition introduced when redzones were added. Use an
atomic operation to return and adjust the stack (amd64).
test
-----
o Include <string.h>
o Make this ILP32/LP64 clean: cast pointers to long.
Approved by: re (scottl)
Notes:
svn path=/stable/6/; revision=156790
|
| |
|
|
|
|
|
| |
Add file thr_mattr_pshared.c and thr_condattr_pshared.c.
Notes:
svn path=/stable/6/; revision=153442
|
| |
|
|
| |
Notes:
svn path=/stable/6/; revision=151613
|
| |
|
|
|
|
|
|
|
|
|
|
|
| |
| Add a cancellation point for usleep().
|
| Revision Changes Path
| 1.9 +16 -1 src/lib/libpthread/thread/thr_sleep.c
Approved by: re (kensmith)
Ok'ed by: deischen, davidxu
Notes:
svn path=/stable/6/; revision=151096
|
| |
|
|
|
|
|
|
|
| |
Reviewed by: deischen
Approved by: re (dwhite)
MFC after : 4 days
Notes:
svn path=/head/; revision=147533
|
| |
|
|
|
|
|
|
|
|
| |
changed to use the statclock. Make sure we calculate the value
of a tick correctly in userland.
Noticed by: Kazuaki Oda <kaakun at highway dot ne dot jp>
Notes:
svn path=/head/; revision=142047
|
| |
|
|
|
|
|
| |
attribute when the library is initialized.
Notes:
svn path=/head/; revision=141949
|
| |
|
|
|
|
|
|
|
| |
32-bit 64-bit
main thread 2MB 4MB
other threads 1MB 2MB
Notes:
svn path=/head/; revision=141822
|
| |
|
|
|
|
|
| |
PR: 75273
Notes:
svn path=/head/; revision=139052
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
signals instead of having more intricate knowledge of thread state
within signal handling.
Simplify signal code because of above (by David Xu).
Use macros for libpthread usage of pthread_cleanup_push() and
pthread_cleanup_pop(). This removes some instances of malloc()
and free() from the semaphore and pthread_once() implementations.
When single threaded and forking(), make sure that the current
thread's signal mask is inherited by the forked thread.
Use private mutexes for libc and libpthread. Signals are
deferred while threads hold private mutexes. This fix also
breaks www/linuxpluginwrapper; a patch that fixes it is at
http://people.freebsd.org/~deischen/kse/linuxpluginwrapper.diff
Fix race condition in condition variables where handling a
signal (pthread_kill() or kill()) may not see a wakeup
(pthread_cond_signal() or pthread_cond_broadcast()).
In collaboration with: davidxu
Notes:
svn path=/head/; revision=139023
|
| |
|
|
|
|
|
|
|
|
| |
a thread in pthread_cond_wait handled a signal can no longer
be canceled.
Reviewed by: deischen
Notes:
svn path=/head/; revision=137105
|
| |
|
|
|
|
|
|
|
|
|
|
| |
packages expect and seems to be most correct according to the slightly-
ambiguous standards.
MFC after: 1 month
Corroborated by: POSIX <http://tinyurl.com/4uvub>
Reviewed by: silence on threads@
Notes:
svn path=/head/; revision=137095
|
| |
|
|
|
|
|
|
| |
this reduces chances of signal losting problem found by
Peter Holm <peter@holm.cc>
Notes:
svn path=/head/; revision=136847
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
| |
put DEAD thread on GC list, this closes a race between pthread_join
and thr_cleanup.
2. Introduce a mutex to protect tcb initialization, tls allocation and
deallocation code in rtld seems no lock protection or it is broken,
under stress testing, memory is corrupted.
Reviewed by: deischen
patch partly provided by: deischen
Notes:
svn path=/head/; revision=136846
|
| |
|
|
|
|
|
| |
leak under some cases.
Notes:
svn path=/head/; revision=136735
|
| |
|
|
|
|
|
|
|
| |
before and after sleeping.
Reviewed by: deischen
Notes:
svn path=/head/; revision=136286
|
| |
|
|
| |
Notes:
svn path=/head/; revision=136227
|
| |
|
|
|
|
|
| |
of kse_thr_interrupt.
Notes:
svn path=/head/; revision=136223
|
| |
|
|
|
|
|
|
| |
allocated space, orignal code left red zone unallocated, but those space
can be allocated by user code, and result was providing no protection.
Notes:
svn path=/head/; revision=136190
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
the signal mask and pending signals of the calling thread. These
are stored in userland in libpthread.
There is a small race condition in this patch which could cause
problems if a signal arrives after setting the (kernel) signal
mask and before exec'ing. The thread's set of pending signals
also are not yet installed in the exec'd process. Both of these
will be corrected with the addition of a special syscall.
Reported & Tested by: Joost Bekkers <joost at jodocus dot org>
Reviewed by: julian, davidxu
Notes:
svn path=/head/; revision=135809
|
| |
|
|
|
|
|
|
|
| |
defined. This makes libpthread usable on powerpc.
Approved by: grehan (mentor), deischen
Notes:
svn path=/head/; revision=135714
|
| |
|
|
|
|
|
| |
Reviewed by: desichen
Notes:
svn path=/head/; revision=134115
|
| |
|
|
|
|
|
| |
2. Export symbols needed by debugger.
Notes:
svn path=/head/; revision=133801
|
| |
|
|
| |
Notes:
svn path=/head/; revision=133800
|
| |
|
|
| |
Notes:
svn path=/head/; revision=133756
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
a knob to force process scope threads. If the environment variable
LIBPTHREAD_PROCESS_SCOPE is set, force all threads to be process
scope threads regardless of how the application creates them. If
LIBPTHREAD_SYSTEM_SCOPE is set (forcing system scope threads), it
overrides LIBPTHREAD_PROCESS_SCOPE.
$ # To force system scope threads
$ LIBPTHREAD_SYSTEM_SCOPE=anything threaded_app
$ # To force process scope threads
$ LIBPTHREAD_PROCESS_SCOPE=anything threaded_app
Notes:
svn path=/head/; revision=133563
|
| |
|
|
|
|
|
| |
Reviewed by: deischen
Notes:
svn path=/head/; revision=133344
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
| |
LIBPTHREAD_SYSTEM_SCOPE in the environment.
You can still force libpthread to be built in strictly 1:1 by
adding -DSYSTEM_SCOPE_ONLY to CFLAGS. This is kept for archs
that don't yet support M:N mode.
Requested by: rwatson
Reviewed by: davidxu
Notes:
svn path=/head/; revision=133269
|
| |
|
|
|
|
|
| |
Dicussed with: deischen
Notes:
svn path=/head/; revision=133047
|
| |
|
|
|
|
|
| |
libthread_db. Both headers are included seperately.
Notes:
svn path=/head/; revision=132333
|
| |
|
|
| |
Notes:
svn path=/head/; revision=132124
|
| |
|
|
| |
Notes:
svn path=/head/; revision=132122
|
| |
|
|
| |
Notes:
svn path=/head/; revision=132121
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
1. Add global varible _libkse_debug, debugger uses the varible to identify
libpthread. when the varible is written to non-zero by debugger, libpthread
will take some special action at context switch time, it will check
TMDF_DOTRUNUSER flags, if a thread has the flags set by debugger, it won't
be scheduled, when a thread leaves KSE critical region, thread checks
the flag, if it was set, the thread relinquish CPU.
2. Add pq_first_debug to select a thread allowd to run by debugger.
3. Some names prefixed with _thr are renamed to _thread prefix.
which is allowed to run by debugger.
Notes:
svn path=/head/; revision=132120
|
| |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
sigsuspend, thread shouldn't wait, in old code, it may be
ignored.
When a signal handler is invoked in sigsuspend, thread gets
two different signal masks, one is in thread structure,
sigprocmask() can retrieve it, another is in ucontext
which is a third parameter of signal handler, the former is
the result of sigsuspend mask ORed with sigaction's sa_mask
and current signal, the later is the mask in thread structure
before sigsuspend is called. After signal handler is called,
the mask in ucontext should be copied into thread structure,
and becomes CURRENT signal mask, then sigsuspend returns to
user code.
Reviewed by: deischen
Tested by: Sean McNeil <sean@mcneil.com>
Notes:
svn path=/head/; revision=130374
|
| |
|
|
|
|
|
|
|
|
|
|
|
| |
mode (where the forked thread is the one and only thread and
is marked as system scope), set the system scope flag before
initializing the signal mask. This prevents trying to use
internal locks that haven't yet been initialized.
Reported by: Dan Nelson <dnelson at allantgroup.com>
Reviewed by: davidxu
Notes:
svn path=/head/; revision=128041
|
| |
|
|
|
|
|
| |
in return value not in errno.
Notes:
svn path=/head/; revision=127102
|
| |
|
|
| |
Notes:
svn path=/head/; revision=126952
|
| |
|
|
|
|
|
|
|
|
|
| |
These files had tags after the copyright notice,
inside the comment block (incorrect, removed),
and outside the comment block (correct).
Approved by: rwatson (mentor)
Notes:
svn path=/head/; revision=125668
|
| |
|
|
|
|
|
|
|
|
|
| |
semaphores. Also add cancellation cleanup handlers to keep semaphores
in a consistent state.
Submitted in part by: davidxu
Reviewed by: davidxu
Notes:
svn path=/head/; revision=125522
|
| |
|
|
|
|
|
| |
points to sem_wait() and sem_timedwait(). Also make sem_post signal-safe.
Notes:
svn path=/head/; revision=125373
|
| |
|
|
|
|
|
|
|
| |
unlock the mutex, old code confuses some programs when it returns EINVAL.
Noticed by: bland
Notes:
svn path=/head/; revision=124606
|
| |
|
|
|
|
|
|
|
|
|
|
|
| |
on a rwlock while there are writers waiting. We normally favor
writers but when a reader already has at least one other read lock,
we favor the reader. We don't track all the rwlocks owned by a
thread, nor all the threads that own a rwlock -- we just keep
a count of all the read locks owned by a thread.
PR: 24641
Notes:
svn path=/head/; revision=124252
|
| |
|
|
|
|
|
| |
enable sigaltstack for scope system thread.
Notes:
svn path=/head/; revision=124095
|
| |
|
|
| |
Notes:
svn path=/head/; revision=124056
|
| |
|
|
| |
Notes:
svn path=/head/; revision=124055
|
| |
|
|
| |
Notes:
svn path=/head/; revision=123975
|