Subject: Re: pkg/33932
To: None <taya@NetBSD.org, gnats-admin@netbsd.org, pkgsrc-bugs@netbsd.org,>
From: Sergey Svishchev <svs@ropnet.ru>
List: pkgsrc-bugs
Date: 07/09/2006 09:20:02
The following reply was made to PR pkg/33932; it has been noted by GNATS.
From: Sergey Svishchev <svs@ropnet.ru>
To: gnats-bugs@NetBSD.org
Cc: taya@NetBSD.org, joerg@britannica.bec.de
Subject: Re: pkg/33932
Date: Sun, 9 Jul 2006 13:15:46 +0400
--Dxnq1zWXvFF0Q93v
Content-Type: text/plain; charset=us-ascii; format=flowed
Content-Disposition: inline
Content-Transfer-Encoding: quoted-printable
On Fri, Jul 07, 2006 at 01:10:02PM +0000, joerg@britannica.bec.de wrote:
>
> On Thu, Jul 06, 2006 at 08:00:01PM +0000, svs@ropnet.ru wrote:
> > The problem is, once the SSL subsystem has been initialized in
> > Firefox/Thunderbird, the NSS libraries are dynamically loaded into the
> > running image. Later, when one chooses to print, libcups is also
> > loaded. Libcups brings with it OpenSSL. Both OpenSSL and NSS share a
> > SHA1_Update() symbol. These symbols conflict in the running image of
> > Firefox/Thunderbird. What ends up happening is that the SHA1_Update
> > from NSS gets called by CUPS instead of the SHA1_Update from OpenSSL.
> > Thus, when SHA1_Final gets called from OpenSSL, bad things happen.
> >=20
> > http://lists.freebsd.org/pipermail/freebsd-ports/2004-November/017495.h=
tml
> >=20
> > Use -Bsymbolic when linking nss to avoid symbol conflicts with libraries
> > that include OpenSSL (e.g. CUPS). This may help alleviate the problem =
with
> > Firefox crashing when trying to print when using CUPS.
>=20
> I don't think this is a correct solution. Can you investigate whether
> using RTLD_LOCAL for the dlopen calls of NSS and CUPS help?
I'm not familiar with Mozilla code, but a quick grep revealed this:
- CUPS (libcups.so.2) is loaded by NS_LoadLibrary, which uses default
flags (RTLD_NOW).
- NSS is loaded by nsDll::Load, which uses RTLD_LAZY|RTLD_GLOBAL.
As far as I understand, our dynamic linker default behaviour is
equivalent to RTLD_LOCAL. I couldn't find a way for nsDll::Load to use
non-default flags while loading NSS.
--=20
Sergey Svishchev
--Dxnq1zWXvFF0Q93v
Content-Type: application/pgp-signature
Content-Disposition: inline
-----BEGIN PGP SIGNATURE-----
Comment: ''
iD8DBQFEsMlC3P+wmuUns7URAoZ4AJ90gFwKybNTjpW6mgSSEKQvWJzfOwCfdIe0
FZYMNr1FAsBgg7GVVi/3s50=
=OfG6
-----END PGP SIGNATURE-----
--Dxnq1zWXvFF0Q93v--