hlsl.rw.vec2.bracket.frag 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. SamplerState g_sSamp : register(s0);
  2. RWTexture1D <float2> g_tTex1df2;
  3. RWTexture1D <int2> g_tTex1di2;
  4. RWTexture1D <uint2> g_tTex1du2;
  5. RWTexture2D <float2> g_tTex2df2;
  6. RWTexture2D <int2> g_tTex2di2;
  7. RWTexture2D <uint2> g_tTex2du2;
  8. RWTexture3D <float2> g_tTex3df2;
  9. RWTexture3D <int2> g_tTex3di2;
  10. RWTexture3D <uint2> g_tTex3du2;
  11. RWTexture1DArray <float2> g_tTex1df2a;
  12. RWTexture1DArray <int2> g_tTex1di2a;
  13. RWTexture1DArray <uint2> g_tTex1du2a;
  14. RWTexture2DArray <float2> g_tTex2df2a;
  15. RWTexture2DArray <int2> g_tTex2di2a;
  16. RWTexture2DArray <uint2> g_tTex2du2a;
  17. struct PS_OUTPUT
  18. {
  19. float4 Color : SV_Target0;
  20. };
  21. uniform int c1;
  22. uniform int2 c2;
  23. uniform int3 c3;
  24. uniform int4 c4;
  25. uniform int o1;
  26. uniform int2 o2;
  27. uniform int3 o3;
  28. uniform int4 o4;
  29. uniform float2 uf2;
  30. uniform int2 ui2;
  31. uniform uint2 uu2;
  32. int2 Fn1(in int2 x) { return x; }
  33. uint2 Fn1(in uint2 x) { return x; }
  34. float2 Fn1(in float2 x) { return x; }
  35. void Fn2(out int2 x) { x = int2(0,0); }
  36. void Fn2(out uint2 x) { x = uint2(0,0); }
  37. void Fn2(out float2 x) { x = float2(0,0); }
  38. float2 SomeValue() { return c2; }
  39. PS_OUTPUT main()
  40. {
  41. PS_OUTPUT psout;
  42. // 1D
  43. g_tTex1df2[c1];
  44. float2 r00 = g_tTex1df2[c1];
  45. int2 r01 = g_tTex1di2[c1];
  46. uint2 r02 = g_tTex1du2[c1];
  47. // 2D
  48. float2 r10 = g_tTex2df2[c2];
  49. int2 r11 = g_tTex2di2[c2];
  50. uint2 r12 = g_tTex2du2[c2];
  51. // 3D
  52. float2 r20 = g_tTex3df2[c3];
  53. int2 r21 = g_tTex3di2[c3];
  54. uint2 r22 = g_tTex3du2[c3];
  55. float2 lf2 = uf2;
  56. // Test as L-values
  57. // 1D
  58. g_tTex1df2[c1] = SomeValue(); // complex R-value
  59. g_tTex1df2[c1] = lf2;
  60. g_tTex1di2[c1] = int2(2,2);
  61. g_tTex1du2[c1] = uint2(3,2);
  62. // Test some operator= things, which need to do both a load and a store.
  63. float2 val1 = (g_tTex1df2[c1] *= 2.0);
  64. g_tTex1df2[c1] -= 3.0;
  65. g_tTex1df2[c1] += 4.0;
  66. g_tTex1di2[c1] /= 2;
  67. g_tTex1di2[c1] %= 2;
  68. g_tTex1di2[c1] &= 0xffff;
  69. g_tTex1di2[c1] |= 0xf0f0;
  70. g_tTex1di2[c1] <<= 2;
  71. g_tTex1di2[c1] >>= 2;
  72. // 2D
  73. g_tTex2df2[c2] = SomeValue(); // complex L-value
  74. g_tTex2df2[c2] = lf2;
  75. g_tTex2di2[c2] = int2(5,2);
  76. g_tTex2du2[c2] = uint2(6,2);
  77. // 3D
  78. g_tTex3df2[c3] = SomeValue(); // complex L-value
  79. g_tTex3df2[c3] = lf2;
  80. g_tTex3di2[c3] = int2(8,6);
  81. g_tTex3du2[c3] = uint2(9,2);
  82. // Test function calling
  83. Fn1(g_tTex1df2[c1]); // in
  84. Fn1(g_tTex1di2[c1]); // in
  85. Fn1(g_tTex1du2[c1]); // in
  86. Fn2(g_tTex1df2[c1]); // out
  87. Fn2(g_tTex1di2[c1]); // out
  88. Fn2(g_tTex1du2[c1]); // out
  89. // Test increment operators
  90. // pre-ops
  91. ++g_tTex1df2[c1];
  92. ++g_tTex1di2[c1];
  93. ++g_tTex1du2[c1];
  94. --g_tTex1df2[c1];
  95. --g_tTex1di2[c1];
  96. --g_tTex1du2[c1];
  97. // post-ops
  98. g_tTex1df2[c1]++;
  99. g_tTex1du2[c1]--;
  100. g_tTex1di2[c1]++;
  101. g_tTex1df2[c1]--;
  102. g_tTex1di2[c1]++;
  103. g_tTex1du2[c1]--;
  104. // read and write
  105. g_tTex1df2[1] = g_tTex2df2[int2(2,3)];
  106. psout.Color = 1.0;
  107. return psout;
  108. }