diff options
author | bunnei <bunneidev@gmail.com> | 2014-09-08 06:10:13 +0200 |
---|---|---|
committer | bunnei <bunneidev@gmail.com> | 2014-09-08 06:10:13 +0200 |
commit | 335082e74e5f015450f1ad57cb90d1f8fd4afbdb (patch) | |
tree | 576c57f45d933885d31f7eddfbf85167bc1b88ac /src/citra_qt | |
parent | Merge pull request #87 from archshift/remove-cruft (diff) | |
parent | core: Make the ARM disassembler use std::string internally (diff) | |
download | yuzu-335082e74e5f015450f1ad57cb90d1f8fd4afbdb.tar yuzu-335082e74e5f015450f1ad57cb90d1f8fd4afbdb.tar.gz yuzu-335082e74e5f015450f1ad57cb90d1f8fd4afbdb.tar.bz2 yuzu-335082e74e5f015450f1ad57cb90d1f8fd4afbdb.tar.lz yuzu-335082e74e5f015450f1ad57cb90d1f8fd4afbdb.tar.xz yuzu-335082e74e5f015450f1ad57cb90d1f8fd4afbdb.tar.zst yuzu-335082e74e5f015450f1ad57cb90d1f8fd4afbdb.zip |
Diffstat (limited to '')
-rw-r--r-- | src/citra_qt/debugger/callstack.cpp | 2 | ||||
-rw-r--r-- | src/citra_qt/debugger/disassembler.cpp | 8 |
2 files changed, 4 insertions, 6 deletions
diff --git a/src/citra_qt/debugger/callstack.cpp b/src/citra_qt/debugger/callstack.cpp index f59f2d8c8..77fb0c9ed 100644 --- a/src/citra_qt/debugger/callstack.cpp +++ b/src/citra_qt/debugger/callstack.cpp @@ -37,7 +37,7 @@ void CallstackWidget::OnCPUStepped() /* TODO (mattvail) clean me, move to debugger interface */ u32 insn = Memory::Read32(call_addr); - if (disasm->decode(insn) == OP_BL) + if (disasm->Decode(insn) == OP_BL) { std::string name; // ripped from disasm diff --git a/src/citra_qt/debugger/disassembler.cpp b/src/citra_qt/debugger/disassembler.cpp index 507a35718..856baf63d 100644 --- a/src/citra_qt/debugger/disassembler.cpp +++ b/src/citra_qt/debugger/disassembler.cpp @@ -36,22 +36,20 @@ QVariant DisassemblerModel::data(const QModelIndex& index, int role) const { switch (role) { case Qt::DisplayRole: { - static char result[255]; - u32 address = base_address + index.row() * 4; u32 instr = Memory::Read32(address); - ARM_Disasm::disasm(address, instr, result); + std::string disassembly = ARM_Disasm::Disassemble(address, instr); if (index.column() == 0) { return QString("0x%1").arg((uint)(address), 8, 16, QLatin1Char('0')); } else if (index.column() == 1) { - return QString::fromLatin1(result); + return QString::fromStdString(disassembly); } else if (index.column() == 2) { if(Symbols::HasSymbol(address)) { TSymbol symbol = Symbols::GetSymbol(address); return QString("%1 - Size:%2").arg(QString::fromStdString(symbol.name)) .arg(symbol.size / 4); // divide by 4 to get instruction count - } else if (ARM_Disasm::decode(instr) == OP_BL) { + } else if (ARM_Disasm::Decode(instr) == OP_BL) { u32 offset = instr & 0xFFFFFF; // Sign-extend the 24-bit offset |