[C++-sig] that problem with comparing types across DLLs
Zooko O'Whielacronx
zookog at gmail.com
Wed May 27 17:42:48 CEST 2009
(Note that several individuals, plus tahoe-dev at allmydata.org and
cplusplus-sig at python.org are Cc:'ed. This is appropriate because this
is fundamentally a "cross project" issue and we need to talk to each
other until we understand what the other developers are planning.
Unfortunately, you're likely to have problems following-up to the
mailing lists if you aren't subscribed to them.)
On May 27, 2009, at 1:01 AM, Matthias Klose wrote:
>
> Well, maybe nobody did ask, because it's policy for distributions to build
> against shared libs? If there needs something to be fixed in the library
> package, you only have to take care of the library packages, not all packages
> which are linked against the static library (of course you would have to find
> out which these packages are). Plus you usually cannot link a python extension
> against a static lib because the static lib is built without -fPIC.
Thanks, Matthias, and thanks to Ruben for the earlier answers about Fedora.
It looks like option #1 from this list is right out:
http://mail.python.org/pipermail/cplusplus-sig/2009-May/014531.html
(Option #1 was to persuade distributions to support Crypto++ as a
static library.)
The option that would be technically the most general would be to
figure out how to annotate and compile Crypto++ as a shared lib that
has visible only the symbols that it needs to have visible, and then
use the RTLD_GLOBAL flag to dlopen() to make sure multiple .so's which
each depend on libcryptopp.so will get those symbols unified at
load-time so that cross-shared-library RTTI will work. That is what
Niall Douglas recommends and has done successfully in the past.
However, I've already spent a couple of days trying to learn how to do
this and I haven't succeeded yet. I'm not even sure that it is
possible. Wei Dai, the author of Crypto++, has also tried in the past
to build such a shared lib of Crypto++ for Unix in the past, and he
too gave up. That also means that he does not currently support using
Crypto++ as a shared library, which makes me uncomfortable, but I
guess that's the Linux distributions' problem more than mine.
I think that leaves option #2 from that list: refactor pycryptopp so
that it contains only a single shared library, and use RTLD_GLOBAL to
unify the symbols that are visible in the _pycryptopp.so with the
symbols in the the libcryptopp.so. I think this is doable and that it
will solve all known problems for pycryptopp and Tahoe. I think this
does mean that if in the future there is a different Python module
than pycryptopp which is dynamically linked to libcryptopp.so, that
anyone who imports both pycryptopp and that other Python module into
their Python interpreter will get a seg fault. However, I suppose
this too is someone else's problem than mine.
So unless anyone else has a better suggestion, I'm going to proceed
with strategy #2. I'll probably also continue to support the current
linking strategy of linking pycryptopp statically against
libcryptopp.a, as a build-time option for pycryptopp. Therefore
people who have chosen the static-link-to-Crypto++ build-time option
(which excludes users of the Fedora, Debian, or Ubuntu packages of
pycryptopp) will be able to also import another Python module which
links to Crypto++.
Thanks, folks!
Regards,
Zooko
More information about the Cplusplus-sig
mailing list