text_to_binary.memory_test.cpp 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426
  1. // Copyright (c) 2015-2016 The Khronos Group Inc.
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. // Assembler tests for instructions in the "Memory Instructions" section of
  15. // the SPIR-V spec.
  16. #include <sstream>
  17. #include <string>
  18. #include <vector>
  19. #include "gmock/gmock.h"
  20. #include "test/test_fixture.h"
  21. #include "test/unit_spirv.h"
  22. namespace spvtools {
  23. namespace {
  24. using spvtest::EnumCase;
  25. using spvtest::MakeInstruction;
  26. using spvtest::TextToBinaryTest;
  27. using ::testing::Eq;
  28. using ::testing::HasSubstr;
  29. // Test assembly of Memory Access masks
  30. using MemoryAccessTest = spvtest::TextToBinaryTestBase<
  31. ::testing::TestWithParam<EnumCase<SpvMemoryAccessMask>>>;
  32. TEST_P(MemoryAccessTest, AnySingleMemoryAccessMask) {
  33. std::stringstream input;
  34. input << "OpStore %ptr %value " << GetParam().name();
  35. for (auto operand : GetParam().operands()) input << " " << operand;
  36. EXPECT_THAT(CompiledInstructions(input.str()),
  37. Eq(MakeInstruction(SpvOpStore, {1, 2, GetParam().value()},
  38. GetParam().operands())));
  39. }
  40. INSTANTIATE_TEST_SUITE_P(
  41. TextToBinaryMemoryAccessTest, MemoryAccessTest,
  42. ::testing::ValuesIn(std::vector<EnumCase<SpvMemoryAccessMask>>{
  43. {SpvMemoryAccessMaskNone, "None", {}},
  44. {SpvMemoryAccessVolatileMask, "Volatile", {}},
  45. {SpvMemoryAccessAlignedMask, "Aligned", {16}},
  46. {SpvMemoryAccessNontemporalMask, "Nontemporal", {}},
  47. }));
  48. TEST_F(TextToBinaryTest, CombinedMemoryAccessMask) {
  49. const std::string input = "OpStore %ptr %value Volatile|Aligned 16";
  50. const uint32_t expected_mask =
  51. SpvMemoryAccessVolatileMask | SpvMemoryAccessAlignedMask;
  52. EXPECT_THAT(expected_mask, Eq(3u));
  53. EXPECT_THAT(CompiledInstructions(input),
  54. Eq(MakeInstruction(SpvOpStore, {1, 2, expected_mask, 16})));
  55. }
  56. // Test Storage Class enum values
  57. using StorageClassTest = spvtest::TextToBinaryTestBase<
  58. ::testing::TestWithParam<EnumCase<SpvStorageClass>>>;
  59. TEST_P(StorageClassTest, AnyStorageClass) {
  60. const std::string input = "%1 = OpVariable %2 " + GetParam().name();
  61. EXPECT_THAT(CompiledInstructions(input),
  62. Eq(MakeInstruction(SpvOpVariable, {1, 2, GetParam().value()})));
  63. }
  64. // clang-format off
  65. #define CASE(NAME) { SpvStorageClass##NAME, #NAME, {} }
  66. INSTANTIATE_TEST_SUITE_P(
  67. TextToBinaryStorageClassTest, StorageClassTest,
  68. ::testing::ValuesIn(std::vector<EnumCase<SpvStorageClass>>{
  69. CASE(UniformConstant),
  70. CASE(Input),
  71. CASE(Uniform),
  72. CASE(Output),
  73. CASE(Workgroup),
  74. CASE(CrossWorkgroup),
  75. CASE(Private),
  76. CASE(Function),
  77. CASE(Generic),
  78. CASE(PushConstant),
  79. CASE(AtomicCounter),
  80. CASE(Image),
  81. }));
  82. #undef CASE
  83. // clang-format on
  84. using MemoryRoundTripTest = RoundTripTest;
  85. // OpPtrEqual appeared in SPIR-V 1.4
  86. TEST_F(MemoryRoundTripTest, OpPtrEqualGood) {
  87. std::string spirv = "%2 = OpPtrEqual %1 %3 %4\n";
  88. EXPECT_THAT(CompiledInstructions(spirv, SPV_ENV_UNIVERSAL_1_4),
  89. Eq(MakeInstruction(SpvOpPtrEqual, {1, 2, 3, 4})));
  90. std::string disassembly = EncodeAndDecodeSuccessfully(
  91. spirv, SPV_BINARY_TO_TEXT_OPTION_NONE, SPV_ENV_UNIVERSAL_1_4);
  92. EXPECT_THAT(disassembly, Eq(spirv));
  93. }
  94. TEST_F(MemoryRoundTripTest, OpPtrEqualV13Bad) {
  95. std::string spirv = "%2 = OpPtrEqual %1 %3 %4\n";
  96. std::string err = CompileFailure(spirv, SPV_ENV_UNIVERSAL_1_3);
  97. EXPECT_THAT(err, HasSubstr("Invalid Opcode name 'OpPtrEqual'"));
  98. }
  99. // OpPtrNotEqual appeared in SPIR-V 1.4
  100. TEST_F(MemoryRoundTripTest, OpPtrNotEqualGood) {
  101. std::string spirv = "%2 = OpPtrNotEqual %1 %3 %4\n";
  102. EXPECT_THAT(CompiledInstructions(spirv, SPV_ENV_UNIVERSAL_1_4),
  103. Eq(MakeInstruction(SpvOpPtrNotEqual, {1, 2, 3, 4})));
  104. std::string disassembly = EncodeAndDecodeSuccessfully(
  105. spirv, SPV_BINARY_TO_TEXT_OPTION_NONE, SPV_ENV_UNIVERSAL_1_4);
  106. EXPECT_THAT(disassembly, Eq(spirv));
  107. }
  108. TEST_F(MemoryRoundTripTest, OpPtrNotEqualV13Bad) {
  109. std::string spirv = "%2 = OpPtrNotEqual %1 %3 %4\n";
  110. std::string err = CompileFailure(spirv, SPV_ENV_UNIVERSAL_1_3);
  111. EXPECT_THAT(err, HasSubstr("Invalid Opcode name 'OpPtrNotEqual'"));
  112. }
  113. // OpPtrDiff appeared in SPIR-V 1.4
  114. TEST_F(MemoryRoundTripTest, OpPtrDiffGood) {
  115. std::string spirv = "%2 = OpPtrDiff %1 %3 %4\n";
  116. EXPECT_THAT(CompiledInstructions(spirv, SPV_ENV_UNIVERSAL_1_4),
  117. Eq(MakeInstruction(SpvOpPtrDiff, {1, 2, 3, 4})));
  118. std::string disassembly = EncodeAndDecodeSuccessfully(
  119. spirv, SPV_BINARY_TO_TEXT_OPTION_NONE, SPV_ENV_UNIVERSAL_1_4);
  120. EXPECT_THAT(disassembly, Eq(spirv));
  121. }
  122. TEST_F(MemoryRoundTripTest, OpPtrDiffV13Good) {
  123. // OpPtrDiff is enabled by a capability as well, so we can assemble
  124. // it even in older SPIR-V environments. We do that so we can
  125. // write tests.
  126. std::string spirv = "%2 = OpPtrDiff %1 %3 %4\n";
  127. std::string disassembly = EncodeAndDecodeSuccessfully(
  128. spirv, SPV_BINARY_TO_TEXT_OPTION_NONE, SPV_ENV_UNIVERSAL_1_4);
  129. }
  130. // OpCopyMemory
  131. TEST_F(MemoryRoundTripTest, OpCopyMemoryNoMemAccessGood) {
  132. std::string spirv = "OpCopyMemory %1 %2\n";
  133. EXPECT_THAT(CompiledInstructions(spirv),
  134. Eq(MakeInstruction(SpvOpCopyMemory, {1, 2})));
  135. std::string disassembly =
  136. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  137. EXPECT_THAT(disassembly, Eq(spirv));
  138. }
  139. TEST_F(MemoryRoundTripTest, OpCopyMemoryTooFewArgsBad) {
  140. std::string spirv = "OpCopyMemory %1\n";
  141. std::string err = CompileFailure(spirv);
  142. EXPECT_THAT(err, HasSubstr("Expected operand, found end of stream"));
  143. }
  144. TEST_F(MemoryRoundTripTest, OpCopyMemoryTooManyArgsBad) {
  145. std::string spirv = "OpCopyMemory %1 %2 %3\n";
  146. std::string err = CompileFailure(spirv);
  147. EXPECT_THAT(err, HasSubstr("Invalid memory access operand '%3'"));
  148. }
  149. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessNoneGood) {
  150. std::string spirv = "OpCopyMemory %1 %2 None\n";
  151. EXPECT_THAT(CompiledInstructions(spirv),
  152. Eq(MakeInstruction(SpvOpCopyMemory, {1, 2, 0})));
  153. std::string disassembly =
  154. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  155. EXPECT_THAT(disassembly, Eq(spirv));
  156. }
  157. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessVolatileGood) {
  158. std::string spirv = "OpCopyMemory %1 %2 Volatile\n";
  159. EXPECT_THAT(CompiledInstructions(spirv),
  160. Eq(MakeInstruction(SpvOpCopyMemory, {1, 2, 1})));
  161. std::string disassembly =
  162. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  163. EXPECT_THAT(disassembly, Eq(spirv));
  164. }
  165. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessAligned8Good) {
  166. std::string spirv = "OpCopyMemory %1 %2 Aligned 8\n";
  167. EXPECT_THAT(CompiledInstructions(spirv),
  168. Eq(MakeInstruction(SpvOpCopyMemory, {1, 2, 2, 8})));
  169. std::string disassembly =
  170. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  171. EXPECT_THAT(disassembly, Eq(spirv));
  172. }
  173. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessNontemporalGood) {
  174. std::string spirv = "OpCopyMemory %1 %2 Nontemporal\n";
  175. EXPECT_THAT(CompiledInstructions(spirv),
  176. Eq(MakeInstruction(SpvOpCopyMemory, {1, 2, 4})));
  177. std::string disassembly =
  178. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  179. EXPECT_THAT(disassembly, Eq(spirv));
  180. }
  181. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessAvGood) {
  182. std::string spirv = "OpCopyMemory %1 %2 MakePointerAvailable %3\n";
  183. EXPECT_THAT(CompiledInstructions(spirv),
  184. Eq(MakeInstruction(SpvOpCopyMemory, {1, 2, 8, 3})));
  185. std::string disassembly =
  186. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  187. EXPECT_THAT(disassembly, Eq(spirv));
  188. }
  189. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessVisGood) {
  190. std::string spirv = "OpCopyMemory %1 %2 MakePointerVisible %3\n";
  191. EXPECT_THAT(CompiledInstructions(spirv),
  192. Eq(MakeInstruction(SpvOpCopyMemory, {1, 2, 16, 3})));
  193. std::string disassembly =
  194. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  195. EXPECT_THAT(disassembly, Eq(spirv));
  196. }
  197. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessNonPrivateGood) {
  198. std::string spirv = "OpCopyMemory %1 %2 NonPrivatePointer\n";
  199. EXPECT_THAT(CompiledInstructions(spirv),
  200. Eq(MakeInstruction(SpvOpCopyMemory, {1, 2, 32})));
  201. std::string disassembly =
  202. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  203. EXPECT_THAT(disassembly, Eq(spirv));
  204. }
  205. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessMixedGood) {
  206. std::string spirv =
  207. "OpCopyMemory %1 %2 "
  208. "Volatile|Aligned|Nontemporal|MakePointerAvailable|"
  209. "MakePointerVisible|NonPrivatePointer 16 %3 %4\n";
  210. EXPECT_THAT(CompiledInstructions(spirv),
  211. Eq(MakeInstruction(SpvOpCopyMemory, {1, 2, 63, 16, 3, 4})));
  212. std::string disassembly =
  213. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  214. EXPECT_THAT(disassembly, Eq(spirv));
  215. }
  216. TEST_F(MemoryRoundTripTest, OpCopyMemoryTwoAccessV13Good) {
  217. std::string spirv = "OpCopyMemory %1 %2 Volatile Volatile\n";
  218. // Note: This will assemble but should not validate for SPIR-V 1.3
  219. EXPECT_THAT(CompiledInstructions(spirv, SPV_ENV_UNIVERSAL_1_3),
  220. Eq(MakeInstruction(SpvOpCopyMemory, {1, 2, 1, 1})));
  221. std::string disassembly =
  222. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  223. EXPECT_THAT(disassembly, Eq(spirv));
  224. }
  225. TEST_F(MemoryRoundTripTest, OpCopyMemoryTwoAccessV14Good) {
  226. std::string spirv = "OpCopyMemory %1 %2 Volatile Volatile\n";
  227. EXPECT_THAT(CompiledInstructions(spirv, SPV_ENV_UNIVERSAL_1_4),
  228. Eq(MakeInstruction(SpvOpCopyMemory, {1, 2, 1, 1})));
  229. std::string disassembly =
  230. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  231. EXPECT_THAT(disassembly, Eq(spirv));
  232. }
  233. TEST_F(MemoryRoundTripTest, OpCopyMemoryTwoAccessMixedV14Good) {
  234. std::string spirv =
  235. "OpCopyMemory %1 %2 Volatile|Nontemporal|"
  236. "MakePointerVisible %3 "
  237. "Aligned|MakePointerAvailable|NonPrivatePointer 16 %4\n";
  238. EXPECT_THAT(CompiledInstructions(spirv),
  239. Eq(MakeInstruction(SpvOpCopyMemory, {1, 2, 21, 3, 42, 16, 4})));
  240. std::string disassembly =
  241. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  242. EXPECT_THAT(disassembly, Eq(spirv));
  243. }
  244. // OpCopyMemorySized
  245. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedNoMemAccessGood) {
  246. std::string spirv = "OpCopyMemorySized %1 %2 %3\n";
  247. EXPECT_THAT(CompiledInstructions(spirv),
  248. Eq(MakeInstruction(SpvOpCopyMemorySized, {1, 2, 3})));
  249. std::string disassembly =
  250. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  251. EXPECT_THAT(disassembly, Eq(spirv));
  252. }
  253. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedTooFewArgsBad) {
  254. std::string spirv = "OpCopyMemorySized %1 %2\n";
  255. std::string err = CompileFailure(spirv);
  256. EXPECT_THAT(err, HasSubstr("Expected operand, found end of stream"));
  257. }
  258. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedTooManyArgsBad) {
  259. std::string spirv = "OpCopyMemorySized %1 %2 %3 %4\n";
  260. std::string err = CompileFailure(spirv);
  261. EXPECT_THAT(err, HasSubstr("Invalid memory access operand '%4'"));
  262. }
  263. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessNoneGood) {
  264. std::string spirv = "OpCopyMemorySized %1 %2 %3 None\n";
  265. EXPECT_THAT(CompiledInstructions(spirv),
  266. Eq(MakeInstruction(SpvOpCopyMemorySized, {1, 2, 3, 0})));
  267. std::string disassembly =
  268. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  269. EXPECT_THAT(disassembly, Eq(spirv));
  270. }
  271. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessVolatileGood) {
  272. std::string spirv = "OpCopyMemorySized %1 %2 %3 Volatile\n";
  273. EXPECT_THAT(CompiledInstructions(spirv),
  274. Eq(MakeInstruction(SpvOpCopyMemorySized, {1, 2, 3, 1})));
  275. std::string disassembly =
  276. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  277. EXPECT_THAT(disassembly, Eq(spirv));
  278. }
  279. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessAligned8Good) {
  280. std::string spirv = "OpCopyMemorySized %1 %2 %3 Aligned 8\n";
  281. EXPECT_THAT(CompiledInstructions(spirv),
  282. Eq(MakeInstruction(SpvOpCopyMemorySized, {1, 2, 3, 2, 8})));
  283. std::string disassembly =
  284. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  285. EXPECT_THAT(disassembly, Eq(spirv));
  286. }
  287. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessNontemporalGood) {
  288. std::string spirv = "OpCopyMemorySized %1 %2 %3 Nontemporal\n";
  289. EXPECT_THAT(CompiledInstructions(spirv),
  290. Eq(MakeInstruction(SpvOpCopyMemorySized, {1, 2, 3, 4})));
  291. std::string disassembly =
  292. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  293. EXPECT_THAT(disassembly, Eq(spirv));
  294. }
  295. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessAvGood) {
  296. std::string spirv = "OpCopyMemorySized %1 %2 %3 MakePointerAvailable %4\n";
  297. EXPECT_THAT(CompiledInstructions(spirv),
  298. Eq(MakeInstruction(SpvOpCopyMemorySized, {1, 2, 3, 8, 4})));
  299. std::string disassembly =
  300. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  301. EXPECT_THAT(disassembly, Eq(spirv));
  302. }
  303. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessVisGood) {
  304. std::string spirv = "OpCopyMemorySized %1 %2 %3 MakePointerVisible %4\n";
  305. EXPECT_THAT(CompiledInstructions(spirv),
  306. Eq(MakeInstruction(SpvOpCopyMemorySized, {1, 2, 3, 16, 4})));
  307. std::string disassembly =
  308. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  309. EXPECT_THAT(disassembly, Eq(spirv));
  310. }
  311. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessNonPrivateGood) {
  312. std::string spirv = "OpCopyMemorySized %1 %2 %3 NonPrivatePointer\n";
  313. EXPECT_THAT(CompiledInstructions(spirv),
  314. Eq(MakeInstruction(SpvOpCopyMemorySized, {1, 2, 3, 32})));
  315. std::string disassembly =
  316. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  317. EXPECT_THAT(disassembly, Eq(spirv));
  318. }
  319. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessMixedGood) {
  320. std::string spirv =
  321. "OpCopyMemorySized %1 %2 %3 "
  322. "Volatile|Aligned|Nontemporal|MakePointerAvailable|"
  323. "MakePointerVisible|NonPrivatePointer 16 %4 %5\n";
  324. EXPECT_THAT(
  325. CompiledInstructions(spirv),
  326. Eq(MakeInstruction(SpvOpCopyMemorySized, {1, 2, 3, 63, 16, 4, 5})));
  327. std::string disassembly =
  328. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  329. EXPECT_THAT(disassembly, Eq(spirv));
  330. }
  331. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedTwoAccessV13Good) {
  332. std::string spirv = "OpCopyMemorySized %1 %2 %3 Volatile Volatile\n";
  333. // Note: This will assemble but should not validate for SPIR-V 1.3
  334. EXPECT_THAT(CompiledInstructions(spirv, SPV_ENV_UNIVERSAL_1_3),
  335. Eq(MakeInstruction(SpvOpCopyMemorySized, {1, 2, 3, 1, 1})));
  336. std::string disassembly =
  337. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  338. EXPECT_THAT(disassembly, Eq(spirv));
  339. }
  340. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedTwoAccessV14Good) {
  341. std::string spirv = "OpCopyMemorySized %1 %2 %3 Volatile Volatile\n";
  342. EXPECT_THAT(CompiledInstructions(spirv, SPV_ENV_UNIVERSAL_1_4),
  343. Eq(MakeInstruction(SpvOpCopyMemorySized, {1, 2, 3, 1, 1})));
  344. std::string disassembly =
  345. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  346. EXPECT_THAT(disassembly, Eq(spirv));
  347. }
  348. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedTwoAccessMixedV14Good) {
  349. std::string spirv =
  350. "OpCopyMemorySized %1 %2 %3 Volatile|Nontemporal|"
  351. "MakePointerVisible %4 "
  352. "Aligned|MakePointerAvailable|NonPrivatePointer 16 %5\n";
  353. EXPECT_THAT(
  354. CompiledInstructions(spirv),
  355. Eq(MakeInstruction(SpvOpCopyMemorySized, {1, 2, 3, 21, 4, 42, 16, 5})));
  356. std::string disassembly =
  357. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  358. EXPECT_THAT(disassembly, Eq(spirv));
  359. }
  360. // TODO(dneto): OpVariable with initializers
  361. // TODO(dneto): OpImageTexelPointer
  362. // TODO(dneto): OpLoad
  363. // TODO(dneto): OpStore
  364. // TODO(dneto): OpAccessChain
  365. // TODO(dneto): OpInBoundsAccessChain
  366. // TODO(dneto): OpPtrAccessChain
  367. // TODO(dneto): OpArrayLength
  368. // TODO(dneto): OpGenercPtrMemSemantics
  369. } // namespace
  370. } // namespace spvtools