2 * @brief Data race detection code.
10 #include "modeltypes.h"
12 /* Forward declaration */
19 struct ShadowBaseTable {
20 uint64_t array[65536];
24 /* Clock and thread associated with first action. This won't change in
25 response to synchronization. */
27 thread_id_t oldthread;
28 modelclock_t oldclock;
29 /* Record whether this is a write, so we can tell the user. */
32 /* Model action associated with second action. This could change as
33 a result of synchronization. */
34 ModelAction *newaction;
35 /* Record whether this is a write, so we can tell the user. */
38 /* Address of data race. */
42 #define MASK16BIT 0xffff
44 void initRaceDetector();
45 void raceCheckWrite(thread_id_t thread, void *location);
46 void raceCheckRead(thread_id_t thread, const void *location);
47 bool checkDataRaces();
48 void assert_race(struct DataRace *race);
49 bool haveUnrealizedRaces();
52 * @brief A record of information for detecting data races
55 modelclock_t *readClock;
59 thread_id_t writeThread;
60 modelclock_t writeClock;
63 #define INITCAPACITY 4
65 #define ISSHORTRECORD(x) ((x)&0x1)
67 #define THREADMASK 0xff
68 #define RDTHREADID(x) (((x)>>1)&THREADMASK)
69 #define READMASK 0x07fffff
70 #define READVECTOR(x) (((x)>>9)&READMASK)
72 #define WRTHREADID(x) (((x)>>32)&THREADMASK)
74 #define WRITEMASK READMASK
75 #define WRITEVECTOR(x) (((x)>>40)&WRITEMASK)
78 * The basic encoding idea is that (void *) either:
79 * -# points to a full record (RaceRecord) or
80 * -# encodes the information in a 64 bit word. Encoding is as
82 * - lowest bit set to 1
83 * - next 8 bits are read thread id
84 * - next 23 bits are read clock vector
85 * - next 8 bits are write thread id
86 * - next 23 bits are write clock vector
88 #define ENCODEOP(rdthread, rdtime, wrthread, wrtime) (0x1ULL | ((rdthread)<<1) | ((rdtime) << 9) | (((uint64_t)wrthread)<<32) | (((uint64_t)wrtime)<<40))
90 #define MAXTHREADID (THREADMASK-1)
91 #define MAXREADVECTOR (READMASK-1)
92 #define MAXWRITEVECTOR (WRITEMASK-1)
94 #endif /* __DATARACE_H__ */