Home | History | Annotate | Download | only in rtl
      1 //===-- tsan_platform_mac.cc ----------------------------------------------===//
      2 //
      3 //                     The LLVM Compiler Infrastructure
      4 //
      5 // This file is distributed under the University of Illinois Open Source
      6 // License. See LICENSE.TXT for details.
      7 //
      8 //===----------------------------------------------------------------------===//
      9 //
     10 // This file is a part of ThreadSanitizer (TSan), a race detector.
     11 //
     12 // Mac-specific code.
     13 //===----------------------------------------------------------------------===//
     14 
     15 #include "sanitizer_common/sanitizer_platform.h"
     16 #if SANITIZER_MAC
     17 
     18 #include "sanitizer_common/sanitizer_common.h"
     19 #include "sanitizer_common/sanitizer_libc.h"
     20 #include "sanitizer_common/sanitizer_procmaps.h"
     21 #include "tsan_platform.h"
     22 #include "tsan_rtl.h"
     23 #include "tsan_flags.h"
     24 
     25 #include <pthread.h>
     26 #include <signal.h>
     27 #include <stdio.h>
     28 #include <stdlib.h>
     29 #include <string.h>
     30 #include <stdarg.h>
     31 #include <sys/mman.h>
     32 #include <sys/syscall.h>
     33 #include <sys/time.h>
     34 #include <sys/types.h>
     35 #include <sys/resource.h>
     36 #include <sys/stat.h>
     37 #include <unistd.h>
     38 #include <errno.h>
     39 #include <sched.h>
     40 
     41 namespace __tsan {
     42 
     43 uptr GetShadowMemoryConsumption() {
     44   return 0;
     45 }
     46 
     47 void FlushShadowMemory() {
     48 }
     49 
     50 void WriteMemoryProfile(char *buf, uptr buf_size, uptr nthread, uptr nlive) {
     51 }
     52 
     53 uptr GetRSS() {
     54   return 0;
     55 }
     56 
     57 #ifndef TSAN_GO
     58 void InitializeShadowMemory() {
     59   uptr shadow = (uptr)MmapFixedNoReserve(kLinuxShadowBeg,
     60     kLinuxShadowEnd - kLinuxShadowBeg);
     61   if (shadow != kLinuxShadowBeg) {
     62     Printf("FATAL: ThreadSanitizer can not mmap the shadow memory\n");
     63     Printf("FATAL: Make sure to compile with -fPIE and "
     64            "to link with -pie.\n");
     65     Die();
     66   }
     67   DPrintf("kLinuxShadow %zx-%zx (%zuGB)\n",
     68       kLinuxShadowBeg, kLinuxShadowEnd,
     69       (kLinuxShadowEnd - kLinuxShadowBeg) >> 30);
     70   DPrintf("kLinuxAppMem %zx-%zx (%zuGB)\n",
     71       kLinuxAppMemBeg, kLinuxAppMemEnd,
     72       (kLinuxAppMemEnd - kLinuxAppMemBeg) >> 30);
     73 }
     74 #endif
     75 
     76 const char *InitializePlatform() {
     77   void *p = 0;
     78   if (sizeof(p) == 8) {
     79     // Disable core dumps, dumping of 16TB usually takes a bit long.
     80     // The following magic is to prevent clang from replacing it with memset.
     81     volatile rlimit lim;
     82     lim.rlim_cur = 0;
     83     lim.rlim_max = 0;
     84     setrlimit(RLIMIT_CORE, (rlimit*)&lim);
     85   }
     86 
     87   return GetEnv(kTsanOptionsEnv);
     88 }
     89 
     90 void FinalizePlatform() {
     91   fflush(0);
     92 }
     93 
     94 #ifndef TSAN_GO
     95 int call_pthread_cancel_with_cleanup(int(*fn)(void *c, void *m,
     96     void *abstime), void *c, void *m, void *abstime,
     97     void(*cleanup)(void *arg), void *arg) {
     98   // pthread_cleanup_push/pop are hardcore macros mess.
     99   // We can't intercept nor call them w/o including pthread.h.
    100   int res;
    101   pthread_cleanup_push(cleanup, arg);
    102   res = fn(c, m, abstime);
    103   pthread_cleanup_pop(0);
    104   return res;
    105 }
    106 #endif
    107 
    108 }  // namespace __tsan
    109 
    110 #endif  // SANITIZER_MAC
    111