// Copyright 2015 The Crashpad Authors // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #ifndef CRASHPAD_SNAPSHOT_MINIDUMP_PROCESS_SNAPSHOT_MINIDUMP_H_ #define CRASHPAD_SNAPSHOT_MINIDUMP_PROCESS_SNAPSHOT_MINIDUMP_H_ #include <windows.h> #include <dbghelp.h> #include <stdint.h> #include <sys/time.h> #include <map> #include <memory> #include <string> #include <vector> #include "minidump/minidump_extensions.h" #include "snapshot/exception_snapshot.h" #include "snapshot/memory_snapshot.h" #include "snapshot/minidump/exception_snapshot_minidump.h" #include "snapshot/minidump/minidump_stream.h" #include "snapshot/minidump/module_snapshot_minidump.h" #include "snapshot/minidump/system_snapshot_minidump.h" #include "snapshot/minidump/thread_snapshot_minidump.h" #include "snapshot/module_snapshot.h" #include "snapshot/process_snapshot.h" #include "snapshot/system_snapshot.h" #include "snapshot/thread_snapshot.h" #include "snapshot/unloaded_module_snapshot.h" #include "util/file/file_reader.h" #include "util/misc/initialization_state_dcheck.h" #include "util/misc/uuid.h" #include "util/process/process_id.h" namespace crashpad { namespace internal { class MemoryMapRegionSnapshotMinidump; } // namespace internal //! \brief A ProcessSnapshot based on a minidump file. class ProcessSnapshotMinidump final : public ProcessSnapshot { public: ProcessSnapshotMinidump(); ProcessSnapshotMinidump(const ProcessSnapshotMinidump&) = delete; ProcessSnapshotMinidump& operator=(const ProcessSnapshotMinidump&) = delete; ~ProcessSnapshotMinidump() override; //! \brief Initializes the object. //! //! \param[in] file_reader A file reader corresponding to a minidump file. //! The file reader must support seeking. //! //! \return `true` if the snapshot could be created, `false` otherwise with //! an appropriate message logged. bool Initialize(FileReaderInterface* file_reader); // ProcessSnapshot: crashpad::ProcessID ProcessID() const override; crashpad::ProcessID ParentProcessID() const override; void SnapshotTime(timeval* snapshot_time) const override; void ProcessStartTime(timeval* start_time) const override; void ProcessCPUTimes(timeval* user_time, timeval* system_time) const override; void ReportID(UUID* report_id) const override; void ClientID(UUID* client_id) const override; const std::map<std::string, std::string>& AnnotationsSimpleMap() const override; const SystemSnapshot* System() const override; std::vector<const ThreadSnapshot*> Threads() const override; std::vector<const ModuleSnapshot*> Modules() const override; std::vector<UnloadedModuleSnapshot> UnloadedModules() const override; const ExceptionSnapshot* Exception() const override; std::vector<const MemoryMapRegionSnapshot*> MemoryMap() const override; std::vector<HandleSnapshot> Handles() const override; std::vector<const MemorySnapshot*> ExtraMemory() const override; const ProcessMemory* Memory() const override; //! \brief Returns a list of custom minidump streams. This routine is the //! equivalent of ModuleSnapshot::CustomMinidumpStreams(), except that in //! a minidump it is impossible to associate a custom stream to a specific //! module. //! //! \return The caller does not take ownership of the returned objects, they //! are scoped to the lifetime of the ProcessSnapshotMinidump object that //! they were obtained from. std::vector<const MinidumpStream*> CustomMinidumpStreams() const; private: // Initializes data carried in a MinidumpCrashpadInfo stream on behalf of // Initialize(). bool InitializeCrashpadInfo(); // Initializes data carried in a MINIDUMP_MODULE_LIST stream on behalf of // Initialize(). bool InitializeModules(); // Initializes data carried in a MINIDUMP_THREAD_LIST stream on behalf of // Initialize(). bool InitializeThreads(); // Initializes data carried in a MINIDUMP_THREAD_NAME_LIST stream on behalf of // Initialize(). bool InitializeThreadNames(); // Initializes data carried in a MINIDUMP_MEMORY_INFO_LIST stream on behalf of // Initialize(). bool InitializeMemoryInfo(); // Initializes data carried in a MINIDUMP_MEMORY_LIST stream on behalf of // Initialize(). bool InitializeExtraMemory(); // Initializes data carried in a MINIDUMP_SYSTEM_INFO stream on behalf of // Initialize(). bool InitializeSystemSnapshot(); // Initializes data carried in a MinidumpModuleCrashpadInfoList structure on // behalf of InitializeModules(). This makes use of MinidumpCrashpadInfo as // well, so it must be called after InitializeCrashpadInfo(). bool InitializeModulesCrashpadInfo( std::map<uint32_t, MINIDUMP_LOCATION_DESCRIPTOR>* module_crashpad_info_links); // Initializes data carried in a MINIDUMP_MISC_INFO structure on behalf of // Initialize(). bool InitializeMiscInfo(); // Initializes custom minidump streams. bool InitializeCustomMinidumpStreams(); // Initializes data carried in a MINIDUMP_EXCEPTION_STREAM stream on behalf of // Initialize(). bool InitializeExceptionSnapshot(); MINIDUMP_HEADER header_; std::vector<MINIDUMP_DIRECTORY> stream_directory_; std::map<MinidumpStreamType, const MINIDUMP_LOCATION_DESCRIPTOR*> stream_map_; std::vector<std::unique_ptr<internal::ModuleSnapshotMinidump>> modules_; std::vector<std::unique_ptr<internal::ThreadSnapshotMinidump>> threads_; std::map<uint32_t, std::string> thread_names_; std::vector<UnloadedModuleSnapshot> unloaded_modules_; std::vector<std::unique_ptr<internal::MemoryMapRegionSnapshotMinidump>> mem_regions_; std::vector<const MemoryMapRegionSnapshot*> mem_regions_exposed_; std::vector<std::unique_ptr<internal::MemorySnapshotMinidump>> extra_memory_; std::vector<std::unique_ptr<MinidumpStream>> custom_streams_; MinidumpCrashpadInfo crashpad_info_; internal::SystemSnapshotMinidump system_snapshot_; internal::ExceptionSnapshotMinidump exception_snapshot_; CPUArchitecture arch_; std::map<std::string, std::string> annotations_simple_map_; std::string full_version_; FileReaderInterface* file_reader_; // weak crashpad::ProcessID process_id_; uint32_t create_time_; uint32_t user_time_; uint32_t kernel_time_; InitializationStateDcheck initialized_; }; } // namespace crashpad #endif // CRASHPAD_SNAPSHOT_MINIDUMP_PROCESS_SNAPSHOT_MINIDUMP_H_