dff0c46c97
upcoming 3.1 release (expected in a few weeks). Preliminary release notes can be found at: <http://llvm.org/docs/ReleaseNotes.html> MFC after: 2 weeks
68 lines
2.1 KiB
C++
68 lines
2.1 KiB
C++
//===-- Valgrind.cpp - Implement Valgrind communication ---------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Defines Valgrind communication methods, if HAVE_VALGRIND_VALGRIND_H is
|
|
// defined. If we have valgrind.h but valgrind isn't running, its macros are
|
|
// no-ops.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/Support/Valgrind.h"
|
|
#include "llvm/Config/config.h"
|
|
|
|
#if HAVE_VALGRIND_VALGRIND_H
|
|
#include <valgrind/valgrind.h>
|
|
|
|
static bool InitNotUnderValgrind() {
|
|
return !RUNNING_ON_VALGRIND;
|
|
}
|
|
|
|
// This bool is negated from what we'd expect because code may run before it
|
|
// gets initialized. If that happens, it will appear to be 0 (false), and we
|
|
// want that to cause the rest of the code in this file to run the
|
|
// Valgrind-provided macros.
|
|
static const bool NotUnderValgrind = InitNotUnderValgrind();
|
|
|
|
bool llvm::sys::RunningOnValgrind() {
|
|
if (NotUnderValgrind)
|
|
return false;
|
|
return RUNNING_ON_VALGRIND;
|
|
}
|
|
|
|
void llvm::sys::ValgrindDiscardTranslations(const void *Addr, size_t Len) {
|
|
if (NotUnderValgrind)
|
|
return;
|
|
|
|
VALGRIND_DISCARD_TRANSLATIONS(Addr, Len);
|
|
}
|
|
|
|
#else // !HAVE_VALGRIND_VALGRIND_H
|
|
|
|
bool llvm::sys::RunningOnValgrind() {
|
|
return false;
|
|
}
|
|
|
|
void llvm::sys::ValgrindDiscardTranslations(const void *Addr, size_t Len) {
|
|
}
|
|
|
|
#endif // !HAVE_VALGRIND_VALGRIND_H
|
|
|
|
#if LLVM_ENABLE_THREADS != 0 && !defined(NDEBUG)
|
|
// These functions require no implementation, tsan just looks at the arguments
|
|
// they're called with.
|
|
extern "C" {
|
|
void AnnotateHappensBefore(const char *file, int line,
|
|
const volatile void *cv) {}
|
|
void AnnotateHappensAfter(const char *file, int line,
|
|
const volatile void *cv) {}
|
|
void AnnotateIgnoreWritesBegin(const char *file, int line) {}
|
|
void AnnotateIgnoreWritesEnd(const char *file, int line) {}
|
|
}
|
|
#endif
|