// RUN: %clang_tsan -O1 %s -o %t && %run %t 2>&1 | FileCheck %s // Test that mmap does not return unexpected addresses // (the check is in the interceptor). #include #include #include #include #include #include #include #include int main() { int fd = open("/dev/zero", O_RDWR); if (fd == -1) perror("open(/dev/zero)"), exit(1); for (size_t mmap_size = 64ull << 30; mmap_size >= 4 << 10; mmap_size /= 2) { size_t allocated = 0; while (mmap(0, mmap_size, PROT_READ | PROT_WRITE, MAP_ANON | MAP_PRIVATE, fd, 0) != MAP_FAILED) { allocated += mmap_size; } fprintf(stderr, "allocated %zu with size %zu\n", allocated, mmap_size); } fprintf(stderr, "DONE\n"); // If tsan runtime will try to allocate something during exit handling, // the allocation will fail because there is no VA whatsoever. // It's observed to fail with the following error in some cases: // failed to allocate 0x1000 (4096) bytes of DTLS_NextBlock. // So terminate the process immediately. _exit(0); } // CHECK: DONE