2018-03-19 Richard Biener <rguenther@suse.de>
[official-gcc.git] / libsanitizer / tsan / tsan_stat.cc
blobdecb7a20b842d8494fb0fbc76e3f9071a70f8540
1 //===-- tsan_stat.cc ------------------------------------------------------===//
2 //
3 // This file is distributed under the University of Illinois Open Source
4 // License. See LICENSE.TXT for details.
5 //
6 //===----------------------------------------------------------------------===//
7 //
8 // This file is a part of ThreadSanitizer (TSan), a race detector.
9 //
10 //===----------------------------------------------------------------------===//
11 #include "tsan_stat.h"
12 #include "tsan_rtl.h"
14 namespace __tsan {
16 #if TSAN_COLLECT_STATS
18 void StatAggregate(u64 *dst, u64 *src) {
19 for (int i = 0; i < StatCnt; i++)
20 dst[i] += src[i];
23 void StatOutput(u64 *stat) {
24 stat[StatShadowNonZero] = stat[StatShadowProcessed] - stat[StatShadowZero];
26 static const char *name[StatCnt] = {};
27 name[StatMop] = "Memory accesses ";
28 name[StatMopRead] = " Including reads ";
29 name[StatMopWrite] = " writes ";
30 name[StatMop1] = " Including size 1 ";
31 name[StatMop2] = " size 2 ";
32 name[StatMop4] = " size 4 ";
33 name[StatMop8] = " size 8 ";
34 name[StatMopSame] = " Including same ";
35 name[StatMopIgnored] = " Including ignored ";
36 name[StatMopRange] = " Including range ";
37 name[StatMopRodata] = " Including .rodata ";
38 name[StatMopRangeRodata] = " Including .rodata range ";
39 name[StatShadowProcessed] = "Shadow processed ";
40 name[StatShadowZero] = " Including empty ";
41 name[StatShadowNonZero] = " Including non empty ";
42 name[StatShadowSameSize] = " Including same size ";
43 name[StatShadowIntersect] = " intersect ";
44 name[StatShadowNotIntersect] = " not intersect ";
45 name[StatShadowSameThread] = " Including same thread ";
46 name[StatShadowAnotherThread] = " another thread ";
47 name[StatShadowReplace] = " Including evicted ";
49 name[StatFuncEnter] = "Function entries ";
50 name[StatFuncExit] = "Function exits ";
51 name[StatEvents] = "Events collected ";
53 name[StatThreadCreate] = "Total threads created ";
54 name[StatThreadFinish] = " threads finished ";
55 name[StatThreadReuse] = " threads reused ";
56 name[StatThreadMaxTid] = " max tid ";
57 name[StatThreadMaxAlive] = " max alive threads ";
59 name[StatMutexCreate] = "Mutexes created ";
60 name[StatMutexDestroy] = " destroyed ";
61 name[StatMutexLock] = " lock ";
62 name[StatMutexUnlock] = " unlock ";
63 name[StatMutexRecLock] = " recursive lock ";
64 name[StatMutexRecUnlock] = " recursive unlock ";
65 name[StatMutexReadLock] = " read lock ";
66 name[StatMutexReadUnlock] = " read unlock ";
68 name[StatSyncCreated] = "Sync objects created ";
69 name[StatSyncDestroyed] = " destroyed ";
70 name[StatSyncAcquire] = " acquired ";
71 name[StatSyncRelease] = " released ";
73 name[StatClockAcquire] = "Clock acquire ";
74 name[StatClockAcquireEmpty] = " empty clock ";
75 name[StatClockAcquireFastRelease] = " fast from release-store ";
76 name[StatClockAcquireFull] = " full (slow) ";
77 name[StatClockAcquiredSomething] = " acquired something ";
78 name[StatClockRelease] = "Clock release ";
79 name[StatClockReleaseResize] = " resize ";
80 name[StatClockReleaseFast] = " fast ";
81 name[StatClockReleaseSlow] = " dirty overflow (slow) ";
82 name[StatClockReleaseFull] = " full (slow) ";
83 name[StatClockReleaseAcquired] = " was acquired ";
84 name[StatClockReleaseClearTail] = " clear tail ";
85 name[StatClockStore] = "Clock release store ";
86 name[StatClockStoreResize] = " resize ";
87 name[StatClockStoreFast] = " fast ";
88 name[StatClockStoreFull] = " slow ";
89 name[StatClockStoreTail] = " clear tail ";
90 name[StatClockAcquireRelease] = "Clock acquire-release ";
92 name[StatAtomic] = "Atomic operations ";
93 name[StatAtomicLoad] = " Including load ";
94 name[StatAtomicStore] = " store ";
95 name[StatAtomicExchange] = " exchange ";
96 name[StatAtomicFetchAdd] = " fetch_add ";
97 name[StatAtomicFetchSub] = " fetch_sub ";
98 name[StatAtomicFetchAnd] = " fetch_and ";
99 name[StatAtomicFetchOr] = " fetch_or ";
100 name[StatAtomicFetchXor] = " fetch_xor ";
101 name[StatAtomicFetchNand] = " fetch_nand ";
102 name[StatAtomicCAS] = " compare_exchange ";
103 name[StatAtomicFence] = " fence ";
104 name[StatAtomicRelaxed] = " Including relaxed ";
105 name[StatAtomicConsume] = " consume ";
106 name[StatAtomicAcquire] = " acquire ";
107 name[StatAtomicRelease] = " release ";
108 name[StatAtomicAcq_Rel] = " acq_rel ";
109 name[StatAtomicSeq_Cst] = " seq_cst ";
110 name[StatAtomic1] = " Including size 1 ";
111 name[StatAtomic2] = " size 2 ";
112 name[StatAtomic4] = " size 4 ";
113 name[StatAtomic8] = " size 8 ";
114 name[StatAtomic16] = " size 16 ";
116 name[StatAnnotation] = "Dynamic annotations ";
117 name[StatAnnotateHappensBefore] = " HappensBefore ";
118 name[StatAnnotateHappensAfter] = " HappensAfter ";
119 name[StatAnnotateCondVarSignal] = " CondVarSignal ";
120 name[StatAnnotateCondVarSignalAll] = " CondVarSignalAll ";
121 name[StatAnnotateMutexIsNotPHB] = " MutexIsNotPHB ";
122 name[StatAnnotateCondVarWait] = " CondVarWait ";
123 name[StatAnnotateRWLockCreate] = " RWLockCreate ";
124 name[StatAnnotateRWLockCreateStatic] = " StatAnnotateRWLockCreateStatic ";
125 name[StatAnnotateRWLockDestroy] = " RWLockDestroy ";
126 name[StatAnnotateRWLockAcquired] = " RWLockAcquired ";
127 name[StatAnnotateRWLockReleased] = " RWLockReleased ";
128 name[StatAnnotateTraceMemory] = " TraceMemory ";
129 name[StatAnnotateFlushState] = " FlushState ";
130 name[StatAnnotateNewMemory] = " NewMemory ";
131 name[StatAnnotateNoOp] = " NoOp ";
132 name[StatAnnotateFlushExpectedRaces] = " FlushExpectedRaces ";
133 name[StatAnnotateEnableRaceDetection] = " EnableRaceDetection ";
134 name[StatAnnotateMutexIsUsedAsCondVar] = " MutexIsUsedAsCondVar ";
135 name[StatAnnotatePCQGet] = " PCQGet ";
136 name[StatAnnotatePCQPut] = " PCQPut ";
137 name[StatAnnotatePCQDestroy] = " PCQDestroy ";
138 name[StatAnnotatePCQCreate] = " PCQCreate ";
139 name[StatAnnotateExpectRace] = " ExpectRace ";
140 name[StatAnnotateBenignRaceSized] = " BenignRaceSized ";
141 name[StatAnnotateBenignRace] = " BenignRace ";
142 name[StatAnnotateIgnoreReadsBegin] = " IgnoreReadsBegin ";
143 name[StatAnnotateIgnoreReadsEnd] = " IgnoreReadsEnd ";
144 name[StatAnnotateIgnoreWritesBegin] = " IgnoreWritesBegin ";
145 name[StatAnnotateIgnoreWritesEnd] = " IgnoreWritesEnd ";
146 name[StatAnnotateIgnoreSyncBegin] = " IgnoreSyncBegin ";
147 name[StatAnnotateIgnoreSyncEnd] = " IgnoreSyncEnd ";
148 name[StatAnnotatePublishMemoryRange] = " PublishMemoryRange ";
149 name[StatAnnotateUnpublishMemoryRange] = " UnpublishMemoryRange ";
150 name[StatAnnotateThreadName] = " ThreadName ";
151 name[Stat__tsan_mutex_create] = " __tsan_mutex_create ";
152 name[Stat__tsan_mutex_destroy] = " __tsan_mutex_destroy ";
153 name[Stat__tsan_mutex_pre_lock] = " __tsan_mutex_pre_lock ";
154 name[Stat__tsan_mutex_post_lock] = " __tsan_mutex_post_lock ";
155 name[Stat__tsan_mutex_pre_unlock] = " __tsan_mutex_pre_unlock ";
156 name[Stat__tsan_mutex_post_unlock] = " __tsan_mutex_post_unlock ";
157 name[Stat__tsan_mutex_pre_signal] = " __tsan_mutex_pre_signal ";
158 name[Stat__tsan_mutex_post_signal] = " __tsan_mutex_post_signal ";
159 name[Stat__tsan_mutex_pre_divert] = " __tsan_mutex_pre_divert ";
160 name[Stat__tsan_mutex_post_divert] = " __tsan_mutex_post_divert ";
162 name[StatMtxTotal] = "Contentionz ";
163 name[StatMtxTrace] = " Trace ";
164 name[StatMtxThreads] = " Threads ";
165 name[StatMtxReport] = " Report ";
166 name[StatMtxSyncVar] = " SyncVar ";
167 name[StatMtxSyncTab] = " SyncTab ";
168 name[StatMtxSlab] = " Slab ";
169 name[StatMtxAtExit] = " Atexit ";
170 name[StatMtxAnnotations] = " Annotations ";
171 name[StatMtxMBlock] = " MBlock ";
172 name[StatMtxDeadlockDetector] = " DeadlockDetector ";
173 name[StatMtxFired] = " FiredSuppressions ";
174 name[StatMtxRacy] = " RacyStacks ";
175 name[StatMtxFD] = " FD ";
176 name[StatMtxGlobalProc] = " GlobalProc ";
178 Printf("Statistics:\n");
179 for (int i = 0; i < StatCnt; i++)
180 Printf("%s: %16zu\n", name[i], (uptr)stat[i]);
183 #endif
185 } // namespace __tsan