zbrid updated this revision to Diff 258462. zbrid added a comment. Update nit from Matt
Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D78390/new/ https://reviews.llvm.org/D78390 Files: clang/docs/DataFlowSanitizer.rst libcxx/CMakeLists.txt libcxx/utils/libcxx/test/config.py llvm/cmake/modules/HandleLLVMOptions.cmake llvm/docs/CMake.rst Index: llvm/docs/CMake.rst =================================================================== --- llvm/docs/CMake.rst +++ llvm/docs/CMake.rst @@ -422,7 +422,7 @@ **LLVM_USE_SANITIZER**:STRING Define the sanitizer used to build LLVM binaries and tests. Possible values are ``Address``, ``Memory``, ``MemoryWithOrigins``, ``Undefined``, ``Thread``, - and ``Address;Undefined``. Defaults to empty string. + ``DataFlow``, and ``Address;Undefined``. Defaults to empty string. **LLVM_ENABLE_LTO**:STRING Add ``-flto`` or ``-flto=`` flags to the compile and link command Index: llvm/cmake/modules/HandleLLVMOptions.cmake =================================================================== --- llvm/cmake/modules/HandleLLVMOptions.cmake +++ llvm/cmake/modules/HandleLLVMOptions.cmake @@ -728,6 +728,8 @@ elseif (LLVM_USE_SANITIZER STREQUAL "Thread") append_common_sanitizer_flags() append("-fsanitize=thread" CMAKE_C_FLAGS CMAKE_CXX_FLAGS) + elseif (LLVM_USE_SANITIZER STREQUAL "DataFlow") + append("-fsanitize=dataflow" CMAKE_C_FLAGS CMAKE_CXX_FLAGS) elseif (LLVM_USE_SANITIZER STREQUAL "Address;Undefined" OR LLVM_USE_SANITIZER STREQUAL "Undefined;Address") append_common_sanitizer_flags() Index: libcxx/utils/libcxx/test/config.py =================================================================== --- libcxx/utils/libcxx/test/config.py +++ libcxx/utils/libcxx/test/config.py @@ -909,6 +909,9 @@ self.cxx.flags += ['-fsanitize=thread'] self.config.available_features.add('tsan') self.config.available_features.add('sanitizer-new-delete') + elif san == 'DataFlow': + self.cxx.flags += ['-fsanitize=dataflow'] + self.config.available_features.add('dfsan') else: self.lit_config.fatal('unsupported value for ' 'use_sanitizer: {0}'.format(san)) Index: libcxx/CMakeLists.txt =================================================================== --- libcxx/CMakeLists.txt +++ libcxx/CMakeLists.txt @@ -682,6 +682,8 @@ append_flags(SANITIZER_FLAGS "-fsanitize=address,undefined -fno-sanitize=vptr,function -fno-sanitize-recover=all") elseif (USE_SANITIZER STREQUAL "Thread") append_flags(SANITIZER_FLAGS -fsanitize=thread) + elseif (USE_SANITIZER STREQUAL "DataFlow") + append_flags(SANITIZER_FLAGS -fsanitize=dataflow) else() message(WARNING "Unsupported value of LLVM_USE_SANITIZER: ${USE_SANITIZER}") endif() Index: clang/docs/DataFlowSanitizer.rst =================================================================== --- clang/docs/DataFlowSanitizer.rst +++ clang/docs/DataFlowSanitizer.rst @@ -20,6 +20,31 @@ dynamic data flow analysis framework to be used by clients to help detect application-specific issues within their own code. +How to build libc++ with DFSan +============================== + +DFSan requires either all of your code to be instrumented or for uninstrumented +functions to be listed as``uninstrumented`` in the `ABI list`_. + +If you'd like to have instrumented libc++ functions, then you need to build it +with DFSan instrumentation from source. Here is an example of how to build +libc++ and the libc++ ABI with data flow sanitizer instrumentation. + +.. code-block:: console + cd libcxx-build + + # An example using ninja + cmake -GNinja path/to/llvm-project/llvm \ + -DCMAKE_C_COMPILER=clang \ + -DCMAKE_CXX_COMPILER=clang++ \ + -DLLVM_USE_SANITIZER="DataFlow" \ + -DLLVM_ENABLE_LIBCXX=ON \ + -DLLVM_ENABLE_PROJECTS="libcxx;libcxxabi" + + ninja cxx cxxabi + +Note: Ensure you are building with a sufficiently new version of Clang. + Usage ===== @@ -33,6 +58,8 @@ For further information about each function, please refer to the header file. +.. _ABI list: + ABI List --------
Index: llvm/docs/CMake.rst =================================================================== --- llvm/docs/CMake.rst +++ llvm/docs/CMake.rst @@ -422,7 +422,7 @@ **LLVM_USE_SANITIZER**:STRING Define the sanitizer used to build LLVM binaries and tests. Possible values are ``Address``, ``Memory``, ``MemoryWithOrigins``, ``Undefined``, ``Thread``, - and ``Address;Undefined``. Defaults to empty string. + ``DataFlow``, and ``Address;Undefined``. Defaults to empty string. **LLVM_ENABLE_LTO**:STRING Add ``-flto`` or ``-flto=`` flags to the compile and link command Index: llvm/cmake/modules/HandleLLVMOptions.cmake =================================================================== --- llvm/cmake/modules/HandleLLVMOptions.cmake +++ llvm/cmake/modules/HandleLLVMOptions.cmake @@ -728,6 +728,8 @@ elseif (LLVM_USE_SANITIZER STREQUAL "Thread") append_common_sanitizer_flags() append("-fsanitize=thread" CMAKE_C_FLAGS CMAKE_CXX_FLAGS) + elseif (LLVM_USE_SANITIZER STREQUAL "DataFlow") + append("-fsanitize=dataflow" CMAKE_C_FLAGS CMAKE_CXX_FLAGS) elseif (LLVM_USE_SANITIZER STREQUAL "Address;Undefined" OR LLVM_USE_SANITIZER STREQUAL "Undefined;Address") append_common_sanitizer_flags() Index: libcxx/utils/libcxx/test/config.py =================================================================== --- libcxx/utils/libcxx/test/config.py +++ libcxx/utils/libcxx/test/config.py @@ -909,6 +909,9 @@ self.cxx.flags += ['-fsanitize=thread'] self.config.available_features.add('tsan') self.config.available_features.add('sanitizer-new-delete') + elif san == 'DataFlow': + self.cxx.flags += ['-fsanitize=dataflow'] + self.config.available_features.add('dfsan') else: self.lit_config.fatal('unsupported value for ' 'use_sanitizer: {0}'.format(san)) Index: libcxx/CMakeLists.txt =================================================================== --- libcxx/CMakeLists.txt +++ libcxx/CMakeLists.txt @@ -682,6 +682,8 @@ append_flags(SANITIZER_FLAGS "-fsanitize=address,undefined -fno-sanitize=vptr,function -fno-sanitize-recover=all") elseif (USE_SANITIZER STREQUAL "Thread") append_flags(SANITIZER_FLAGS -fsanitize=thread) + elseif (USE_SANITIZER STREQUAL "DataFlow") + append_flags(SANITIZER_FLAGS -fsanitize=dataflow) else() message(WARNING "Unsupported value of LLVM_USE_SANITIZER: ${USE_SANITIZER}") endif() Index: clang/docs/DataFlowSanitizer.rst =================================================================== --- clang/docs/DataFlowSanitizer.rst +++ clang/docs/DataFlowSanitizer.rst @@ -20,6 +20,31 @@ dynamic data flow analysis framework to be used by clients to help detect application-specific issues within their own code. +How to build libc++ with DFSan +============================== + +DFSan requires either all of your code to be instrumented or for uninstrumented +functions to be listed as``uninstrumented`` in the `ABI list`_. + +If you'd like to have instrumented libc++ functions, then you need to build it +with DFSan instrumentation from source. Here is an example of how to build +libc++ and the libc++ ABI with data flow sanitizer instrumentation. + +.. code-block:: console + cd libcxx-build + + # An example using ninja + cmake -GNinja path/to/llvm-project/llvm \ + -DCMAKE_C_COMPILER=clang \ + -DCMAKE_CXX_COMPILER=clang++ \ + -DLLVM_USE_SANITIZER="DataFlow" \ + -DLLVM_ENABLE_LIBCXX=ON \ + -DLLVM_ENABLE_PROJECTS="libcxx;libcxxabi" + + ninja cxx cxxabi + +Note: Ensure you are building with a sufficiently new version of Clang. + Usage ===== @@ -33,6 +58,8 @@ For further information about each function, please refer to the header file. +.. _ABI list: + ABI List --------
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits