mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-24 07:56:15 +00:00
dmnt-cheat: add other register source to new condition opcode
This commit is contained in:
parent
da664b49ad
commit
433b01aaf8
2 changed files with 29 additions and 2 deletions
|
@ -153,6 +153,10 @@ void DmntCheatVm::LogOpcode(const CheatVmOpcode *opcode) {
|
||||||
this->LogToDebugFile("Comp Type: Static Value\n");
|
this->LogToDebugFile("Comp Type: Static Value\n");
|
||||||
this->LogToDebugFile("Value: %lx\n", opcode->begin_reg_cond.value.bit64);
|
this->LogToDebugFile("Value: %lx\n", opcode->begin_reg_cond.value.bit64);
|
||||||
break;
|
break;
|
||||||
|
case CompareRegisterValueType_OtherRegister:
|
||||||
|
this->LogToDebugFile("Comp Type: Other Register\n");
|
||||||
|
this->LogToDebugFile("X Reg Idx: %x\n", opcode->begin_reg_cond.other_reg_index);
|
||||||
|
break;
|
||||||
case CompareRegisterValueType_MemoryRelAddr:
|
case CompareRegisterValueType_MemoryRelAddr:
|
||||||
this->LogToDebugFile("Comp Type: Memory Relative Address\n");
|
this->LogToDebugFile("Comp Type: Memory Relative Address\n");
|
||||||
this->LogToDebugFile("Mem Type: %x\n", opcode->begin_reg_cond.mem_type);
|
this->LogToDebugFile("Mem Type: %x\n", opcode->begin_reg_cond.mem_type);
|
||||||
|
@ -396,16 +400,19 @@ bool DmntCheatVm::DecodeNextOpcode(CheatVmOpcode *out) {
|
||||||
/* C0TcS2Ra aaaaaaaa */
|
/* C0TcS2Ra aaaaaaaa */
|
||||||
/* C0TcS3Rr */
|
/* C0TcS3Rr */
|
||||||
/* C0TcS400 VVVVVVVV (VVVVVVVV) */
|
/* C0TcS400 VVVVVVVV (VVVVVVVV) */
|
||||||
|
/* C0TcS5X0 */
|
||||||
/* C0 = opcode 0xC0 */
|
/* C0 = opcode 0xC0 */
|
||||||
/* T = bit width */
|
/* T = bit width */
|
||||||
/* c = condition type. */
|
/* c = condition type. */
|
||||||
/* S = source register. */
|
/* S = source register. */
|
||||||
/* X = value operand type, 0 = main/heap with relative offset, 1 = main/heap with offset register, */
|
/* X = value operand type, 0 = main/heap with relative offset, 1 = main/heap with offset register, */
|
||||||
/* 2 = register with relative offset, 3 = register with offset register, 4 = static value. */
|
/* 2 = register with relative offset, 3 = register with offset register, 4 = static value, 5 = other register. */
|
||||||
/* M = memory type. */
|
/* M = memory type. */
|
||||||
|
/* R = address register. */
|
||||||
/* a = relative address. */
|
/* a = relative address. */
|
||||||
/* r = offset register. */
|
/* r = offset register. */
|
||||||
/* V = value */
|
/* X = other register. */
|
||||||
|
/* V = value. */
|
||||||
opcode.begin_reg_cond.bit_width = (first_dword >> 20) & 0xF;
|
opcode.begin_reg_cond.bit_width = (first_dword >> 20) & 0xF;
|
||||||
opcode.begin_reg_cond.cond_type = (ConditionalComparisonType)((first_dword >> 16) & 0xF);
|
opcode.begin_reg_cond.cond_type = (ConditionalComparisonType)((first_dword >> 16) & 0xF);
|
||||||
opcode.begin_reg_cond.val_reg_index = ((first_dword >> 12) & 0xF);
|
opcode.begin_reg_cond.val_reg_index = ((first_dword >> 12) & 0xF);
|
||||||
|
@ -415,6 +422,9 @@ bool DmntCheatVm::DecodeNextOpcode(CheatVmOpcode *out) {
|
||||||
case CompareRegisterValueType_StaticValue:
|
case CompareRegisterValueType_StaticValue:
|
||||||
opcode.begin_reg_cond.value = GetNextVmInt(opcode.begin_reg_cond.bit_width);
|
opcode.begin_reg_cond.value = GetNextVmInt(opcode.begin_reg_cond.bit_width);
|
||||||
break;
|
break;
|
||||||
|
case CompareRegisterValueType_OtherRegister:
|
||||||
|
opcode.begin_reg_cond.other_reg_index = ((first_dword >> 4) & 0xF);
|
||||||
|
break;
|
||||||
case CompareRegisterValueType_MemoryRelAddr:
|
case CompareRegisterValueType_MemoryRelAddr:
|
||||||
opcode.begin_reg_cond.mem_type = (MemoryAccessType)((first_dword >> 4) & 0xF);
|
opcode.begin_reg_cond.mem_type = (MemoryAccessType)((first_dword >> 4) & 0xF);
|
||||||
opcode.begin_reg_cond.rel_address = (((u64)(first_dword & 0xF) << 32ul) | ((u64)GetNextDword()));
|
opcode.begin_reg_cond.rel_address = (((u64)(first_dword & 0xF) << 32ul) | ((u64)GetNextDword()));
|
||||||
|
@ -855,6 +865,21 @@ void DmntCheatVm::Execute(const CheatProcessMetadata *metadata) {
|
||||||
u64 cond_value = 0;
|
u64 cond_value = 0;
|
||||||
if (cur_opcode.begin_reg_cond.comp_type == CompareRegisterValueType_StaticValue) {
|
if (cur_opcode.begin_reg_cond.comp_type == CompareRegisterValueType_StaticValue) {
|
||||||
cond_value = GetVmInt(cur_opcode.begin_reg_cond.value, cur_opcode.begin_reg_cond.bit_width);
|
cond_value = GetVmInt(cur_opcode.begin_reg_cond.value, cur_opcode.begin_reg_cond.bit_width);
|
||||||
|
} else if (cur_opcode.begin_reg_cond.comp_type == CompareRegisterValueType_OtherRegister) {
|
||||||
|
switch (cur_opcode.begin_reg_cond.bit_width) {
|
||||||
|
case 1:
|
||||||
|
cond_value = static_cast<u8>(this->registers[cur_opcode.begin_reg_cond.other_reg_index] & 0xFFul);
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
cond_value = static_cast<u16>(this->registers[cur_opcode.begin_reg_cond.other_reg_index] & 0xFFFFul);
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
cond_value = static_cast<u32>(this->registers[cur_opcode.begin_reg_cond.other_reg_index] & 0xFFFFFFFFul);
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
cond_value = static_cast<u64>(this->registers[cur_opcode.begin_reg_cond.other_reg_index] & 0xFFFFFFFFFFFFFFFFul);
|
||||||
|
break;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
u64 cond_address = 0;
|
u64 cond_address = 0;
|
||||||
switch (cur_opcode.begin_reg_cond.comp_type) {
|
switch (cur_opcode.begin_reg_cond.comp_type) {
|
||||||
|
|
|
@ -87,6 +87,7 @@ enum CompareRegisterValueType : u32 {
|
||||||
CompareRegisterValueType_RegisterRelAddr = 2,
|
CompareRegisterValueType_RegisterRelAddr = 2,
|
||||||
CompareRegisterValueType_RegisterOfsReg = 3,
|
CompareRegisterValueType_RegisterOfsReg = 3,
|
||||||
CompareRegisterValueType_StaticValue = 4,
|
CompareRegisterValueType_StaticValue = 4,
|
||||||
|
CompareRegisterValueType_OtherRegister = 5,
|
||||||
};
|
};
|
||||||
|
|
||||||
union VmInt {
|
union VmInt {
|
||||||
|
@ -180,6 +181,7 @@ struct BeginRegisterConditionalOpcode {
|
||||||
CompareRegisterValueType comp_type;
|
CompareRegisterValueType comp_type;
|
||||||
MemoryAccessType mem_type;
|
MemoryAccessType mem_type;
|
||||||
u32 addr_reg_index;
|
u32 addr_reg_index;
|
||||||
|
u32 other_reg_index;
|
||||||
u32 ofs_reg_index;
|
u32 ofs_reg_index;
|
||||||
u64 rel_address;
|
u64 rel_address;
|
||||||
VmInt value;
|
VmInt value;
|
||||||
|
|
Loading…
Reference in a new issue