1018981977
libsanitizer/ * All source files: Merge from upstream 285547. * configure.tgt (SANITIZER_COMMON_TARGET_DEPENDENT_OBJECTS): New variable. * configure.ac (SANITIZER_COMMON_TARGET_DEPENDENT_OBJECTS): Handle it. * asan/Makefile.am (asan_files): Add new files. * asan/Makefile.in: Regenerate. * ubsan/Makefile.in: Likewise. * lsan/Makefile.in: Likewise. * tsan/Makefile.am (tsan_files): Add new files. * tsan/Makefile.in: Regenerate. * sanitizer_common/Makefile.am (sanitizer_common_files): Add new files. (EXTRA_libsanitizer_common_la_SOURCES): Define. (libsanitizer_common_la_LIBADD): Likewise. (libsanitizer_common_la_DEPENDENCIES): Likewise. * sanitizer_common/Makefile.in: Regenerate. * interception/Makefile.in: Likewise. * libbacktace/Makefile.in: Likewise. * Makefile.in: Likewise. * configure: Likewise. * merge.sh: Handle builtins/assembly.h merging. * builtins/assembly.h: New file. * asan/libtool-version: Bump the libasan SONAME. From-SVN: r241977
92 lines
2.6 KiB
C++
92 lines
2.6 KiB
C++
//===-- sanitizer_deadlock_detector_interface.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 Sanitizer runtime.
|
|
// Abstract deadlock detector interface.
|
|
// FIXME: this is work in progress, nothing really works yet.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef SANITIZER_DEADLOCK_DETECTOR_INTERFACE_H
|
|
#define SANITIZER_DEADLOCK_DETECTOR_INTERFACE_H
|
|
|
|
#ifndef SANITIZER_DEADLOCK_DETECTOR_VERSION
|
|
# define SANITIZER_DEADLOCK_DETECTOR_VERSION 1
|
|
#endif
|
|
|
|
#include "sanitizer_internal_defs.h"
|
|
#include "sanitizer_atomic.h"
|
|
|
|
namespace __sanitizer {
|
|
|
|
// dd - deadlock detector.
|
|
// lt - logical (user) thread.
|
|
// pt - physical (OS) thread.
|
|
|
|
struct DDPhysicalThread;
|
|
struct DDLogicalThread;
|
|
|
|
struct DDMutex {
|
|
#if SANITIZER_DEADLOCK_DETECTOR_VERSION == 1
|
|
uptr id;
|
|
u32 stk; // creation stack
|
|
#elif SANITIZER_DEADLOCK_DETECTOR_VERSION == 2
|
|
u32 id;
|
|
u32 recursion;
|
|
atomic_uintptr_t owner;
|
|
#else
|
|
# error "BAD SANITIZER_DEADLOCK_DETECTOR_VERSION"
|
|
#endif
|
|
u64 ctx;
|
|
};
|
|
|
|
struct DDFlags {
|
|
bool second_deadlock_stack;
|
|
};
|
|
|
|
struct DDReport {
|
|
enum { kMaxLoopSize = 20 };
|
|
int n; // number of entries in loop
|
|
struct {
|
|
u64 thr_ctx; // user thread context
|
|
u64 mtx_ctx0; // user mutex context, start of the edge
|
|
u64 mtx_ctx1; // user mutex context, end of the edge
|
|
u32 stk[2]; // stack ids for the edge
|
|
} loop[kMaxLoopSize];
|
|
};
|
|
|
|
struct DDCallback {
|
|
DDPhysicalThread *pt;
|
|
DDLogicalThread *lt;
|
|
|
|
virtual u32 Unwind() { return 0; }
|
|
virtual int UniqueTid() { return 0; }
|
|
};
|
|
|
|
struct DDetector {
|
|
static DDetector *Create(const DDFlags *flags);
|
|
|
|
virtual DDPhysicalThread* CreatePhysicalThread() { return nullptr; }
|
|
virtual void DestroyPhysicalThread(DDPhysicalThread *pt) {}
|
|
|
|
virtual DDLogicalThread* CreateLogicalThread(u64 ctx) { return nullptr; }
|
|
virtual void DestroyLogicalThread(DDLogicalThread *lt) {}
|
|
|
|
virtual void MutexInit(DDCallback *cb, DDMutex *m) {}
|
|
virtual void MutexBeforeLock(DDCallback *cb, DDMutex *m, bool wlock) {}
|
|
virtual void MutexAfterLock(DDCallback *cb, DDMutex *m, bool wlock,
|
|
bool trylock) {}
|
|
virtual void MutexBeforeUnlock(DDCallback *cb, DDMutex *m, bool wlock) {}
|
|
virtual void MutexDestroy(DDCallback *cb, DDMutex *m) {}
|
|
|
|
virtual DDReport *GetReport(DDCallback *cb) { return nullptr; }
|
|
};
|
|
|
|
} // namespace __sanitizer
|
|
|
|
#endif // SANITIZER_DEADLOCK_DETECTOR_INTERFACE_H
|