//===-- ProcessWinMiniDump.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_ProcessWinMiniDump_h_ #define liblldb_ProcessWinMiniDump_h_ #include #include #include "lldb/Core/ConstString.h" #include "lldb/Core/Error.h" #include "lldb/Target/Process.h" #include "Plugins/Process/Windows/Common/ProcessWindows.h" struct ThreadData; class ProcessWinMiniDump : public lldb_private::ProcessWindows { public: static lldb::ProcessSP CreateInstance (lldb::TargetSP target_sp, lldb_private::Listener &listener, const lldb_private::FileSpec *crash_file_path); static void Initialize(); static void Terminate(); static lldb_private::ConstString GetPluginNameStatic(); static const char * GetPluginDescriptionStatic(); ProcessWinMiniDump(lldb::TargetSP target_sp, lldb_private::Listener &listener, const lldb_private::FileSpec &core_file); virtual ~ProcessWinMiniDump(); bool CanDebug(lldb::TargetSP target_sp, bool plugin_specified_by_name) override; lldb_private::Error DoLoadCore() override; lldb_private::DynamicLoader * GetDynamicLoader() override; lldb_private::ConstString GetPluginName() override; uint32_t GetPluginVersion() override; lldb_private::Error DoDestroy() override; void RefreshStateAfterStop() override; bool IsAlive() override; bool WarnBeforeDetach () const override; size_t ReadMemory(lldb::addr_t addr, void *buf, size_t size, lldb_private::Error &error) override; size_t DoReadMemory(lldb::addr_t addr, void *buf, size_t size, lldb_private::Error &error) override; lldb_private::ArchSpec GetArchitecture(); protected: void Clear(); bool UpdateThreadList(lldb_private::ThreadList &old_thread_list, lldb_private::ThreadList &new_thread_list) override; private: // Describes a range of memory captured in the mini dump. struct Range { lldb::addr_t start; // virtual address of the beginning of the range size_t size; // size of the range in bytes const uint8_t *ptr; // absolute pointer to the first byte of the range }; // If the mini dump has a memory range that contains the desired address, it // returns true with the details of the range in *range_out. Otherwise, it // returns false. bool FindMemoryRange(lldb::addr_t addr, Range *range_out) const; lldb_private::Error MapMiniDumpIntoMemory(const char *file); lldb_private::ArchSpec DetermineArchitecture(); void ReadExceptionRecord(); void ReadMiscInfo(); void ReadModuleList(); // A thin wrapper around WinAPI's MiniDumpReadDumpStream to avoid redundant // checks. If there's a failure (e.g., if the requested stream doesn't exist), // the function returns nullptr and sets *size_out to 0. void * FindDumpStream(unsigned stream_number, size_t *size_out) const; // Isolate the data to keep Windows-specific types out of this header. Can't // use the typical pimpl idiom because the implementation of this class also // needs access to public and protected members of the base class. class Data; std::unique_ptr m_data_up; }; #endif // liblldb_ProcessWinMiniDump_h_