1 //===-- tsan_stat.cc ------------------------------------------------------===//
3 // This file is distributed under the University of Illinois Open Source
4 // License. See LICENSE.TXT for details.
6 //===----------------------------------------------------------------------===//
8 // This file is a part of ThreadSanitizer (TSan), a race detector.
10 //===----------------------------------------------------------------------===//
11 #include "tsan_stat.h"
16 #if TSAN_COLLECT_STATS
18 void StatAggregate(u64
*dst
, u64
*src
) {
19 for (int i
= 0; i
< StatCnt
; 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
]);
185 } // namespace __tsan