running threaded tasks in dynamically linked objects from a
non-threaded app
John E Hein
jhein at timing.com
Sun Mar 2 17:18:49 UTC 2008
I am having some issues with an application that uses...
[1] perl to run test scripts
[2] with eventually call modules in C modules
[3] which link with a lib that contains pthread* references.
When the tests run, one gets undefined references to pthread calls
from the run-time linker.
[1] the perl port was not built WITH_THREADS=yes (non-threaded
is the default)
[3] this lib was built with -pthread, but this does not contain
an explicit dependency on any threading library. That's
how our -pthread works (so one can decide at the time an
application is linked which threading lib to use)
workarounds:
- LD_PRELOAD=/usr/lib/libthr.so (or libpthread.so if desired)
- require perl to be built WITH_THREADS=yes for
users of this application
- build the lib in [3] with -lthr or -lpthread. This
can break if perl in built WITH_THREADS=yes and
the threading libs in [1] and [3] don't match.
These all have weaknesses in one facet or another.
Are there any different solutions?
More information about the freebsd-threads
mailing list