2012-05-31 56 views
2

我在同一个Ubuntu 11.04机器上有两个不同的libGL库。一个库被安装在Nvidia显卡的/usr/lib/libGL.so另一个是默认安装在Ubuntu上的,位于usr/lib/x86_64-linux-gnu/mesa/libGL.so覆盖Qt 4.8.1的OpenGL选择

现在,我遇到的问题是从Ubuntu的存储库链接下载的Qt库与mesa库相关,但我想链接到Nvidia的库。这可能会提供更好的性能,并且在编译程序时使用mesa的libGL存在问题。这些已被修复:

export LIBGL_ALWAYS_INDIRECT=1 

据我所知,这迫使X11选择openGL库,它是选择正确的。但是,我宁愿让Qt和用QtOpenGL编译的程序直接与正确的库链接。

我下载Qt和使用这些选项来编译它自己:

./configure -nomake examples -nomake demos -nomake tools -release -no-webkit 

我希望连接将使用正确的库。没有骰子。接下来,我想编辑mkspec/linux-g++-64/qmake.conf与这些变量设置:

QMAKE_LIBDIR_X11  = /usr/lib/x86_64-linux-gnu 
QMAKE_LIBDIR_OPENGL = /usr/lib 

是否有一个选项,在那里我可以强制特定的库而不是另一个(配置脚本运行特别是当)的链接?我宁愿不以任何特定的方式配置链接器。我也不想删除台面库。

如果没有这样的配置脚本标记这样做,有没有办法设置链接器使用的库的优先级?

最坏的情况下,我可能在./configure运行后更改所有的Makefiles。 grep整个Qt树使用-lGL并将其更改为/usr/lib/libGL.so。我觉得这是一个相当黑客。

更新

了一些成功。我在lg的Qt树上做了一个grep,发现其他mkspecs(除了linux-g++-64)使用其他变量来指定OpenGL路径。所以我说他们linux-g++-64的mkspec,这里的mkspec/linux-g++-64/qmake.conf结果:

QMAKE_LIBS_OPENGL  = /usr/lib/libGL.so 
QMAKE_LIBS_OPENGL_QT = /usr/lib/libGL.so 

所以我设置到库的路径,我想直接在想它会正确地链接。事实上,这是一个好消息,在编译期间,从未使用过lGL。然而,最终的结果是lib/libQtOpenGL.so仍与错误的库链接:

$ ldd lib/libQtOpenGL.so 
    linux-vdso.so.1 => (0x00007fffd83ff000) 
    libQtGui.so.4 => (edited)lib/libQtGui.so.4 (0x00007f554c684000) 
    libQtCore.so.4 => (edited)lib/libQtCore.so.4 (0x00007f554c19c000) 
    libfreetype.so.6 => /usr/lib/x86_64-linux-gnu/libfreetype.so.6 (0x00007f554beda000) 
    libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f554bcd6000) 
    **libGL.so.1 => /usr/lib/x86_64-linux-gnu/mesa/libGL.so.1 (0x00007f554ba7a000)** 
    libXrender.so.1 => /usr/lib/x86_64-linux-gnu/libXrender.so.1 (0x00007f554b86e000) 
    libX11.so.6 => /usr/lib/x86_64-linux-gnu/libX11.so.6 (0x00007f554b536000) 
    libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007f554b22f000) 
    libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f554afaa000) 
    libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007f554ad94000) 
    libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f554a9f5000) 
    libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f554a7d7000) 
    libglib-2.0.so.0 => /lib/x86_64-linux-gnu/libglib-2.0.so.0 (0x00007f554a4e1000) 
    libpng12.so.0 => /lib/x86_64-linux-gnu/libpng12.so.0 (0x00007f554a2ba000) 
    libz.so.1 => /lib/x86_64-linux-gnu/libz.so.1 (0x00007f554a0a1000) 
    libSM.so.6 => /usr/lib/x86_64-linux-gnu/libSM.so.6 (0x00007f5549e99000) 
    libICE.so.6 => /usr/lib/x86_64-linux-gnu/libICE.so.6 (0x00007f5549c7f000) 
    libfontconfig.so.1 => /usr/lib/x86_64-linux-gnu/libfontconfig.so.1 (0x00007f5549a48000) 
    libXext.so.6 => /usr/lib/x86_64-linux-gnu/libXext.so.6 (0x00007f5549835000) 
    libgthread-2.0.so.0 => /usr/lib/x86_64-linux-gnu/libgthread-2.0.so.0 (0x00007f554962f000) 
    librt.so.1 => /lib/x86_64-linux-gnu/librt.so.1 (0x00007f5549427000) 
    /lib64/ld-linux-x86-64.so.2 (0x00007f554d66f000) 
    libglapi.so.0 => /usr/lib/x86_64-linux-gnu/libglapi.so.0 (0x00007f5549203000) 
    libXdamage.so.1 => /usr/lib/x86_64-linux-gnu/libXdamage.so.1 (0x00007f5548fff000) 
    libXfixes.so.3 => /usr/lib/x86_64-linux-gnu/libXfixes.so.3 (0x00007f5548df9000) 
    libXxf86vm.so.1 => /usr/lib/x86_64-linux-gnu/libXxf86vm.so.1 (0x00007f5548bf3000) 
    libdrm.so.2 => /usr/lib/x86_64-linux-gnu/libdrm.so.2 (0x00007f55489e7000) 
    libxcb.so.1 => /usr/lib/x86_64-linux-gnu/libxcb.so.1 (0x00007f55487cb000) 
    libpcre.so.3 => /lib/x86_64-linux-gnu/libpcre.so.3 (0x00007f554858e000) 
    libuuid.so.1 => /lib/x86_64-linux-gnu/libuuid.so.1 (0x00007f5548389000) 
    libexpat.so.1 => /lib/x86_64-linux-gnu/libexpat.so.1 (0x00007f554815f000) 
    libXau.so.6 => /usr/lib/x86_64-linux-gnu/libXau.so.6 (0x00007f5547f5b000) 
    libXdmcp.so.6 => /usr/lib/x86_64-linux-gnu/libXdmcp.so.6 (0x00007f5547d55000) 

