Compare commits

...

2 Commits

Author SHA1 Message Date
Skyth (Asilkan)
c017eb630a PPC context header adjustments. (#123) 2025-03-21 17:40:55 +03:00
Skyth (Asilkan)
82b4cd3bb7 Fix return value from longjmp getting forgotten after setjmp. (#122)
Restoring env to ctx was causing this because the return value was getting assigned to r3 before the if check.
2025-03-21 17:38:08 +03:00
2 changed files with 26 additions and 31 deletions

View File

@@ -378,8 +378,9 @@ bool Recompiler::Recompile(
else if (address == config.setJmpAddress)
{
println("\t{} = ctx;", env());
println("\t{}.s64 = setjmp(*reinterpret_cast<jmp_buf*>(base + {}.u32));", r(3), r(3));
println("\tif ({}.s64 != 0) ctx = {};", r(3), env());
println("\t{}.s64 = setjmp(*reinterpret_cast<jmp_buf*>(base + {}.u32));", temp(), r(3));
println("\tif ({}.s64 != 0) ctx = {};", temp(), env());
println("\t{} = {};", r(3), temp());
}
else
{

View File

@@ -123,9 +123,7 @@ struct PPCFuncMapping
extern PPCFuncMapping PPCFuncMappings[];
struct PPCRegister
{
union
union PPCRegister
{
int8_t s8;
uint8_t u8;
@@ -138,7 +136,6 @@ struct PPCRegister
float f32;
double f64;
};
};
struct PPCXERRegister
{
@@ -194,9 +191,7 @@ struct PPCCRRegister
}
};
struct alignas(0x10) PPCVRegister
{
union
union alignas(0x10) PPCVRegister
{
int8_t s8[16];
uint8_t u8[16];
@@ -209,7 +204,6 @@ struct alignas(0x10) PPCVRegister
float f32[4];
double f64[2];
};
};
#define PPC_ROUND_NEAREST 0x00
#define PPC_ROUND_TOWARD_ZERO 0x01
@@ -270,7 +264,7 @@ struct PPCFPSCRRegister
}
};
struct PPCContext
struct alignas(0x40) PPCContext
{
PPCRegister r3;
#ifndef PPC_CONFIG_NON_ARGUMENT_AS_LOCAL