//===-- 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: 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_