static uint gs_ua;
static uint gs_ub;
static uint gs_uc;
static uint2 gs_ua2;
static uint2 gs_ub2;
static uint2 gs_uc2;
static uint3 gs_ua3;
static uint3 gs_ub3;
static uint3 gs_uc3;
static uint4 gs_ua4;
static uint4 gs_ub4;
static uint4 gs_uc4;

float VertexShaderFunctionS(float inF0, float inF1, float inF2, int inI0)
{
    uint out_u1;

    // AllMemoryBarrier();                       // expected error: only valid in compute stage
    // AllMemoryBarrierWithGroupSync();          // expected error: only valid in compute stage
    // asdouble(inF0, inF1);                     // expected error: only integer inputs
    // CheckAccessFullyMapped(3.0);              // expected error: only valid on integers
    // CheckAccessFullyMapped(3);                // expected error: only valid in pixel & compute stages
    // clip(inF0);                               // expected error: only valid in pixel stage
    // countbits(inF0);                          // expected error: only integer inputs
    // cross(inF0, inF1);                        // expected error: only on float3 inputs
    // D3DCOLORtoUBYTE4(inF0);                   // expected error: only on float4 inputs
    // DeviceMemoryBarrier();                    // expected error: only valid in pixel & compute stages
    // DeviceMemoryBarrierWithGroupSync();       // expected error: only valid in compute stage
    // ddx(inF0);                                // expected error: only valid in pixel stage
    // ddx_coarse(inF0);                         // expected error: only valid in pixel stage
    // ddx_fine(inF0);                           // expected error: only valid in pixel stage
    // ddy(inF0);                                // expected error: only valid in pixel stage
    // ddy_coarse(inF0);                         // expected error: only valid in pixel stage
    // ddy_fine(inF0);                           // expected error: only valid in pixel stage
    // determinant(inF0);                        // expected error: only valid on mats
    // EvaluateAttributeAtCentroid(inF0);        // expected error: only interpolant
    // EvaluateAttributeAtSample(inF0, 2);       // expected error: only interpolant
    // EvaluateAttributeSnapped(inF0, int2(2));  // expected error: only interpolant
    // f16tof32(inF0);                           // expected error: only integer inputs
    // firstbithigh(inF0);                       // expected error: only integer inputs
    // firstbitlow(inF0);                        // expected error: only integer inputs
    // fma(inF0, inF1, inF2); // TODO: this might auto-promote: need to check against FXC
    // fwidth(inF0);                             // expected error: only valid in pixel stage
    // InterlockedAdd(gs_ua, gs_ub);             // expected error: only valid in pixel stage
    // InterlockedAdd(gs_ua, gs_ub, out_u1);     // expected error: only valid in pixel stage
    // InterlockedAnd(gs_ua, gs_ub);             // expected error: only valid in pixel stage
    // InterlockedAnd(gs_ua, gs_ub, out_u1);     // expected error: only valid in pixel stage
    // InterlockedCompareExchange(gs_ua, gs_ub, gs_uc, out_u1); // expected error: only valid in pixel stage
    // InterlockedExchange(gs_ua, gs_ub, out_u1);// expected error: only valid in pixel stage
    // InterlockedMax(gs_ua, gs_ub);             // expected error: only valid in pixel stage
    // InterlockedMax(gs_ua, gs_ub, out_u1);     // expected error: only valid in pixel stage
    // InterlockedMin(gs_ua, gs_ub);             // expected error: only valid in pixel stage
    // InterlockedMin(gs_ua, gs_ub, out_u1);     // expected error: only valid in pixel stage
    // InterlockedOr(gs_ua, gs_ub);              // expected error: only valid in pixel stage
    // InterlockedOr(gs_ua, gs_ub, out_u1);      // expected error: only valid in pixel stage
    // InterlockedXor(gs_ua, gs_ub);             // expected error: only valid in pixel stage
    // InterlockedXor(gs_ua, gs_ub, out_u1);     // expected error: only valid in pixel stage
    // GroupMemoryBarrier();                     // expected error: only valid in compute stage
    // GroupMemoryBarrierWithGroupSync();        // expected error: only valid in compute stage
    // length(inF0);                             // expect error: invalid on scalars
    // msad4(inF0, float2(0), float4(0));        // expected error: only integer inputs
    // normalize(inF0);                          // expect error: invalid on scalars
    // reflect(inF0, inF1);                      // expect error: invalid on scalars
    // refract(inF0, inF1, inF2);                // expect error: invalid on scalars
    // refract(float2(0), float2(0), float2(0)); // expected error: last parameter only scalar
    // reversebits(inF0);                        // expected error: only integer inputs
    // transpose(inF0);                          // expect error: only valid on mats

    // TODO: texture intrinsics, when we can declare samplers.

    return 0.0;
}

