Skip to content

Commit

Permalink
SymbolDB: GetSymbolsFromName added
Browse files Browse the repository at this point in the history
  • Loading branch information
sepalani committed Oct 5, 2016
1 parent 22d9259 commit d068c24
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 5 deletions.
13 changes: 13 additions & 0 deletions Source/Core/Common/SymbolDB.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,19 @@ Symbol* SymbolDB::GetSymbolFromName(const std::string& name)
return nullptr;
}

std::vector<Symbol*> SymbolDB::GetSymbolsFromName(const std::string& name)
{
std::vector<Symbol*> symbols;

for (auto& func : functions)
{
if (func.second.function_name == name)
symbols.push_back(&func.second);
}

return symbols;
}

void SymbolDB::AddCompleteSymbol(const Symbol& symbol)
{
functions.emplace(symbol.address, symbol);
Expand Down
1 change: 1 addition & 0 deletions Source/Core/Common/SymbolDB.h
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,7 @@ class SymbolDB
void AddCompleteSymbol(const Symbol& symbol);

Symbol* GetSymbolFromName(const std::string& name);
std::vector<Symbol*> GetSymbolsFromName(const std::string& name);
Symbol* GetSymbolFromHash(u32 hash)
{
XFuncPtrMap::iterator iter = checksumToFunction.find(hash);
Expand Down
8 changes: 3 additions & 5 deletions Source/Core/Core/HLE/HLE.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -108,8 +108,7 @@ void PatchFunctions()
if (OSPatches[i].flags == HLE_TYPE_FIXED)
continue;

Symbol* symbol = g_symbolDB.GetSymbolFromName(OSPatches[i].m_szPatchName);
if (symbol)
for (const auto& symbol : g_symbolDB.GetSymbolsFromName(OSPatches[i].m_szPatchName))
{
for (u32 addr = symbol->address; addr < symbol->address + symbol->size; addr += 4)
{
Expand All @@ -124,8 +123,7 @@ void PatchFunctions()
{
for (size_t i = 1; i < ArraySize(OSBreakPoints); ++i)
{
Symbol* symbol = g_symbolDB.GetSymbolFromName(OSBreakPoints[i].m_szPatchName);
if (symbol)
for (const auto& symbol : g_symbolDB.GetSymbolsFromName(OSBreakPoints[i].m_szPatchName))
{
PowerPC::breakpoints.Add(symbol->address, false);
INFO_LOG(OSHLE, "Adding BP to %s %08x", OSBreakPoints[i].m_szPatchName, symbol->address);
Expand Down Expand Up @@ -210,7 +208,7 @@ u32 UnPatch(const std::string& patch_name)
return addr;
}

if (Symbol* symbol = g_symbolDB.GetSymbolFromName(patch_name))
for (const auto& symbol : g_symbolDB.GetSymbolsFromName(patch_name))
{
for (u32 addr = symbol->address; addr < symbol->address + symbol->size; addr += 4)
{
Expand Down

0 comments on commit d068c24

Please sign in to comment.