reference, declaration → definition definition → references, declarations, derived classes, virtual overrides reference to multiple definitions → definitions unreferenced
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
//===-- InstrumentationRuntime.cpp ------------------------------*- C++ -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===---------------------------------------------------------------------===// #include "lldb/Target/InstrumentationRuntime.h" #include "lldb/Core/Module.h" #include "lldb/Core/ModuleList.h" #include "lldb/Core/PluginManager.h" #include "lldb/Target/Process.h" #include "lldb/Utility/RegularExpression.h" #include "lldb/lldb-private.h" using namespace lldb; using namespace lldb_private; void InstrumentationRuntime::ModulesDidLoad( lldb_private::ModuleList &module_list, lldb_private::Process *process, InstrumentationRuntimeCollection &runtimes) { InstrumentationRuntimeCreateInstance create_callback = nullptr; InstrumentationRuntimeGetType get_type_callback; for (uint32_t idx = 0;; ++idx) { create_callback = PluginManager::GetInstrumentationRuntimeCreateCallbackAtIndex(idx); if (create_callback == nullptr) break; get_type_callback = PluginManager::GetInstrumentationRuntimeGetTypeCallbackAtIndex(idx); InstrumentationRuntimeType type = get_type_callback(); InstrumentationRuntimeCollection::iterator pos; pos = runtimes.find(type); if (pos == runtimes.end()) { runtimes[type] = create_callback(process->shared_from_this()); } } } void InstrumentationRuntime::ModulesDidLoad( lldb_private::ModuleList &module_list) { if (IsActive()) return; if (GetRuntimeModuleSP()) { Activate(); return; } module_list.ForEach([this](const lldb::ModuleSP module_sp) -> bool { const FileSpec &file_spec = module_sp->GetFileSpec(); if (!file_spec) return true; // Keep iterating. const RegularExpression &runtime_regex = GetPatternForRuntimeLibrary(); if (runtime_regex.Execute(file_spec.GetFilename().GetCString()) || module_sp->IsExecutable()) { if (CheckIfRuntimeIsValid(module_sp)) { SetRuntimeModuleSP(module_sp); Activate(); return false; // Stop iterating, we're done. } } return true; }); } lldb::ThreadCollectionSP InstrumentationRuntime::GetBacktracesFromExtendedStopInfo( StructuredData::ObjectSP info) { return ThreadCollectionSP(new ThreadCollection()); }