spv.explicittypes.frag 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335
  1. #version 450
  2. #extension GL_KHX_shader_explicit_arithmetic_types: enable
  3. #extension GL_KHX_shader_explicit_arithmetic_types_int8: require
  4. #extension GL_KHX_shader_explicit_arithmetic_types_int16: require
  5. #extension GL_KHX_shader_explicit_arithmetic_types_int32: require
  6. #extension GL_KHX_shader_explicit_arithmetic_types_int64: require
  7. #extension GL_KHX_shader_explicit_arithmetic_types_float16: require
  8. #extension GL_KHX_shader_explicit_arithmetic_types_float32: require
  9. #extension GL_KHX_shader_explicit_arithmetic_types_float64: require
  10. layout(binding = 0) uniform Uniforms
  11. {
  12. uint index;
  13. };
  14. layout(std140, binding = 1) uniform Block
  15. {
  16. int16_t i16;
  17. i16vec2 i16v2;
  18. i16vec3 i16v3;
  19. i16vec4 i16v4;
  20. uint16_t u16;
  21. u16vec2 u16v2;
  22. u16vec3 u16v3;
  23. u16vec4 u16v4;
  24. int32_t i32;
  25. i32vec2 i32v2;
  26. i32vec3 i32v3;
  27. i32vec4 i32v4;
  28. uint32_t u32;
  29. u32vec2 u32v2;
  30. u32vec3 u32v3;
  31. u32vec4 u32v4;
  32. } block;
  33. void main()
  34. {
  35. }
  36. void literal()
  37. {
  38. const int64_t i64Const[3] =
  39. {
  40. -0x1111111111111111l, // Hex
  41. -1l, // Dec
  42. 040000000000l, // Oct
  43. };
  44. int64_t i64 = i64Const[index];
  45. const uint64_t u64Const[] =
  46. {
  47. 0xFFFFFFFFFFFFFFFFul, // Hex
  48. 4294967296UL, // Dec
  49. 077777777777ul, // Oct
  50. };
  51. uint64_t u64 = u64Const[index];
  52. const int32_t i32Const[3] =
  53. {
  54. -0x11111111, // Hex
  55. -1, // Dec
  56. 04000000000, // Oct
  57. };
  58. int32_t i32 = i32Const[index];
  59. const uint32_t u32Const[] =
  60. {
  61. 0xFFFFFFFF, // Hex
  62. 4294967295, // Dec
  63. 017777777777, // Oct
  64. };
  65. uint32_t u32 = u32Const[index];
  66. const int16_t i16Const[3] =
  67. {
  68. int16_t(-0x1111), // Hex
  69. int16_t(-1), // Dec
  70. int16_t(040000), // Oct
  71. };
  72. int16_t i16 = i16Const[index];
  73. const uint16_t u16Const[] =
  74. {
  75. uint16_t(0xFFFF), // Hex
  76. uint16_t(65535), // Dec
  77. uint16_t(077777), // Oct
  78. };
  79. uint16_t u16 = u16Const[index];
  80. const int8_t i8Const[3] =
  81. {
  82. int8_t(-0x11), // Hex
  83. int8_t(-1), // Dec
  84. int8_t(0400), // Oct
  85. };
  86. int8_t i8 = i8Const[index];
  87. const uint8_t u8Const[] =
  88. {
  89. uint8_t(0xFF), // Hex
  90. uint8_t(255), // Dec
  91. uint8_t(0177), // Oct
  92. };
  93. uint8_t u8 = u8Const[index];
  94. }
  95. void typeCast8()
  96. {
  97. i8vec2 i8v;
  98. u8vec2 u8v;
  99. i16vec2 i16v;
  100. u16vec2 u16v;
  101. i32vec2 i32v;
  102. u32vec2 u32v;
  103. i64vec2 i64v;
  104. u64vec2 u64v;
  105. f16vec2 f16v;
  106. f32vec2 f32v;
  107. f64vec2 f64v;
  108. bvec2 bv;
  109. u8v = i8v; // int8_t -> uint8_t
  110. i16v = i8v; // int8_t -> int16_t
  111. i16v = u8v; // uint8_t -> int16_t
  112. i32v = i8v; // int8_t -> int32_t
  113. i32v = u8v; // uint8_t -> int32_t
  114. u32v = i8v; // int8_t -> uint32_t
  115. i64v = i8v; // int8_t -> int64_t
  116. u64v = i8v; // int8_t -> uint64_t
  117. u32v = u8v; // uint8_t -> uint32_t
  118. i64v = u8v; // uint8_t -> int64_t
  119. u64v = u8v; // uint8_t -> uint64_t
  120. f16v = i8v; // int8_t -> float16_t
  121. f32v = i8v; // int8_t -> float32_t
  122. f64v = i8v; // int8_t -> float64_t
  123. f16v = u8v; // uint8_t -> float16_t
  124. f32v = u8v; // uint8_t -> float32_t
  125. f64v = u8v; // uint8_t -> float64_t
  126. i8v = i8vec2(u8v); // uint8_t -> int8_t
  127. i16v = i16vec2(i8v); // int8_t -> int16_t
  128. i16v = i16vec2(u8v); // uint8_t -> int16_t
  129. i32v = i32vec2(i8v); // int8_t -> int32_t
  130. i32v = i32vec2(u8v); // uint8_t -> int32_t
  131. i64v = i64vec2(i8v); // int8_t -> int64_t
  132. u64v = i64vec2(i8v); // int8_t -> uint64_t
  133. u16v = u16vec2(i8v); // int8_t -> uint16_t
  134. u16v = u16vec2(u8v); // uint8_t -> uint16_t
  135. u32v = u32vec2(u8v); // uint8_t -> uint32_t
  136. i64v = i64vec2(u8v); // uint8_t -> int64_t
  137. u64v = i64vec2(u8v); // uint8_t -> uint64_t
  138. f16v = f16vec2(i8v); // int8_t -> float16_t
  139. f32v = f32vec2(i8v); // int8_t -> float32_t
  140. f64v = f64vec2(i8v); // int8_t -> float64_t
  141. f16v = f16vec2(u8v); // uint8_t -> float16_t
  142. f32v = f32vec2(u8v); // uint8_t -> float32_t
  143. f64v = f64vec2(u8v); // uint8_t -> float64_t
  144. i8v = i8vec2(bv); // bool -> int8
  145. u8v = u8vec2(bv); // bool -> uint8
  146. bv = bvec2(i8v); // int8 -> bool
  147. bv = bvec2(u8v); // uint8 -> bool
  148. }
  149. void typeCast16()
  150. {
  151. i8vec2 i8v;
  152. u8vec2 u8v;
  153. i16vec2 i16v;
  154. u16vec2 u16v;
  155. i32vec2 i32v;
  156. u32vec2 u32v;
  157. i64vec2 i64v;
  158. u64vec2 u64v;
  159. f16vec2 f16v;
  160. f32vec2 f32v;
  161. f64vec2 f64v;
  162. bvec2 bv;
  163. i32v = i16v; // int16_t -> int32_t
  164. i32v = u16v; // uint16_t -> int32_t
  165. u16v = i16v; // int16_t -> uint16_t
  166. u32v = i16v; // int16_t -> uint32_t
  167. i64v = i16v; // int16_t -> int64_t
  168. u64v = i16v; // int16_t -> uint64_t
  169. u32v = u16v; // uint16_t -> uint32_t
  170. i64v = u16v; // uint16_t -> int64_t
  171. u64v = u16v; // uint16_t -> uint64_t
  172. f16v = i16v; // int16_t -> float16_t
  173. f32v = i16v; // int16_t -> float32_t
  174. f64v = i16v; // int16_t -> float64_t
  175. f16v = u16v; // uint16_t -> float16_t
  176. f32v = u16v; // uint16_t -> float32_t
  177. f64v = u16v; // uint16_t -> float64_t
  178. i32v = i32vec2(i16v); // int16_t -> int32_t
  179. i32v = i32vec2(u16v); // uint16_t -> int32_t
  180. u16v = u16vec2(i16v); // int16_t -> uint16_t
  181. u32v = u32vec2(i16v); // int16_t -> uint32_t
  182. i64v = i64vec2(i16v); // int16_t -> int64_t
  183. u64v = i64vec2(i16v); // int16_t -> uint64_t
  184. u32v = u32vec2(u16v); // uint16_t -> uint32_t
  185. i64v = i64vec2(u16v); // uint16_t -> int64_t
  186. u64v = i64vec2(u16v); // uint16_t -> uint64_t
  187. f16v = f16vec2(i16v); // int16_t -> float16_t
  188. f32v = f32vec2(i16v); // int16_t -> float32_t
  189. f64v = f64vec2(i16v); // int16_t -> float64_t
  190. f16v = f16vec2(u16v); // uint16_t -> float16_t
  191. f32v = f32vec2(u16v); // uint16_t -> float32_t
  192. f64v = f64vec2(u16v); // uint16_t -> float64_t
  193. i8v = i8vec2(i16v); // int16_t -> int8_t
  194. i8v = i8vec2(u16v); // uint16_t -> int8_t
  195. u8v = u8vec2(i16v); // int16_t -> uint8_t
  196. u8v = u8vec2(u16v); // uint16_t -> uint8_t
  197. i16v = u8vec2(u16v); // uint16_t -> int16_t
  198. i16v = i16vec2(bv); // bool -> int16
  199. u16v = u16vec2(bv); // bool -> uint16
  200. bv = bvec2(i16v); // int16 -> bool
  201. bv = bvec2(u16v); // uint16 -> bool
  202. }
  203. void typeCast32()
  204. {
  205. i8vec2 i8v;
  206. u8vec2 u8v;
  207. i16vec2 i16v;
  208. u16vec2 u16v;
  209. i32vec2 i32v;
  210. u32vec2 u32v;
  211. i64vec2 i64v;
  212. u64vec2 u64v;
  213. f16vec2 f16v;
  214. f32vec2 f32v;
  215. f64vec2 f64v;
  216. bvec2 bv;
  217. u32v = i32v; // int32_t -> uint32_t
  218. i64v = i32v; // int32_t -> int64_t
  219. u64v = i32v; // int32_t -> uint64_t
  220. i64v = u32v; // uint32_t -> int64_t
  221. u64v = u32v; // uint32_t -> uint64_t
  222. f32v = i32v; // int32_t -> float32_t
  223. f64v = i32v; // int32_t -> float64_t
  224. f32v = u32v; // uint32_t -> float32_t
  225. f64v = u32v; // uint32_t -> float64_t
  226. i8v = i8vec2(i32v); // int32_t -> int8_t
  227. i8v = i8vec2(u32v); // uint32_t -> int8_t
  228. i16v = i16vec2(i32v); // int32_t -> int16_t
  229. i16v = i16vec2(u32v); // uint32_t -> int16_t
  230. i32v = i32vec2(i32v); // int32_t -> int32_t
  231. i32v = i32vec2(u32v); // uint32_t -> int32_t
  232. i64v = i64vec2(i32v); // int32_t -> int64_t
  233. i64v = i64vec2(u32v); // uint32_t -> int64_t
  234. u8v = u8vec2(i32v); // int32_t -> uint8_t
  235. u8v = u8vec2(u32v); // uint32_t -> uint8_t
  236. u16v = u16vec2(i32v); // int32_t -> uint16_t
  237. u16v = u16vec2(u32v); // uint32_t -> uint16_t
  238. u32v = u32vec2(i32v); // int32_t -> uint32_t
  239. u32v = u32vec2(u32v); // uint32_t -> uint32_t
  240. u64v = u64vec2(i32v); // int32_t -> uint64_t
  241. u64v = u64vec2(u32v); // uint32_t -> uint64_t
  242. f16v = f16vec2(i32v); // int32_t -> float16_t
  243. f32v = f32vec2(i32v); // int32_t -> float32_t
  244. f64v = f64vec2(i32v); // int32_t -> float64_t
  245. f16v = f16vec2(u32v); // uint32_t -> float16_t
  246. f32v = f32vec2(u32v); // uint32_t -> float32_t
  247. f64v = f64vec2(u32v); // uint32_t -> float64_t
  248. i32v = i32vec2(bv); // bool -> int32
  249. u32v = u32vec2(bv); // bool -> uint32
  250. bv = bvec2(i32v); // int32 -> bool
  251. bv = bvec2(u32v); // uint32 -> bool
  252. }
  253. void typeCast64()
  254. {
  255. i8vec2 i8v;
  256. u8vec2 u8v;
  257. i16vec2 i16v;
  258. u16vec2 u16v;
  259. i32vec2 i32v;
  260. u32vec2 u32v;
  261. i64vec2 i64v;
  262. u64vec2 u64v;
  263. f16vec2 f16v;
  264. f32vec2 f32v;
  265. f64vec2 f64v;
  266. bvec2 bv;
  267. u64v = i64v; // int64_t -> uint64_t
  268. f64v = i64v; // int64_t -> float64_t
  269. f64v = u64v; // uint64_t -> float64_t
  270. i8v = i8vec2(i64v); // int64_t -> int8_t
  271. i8v = i8vec2(u64v); // uint64_t -> int8_t
  272. i16v = i16vec2(i64v); // int64_t -> int16_t
  273. i16v = i16vec2(u64v); // uint64_t -> int16_t
  274. i32v = i32vec2(i64v); // int64_t -> int32_t
  275. i32v = i32vec2(u64v); // uint64_t -> int32_t
  276. i64v = i64vec2(u64v); // uint64_t -> int64_t
  277. u8v = u8vec2(i64v); // int64_t -> uint8_t
  278. u8v = u8vec2(u64v); // uint64_t -> uint8_t
  279. u16v = u16vec2(i64v); // int64_t -> uint16_t
  280. u16v = u16vec2(u64v); // uint64_t -> uint16_t
  281. u32v = u32vec2(i64v); // int64_t -> uint32_t
  282. u32v = u32vec2(u64v); // uint64_t -> uint32_t
  283. u64v = u64vec2(i64v); // int64_t -> uint64_t
  284. u64v = u64vec2(u64v); // uint64_t -> uint64_t
  285. f16v = f16vec2(i64v); // int64_t -> float16_t
  286. f32v = f32vec2(i64v); // int64_t -> float32_t
  287. f64v = f64vec2(i64v); // int64_t -> float64_t
  288. f16v = f16vec2(u64v); // uint64_t -> float16_t
  289. f32v = f32vec2(u64v); // uint64_t -> float32_t
  290. f64v = f64vec2(u64v); // uint64_t -> float64_t
  291. i64v = i64vec2(bv); // bool -> int64
  292. u64v = u64vec2(bv); // bool -> uint64
  293. bv = bvec2(i64v); // int64 -> bool
  294. bv = bvec2(u64v); // uint64 -> bool
  295. }