Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 1 | //===-- AddressResolverName.cpp ---------------------------------*- C++ -*-===// |
| 2 | // |
| 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
| 5 | // This file is distributed under the University of Illinois Open Source |
| 6 | // License. See LICENSE.TXT for details. |
| 7 | // |
| 8 | //===----------------------------------------------------------------------===// |
| 9 | |
| 10 | #include "lldb/Core/AddressResolverName.h" |
| 11 | |
Zachary Turner | 2f3df61 | 2017-04-06 21:28:29 +0000 | [diff] [blame] | 12 | #include "lldb/Core/Address.h" // for Address, operator== |
| 13 | #include "lldb/Core/AddressRange.h" // for AddressRange |
Greg Clayton | 1f74607 | 2012-08-29 21:13:06 +0000 | [diff] [blame] | 14 | #include "lldb/Core/Module.h" |
Greg Clayton | 1f74607 | 2012-08-29 21:13:06 +0000 | [diff] [blame] | 15 | #include "lldb/Symbol/Function.h" |
Greg Clayton | 1f74607 | 2012-08-29 21:13:06 +0000 | [diff] [blame] | 16 | #include "lldb/Symbol/Symbol.h" |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 17 | #include "lldb/Symbol/SymbolContext.h" |
Zachary Turner | 6f9e690 | 2017-03-03 20:56:28 +0000 | [diff] [blame] | 18 | #include "lldb/Utility/Log.h" |
Zachary Turner | 2f3df61 | 2017-04-06 21:28:29 +0000 | [diff] [blame] | 19 | #include "lldb/Utility/Logging.h" // for GetLogIfAllCategoriesSet, LIB... |
| 20 | #include "lldb/Utility/Stream.h" // for Stream |
| 21 | #include "lldb/lldb-enumerations.h" // for SymbolType::eSymbolTypeCode |
| 22 | #include "lldb/lldb-forward.h" // for ModuleSP |
| 23 | #include "lldb/lldb-types.h" // for addr_t |
| 24 | #include "llvm/ADT/StringRef.h" // for StringRef |
| 25 | |
| 26 | #include <memory> // for shared_ptr |
| 27 | #include <string> // for string |
| 28 | #include <vector> // for vector |
| 29 | |
| 30 | #include <stdint.h> // for uint32_t |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 31 | |
| 32 | using namespace lldb; |
| 33 | using namespace lldb_private; |
| 34 | |
Eugene Zelenko | 896ddd0 | 2016-03-02 01:09:03 +0000 | [diff] [blame] | 35 | AddressResolverName::AddressResolverName(const char *func_name, |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 36 | AddressResolver::MatchType type) |
| 37 | : AddressResolver(), m_func_name(func_name), m_class_name(nullptr), |
| 38 | m_regex(), m_match_type(type) { |
| 39 | if (m_match_type == AddressResolver::Regexp) { |
Zachary Turner | 95eae42 | 2016-09-21 16:01:28 +0000 | [diff] [blame] | 40 | if (!m_regex.Compile(m_func_name.GetStringRef())) { |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 41 | Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_BREAKPOINTS)); |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 42 | |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 43 | if (log) |
| 44 | log->Warning("function name regexp: \"%s\" did not compile.", |
| 45 | m_func_name.AsCString()); |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 46 | } |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 47 | } |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 48 | } |
| 49 | |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 50 | AddressResolverName::AddressResolverName(RegularExpression &func_regex) |
| 51 | : AddressResolver(), m_func_name(nullptr), m_class_name(nullptr), |
| 52 | m_regex(func_regex), m_match_type(AddressResolver::Regexp) {} |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 53 | |
Eugene Zelenko | 896ddd0 | 2016-03-02 01:09:03 +0000 | [diff] [blame] | 54 | AddressResolverName::AddressResolverName(const char *class_name, |
| 55 | const char *method, |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 56 | AddressResolver::MatchType type) |
| 57 | : AddressResolver(), m_func_name(method), m_class_name(class_name), |
| 58 | m_regex(), m_match_type(type) {} |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 59 | |
Eugene Zelenko | 896ddd0 | 2016-03-02 01:09:03 +0000 | [diff] [blame] | 60 | AddressResolverName::~AddressResolverName() = default; |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 61 | |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 62 | // FIXME: Right now we look at the module level, and call the module's |
| 63 | // "FindFunctions". |
| 64 | // Greg says he will add function tables, maybe at the CompileUnit level to |
Adrian Prantl | 0509724 | 2018-04-30 16:49:04 +0000 | [diff] [blame] | 65 | // accelerate function lookup. At that point, we should switch the depth to |
| 66 | // CompileUnit, and look in these tables. |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 67 | |
| 68 | Searcher::CallbackReturn |
Eugene Zelenko | 896ddd0 | 2016-03-02 01:09:03 +0000 | [diff] [blame] | 69 | AddressResolverName::SearchCallback(SearchFilter &filter, |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 70 | SymbolContext &context, Address *addr, |
| 71 | bool containing) { |
| 72 | SymbolContextList func_list; |
| 73 | SymbolContextList sym_list; |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 74 | |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 75 | bool skip_prologue = true; |
| 76 | uint32_t i; |
| 77 | SymbolContext sc; |
| 78 | Address func_addr; |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 79 | |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 80 | Log *log(lldb_private::GetLogIfAllCategoriesSet(LIBLLDB_LOG_BREAKPOINTS)); |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 81 | |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 82 | if (m_class_name) { |
| 83 | if (log) |
| 84 | log->Warning("Class/method function specification not supported yet.\n"); |
| 85 | return Searcher::eCallbackReturnStop; |
| 86 | } |
| 87 | |
| 88 | const bool include_symbols = false; |
| 89 | const bool include_inlines = true; |
| 90 | const bool append = false; |
| 91 | switch (m_match_type) { |
| 92 | case AddressResolver::Exact: |
| 93 | if (context.module_sp) { |
| 94 | context.module_sp->FindSymbolsWithNameAndType(m_func_name, |
| 95 | eSymbolTypeCode, sym_list); |
| 96 | context.module_sp->FindFunctions(m_func_name, nullptr, |
| 97 | eFunctionNameTypeAuto, include_symbols, |
| 98 | include_inlines, append, func_list); |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 99 | } |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 100 | break; |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 101 | |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 102 | case AddressResolver::Regexp: |
| 103 | if (context.module_sp) { |
| 104 | context.module_sp->FindSymbolsMatchingRegExAndType( |
| 105 | m_regex, eSymbolTypeCode, sym_list); |
| 106 | context.module_sp->FindFunctions(m_regex, include_symbols, |
| 107 | include_inlines, append, func_list); |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 108 | } |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 109 | break; |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 110 | |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 111 | case AddressResolver::Glob: |
| 112 | if (log) |
| 113 | log->Warning("glob is not supported yet."); |
| 114 | break; |
| 115 | } |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 116 | |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 117 | // Remove any duplicates between the function list and the symbol list |
| 118 | if (func_list.GetSize()) { |
| 119 | for (i = 0; i < func_list.GetSize(); i++) { |
| 120 | if (!func_list.GetContextAtIndex(i, sc)) |
| 121 | continue; |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 122 | |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 123 | if (sc.function == nullptr) |
| 124 | continue; |
| 125 | uint32_t j = 0; |
| 126 | while (j < sym_list.GetSize()) { |
| 127 | SymbolContext symbol_sc; |
| 128 | if (sym_list.GetContextAtIndex(j, symbol_sc)) { |
| 129 | if (symbol_sc.symbol && symbol_sc.symbol->ValueIsAddress()) { |
| 130 | if (sc.function->GetAddressRange().GetBaseAddress() == |
| 131 | symbol_sc.symbol->GetAddressRef()) { |
| 132 | sym_list.RemoveContextAtIndex(j); |
| 133 | continue; // Don't increment j |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 134 | } |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 135 | } |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 136 | } |
| 137 | |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 138 | j++; |
| 139 | } |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 140 | } |
| 141 | |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 142 | for (i = 0; i < func_list.GetSize(); i++) { |
| 143 | if (func_list.GetContextAtIndex(i, sc)) { |
| 144 | if (sc.function) { |
| 145 | func_addr = sc.function->GetAddressRange().GetBaseAddress(); |
| 146 | addr_t byte_size = sc.function->GetAddressRange().GetByteSize(); |
| 147 | if (skip_prologue) { |
| 148 | const uint32_t prologue_byte_size = |
| 149 | sc.function->GetPrologueByteSize(); |
| 150 | if (prologue_byte_size) { |
| 151 | func_addr.SetOffset(func_addr.GetOffset() + prologue_byte_size); |
| 152 | byte_size -= prologue_byte_size; |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 153 | } |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 154 | } |
| 155 | |
| 156 | if (filter.AddressPasses(func_addr)) { |
| 157 | AddressRange new_range(func_addr, byte_size); |
| 158 | m_address_ranges.push_back(new_range); |
| 159 | } |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 160 | } |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 161 | } |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 162 | } |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 163 | } |
| 164 | |
| 165 | for (i = 0; i < sym_list.GetSize(); i++) { |
| 166 | if (sym_list.GetContextAtIndex(i, sc)) { |
| 167 | if (sc.symbol && sc.symbol->ValueIsAddress()) { |
| 168 | func_addr = sc.symbol->GetAddressRef(); |
| 169 | addr_t byte_size = sc.symbol->GetByteSize(); |
| 170 | |
| 171 | if (skip_prologue) { |
| 172 | const uint32_t prologue_byte_size = sc.symbol->GetPrologueByteSize(); |
| 173 | if (prologue_byte_size) { |
| 174 | func_addr.SetOffset(func_addr.GetOffset() + prologue_byte_size); |
| 175 | byte_size -= prologue_byte_size; |
| 176 | } |
| 177 | } |
| 178 | |
| 179 | if (filter.AddressPasses(func_addr)) { |
| 180 | AddressRange new_range(func_addr, byte_size); |
| 181 | m_address_ranges.push_back(new_range); |
| 182 | } |
| 183 | } |
| 184 | } |
| 185 | } |
| 186 | return Searcher::eCallbackReturnContinue; |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 187 | } |
| 188 | |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 189 | Searcher::Depth AddressResolverName::GetDepth() { |
| 190 | return Searcher::eDepthModule; |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 191 | } |
| 192 | |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 193 | void AddressResolverName::GetDescription(Stream *s) { |
| 194 | s->PutCString("Address by function name: "); |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 195 | |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 196 | if (m_match_type == AddressResolver::Regexp) |
Zachary Turner | 95eae42 | 2016-09-21 16:01:28 +0000 | [diff] [blame] | 197 | s->Printf("'%s' (regular expression)", m_regex.GetText().str().c_str()); |
Kate Stone | b9c1b51 | 2016-09-06 20:57:50 +0000 | [diff] [blame] | 198 | else |
| 199 | s->Printf("'%s'", m_func_name.AsCString()); |
Chris Lattner | 30fdc8d | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 200 | } |