mirror of
https://github.com/RPCS3/rpcs3.git
synced 2025-01-01 12:08:12 +00:00
SPU/DisAsm: Fix constant propagation with non-GPR-writing instructions
This commit is contained in:
parent
fdbb0b0e2f
commit
eacfa36fe6
@ -104,8 +104,7 @@ std::pair<bool, v128> SPUDisAsm::try_get_const_value(u32 reg, u32 pc, u32 TTL) c
|
||||
|
||||
//const auto flag = g_spu_iflag.decode(opcode);
|
||||
|
||||
// TODO: It detects spurious register modifications
|
||||
if (u32 dst = type & spu_itype::_quadrop ? +op0.rt4 : +op0.rt; dst == reg)
|
||||
if (u32 dst = type & spu_itype::_quadrop ? +op0.rt4 : +op0.rt; dst == reg && !(type & spu_itype::zregmod))
|
||||
{
|
||||
// Note: It's not 100% reliable because it won't detect branch targets within [i, dump_pc] range (e.g. if-else statement for command's value)
|
||||
switch (type)
|
||||
@ -183,15 +182,6 @@ std::pair<bool, v128> SPUDisAsm::try_get_const_value(u32 reg, u32 pc, u32 TTL) c
|
||||
|
||||
return { true, reg_val | v128::from32p(op0.i16) };
|
||||
}
|
||||
case spu_itype::STQA:
|
||||
case spu_itype::STQD:
|
||||
case spu_itype::STQR:
|
||||
case spu_itype::STQX:
|
||||
case spu_itype::WRCH:
|
||||
{
|
||||
// Do not modify RT
|
||||
break;
|
||||
}
|
||||
case spu_itype::SHLQBYI:
|
||||
{
|
||||
if (op0.si7)
|
||||
|
Loading…
Reference in New Issue
Block a user