// 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 <fcntl.h>
#include <stddef.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/mman.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <unistd.h>
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