mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-07-10 15:15:58 +00:00
Move the generic code for building up a SPIR-V module from Builder to a new Module class. This can then be reused by the new IR-based SPIR-V writer. Switches to naming of methods to camel case to bring in line with the rest of the codebase. Bug: tint:1906 Change-Id: I7775edff6fe56328c6562559c016a19097b50805 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/131340 Reviewed-by: Dan Sinclair <dsinclair@chromium.org> Commit-Queue: James Price <jrprice@google.com> Kokoro: Kokoro <noreply+kokoro@google.com>
118 lines
3.6 KiB
C++
118 lines
3.6 KiB
C++
// Copyright 2020 The Tint Authors.
|
|
//
|
|
// 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
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// 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.
|
|
|
|
#include "src/tint/writer/spirv/spv_dump.h"
|
|
#include "src/tint/writer/spirv/test_helper.h"
|
|
|
|
using namespace tint::number_suffixes; // NOLINT
|
|
|
|
namespace tint::writer::spirv {
|
|
namespace {
|
|
|
|
using BuilderTest = TestHelper;
|
|
|
|
TEST_F(BuilderTest, UnaryOp_Negation_Integer) {
|
|
auto* expr = create<ast::UnaryOpExpression>(ast::UnaryOp::kNegation, Expr(1_i));
|
|
WrapInFunction(expr);
|
|
|
|
spirv::Builder& b = Build();
|
|
|
|
b.PushFunctionForTesting();
|
|
EXPECT_EQ(b.GenerateUnaryOpExpression(expr), 1u) << b.error();
|
|
EXPECT_EQ(DumpInstructions(b.Module().Types()), R"(%2 = OpTypeInt 32 1
|
|
%3 = OpConstant %2 1
|
|
)");
|
|
EXPECT_EQ(DumpInstructions(b.CurrentFunction().instructions()),
|
|
R"(%1 = OpSNegate %2 %3
|
|
)");
|
|
}
|
|
|
|
TEST_F(BuilderTest, UnaryOp_Negation_Float) {
|
|
auto* expr = create<ast::UnaryOpExpression>(ast::UnaryOp::kNegation, Expr(1_f));
|
|
WrapInFunction(expr);
|
|
|
|
spirv::Builder& b = Build();
|
|
|
|
b.PushFunctionForTesting();
|
|
EXPECT_EQ(b.GenerateUnaryOpExpression(expr), 1u) << b.error();
|
|
EXPECT_EQ(DumpInstructions(b.Module().Types()), R"(%2 = OpTypeFloat 32
|
|
%3 = OpConstant %2 1
|
|
)");
|
|
EXPECT_EQ(DumpInstructions(b.CurrentFunction().instructions()),
|
|
R"(%1 = OpFNegate %2 %3
|
|
)");
|
|
}
|
|
|
|
TEST_F(BuilderTest, UnaryOp_Complement) {
|
|
auto* expr = create<ast::UnaryOpExpression>(ast::UnaryOp::kComplement, Expr(1_i));
|
|
WrapInFunction(expr);
|
|
|
|
spirv::Builder& b = Build();
|
|
|
|
b.PushFunctionForTesting();
|
|
EXPECT_EQ(b.GenerateUnaryOpExpression(expr), 1u) << b.error();
|
|
EXPECT_EQ(DumpInstructions(b.Module().Types()), R"(%2 = OpTypeInt 32 1
|
|
%3 = OpConstant %2 1
|
|
)");
|
|
EXPECT_EQ(DumpInstructions(b.CurrentFunction().instructions()),
|
|
R"(%1 = OpNot %2 %3
|
|
)");
|
|
}
|
|
|
|
TEST_F(BuilderTest, UnaryOp_Not) {
|
|
auto* expr = create<ast::UnaryOpExpression>(ast::UnaryOp::kNot, Expr(false));
|
|
WrapInFunction(expr);
|
|
|
|
spirv::Builder& b = Build();
|
|
|
|
b.PushFunctionForTesting();
|
|
EXPECT_EQ(b.GenerateUnaryOpExpression(expr), 1u) << b.error();
|
|
EXPECT_EQ(DumpInstructions(b.Module().Types()), R"(%2 = OpTypeBool
|
|
%3 = OpConstantNull %2
|
|
)");
|
|
EXPECT_EQ(DumpInstructions(b.CurrentFunction().instructions()),
|
|
R"(%1 = OpLogicalNot %2 %3
|
|
)");
|
|
}
|
|
|
|
TEST_F(BuilderTest, UnaryOp_LoadRequired) {
|
|
auto* var = Var("param", ty.vec3<f32>());
|
|
|
|
auto* expr = create<ast::UnaryOpExpression>(ast::UnaryOp::kNegation, Expr("param"));
|
|
WrapInFunction(var, expr);
|
|
|
|
spirv::Builder& b = Build();
|
|
|
|
b.PushFunctionForTesting();
|
|
EXPECT_TRUE(b.GenerateFunctionVariable(var)) << b.error();
|
|
EXPECT_EQ(b.GenerateUnaryOpExpression(expr), 6u) << b.error();
|
|
ASSERT_FALSE(b.has_error()) << b.error();
|
|
|
|
EXPECT_EQ(DumpInstructions(b.Module().Types()), R"(%4 = OpTypeFloat 32
|
|
%3 = OpTypeVector %4 3
|
|
%2 = OpTypePointer Function %3
|
|
%5 = OpConstantNull %3
|
|
)");
|
|
EXPECT_EQ(DumpInstructions(b.CurrentFunction().variables()),
|
|
R"(%1 = OpVariable %2 Function %5
|
|
)");
|
|
EXPECT_EQ(DumpInstructions(b.CurrentFunction().instructions()),
|
|
R"(%7 = OpLoad %3 %1
|
|
%6 = OpFNegate %3 %7
|
|
)");
|
|
}
|
|
|
|
} // namespace
|
|
} // namespace tint::writer::spirv
|