我不知道为什么,我直接指定什么库使用,它被正确地传递给g++,但链接显然忽略了它。我相信它不再是一个Qt问题,而是一个链接器问题。

有没有什么办法与ldconfig或其他工具来指定什么库链接到的情况下-lGL?我知道其他图书馆有一个程序,将组织什么图书馆使用(libusb-config来到我的),但我不认为这是openGL的情况。

回答

0

链接器需要重新配置才能找到正确的openGL库。一个这样的选项,经常被忽视的是将LD_LIBRARY_PATH变量改为包含希望使用的openGL库的路径。在我的情况下,它位于/usr/lib,所以我相应地更改了变量。

export LD_LIBRARY_PATH=/usr/lib/fsl/4.1:/usr/lib

使用相同的选项运行./configure脚本,使它后,它终于指向正确的库。

ldd lib/libQtOpenGL.so 
    linux-vdso.so.1 => (0x00007fff04ebf000) 
    libQtGui.so.4 => (edited)Qt4.8.1/lib/libQtGui.so.4 (0x00007fad8826c000) 
    libQtCore.so.4 => (edited)Qt4.8.1/lib/libQtCore.so.4 (0x00007fad87d84000) 
    libfreetype.so.6 => /usr/lib/x86_64-linux-gnu/libfreetype.so.6 (0x00007fad87ac2000) 
    libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007fad878be000) 
    **libGL.so.1 => /usr/lib/libGL.so.1 (0x00007fad875a8000)** 
    libXrender.so.1 => /usr/lib/x86_64-linux-gnu/libXrender.so.1 (0x00007fad8739c000) 
    libX11.so.6 => /usr/lib/x86_64-linux-gnu/libX11.so.6 (0x00007fad87064000) 
    libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007fad86d5d000) 
    libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007fad86ad8000) 
    libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007fad868c2000) 
    libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fad86523000) 
    libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007fad86305000) 
    libglib-2.0.so.0 => /lib/x86_64-linux-gnu/libglib-2.0.so.0 (0x00007fad8600f000) 
    libpng12.so.0 => /lib/x86_64-linux-gnu/libpng12.so.0 (0x00007fad85de8000) 
    libz.so.1 => /lib/x86_64-linux-gnu/libz.so.1 (0x00007fad85bcf000) 
    libSM.so.6 => /usr/lib/x86_64-linux-gnu/libSM.so.6 (0x00007fad859c7000) 
    libICE.so.6 => /usr/lib/x86_64-linux-gnu/libICE.so.6 (0x00007fad857ad000) 
    libfontconfig.so.1 => /usr/lib/x86_64-linux-gnu/libfontconfig.so.1 (0x00007fad85576000) 
    libXext.so.6 => /usr/lib/x86_64-linux-gnu/libXext.so.6 (0x00007fad85363000) 
    libgthread-2.0.so.0 => /usr/lib/x86_64-linux-gnu/libgthread-2.0.so.0 (0x00007fad8515d000) 
    librt.so.1 => /lib/x86_64-linux-gnu/librt.so.1 (0x00007fad84f55000) 
    /lib64/ld-linux-x86-64.so.2 (0x00007fad89257000) 
    libnvidia-tls.so.290.10 => /usr/lib/tls/libnvidia-tls.so.290.10 (0x00007fad84d52000) 
    libnvidia-glcore.so.290.10 => /usr/lib/libnvidia-glcore.so.290.10 (0x00007fad82a4a000) 
    libxcb.so.1 => /usr/lib/x86_64-linux-gnu/libxcb.so.1 (0x00007fad8282e000) 
    libpcre.so.3 => /lib/x86_64-linux-gnu/libpcre.so.3 (0x00007fad825f1000) 
    libuuid.so.1 => /lib/x86_64-linux-gnu/libuuid.so.1 (0x00007fad823ec000) 
    libexpat.so.1 => /lib/x86_64-linux-gnu/libexpat.so.1 (0x00007fad821c2000) 
    libXau.so.6 => /usr/lib/x86_64-linux-gnu/libXau.so.6 (0x00007fad81fbe000) 
    libXdmcp.so.6 => /usr/lib/x86_64-linux-gnu/libXdmcp.so.6 (0x00007fad81db8000) 

我相信还有另一种可能,也许更好的选择。在Ubuntu 11.04中,链接器被配置为在/usr/lib/x86_64-linux-gnu/mesa/目录中查找位于/etc/ld.so.conf.d/x86_64-linux-gnu_GL.conf的配置文件。

如果编辑此文件以反映不同的路径,链接器可能会选择该库。看起来链接器的库搜索优先级为:

LD_LIBRARY_PATH =>位于/etc/ld.so.conf.d =>中的文件最后诉诸搜索默认路径中的库。

这可能是一个更好的解决方案,在/etc/ld.so.conf.d中相应地编辑这些文件,但在我的情况下,我没有编辑这些文件的权限,因此编辑LD_LIBRARY_PATH没有办法。