forked from OSchip/llvm-project
103 lines
3.4 KiB
C++
103 lines
3.4 KiB
C++
//===-- ProcessPOSIXLog.h -----------------------------------------*- C++
|
|
//-*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef liblldb_ProcessPOSIXLog_h_
|
|
#define liblldb_ProcessPOSIXLog_h_
|
|
|
|
// C Includes
|
|
// C++ Includes
|
|
// Other libraries and framework includes
|
|
|
|
// Project includes
|
|
#include "lldb/Core/Log.h"
|
|
|
|
#define POSIX_LOG_VERBOSE (1u << 0)
|
|
#define POSIX_LOG_PROCESS (1u << 1)
|
|
#define POSIX_LOG_THREAD (1u << 2)
|
|
#define POSIX_LOG_PACKETS (1u << 3)
|
|
#define POSIX_LOG_MEMORY (1u << 4) // Log memory reads/writes calls
|
|
#define POSIX_LOG_MEMORY_DATA_SHORT \
|
|
(1u << 5) // Log short memory reads/writes bytes
|
|
#define POSIX_LOG_MEMORY_DATA_LONG \
|
|
(1u << 6) // Log all memory reads/writes bytes
|
|
#define POSIX_LOG_BREAKPOINTS (1u << 7)
|
|
#define POSIX_LOG_WATCHPOINTS (1u << 8)
|
|
#define POSIX_LOG_STEP (1u << 9)
|
|
#define POSIX_LOG_COMM (1u << 10)
|
|
#define POSIX_LOG_ASYNC (1u << 11)
|
|
#define POSIX_LOG_PTRACE (1u << 12)
|
|
#define POSIX_LOG_REGISTERS (1u << 13)
|
|
#define POSIX_LOG_ALL (UINT32_MAX)
|
|
#define POSIX_LOG_DEFAULT POSIX_LOG_PACKETS
|
|
|
|
// The size which determines "short memory reads/writes".
|
|
#define POSIX_LOG_MEMORY_SHORT_BYTES (4 * sizeof(ptrdiff_t))
|
|
|
|
class ProcessPOSIXLog {
|
|
static int m_nestinglevel;
|
|
static const char *m_pluginname;
|
|
|
|
public:
|
|
// ---------------------------------------------------------------------
|
|
// Public Static Methods
|
|
// ---------------------------------------------------------------------
|
|
static void Initialize(lldb_private::ConstString name);
|
|
|
|
static void RegisterPluginName(const char *pluginName) {
|
|
m_pluginname = pluginName;
|
|
}
|
|
|
|
static void RegisterPluginName(lldb_private::ConstString pluginName) {
|
|
m_pluginname = pluginName.GetCString();
|
|
}
|
|
|
|
static lldb_private::Log *GetLogIfAllCategoriesSet(uint32_t mask = 0);
|
|
|
|
static void DisableLog(const char **args,
|
|
lldb_private::Stream *feedback_strm);
|
|
|
|
static lldb_private::Log *EnableLog(lldb::StreamSP &log_stream_sp,
|
|
uint32_t log_options, const char **args,
|
|
lldb_private::Stream *feedback_strm);
|
|
|
|
static void ListLogCategories(lldb_private::Stream *strm);
|
|
|
|
static void LogIf(uint32_t mask, const char *format, ...);
|
|
|
|
// The following functions can be used to enable the client to limit
|
|
// logging to only the top level function calls. This is useful for
|
|
// recursive functions. FIXME: not thread safe!
|
|
// Example:
|
|
// void NestingFunc() {
|
|
// LogSP log
|
|
// (ProcessPOSIXLog::GetLogIfAllCategoriesSet(POSIX_LOG_ALL));
|
|
// if (log)
|
|
// {
|
|
// ProcessPOSIXLog::IncNestLevel();
|
|
// if (ProcessPOSIXLog::AtTopNestLevel())
|
|
// log->Print(msg);
|
|
// }
|
|
// NestingFunc();
|
|
// if (log)
|
|
// ProcessPOSIXLog::DecNestLevel();
|
|
// }
|
|
|
|
static bool AtTopNestLevel() { return m_nestinglevel == 1; }
|
|
|
|
static void IncNestLevel() { ++m_nestinglevel; }
|
|
|
|
static void DecNestLevel() {
|
|
--m_nestinglevel;
|
|
assert(m_nestinglevel >= 0);
|
|
}
|
|
};
|
|
|
|
#endif // liblldb_ProcessPOSIXLog_h_
|