[PATCH] D50753: [hwasan] Add malloc_fill_byte and free_fill_byte flags.
Evgenii Stepanov via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Aug 16 13:13:59 PDT 2018
This revision was automatically updated to reflect the committed changes.
Closed by commit rL339932: [hwasan] Add malloc_fill_byte and free_fill_byte flags. (authored by eugenis, committed by ).
Herald added a subscriber: delcypher.
Changed prior to commit:
https://reviews.llvm.org/D50753?vs=160738&id=161094#toc
Repository:
rL LLVM
https://reviews.llvm.org/D50753
Files:
compiler-rt/trunk/lib/hwasan/hwasan_allocator.cc
compiler-rt/trunk/lib/hwasan/hwasan_flags.inc
compiler-rt/trunk/test/hwasan/TestCases/malloc_fill.cc
Index: compiler-rt/trunk/test/hwasan/TestCases/malloc_fill.cc
===================================================================
--- compiler-rt/trunk/test/hwasan/TestCases/malloc_fill.cc
+++ compiler-rt/trunk/test/hwasan/TestCases/malloc_fill.cc
@@ -0,0 +1,22 @@
+// Check that we fill malloc-ed memory correctly.
+// RUN: %clangxx_hwasan %s -o %t
+// RUN: %run %t | FileCheck %s
+// RUN: %env_hwasan_opts=max_malloc_fill_size=10:malloc_fill_byte=8 %run %t | FileCheck %s --check-prefix=CHECK-10-8
+// RUN: %env_hwasan_opts=max_malloc_fill_size=20:malloc_fill_byte=171 %run %t | FileCheck %s --check-prefix=CHECK-20-ab
+
+#include <stdio.h>
+int main(int argc, char **argv) {
+ // With asan allocator this makes sure we get memory from mmap.
+ static const int kSize = 1 << 25;
+ unsigned char *x = new unsigned char[kSize];
+ printf("-");
+ for (int i = 0; i <= 32; i++) {
+ printf("%02x", x[i]);
+ }
+ printf("-\n");
+ delete [] x;
+}
+
+// CHECK: -bebebebebebebebebebebebebebebebebebebebebebebebebebebebebebebebebe-
+// CHECK-10-8: -080808080808080808080000000000000000000000000000000000000000000000-
+// CHECK-20-ab: -abababababababababababababababababababab00000000000000000000000000-
Index: compiler-rt/trunk/lib/hwasan/hwasan_flags.inc
===================================================================
--- compiler-rt/trunk/lib/hwasan/hwasan_flags.inc
+++ compiler-rt/trunk/lib/hwasan/hwasan_flags.inc
@@ -31,3 +31,16 @@
// If false, use simple increment of a thread local counter to generate new
// tags.
HWASAN_FLAG(bool, random_tags, true, "")
+
+HWASAN_FLAG(
+ int, max_malloc_fill_size, 0x1000, // By default, fill only the first 4K.
+ "HWASan allocator flag. max_malloc_fill_size is the maximal amount of "
+ "bytes that will be filled with malloc_fill_byte on malloc.")
+HWASAN_FLAG(
+ int, max_free_fill_size, 0,
+ "HWASan allocator flag. max_free_fill_size is the maximal amount of "
+ "bytes that will be filled with free_fill_byte during free.")
+HWASAN_FLAG(int, malloc_fill_byte, 0xbe,
+ "Value used to fill the newly allocated memory.")
+HWASAN_FLAG(int, free_fill_byte, 0x55,
+ "Value used to fill deallocated memory.")
Index: compiler-rt/trunk/lib/hwasan/hwasan_allocator.cc
===================================================================
--- compiler-rt/trunk/lib/hwasan/hwasan_allocator.cc
+++ compiler-rt/trunk/lib/hwasan/hwasan_allocator.cc
@@ -156,8 +156,12 @@
meta->state = CHUNK_ALLOCATED;
meta->requested_size = size;
meta->alloc_context_id = StackDepotPut(*stack);
- if (zeroise)
+ if (zeroise) {
internal_memset(allocated, 0, size);
+ } else if (flags()->max_malloc_fill_size > 0) {
+ uptr fill_size = Min(size, (uptr)flags()->max_malloc_fill_size);
+ internal_memset(allocated, flags()->malloc_fill_byte, fill_size);
+ }
void *user_ptr = allocated;
if (flags()->tag_in_malloc &&
@@ -182,6 +186,10 @@
// This memory will not be reused by anyone else, so we are free to keep it
// poisoned.
HwasanThread *t = GetCurrentThread();
+ if (flags()->max_free_fill_size > 0) {
+ uptr fill_size = Min(size, (uptr)flags()->max_free_fill_size);
+ internal_memset(p, flags()->free_fill_byte, fill_size);
+ }
if (flags()->tag_in_free &&
atomic_load_relaxed(&hwasan_allocator_tagging_enabled))
TagMemoryAligned((uptr)p, size,
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D50753.161094.patch
Type: text/x-patch
Size: 3368 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20180816/84611f09/attachment.bin>
More information about the llvm-commits
mailing list