2012-11-22 23:03:11 +01:00
|
|
|
//===-- tsan_mutex.h --------------------------------------------*- C++ -*-===//
|
|
|
|
//
|
2019-08-14 10:47:11 +02:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2012-11-22 23:03:11 +01:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// 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,
|
2013-01-10 13:44:08 +01:00
|
|
|
MutexTypeMBlock,
|
|
|
|
MutexTypeJavaMBlock,
|
2014-05-22 09:09:21 +02:00
|
|
|
MutexTypeDDetector,
|
2015-10-21 09:32:45 +02:00
|
|
|
MutexTypeFired,
|
|
|
|
MutexTypeRacy,
|
2016-11-08 23:04:09 +01:00
|
|
|
MutexTypeGlobalProc,
|
2012-11-22 23:03:11 +01: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_;
|
2015-10-21 09:32:45 +02:00
|
|
|
#if SANITIZER_DEBUG
|
2012-11-22 23:03:11 +01: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;
|
|
|
|
|
2014-05-22 09:09:21 +02:00
|
|
|
class InternalDeadlockDetector {
|
2012-11-22 23:03:11 +01:00
|
|
|
public:
|
2014-05-22 09:09:21 +02:00
|
|
|
InternalDeadlockDetector();
|
2012-11-22 23:03:11 +01:00
|
|
|
void Lock(MutexType t);
|
|
|
|
void Unlock(MutexType t);
|
2014-09-23 19:59:53 +02:00
|
|
|
void CheckNoLocks();
|
2012-11-22 23:03:11 +01:00
|
|
|
private:
|
|
|
|
u64 seq_;
|
|
|
|
u64 locked_[MutexTypeCount];
|
|
|
|
};
|
|
|
|
|
|
|
|
void InitializeMutex();
|
|
|
|
|
2014-09-23 19:59:53 +02:00
|
|
|
// Checks that the current thread does not hold any runtime locks
|
|
|
|
// (e.g. when returning from an interceptor).
|
|
|
|
void CheckNoLocks(ThreadState *thr);
|
|
|
|
|
2012-11-22 23:03:11 +01:00
|
|
|
} // namespace __tsan
|
|
|
|
|
|
|
|
#endif // TSAN_MUTEX_H
|