File: unpoison-mutated-buffers-from-libfuzzer.patch

package info (click to toggle)
cryptsetup 2%3A2.7.5-2
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 19,624 kB
  • sloc: ansic: 62,955; sh: 16,774; cpp: 994; xml: 920; makefile: 488; perl: 486
file content (29 lines) | stat: -rw-r--r-- 1,007 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
diff --git a/src/libfuzzer/libfuzzer_mutator.cc b/src/libfuzzer/libfuzzer_mutator.cc
index 34d144c..b671fd4 100644
--- a/src/libfuzzer/libfuzzer_mutator.cc
+++ b/src/libfuzzer/libfuzzer_mutator.cc
@@ -14,6 +14,8 @@
 
 #include "src/libfuzzer/libfuzzer_mutator.h"
 
+#include <sanitizer/msan_interface.h>
+
 #include <string.h>
 
 #include <algorithm>
@@ -64,6 +66,7 @@ template <class T>
 T MutateValue(T v) {
   size_t size =
       LLVMFuzzerMutate(reinterpret_cast<uint8_t*>(&v), sizeof(v), sizeof(v));
+  __msan_unpoison(reinterpret_cast<uint8_t*>(&v), size);
   memset(reinterpret_cast<uint8_t*>(&v) + size, 0, sizeof(v) - size);
   return v;
 }
@@ -93,6 +96,7 @@ std::string Mutator::MutateString(const std::string& value,
   result.resize(std::max(1, new_size));
   result.resize(LLVMFuzzerMutate(reinterpret_cast<uint8_t*>(&result[0]),
                                  value.size(), result.size()));
+  __msan_unpoison(reinterpret_cast<uint8_t*>(&result[0]), result.size());
   return result;
 }