[spirv-writer] Add DiscardStatement support.
This CL updates the spirv-writer to emit the DiscardStatement as an OpKill. Bug: tint:163 Change-Id: Ic2514ee8a4ef7ef0220fc2e1145f8df0c3d32069 Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/25641 Reviewed-by: David Neto <dneto@google.com>
This commit is contained in:
parent
b4374c271e
commit
6a61d4127e
1
BUILD.gn
1
BUILD.gn
|
@ -803,6 +803,7 @@ source_set("tint_unittests_spv_writer_src") {
|
||||||
"src/writer/spirv/builder_call_test.cc",
|
"src/writer/spirv/builder_call_test.cc",
|
||||||
"src/writer/spirv/builder_cast_expression_test.cc",
|
"src/writer/spirv/builder_cast_expression_test.cc",
|
||||||
"src/writer/spirv/builder_constructor_expression_test.cc",
|
"src/writer/spirv/builder_constructor_expression_test.cc",
|
||||||
|
"src/writer/spirv/builder_discard_test.cc",
|
||||||
"src/writer/spirv/builder_entry_point_test.cc",
|
"src/writer/spirv/builder_entry_point_test.cc",
|
||||||
"src/writer/spirv/builder_function_test.cc",
|
"src/writer/spirv/builder_function_test.cc",
|
||||||
"src/writer/spirv/builder_function_variable_test.cc",
|
"src/writer/spirv/builder_function_variable_test.cc",
|
||||||
|
|
|
@ -457,6 +457,7 @@ if(${TINT_BUILD_SPV_WRITER})
|
||||||
writer/spirv/builder_call_test.cc
|
writer/spirv/builder_call_test.cc
|
||||||
writer/spirv/builder_cast_expression_test.cc
|
writer/spirv/builder_cast_expression_test.cc
|
||||||
writer/spirv/builder_constructor_expression_test.cc
|
writer/spirv/builder_constructor_expression_test.cc
|
||||||
|
writer/spirv/builder_discard_test.cc
|
||||||
writer/spirv/builder_entry_point_test.cc
|
writer/spirv/builder_entry_point_test.cc
|
||||||
writer/spirv/builder_function_test.cc
|
writer/spirv/builder_function_test.cc
|
||||||
writer/spirv/builder_function_variable_test.cc
|
writer/spirv/builder_function_variable_test.cc
|
||||||
|
|
|
@ -105,8 +105,8 @@ bool LastIsTerminator(const ast::StatementList& stmts) {
|
||||||
}
|
}
|
||||||
|
|
||||||
auto* last = stmts.back().get();
|
auto* last = stmts.back().get();
|
||||||
return last->IsBreak() || last->IsContinue() || last->IsReturn() ||
|
return last->IsBreak() || last->IsContinue() || last->IsDiscard() ||
|
||||||
last->IsKill() || last->IsFallthrough();
|
last->IsReturn() || last->IsKill() || last->IsFallthrough();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t IndexFromName(char name) {
|
uint32_t IndexFromName(char name) {
|
||||||
|
@ -273,6 +273,14 @@ bool Builder::GenerateContinueStatement(ast::ContinueStatement*) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO(dsinclair): This is generating an OpKill but the semantics of kill
|
||||||
|
// haven't been defined for WGSL yet. So, this may need to change.
|
||||||
|
// https://github.com/gpuweb/gpuweb/issues/676
|
||||||
|
bool Builder::GenerateDiscardStatement(ast::DiscardStatement*) {
|
||||||
|
push_function_inst(spv::Op::OpKill, {});
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
// TODO(dsinclair): This is generating an OpKill but the semantics of kill
|
// TODO(dsinclair): This is generating an OpKill but the semantics of kill
|
||||||
// haven't been defined for WGSL yet. So, this may need to change.
|
// haven't been defined for WGSL yet. So, this may need to change.
|
||||||
// https://github.com/gpuweb/gpuweb/issues/676
|
// https://github.com/gpuweb/gpuweb/issues/676
|
||||||
|
@ -1816,6 +1824,9 @@ bool Builder::GenerateStatement(ast::Statement* stmt) {
|
||||||
if (stmt->IsContinue()) {
|
if (stmt->IsContinue()) {
|
||||||
return GenerateContinueStatement(stmt->AsContinue());
|
return GenerateContinueStatement(stmt->AsContinue());
|
||||||
}
|
}
|
||||||
|
if (stmt->IsDiscard()) {
|
||||||
|
return GenerateDiscardStatement(stmt->AsDiscard());
|
||||||
|
}
|
||||||
if (stmt->IsFallthrough()) {
|
if (stmt->IsFallthrough()) {
|
||||||
// Do nothing here, the fallthrough gets handled by the switch code.
|
// Do nothing here, the fallthrough gets handled by the switch code.
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -175,6 +175,10 @@ class Builder {
|
||||||
/// @param stmt the statement to generate
|
/// @param stmt the statement to generate
|
||||||
/// @returns true if the statement was successfully generated
|
/// @returns true if the statement was successfully generated
|
||||||
bool GenerateContinueStatement(ast::ContinueStatement* stmt);
|
bool GenerateContinueStatement(ast::ContinueStatement* stmt);
|
||||||
|
/// Generates a discard statement
|
||||||
|
/// @param stmt the statement to generate
|
||||||
|
/// @returns true if the statement was successfully generated
|
||||||
|
bool GenerateDiscardStatement(ast::DiscardStatement* stmt);
|
||||||
/// Generates a kill statement
|
/// Generates a kill statement
|
||||||
/// @param stmt the statement to generate
|
/// @param stmt the statement to generate
|
||||||
/// @returns true if the statement was successfully generated
|
/// @returns true if the statement was successfully generated
|
||||||
|
|
|
@ -0,0 +1,43 @@
|
||||||
|
// 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 "gtest/gtest.h"
|
||||||
|
#include "src/ast/discard_statement.h"
|
||||||
|
#include "src/context.h"
|
||||||
|
#include "src/type_determiner.h"
|
||||||
|
#include "src/writer/spirv/builder.h"
|
||||||
|
#include "src/writer/spirv/spv_dump.h"
|
||||||
|
|
||||||
|
namespace tint {
|
||||||
|
namespace writer {
|
||||||
|
namespace spirv {
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
using BuilderTest = testing::Test;
|
||||||
|
|
||||||
|
TEST_F(BuilderTest, Discard) {
|
||||||
|
ast::DiscardStatement expr;
|
||||||
|
|
||||||
|
ast::Module mod;
|
||||||
|
Builder b(&mod);
|
||||||
|
b.push_function(Function{});
|
||||||
|
EXPECT_EQ(b.GenerateStatement(&expr), 1u) << b.error();
|
||||||
|
EXPECT_EQ(DumpInstructions(b.functions()[0].instructions()), R"(OpKill
|
||||||
|
)");
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace
|
||||||
|
} // namespace spirv
|
||||||
|
} // namespace writer
|
||||||
|
} // namespace tint
|
Loading…
Reference in New Issue