annotate libsanitizer/tsan/tsan_rtl_proc.cpp @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
1 //===-- tsan_rtl_proc.cpp -----------------------------------------------===//
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
2 //
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
6 //
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
8 //
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
9 // This file is a part of ThreadSanitizer (TSan), a race detector.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
10 //
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
11 //===----------------------------------------------------------------------===//
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
12
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
13 #include "sanitizer_common/sanitizer_placement_new.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
14 #include "tsan_rtl.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
15 #include "tsan_mman.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
16 #include "tsan_flags.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
17
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
18 namespace __tsan {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
19
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
20 Processor *ProcCreate() {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
21 void *mem = InternalAlloc(sizeof(Processor));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
22 internal_memset(mem, 0, sizeof(Processor));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
23 Processor *proc = new(mem) Processor;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
24 proc->thr = nullptr;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
25 #if !SANITIZER_GO
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
26 AllocatorProcStart(proc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
27 #endif
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
28 if (common_flags()->detect_deadlocks)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
29 proc->dd_pt = ctx->dd->CreatePhysicalThread();
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
30 return proc;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
31 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
32
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
33 void ProcDestroy(Processor *proc) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
34 CHECK_EQ(proc->thr, nullptr);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
35 #if !SANITIZER_GO
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
36 AllocatorProcFinish(proc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
37 #endif
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
38 ctx->clock_alloc.FlushCache(&proc->clock_cache);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
39 ctx->metamap.OnProcIdle(proc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
40 if (common_flags()->detect_deadlocks)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
41 ctx->dd->DestroyPhysicalThread(proc->dd_pt);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
42 proc->~Processor();
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
43 InternalFree(proc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
44 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
45
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
46 void ProcWire(Processor *proc, ThreadState *thr) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
47 CHECK_EQ(thr->proc1, nullptr);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
48 CHECK_EQ(proc->thr, nullptr);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
49 thr->proc1 = proc;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
50 proc->thr = thr;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
51 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
52
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
53 void ProcUnwire(Processor *proc, ThreadState *thr) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
54 CHECK_EQ(thr->proc1, proc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
55 CHECK_EQ(proc->thr, thr);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
56 thr->proc1 = nullptr;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
57 proc->thr = nullptr;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
58 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
59
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
60 } // namespace __tsan