[Mesa-dev] [PATCH 2/3] configure.ac: Force use of LLVM shared libs with --enable-opencl
Tom Stellard
tom at stellard.net
Mon Jan 21 10:01:49 PST 2013
On Mon, Jan 21, 2013 at 06:36:00PM +0100, Tom Stellard wrote:
> On Mon, Jan 21, 2013 at 06:32:04PM +0100, Johannes Obermayr wrote:
> > Am Freitag, 18. Januar 2013, 17:58:27 schrieben Sie:
> > > From: Tom Stellard <thomas.stellard at amd.com>
> > >
> > > If we build clover with LLVM static libraries, then clover and also each
> > > pipe_*.so driver that is built will contain their own static copy of
> > > LLVM. The recent automake changes have uncovered a problem where
> > > the pipe_*.so drivers try to use clover's LLVM symbols. This causes
> > > LLVM's static registry objects to be initialized each time
> > > a pipe_*.so driver is loaded by clover. Initializing these objects
> > > multiple times is not allowed and leads to assertion failures in the
> > > LLVM code.
> > >
> > > We can avoid all these problems by having clover and all the pipe_*.so
> > > drivers link against the same LLVM shared library.
> > >
> > > https://bugs.freedesktop.org/show_bug.cgi?id=59334
> > > https://bugs.freedesktop.org/show_bug.cgi?id=59534
> > > ---
> > > configure.ac | 23 ++++++++++++++++++++---
> > > 1 file changed, 20 insertions(+), 3 deletions(-)
> > >
> > > diff --git a/configure.ac b/configure.ac
> > > index c85c836..4b93f22 100644
> > > --- a/configure.ac
> > > +++ b/configure.ac
> > > @@ -609,8 +609,10 @@ AC_ARG_ENABLE([vdpau],
> > > [enable_vdpau=auto])
> > > AC_ARG_ENABLE([opencl],
> > > [AS_HELP_STRING([--enable-opencl],
> > > - [enable OpenCL library @<:@default=no@:>@])],
> > > - [enable_opencl="$enableval"],
> > > + [enable OpenCL library NOTE: Enabling this option will also enable
> > > + --with-llvm-shared-libs
> > > + @<:@default=no@:>@])],
> > > + [enable_opencl="$enableval" with_llvm_shared_libs="$enableval"],
> > > [enable_opencl=no])
> > > AC_ARG_ENABLE([xlib_glx],
> > > [AS_HELP_STRING([--enable-xlib-glx],
> > > @@ -1903,7 +1905,22 @@ dnl in LLVM_LIBS.
> > >
> > > if test "x$with_llvm_shared_libs" = xyes; then
> > > dnl We can't use $LLVM_VERSION because it has 'svn' stripped out,
> > > - LLVM_LIBS="-lLLVM-`$LLVM_CONFIG --version`"
> > > + LLVM_SO_NAME=LLVM-`$LLVM_CONFIG --version`
> > > + AC_CHECK_FILE("$LLVM_LIBDIR/lib$LLVM_SO_NAME.so",,
> > > + AC_MSG_ERROR([Could not find llvm shared library: lib$LLVM_SO_NAME.so :
> > > + Please make sure you have built llvm with the --enable-shared option
> > > + and that your llvm libraries are installed in $LLVM_LIBDIR
> > > + If you have installed your llvm libraries to a different directory you
> > > + can use the --with-llvm-prefix= configure flag to specify this directory.
> > > + NOTE: Mesa is attempting to use llvm shared libraries because you have
> > > + passed one of the following options to configure:
> > > + --with-llvm-shared-libs
> > > + --enable-opencl
> > > + If you do not want to build with llvm shared libraries and instead want to
> > > + use llvm static libraries then remove these options from your configure
> > > + invocation and reconfigure.]))
> > > +
> > > + LLVM_LIBS="-l$LLVM_SO_NAME"
> > > else
> > > LLVM_LIBS="`$LLVM_CONFIG --libs ${LLVM_COMPONENTS}`"
> > > fi
> > >
> >
> > I am against this patch because it breaks Mesa with my cmake build of LLVM which generates shared instead of static libraries:
> >
> > $ ls /usr/lib64/*LLVM*
> > /usr/lib64/libLLVMAnalysis.so /usr/lib64/libLLVMInstCombine.so /usr/lib64/libLLVMMipsInfo.so /usr/lib64/libLLVMSparcCodeGen.so
> > /usr/lib64/libLLVMArchive.so /usr/lib64/libLLVMInstrumentation.so /usr/lib64/libLLVMMSP430AsmPrinter.so /usr/lib64/libLLVMSparcDesc.so
> > /usr/lib64/libLLVMARMAsmParser.so /usr/lib64/libLLVMInterpreter.so /usr/lib64/libLLVMMSP430CodeGen.so /usr/lib64/libLLVMSparcInfo.so
> > /usr/lib64/libLLVMARMAsmPrinter.so /usr/lib64/libLLVMipa.so /usr/lib64/libLLVMMSP430Desc.so /usr/lib64/libLLVMSupport.so
> > /usr/lib64/libLLVMARMCodeGen.so /usr/lib64/libLLVMipo.so /usr/lib64/libLLVMMSP430Info.so /usr/lib64/libLLVMTableGen.so
> > /usr/lib64/libLLVMARMDesc.so /usr/lib64/libLLVMJIT.so /usr/lib64/libLLVMNVPTXAsmPrinter.so /usr/lib64/libLLVMTarget.so
> > /usr/lib64/libLLVMARMDisassembler.so /usr/lib64/libLLVMLinker.so /usr/lib64/libLLVMNVPTXCodeGen.so /usr/lib64/libLLVMTransformUtils.so
> > /usr/lib64/libLLVMARMInfo.so /usr/lib64/libLLVMMBlazeAsmParser.so /usr/lib64/libLLVMNVPTXDesc.so /usr/lib64/libLLVMVectorize.so
> > /usr/lib64/libLLVMAsmParser.so /usr/lib64/libLLVMMBlazeAsmPrinter.so /usr/lib64/libLLVMNVPTXInfo.so /usr/lib64/libLLVMX86AsmParser.so
> > /usr/lib64/libLLVMAsmPrinter.so /usr/lib64/libLLVMMBlazeCodeGen.so /usr/lib64/libLLVMObject.so /usr/lib64/libLLVMX86AsmPrinter.so
> > /usr/lib64/libLLVMBitReader.so /usr/lib64/libLLVMMBlazeDesc.so /usr/lib64/libLLVMOption.so /usr/lib64/libLLVMX86CodeGen.so
> > /usr/lib64/libLLVMBitWriter.so /usr/lib64/libLLVMMBlazeDisassembler.so /usr/lib64/libLLVMPowerPCAsmPrinter.so /usr/lib64/libLLVMX86Desc.so
> > /usr/lib64/libLLVMCodeGen.so /usr/lib64/libLLVMMBlazeInfo.so /usr/lib64/libLLVMPowerPCCodeGen.so /usr/lib64/libLLVMX86Disassembler.so
> > /usr/lib64/libLLVMCore.so /usr/lib64/libLLVMMCDisassembler.so /usr/lib64/libLLVMPowerPCDesc.so /usr/lib64/libLLVMX86Info.so
> > /usr/lib64/libLLVMCppBackendCodeGen.so /usr/lib64/libLLVMMCJIT.so /usr/lib64/libLLVMPowerPCInfo.so /usr/lib64/libLLVMX86Utils.so
> > /usr/lib64/libLLVMCppBackendInfo.so /usr/lib64/libLLVMMCParser.so /usr/lib64/libLLVMR600AsmPrinter.so /usr/lib64/libLLVMXCoreAsmPrinter.so
> > /usr/lib64/libLLVMDebugInfo.so /usr/lib64/libLLVMMC.so /usr/lib64/libLLVMR600CodeGen.so /usr/lib64/libLLVMXCoreCodeGen.so
> > /usr/lib64/libLLVMExecutionEngine.so /usr/lib64/libLLVMMipsAsmParser.so /usr/lib64/libLLVMR600Desc.so /usr/lib64/libLLVMXCoreDesc.so
> > /usr/lib64/libLLVMHexagonAsmPrinter.so /usr/lib64/libLLVMMipsAsmPrinter.so /usr/lib64/libLLVMR600Info.so /usr/lib64/libLLVMXCoreDisassembler.so
> > /usr/lib64/libLLVMHexagonCodeGen.so /usr/lib64/libLLVMMipsCodeGen.so /usr/lib64/libLLVMRuntimeDyld.so /usr/lib64/libLLVMXCoreInfo.so
> > /usr/lib64/libLLVMHexagonDesc.so /usr/lib64/libLLVMMipsDesc.so /usr/lib64/libLLVMScalarOpts.so /usr/lib64/LLVMHello.so
> > /usr/lib64/libLLVMHexagonInfo.so /usr/lib64/libLLVMMipsDisassembler.so /usr/lib64/libLLVMSelectionDAG.so
>
> Is there some way to get the shared object names using llvm-config ?
>
I think I have a fix. Does this patch help?
-Tom
-------------- next part --------------
A non-text attachment was scrubbed...
Name: 0001-configure.ac-Force-use-of-LLVM-shared-libs-with-enab.patch
Type: text/x-diff
Size: 3715 bytes
Desc: not available
URL: <http://lists.freedesktop.org/archives/mesa-dev/attachments/20130121/6afdd2c5/attachment.patch>
More information about the mesa-dev
mailing list