2014-09-21 17:33:12 +00:00
|
|
|
//===-- tsan_mutex.h --------------------------------------------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file is a part of ThreadSanitizer (TSan), a race detector.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef TSAN_MUTEX_H
|
|
|
|
#define TSAN_MUTEX_H
|
|
|
|
|
|
|
|
#include "sanitizer_common/sanitizer_atomic.h"
|
|
|
|
#include "sanitizer_common/sanitizer_mutex.h"
|
|
|
|
#include "tsan_defs.h"
|
|
|
|
|
|
|
|
namespace __tsan {
|
|
|
|
|
|
|
|
enum MutexType {
|
|
|
|
MutexTypeInvalid,
|
|
|
|
MutexTypeTrace,
|
|
|
|
MutexTypeThreads,
|
|
|
|
MutexTypeReport,
|
|
|
|
MutexTypeSyncVar,
|
|
|
|
MutexTypeSyncTab,
|
|
|
|
MutexTypeSlab,
|
|
|
|
MutexTypeAnnotations,
|
|
|
|
MutexTypeAtExit,
|
|
|
|
MutexTypeMBlock,
|
|
|
|
MutexTypeJavaMBlock,
|
2015-08-28 15:33:40 +00:00
|
|
|
MutexTypeDDetector,
|
2017-04-10 11:32:00 +00:00
|
|
|
MutexTypeFired,
|
|
|
|
MutexTypeRacy,
|
2014-09-21 17:33:12 +00:00
|
|
|
|
|
|
|
// This must be the last.
|
|
|
|
MutexTypeCount
|
|
|
|
};
|
|
|
|
|
|
|
|
class Mutex {
|
|
|
|
public:
|
|
|
|
explicit Mutex(MutexType type, StatType stat_type);
|
|
|
|
~Mutex();
|
|
|
|
|
|
|
|
void Lock();
|
|
|
|
void Unlock();
|
|
|
|
|
|
|
|
void ReadLock();
|
|
|
|
void ReadUnlock();
|
|
|
|
|
|
|
|
void CheckLocked();
|
|
|
|
|
|
|
|
private:
|
|
|
|
atomic_uintptr_t state_;
|
2017-04-10 11:32:00 +00:00
|
|
|
#if SANITIZER_DEBUG
|
2014-09-21 17:33:12 +00:00
|
|
|
MutexType type_;
|
|
|
|
#endif
|
|
|
|
#if TSAN_COLLECT_STATS
|
|
|
|
StatType stat_type_;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
Mutex(const Mutex&);
|
|
|
|
void operator = (const Mutex&);
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef GenericScopedLock<Mutex> Lock;
|
|
|
|
typedef GenericScopedReadLock<Mutex> ReadLock;
|
|
|
|
|
2015-08-28 15:33:40 +00:00
|
|
|
class InternalDeadlockDetector {
|
2014-09-21 17:33:12 +00:00
|
|
|
public:
|
2015-08-28 15:33:40 +00:00
|
|
|
InternalDeadlockDetector();
|
2014-09-21 17:33:12 +00:00
|
|
|
void Lock(MutexType t);
|
|
|
|
void Unlock(MutexType t);
|
2015-08-28 15:33:40 +00:00
|
|
|
void CheckNoLocks();
|
2014-09-21 17:33:12 +00:00
|
|
|
private:
|
|
|
|
u64 seq_;
|
|
|
|
u64 locked_[MutexTypeCount];
|
|
|
|
};
|
|
|
|
|
|
|
|
void InitializeMutex();
|
|
|
|
|
2015-08-28 15:33:40 +00:00
|
|
|
// Checks that the current thread does not hold any runtime locks
|
|
|
|
// (e.g. when returning from an interceptor).
|
|
|
|
void CheckNoLocks(ThreadState *thr);
|
|
|
|
|
2014-09-21 17:33:12 +00:00
|
|
|
} // namespace __tsan
|
|
|
|
|
|
|
|
#endif // TSAN_MUTEX_H
|