2016-09-01 17:04:00 +00:00
|
|
|
// Copyright (c) 2016 Google Inc.
|
2016-04-21 19:46:08 +00:00
|
|
|
//
|
2016-09-01 19:33:59 +00:00
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
2016-04-21 19:46:08 +00:00
|
|
|
//
|
2016-09-01 19:33:59 +00:00
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
2016-04-21 19:46:08 +00:00
|
|
|
//
|
2016-09-01 19:33:59 +00:00
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
2016-04-21 19:46:08 +00:00
|
|
|
|
|
|
|
// Assembler tests for instructions in the "Barrier Instructions" section
|
|
|
|
// of the SPIR-V spec.
|
|
|
|
|
2018-08-03 19:06:09 +00:00
|
|
|
#include "test/unit_spirv.h"
|
2016-04-21 19:46:08 +00:00
|
|
|
|
|
|
|
#include "gmock/gmock.h"
|
2018-08-03 19:06:09 +00:00
|
|
|
#include "test/test_fixture.h"
|
2016-04-21 19:46:08 +00:00
|
|
|
|
2018-07-11 13:24:49 +00:00
|
|
|
namespace spvtools {
|
2016-04-21 19:46:08 +00:00
|
|
|
namespace {
|
|
|
|
|
|
|
|
using ::spvtest::MakeInstruction;
|
2017-11-27 15:16:41 +00:00
|
|
|
using ::testing::Eq;
|
2016-04-21 19:46:08 +00:00
|
|
|
|
|
|
|
using OpGetKernelLocalSizeForSubgroupCountTest = spvtest::TextToBinaryTest;
|
|
|
|
|
2018-06-19 13:54:33 +00:00
|
|
|
// We should be able to assemble it. Validation checks are in another test
|
|
|
|
// file.
|
|
|
|
TEST_F(OpGetKernelLocalSizeForSubgroupCountTest, OpcodeAssemblesInV10) {
|
2016-04-21 19:46:08 +00:00
|
|
|
EXPECT_THAT(
|
2018-06-19 13:54:33 +00:00
|
|
|
CompiledInstructions("%res = OpGetKernelLocalSizeForSubgroupCount %type "
|
|
|
|
"%sgcount %invoke %param %param_size %param_align",
|
|
|
|
SPV_ENV_UNIVERSAL_1_0),
|
2022-11-04 21:27:10 +00:00
|
|
|
Eq(MakeInstruction(spv::Op::OpGetKernelLocalSizeForSubgroupCount,
|
2018-06-19 13:54:33 +00:00
|
|
|
{1, 2, 3, 4, 5, 6, 7})));
|
2016-04-21 19:46:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(OpGetKernelLocalSizeForSubgroupCountTest, ArgumentCount) {
|
|
|
|
EXPECT_THAT(CompileFailure("OpGetKernelLocalSizeForSubgroupCount",
|
|
|
|
SPV_ENV_UNIVERSAL_1_1),
|
|
|
|
Eq("Expected <result-id> at the beginning of an instruction, "
|
|
|
|
"found 'OpGetKernelLocalSizeForSubgroupCount'."));
|
|
|
|
EXPECT_THAT(CompileFailure("%res = OpGetKernelLocalSizeForSubgroupCount",
|
|
|
|
SPV_ENV_UNIVERSAL_1_1),
|
2022-03-28 14:46:39 +00:00
|
|
|
Eq("Expected operand for OpGetKernelLocalSizeForSubgroupCount "
|
|
|
|
"instruction, but found the end of the stream."));
|
2016-04-21 19:46:08 +00:00
|
|
|
EXPECT_THAT(
|
|
|
|
CompileFailure("%1 = OpGetKernelLocalSizeForSubgroupCount %2 %3 %4 %5 %6",
|
|
|
|
SPV_ENV_UNIVERSAL_1_1),
|
2022-03-28 14:46:39 +00:00
|
|
|
Eq("Expected operand for OpGetKernelLocalSizeForSubgroupCount "
|
|
|
|
"instruction, but found the end of the stream."));
|
2016-04-21 19:46:08 +00:00
|
|
|
EXPECT_THAT(
|
|
|
|
CompiledInstructions("%res = OpGetKernelLocalSizeForSubgroupCount %type "
|
|
|
|
"%sgcount %invoke %param %param_size %param_align",
|
|
|
|
SPV_ENV_UNIVERSAL_1_1),
|
2022-11-04 21:27:10 +00:00
|
|
|
Eq(MakeInstruction(spv::Op::OpGetKernelLocalSizeForSubgroupCount,
|
2016-04-21 19:46:08 +00:00
|
|
|
{1, 2, 3, 4, 5, 6, 7})));
|
|
|
|
EXPECT_THAT(
|
|
|
|
CompileFailure("%res = OpGetKernelLocalSizeForSubgroupCount %type "
|
|
|
|
"%sgcount %invoke %param %param_size %param_align %extra",
|
|
|
|
SPV_ENV_UNIVERSAL_1_1),
|
|
|
|
Eq("Expected '=', found end of stream."));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(OpGetKernelLocalSizeForSubgroupCountTest, ArgumentTypes) {
|
|
|
|
EXPECT_THAT(CompileFailure(
|
|
|
|
"%1 = OpGetKernelLocalSizeForSubgroupCount 2 %3 %4 %5 %6 %7",
|
|
|
|
SPV_ENV_UNIVERSAL_1_1),
|
|
|
|
Eq("Expected id to start with %."));
|
|
|
|
EXPECT_THAT(
|
|
|
|
CompileFailure(
|
|
|
|
"%1 = OpGetKernelLocalSizeForSubgroupCount %2 %3 %4 %5 %6 \"abc\"",
|
|
|
|
SPV_ENV_UNIVERSAL_1_1),
|
|
|
|
Eq("Expected id to start with %."));
|
|
|
|
}
|
|
|
|
|
|
|
|
using OpGetKernelMaxNumSubgroupsTest = spvtest::TextToBinaryTest;
|
|
|
|
|
2018-06-19 13:54:33 +00:00
|
|
|
TEST_F(OpGetKernelMaxNumSubgroupsTest, OpcodeAssemblesInV10) {
|
2022-11-04 21:27:10 +00:00
|
|
|
EXPECT_THAT(CompiledInstructions("%res = OpGetKernelMaxNumSubgroups %type "
|
|
|
|
"%invoke %param %param_size %param_align",
|
|
|
|
SPV_ENV_UNIVERSAL_1_0),
|
|
|
|
Eq(MakeInstruction(spv::Op::OpGetKernelMaxNumSubgroups,
|
|
|
|
{1, 2, 3, 4, 5, 6})));
|
2016-04-21 19:46:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(OpGetKernelMaxNumSubgroupsTest, ArgumentCount) {
|
|
|
|
EXPECT_THAT(
|
|
|
|
CompileFailure("OpGetKernelMaxNumSubgroups", SPV_ENV_UNIVERSAL_1_1),
|
|
|
|
Eq("Expected <result-id> at the beginning of an instruction, found "
|
|
|
|
"'OpGetKernelMaxNumSubgroups'."));
|
|
|
|
EXPECT_THAT(CompileFailure("%res = OpGetKernelMaxNumSubgroups",
|
|
|
|
SPV_ENV_UNIVERSAL_1_1),
|
2022-03-28 14:46:39 +00:00
|
|
|
Eq("Expected operand for OpGetKernelMaxNumSubgroups instruction, "
|
|
|
|
"but found the end of the stream."));
|
2016-04-21 19:46:08 +00:00
|
|
|
EXPECT_THAT(CompileFailure("%1 = OpGetKernelMaxNumSubgroups %2 %3 %4 %5",
|
|
|
|
SPV_ENV_UNIVERSAL_1_1),
|
2022-03-28 14:46:39 +00:00
|
|
|
Eq("Expected operand for OpGetKernelMaxNumSubgroups instruction, "
|
|
|
|
"but found the end of the stream."));
|
2022-11-04 21:27:10 +00:00
|
|
|
EXPECT_THAT(CompiledInstructions("%res = OpGetKernelMaxNumSubgroups %type "
|
|
|
|
"%invoke %param %param_size %param_align",
|
|
|
|
SPV_ENV_UNIVERSAL_1_1),
|
|
|
|
Eq(MakeInstruction(spv::Op::OpGetKernelMaxNumSubgroups,
|
|
|
|
{1, 2, 3, 4, 5, 6})));
|
2016-04-21 19:46:08 +00:00
|
|
|
EXPECT_THAT(CompileFailure("%res = OpGetKernelMaxNumSubgroups %type %invoke "
|
|
|
|
"%param %param_size %param_align %extra",
|
|
|
|
SPV_ENV_UNIVERSAL_1_1),
|
|
|
|
Eq("Expected '=', found end of stream."));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(OpGetKernelMaxNumSubgroupsTest, ArgumentTypes) {
|
|
|
|
EXPECT_THAT(CompileFailure("%1 = OpGetKernelMaxNumSubgroups 2 %3 %4 %5 %6",
|
|
|
|
SPV_ENV_UNIVERSAL_1_1),
|
|
|
|
Eq("Expected id to start with %."));
|
|
|
|
EXPECT_THAT(
|
|
|
|
CompileFailure("%1 = OpGetKernelMaxNumSubgroups %2 %3 %4 %5 \"abc\"",
|
|
|
|
SPV_ENV_UNIVERSAL_1_1),
|
|
|
|
Eq("Expected id to start with %."));
|
|
|
|
}
|
|
|
|
|
2018-07-11 13:24:49 +00:00
|
|
|
} // namespace
|
|
|
|
} // namespace spvtools
|