From f4fde6c60d71a1974db05adbc019b1dcc8e4a9ed Mon Sep 17 00:00:00 2001 From: David Neto Date: Mon, 14 Sep 2015 14:50:37 -0400 Subject: [PATCH] Assembler test for single-valued FunctionControl mask Fixed name of "Inline" enumerant. Support for combinations of function control masks should come later. --- CMakeLists.txt | 1 + readme.md | 2 ++ source/operand.cpp | 2 +- test/TextToBinary.Function.cpp | 79 ++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 83 insertions(+), 1 deletion(-) create mode 100644 test/TextToBinary.Function.cpp diff --git a/CMakeLists.txt b/CMakeLists.txt index 5e6fa9c..179270c 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -188,6 +188,7 @@ if (NOT ${SPIRV_SKIP_EXECUTABLES}) ${CMAKE_CURRENT_SOURCE_DIR}/test/TextToBinary.Annotation.cpp ${CMAKE_CURRENT_SOURCE_DIR}/test/TextToBinary.ControlFlow.cpp ${CMAKE_CURRENT_SOURCE_DIR}/test/TextToBinary.Debug.cpp + ${CMAKE_CURRENT_SOURCE_DIR}/test/TextToBinary.Function.cpp ${CMAKE_CURRENT_SOURCE_DIR}/test/TextToBinary.Miscellaneous.cpp ${CMAKE_CURRENT_SOURCE_DIR}/test/TextToBinary.ModeSetting.cpp ${CMAKE_CURRENT_SOURCE_DIR}/test/TextWordGet.cpp diff --git a/readme.md b/readme.md index 3e01846..a9276db 100644 --- a/readme.md +++ b/readme.md @@ -27,6 +27,8 @@ The validator is incomplete. See the Future Work section for more information. ## CHANGES (for tools hackers) +* Fixed spelling of Function Control "Inline" enumerated value. + 2015-09-11 * Assembly format must be consistent across the entire source module. * Add API assembler and disassembler entry points to control the format. diff --git a/source/operand.cpp b/source/operand.cpp index 3b49acf..5bee108 100644 --- a/source/operand.cpp +++ b/source/operand.cpp @@ -1004,7 +1004,7 @@ static const spv_operand_desc_t functionControlEntries[] = { SPV_OPCODE_FLAGS_NONE, 0, {SPV_OPERAND_TYPE_NONE}}, - {"InLine", + {"Inline", FunctionControlInlineMask, SPV_OPCODE_FLAGS_NONE, 0, diff --git a/test/TextToBinary.Function.cpp b/test/TextToBinary.Function.cpp new file mode 100644 index 0000000..7deb2fb --- /dev/null +++ b/test/TextToBinary.Function.cpp @@ -0,0 +1,79 @@ +// Copyright (c) 2015 The Khronos Group Inc. +// +// Permission is hereby granted, free of charge, to any person obtaining a +// copy of this software and/or associated documentation files (the +// "Materials"), to deal in the Materials without restriction, including +// without limitation the rights to use, copy, modify, merge, publish, +// distribute, sublicense, and/or sell copies of the Materials, and to +// permit persons to whom the Materials are furnished to do so, subject to +// the following conditions: +// +// The above copyright notice and this permission notice shall be included +// in all copies or substantial portions of the Materials. +// +// MODIFICATIONS TO THIS FILE MAY MEAN IT NO LONGER ACCURATELY REFLECTS +// KHRONOS STANDARDS. THE UNMODIFIED, NORMATIVE VERSIONS OF KHRONOS +// SPECIFICATIONS AND HEADER INFORMATION ARE LOCATED AT +// https://www.khronos.org/registry/ +// +// THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +// IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY +// CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, +// TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE +// MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS. + +// Assembler tests for instructions in the "Function" section of the +// SPIR-V spec. + +#include "UnitSPIRV.h" + +#include "gmock/gmock.h" +#include "TestFixture.h" + +namespace { + +using spvtest::MakeInstruction; +using ::testing::Eq; + +// An example case for an enumerated value. +template +struct EnumCase { + E value; + std::string name; +}; + +// Test OpFunction + +using OpFunctionControlTest = test_fixture::TextToBinaryTestBase< + ::testing::TestWithParam>>; + +TEST_P(OpFunctionControlTest, AnySingleFunctionControlMask) { + std::string input = "%result_id = OpFunction %result_type " + + GetParam().name + " %function_type "; + EXPECT_THAT( + CompiledInstructions(input), + Eq(MakeInstruction(spv::OpFunction, {1, 2, GetParam().value, 3}))); +} + +// clang-format off +#define CASE(VALUE,NAME) { spv::FunctionControl##VALUE, NAME} +INSTANTIATE_TEST_CASE_P(TextToBinaryFunctionTest, OpFunctionControlTest, + ::testing::ValuesIn(std::vector>{ + CASE(MaskNone, "None"), + CASE(InlineMask, "Inline"), + CASE(DontInlineMask, "DontInline"), + CASE(PureMask, "Pure"), + CASE(ConstMask, "Const"), + })); +#undef CASE +// clang-format on + +// TODO(dneto): Combination of function control masks. + +// TODO(dneto): OpFunctionParameter +// TODO(dneto): OpFunctionEnd +// TODO(dneto): OpFunctionCall + +} // anonymous namespace -- 2.7.4