1fd4e5da5Sopenharmony_ci// Copyright (c) 2015-2016 The Khronos Group Inc. 2fd4e5da5Sopenharmony_ci// 3fd4e5da5Sopenharmony_ci// Licensed under the Apache License, Version 2.0 (the "License"); 4fd4e5da5Sopenharmony_ci// you may not use this file except in compliance with the License. 5fd4e5da5Sopenharmony_ci// You may obtain a copy of the License at 6fd4e5da5Sopenharmony_ci// 7fd4e5da5Sopenharmony_ci// http://www.apache.org/licenses/LICENSE-2.0 8fd4e5da5Sopenharmony_ci// 9fd4e5da5Sopenharmony_ci// Unless required by applicable law or agreed to in writing, software 10fd4e5da5Sopenharmony_ci// distributed under the License is distributed on an "AS IS" BASIS, 11fd4e5da5Sopenharmony_ci// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12fd4e5da5Sopenharmony_ci// See the License for the specific language governing permissions and 13fd4e5da5Sopenharmony_ci// limitations under the License. 14fd4e5da5Sopenharmony_ci 15fd4e5da5Sopenharmony_ci// Assembler tests for instructions in the "Miscellaneous" section of the 16fd4e5da5Sopenharmony_ci// SPIR-V spec. 17fd4e5da5Sopenharmony_ci 18fd4e5da5Sopenharmony_ci#include "test/unit_spirv.h" 19fd4e5da5Sopenharmony_ci 20fd4e5da5Sopenharmony_ci#include "gmock/gmock.h" 21fd4e5da5Sopenharmony_ci#include "test/test_fixture.h" 22fd4e5da5Sopenharmony_ci 23fd4e5da5Sopenharmony_cinamespace spvtools { 24fd4e5da5Sopenharmony_cinamespace { 25fd4e5da5Sopenharmony_ci 26fd4e5da5Sopenharmony_ciusing SpirvVector = spvtest::TextToBinaryTest::SpirvVector; 27fd4e5da5Sopenharmony_ciusing spvtest::MakeInstruction; 28fd4e5da5Sopenharmony_ciusing ::testing::Eq; 29fd4e5da5Sopenharmony_ciusing TextToBinaryMisc = spvtest::TextToBinaryTest; 30fd4e5da5Sopenharmony_ci 31fd4e5da5Sopenharmony_ciTEST_F(TextToBinaryMisc, OpNop) { 32fd4e5da5Sopenharmony_ci EXPECT_THAT(CompiledInstructions("OpNop"), 33fd4e5da5Sopenharmony_ci Eq(MakeInstruction(spv::Op::OpNop, {}))); 34fd4e5da5Sopenharmony_ci} 35fd4e5da5Sopenharmony_ci 36fd4e5da5Sopenharmony_ciTEST_F(TextToBinaryMisc, OpUndef) { 37fd4e5da5Sopenharmony_ci const SpirvVector code = CompiledInstructions(R"(%f32 = OpTypeFloat 32 38fd4e5da5Sopenharmony_ci %u = OpUndef %f32)"); 39fd4e5da5Sopenharmony_ci const uint32_t typeID = 1; 40fd4e5da5Sopenharmony_ci EXPECT_THAT(code[1], Eq(typeID)); 41fd4e5da5Sopenharmony_ci EXPECT_THAT(Subvector(code, 3), 42fd4e5da5Sopenharmony_ci Eq(MakeInstruction(spv::Op::OpUndef, {typeID, 2}))); 43fd4e5da5Sopenharmony_ci} 44fd4e5da5Sopenharmony_ci 45fd4e5da5Sopenharmony_ciTEST_F(TextToBinaryMisc, OpWrong) { 46fd4e5da5Sopenharmony_ci EXPECT_THAT(CompileFailure(" OpWrong %1 %2"), 47fd4e5da5Sopenharmony_ci Eq("Invalid Opcode name 'OpWrong'")); 48fd4e5da5Sopenharmony_ci} 49fd4e5da5Sopenharmony_ci 50fd4e5da5Sopenharmony_ciTEST_F(TextToBinaryMisc, OpWrongAfterRight) { 51fd4e5da5Sopenharmony_ci const auto assembly = R"( 52fd4e5da5Sopenharmony_ciOpCapability Shader 53fd4e5da5Sopenharmony_ciOpMemoryModel Logical GLSL450 54fd4e5da5Sopenharmony_ciOpXYZ 55fd4e5da5Sopenharmony_ci)"; 56fd4e5da5Sopenharmony_ci EXPECT_THAT(CompileFailure(assembly), Eq("Invalid Opcode name 'OpXYZ'")); 57fd4e5da5Sopenharmony_ci} 58fd4e5da5Sopenharmony_ci 59fd4e5da5Sopenharmony_ci} // namespace 60fd4e5da5Sopenharmony_ci} // namespace spvtools 61