[llvm-dev] LLVM compilation problem with musl
Dmitry Golovin via llvm-dev
llvm-dev at lists.llvm.org
Sun Jun 4 13:20:32 PDT 2017
Thank you very much! It seems to solve the problem, only the patch should now be applied to a different file (lib/Support/Unix/DynamicLibrary.inc instead of lib/Support/DynamicLibrary.cpp), it is compiling now.
Regards,
Dmitry
04.06.2017, 23:01, "Dimitry Andric" <dimitry at andric.com>:
> Most likely, you mean this particular fix?
>
> https://git.alpinelinux.org/cgit/aports/tree/main/llvm4/llvm-fix-DynamicLibrary-to-build-with-musl-libc.patch?id=HEAD
>
> Indeed, checking #if defined(__GLIBC__) seems to be a better solution that assuming all C libraries on Linux are the same.
>
> -Dimitry
>
>> On 4 Jun 2017, at 21:54, Dmitry Golovin via llvm-dev <llvm-dev at lists.llvm.org> wrote:
>>
>> I'm trying to compile LLVM with musl libc library. The compilation process fails on the following:
>>
>> x86_64-linux-musl-g++ -DGTEST_HAS_RTTI=0 -DLLVM_BUILD_GLOBAL_ISEL -D__STDC_CONSTANT_MACROS -D__STDC_FORMAT_MACROS -D__STDC_LIMIT_MACROS -Ilib/Support -I../lib/Support -Iinclude -I../include -fPIC -fvisibility-inlines-hidden -Werror=date-time -std=c++11 -Wall -W -Wno-unused-parameter -Wwrite-strings -Wcast-qual -Wno-missing-field-initializers -pedantic -Wno-long-long -Wno-maybe-uninitialized -Wdelete-non-virtual-dtor -Wno-comment -ffunction-sections -fdata-sections -O3 -DNDEBUG -fno-exceptions -fno-rtti -MD -MT lib/Support/CMakeFiles/LLVMSupport.dir/DynamicLibrary.cpp.o -MF lib/Support/CMakeFiles/LLVMSupport.dir/DynamicLibrary.cpp.o.d -o lib/Support/CMakeFiles/LLVMSupport.dir/DynamicLibrary.cpp.o -c ../lib/Support/DynamicLibrary.cpp
>> In file included from ../lib/Support/DynamicLibrary.cpp:111:0:
>> ../lib/Support/Unix/DynamicLibrary.inc: In function ‘void* DoSearch(const char*)’:
>> ../lib/Support/Unix/DynamicLibrary.inc:102:42: error: invalid conversion from ‘const void*’ to ‘void*’ [-fpermissive]
>> if (!strcmp(SymbolName, #SYM)) return &SYM
>> ^
>> ../lib/Support/Unix/DynamicLibrary.inc:109:5: note: in expansion of macro ‘EXPLICIT_SYMBOL’
>> EXPLICIT_SYMBOL(stderr);
>> ^~~~~~~~~~~~~~~
>> ../lib/Support/Unix/DynamicLibrary.inc:102:42: error: invalid conversion from ‘const void*’ to ‘void*’ [-fpermissive]
>> if (!strcmp(SymbolName, #SYM)) return &SYM
>> ^
>> ../lib/Support/Unix/DynamicLibrary.inc:110:5: note: in expansion of macro ‘EXPLICIT_SYMBOL’
>> EXPLICIT_SYMBOL(stdout);
>> ^~~~~~~~~~~~~~~
>> ../lib/Support/Unix/DynamicLibrary.inc:102:42: error: invalid conversion from ‘const void*’ to ‘void*’ [-fpermissive]
>> if (!strcmp(SymbolName, #SYM)) return &SYM
>> ^
>> ../lib/Support/Unix/DynamicLibrary.inc:111:5: note: in expansion of macro ‘EXPLICIT_SYMBOL’
>> EXPLICIT_SYMBOL(stdin);
>> ^~~~~~~~~~~~~~~
>>
>> Have anyone had similar problem? Maybe someone had already successfully compiled LLVM with musl?
>>
>> All musl-based distros (like Alpine, sabotage, void-musl) should be affected. I think that Rust team had similar problem (https://github.com/rust-lang/rust/issues/28667) and they came up with some kind of workaround for it.
>>
>> Regards,
>> Dmitry
>> _______________________________________________
>> LLVM Developers mailing list
>> llvm-dev at lists.llvm.org
>> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev
More information about the llvm-dev
mailing list