Summary: | dlopen/libthr appears broken | ||
---|---|---|---|
Product: | Base System | Reporter: | Kyle Evans <kevans> |
Component: | threads | Assignee: | freebsd-threads (Nobody) <threads> |
Status: | Closed FIXED | ||
Severity: | Affects Only Me | CC: | andrew, i+fbsd, kib |
Priority: | --- | Keywords: | patch |
Version: | CURRENT | ||
Hardware: | Any | ||
OS: | Any | ||
See Also: |
https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=235158 https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=220767 https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=236689 |
Description
Kyle Evans
2019-01-26 05:41:25 UTC
CC kib@ because it looks like an rtld bug, perhaps. A commit references this bug: Author: kib Date: Tue Jan 29 22:46:46 UTC 2019 New revision: 343566 URL: https://svnweb.freebsd.org/changeset/base/343566 Log: Untangle jemalloc and mutexes initialization. The need to use libc malloc(3) from some places in libthr always caused issues. For instance, per-thread key allocation was switched to use plain mmap(2) to get storage, because some third party mallocs used keys for implementation of calloc(3). Even more important, libthr calls calloc(3) during initialization of pthread mutexes, and jemalloc uses pthread mutexes. Jemalloc provides some way to both postpone the initialization, and to make initialization to use specialized allocator, but this is very fragile and often breaks. See the referenced PR for another example. Add the small malloc implementation used by rtld, to libthr. Use it in thr_spec.c and for mutexes initialization. This avoids the issues with mutual dependencies between malloc and libthr in principle. The drawback is that some more allocations are not interceptable for alternate malloc implementations. There should be not too much memory use from this allocator, and the alternative, direct use of mmap(2) is obviously worse. PR: 235211 MFC after: 2 weeks Sponsored by: The FreeBSD Foundation Differential revision: https://reviews.freebsd.org/D18988 Changes: head/lib/libthr/Makefile head/lib/libthr/thread/Makefile.inc head/lib/libthr/thread/thr_fork.c head/lib/libthr/thread/thr_init.c head/lib/libthr/thread/thr_malloc.c head/lib/libthr/thread/thr_mutex.c head/lib/libthr/thread/thr_private.h head/lib/libthr/thread/thr_spec.c There's a report on the ARM list of a crash in /rescue/* on armv7 pointing at this new code. Offhand, isn't it a problem that handle_static_init calls atexit() which calls pthread_mutex_lock, before libthr's initialization is run? The follow-up /rescue breakage was fixed by r343754 -- atexit appears to not be an issue. |