Commit 7d8c29ce authored by Sasha Goldshtein's avatar Sasha Goldshtein

cc: Correctly treat PIE files as shared objects for symbols

When resolving symbols, ProcSyms would treat position-independent
executables (PIE files) incorrectly, resulting in symbol resolution
failures. Specifically, PIE files are treated like shared objects
for ASLR, which means all symbol addresses in the file need to be
taken relative to the executable load address at runtime, the same
as with dynamic library shared objects.

The fix is in the `is_so()` method on `ProcSyms::Module`, which
now uses the correct `bcc_elf_is_shared` helper for testing if a
file is a shared object rather than just looking at the extension
".so", which is very brittle -- and wrong.
parent 1e34f4e1
...@@ -140,6 +140,11 @@ bool ProcSyms::resolve_name(const char *module, const char *name, ...@@ -140,6 +140,11 @@ bool ProcSyms::resolve_name(const char *module, const char *name,
return false; return false;
} }
ProcSyms::Module::Module(const char *name, uint64_t start, uint64_t end)
: name_(name), start_(start), end_(end) {
is_so_ = bcc_elf_is_shared_obj(name) == 1;
}
int ProcSyms::Module::_add_symbol(const char *symname, uint64_t start, int ProcSyms::Module::_add_symbol(const char *symname, uint64_t start,
uint64_t end, int flags, void *p) { uint64_t end, int flags, void *p) {
Module *m = static_cast<Module *>(p); Module *m = static_cast<Module *>(p);
...@@ -148,10 +153,6 @@ int ProcSyms::Module::_add_symbol(const char *symname, uint64_t start, ...@@ -148,10 +153,6 @@ int ProcSyms::Module::_add_symbol(const char *symname, uint64_t start,
return 0; return 0;
} }
bool ProcSyms::Module::is_so() const {
return strstr(name_.c_str(), ".so") != nullptr;
}
bool ProcSyms::Module::is_perf_map() const { bool ProcSyms::Module::is_perf_map() const {
return strstr(name_.c_str(), ".map") != nullptr; return strstr(name_.c_str(), ".map") != nullptr;
} }
......
...@@ -79,18 +79,18 @@ class ProcSyms : SymbolCache { ...@@ -79,18 +79,18 @@ class ProcSyms : SymbolCache {
}; };
struct Module { struct Module {
Module(const char *name, uint64_t start, uint64_t end) Module(const char *name, uint64_t start, uint64_t end);
: name_(name), start_(start), end_(end) {}
std::string name_; std::string name_;
uint64_t start_; uint64_t start_;
uint64_t end_; uint64_t end_;
bool is_so_;
std::unordered_set<std::string> symnames_; std::unordered_set<std::string> symnames_;
std::vector<Symbol> syms_; std::vector<Symbol> syms_;
void load_sym_table(); void load_sym_table();
bool find_addr(uint64_t addr, struct bcc_symbol *sym); bool find_addr(uint64_t addr, struct bcc_symbol *sym);
bool find_name(const char *symname, uint64_t *addr); bool find_name(const char *symname, uint64_t *addr);
bool is_so() const; bool is_so() const { return is_so_; }
bool is_perf_map() const; bool is_perf_map() const;
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