<div dir="ltr">Hi Frederic,<div><br></div><div>Ah, just noticed it. Sorry for the breakage :-/.</div><div>I don't think your analysis is correct, though - we used to unconditionally set MIN_OSX_VERSION to 10.7 before, so the default behavior was not changed.</div><div>The problem happens with newly added CFI diagnostic mode, that uses UBSan runtime, and depends on the presence of c++abi-specific code there, while we disabled</div><div>linking in this code on older versions of Darwin.</div><div><br></div><div>I will disable cfi tests on Darwin to fix the bot, and then discuss with Peter the way to resolve this.</div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Jun 25, 2015 at 11:20 AM, Frédéric Riss <span dir="ltr"><<a href="mailto:friss@apple.com" target="_blank">friss@apple.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class=""><br>
> On Jun 25, 2015, at 9:22 AM, Frédéric Riss <<a href="mailto:friss@apple.com">friss@apple.com</a>> wrote:<br>
><br>
> Hi Alexey<br>
><br>
> This commit broke the Darwin bot at:<br>
> <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__lab.llvm.org-3A8080_green_job_clang-2Dstage1-2Dcmake-2DRA_&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=GkaIftKs3PjfqRnBuJ61l3qa3oaYQL-gLJJciWPCNf4&s=sYTPJ8E3sE-xzU3WShTbVGkB5D62_TFBKikyUlMixSQ&e=" rel="noreferrer" target="_blank">http://lab.llvm.org:8080/green/job/clang-stage1-cmake-RA/</a><br>
><br>
> The failures are link errors like:<br>
> undef: ___ubsan_handle_cfi_bad_type<br>
> Undefined symbols for architecture x86_64:<br>
>  "___ubsan_handle_cfi_bad_type", referenced from:<br>
>      _main in vdtor-0e96d6.o<br>
> ld: symbol(s) not found for architecture x86_64<br>
> clang-3.7: error: linker command failed with exit code 1 (use -v to see invocation)<br>
><br>
> I guess that somehow the check you added triggers on the bot, although it shouldn’t as the machines there are 10.10<br>
><br>
> Did you notice this?<br>
<br>
</span>What happens is that you added a check against SANITIZER_MIN_OSX_VERSION, but when none is specified (which is the default) the CMakelists decides that the default value is 10.7. So you actually changed the default behavior here. As this breaks a public bot, I’ll revert it if I don’t here from you soon.<br>
<br>
(There is a more fundamental issue here that the link error is really the wrong diagnostic. The fronted should prevent you from getting into that situation by telling you that the configuration your asking for won’t work.)<br>
<br>
Fred<br>
<div class="HOEnZb"><div class="h5"><br>
> Fred<br>
><br>
>> On Jun 24, 2015, at 5:57 PM, Alexey Samsonov <<a href="mailto:vonosmas@gmail.com">vonosmas@gmail.com</a>> wrote:<br>
>><br>
>> Author: samsonov<br>
>> Date: Wed Jun 24 19:57:42 2015<br>
>> New Revision: 240617<br>
>><br>
>> URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject-3Frev-3D240617-26view-3Drev&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=GkaIftKs3PjfqRnBuJ61l3qa3oaYQL-gLJJciWPCNf4&s=hgFRm2LB6KAn_WLd0-VOfIdiIeFN5NE0NUoHobf0kr8&e=" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project?rev=240617&view=rev</a><br>
>> Log:<br>
>> [CMake] Fix PR23539: Don't reference C++ ABI symbols prior to Mac OS 10.9.<br>
>><br>
>> Summary:<br>
>> This patch implements step 1 from<br>
>> <a href="https://urldefense.proofpoint.com/v2/url?u=https-3A__llvm.org_bugs_show-5Fbug.cgi-3Fid-3D23539-23c10&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=GkaIftKs3PjfqRnBuJ61l3qa3oaYQL-gLJJciWPCNf4&s=cQpMoOGHg6BcgzgGGeTrtv4v9rx4IxLhPQ5Z4lvNajE&e=" rel="noreferrer" target="_blank">https://llvm.org/bugs/show_bug.cgi?id=23539#c10</a><br>
>><br>
>> I'd appreciate if you could test it on Mac OS and verify that parts of UBSan<br>
>> runtime that reference C++ ABI symbols are properly excluded, and fix ASan/UBSan<br>
>> builds.<br>
>><br>
>> Test Plan: regression test suite<br>
>><br>
>> Reviewers: thakis, hans<br>
>><br>
>> Subscribers: llvm-commits, zaks.anna, kubabrecka<br>
>><br>
>> Differential Revision: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__reviews.llvm.org_D10621&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=GkaIftKs3PjfqRnBuJ61l3qa3oaYQL-gLJJciWPCNf4&s=VRMeGZbG5_08c-wNMtY5mprKv0rGxRz1vujzOd6fUe0&e=" rel="noreferrer" target="_blank">http://reviews.llvm.org/D10621</a><br>
>><br>
>> Modified:<br>
>>   compiler-rt/trunk/CMakeLists.txt<br>
>>   compiler-rt/trunk/lib/ubsan/CMakeLists.txt<br>
>>   compiler-rt/trunk/test/lit.common.cfg<br>
>>   compiler-rt/trunk/test/<a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__lit.common.configured.in&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=GkaIftKs3PjfqRnBuJ61l3qa3oaYQL-gLJJciWPCNf4&s=MfYbC6oOTEdxWF_rtFT9IhNW73HiuYBGByRPaHLcnog&e=" rel="noreferrer" target="_blank">lit.common.configured.in</a><br>
>>   compiler-rt/trunk/test/ubsan/TestCases/TypeCheck/vptr-virtual-base.cpp<br>
>>   compiler-rt/trunk/test/ubsan/TestCases/TypeCheck/vptr.cpp<br>
>><br>
>> Modified: compiler-rt/trunk/CMakeLists.txt<br>
>> URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_compiler-2Drt_trunk_CMakeLists.txt-3Frev-3D240617-26r1-3D240616-26r2-3D240617-26view-3Ddiff&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=GkaIftKs3PjfqRnBuJ61l3qa3oaYQL-gLJJciWPCNf4&s=mB6zQTbdItdrwE1iz4VUBf5sFr6umkDqWq73edDEQAE&e=" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/CMakeLists.txt?rev=240617&r1=240616&r2=240617&view=diff</a><br>
>> ==============================================================================<br>
>> --- compiler-rt/trunk/CMakeLists.txt (original)<br>
>> +++ compiler-rt/trunk/CMakeLists.txt Wed Jun 24 19:57:42 2015<br>
>> @@ -327,6 +327,15 @@ if(APPLE)<br>
>>  endif()<br>
>> endif()<br>
>><br>
>> +if(APPLE AND SANITIZER_MIN_OSX_VERSION VERSION_LESS "10.9")<br>
>> +  # Mac OS X prior to 10.9 had problems with exporting symbols from<br>
>> +  # libc++/libc++abi.<br>
>> +  set(SANITIZER_CAN_USE_CXXABI FALSE)<br>
>> +else()<br>
>> +  set(SANITIZER_CAN_USE_CXXABI TRUE)<br>
>> +endif()<br>
>> +pythonize_bool(SANITIZER_CAN_USE_CXXABI)<br>
>> +<br>
>> add_subdirectory(include)<br>
>><br>
>> set(COMPILER_RT_LIBCXX_PATH ${LLVM_MAIN_SRC_DIR}/projects/libcxx)<br>
>><br>
>> Modified: compiler-rt/trunk/lib/ubsan/CMakeLists.txt<br>
>> URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_compiler-2Drt_trunk_lib_ubsan_CMakeLists.txt-3Frev-3D240617-26r1-3D240616-26r2-3D240617-26view-3Ddiff&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=GkaIftKs3PjfqRnBuJ61l3qa3oaYQL-gLJJciWPCNf4&s=vJdX2g9dkgEte1L7nASmfswc0O-CVJx0ec0_Ndij8W0&e=" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/ubsan/CMakeLists.txt?rev=240617&r1=240616&r2=240617&view=diff</a><br>
>> ==============================================================================<br>
>> --- compiler-rt/trunk/lib/ubsan/CMakeLists.txt (original)<br>
>> +++ compiler-rt/trunk/lib/ubsan/CMakeLists.txt Wed Jun 24 19:57:42 2015<br>
>> @@ -28,11 +28,16 @@ set(UBSAN_CXXFLAGS ${SANITIZER_COMMON_CF<br>
>> add_custom_target(ubsan)<br>
>><br>
>> if(APPLE)<br>
>> +  set(UBSAN_COMMON_SOURCES ${UBSAN_SOURCES})<br>
>> +  if(SANITIZER_CAN_USE_CXXABI)<br>
>> +    list(APPEND UBSAN_COMMON_SOURCES ${UBSAN_CXX_SOURCES})<br>
>> +  endif()<br>
>> +<br>
>>  # Common parts of UBSan runtime.<br>
>>  add_compiler_rt_object_libraries(RTUbsan<br>
>>    OS ${SANITIZER_COMMON_SUPPORTED_OS}<br>
>>    ARCHS ${UBSAN_COMMON_SUPPORTED_ARCH}<br>
>> -    SOURCES ${UBSAN_SOURCES} ${UBSAN_CXX_SOURCES}<br>
>> +    SOURCES ${UBSAN_COMMON_SOURCES}<br>
>>    CFLAGS ${UBSAN_CXXFLAGS})<br>
>><br>
>>  if(COMPILER_RT_HAS_UBSAN)<br>
>><br>
>> Modified: compiler-rt/trunk/test/lit.common.cfg<br>
>> URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_compiler-2Drt_trunk_test_lit.common.cfg-3Frev-3D240617-26r1-3D240616-26r2-3D240617-26view-3Ddiff&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=GkaIftKs3PjfqRnBuJ61l3qa3oaYQL-gLJJciWPCNf4&s=q45K_5oA96im7lNo2Lf9x_Or6d0ITIy6nu3eZrsF7rg&e=" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/test/lit.common.cfg?rev=240617&r1=240616&r2=240617&view=diff</a><br>
>> ==============================================================================<br>
>> --- compiler-rt/trunk/test/lit.common.cfg (original)<br>
>> +++ compiler-rt/trunk/test/lit.common.cfg Wed Jun 24 19:57:42 2015<br>
>> @@ -90,6 +90,10 @@ compiler_rt_debug = getattr(config, 'com<br>
>> if not compiler_rt_debug:<br>
>>  config.available_features.add('compiler-rt-optimized')<br>
>><br>
>> +sanitizer_can_use_cxxabi = getattr(config, 'sanitizer_can_use_cxxabi', True)<br>
>> +if sanitizer_can_use_cxxabi:<br>
>> +  config.available_features.add('cxxabi')<br>
>> +<br>
>> lit.util.usePlatformSdkOnDarwin(config, lit_config)<br>
>><br>
>> def is_darwin_lto_supported():<br>
>><br>
>> Modified: compiler-rt/trunk/test/<a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__lit.common.configured.in&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=GkaIftKs3PjfqRnBuJ61l3qa3oaYQL-gLJJciWPCNf4&s=MfYbC6oOTEdxWF_rtFT9IhNW73HiuYBGByRPaHLcnog&e=" rel="noreferrer" target="_blank">lit.common.configured.in</a><br>
>> URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_compiler-2Drt_trunk_test_lit.common.configured.in-3Frev-3D240617-26r1-3D240616-26r2-3D240617-26view-3Ddiff&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=GkaIftKs3PjfqRnBuJ61l3qa3oaYQL-gLJJciWPCNf4&s=EQh-aQakYnQNz3urv4Lq98JriZ9Q65rjWpJV4U3Y9Pc&e=" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/test/lit.common.configured.in?rev=240617&r1=240616&r2=240617&view=diff</a><br>
>> ==============================================================================<br>
>> --- compiler-rt/trunk/test/<a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__lit.common.configured.in&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=GkaIftKs3PjfqRnBuJ61l3qa3oaYQL-gLJJciWPCNf4&s=MfYbC6oOTEdxWF_rtFT9IhNW73HiuYBGByRPaHLcnog&e=" rel="noreferrer" target="_blank">lit.common.configured.in</a> (original)<br>
>> +++ compiler-rt/trunk/test/<a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__lit.common.configured.in&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=GkaIftKs3PjfqRnBuJ61l3qa3oaYQL-gLJJciWPCNf4&s=MfYbC6oOTEdxWF_rtFT9IhNW73HiuYBGByRPaHLcnog&e=" rel="noreferrer" target="_blank">lit.common.configured.in</a> Wed Jun 24 19:57:42 2015<br>
>> @@ -27,6 +27,7 @@ set_default("python_executable", "@PYTHO<br>
>> set_default("compiler_rt_debug", @COMPILER_RT_DEBUG_PYBOOL@)<br>
>> set_default("compiler_rt_libdir", "@COMPILER_RT_LIBRARY_OUTPUT_DIR@")<br>
>> set_default("emulator", "@COMPILER_RT_EMULATOR@")<br>
>> +set_default("sanitizer_can_use_cxxabi", @SANITIZER_CAN_USE_CXXABI_PYBOOL@)<br>
>><br>
>> # LLVM tools dir can be passed in lit parameters, so try to<br>
>> # apply substitution.<br>
>><br>
>> Modified: compiler-rt/trunk/test/ubsan/TestCases/TypeCheck/vptr-virtual-base.cpp<br>
>> URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_compiler-2Drt_trunk_test_ubsan_TestCases_TypeCheck_vptr-2Dvirtual-2Dbase.cpp-3Frev-3D240617-26r1-3D240616-26r2-3D240617-26view-3Ddiff&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=GkaIftKs3PjfqRnBuJ61l3qa3oaYQL-gLJJciWPCNf4&s=k_x7IjvZ6MlVFQJg2Vveo2qAuIS-n9X4eihnmwKi_XA&e=" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/test/ubsan/TestCases/TypeCheck/vptr-virtual-base.cpp?rev=240617&r1=240616&r2=240617&view=diff</a><br>
>> ==============================================================================<br>
>> --- compiler-rt/trunk/test/ubsan/TestCases/TypeCheck/vptr-virtual-base.cpp (original)<br>
>> +++ compiler-rt/trunk/test/ubsan/TestCases/TypeCheck/vptr-virtual-base.cpp Wed Jun 24 19:57:42 2015<br>
>> @@ -1,6 +1,8 @@<br>
>> // RUN: %clangxx -frtti -fsanitize=vptr -fno-sanitize-recover=vptr -g %s -O3 -o %t<br>
>> // RUN: not %run %t 2>&1 | FileCheck %s<br>
>><br>
>> +// REQUIRES: cxxabi<br>
>> +<br>
>> struct S { virtual int f() { return 0; } };<br>
>> struct T : virtual S {};<br>
>><br>
>><br>
>> Modified: compiler-rt/trunk/test/ubsan/TestCases/TypeCheck/vptr.cpp<br>
>> URL: <a href="https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_viewvc_llvm-2Dproject_compiler-2Drt_trunk_test_ubsan_TestCases_TypeCheck_vptr.cpp-3Frev-3D240617-26r1-3D240616-26r2-3D240617-26view-3Ddiff&d=AwMFaQ&c=8hUWFZcy2Z-Za5rBPlktOQ&r=mQ4LZ2PUj9hpadE3cDHZnIdEwhEBrbAstXeMaFoB9tg&m=GkaIftKs3PjfqRnBuJ61l3qa3oaYQL-gLJJciWPCNf4&s=D_wpUPT2Z2owLouSoW67waJN6cPqUFBxijsLy_gfIAI&e=" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/test/ubsan/TestCases/TypeCheck/vptr.cpp?rev=240617&r1=240616&r2=240617&view=diff</a><br>
>> ==============================================================================<br>
>> --- compiler-rt/trunk/test/ubsan/TestCases/TypeCheck/vptr.cpp (original)<br>
>> +++ compiler-rt/trunk/test/ubsan/TestCases/TypeCheck/vptr.cpp Wed Jun 24 19:57:42 2015<br>
>> @@ -24,7 +24,7 @@<br>
>> // RUN: echo "vptr_check:S" > %t.loc-supp<br>
>> // RUN: UBSAN_OPTIONS="suppressions='%t.loc-supp'" not %run %t x- 2>&1 | FileCheck %s --check-prefix=CHECK-LOC-SUPPRESS<br>
>><br>
>> -// REQUIRES: stable-runtime<br>
>> +// REQUIRES: stable-runtime, cxxabi<br>
>> #include <new><br>
>> #include <assert.h><br>
>> #include <stdio.h><br>
>><br>
>><br>
>> _______________________________________________<br>
>> llvm-commits mailing list<br>
>> <a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br>
>> <a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits" rel="noreferrer" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits</a><br>
><br>
<br>
</div></div></blockquote></div><br><br clear="all"><div><br></div>-- <br><div class="gmail_signature"><div dir="ltr">Alexey Samsonov<br><a href="mailto:vonosmas@gmail.com" target="_blank">vonosmas@gmail.com</a></div></div>
</div>