[PATCH] D15133: [CMake] Add option LLVM_EXTERNALIZE_DEBUGINFO

Chris Bieneman via llvm-commits llvm-commits at lists.llvm.org
Wed Dec 2 14:09:22 PST 2015


> On Dec 2, 2015, at 2:02 PM, Justin Bogner <mail at justinbogner.com> wrote:
> 
> Chris Bieneman <beanz at apple.com <mailto:beanz at apple.com>> writes:
>> beanz updated this revision to Diff 41660.
>> beanz added a comment.
>> 
>> For LTO builds, dsymutil doesn't need to run against the intermediate
>> object, we just need to make sure it sticks around.
>> 
>> 
>> http://reviews.llvm.org/D15133
>> 
>> Files:
>>  CMakeLists.txt
>>  cmake/modules/AddLLVM.cmake
>> 
>> Index: cmake/modules/AddLLVM.cmake
>> ===================================================================
>> --- cmake/modules/AddLLVM.cmake
>> +++ cmake/modules/AddLLVM.cmake
>> @@ -512,6 +512,10 @@
>>       add_dependencies(${objlib} ${LLVM_COMMON_DEPENDS})
>>     endforeach()
>>   endif()
>> +
>> +  if(ARG_SHARED OR ARG_MODULE)
>> +    llvm_externalize_darwin_debuginfo(${name})
>> +  endif()
>> endfunction()
>> 
>> macro(add_llvm_library name)
>> @@ -655,6 +659,8 @@
>>   if( LLVM_COMMON_DEPENDS )
>>     add_dependencies( ${name} ${LLVM_COMMON_DEPENDS} )
>>   endif( LLVM_COMMON_DEPENDS )
>> +
>> +  llvm_externalize_darwin_debuginfo(${name})
>> endmacro(add_llvm_executable name)
>> 
>> function(export_executable_symbols target)
>> @@ -1168,3 +1174,18 @@
>>     endif()
>>   endif()
>> endfunction()
>> +
>> +function(llvm_externalize_darwin_debuginfo name)
>> +  if(APPLE AND LLVM_EXTERNALIZE_DEBUGINFO)
> 
> Better to early exit `if (NOT LLVM_EXTERNALIZE_DEBUGINFO)` before
> checking APPLE.
> 
> I'd also prefer if we error'd out on non-darwin for now. I don't like
> silently ignored flags, and if someone wants to implement it later this
> is the obvious place to do split-dwarf on linux-like platforms. Then
> presumably the "_darwin" isn't necessary in the function name.

will do.

> 
>> +    if(CMAKE_CXX_FLAGS MATCHES "-flto"
>> +      OR CMAKE_CXX_FLAGS_${uppercase_CMAKE_BUILD_TYPE} MATCHES "-flto")
>> +
>> +      set(lto_object ${CMAKE_CURRENT_BINARY_DIR}/${CMAKE_CFG_INTDIR}/${name}.o)
> 
> Can this collide with anything? Maybe ${name}.lto.o is safer?

It shouldn’t because CMake doesn’t put objects in that folder, but I updated the patches with a similar change as per Fred’s comments :-).

-Chris

> 
> Other than those couple of points, this LGTM.
> 
>> +      set_target_properties(${name} PROPERTIES
>> +        LINK_FLAGS "-Wl,-object_path_lto -Wl,${lto_object}")
>> +    endif()
>> +    add_custom_command(TARGET ${name} POST_BUILD
>> +      COMMAND xcrun dsymutil $<TARGET_FILE:${name}>
>> +      COMMAND xcrun strip -Sl $<TARGET_FILE:${name}>)
>> +  endif()
>> +endfunction()
>> Index: CMakeLists.txt
>> ===================================================================
>> --- CMakeLists.txt
>> +++ CMakeLists.txt
>> @@ -301,6 +301,9 @@
>> option(LLVM_USE_OPROFILE
>>   "Use opagent JIT interface to inform OProfile about JIT code" OFF)
>> 
>> +option(LLVM_EXTERNALIZE_DEBUGINFO
>> +  "Generate dSYM files and strip executables and libraries (Darwin Only)" OFF)
>> +
>> # If enabled, verify we are on a platform that supports oprofile.
>> if( LLVM_USE_OPROFILE )
>>   if( NOT CMAKE_SYSTEM_NAME MATCHES "Linux" )

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20151202/d0010443/attachment.html>


More information about the llvm-commits mailing list