Date: Fri, 11 Jul 2008 14:08:10 +0200 From: Mel <fbsd.questions@rachie.is-a-geek.net> To: freebsd-questions@freebsd.org, unga888@yahoo.com Subject: Re: Library mapping question Message-ID: <200807111408.11050.fbsd.questions@rachie.is-a-geek.net> In-Reply-To: <310032.41745.qm@web57009.mail.re3.yahoo.com> References: <310032.41745.qm@web57009.mail.re3.yahoo.com>
next in thread | previous in thread | raw e-mail | index | archive | help
On Friday 11 July 2008 10:22:21 Unga wrote: > Hi all > > I have same name libraries in two different locations, eg. > /usr/lib/libXXX.so and /usr/local/lib/libXXX.so. They were created using > same sources and the same compiler. > > The app1 is linked with /usr/lib/libXXX.so and app2 is linked with > /usr/local/lib/libXXX.so. > > When app2 is run, the dynamic linker (ld-elf.so.1) finds /usr/lib/libXXX.so > first and ends up with following error: undefined reference to `_myxxx' > > This is not an issue with Linux's dynamic linker but it seems FreeBSD's > function look up is very specific. I cannot change the dynamic linker's > search path, then app1 fails. > > How do I get the app2 to refer to /usr/local/lib/libXXX.so? > > In FreeBSD, is there a way to instruct the dynamic linker (ld-elf.so.1) to > continue to search for the same library name in different locations? > > What are the other possible options? The best option is to bump version number of the shared library with the more functions. FreeBSD doesn't link with .so, it links with .so.$VERSION. It would be easier to help you though, if we wouldn't be talking about libXXX but the actual libraries. Maybe it can be done by adding small changes to the port that installs /usr/local/lib/libXXX.so (if this isn't your own library). -- Mel Problem with today's modular software: they start with the modules and never get to the software part.
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200807111408.11050.fbsd.questions>