mirror of
https://github.com/shadps4-emu/shadPS4.git
synced 2025-08-05 00:42:48 +00:00
shader_recompiler: Reduce CompositeConstruct to constants where possible.
This commit is contained in:
parent
4d81b41462
commit
11eb7413fb
@ -6,16 +6,22 @@
|
|||||||
|
|
||||||
namespace Shader::Backend::SPIRV {
|
namespace Shader::Backend::SPIRV {
|
||||||
|
|
||||||
Id EmitCompositeConstructU32x2(EmitContext& ctx, Id e1, Id e2) {
|
template <typename... Args>
|
||||||
return ctx.OpCompositeConstruct(ctx.U32[2], e1, e2);
|
Id EmitCompositeConstruct(EmitContext& ctx, IR::Inst* inst, Args&&... args) {
|
||||||
|
return inst->AreAllArgsImmediates() ? ctx.ConstantComposite(args...)
|
||||||
|
: ctx.OpCompositeConstruct(args...);
|
||||||
}
|
}
|
||||||
|
|
||||||
Id EmitCompositeConstructU32x3(EmitContext& ctx, Id e1, Id e2, Id e3) {
|
Id EmitCompositeConstructU32x2(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2) {
|
||||||
return ctx.OpCompositeConstruct(ctx.U32[3], e1, e2, e3);
|
return EmitCompositeConstruct(ctx, inst, ctx.U32[2], e1, e2);
|
||||||
}
|
}
|
||||||
|
|
||||||
Id EmitCompositeConstructU32x4(EmitContext& ctx, Id e1, Id e2, Id e3, Id e4) {
|
Id EmitCompositeConstructU32x3(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2, Id e3) {
|
||||||
return ctx.OpCompositeConstruct(ctx.U32[4], e1, e2, e3, e4);
|
return EmitCompositeConstruct(ctx, inst, ctx.U32[3], e1, e2, e3);
|
||||||
|
}
|
||||||
|
|
||||||
|
Id EmitCompositeConstructU32x4(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2, Id e3, Id e4) {
|
||||||
|
return EmitCompositeConstruct(ctx, inst, ctx.U32[4], e1, e2, e3, e4);
|
||||||
}
|
}
|
||||||
|
|
||||||
Id EmitCompositeExtractU32x2(EmitContext& ctx, Id composite, u32 index) {
|
Id EmitCompositeExtractU32x2(EmitContext& ctx, Id composite, u32 index) {
|
||||||
@ -56,16 +62,16 @@ Id EmitCompositeShuffleU32x4(EmitContext& ctx, Id composite1, Id composite2, u32
|
|||||||
return ctx.OpVectorShuffle(ctx.U32[4], composite1, composite2, comp0, comp1, comp2, comp3);
|
return ctx.OpVectorShuffle(ctx.U32[4], composite1, composite2, comp0, comp1, comp2, comp3);
|
||||||
}
|
}
|
||||||
|
|
||||||
Id EmitCompositeConstructF16x2(EmitContext& ctx, Id e1, Id e2) {
|
Id EmitCompositeConstructF16x2(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2) {
|
||||||
return ctx.OpCompositeConstruct(ctx.F16[2], e1, e2);
|
return EmitCompositeConstruct(ctx, inst, ctx.F16[2], e1, e2);
|
||||||
}
|
}
|
||||||
|
|
||||||
Id EmitCompositeConstructF16x3(EmitContext& ctx, Id e1, Id e2, Id e3) {
|
Id EmitCompositeConstructF16x3(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2, Id e3) {
|
||||||
return ctx.OpCompositeConstruct(ctx.F16[3], e1, e2, e3);
|
return EmitCompositeConstruct(ctx, inst, ctx.F16[3], e1, e2, e3);
|
||||||
}
|
}
|
||||||
|
|
||||||
Id EmitCompositeConstructF16x4(EmitContext& ctx, Id e1, Id e2, Id e3, Id e4) {
|
Id EmitCompositeConstructF16x4(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2, Id e3, Id e4) {
|
||||||
return ctx.OpCompositeConstruct(ctx.F16[4], e1, e2, e3, e4);
|
return EmitCompositeConstruct(ctx, inst, ctx.F16[4], e1, e2, e3, e4);
|
||||||
}
|
}
|
||||||
|
|
||||||
Id EmitCompositeExtractF16x2(EmitContext& ctx, Id composite, u32 index) {
|
Id EmitCompositeExtractF16x2(EmitContext& ctx, Id composite, u32 index) {
|
||||||
@ -106,16 +112,16 @@ Id EmitCompositeShuffleF16x4(EmitContext& ctx, Id composite1, Id composite2, u32
|
|||||||
return ctx.OpVectorShuffle(ctx.F16[4], composite1, composite2, comp0, comp1, comp2, comp3);
|
return ctx.OpVectorShuffle(ctx.F16[4], composite1, composite2, comp0, comp1, comp2, comp3);
|
||||||
}
|
}
|
||||||
|
|
||||||
Id EmitCompositeConstructF32x2(EmitContext& ctx, Id e1, Id e2) {
|
Id EmitCompositeConstructF32x2(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2) {
|
||||||
return ctx.OpCompositeConstruct(ctx.F32[2], e1, e2);
|
return EmitCompositeConstruct(ctx, inst, ctx.F32[2], e1, e2);
|
||||||
}
|
}
|
||||||
|
|
||||||
Id EmitCompositeConstructF32x3(EmitContext& ctx, Id e1, Id e2, Id e3) {
|
Id EmitCompositeConstructF32x3(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2, Id e3) {
|
||||||
return ctx.OpCompositeConstruct(ctx.F32[3], e1, e2, e3);
|
return EmitCompositeConstruct(ctx, inst, ctx.F32[3], e1, e2, e3);
|
||||||
}
|
}
|
||||||
|
|
||||||
Id EmitCompositeConstructF32x4(EmitContext& ctx, Id e1, Id e2, Id e3, Id e4) {
|
Id EmitCompositeConstructF32x4(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2, Id e3, Id e4) {
|
||||||
return ctx.OpCompositeConstruct(ctx.F32[4], e1, e2, e3, e4);
|
return EmitCompositeConstruct(ctx, inst, ctx.F32[4], e1, e2, e3, e4);
|
||||||
}
|
}
|
||||||
|
|
||||||
Id EmitCompositeExtractF32x2(EmitContext& ctx, Id composite, u32 index) {
|
Id EmitCompositeExtractF32x2(EmitContext& ctx, Id composite, u32 index) {
|
||||||
|
@ -118,9 +118,9 @@ Id EmitSharedAtomicSMin32(EmitContext& ctx, Id offset, Id value);
|
|||||||
Id EmitSharedAtomicAnd32(EmitContext& ctx, Id offset, Id value);
|
Id EmitSharedAtomicAnd32(EmitContext& ctx, Id offset, Id value);
|
||||||
Id EmitSharedAtomicOr32(EmitContext& ctx, Id offset, Id value);
|
Id EmitSharedAtomicOr32(EmitContext& ctx, Id offset, Id value);
|
||||||
Id EmitSharedAtomicXor32(EmitContext& ctx, Id offset, Id value);
|
Id EmitSharedAtomicXor32(EmitContext& ctx, Id offset, Id value);
|
||||||
Id EmitCompositeConstructU32x2(EmitContext& ctx, Id e1, Id e2);
|
Id EmitCompositeConstructU32x2(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2);
|
||||||
Id EmitCompositeConstructU32x3(EmitContext& ctx, Id e1, Id e2, Id e3);
|
Id EmitCompositeConstructU32x3(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2, Id e3);
|
||||||
Id EmitCompositeConstructU32x4(EmitContext& ctx, Id e1, Id e2, Id e3, Id e4);
|
Id EmitCompositeConstructU32x4(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2, Id e3, Id e4);
|
||||||
Id EmitCompositeExtractU32x2(EmitContext& ctx, Id composite, u32 index);
|
Id EmitCompositeExtractU32x2(EmitContext& ctx, Id composite, u32 index);
|
||||||
Id EmitCompositeExtractU32x3(EmitContext& ctx, Id composite, u32 index);
|
Id EmitCompositeExtractU32x3(EmitContext& ctx, Id composite, u32 index);
|
||||||
Id EmitCompositeExtractU32x4(EmitContext& ctx, Id composite, u32 index);
|
Id EmitCompositeExtractU32x4(EmitContext& ctx, Id composite, u32 index);
|
||||||
@ -132,9 +132,9 @@ Id EmitCompositeShuffleU32x3(EmitContext& ctx, Id composite1, Id composite2, u32
|
|||||||
u32 comp2);
|
u32 comp2);
|
||||||
Id EmitCompositeShuffleU32x4(EmitContext& ctx, Id composite1, Id composite2, u32 comp0, u32 comp1,
|
Id EmitCompositeShuffleU32x4(EmitContext& ctx, Id composite1, Id composite2, u32 comp0, u32 comp1,
|
||||||
u32 comp2, u32 comp3);
|
u32 comp2, u32 comp3);
|
||||||
Id EmitCompositeConstructF16x2(EmitContext& ctx, Id e1, Id e2);
|
Id EmitCompositeConstructF16x2(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2);
|
||||||
Id EmitCompositeConstructF16x3(EmitContext& ctx, Id e1, Id e2, Id e3);
|
Id EmitCompositeConstructF16x3(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2, Id e3);
|
||||||
Id EmitCompositeConstructF16x4(EmitContext& ctx, Id e1, Id e2, Id e3, Id e4);
|
Id EmitCompositeConstructF16x4(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2, Id e3, Id e4);
|
||||||
Id EmitCompositeExtractF16x2(EmitContext& ctx, Id composite, u32 index);
|
Id EmitCompositeExtractF16x2(EmitContext& ctx, Id composite, u32 index);
|
||||||
Id EmitCompositeExtractF16x3(EmitContext& ctx, Id composite, u32 index);
|
Id EmitCompositeExtractF16x3(EmitContext& ctx, Id composite, u32 index);
|
||||||
Id EmitCompositeExtractF16x4(EmitContext& ctx, Id composite, u32 index);
|
Id EmitCompositeExtractF16x4(EmitContext& ctx, Id composite, u32 index);
|
||||||
@ -146,9 +146,9 @@ Id EmitCompositeShuffleF16x3(EmitContext& ctx, Id composite1, Id composite2, u32
|
|||||||
u32 comp2);
|
u32 comp2);
|
||||||
Id EmitCompositeShuffleF16x4(EmitContext& ctx, Id composite1, Id composite2, u32 comp0, u32 comp1,
|
Id EmitCompositeShuffleF16x4(EmitContext& ctx, Id composite1, Id composite2, u32 comp0, u32 comp1,
|
||||||
u32 comp2, u32 comp3);
|
u32 comp2, u32 comp3);
|
||||||
Id EmitCompositeConstructF32x2(EmitContext& ctx, Id e1, Id e2);
|
Id EmitCompositeConstructF32x2(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2);
|
||||||
Id EmitCompositeConstructF32x3(EmitContext& ctx, Id e1, Id e2, Id e3);
|
Id EmitCompositeConstructF32x3(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2, Id e3);
|
||||||
Id EmitCompositeConstructF32x4(EmitContext& ctx, Id e1, Id e2, Id e3, Id e4);
|
Id EmitCompositeConstructF32x4(EmitContext& ctx, IR::Inst* inst, Id e1, Id e2, Id e3, Id e4);
|
||||||
Id EmitCompositeExtractF32x2(EmitContext& ctx, Id composite, u32 index);
|
Id EmitCompositeExtractF32x2(EmitContext& ctx, Id composite, u32 index);
|
||||||
Id EmitCompositeExtractF32x3(EmitContext& ctx, Id composite, u32 index);
|
Id EmitCompositeExtractF32x3(EmitContext& ctx, Id composite, u32 index);
|
||||||
Id EmitCompositeExtractF32x4(EmitContext& ctx, Id composite, u32 index);
|
Id EmitCompositeExtractF32x4(EmitContext& ctx, Id composite, u32 index);
|
||||||
|
Loading…
Reference in New Issue
Block a user