Home
last modified time | relevance | path

Searched refs:thr (Results 1 – 25 of 132) sorted by relevance

123456

/external/compiler-rt/lib/tsan/rtl/
Dtsan_rtl_mutex.cc26 void ReportDeadlock(ThreadState *thr, uptr pc, DDReport *r);
29 ThreadState *thr; member
32 Callback(ThreadState *thr, uptr pc) in Callback()
33 : thr(thr) in Callback()
35 DDCallback::pt = thr->proc()->dd_pt; in Callback()
36 DDCallback::lt = thr->dd_lt; in Callback()
39 u32 Unwind() override { return CurrentStackId(thr, pc); } in Unwind()
40 int UniqueTid() override { return thr->unique_id; } in UniqueTid()
43 void DDMutexInit(ThreadState *thr, uptr pc, SyncVar *s) { in DDMutexInit() argument
44 Callback cb(thr, pc); in DDMutexInit()
[all …]
Dtsan_rtl_thread.cc27 , thr() in ThreadContext()
49 ThreadState *thr; member
54 thr = 0; in OnCreated()
58 if (!args->thr) // GCD workers don't have a parent thread. in OnCreated()
60 args->thr->fast_state.IncrementEpoch(); in OnCreated()
62 TraceAddEvent(args->thr, args->thr->fast_state, EventTypeMop, 0); in OnCreated()
63 ReleaseImpl(args->thr, 0, &sync); in OnCreated()
64 creation_stack_id = CurrentStackId(args->thr, args->pc); in OnCreated()
66 StatInc(args->thr, StatThreadMaxTid); in OnCreated()
81 ThreadState *thr; member
[all …]
Dtsan_fd.cc50 static FdSync *allocsync(ThreadState *thr, uptr pc) { in allocsync() argument
51 FdSync *s = (FdSync*)user_alloc(thr, pc, sizeof(FdSync), kDefaultAlignment, in allocsync()
63 static void unref(ThreadState *thr, uptr pc, FdSync *s) { in unref() argument
69 user_free(thr, pc, s, false); in unref()
74 static FdDesc *fddesc(ThreadState *thr, uptr pc, int fd) { in fddesc() argument
82 void *p = user_alloc(thr, pc, size, kDefaultAlignment, false); in fddesc()
84 MemoryResetRange(thr, (uptr)&fddesc, (uptr)p, size); in fddesc()
88 user_free(thr, pc, p, false); in fddesc()
94 static void init(ThreadState *thr, uptr pc, int fd, FdSync *s, in init() argument
96 FdDesc *d = fddesc(thr, pc, fd); in init()
[all …]
Dtsan_rtl.cc308 void Initialize(ThreadState *thr) { in Initialize() argument
336 ProcWire(proc, thr); in Initialize()
365 int tid = ThreadCreate(thr, 0, 0, true); in Initialize()
367 ThreadStart(thr, tid, internal_getpid()); in Initialize()
387 int Finalize(ThreadState *thr) { in Finalize() argument
390 if (flags()->atexit_sleep_ms > 0 && ThreadCount(thr) > 1) in Finalize()
403 ThreadFinalize(thr); in Finalize()
430 StatAggregate(ctx->stat, thr->stat); in Finalize()
438 void ForkBefore(ThreadState *thr, uptr pc) { in ForkBefore() argument
443 void ForkParentAfter(ThreadState *thr, uptr pc) { in ForkParentAfter() argument
[all …]
Dtsan_mman.cc83 ThreadState *thr = cur_thread(); in ScopedGlobalProcessor() local
84 if (thr->proc()) in ScopedGlobalProcessor()
101 ProcWire(gp->proc, thr); in ScopedGlobalProcessor()
106 ThreadState *thr = cur_thread(); in ~ScopedGlobalProcessor() local
107 if (thr->proc() != gp->proc) in ~ScopedGlobalProcessor()
109 ProcUnwire(gp->proc, thr); in ~ScopedGlobalProcessor()
135 static void SignalUnsafeCall(ThreadState *thr, uptr pc) { in SignalUnsafeCall() argument
136 if (atomic_load_relaxed(&thr->in_signal_handler) == 0 || in SignalUnsafeCall()
140 ObtainCurrentStack(thr, pc, &stack); in SignalUnsafeCall()
146 OutputReport(thr, rep); in SignalUnsafeCall()
[all …]
Dtsan_interceptors.cc241 static ThreadSignalContext *SigCtx(ThreadState *thr) { in SigCtx() argument
242 ThreadSignalContext *ctx = (ThreadSignalContext*)thr->signal_ctx; in SigCtx()
243 if (ctx == 0 && !thr->is_dead) { in SigCtx()
245 MemoryResetRange(thr, (uptr)&SigCtx, (uptr)ctx, sizeof(*ctx)); in SigCtx()
246 thr->signal_ctx = ctx; in SigCtx()
255 ScopedInterceptor::ScopedInterceptor(ThreadState *thr, const char *fname, in ScopedInterceptor() argument
257 : thr_(thr) in ScopedInterceptor()
260 Initialize(thr); in ScopedInterceptor()
264 FuncEntry(thr, pc); in ScopedInterceptor()
312 #define READ_STRING_OF_LEN(thr, pc, s, len, n) \ argument
[all …]
Dtsan_rtl.h337 ThreadState *thr; // currently wired thread, or nullptr member
464 ThreadState *thr; variable
591 void ObtainCurrentStack(ThreadState *thr, uptr toppc, StackTraceTy *stack) { in ObtainCurrentStack() argument
592 uptr size = thr->shadow_stack_pos - thr->shadow_stack; in ObtainCurrentStack()
598 stack->Init(&thr->shadow_stack[start], size, toppc); in ObtainCurrentStack()
607 void ALWAYS_INLINE StatInc(ThreadState *thr, StatType typ, u64 n = 1) {
609 thr->stat[typ] += n;
612 void ALWAYS_INLINE StatSet(ThreadState *thr, StatType typ, u64 n) { in StatSet() argument
614 thr->stat[typ] = n; in StatSet()
626 void ForkBefore(ThreadState *thr, uptr pc);
[all …]
Dtsan_interface_java.cc41 ScopedJavaFunc(ThreadState *thr, uptr pc) in ScopedJavaFunc() argument
42 : thr_(thr) { in ScopedJavaFunc()
44 FuncEntry(thr, pc); in ScopedJavaFunc()
62 ThreadState *thr = cur_thread(); \
66 ScopedJavaFunc scoped(thr, caller_pc); \
71 DPrintf("#%d: java_init(%p, %p)\n", thr->tid, heap_begin, heap_size); in __tsan_java_init()
83 DPrintf("#%d: java_fini()\n", thr->tid); in __tsan_java_fini()
86 int status = Finalize(thr); in __tsan_java_fini()
87 DPrintf("#%d: java_fini() = %d\n", thr->tid, status); in __tsan_java_fini()
93 DPrintf("#%d: java_alloc(%p, %p)\n", thr->tid, ptr, size); in __tsan_java_alloc()
[all …]
Dtsan_fd.h42 void FdAcquire(ThreadState *thr, uptr pc, int fd);
43 void FdRelease(ThreadState *thr, uptr pc, int fd);
44 void FdAccess(ThreadState *thr, uptr pc, int fd);
45 void FdClose(ThreadState *thr, uptr pc, int fd, bool write = true);
46 void FdFileCreate(ThreadState *thr, uptr pc, int fd);
47 void FdDup(ThreadState *thr, uptr pc, int oldfd, int newfd, bool write);
48 void FdPipeCreate(ThreadState *thr, uptr pc, int rfd, int wfd);
49 void FdEventCreate(ThreadState *thr, uptr pc, int fd);
50 void FdSignalCreate(ThreadState *thr, uptr pc, int fd);
51 void FdInotifyCreate(ThreadState *thr, uptr pc, int fd);
[all …]
Dtsan_rtl_proc.cc25 proc->thr = nullptr; in ProcCreate()
35 CHECK_EQ(proc->thr, nullptr); in ProcDestroy()
47 void ProcWire(Processor *proc, ThreadState *thr) { in ProcWire() argument
48 CHECK_EQ(thr->proc1, nullptr); in ProcWire()
49 CHECK_EQ(proc->thr, nullptr); in ProcWire()
50 thr->proc1 = proc; in ProcWire()
51 proc->thr = thr; in ProcWire()
54 void ProcUnwire(Processor *proc, ThreadState *thr) { in ProcUnwire() argument
55 CHECK_EQ(thr->proc1, proc); in ProcUnwire()
56 CHECK_EQ(proc->thr, thr); in ProcUnwire()
[all …]
Dtsan_interface_atomic.cc223 static T AtomicLoad(ThreadState *thr, uptr pc, const volatile T *a, in AtomicLoad() argument
229 MemoryReadAtomic(thr, pc, (uptr)a, SizeLog<T>()); in AtomicLoad()
232 SyncVar *s = ctx->metamap.GetOrCreateAndLock(thr, pc, (uptr)a, false); in AtomicLoad()
233 AcquireImpl(thr, pc, &s->clock); in AtomicLoad()
236 MemoryReadAtomic(thr, pc, (uptr)a, SizeLog<T>()); in AtomicLoad()
253 static void AtomicStore(ThreadState *thr, uptr pc, volatile T *a, T v, in AtomicStore() argument
256 MemoryWriteAtomic(thr, pc, (uptr)a, SizeLog<T>()); in AtomicStore()
266 SyncVar *s = ctx->metamap.GetOrCreateAndLock(thr, pc, (uptr)a, true); in AtomicStore()
267 thr->fast_state.IncrementEpoch(); in AtomicStore()
269 TraceAddEvent(thr, thr->fast_state, EventTypeMop, 0); in AtomicStore()
[all …]
Dtsan_rtl_report.cc231 ThreadState *thr = tctx->thr; in IsInStackOrTls() local
232 CHECK(thr); in IsInStackOrTls()
233 return ((addr >= thr->stk_addr && addr < thr->stk_addr + thr->stk_size) || in IsInStackOrTls()
234 (addr >= thr->tls_addr && addr < thr->tls_addr + thr->tls_size)); in IsInStackOrTls()
244 ThreadState *thr = tctx->thr; in IsThreadStackOrTls() local
245 CHECK(thr); in IsThreadStackOrTls()
246 *is_stack = (addr >= thr->stk_addr && addr < thr->stk_addr + thr->stk_size); in IsThreadStackOrTls()
434 static bool HandleRacyStacks(ThreadState *thr, VarSizeStackTrace traces[2], in HandleRacyStacks() argument
480 static void AddRacyStacks(ThreadState *thr, VarSizeStackTrace traces[2], in AddRacyStacks() argument
495 bool OutputReport(ThreadState *thr, const ScopedReport &srep) { in OutputReport() argument
[all …]
Dtsan_update_shadow_word_inl.h17 StatInc(thr, StatShadowProcessed);
22 StatInc(thr, StatShadowZero);
31 StatInc(thr, StatShadowSameSize);
34 StatInc(thr, StatShadowSameThread);
39 StatInc(thr, StatShadowAnotherThread);
40 if (HappensBefore(old, thr)) {
51 StatInc(thr, StatShadowIntersect);
53 StatInc(thr, StatShadowSameThread);
56 StatInc(thr, StatShadowAnotherThread);
59 if (HappensBefore(old, thr))
[all …]
Dtsan_libdispatch_mac.cc80 static tsan_block_context_t *AllocContext(ThreadState *thr, uptr pc, in AllocContext() argument
85 (tsan_block_context_t *)user_alloc(thr, pc, sizeof(tsan_block_context_t)); in AllocContext()
106 Acquire(thr, pc, submit_sync); in dispatch_callback_wrap()
107 Acquire(thr, pc, serial_sync); in dispatch_callback_wrap()
108 if (serial_task) Acquire(thr, pc, concurrent_sync); in dispatch_callback_wrap()
114 Release(thr, pc, serial_task ? serial_sync : concurrent_sync); in dispatch_callback_wrap()
115 if (context->submitted_synchronously) Release(thr, pc, submit_sync); in dispatch_callback_wrap()
117 if (context->free_context_in_callback) user_free(thr, pc, context); in dispatch_callback_wrap()
138 AllocContext(thr, pc, q, heap_block, &invoke_and_release_block); \
140 Release(thr, pc, (uptr)new_context); \
[all …]
/external/compiler-rt/lib/tsan/go/
Dtsan_go.cc135 ThreadState *thr = (ThreadState*)internal_alloc(MBlockThreadContex, in AllocGoroutine() local
137 internal_memset(thr, 0, sizeof(*thr)); in AllocGoroutine()
138 return thr; in AllocGoroutine()
144 ThreadState *thr = AllocGoroutine(); in __tsan_init() local
145 main_thr = *thrp = thr; in __tsan_init()
146 Initialize(thr); in __tsan_init()
147 *procp = thr->proc1; in __tsan_init()
153 ThreadState *thr = main_thr; in __tsan_fini() local
154 int res = Finalize(thr); in __tsan_fini()
162 void __tsan_read(ThreadState *thr, void *addr, void *pc) { in __tsan_read() argument
[all …]
Dtest.c17 void __tsan_init(void **thr, void **proc, void (*cb)(long, void*));
20 void __tsan_go_start(void *thr, void **chthr, void *pc);
21 void __tsan_go_end(void *thr);
24 void __tsan_proc_wire(void *proc, void *thr);
25 void __tsan_proc_unwire(void *proc, void *thr);
26 void __tsan_read(void *thr, void *addr, void *pc);
27 void __tsan_write(void *thr, void *addr, void *pc);
28 void __tsan_func_enter(void *thr, void *pc);
29 void __tsan_func_exit(void *thr);
30 void __tsan_malloc(void *thr, void *pc, void *p, unsigned long sz);
[all …]
/external/compiler-rt/lib/tsan/dd/
Ddd_rtl.cc22 static u32 CurrentStackTrace(Thread *thr, uptr skip) { in CurrentStackTrace() argument
24 thr->ignore_interceptors = true; in CurrentStackTrace()
26 thr->ignore_interceptors = false; in CurrentStackTrace()
32 static void PrintStackTrace(Thread *thr, u32 stk) { in PrintStackTrace() argument
34 thr->ignore_interceptors = true; in PrintStackTrace()
36 thr->ignore_interceptors = false; in PrintStackTrace()
39 static void ReportDeadlock(Thread *thr, DDReport *rep) { in ReportDeadlock() argument
48 PrintStackTrace(thr, rep->loop[i].stk[1]); in ReportDeadlock()
52 PrintStackTrace(thr, rep->loop[i].stk[0]); in ReportDeadlock()
58 Callback::Callback(Thread *thr) in Callback() argument
[all …]
Ddd_interceptors.cc19 static __thread Thread *thr; variable
29 if (thr != 0) in InitThread()
36 thr = (Thread*)InternalAlloc(sizeof(*thr)); in InitThread()
37 internal_memset(thr, 0, sizeof(*thr)); in InitThread()
38 ThreadInit(thr); in InitThread()
45 MutexDestroy(thr, (uptr)m); in INTERCEPTOR()
51 MutexBeforeLock(thr, (uptr)m, true); in INTERCEPTOR()
53 MutexAfterLock(thr, (uptr)m, true, false); in INTERCEPTOR()
61 MutexAfterLock(thr, (uptr)m, true, true); in INTERCEPTOR()
67 MutexBeforeUnlock(thr, (uptr)m, true); in INTERCEPTOR()
[all …]
/external/compiler-rt/lib/tsan/tests/unit/
Dtsan_mman_test.cc38 ThreadState *thr = cur_thread(); in TEST() local
40 char *p = (char*)user_alloc(thr, pc, 10); in TEST()
42 char *p2 = (char*)user_alloc(thr, pc, 20); in TEST()
47 user_free(thr, pc, p); in TEST()
48 user_free(thr, pc, p2); in TEST()
52 ThreadState *thr = cur_thread(); in TEST() local
55 void *p = user_realloc(thr, pc, 0, 0); in TEST()
61 void *p = user_realloc(thr, pc, 0, 100); in TEST()
64 user_free(thr, pc, p); in TEST()
67 void *p = user_alloc(thr, pc, 100); in TEST()
[all …]
Dtsan_stack_test.cc22 ThreadState thr(0, 0, 0, 0, 0, 0, 0, 0, 0); in TestStackTrace() local
24 thr.shadow_stack = &stack[0]; in TestStackTrace()
25 thr.shadow_stack_pos = &stack[0]; in TestStackTrace()
26 thr.shadow_stack_end = &stack[128]; in TestStackTrace()
28 ObtainCurrentStack(&thr, 0, trace); in TestStackTrace()
31 ObtainCurrentStack(&thr, 42, trace); in TestStackTrace()
35 *thr.shadow_stack_pos++ = 100; in TestStackTrace()
36 *thr.shadow_stack_pos++ = 101; in TestStackTrace()
37 ObtainCurrentStack(&thr, 0, trace); in TestStackTrace()
42 ObtainCurrentStack(&thr, 42, trace); in TestStackTrace()
[all …]
Dtsan_sync_test.cc20 ThreadState *thr = cur_thread(); in TEST() local
23 m->AllocBlock(thr, 0, (uptr)&block[0], 1 * sizeof(u64)); in TEST()
27 EXPECT_EQ(mb->tid, thr->tid); in TEST()
28 uptr sz = m->FreeBlock(thr->proc(), (uptr)&block[0]); in TEST()
35 ThreadState *thr = cur_thread(); in TEST() local
38 m->AllocBlock(thr, 0, (uptr)&block[0], 1 * sizeof(u64)); in TEST()
39 m->AllocBlock(thr, 0, (uptr)&block[1], 3 * sizeof(u64)); in TEST()
44 m->FreeRange(thr->proc(), (uptr)&block[0], 4 * sizeof(u64)); in TEST()
52 ThreadState *thr = cur_thread(); in TEST() local
55 m->AllocBlock(thr, 0, (uptr)&block[0], 4 * sizeof(u64)); in TEST()
[all …]
/external/valgrind/helgrind/
Dhg_main.c172 ThreadId map_threads_maybe_reverse_lookup_SLOW ( Thread* thr ); /*fwds*/
253 static void lockN_acquire_writer ( Lock* lk, Thread* thr ) in lockN_acquire_writer() argument
256 tl_assert(HG_(is_sane_Thread)(thr)); in lockN_acquire_writer()
266 tid = map_threads_maybe_reverse_lookup_SLOW(thr); in lockN_acquire_writer()
281 VG_(addToBag)( lk->heldBy, (UWord)thr ); in lockN_acquire_writer()
291 tl_assert(VG_(elemBag)(lk->heldBy, (UWord)thr) in lockN_acquire_writer()
293 VG_(addToBag)(lk->heldBy, (UWord)thr); in lockN_acquire_writer()
304 static void lockN_acquire_reader ( Lock* lk, Thread* thr ) in lockN_acquire_reader() argument
307 tl_assert(HG_(is_sane_Thread)(thr)); in lockN_acquire_reader()
322 tid = map_threads_maybe_reverse_lookup_SLOW(thr); in lockN_acquire_reader()
[all …]
Dhg_errors.c312 Thread* thr; member
326 Thread* thr; /* doing the unlocking */ member
330 Thread* thr; /* doing the unlocking */ member
335 Thread* thr; /* doing the unlocking */ member
339 Thread* thr; member
345 Thread* thr; member
361 Thread* thr; member
406 tl_assert(xe->XE.Race.thr); in HG_()
410 xe->XE.Race.thr->locksetW, in HG_()
434 Thr* acc_thr = xe->XE.Race.thr->hbthr; in HG_()
[all …]
Dlibhb.h84 void libhb_so_send ( Thr* thr, SO* so, Bool strong_send );
94 void libhb_so_recv ( Thr* thr, SO* so, Bool strong_recv );
113 void zsm_sapply08_f__msmcwrite ( Thr* thr, Addr a );
114 void zsm_sapply16_f__msmcwrite ( Thr* thr, Addr a );
115 void zsm_sapply32_f__msmcwrite ( Thr* thr, Addr a );
116 void zsm_sapply64_f__msmcwrite ( Thr* thr, Addr a );
117 void zsm_sapplyNN_f__msmcwrite ( Thr* thr, Addr a, SizeT len );
119 void zsm_sapply08_f__msmcread ( Thr* thr, Addr a );
120 void zsm_sapply16_f__msmcread ( Thr* thr, Addr a );
121 void zsm_sapply32_f__msmcread ( Thr* thr, Addr a );
[all …]
/external/compiler-rt/test/asan/TestCases/Windows/
Dthread_stack_reuse.cc22 HANDLE thr = NULL; in main() local
24 thr = CreateThread(NULL, 0, thread_proc_1, NULL, 0, NULL); in main()
25 if (thr == 0) in main()
27 if (WAIT_OBJECT_0 != WaitForSingleObject(thr, INFINITE)) in main()
30 thr = CreateThread(NULL, 0, thread_proc_2, NULL, 0, NULL); in main()
31 if (thr == 0) in main()
33 if (WAIT_OBJECT_0 != WaitForSingleObject(thr, INFINITE)) in main()
35 CloseHandle(thr); in main()

123456