[CPU] break_on_unimplemented_instructions cvar
This commit is contained in:
parent
36501be9f8
commit
9428af52e4
|
@ -15,6 +15,7 @@
|
||||||
#include "third_party/fmt/include/fmt/format.h"
|
#include "third_party/fmt/include/fmt/format.h"
|
||||||
|
|
||||||
#include "xenia/base/byte_order.h"
|
#include "xenia/base/byte_order.h"
|
||||||
|
#include "xenia/base/cvar.h"
|
||||||
#include "xenia/base/logging.h"
|
#include "xenia/base/logging.h"
|
||||||
#include "xenia/base/memory.h"
|
#include "xenia/base/memory.h"
|
||||||
#include "xenia/base/profiling.h"
|
#include "xenia/base/profiling.h"
|
||||||
|
@ -26,6 +27,12 @@
|
||||||
#include "xenia/cpu/ppc/ppc_opcode_info.h"
|
#include "xenia/cpu/ppc/ppc_opcode_info.h"
|
||||||
#include "xenia/cpu/processor.h"
|
#include "xenia/cpu/processor.h"
|
||||||
|
|
||||||
|
DEFINE_bool(
|
||||||
|
break_on_unimplemented_instructions, true,
|
||||||
|
"Break to the host debugger (or crash if no debugger attached) if an "
|
||||||
|
"unimplemented PowerPC instruction is encountered.",
|
||||||
|
"CPU");
|
||||||
|
|
||||||
namespace xe {
|
namespace xe {
|
||||||
namespace cpu {
|
namespace cpu {
|
||||||
namespace ppc {
|
namespace ppc {
|
||||||
|
@ -169,12 +176,16 @@ bool PPCHIRBuilder::Emit(GuestFunction* function, uint32_t flags) {
|
||||||
i.opcode_info = &opcode_info;
|
i.opcode_info = &opcode_info;
|
||||||
if (!opcode_info.emit || opcode_info.emit(*this, i)) {
|
if (!opcode_info.emit || opcode_info.emit(*this, i)) {
|
||||||
auto& disasm_info = GetOpcodeDisasmInfo(opcode);
|
auto& disasm_info = GetOpcodeDisasmInfo(opcode);
|
||||||
XELOGE("Unimplemented instr {:08X} {:08X} {}", address, code,
|
XELOGE(
|
||||||
disasm_info.name);
|
"Unimplemented instr {:08X} {:08X} {} - report the game to Xenia "
|
||||||
|
"developers; to skip, disable break_on_unimplemented_instructions",
|
||||||
|
address, code, disasm_info.name);
|
||||||
Comment("UNIMPLEMENTED!");
|
Comment("UNIMPLEMENTED!");
|
||||||
|
if (cvars::break_on_unimplemented_instructions) {
|
||||||
DebugBreak();
|
DebugBreak();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (false) {
|
if (false) {
|
||||||
DumpAllOpcodeCounts();
|
DumpAllOpcodeCounts();
|
||||||
|
|
Loading…
Reference in New Issue