/ usr / lib似乎不是默认的链接位置

时间:2013-01-22 08:31:39

标签: c++ linux linker

编辑:
经过一番挖掘,我发现我在/usr/lib/i386-linux-gnu/libGL.so有一个libGL.so,如果我把它移开,那么链接再次正常工作。在查看错误行一段时间后,我认为邮件中libGL.so的完整路径是可疑的,因为它本来会查看多个位置来查找它,通常它只显示库的名称而不是一个特定的完整路径。所以现在的问题是;为什么找到其他版本导致搜索停止并显示一个令人困惑的错误消息? (我是i386ness在某种程度上使它不兼容)。

ORIG:
出于某种原因,我无法将libGL.so链接到我的应用程序中。问题似乎是ld(或者在这种情况下是黄金)没有查找/ usr / lib(我可以找到的所有东西都是默认位置之一)当试图找到它而不是它看起来有点像whacky location例如

  

/ usr / bin / ld:错误:无法打开/usr/lib/gcc/i686-linux-gnu/4.7/../../../i386-linux-gnu/libGL.so:No   这样的文件或目录

现在/usr/lib/libGL.so肯定存在,如果我在makefile中做一个显式的-L / usr / lib,一切都正确链接。

我想知道有谁知道这里发生了什么?

的信息:
Ubuntu linux 12.10 x86
g ++ 4.7
GNU金链接器
CPU AMD Phenom 2 x6
uname -m out:i686

编辑: 使用-v参数输出链接:

Using built-in specs.
COLLECT_GCC=g++
COLLECT_LTO_WRAPPER=/usr/lib/gcc/i686-linux-gnu/4.7/lto-wrapper
Target: i686-linux-gnu
Configured with: ../src/configure -v --with-pkgversion='Ubuntu/Linaro 4.7.2-2ubuntu1' --with-bugurl=file:///usr/share/doc/gcc-4.7/README.Bugs --enable-languages=c,c++,go,fortran,objc,obj-c++ --prefix=/usr --program-suffix=-4.7 --enable-shared --enable-linker-build-id --with-system-zlib --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --with-gxx-include-dir=/usr/include/c++/4.7 --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --enable-gnu-unique-object --enable-plugin --enable-objc-gc --enable-targets=all --disable-werror --with-arch-32=i686 --with-tune=generic --enable-checking=release --build=i686-linux-gnu --host=i686-linux-gnu --target=i686-linux-gnu
Thread model: posix
gcc version 4.7.2 (Ubuntu/Linaro 4.7.2-2ubuntu1) 
COMPILER_PATH=/usr/lib/gcc/i686-linux-gnu/4.7/:/usr/lib/gcc/i686-linux-gnu/4.7/:/usr/lib/gcc/i686-linux-gnu/:/usr/lib/gcc/i686-linux-gnu/4.7/:/usr/lib/gcc/i686-linux-gnu/
LIBRARY_PATH=/usr/lib/gcc/i686-linux-gnu/4.7/:/usr/lib/gcc/i686-linux-gnu/4.7/../../../i386-linux-gnu/:/usr/lib/gcc/i686-linux-gnu/4.7/../../../../lib/:/lib/i386-linux-gnu/:/lib/../lib/:/usr/lib/i386-linux-gnu/:/usr/lib/../lib/:/usr/lib/gcc/i686-linux-gnu/4.7/../../../:/lib/:/usr/lib/
COLLECT_GCC_OPTIONS='-o' 'application' '-v' '-L/home/user/src/tutorials/application/builds/./vendor/ogre3d/./lib' '-shared-libgcc' '-mtune=generic' '-march=i686'
 /usr/lib/gcc/i686-linux-gnu/4.7/collect2 --sysroot=/ --build-id --no-add-needed --as-needed --eh-frame-hdr -m elf_i386 --hash-style=gnu -dynamic-linker /lib/ld-linux.so.2 -z relro -o application /usr/lib/gcc/i686-linux-gnu/4.7/../../../i386-linux-gnu/crt1.o /usr/lib/gcc/i686-linux-gnu/4.7/../../../i386-linux-gnu/crti.o /usr/lib/gcc/i686-linux-gnu/4.7/crtbegin.o -L/home/user/src/tutorials/application/builds/./vendor/ogre3d/./lib -L/usr/lib/gcc/i686-linux-gnu/4.7 -L/usr/lib/gcc/i686-linux-gnu/4.7/../../../i386-linux-gnu -L/usr/lib/gcc/i686-linux-gnu/4.7/../../../../lib -L/lib/i386-linux-gnu -L/lib/../lib -L/usr/lib/i386-linux-gnu -L/usr/lib/../lib -L/usr/lib/gcc/i686-linux-gnu/4.7/../../.. /home/user/src/tutorials/application/builds/./src/most_basic_main.o /home/user/src/tutorials/application/builds/./src/QOgreWidget.o /home/user/src/tutorials/application/builds/./src/QtOgreApplication.o /home/user/src/tutorials/application/builds/./src/qt_gen/QtOgreApplication.moc.o /home/user/src/tutorials/application/builds/./src/qt_gen/QOgreWidget.moc.o -lpthread -lQtCore -lQtNetwork -lQtGui -lQtOpenGL -lRenderSystem_GLStatic -lOgreMainStatic -ldl -lfreetype -lXrandr -lGL -lGLU -lxcb -lX11 -lXext -lXpm -lXaw7 -lXt -lzzip -lfreeimage -lstdc++ -lm -lgcc_s -lgcc -lc -lgcc_s -lgcc /usr/lib/gcc/i686-linux-gnu/4.7/crtend.o /usr/lib/gcc/i686-linux-gnu/4.7/../../../i386-linux-gnu/crtn.o
/usr/bin/ld: error: cannot open /usr/lib/gcc/i686-linux-gnu/4.7/../../../i386-linux-gnu/libGL.so: No such file or directory

3 个答案:

答案 0 :(得分:1)

经过一堆挖掘后,我发现我是一个悬空符号链接的受害者(这基本上是一个没有链接到有效内容的符号链接)。所以发生的事情是链接器在libGL.so找到/usr/lib/i386-linux-gnu/libGL.so并确定它的搜索结束了,但是当它试图获取文件时,符号链接的末尾没有任何内容导致错误我看到的消息。一旦我删除了悬空符号链接,搜索就找不到libGL.so,直到它到达/usr/lib/libGL.so处的正确版本,此时一切正常。

答案 1 :(得分:0)

似乎您的库路径由于某种原因未设置。您的configure是否可以选择设置--libexecdir = / usr / lib。我有类似的问题,缺少这个选项--libexecdir。

您可以通过在makefile中传递LDFLAGS来修复它。如何在makefile中使用LDFLAGS会被除名here。 您使用-L / usr / lib的选项也很完美。

答案 2 :(得分:0)

gcc需要明确的-L/usr/lib库搜索选项时,我遇到了类似的问题;即使它应该已经在默认库搜索路径中。奇怪的是,所有库都可用,ldconfig也正确地找到了它们。

由于@radman的发现,我记得创建了一个指向.a静态符号库的符号链接,该符号库最初安装在/usr/lib中,但是我在追逐其他配置时将其符号链接添加到/usr/lib/i386-linux-gnu中。 / build问题。

删除符号链接(有效,不悬挂)可以解决库搜索问题,因此gcc可以在没有显式-L/usr/lib的情况下正确地找到库