float1 VertexShaderFunction1(float1 inF0, float1 inF1, float1 inF2, int1 inI0)
{
    // TODO: ... add when float1 prototypes are generated

    // GetRenderTargetSamplePosition(inF0); // expected error: only integer inputs

    return 0.0;
}

float2 VertexShaderFunction2(float2 inF0, float2 inF1, float2 inF2, int2 inI0)
{
    uint2 out_u2;

    // asdouble(inF0, inF1);                                       // expected error: only integer inputs
    // CheckAccessFullyMapped(inF0);                               // expect error: only valid on scalars
    // countbits(inF0);                                            // expected error: only integer inputs
    // cross(inF0, inF1);                                          // expected error: only on float3 inputs
    // D3DCOLORtoUBYTE4(inF0);                                     // expected error: only on float4 inputs
    // ddx(inF0);                                                  // only valid in pixel stage
    // ddx_coarse(inF0);                                           // only valid in pixel stage
    // ddx_fine(inF0);                                             // only valid in pixel stage
    // ddy(inF0);                                                  // only valid in pixel stage
    // ddy_coarse(inF0);                                           // only valid in pixel stage
    // ddy_fine(inF0);                                             // only valid in pixel stage
    // determinant(inF0);                                          // expect error: only valid on mats
    // EvaluateAttributeAtCentroid(inF0);                          // expected error: only interpolant
    // EvaluateAttributeAtSample(inF0, 2);                         // expected error: only interpolant
    // EvaluateAttributeSnapped(inF0, int2(2));                    // expected error: only interpolant
    // f16tof32(inF0);                                             // expected error: only integer inputs
    // firstbithigh(inF0);                                         // expected error: only integer inputs
    // firstbitlow(inF0);                                          // expected error: only integer inputs
    // fma(inF0, inF1, inF2); // TODO: this might auto-promote: need to check against FXC
    // fwidth(inF0);                                               // expected error: only valid in pixel stage
    // InterlockedAdd(gs_ua2, gs_ub2);                             // expected error: only valid in pixel stage
    // InterlockedAdd(gs_ua2, gs_ub2, out_u2);                     // expected error: only valid in pixel stage
    // InterlockedAnd(gs_ua2, gs_ub2);                             // expected error: only valid in pixel stage
    // InterlockedAnd(gs_ua2, gs_ub2, out_u2);                     // expected error: only valid in pixel stage
    // InterlockedCompareExchange(gs_ua2, gs_ub2, gs_uc2, out_u2); // expected error: only valid in pixel stage
    // InterlockedExchange(gs_ua2, gs_ub2, out_u2);                // expected error: only valid in pixel stage
    // InterlockedMax(gs_ua2, gs_ub2);                             // expected error: only valid in pixel stage
    // InterlockedMax(gs_ua2, gs_ub2, out_u2);                     // expected error: only valid in pixel stage
    // InterlockedMin(gs_ua2, gs_ub2);                             // expected error: only valid in pixel stage
    // InterlockedMin(gs_ua2, gs_ub2, out_u2);                     // expected error: only valid in pixel stage
    // InterlockedOr(gs_ua2, gs_ub2);                              // expected error: only valid in pixel stage
    // InterlockedOr(gs_ua2, gs_ub2, out_u2);                      // expected error: only valid in pixel stage
    // InterlockedXor(gs_ua2, gs_ub2);                             // expected error: only valid in pixel stage
    // InterlockedXor(gs_ua2, gs_ub2, out_u2);                     // expected error: only valid in pixel stage
    // noise(inF0);                                                // expected error: only valid in pixel stage
    // reversebits(inF0);                                          // expected error: only integer inputs
    // transpose(inF0);                                            // expect error: only valid on mats

    // TODO: texture intrinsics, when we can declare samplers.

    return float2(1,2);
}

