mirror of
https://github.com/RPCS3/rpcs3.git
synced 2025-07-07 23:41:26 +12:00
common/d3d12/gl: Add support for textureProj
This commit is contained in:
parent
56704888b5
commit
6fae5863cf
4 changed files with 6 additions and 1 deletions
|
@ -423,7 +423,7 @@ bool FragmentProgramDecompiler::handle_tex_srb(u32 opcode)
|
||||||
case RSX_FP_OPCODE_BEM: LOG_ERROR(RSX, "Unimplemented TEX_SRB instruction: BEM"); return true;
|
case RSX_FP_OPCODE_BEM: LOG_ERROR(RSX, "Unimplemented TEX_SRB instruction: BEM"); return true;
|
||||||
case RSX_FP_OPCODE_TEX: SetDst(getFunction(FUNCTION::FUNCTION_TEXTURE_SAMPLE)); return true;
|
case RSX_FP_OPCODE_TEX: SetDst(getFunction(FUNCTION::FUNCTION_TEXTURE_SAMPLE)); return true;
|
||||||
case RSX_FP_OPCODE_TEXBEM: SetDst("texture($t, $0.xy, $1.x)"); return true;
|
case RSX_FP_OPCODE_TEXBEM: SetDst("texture($t, $0.xy, $1.x)"); return true;
|
||||||
case RSX_FP_OPCODE_TXP: SetDst("textureProj($t, $0.xyz, $1.x)"); return true; //TODO: More testing (Sonic The Hedgehog (NPUB-30442/NPEB-00478) and The Simpsons Arcade Game (NPUB30563))
|
case RSX_FP_OPCODE_TXP: SetDst(getFunction(FUNCTION::FUNCTION_TEXTURE_SAMPLE_PROJ)); return true; //TODO: More testing (Sonic The Hedgehog (NPUB-30442/NPEB-00478) and The Simpsons Arcade Game (NPUB30563))
|
||||||
case RSX_FP_OPCODE_TXPBEM: SetDst("textureProj($t, $0.xyz, $1.x)"); return true;
|
case RSX_FP_OPCODE_TXPBEM: SetDst("textureProj($t, $0.xyz, $1.x)"); return true;
|
||||||
case RSX_FP_OPCODE_TXD: LOG_ERROR(RSX, "Unimplemented TEX_SRB instruction: TXD"); return true;
|
case RSX_FP_OPCODE_TXD: LOG_ERROR(RSX, "Unimplemented TEX_SRB instruction: TXD"); return true;
|
||||||
case RSX_FP_OPCODE_TXB: SetDst("texture($t, $0.xy, $1.x)"); return true;
|
case RSX_FP_OPCODE_TXB: SetDst("texture($t, $0.xy, $1.x)"); return true;
|
||||||
|
|
|
@ -14,6 +14,7 @@ enum class FUNCTION {
|
||||||
FUNCTION_DFDX,
|
FUNCTION_DFDX,
|
||||||
FUNCTION_DFDY,
|
FUNCTION_DFDY,
|
||||||
FUNCTION_TEXTURE_SAMPLE,
|
FUNCTION_TEXTURE_SAMPLE,
|
||||||
|
FUNCTION_TEXTURE_SAMPLE_PROJ,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum class COMPARE {
|
enum class COMPARE {
|
||||||
|
|
|
@ -44,6 +44,8 @@ std::string getFunctionImp(FUNCTION f)
|
||||||
return "frac($0)";
|
return "frac($0)";
|
||||||
case FUNCTION::FUNCTION_TEXTURE_SAMPLE:
|
case FUNCTION::FUNCTION_TEXTURE_SAMPLE:
|
||||||
return "$t.Sample($tsampler, $0.xy * $t_scale)";
|
return "$t.Sample($tsampler, $0.xy * $t_scale)";
|
||||||
|
case FUNCTION::FUNCTION_TEXTURE_SAMPLE_PROJ:
|
||||||
|
return "$t.Sample($tsampler, ($0.xy / $0.z) * $t_scale)";
|
||||||
case FUNCTION::FUNCTION_DFDX:
|
case FUNCTION::FUNCTION_DFDX:
|
||||||
return "ddx($0)";
|
return "ddx($0)";
|
||||||
case FUNCTION::FUNCTION_DFDY:
|
case FUNCTION::FUNCTION_DFDY:
|
||||||
|
|
|
@ -42,6 +42,8 @@ std::string getFunctionImpl(FUNCTION f)
|
||||||
return "fract($0)";
|
return "fract($0)";
|
||||||
case FUNCTION::FUNCTION_TEXTURE_SAMPLE:
|
case FUNCTION::FUNCTION_TEXTURE_SAMPLE:
|
||||||
return "texture($t, $0.xy)";
|
return "texture($t, $0.xy)";
|
||||||
|
case FUNCTION::FUNCTION_TEXTURE_SAMPLE_PROJ:
|
||||||
|
return "textureProj($t, $0.xyz, $1.x)"; // Note: $1.x is bias
|
||||||
case FUNCTION::FUNCTION_DFDX:
|
case FUNCTION::FUNCTION_DFDX:
|
||||||
return "dFdx($0)";
|
return "dFdx($0)";
|
||||||
case FUNCTION::FUNCTION_DFDY:
|
case FUNCTION::FUNCTION_DFDY:
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue