[llvm-commits] [compiler-rt] r165214 - in /compiler-rt/trunk/lib: asan/lit_tests/Linux/rlimit_mmap_test.cc sanitizer_common/sanitizer_posix.cc
Kostya Serebryany
kcc at google.com
Thu Oct 4 00:21:09 PDT 2012
Author: kcc
Date: Thu Oct 4 02:21:09 2012
New Revision: 165214
URL: http://llvm.org/viewvc/llvm-project?rev=165214&view=rev
Log:
[asan] properly report mmap failure
Added:
compiler-rt/trunk/lib/asan/lit_tests/Linux/rlimit_mmap_test.cc
Modified:
compiler-rt/trunk/lib/sanitizer_common/sanitizer_posix.cc
Added: compiler-rt/trunk/lib/asan/lit_tests/Linux/rlimit_mmap_test.cc
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/asan/lit_tests/Linux/rlimit_mmap_test.cc?rev=165214&view=auto
==============================================================================
--- compiler-rt/trunk/lib/asan/lit_tests/Linux/rlimit_mmap_test.cc (added)
+++ compiler-rt/trunk/lib/asan/lit_tests/Linux/rlimit_mmap_test.cc Thu Oct 4 02:21:09 2012
@@ -0,0 +1,16 @@
+// Check that we properly report mmap failure.
+// RUN: %clangxx_asan %s -o %t && %t 2>&1 | FileCheck %s
+#include <stdlib.h>
+#include <assert.h>
+#include <sys/time.h>
+#include <sys/resource.h>
+
+static volatile void *x;
+
+int main(int argc, char **argv) {
+ struct rlimit mmap_resource_limit = { 0, 0 };
+ assert(0 == setrlimit(RLIMIT_AS, &mmap_resource_limit));
+ x = malloc(10000000);
+// CHECK: AddressSanitizer is unable to mmap
+ return 0;
+}
Modified: compiler-rt/trunk/lib/sanitizer_common/sanitizer_posix.cc
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/sanitizer_common/sanitizer_posix.cc?rev=165214&r1=165213&r2=165214&view=diff
==============================================================================
--- compiler-rt/trunk/lib/sanitizer_common/sanitizer_posix.cc (original)
+++ compiler-rt/trunk/lib/sanitizer_common/sanitizer_posix.cc Thu Oct 4 02:21:09 2012
@@ -47,6 +47,14 @@
PROT_READ | PROT_WRITE,
MAP_PRIVATE | MAP_ANON, -1, 0);
if (res == (void*)-1) {
+ static int recursion_count;
+ if (recursion_count) {
+ // The Report() and CHECK calls below may call mmap recursively and fail.
+ // If we went into recursion, just die.
+ RawWrite("AddressSanitizer is unable to mmap\n");
+ Die();
+ }
+ recursion_count++;
Report("ERROR: Failed to allocate 0x%zx (%zd) bytes of %s: %s\n",
size, size, mem_type, strerror(errno));
DumpProcessMap();
More information about the llvm-commits
mailing list