float3 VertexShaderFunction3(float3 inF0, float3 inF1, float3 inF2, int3 inI0)
{
    uint3 out_u3;

    // CheckAccessFullyMapped(inF0);                               // expect error: only valid on scalars
    // countbits(inF0);                                            // expected error: only integer inputs
    // ddx(inF0);                                                  // only valid in pixel stage
    // ddx_coarse(inF0);                                           // only valid in pixel stage
    // ddx_fine(inF0);                                             // only valid in pixel stage
    // ddy(inF0);                                                  // only valid in pixel stage
    // ddy_coarse(inF0);                                           // only valid in pixel stage
    // ddy_fine(inF0);                                             // only valid in pixel stage
    // D3DCOLORtoUBYTE4(inF0);                                     // expected error: only on float4 inputs
    // determinant(inF0);                                          // expect error: only valid on mats
    // EvaluateAttributeAtCentroid(inF0);                          // expected error: only interpolant
    // EvaluateAttributeAtSample(inF0, 2);                         // expected error: only interpolant
    // EvaluateAttributeSnapped(inF0, int2(2));                    // expected error: only interpolant
    // f16tof32(inF0);                                             // expected error: only integer inputs
    // firstbithigh(inF0);                                         // expected error: only integer inputs
    // firstbitlow(inF0);                                          // expected error: only integer inputs
    // fma(inF0, inF1, inF2); // TODO: this might auto-promote: need to check against FXC
    // fwidth(inF0);                                               // expected error: only valid in pixel stage
    // InterlockedAdd(gs_ua3, gs_ub3);                             // expected error: only valid in pixel stage
    // InterlockedAdd(gs_ua3, gs_ub3, out_u3);                     // expected error: only valid in pixel stage
    // InterlockedAnd(gs_ua3, gs_ub3);                             // expected error: only valid in pixel stage
    // InterlockedAnd(gs_ua3, gs_ub3, out_u3);                     // expected error: only valid in pixel stage
    // InterlockedCompareExchange(gs_ua3, gs_ub3, gs_uc3, out_u3); // expected error: only valid in pixel stage
    // InterlockedExchange(gs_ua3, gs_ub3, out_u3);                // expected error: only valid in pixel stage
    // InterlockedMax(gs_ua3, gs_ub3);                             // expected error: only valid in pixel stage
    // InterlockedMax(gs_ua3, gs_ub3, out_u3);                     // expected error: only valid in pixel stage
    // InterlockedMin(gs_ua3, gs_ub3);                             // expected error: only valid in pixel stage
    // InterlockedMin(gs_ua3, gs_ub3, out_u3);                     // expected error: only valid in pixel stage
    // InterlockedOr(gs_ua3, gs_ub3);                              // expected error: only valid in pixel stage
    // InterlockedOr(gs_ua3, gs_ub3, out_u3);                      // expected error: only valid in pixel stage
    // InterlockedXor(gs_ua3, gs_ub3);                             // expected error: only valid in pixel stage
    // InterlockedXor(gs_ua3, gs_ub3, out_u3);                     // expected error: only valid in pixel stage
    // noise(inF0);                                                // expected error: only valid in pixel stage
    // reversebits(inF0);                                          // expected error: only integer inputs
    // transpose(inF0);                                            // expect error: only valid on mats

    // TODO: texture intrinsics, when we can declare samplers.

    return float3(1,2,3);
}

