text_to_binary.memory_test.cpp 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432
  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<spv::MemoryAccessMask>>>;
  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(
  37. CompiledInstructions(input.str()),
  38. Eq(MakeInstruction(spv::Op::OpStore, {1, 2, (uint32_t)GetParam().value()},
  39. GetParam().operands())));
  40. }
  41. INSTANTIATE_TEST_SUITE_P(
  42. TextToBinaryMemoryAccessTest, MemoryAccessTest,
  43. ::testing::ValuesIn(std::vector<EnumCase<spv::MemoryAccessMask>>{
  44. {spv::MemoryAccessMask::MaskNone, "None", {}},
  45. {spv::MemoryAccessMask::Volatile, "Volatile", {}},
  46. {spv::MemoryAccessMask::Aligned, "Aligned", {16}},
  47. {spv::MemoryAccessMask::Nontemporal, "Nontemporal", {}},
  48. }));
  49. TEST_F(TextToBinaryTest, CombinedMemoryAccessMask) {
  50. const std::string input = "OpStore %ptr %value Volatile|Aligned 16";
  51. const uint32_t expected_mask = uint32_t(spv::MemoryAccessMask::Volatile |
  52. spv::MemoryAccessMask::Aligned);
  53. EXPECT_THAT(expected_mask, Eq(3u));
  54. EXPECT_THAT(CompiledInstructions(input),
  55. Eq(MakeInstruction(spv::Op::OpStore, {1, 2, expected_mask, 16})));
  56. }
  57. // Test Storage Class enum values
  58. using StorageClassTest = spvtest::TextToBinaryTestBase<
  59. ::testing::TestWithParam<EnumCase<spv::StorageClass>>>;
  60. TEST_P(StorageClassTest, AnyStorageClass) {
  61. const std::string input = "%1 = OpVariable %2 " + GetParam().name();
  62. EXPECT_THAT(CompiledInstructions(input),
  63. Eq(MakeInstruction(spv::Op::OpVariable,
  64. {1, 2, (uint32_t)GetParam().value()})));
  65. }
  66. // clang-format off
  67. #define CASE(NAME) { spv::StorageClass::NAME, #NAME, {} }
  68. INSTANTIATE_TEST_SUITE_P(
  69. TextToBinaryStorageClassTest, StorageClassTest,
  70. ::testing::ValuesIn(std::vector<EnumCase<spv::StorageClass>>{
  71. CASE(UniformConstant),
  72. CASE(Input),
  73. CASE(Uniform),
  74. CASE(Output),
  75. CASE(Workgroup),
  76. CASE(CrossWorkgroup),
  77. CASE(Private),
  78. CASE(Function),
  79. CASE(Generic),
  80. CASE(PushConstant),
  81. CASE(AtomicCounter),
  82. CASE(Image),
  83. }));
  84. #undef CASE
  85. // clang-format on
  86. using MemoryRoundTripTest = RoundTripTest;
  87. // OpPtrEqual appeared in SPIR-V 1.4
  88. TEST_F(MemoryRoundTripTest, OpPtrEqualGood) {
  89. std::string spirv = "%2 = OpPtrEqual %1 %3 %4\n";
  90. EXPECT_THAT(CompiledInstructions(spirv, SPV_ENV_UNIVERSAL_1_4),
  91. Eq(MakeInstruction(spv::Op::OpPtrEqual, {1, 2, 3, 4})));
  92. std::string disassembly = EncodeAndDecodeSuccessfully(
  93. spirv, SPV_BINARY_TO_TEXT_OPTION_NONE, SPV_ENV_UNIVERSAL_1_4);
  94. EXPECT_THAT(disassembly, Eq(spirv));
  95. }
  96. TEST_F(MemoryRoundTripTest, OpPtrEqualV13Bad) {
  97. std::string spirv = "%2 = OpPtrEqual %1 %3 %4\n";
  98. std::string err = CompileFailure(spirv, SPV_ENV_UNIVERSAL_1_3);
  99. EXPECT_THAT(err, HasSubstr("Invalid Opcode name 'OpPtrEqual'"));
  100. }
  101. // OpPtrNotEqual appeared in SPIR-V 1.4
  102. TEST_F(MemoryRoundTripTest, OpPtrNotEqualGood) {
  103. std::string spirv = "%2 = OpPtrNotEqual %1 %3 %4\n";
  104. EXPECT_THAT(CompiledInstructions(spirv, SPV_ENV_UNIVERSAL_1_4),
  105. Eq(MakeInstruction(spv::Op::OpPtrNotEqual, {1, 2, 3, 4})));
  106. std::string disassembly = EncodeAndDecodeSuccessfully(
  107. spirv, SPV_BINARY_TO_TEXT_OPTION_NONE, SPV_ENV_UNIVERSAL_1_4);
  108. EXPECT_THAT(disassembly, Eq(spirv));
  109. }
  110. TEST_F(MemoryRoundTripTest, OpPtrNotEqualV13Bad) {
  111. std::string spirv = "%2 = OpPtrNotEqual %1 %3 %4\n";
  112. std::string err = CompileFailure(spirv, SPV_ENV_UNIVERSAL_1_3);
  113. EXPECT_THAT(err, HasSubstr("Invalid Opcode name 'OpPtrNotEqual'"));
  114. }
  115. // OpPtrDiff appeared in SPIR-V 1.4
  116. TEST_F(MemoryRoundTripTest, OpPtrDiffGood) {
  117. std::string spirv = "%2 = OpPtrDiff %1 %3 %4\n";
  118. EXPECT_THAT(CompiledInstructions(spirv, SPV_ENV_UNIVERSAL_1_4),
  119. Eq(MakeInstruction(spv::Op::OpPtrDiff, {1, 2, 3, 4})));
  120. std::string disassembly = EncodeAndDecodeSuccessfully(
  121. spirv, SPV_BINARY_TO_TEXT_OPTION_NONE, SPV_ENV_UNIVERSAL_1_4);
  122. EXPECT_THAT(disassembly, Eq(spirv));
  123. }
  124. TEST_F(MemoryRoundTripTest, OpPtrDiffV13Good) {
  125. // OpPtrDiff is enabled by a capability as well, so we can assemble
  126. // it even in older SPIR-V environments. We do that so we can
  127. // write tests.
  128. std::string spirv = "%2 = OpPtrDiff %1 %3 %4\n";
  129. std::string disassembly = EncodeAndDecodeSuccessfully(
  130. spirv, SPV_BINARY_TO_TEXT_OPTION_NONE, SPV_ENV_UNIVERSAL_1_4);
  131. }
  132. // OpCopyMemory
  133. TEST_F(MemoryRoundTripTest, OpCopyMemoryNoMemAccessGood) {
  134. std::string spirv = "OpCopyMemory %1 %2\n";
  135. EXPECT_THAT(CompiledInstructions(spirv),
  136. Eq(MakeInstruction(spv::Op::OpCopyMemory, {1, 2})));
  137. std::string disassembly =
  138. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  139. EXPECT_THAT(disassembly, Eq(spirv));
  140. }
  141. TEST_F(MemoryRoundTripTest, OpCopyMemoryTooFewArgsBad) {
  142. std::string spirv = "OpCopyMemory %1\n";
  143. std::string err = CompileFailure(spirv);
  144. EXPECT_THAT(err, HasSubstr("Expected operand for OpCopyMemory instruction, "
  145. "but found the end of the stream."));
  146. }
  147. TEST_F(MemoryRoundTripTest, OpCopyMemoryTooManyArgsBad) {
  148. std::string spirv = "OpCopyMemory %1 %2 %3\n";
  149. std::string err = CompileFailure(spirv);
  150. EXPECT_THAT(err, HasSubstr("Invalid memory access operand '%3'"));
  151. }
  152. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessNoneGood) {
  153. std::string spirv = "OpCopyMemory %1 %2 None\n";
  154. EXPECT_THAT(CompiledInstructions(spirv),
  155. Eq(MakeInstruction(spv::Op::OpCopyMemory, {1, 2, 0})));
  156. std::string disassembly =
  157. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  158. EXPECT_THAT(disassembly, Eq(spirv));
  159. }
  160. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessVolatileGood) {
  161. std::string spirv = "OpCopyMemory %1 %2 Volatile\n";
  162. EXPECT_THAT(CompiledInstructions(spirv),
  163. Eq(MakeInstruction(spv::Op::OpCopyMemory, {1, 2, 1})));
  164. std::string disassembly =
  165. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  166. EXPECT_THAT(disassembly, Eq(spirv));
  167. }
  168. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessAligned8Good) {
  169. std::string spirv = "OpCopyMemory %1 %2 Aligned 8\n";
  170. EXPECT_THAT(CompiledInstructions(spirv),
  171. Eq(MakeInstruction(spv::Op::OpCopyMemory, {1, 2, 2, 8})));
  172. std::string disassembly =
  173. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  174. EXPECT_THAT(disassembly, Eq(spirv));
  175. }
  176. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessNontemporalGood) {
  177. std::string spirv = "OpCopyMemory %1 %2 Nontemporal\n";
  178. EXPECT_THAT(CompiledInstructions(spirv),
  179. Eq(MakeInstruction(spv::Op::OpCopyMemory, {1, 2, 4})));
  180. std::string disassembly =
  181. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  182. EXPECT_THAT(disassembly, Eq(spirv));
  183. }
  184. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessAvGood) {
  185. std::string spirv = "OpCopyMemory %1 %2 MakePointerAvailable %3\n";
  186. EXPECT_THAT(CompiledInstructions(spirv),
  187. Eq(MakeInstruction(spv::Op::OpCopyMemory, {1, 2, 8, 3})));
  188. std::string disassembly =
  189. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  190. EXPECT_THAT(disassembly, Eq(spirv));
  191. }
  192. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessVisGood) {
  193. std::string spirv = "OpCopyMemory %1 %2 MakePointerVisible %3\n";
  194. EXPECT_THAT(CompiledInstructions(spirv),
  195. Eq(MakeInstruction(spv::Op::OpCopyMemory, {1, 2, 16, 3})));
  196. std::string disassembly =
  197. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  198. EXPECT_THAT(disassembly, Eq(spirv));
  199. }
  200. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessNonPrivateGood) {
  201. std::string spirv = "OpCopyMemory %1 %2 NonPrivatePointer\n";
  202. EXPECT_THAT(CompiledInstructions(spirv),
  203. Eq(MakeInstruction(spv::Op::OpCopyMemory, {1, 2, 32})));
  204. std::string disassembly =
  205. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  206. EXPECT_THAT(disassembly, Eq(spirv));
  207. }
  208. TEST_F(MemoryRoundTripTest, OpCopyMemoryAccessMixedGood) {
  209. std::string spirv =
  210. "OpCopyMemory %1 %2 "
  211. "Volatile|Aligned|Nontemporal|MakePointerAvailable|"
  212. "MakePointerVisible|NonPrivatePointer 16 %3 %4\n";
  213. EXPECT_THAT(CompiledInstructions(spirv),
  214. Eq(MakeInstruction(spv::Op::OpCopyMemory, {1, 2, 63, 16, 3, 4})));
  215. std::string disassembly =
  216. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  217. EXPECT_THAT(disassembly, Eq(spirv));
  218. }
  219. TEST_F(MemoryRoundTripTest, OpCopyMemoryTwoAccessV13Good) {
  220. std::string spirv = "OpCopyMemory %1 %2 Volatile Volatile\n";
  221. // Note: This will assemble but should not validate for SPIR-V 1.3
  222. EXPECT_THAT(CompiledInstructions(spirv, SPV_ENV_UNIVERSAL_1_3),
  223. Eq(MakeInstruction(spv::Op::OpCopyMemory, {1, 2, 1, 1})));
  224. std::string disassembly =
  225. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  226. EXPECT_THAT(disassembly, Eq(spirv));
  227. }
  228. TEST_F(MemoryRoundTripTest, OpCopyMemoryTwoAccessV14Good) {
  229. std::string spirv = "OpCopyMemory %1 %2 Volatile Volatile\n";
  230. EXPECT_THAT(CompiledInstructions(spirv, SPV_ENV_UNIVERSAL_1_4),
  231. Eq(MakeInstruction(spv::Op::OpCopyMemory, {1, 2, 1, 1})));
  232. std::string disassembly =
  233. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  234. EXPECT_THAT(disassembly, Eq(spirv));
  235. }
  236. TEST_F(MemoryRoundTripTest, OpCopyMemoryTwoAccessMixedV14Good) {
  237. std::string spirv =
  238. "OpCopyMemory %1 %2 Volatile|Nontemporal|"
  239. "MakePointerVisible %3 "
  240. "Aligned|MakePointerAvailable|NonPrivatePointer 16 %4\n";
  241. EXPECT_THAT(
  242. CompiledInstructions(spirv),
  243. Eq(MakeInstruction(spv::Op::OpCopyMemory, {1, 2, 21, 3, 42, 16, 4})));
  244. std::string disassembly =
  245. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  246. EXPECT_THAT(disassembly, Eq(spirv));
  247. }
  248. // OpCopyMemorySized
  249. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedNoMemAccessGood) {
  250. std::string spirv = "OpCopyMemorySized %1 %2 %3\n";
  251. EXPECT_THAT(CompiledInstructions(spirv),
  252. Eq(MakeInstruction(spv::Op::OpCopyMemorySized, {1, 2, 3})));
  253. std::string disassembly =
  254. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  255. EXPECT_THAT(disassembly, Eq(spirv));
  256. }
  257. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedTooFewArgsBad) {
  258. std::string spirv = "OpCopyMemorySized %1 %2\n";
  259. std::string err = CompileFailure(spirv);
  260. EXPECT_THAT(err, HasSubstr("Expected operand for OpCopyMemorySized "
  261. "instruction, but found the end of the stream."));
  262. }
  263. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedTooManyArgsBad) {
  264. std::string spirv = "OpCopyMemorySized %1 %2 %3 %4\n";
  265. std::string err = CompileFailure(spirv);
  266. EXPECT_THAT(err, HasSubstr("Invalid memory access operand '%4'"));
  267. }
  268. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessNoneGood) {
  269. std::string spirv = "OpCopyMemorySized %1 %2 %3 None\n";
  270. EXPECT_THAT(CompiledInstructions(spirv),
  271. Eq(MakeInstruction(spv::Op::OpCopyMemorySized, {1, 2, 3, 0})));
  272. std::string disassembly =
  273. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  274. EXPECT_THAT(disassembly, Eq(spirv));
  275. }
  276. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessVolatileGood) {
  277. std::string spirv = "OpCopyMemorySized %1 %2 %3 Volatile\n";
  278. EXPECT_THAT(CompiledInstructions(spirv),
  279. Eq(MakeInstruction(spv::Op::OpCopyMemorySized, {1, 2, 3, 1})));
  280. std::string disassembly =
  281. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  282. EXPECT_THAT(disassembly, Eq(spirv));
  283. }
  284. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessAligned8Good) {
  285. std::string spirv = "OpCopyMemorySized %1 %2 %3 Aligned 8\n";
  286. EXPECT_THAT(CompiledInstructions(spirv),
  287. Eq(MakeInstruction(spv::Op::OpCopyMemorySized, {1, 2, 3, 2, 8})));
  288. std::string disassembly =
  289. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  290. EXPECT_THAT(disassembly, Eq(spirv));
  291. }
  292. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessNontemporalGood) {
  293. std::string spirv = "OpCopyMemorySized %1 %2 %3 Nontemporal\n";
  294. EXPECT_THAT(CompiledInstructions(spirv),
  295. Eq(MakeInstruction(spv::Op::OpCopyMemorySized, {1, 2, 3, 4})));
  296. std::string disassembly =
  297. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  298. EXPECT_THAT(disassembly, Eq(spirv));
  299. }
  300. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessAvGood) {
  301. std::string spirv = "OpCopyMemorySized %1 %2 %3 MakePointerAvailable %4\n";
  302. EXPECT_THAT(CompiledInstructions(spirv),
  303. Eq(MakeInstruction(spv::Op::OpCopyMemorySized, {1, 2, 3, 8, 4})));
  304. std::string disassembly =
  305. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  306. EXPECT_THAT(disassembly, Eq(spirv));
  307. }
  308. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessVisGood) {
  309. std::string spirv = "OpCopyMemorySized %1 %2 %3 MakePointerVisible %4\n";
  310. EXPECT_THAT(
  311. CompiledInstructions(spirv),
  312. Eq(MakeInstruction(spv::Op::OpCopyMemorySized, {1, 2, 3, 16, 4})));
  313. std::string disassembly =
  314. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  315. EXPECT_THAT(disassembly, Eq(spirv));
  316. }
  317. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessNonPrivateGood) {
  318. std::string spirv = "OpCopyMemorySized %1 %2 %3 NonPrivatePointer\n";
  319. EXPECT_THAT(CompiledInstructions(spirv),
  320. Eq(MakeInstruction(spv::Op::OpCopyMemorySized, {1, 2, 3, 32})));
  321. std::string disassembly =
  322. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  323. EXPECT_THAT(disassembly, Eq(spirv));
  324. }
  325. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedAccessMixedGood) {
  326. std::string spirv =
  327. "OpCopyMemorySized %1 %2 %3 "
  328. "Volatile|Aligned|Nontemporal|MakePointerAvailable|"
  329. "MakePointerVisible|NonPrivatePointer 16 %4 %5\n";
  330. EXPECT_THAT(
  331. CompiledInstructions(spirv),
  332. Eq(MakeInstruction(spv::Op::OpCopyMemorySized, {1, 2, 3, 63, 16, 4, 5})));
  333. std::string disassembly =
  334. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  335. EXPECT_THAT(disassembly, Eq(spirv));
  336. }
  337. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedTwoAccessV13Good) {
  338. std::string spirv = "OpCopyMemorySized %1 %2 %3 Volatile Volatile\n";
  339. // Note: This will assemble but should not validate for SPIR-V 1.3
  340. EXPECT_THAT(CompiledInstructions(spirv, SPV_ENV_UNIVERSAL_1_3),
  341. Eq(MakeInstruction(spv::Op::OpCopyMemorySized, {1, 2, 3, 1, 1})));
  342. std::string disassembly =
  343. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  344. EXPECT_THAT(disassembly, Eq(spirv));
  345. }
  346. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedTwoAccessV14Good) {
  347. std::string spirv = "OpCopyMemorySized %1 %2 %3 Volatile Volatile\n";
  348. EXPECT_THAT(CompiledInstructions(spirv, SPV_ENV_UNIVERSAL_1_4),
  349. Eq(MakeInstruction(spv::Op::OpCopyMemorySized, {1, 2, 3, 1, 1})));
  350. std::string disassembly =
  351. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  352. EXPECT_THAT(disassembly, Eq(spirv));
  353. }
  354. TEST_F(MemoryRoundTripTest, OpCopyMemorySizedTwoAccessMixedV14Good) {
  355. std::string spirv =
  356. "OpCopyMemorySized %1 %2 %3 Volatile|Nontemporal|"
  357. "MakePointerVisible %4 "
  358. "Aligned|MakePointerAvailable|NonPrivatePointer 16 %5\n";
  359. EXPECT_THAT(CompiledInstructions(spirv),
  360. Eq(MakeInstruction(spv::Op::OpCopyMemorySized,
  361. {1, 2, 3, 21, 4, 42, 16, 5})));
  362. std::string disassembly =
  363. EncodeAndDecodeSuccessfully(spirv, SPV_BINARY_TO_TEXT_OPTION_NONE);
  364. EXPECT_THAT(disassembly, Eq(spirv));
  365. }
  366. // TODO(dneto): OpVariable with initializers
  367. // TODO(dneto): OpImageTexelPointer
  368. // TODO(dneto): OpLoad
  369. // TODO(dneto): OpStore
  370. // TODO(dneto): OpAccessChain
  371. // TODO(dneto): OpInBoundsAccessChain
  372. // TODO(dneto): OpPtrAccessChain
  373. // TODO(dneto): OpArrayLength
  374. // TODO(dneto): OpGenercPtrMemSemantics
  375. } // namespace
  376. } // namespace spvtools