[compiler-rt] r369623 - Revert "[GWP-ASan] Remove c++ standard lib dependency."

Petr Hosek via llvm-commits llvm-commits at lists.llvm.org
Thu Aug 22 00:03:38 PDT 2019


Author: phosek
Date: Thu Aug 22 00:03:38 2019
New Revision: 369623

URL: http://llvm.org/viewvc/llvm-project?rev=369623&view=rev
Log:
Revert "[GWP-ASan] Remove c++ standard lib dependency."

This reverts commit r369606: this doesn't addressed the underlying
problem and it's not the correct solution.

Modified:
    compiler-rt/trunk/lib/gwp_asan/CMakeLists.txt
    compiler-rt/trunk/lib/gwp_asan/stack_trace_compressor_fuzzer.cpp

Modified: compiler-rt/trunk/lib/gwp_asan/CMakeLists.txt
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/gwp_asan/CMakeLists.txt?rev=369623&r1=369622&r2=369623&view=diff
==============================================================================
--- compiler-rt/trunk/lib/gwp_asan/CMakeLists.txt (original)
+++ compiler-rt/trunk/lib/gwp_asan/CMakeLists.txt Thu Aug 22 00:03:38 2019
@@ -108,11 +108,8 @@ if (COMPILER_RT_HAS_GWP_ASAN)
         ${GWP_ASAN_HEADERS})
     set_target_properties(
         stack_trace_compressor_fuzzer PROPERTIES FOLDER "Fuzzers")
-
-    # TODO(phosek): Remove -nostdlib++ and remove the "no c++ standard library
-    # for compiler-rt" dependency here.
-    target_compile_options(stack_trace_compressor_fuzzer
-        PRIVATE -nostdlib++ -fsanitize=fuzzer-no-link)
+    target_compile_options(
+        stack_trace_compressor_fuzzer PRIVATE -fsanitize=fuzzer-no-link)
     set_target_properties(
         stack_trace_compressor_fuzzer PROPERTIES LINK_FLAGS -fsanitize=fuzzer)
     add_dependencies(stack_trace_compressor_fuzzer fuzzer)

Modified: compiler-rt/trunk/lib/gwp_asan/stack_trace_compressor_fuzzer.cpp
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/gwp_asan/stack_trace_compressor_fuzzer.cpp?rev=369623&r1=369622&r2=369623&view=diff
==============================================================================
--- compiler-rt/trunk/lib/gwp_asan/stack_trace_compressor_fuzzer.cpp (original)
+++ compiler-rt/trunk/lib/gwp_asan/stack_trace_compressor_fuzzer.cpp Thu Aug 22 00:03:38 2019
@@ -1,7 +1,8 @@
-#include <stddef.h>
-#include <stdint.h>
-#include <stdio.h>
-#include <stdlib.h>
+#include <cstddef>
+#include <cstdint>
+#include <cstdio>
+#include <cstdlib>
+#include <vector>
 
 #include "gwp_asan/stack_trace_compressor.h"
 
@@ -9,22 +10,23 @@ constexpr size_t kBytesForLargestVarInt
 
 extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
   size_t BufferSize = kBytesForLargestVarInt * Size / sizeof(uintptr_t);
-  uint8_t *Buffer = reinterpret_cast<uint8_t *>(malloc(BufferSize));
-  uint8_t *Buffer2 = reinterpret_cast<uint8_t *>(malloc(BufferSize));
+  std::vector<uint8_t> Buffer(BufferSize);
+  std::vector<uint8_t> Buffer2(BufferSize);
 
   // Unpack the fuzz bytes.
   gwp_asan::compression::unpack(Data, Size,
-                                reinterpret_cast<uintptr_t *>(Buffer2),
+                                reinterpret_cast<uintptr_t *>(Buffer2.data()),
                                 BufferSize / sizeof(uintptr_t));
 
   // Pack the fuzz bytes.
-  size_t BytesWritten =
-      gwp_asan::compression::pack(reinterpret_cast<const uintptr_t *>(Data),
-                                  Size / sizeof(uintptr_t), Buffer, BufferSize);
+  size_t BytesWritten = gwp_asan::compression::pack(
+      reinterpret_cast<const uintptr_t *>(Data), Size / sizeof(uintptr_t),
+      Buffer.data(), BufferSize);
 
   // Unpack the compressed buffer.
   size_t DecodedElements = gwp_asan::compression::unpack(
-      Buffer, BytesWritten, reinterpret_cast<uintptr_t *>(Buffer2),
+      Buffer.data(), BytesWritten,
+      reinterpret_cast<uintptr_t *>(Buffer2.data()),
       BufferSize / sizeof(uintptr_t));
 
   // Ensure that every element was encoded and decoded properly.
@@ -33,7 +35,8 @@ extern "C" int LLVMFuzzerTestOneInput(co
 
   // Ensure that the compression and uncompression resulted in the same trace.
   const uintptr_t *FuzzPtrs = reinterpret_cast<const uintptr_t *>(Data);
-  const uintptr_t *DecodedPtrs = reinterpret_cast<const uintptr_t *>(Buffer2);
+  const uintptr_t *DecodedPtrs =
+      reinterpret_cast<const uintptr_t *>(Buffer2.data());
   for (size_t i = 0; i < Size / sizeof(uintptr_t); ++i) {
     if (FuzzPtrs[i] != DecodedPtrs[i]) {
       fprintf(stderr, "FuzzPtrs[%zu] != DecodedPtrs[%zu] (0x%zx vs. 0x%zx)", i,




More information about the llvm-commits mailing list