1617a3babSopenharmony_civoid ComputeShaderFunctionS(float inF0, float inF1, float inF2, int inI0) 2617a3babSopenharmony_ci{ 3617a3babSopenharmony_ci uint out_u1; 4617a3babSopenharmony_ci 5617a3babSopenharmony_ci // AllMemoryBarrier(); // invalid in fragment stage TODO: parser currently crashes on empty arg list 6617a3babSopenharmony_ci // AllMemoryBarrierWithGroupSync(); // invalid in fragment stage TODO: parser currently crashes on empty arg list 7617a3babSopenharmony_ci // asdouble(inF0, inF1); // expected error: only integer inputs 8617a3babSopenharmony_ci // CheckAccessFullyMapped(3.0); // expected error: only valid on integers 9617a3babSopenharmony_ci // clip(inF0); // expected error: only valid in pixel stage 10617a3babSopenharmony_ci // countbits(inF0); // expected error: only integer inputs 11617a3babSopenharmony_ci // cross(inF0, inF1); // expected error: only on float3 inputs 12617a3babSopenharmony_ci // D3DCOLORtoUBYTE4(inF0); // expected error: only on float4 inputs 13617a3babSopenharmony_ci // ddx(inF0); // expected error: only valid in pixel stage 14617a3babSopenharmony_ci // ddx_coarse(inF0); // expected error: only valid in pixel stage 15617a3babSopenharmony_ci // ddx_fine(inF0); // expected error: only valid in pixel stage 16617a3babSopenharmony_ci // ddy(inF0); // expected error: only valid in pixel stage 17617a3babSopenharmony_ci // ddy_coarse(inF0); // expected error: only valid in pixel stage 18617a3babSopenharmony_ci // ddy_fine(inF0); // expected error: only valid in pixel stage 19617a3babSopenharmony_ci // determinant(inF0); // expected error: only valid on mats 20617a3babSopenharmony_ci // EvaluateAttributeAtCentroid(inF0); // expected error: only interpolant 21617a3babSopenharmony_ci // EvaluateAttributeAtSample(inF0, 2); // expected error: only interpolant 22617a3babSopenharmony_ci // EvaluateAttributeSnapped(inF0, int2(2)); // expected error: only interpolant 23617a3babSopenharmony_ci // f16tof32(inF0); // expected error: only integer inputs 24617a3babSopenharmony_ci // firstbithigh(inF0); // expected error: only integer inputs 25617a3babSopenharmony_ci // firstbitlow(inF0); // expected error: only integer inputs 26617a3babSopenharmony_ci // fma(inF0, inF1, inF2); // TODO: this might auto-promote: need to check against FXC 27617a3babSopenharmony_ci // fwidth(inF0); // expected error: only valid in pixel stage 28617a3babSopenharmony_ci // InterlockedAdd(gs_ua, gs_ub); // expected error: only valid in pixel stage 29617a3babSopenharmony_ci // InterlockedAdd(gs_ua, gs_ub, out_u1); // expected error: only valid in pixel stage 30617a3babSopenharmony_ci // InterlockedAnd(gs_ua, gs_ub); // expected error: only valid in pixel stage 31617a3babSopenharmony_ci // InterlockedAnd(gs_ua, gs_ub, out_u1); // expected error: only valid in pixel stage 32617a3babSopenharmony_ci // InterlockedCompareExchange(gs_ua, gs_ub, gs_uc, out_u1); // expected error: only valid in pixel stage 33617a3babSopenharmony_ci // InterlockedExchange(gs_ua, gs_ub, out_u1);// expected error: only valid in pixel stage 34617a3babSopenharmony_ci // InterlockedMax(gs_ua, gs_ub); // expected error: only valid in pixel stage 35617a3babSopenharmony_ci // InterlockedMax(gs_ua, gs_ub, out_u1); // expected error: only valid in pixel stage 36617a3babSopenharmony_ci // InterlockedMin(gs_ua, gs_ub); // expected error: only valid in pixel stage 37617a3babSopenharmony_ci // InterlockedMin(gs_ua, gs_ub, out_u1); // expected error: only valid in pixel stage 38617a3babSopenharmony_ci // InterlockedOr(gs_ua, gs_ub); // expected error: only valid in pixel stage 39617a3babSopenharmony_ci // InterlockedOr(gs_ua, gs_ub, out_u1); // expected error: only valid in pixel stage 40617a3babSopenharmony_ci // InterlockedXor(gs_ua, gs_ub); // expected error: only valid in pixel stage 41617a3babSopenharmony_ci // InterlockedXor(gs_ua, gs_ub, out_u1); // expected error: only valid in pixel stage 42617a3babSopenharmony_ci // length(inF0); // expect error: invalid on scalars 43617a3babSopenharmony_ci // msad4(inF0, float2(0), float4(0)); // expected error: only integer inputs 44617a3babSopenharmony_ci // normalize(inF0); // expect error: invalid on scalars 45617a3babSopenharmony_ci // reflect(inF0, inF1); // expect error: invalid on scalars 46617a3babSopenharmony_ci // refract(inF0, inF1, inF2); // expect error: invalid on scalars 47617a3babSopenharmony_ci // refract(float2(0), float2(0), float2(0)); // expected error: last parameter only scalar 48617a3babSopenharmony_ci // reversebits(inF0); // expected error: only integer inputs 49617a3babSopenharmony_ci // transpose(inF0); // expect error: only valid on mats 50617a3babSopenharmony_ci 51617a3babSopenharmony_ci // TODO: texture intrinsics, when we can declare samplers. 52617a3babSopenharmony_ci} 53617a3babSopenharmony_ci 54617a3babSopenharmony_civoid ComputeShaderFunction1(float1 inF0, float1 inF1, float1 inF2, int1 inI0) 55617a3babSopenharmony_ci{ 56617a3babSopenharmony_ci // TODO: ... add when float1 prototypes are generated 57617a3babSopenharmony_ci 58617a3babSopenharmony_ci // GetRenderTargetSamplePosition(inF0); // expected error: only integer inputs 59617a3babSopenharmony_ci} 60617a3babSopenharmony_ci 61617a3babSopenharmony_civoid ComputeShaderFunction2(float2 inF0, float2 inF1, float2 inF2, int2 inI0) 62617a3babSopenharmony_ci{ 63617a3babSopenharmony_ci uint2 out_u2; 64617a3babSopenharmony_ci 65617a3babSopenharmony_ci // asdouble(inF0, inF1); // expected error: only integer inputs 66617a3babSopenharmony_ci // CheckAccessFullyMapped(inF0); // expect error: only valid on scalars 67617a3babSopenharmony_ci // countbits(inF0); // expected error: only integer inputs 68617a3babSopenharmony_ci // cross(inF0, inF1); // expected error: only on float3 inputs 69617a3babSopenharmony_ci // D3DCOLORtoUBYTE4(inF0); // expected error: only on float4 inputs 70617a3babSopenharmony_ci // ddx(inF0); // only valid in pixel stage 71617a3babSopenharmony_ci // ddx_coarse(inF0); // only valid in pixel stage 72617a3babSopenharmony_ci // ddx_fine(inF0); // only valid in pixel stage 73617a3babSopenharmony_ci // ddy(inF0); // only valid in pixel stage 74617a3babSopenharmony_ci // ddy_coarse(inF0); // only valid in pixel stage 75617a3babSopenharmony_ci // ddy_fine(inF0); // only valid in pixel stage 76617a3babSopenharmony_ci // determinant(inF0); // expect error: only valid on mats 77617a3babSopenharmony_ci // EvaluateAttributeAtCentroid(inF0); // expected error: only interpolant 78617a3babSopenharmony_ci // EvaluateAttributeAtSample(inF0, 2); // expected error: only interpolant 79617a3babSopenharmony_ci // EvaluateAttributeSnapped(inF0, int2(2)); // expected error: only interpolant 80617a3babSopenharmony_ci // f16tof32(inF0); // expected error: only integer inputs 81617a3babSopenharmony_ci // firstbithigh(inF0); // expected error: only integer inputs 82617a3babSopenharmony_ci // firstbitlow(inF0); // expected error: only integer inputs 83617a3babSopenharmony_ci // fma(inF0, inF1, inF2); // TODO: this might auto-promote: need to check against FXC 84617a3babSopenharmony_ci // fwidth(inF0); // expected error: only valid in pixel stage 85617a3babSopenharmony_ci // InterlockedAdd(gs_ua2, gs_ub2); // expected error: only valid in pixel stage 86617a3babSopenharmony_ci // InterlockedAdd(gs_ua2, gs_ub2, out_u2); // expected error: only valid in pixel stage 87617a3babSopenharmony_ci // InterlockedAnd(gs_ua2, gs_ub2); // expected error: only valid in pixel stage 88617a3babSopenharmony_ci // InterlockedAnd(gs_ua2, gs_ub2, out_u2); // expected error: only valid in pixel stage 89617a3babSopenharmony_ci // InterlockedCompareExchange(gs_ua2, gs_ub2, gs_uc2, out_u2); // expected error: only valid in pixel stage 90617a3babSopenharmony_ci // InterlockedExchange(gs_ua2, gs_ub2, out_u2);// expected error: only valid in pixel stage 91617a3babSopenharmony_ci // InterlockedMax(gs_ua2, gs_ub2); // expected error: only valid in pixel stage 92617a3babSopenharmony_ci // InterlockedMax(gs_ua2, gs_ub2, out_u2); // expected error: only valid in pixel stage 93617a3babSopenharmony_ci // InterlockedMin(gs_ua2, gs_ub2); // expected error: only valid in pixel stage 94617a3babSopenharmony_ci // InterlockedMin(gs_ua2, gs_ub2, out_u2); // expected error: only valid in pixel stage 95617a3babSopenharmony_ci // InterlockedOr(gs_ua2, gs_ub2); // expected error: only valid in pixel stage 96617a3babSopenharmony_ci // InterlockedOr(gs_ua2, gs_ub2, out_u2); // expected error: only valid in pixel stage 97617a3babSopenharmony_ci // InterlockedXor(gs_ua2, gs_ub2); // expected error: only valid in pixel stage 98617a3babSopenharmony_ci // InterlockedXor(gs_ua2, gs_ub2, out_u2); // expected error: only valid in pixel stage 99617a3babSopenharmony_ci // noise(inF0); // expected error: only valid in pixel stage 100617a3babSopenharmony_ci // reversebits(inF0); // expected error: only integer inputs 101617a3babSopenharmony_ci // transpose(inF0); // expect error: only valid on mats 102617a3babSopenharmony_ci 103617a3babSopenharmony_ci // TODO: texture intrinsics, when we can declare samplers. 104617a3babSopenharmony_ci} 105617a3babSopenharmony_ci 106617a3babSopenharmony_civoid ComputeShaderFunction3(float3 inF0, float3 inF1, float3 inF2, int3 inI0) 107617a3babSopenharmony_ci{ 108617a3babSopenharmony_ci uint3 out_u3; 109617a3babSopenharmony_ci 110617a3babSopenharmony_ci // CheckAccessFullyMapped(inF0); // expect error: only valid on scalars 111617a3babSopenharmony_ci // countbits(inF0); // expected error: only integer inputs 112617a3babSopenharmony_ci // ddx(inF0); // only valid in pixel stage 113617a3babSopenharmony_ci // ddx_coarse(inF0); // only valid in pixel stage 114617a3babSopenharmony_ci // ddx_fine(inF0); // only valid in pixel stage 115617a3babSopenharmony_ci // ddy(inF0); // only valid in pixel stage 116617a3babSopenharmony_ci // ddy_coarse(inF0); // only valid in pixel stage 117617a3babSopenharmony_ci // ddy_fine(inF0); // only valid in pixel stage 118617a3babSopenharmony_ci // D3DCOLORtoUBYTE4(inF0); // expected error: only on float4 inputs 119617a3babSopenharmony_ci // determinant(inF0); // expect error: only valid on mats 120617a3babSopenharmony_ci // EvaluateAttributeAtCentroid(inF0); // expected error: only interpolant 121617a3babSopenharmony_ci // EvaluateAttributeAtSample(inF0, 2); // expected error: only interpolant 122617a3babSopenharmony_ci // EvaluateAttributeSnapped(inF0, int2(2)); // expected error: only interpolant 123617a3babSopenharmony_ci // f16tof32(inF0); // expected error: only integer inputs 124617a3babSopenharmony_ci // firstbithigh(inF0); // expected error: only integer inputs 125617a3babSopenharmony_ci // firstbitlow(inF0); // expected error: only integer inputs 126617a3babSopenharmony_ci // fma(inF0, inF1, inF2); // TODO: this might auto-promote: need to check against FXC 127617a3babSopenharmony_ci // fwidth(inF0); // expected error: only valid in pixel stage 128617a3babSopenharmony_ci // InterlockedAdd(gs_ua3, gs_ub3); // expected error: only valid in pixel stage 129617a3babSopenharmony_ci // InterlockedAdd(gs_ua3, gs_ub3, out_u3); // expected error: only valid in pixel stage 130617a3babSopenharmony_ci // InterlockedAnd(gs_ua3, gs_ub3); // expected error: only valid in pixel stage 131617a3babSopenharmony_ci // InterlockedAnd(gs_ua3, gs_ub3, out_u3); // expected error: only valid in pixel stage 132617a3babSopenharmony_ci // InterlockedCompareExchange(gs_ua3, gs_ub3, gs_uc3, out_u3); // expected error: only valid in pixel stage 133617a3babSopenharmony_ci // InterlockedExchange(gs_ua3, gs_ub3, out_u3); // expected error: only valid in pixel stage 134617a3babSopenharmony_ci // InterlockedMax(gs_ua3, gs_ub3); // expected error: only valid in pixel stage 135617a3babSopenharmony_ci // InterlockedMax(gs_ua3, gs_ub3, out_u3); // expected error: only valid in pixel stage 136617a3babSopenharmony_ci // InterlockedMin(gs_ua3, gs_ub3); // expected error: only valid in pixel stage 137617a3babSopenharmony_ci // InterlockedMin(gs_ua3, gs_ub3, out_u3); // expected error: only valid in pixel stage 138617a3babSopenharmony_ci // InterlockedOr(gs_ua3, gs_ub3); // expected error: only valid in pixel stage 139617a3babSopenharmony_ci // InterlockedOr(gs_ua3, gs_ub3, out_u3); // expected error: only valid in pixel stage 140617a3babSopenharmony_ci // InterlockedXor(gs_ua3, gs_ub3); // expected error: only valid in pixel stage 141617a3babSopenharmony_ci // InterlockedXor(gs_ua3, gs_ub3, out_u3); // expected error: only valid in pixel stage 142617a3babSopenharmony_ci // noise(inF0); // expected error: only valid in pixel stage 143617a3babSopenharmony_ci // reversebits(inF0); // expected error: only integer inputs 144617a3babSopenharmony_ci // transpose(inF0); // expect error: only valid on mats 145617a3babSopenharmony_ci 146617a3babSopenharmony_ci // TODO: texture intrinsics, when we can declare samplers. 147617a3babSopenharmony_ci} 148617a3babSopenharmony_ci 149617a3babSopenharmony_civoid ComputeShaderFunction(float4 inF0, float4 inF1, float4 inF2, int4 inI0) 150617a3babSopenharmony_ci{ 151617a3babSopenharmony_ci uint4 out_u4; 152617a3babSopenharmony_ci 153617a3babSopenharmony_ci // CheckAccessFullyMapped(inF0); // expect error: only valid on scalars 154617a3babSopenharmony_ci // countbits(inF0); // expected error: only integer inputs 155617a3babSopenharmony_ci // cross(inF0, inF1); // expected error: only on float3 inputs 156617a3babSopenharmony_ci // determinant(inF0); // expect error: only valid on mats 157617a3babSopenharmony_ci // ddx(inF0); // only valid in pixel stage 158617a3babSopenharmony_ci // ddx_coarse(inF0); // only valid in pixel stage 159617a3babSopenharmony_ci // ddx_fine(inF0); // only valid in pixel stage 160617a3babSopenharmony_ci // ddy(inF0); // only valid in pixel stage 161617a3babSopenharmony_ci // ddy_coarse(inF0); // only valid in pixel stage 162617a3babSopenharmony_ci // ddy_fine(inF0); // only valid in pixel stage 163617a3babSopenharmony_ci // EvaluateAttributeAtCentroid(inF0); // expected error: only valid in pixel stage 164617a3babSopenharmony_ci // EvaluateAttributeAtSample(inF0, 2); // expected error: only valid in pixel stage 165617a3babSopenharmony_ci // EvaluateAttributeSnapped(inF0, int2(2)); // expected error: only valid in pixel stage 166617a3babSopenharmony_ci // f16tof32(inF0); // expected error: only integer inputs 167617a3babSopenharmony_ci // firstbithigh(inF0); // expected error: only integer inputs 168617a3babSopenharmony_ci // firstbitlow(inF0); // expected error: only integer inputs 169617a3babSopenharmony_ci // fma(inF0, inF1, inF2); // TODO: this might auto-promote: need to check against FXC 170617a3babSopenharmony_ci // fwidth(inF0); // expected error: only valid in pixel stage 171617a3babSopenharmony_ci // InterlockedAdd(gs_ua4, gs_ub4); // expected error: only valid in pixel stage 172617a3babSopenharmony_ci // InterlockedAdd(gs_ua4, gs_ub4, out_u4); // expected error: only valid in pixel stage 173617a3babSopenharmony_ci // InterlockedAnd(gs_ua4, gs_ub4); // expected error: only valid in pixel stage 174617a3babSopenharmony_ci // InterlockedAnd(gs_ua4, gs_ub4, out_u4); // expected error: only valid in pixel stage 175617a3babSopenharmony_ci // InterlockedCompareExchange(gs_ua4, gs_ub4, gs_uc4, out_u4); // expected error: only valid in pixel stage 176617a3babSopenharmony_ci // InterlockedExchange(gs_ua4, gs_ub4, out_u4); // expected error: only valid in pixel stage 177617a3babSopenharmony_ci // InterlockedMax(gs_ua4, gs_ub4); // expected error: only valid in pixel stage 178617a3babSopenharmony_ci // InterlockedMax(gs_ua4, gs_ub4, out_u4); // expected error: only valid in pixel stage 179617a3babSopenharmony_ci // InterlockedMin(gs_ua4, gs_ub4); // expected error: only valid in pixel stage 180617a3babSopenharmony_ci // InterlockedMin(gs_ua4, gs_ub4, out_u4); // expected error: only valid in pixel stage 181617a3babSopenharmony_ci // InterlockedOr(gs_ua4, gs_ub4); // expected error: only valid in pixel stage 182617a3babSopenharmony_ci // InterlockedOr(gs_ua4, gs_ub4, out_u4); // expected error: only valid in pixel stage 183617a3babSopenharmony_ci // InterlockedXor(gs_ua4, gs_ub4); // expected error: only valid in pixel stage 184617a3babSopenharmony_ci // InterlockedXor(gs_ua4, gs_ub4, out_u4); // expected error: only valid in pixel stage 185617a3babSopenharmony_ci // noise(inF0); // expected error: only valid in pixel stage 186617a3babSopenharmony_ci // reversebits(inF0); // expected error: only integer inputs 187617a3babSopenharmony_ci // transpose(inF0); // expect error: only valid on mats 188617a3babSopenharmony_ci 189617a3babSopenharmony_ci // TODO: texture intrinsics, when we can declare samplers. 190617a3babSopenharmony_ci} 191617a3babSopenharmony_ci 192