Commit 55ac9847 authored by Teng Qin's avatar Teng Qin

Fix bug when finding symbols for shared libraries

parent fc4d4646
...@@ -201,9 +201,10 @@ bool ProcSyms::resolve_addr(uint64_t addr, struct bcc_symbol *sym, ...@@ -201,9 +201,10 @@ bool ProcSyms::resolve_addr(uint64_t addr, struct bcc_symbol *sym,
sym->offset = 0x0; sym->offset = 0x0;
const char *original_module = nullptr; const char *original_module = nullptr;
uint64_t offset;
for (Module &mod : modules_) { for (Module &mod : modules_) {
if (mod.contains(addr)) { if (mod.contains(addr, offset)) {
bool res = mod.find_addr(addr, sym); bool res = mod.find_addr(offset, sym);
if (demangle) { if (demangle) {
if (sym->name) if (sym->name)
sym->demangle_name = sym->demangle_name =
...@@ -295,11 +296,12 @@ void ProcSyms::Module::load_sym_table() { ...@@ -295,11 +296,12 @@ void ProcSyms::Module::load_sym_table() {
std::sort(syms_.begin(), syms_.end()); std::sort(syms_.begin(), syms_.end());
} }
bool ProcSyms::Module::contains(uint64_t addr) const { bool ProcSyms::Module::contains(uint64_t addr, uint64_t &offset) const {
for (const auto &range : ranges_) { for (const auto &range : ranges_)
if (addr >= range.start && addr < range.end) if (addr >= range.start && addr < range.end) {
offset = type_ == ModuleType::SO ? addr - range.start : addr;
return true; return true;
} }
return false; return false;
} }
...@@ -315,9 +317,7 @@ bool ProcSyms::Module::find_name(const char *symname, uint64_t *addr) { ...@@ -315,9 +317,7 @@ bool ProcSyms::Module::find_name(const char *symname, uint64_t *addr) {
return false; return false;
} }
bool ProcSyms::Module::find_addr(uint64_t addr, struct bcc_symbol *sym) { bool ProcSyms::Module::find_addr(uint64_t offset, struct bcc_symbol *sym) {
uint64_t offset = type_ == ModuleType::SO ? (addr - start()) : addr;
load_sym_table(); load_sym_table();
sym->module = name_.c_str(); sym->module = name_.c_str();
......
...@@ -136,9 +136,9 @@ class ProcSyms : SymbolCache { ...@@ -136,9 +136,9 @@ class ProcSyms : SymbolCache {
std::vector<Symbol> syms_; std::vector<Symbol> syms_;
void load_sym_table(); void load_sym_table();
bool contains(uint64_t addr) const; bool contains(uint64_t addr, uint64_t &offset) const;
uint64_t start() const { return ranges_.begin()->start; } uint64_t start() const { return ranges_.begin()->start; }
bool find_addr(uint64_t addr, struct bcc_symbol *sym); bool find_addr(uint64_t offset, struct bcc_symbol *sym);
bool find_name(const char *symname, uint64_t *addr); bool find_name(const char *symname, uint64_t *addr);
static int _add_symbol(const char *symname, uint64_t start, uint64_t end, static int _add_symbol(const char *symname, uint64_t start, uint64_t end,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment