mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-10 08:09:26 +01:00
Merge pull request #5932 from sepalani/sym-strip
SymbolDB: Blank stripped symbol name fixed
This commit is contained in:
commit
14c2c6092e
@ -11,6 +11,21 @@
|
|||||||
#include "Common/Logging/Log.h"
|
#include "Common/Logging/Log.h"
|
||||||
#include "Common/SymbolDB.h"
|
#include "Common/SymbolDB.h"
|
||||||
|
|
||||||
|
static std::string GetStrippedFunctionName(const std::string& symbol_name)
|
||||||
|
{
|
||||||
|
std::string name = symbol_name.substr(0, symbol_name.find('('));
|
||||||
|
size_t position = name.find(' ');
|
||||||
|
if (position != std::string::npos)
|
||||||
|
name.erase(position);
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Symbol::Rename(const std::string& symbol_name)
|
||||||
|
{
|
||||||
|
this->name = symbol_name;
|
||||||
|
this->function_name = GetStrippedFunctionName(symbol_name);
|
||||||
|
}
|
||||||
|
|
||||||
void SymbolDB::List()
|
void SymbolDB::List()
|
||||||
{
|
{
|
||||||
for (const auto& func : functions)
|
for (const auto& func : functions)
|
||||||
|
@ -30,6 +30,8 @@ struct Symbol
|
|||||||
Data,
|
Data,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
void Rename(const std::string& symbol_name);
|
||||||
|
|
||||||
std::string name;
|
std::string name;
|
||||||
std::string function_name; // stripped function name
|
std::string function_name; // stripped function name
|
||||||
std::vector<SCall> callers; // addresses of functions that call this function
|
std::vector<SCall> callers; // addresses of functions that call this function
|
||||||
|
@ -384,7 +384,7 @@ void RSOView::Apply(PPCSymbolDB* symbol_db) const
|
|||||||
if (symbol)
|
if (symbol)
|
||||||
{
|
{
|
||||||
// Function symbol
|
// Function symbol
|
||||||
symbol->name = export_name;
|
symbol->Rename(export_name);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -149,7 +149,7 @@ bool ReadAnnotatedAssembly(const std::string& filename)
|
|||||||
temp[i - 5] = 0;
|
temp[i - 5] = 0;
|
||||||
|
|
||||||
// Mark symbol so the next hex sets the address
|
// Mark symbol so the next hex sets the address
|
||||||
current_symbol.name = temp;
|
current_symbol.Rename(temp);
|
||||||
current_symbol.address = 0xFFFF;
|
current_symbol.address = 0xFFFF;
|
||||||
current_symbol.index = symbol_count++;
|
current_symbol.index = symbol_count++;
|
||||||
symbol_in_progress = true;
|
symbol_in_progress = true;
|
||||||
|
@ -85,8 +85,8 @@ static u32 EvaluateBranchTarget(UGeckoInstruction instr, u32 pc)
|
|||||||
// one blr or rfi, and keep scanning.
|
// one blr or rfi, and keep scanning.
|
||||||
bool AnalyzeFunction(u32 startAddr, Symbol& func, int max_size)
|
bool AnalyzeFunction(u32 startAddr, Symbol& func, int max_size)
|
||||||
{
|
{
|
||||||
if (!func.name.size())
|
if (func.name.empty())
|
||||||
func.name = StringFromFormat("zz_%07x_", startAddr & 0x0FFFFFFF);
|
func.Rename(StringFromFormat("zz_%07x_", startAddr & 0x0FFFFFFF));
|
||||||
if (func.analyzed)
|
if (func.analyzed)
|
||||||
return true; // No error, just already did it.
|
return true; // No error, just already did it.
|
||||||
|
|
||||||
@ -341,7 +341,7 @@ static void FindFunctionsFromHandlers(PPCSymbolDB* func_db)
|
|||||||
Symbol* f = func_db->AddFunction(entry.first);
|
Symbol* f = func_db->AddFunction(entry.first);
|
||||||
if (!f)
|
if (!f)
|
||||||
continue;
|
continue;
|
||||||
f->name = entry.second;
|
f->Rename(entry.second);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -407,9 +407,9 @@ void FindFunctions(u32 startAddr, u32 endAddr, PPCSymbolDB* func_db)
|
|||||||
if (f.name.substr(0, 3) == "zzz")
|
if (f.name.substr(0, 3) == "zzz")
|
||||||
{
|
{
|
||||||
if (f.flags & FFLAG_LEAF)
|
if (f.flags & FFLAG_LEAF)
|
||||||
f.name += "_leaf";
|
f.Rename(f.name + "_leaf");
|
||||||
if (f.flags & FFLAG_STRAIGHT)
|
if (f.flags & FFLAG_STRAIGHT)
|
||||||
f.name += "_straight";
|
f.Rename(f.name + "_straight");
|
||||||
}
|
}
|
||||||
if (f.flags & FFLAG_LEAF)
|
if (f.flags & FFLAG_LEAF)
|
||||||
{
|
{
|
||||||
|
@ -17,15 +17,6 @@
|
|||||||
#include "Core/PowerPC/PowerPC.h"
|
#include "Core/PowerPC/PowerPC.h"
|
||||||
#include "Core/PowerPC/SignatureDB/SignatureDB.h"
|
#include "Core/PowerPC/SignatureDB/SignatureDB.h"
|
||||||
|
|
||||||
static std::string GetStrippedFunctionName(const std::string& symbol_name)
|
|
||||||
{
|
|
||||||
std::string name = symbol_name.substr(0, symbol_name.find('('));
|
|
||||||
size_t position = name.find(' ');
|
|
||||||
if (position != std::string::npos)
|
|
||||||
name.erase(position);
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
PPCSymbolDB g_symbolDB;
|
PPCSymbolDB g_symbolDB;
|
||||||
|
|
||||||
PPCSymbolDB::PPCSymbolDB()
|
PPCSymbolDB::PPCSymbolDB()
|
||||||
@ -64,8 +55,7 @@ void PPCSymbolDB::AddKnownSymbol(u32 startAddr, u32 size, const std::string& nam
|
|||||||
{
|
{
|
||||||
// already got it, let's just update name, checksum & size to be sure.
|
// already got it, let's just update name, checksum & size to be sure.
|
||||||
Symbol* tempfunc = &iter->second;
|
Symbol* tempfunc = &iter->second;
|
||||||
tempfunc->name = name;
|
tempfunc->Rename(name);
|
||||||
tempfunc->function_name = GetStrippedFunctionName(name);
|
|
||||||
tempfunc->hash = HashSignatureDB::ComputeCodeChecksum(startAddr, startAddr + size - 4);
|
tempfunc->hash = HashSignatureDB::ComputeCodeChecksum(startAddr, startAddr + size - 4);
|
||||||
tempfunc->type = type;
|
tempfunc->type = type;
|
||||||
tempfunc->size = size;
|
tempfunc->size = size;
|
||||||
@ -74,14 +64,13 @@ void PPCSymbolDB::AddKnownSymbol(u32 startAddr, u32 size, const std::string& nam
|
|||||||
{
|
{
|
||||||
// new symbol. run analyze.
|
// new symbol. run analyze.
|
||||||
Symbol tf;
|
Symbol tf;
|
||||||
tf.name = name;
|
tf.Rename(name);
|
||||||
tf.type = type;
|
tf.type = type;
|
||||||
tf.address = startAddr;
|
tf.address = startAddr;
|
||||||
if (tf.type == Symbol::Type::Function)
|
if (tf.type == Symbol::Type::Function)
|
||||||
{
|
{
|
||||||
PPCAnalyst::AnalyzeFunction(startAddr, tf, size);
|
PPCAnalyst::AnalyzeFunction(startAddr, tf, size);
|
||||||
checksumToFunction[tf.hash].insert(&functions[startAddr]);
|
checksumToFunction[tf.hash].insert(&functions[startAddr]);
|
||||||
tf.function_name = GetStrippedFunctionName(name);
|
|
||||||
}
|
}
|
||||||
tf.size = size;
|
tf.size = size;
|
||||||
functions[startAddr] = tf;
|
functions[startAddr] = tf;
|
||||||
|
@ -127,15 +127,14 @@ void HashSignatureDB::Apply(PPCSymbolDB* symbol_db) const
|
|||||||
for (const auto& function : symbol_db->GetSymbolsFromHash(entry.first))
|
for (const auto& function : symbol_db->GetSymbolsFromHash(entry.first))
|
||||||
{
|
{
|
||||||
// Found the function. Let's rename it according to the symbol file.
|
// Found the function. Let's rename it according to the symbol file.
|
||||||
|
function->Rename(entry.second.name);
|
||||||
if (entry.second.size == static_cast<unsigned int>(function->size))
|
if (entry.second.size == static_cast<unsigned int>(function->size))
|
||||||
{
|
{
|
||||||
function->name = entry.second.name;
|
|
||||||
INFO_LOG(OSHLE, "Found %s at %08x (size: %08x)!", entry.second.name.c_str(),
|
INFO_LOG(OSHLE, "Found %s at %08x (size: %08x)!", entry.second.name.c_str(),
|
||||||
function->address, function->size);
|
function->address, function->size);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
function->name = entry.second.name;
|
|
||||||
ERROR_LOG(OSHLE, "Wrong size! Found %s at %08x (size: %08x instead of %08x)!",
|
ERROR_LOG(OSHLE, "Wrong size! Found %s at %08x (size: %08x instead of %08x)!",
|
||||||
entry.second.name.c_str(), function->address, function->size, entry.second.size);
|
entry.second.name.c_str(), function->address, function->size, entry.second.size);
|
||||||
}
|
}
|
||||||
|
@ -361,7 +361,7 @@ void CCodeView::OnPopupMenu(wxCommandEvent& event)
|
|||||||
StrToWxStr(symbol->name));
|
StrToWxStr(symbol->name));
|
||||||
if (input_symbol.ShowModal() == wxID_OK)
|
if (input_symbol.ShowModal() == wxID_OK)
|
||||||
{
|
{
|
||||||
symbol->name = WxStrToStr(input_symbol.GetValue());
|
symbol->Rename(WxStrToStr(input_symbol.GetValue()));
|
||||||
Refresh(); // Redraw to show the renamed symbol
|
Refresh(); // Redraw to show the renamed symbol
|
||||||
}
|
}
|
||||||
Host_NotifyMapLoaded();
|
Host_NotifyMapLoaded();
|
||||||
|
@ -337,7 +337,7 @@ void CCodeWindow::OnSymbolsMenu(wxCommandEvent& event)
|
|||||||
|
|
||||||
Symbol* symbol = g_symbolDB.GetSymbolFromAddr(address);
|
Symbol* symbol = g_symbolDB.GetSymbolFromAddr(address);
|
||||||
if (symbol)
|
if (symbol)
|
||||||
symbol->name = line.substr(12);
|
symbol->Rename(line.substr(12));
|
||||||
}
|
}
|
||||||
|
|
||||||
Host_NotifyMapLoaded();
|
Host_NotifyMapLoaded();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user