diff --git a/server/TracyWorker.cpp b/server/TracyWorker.cpp index a1cc0b62..9ba20a55 100644 --- a/server/TracyWorker.cpp +++ b/server/TracyWorker.cpp @@ -2279,6 +2279,14 @@ const char* Worker::GetSymbolCode( uint64_t sym, uint32_t& len ) const return it->second.data; } +uint64_t Worker::GetSymbolForAddress( uint64_t address, uint32_t& offset ) const +{ + auto it = std::lower_bound( m_data.symbolLoc.begin(), m_data.symbolLoc.end(), address, [] ( const auto& l, const auto& r ) { return l.addr + l.len < r; } ); + if( it == m_data.symbolLoc.end() || address < it->addr ) return 0; + offset = address - it->addr; + return it->addr; +} + int64_t Worker::GetZoneEnd( const ZoneEvent& ev ) { auto ptr = &ev; diff --git a/server/TracyWorker.hpp b/server/TracyWorker.hpp index a353d7b0..bf402d52 100644 --- a/server/TracyWorker.hpp +++ b/server/TracyWorker.hpp @@ -432,6 +432,7 @@ public: uint64_t GetCanonicalPointer( const CallstackFrameId& id ) const; const SymbolData* GetSymbolData( uint64_t sym ) const; const char* GetSymbolCode( uint64_t sym, uint32_t& len ) const; + uint64_t GetSymbolForAddress( uint64_t address, uint32_t& offset ) const; #ifndef TRACY_NO_STATISTICS const VarArray& GetParentCallstack( uint32_t idx ) const { return *m_data.parentCallstackPayload[idx]; }