Adding --target= and --trace_registers flags.
--target=[xex|iso] makes it possible to specify the thing to run from a flagfile.
This commit is contained in:
parent
37530d1438
commit
f307bc9eb1
|
@ -14,6 +14,7 @@
|
|||
|
||||
|
||||
DECLARE_bool(trace_instructions);
|
||||
DECLARE_bool(trace_registers);
|
||||
DECLARE_bool(trace_branches);
|
||||
DECLARE_bool(trace_user_calls);
|
||||
DECLARE_bool(trace_kernel_calls);
|
||||
|
@ -21,11 +22,7 @@ DECLARE_bool(trace_kernel_calls);
|
|||
DECLARE_string(load_module_map);
|
||||
|
||||
DECLARE_string(dump_path);
|
||||
DECLARE_bool(dump_module_bitcode);
|
||||
DECLARE_bool(dump_module_map);
|
||||
|
||||
DECLARE_bool(optimize_ir_modules);
|
||||
DECLARE_bool(optimize_ir_functions);
|
||||
|
||||
|
||||
#endif // XENIA_CPU_PRIVATE_H_
|
||||
|
|
|
@ -13,6 +13,8 @@
|
|||
// Tracing:
|
||||
DEFINE_bool(trace_instructions, false,
|
||||
"Trace all instructions.");
|
||||
DEFINE_bool(trace_registers, false,
|
||||
"Trace register values when tracing instructions.");
|
||||
DEFINE_bool(trace_branches, false,
|
||||
"Trace all branches.");
|
||||
DEFINE_bool(trace_user_calls, false,
|
||||
|
@ -34,10 +36,3 @@ DEFINE_bool(dump_module_bitcode, true,
|
|||
"Writes the module bitcode both before and after optimizations.");
|
||||
DEFINE_bool(dump_module_map, true,
|
||||
"Dumps the module symbol database.");
|
||||
|
||||
|
||||
// Optimizations:
|
||||
DEFINE_bool(optimize_ir_modules, true,
|
||||
"Whether to run LLVM optimizations on modules.");
|
||||
DEFINE_bool(optimize_ir_functions, true,
|
||||
"Whether to run LLVM optimizations on functions.");
|
||||
|
|
|
@ -9,6 +9,7 @@
|
|||
|
||||
#include <xenia/cpu/global_exports.h>
|
||||
|
||||
#include <xenia/cpu/cpu-private.h>
|
||||
#include <xenia/cpu/processor.h>
|
||||
#include <xenia/cpu/sdb.h>
|
||||
#include <xenia/cpu/ppc/instr.h>
|
||||
|
@ -102,6 +103,7 @@ void _cdecl XeTraceBranch(
|
|||
|
||||
void _cdecl XeTraceInstruction(
|
||||
xe_ppc_state_t* state, uint64_t cia, uint64_t data) {
|
||||
if (FLAGS_trace_registers) {
|
||||
XELOGCPU(
|
||||
"\n"
|
||||
" lr=%.16llX ctr=%.16llX cr=%.4X xer=%.16llX\n"
|
||||
|
@ -122,6 +124,7 @@ void _cdecl XeTraceInstruction(
|
|||
state->r[20], state->r[21], state->r[22], state->r[23],
|
||||
state->r[24], state->r[25], state->r[26], state->r[27],
|
||||
state->r[28], state->r[29], state->r[30], state->r[31]);
|
||||
}
|
||||
|
||||
ppc::InstrData i;
|
||||
i.address = (uint32_t)cia;
|
||||
|
|
|
@ -228,7 +228,9 @@ int X64Emitter::MakeFunction(FunctionSymbol* symbol) {
|
|||
int result_code = 1;
|
||||
Lock();
|
||||
|
||||
if (FLAGS_log_codegen) {
|
||||
XELOGCPU("Compile(%s): beginning compilation...", symbol->name());
|
||||
}
|
||||
|
||||
symbol_ = symbol;
|
||||
fn_block_ = NULL;
|
||||
|
|
|
@ -18,6 +18,10 @@ using namespace xe::dbg;
|
|||
using namespace xe::kernel;
|
||||
|
||||
|
||||
DEFINE_string(target, "",
|
||||
"Specifies the target .xex or .iso to execute.");
|
||||
|
||||
|
||||
class Run {
|
||||
public:
|
||||
Run();
|
||||
|
@ -101,12 +105,22 @@ int Run::Launch(const xechar_t* path) {
|
|||
int xenia_run(int argc, xechar_t** argv) {
|
||||
int result_code = 1;
|
||||
|
||||
// Grab path.
|
||||
if (argc < 2) {
|
||||
// Grab path from the flag or unnamed argument.
|
||||
if (!FLAGS_target.size() && argc < 2) {
|
||||
google::ShowUsageWithFlags("xenia-run");
|
||||
return 1;
|
||||
}
|
||||
const xechar_t *path = argv[1];
|
||||
const xechar_t* path = NULL;
|
||||
if (FLAGS_target.size()) {
|
||||
// Passed as a named argument.
|
||||
// TODO(benvanik): find something better than gflags that supports unicode.
|
||||
xechar_t buffer[XE_MAX_PATH];
|
||||
XEIGNORE(xestrwiden(buffer, sizeof(buffer), FLAGS_target.c_str()));
|
||||
path = buffer;
|
||||
} else {
|
||||
// Passed as an unnamed argument.
|
||||
path = argv[1];
|
||||
}
|
||||
|
||||
auto_ptr<Run> run = auto_ptr<Run>(new Run());
|
||||
|
||||
|
|
Loading…
Reference in New Issue