float4 VertexShaderFunction(float4 inF0, float4 inF1, float4 inF2, int4 inI0)
{
    uint4 out_u4;

    // CheckAccessFullyMapped(inF0);                               // expect error: only valid on scalars
    // countbits(inF0);                                            // expected error: only integer inputs
    // cross(inF0, inF1);                                          // expected error: only on float3 inputs
    // determinant(inF0);                                          // expect error: only valid on mats
    // ddx(inF0);                                                  // only valid in pixel stage
    // ddx_coarse(inF0);                                           // only valid in pixel stage
    // ddx_fine(inF0);                                             // only valid in pixel stage
    // ddy(inF0);                                                  // only valid in pixel stage
    // ddy_coarse(inF0);                                           // only valid in pixel stage
    // ddy_fine(inF0);                                             // only valid in pixel stage
    // EvaluateAttributeAtCentroid(inF0);                          // expected error: only interpolant
    // EvaluateAttributeAtSample(inF0, 2);                         // expected error: only interpolant
    // EvaluateAttributeSnapped(inF0, int2(2));                    // expected error: only interpolant
    // f16tof32(inF0);                                             // expected error: only integer inputs
    // firstbithigh(inF0);                                         // expected error: only integer inputs
    // firstbitlow(inF0);                                          // expected error: only integer inputs
    // fma(inF0, inF1, inF2); // TODO: this might auto-promote: need to check against FXC
    // fwidth(inF0);                                               // expected error: only valid in pixel stage
    // InterlockedAdd(gs_ua4, gs_ub4);                             // expected error: only valid in pixel stage
    // InterlockedAdd(gs_ua4, gs_ub4, out_u4);                     // expected error: only valid in pixel stage
    // InterlockedAnd(gs_ua4, gs_ub4);                             // expected error: only valid in pixel stage
    // InterlockedAnd(gs_ua4, gs_ub4, out_u4);                     // expected error: only valid in pixel stage
    // InterlockedCompareExchange(gs_ua4, gs_ub4, gs_uc4, out_u4); // expected error: only valid in pixel stage
    // InterlockedExchange(gs_ua4, gs_ub4, out_u4);                // expected error: only valid in pixel stage
    // InterlockedMax(gs_ua4, gs_ub4);                             // expected error: only valid in pixel stage
    // InterlockedMax(gs_ua4, gs_ub4, out_u4);                     // expected error: only valid in pixel stage
    // InterlockedMin(gs_ua4, gs_ub4);                             // expected error: only valid in pixel stage
    // InterlockedMin(gs_ua4, gs_ub4, out_u4);                     // expected error: only valid in pixel stage
    // InterlockedOr(gs_ua4, gs_ub4);                              // expected error: only valid in pixel stage
    // InterlockedOr(gs_ua4, gs_ub4, out_u4);                      // expected error: only valid in pixel stage
    // InterlockedXor(gs_ua4, gs_ub4);                             // expected error: only valid in pixel stage
    // InterlockedXor(gs_ua4, gs_ub4, out_u4);                     // expected error: only valid in pixel stage
    // noise(inF0);                                                // expected error: only valid in pixel stage
    // reversebits(inF0);                                          // expected error: only integer inputs
    // transpose(inF0);                                            // expect error: only valid on mats

    // TODO: texture intrinsics, when we can declare samplers.

    return float4(1,2,3,4);
}

// TODO: FXC doesn't accept this with (), but glslang doesn't accept it without.
#define MATFNS()

// TODO: turn on non-square matrix tests when protos are available.

float2x2 VertexShaderFunction2x2(float2x2 inF0, float2x2 inF1, float2x2 inF2)
{
    // TODO: FXC doesn't accept this with (), but glslang doesn't accept it without.
    MATFNS()

    return float2x2(2,2,2,2);
}

float3x3 VertexShaderFunction3x3(float3x3 inF0, float3x3 inF1, float3x3 inF2)
{
    // TODO: FXC doesn't accept this with (), but glslang doesn't accept it without.
    MATFNS()

    return float3x3(3,3,3,3,3,3,3,3,3);
}

float4x4 VertexShaderFunction4x4(float4x4 inF0, float4x4 inF1, float4x4 inF2)
{
    // TODO: FXC doesn't accept this with (), but glslang doesn't accept it without.
    MATFNS()

    return float4x4(4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4);
}