mirror of
https://github.com/shadps4-emu/shadPS4.git
synced 2025-01-28 17:28:26 +00:00
shader_recompiler: Remove AMD native CubeFaceCoord. (#2129)
Some checks are pending
Build and Release / reuse (push) Waiting to run
Build and Release / clang-format (push) Waiting to run
Build and Release / get-info (push) Waiting to run
Build and Release / windows-sdl (push) Blocked by required conditions
Build and Release / windows-qt (push) Blocked by required conditions
Build and Release / macos-sdl (push) Blocked by required conditions
Build and Release / linux-qt (push) Blocked by required conditions
Build and Release / macos-qt (push) Blocked by required conditions
Build and Release / linux-sdl (push) Blocked by required conditions
Build and Release / linux-sdl-gcc (push) Blocked by required conditions
Build and Release / linux-qt-gcc (push) Blocked by required conditions
Build and Release / pre-release (push) Blocked by required conditions
Some checks are pending
Build and Release / reuse (push) Waiting to run
Build and Release / clang-format (push) Waiting to run
Build and Release / get-info (push) Waiting to run
Build and Release / windows-sdl (push) Blocked by required conditions
Build and Release / windows-qt (push) Blocked by required conditions
Build and Release / macos-sdl (push) Blocked by required conditions
Build and Release / linux-qt (push) Blocked by required conditions
Build and Release / macos-qt (push) Blocked by required conditions
Build and Release / linux-sdl (push) Blocked by required conditions
Build and Release / linux-sdl-gcc (push) Blocked by required conditions
Build and Release / linux-qt-gcc (push) Blocked by required conditions
Build and Release / pre-release (push) Blocked by required conditions
This commit is contained in:
parent
5810c88c00
commit
82cb298c5c
|
@ -255,14 +255,6 @@ void EmitImageWrite(EmitContext& ctx, IR::Inst* inst, u32 handle, Id coords, Id
|
||||||
ctx.OpImageWrite(image, coords, texel, operands.mask, operands.operands);
|
ctx.OpImageWrite(image, coords, texel, operands.mask, operands.operands);
|
||||||
}
|
}
|
||||||
|
|
||||||
Id EmitCubeFaceCoord(EmitContext& ctx, IR::Inst* inst, Id cube_coords) {
|
|
||||||
if (ctx.profile.supports_native_cube_calc) {
|
|
||||||
return ctx.OpCubeFaceCoordAMD(ctx.F32[2], cube_coords);
|
|
||||||
} else {
|
|
||||||
UNREACHABLE_MSG("SPIR-V Instruction");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Id EmitCubeFaceIndex(EmitContext& ctx, IR::Inst* inst, Id cube_coords) {
|
Id EmitCubeFaceIndex(EmitContext& ctx, IR::Inst* inst, Id cube_coords) {
|
||||||
if (ctx.profile.supports_native_cube_calc) {
|
if (ctx.profile.supports_native_cube_calc) {
|
||||||
return ctx.OpCubeFaceIndexAMD(ctx.F32[1], cube_coords);
|
return ctx.OpCubeFaceIndexAMD(ctx.F32[1], cube_coords);
|
||||||
|
|
|
@ -439,7 +439,6 @@ Id EmitImageAtomicAnd32(EmitContext& ctx, IR::Inst* inst, u32 handle, Id coords,
|
||||||
Id EmitImageAtomicOr32(EmitContext& ctx, IR::Inst* inst, u32 handle, Id coords, Id value);
|
Id EmitImageAtomicOr32(EmitContext& ctx, IR::Inst* inst, u32 handle, Id coords, Id value);
|
||||||
Id EmitImageAtomicXor32(EmitContext& ctx, IR::Inst* inst, u32 handle, Id coords, Id value);
|
Id EmitImageAtomicXor32(EmitContext& ctx, IR::Inst* inst, u32 handle, Id coords, Id value);
|
||||||
Id EmitImageAtomicExchange32(EmitContext& ctx, IR::Inst* inst, u32 handle, Id coords, Id value);
|
Id EmitImageAtomicExchange32(EmitContext& ctx, IR::Inst* inst, u32 handle, Id coords, Id value);
|
||||||
Id EmitCubeFaceCoord(EmitContext& ctx, IR::Inst* inst, Id cube_coords);
|
|
||||||
Id EmitCubeFaceIndex(EmitContext& ctx, IR::Inst* inst, Id cube_coords);
|
Id EmitCubeFaceIndex(EmitContext& ctx, IR::Inst* inst, Id cube_coords);
|
||||||
Id EmitLaneId(EmitContext& ctx);
|
Id EmitLaneId(EmitContext& ctx);
|
||||||
Id EmitWarpId(EmitContext& ctx);
|
Id EmitWarpId(EmitContext& ctx);
|
||||||
|
|
|
@ -1083,19 +1083,13 @@ void Translator::V_CUBESC_F32(const GcnInst& inst) {
|
||||||
const auto y = GetSrc<IR::F32>(inst.src[1]);
|
const auto y = GetSrc<IR::F32>(inst.src[1]);
|
||||||
const auto z = GetSrc<IR::F32>(inst.src[2]);
|
const auto z = GetSrc<IR::F32>(inst.src[2]);
|
||||||
|
|
||||||
IR::F32 result;
|
|
||||||
if (profile.supports_native_cube_calc) {
|
|
||||||
const auto coords{ir.CubeFaceCoord(ir.CompositeConstruct(x, y, z))};
|
|
||||||
result = IR::F32{ir.CompositeExtract(coords, 0)};
|
|
||||||
} else {
|
|
||||||
const auto x_neg_cond{ir.FPLessThan(x, ir.Imm32(0.f))};
|
const auto x_neg_cond{ir.FPLessThan(x, ir.Imm32(0.f))};
|
||||||
const auto z_neg_cond{ir.FPLessThan(z, ir.Imm32(0.f))};
|
const auto z_neg_cond{ir.FPLessThan(z, ir.Imm32(0.f))};
|
||||||
const IR::F32 x_sc{ir.Select(x_neg_cond, z, ir.FPNeg(z))};
|
const IR::F32 x_sc{ir.Select(x_neg_cond, z, ir.FPNeg(z))};
|
||||||
const IR::F32 y_sc{x};
|
const IR::F32 y_sc{x};
|
||||||
const IR::F32 z_sc{ir.Select(z_neg_cond, ir.FPNeg(x), x)};
|
const IR::F32 z_sc{ir.Select(z_neg_cond, ir.FPNeg(x), x)};
|
||||||
|
|
||||||
result = SelectCubeResult(x, y, z, x_sc, y_sc, z_sc);
|
const auto result{SelectCubeResult(x, y, z, x_sc, y_sc, z_sc)};
|
||||||
}
|
|
||||||
SetDst(inst.dst[0], result);
|
SetDst(inst.dst[0], result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1104,17 +1098,11 @@ void Translator::V_CUBETC_F32(const GcnInst& inst) {
|
||||||
const auto y = GetSrc<IR::F32>(inst.src[1]);
|
const auto y = GetSrc<IR::F32>(inst.src[1]);
|
||||||
const auto z = GetSrc<IR::F32>(inst.src[2]);
|
const auto z = GetSrc<IR::F32>(inst.src[2]);
|
||||||
|
|
||||||
IR::F32 result;
|
|
||||||
if (profile.supports_native_cube_calc) {
|
|
||||||
const auto coords{ir.CubeFaceCoord(ir.CompositeConstruct(x, y, z))};
|
|
||||||
result = IR::F32{ir.CompositeExtract(coords, 1)};
|
|
||||||
} else {
|
|
||||||
const auto y_neg_cond{ir.FPLessThan(y, ir.Imm32(0.f))};
|
const auto y_neg_cond{ir.FPLessThan(y, ir.Imm32(0.f))};
|
||||||
const IR::F32 x_z_tc{ir.FPNeg(y)};
|
const IR::F32 x_z_tc{ir.FPNeg(y)};
|
||||||
const IR::F32 y_tc{ir.Select(y_neg_cond, ir.FPNeg(z), z)};
|
const IR::F32 y_tc{ir.Select(y_neg_cond, ir.FPNeg(z), z)};
|
||||||
|
|
||||||
result = SelectCubeResult(x, y, z, x_z_tc, y_tc, x_z_tc);
|
const auto result{SelectCubeResult(x, y, z, x_z_tc, y_tc, x_z_tc)};
|
||||||
}
|
|
||||||
SetDst(inst.dst[0], result);
|
SetDst(inst.dst[0], result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1758,10 +1758,6 @@ void IREmitter::ImageWrite(const Value& handle, const Value& coords, const U32&
|
||||||
Inst(Opcode::ImageWrite, Flags{info}, handle, coords, lod, multisampling, color);
|
Inst(Opcode::ImageWrite, Flags{info}, handle, coords, lod, multisampling, color);
|
||||||
}
|
}
|
||||||
|
|
||||||
[[nodiscard]] Value IREmitter::CubeFaceCoord(const Value& cube_coords) {
|
|
||||||
return Inst(Opcode::CubeFaceCoord, cube_coords);
|
|
||||||
}
|
|
||||||
|
|
||||||
[[nodiscard]] F32 IREmitter::CubeFaceIndex(const Value& cube_coords) {
|
[[nodiscard]] F32 IREmitter::CubeFaceIndex(const Value& cube_coords) {
|
||||||
return Inst<F32>(Opcode::CubeFaceIndex, cube_coords);
|
return Inst<F32>(Opcode::CubeFaceIndex, cube_coords);
|
||||||
}
|
}
|
||||||
|
|
|
@ -342,7 +342,6 @@ public:
|
||||||
void ImageWrite(const Value& handle, const Value& coords, const U32& lod,
|
void ImageWrite(const Value& handle, const Value& coords, const U32& lod,
|
||||||
const U32& multisampling, const Value& color, TextureInstInfo info);
|
const U32& multisampling, const Value& color, TextureInstInfo info);
|
||||||
|
|
||||||
[[nodiscard]] Value CubeFaceCoord(const Value& cube_coords);
|
|
||||||
[[nodiscard]] F32 CubeFaceIndex(const Value& cube_coords);
|
[[nodiscard]] F32 CubeFaceIndex(const Value& cube_coords);
|
||||||
|
|
||||||
void EmitVertex();
|
void EmitVertex();
|
||||||
|
|
|
@ -375,7 +375,6 @@ OPCODE(ImageAtomicXor32, U32, Opaq
|
||||||
OPCODE(ImageAtomicExchange32, U32, Opaque, Opaque, U32, )
|
OPCODE(ImageAtomicExchange32, U32, Opaque, Opaque, U32, )
|
||||||
|
|
||||||
// Cube operations - optional, usable if profile.supports_native_cube_calc
|
// Cube operations - optional, usable if profile.supports_native_cube_calc
|
||||||
OPCODE(CubeFaceCoord, F32x2, F32x3, )
|
|
||||||
OPCODE(CubeFaceIndex, F32, F32x3, )
|
OPCODE(CubeFaceIndex, F32, F32x3, )
|
||||||
|
|
||||||
// Warp operations
|
// Warp operations
|
||||||
|
|
Loading…
Reference in a new issue