mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-12-21 10:49:14 +00:00
Rename builtin(sample_mask_{in,out}) to builtin(sample_mask)
Removes the need to pass the storage class to the SPIR-V reader
builtin mapping function.
Added a deprecation warning for sample_mask_{in,out}.
Bug: tint:715
Change-Id: I948ff2de2d5de7bd05e1c6ff45bd721c856900e3
Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/47743
Commit-Queue: James Price <jrprice@google.com>
Auto-Submit: James Price <jrprice@google.com>
Reviewed-by: Ben Clayton <bclayton@google.com>
This commit is contained in:
committed by
Commit Bot service account
parent
88d7edcf7a
commit
edd4d3cc3b
@@ -197,7 +197,7 @@ TEST_F(CanonicalizeEntryPointIOTest, Return_Struct) {
|
||||
auto* src = R"(
|
||||
struct FragOutput {
|
||||
[[builtin(frag_depth)]] depth : f32;
|
||||
[[builtin(sample_mask_out)]] mask : u32;
|
||||
[[builtin(sample_mask)]] mask : u32;
|
||||
[[location(0)]] color : vec4<f32>;
|
||||
};
|
||||
|
||||
@@ -221,7 +221,7 @@ struct FragOutput {
|
||||
struct tint_symbol {
|
||||
[[builtin(frag_depth)]]
|
||||
depth : f32;
|
||||
[[builtin(sample_mask_out)]]
|
||||
[[builtin(sample_mask)]]
|
||||
mask : u32;
|
||||
[[location(0)]]
|
||||
color : vec4<f32>;
|
||||
|
||||
@@ -59,11 +59,11 @@ void Spirv::HandleEntryPointIOTypes(CloneContext& ctx) const {
|
||||
// ```
|
||||
// struct FragmentInput {
|
||||
// [[builtin(sample_index)]] sample_index : u32;
|
||||
// [[builtin(sample_mask_in)]] sample_mask_in : u32;
|
||||
// [[builtin(sample_mask)]] sample_mask : u32;
|
||||
// };
|
||||
// struct FragmentOutput {
|
||||
// [[builtin(frag_depth)]] depth: f32;
|
||||
// [[builtin(sample_mask_out)]] mask_out : u32;
|
||||
// [[builtin(sample_mask)]] mask_out : u32;
|
||||
// };
|
||||
//
|
||||
// [[stage(fragment)]]
|
||||
@@ -72,7 +72,7 @@ void Spirv::HandleEntryPointIOTypes(CloneContext& ctx) const {
|
||||
// samples : FragmentInput
|
||||
// ) -> FragmentOutput {
|
||||
// var output : FragmentOutput = FragmentOutput(1.0,
|
||||
// samples.sample_mask_in);
|
||||
// samples.sample_mask);
|
||||
// return output;
|
||||
// }
|
||||
// ```
|
||||
@@ -81,7 +81,7 @@ void Spirv::HandleEntryPointIOTypes(CloneContext& ctx) const {
|
||||
// ```
|
||||
// struct FragmentInput {
|
||||
// sample_index : u32;
|
||||
// sample_mask_in : u32;
|
||||
// sample_mask : u32;
|
||||
// };
|
||||
// struct FragmentOutput {
|
||||
// depth: f32;
|
||||
@@ -90,9 +90,9 @@ void Spirv::HandleEntryPointIOTypes(CloneContext& ctx) const {
|
||||
//
|
||||
// [[builtin(position)]] var<in> coord : vec4<f32>,
|
||||
// [[builtin(sample_index)]] var<in> sample_index : u32,
|
||||
// [[builtin(sample_mask_in)]] var<in> sample_mask_in : u32,
|
||||
// [[builtin(sample_mask)]] var<in> sample_mask : u32,
|
||||
// [[builtin(frag_depth)]] var<out> depth: f32;
|
||||
// [[builtin(sample_mask_out)]] var<out> mask_out : u32;
|
||||
// [[builtin(sample_mask)]] var<out> mask_out : u32;
|
||||
//
|
||||
// fn frag_main_ret(retval : FragmentOutput) {
|
||||
// depth = reval.depth;
|
||||
@@ -101,9 +101,9 @@ void Spirv::HandleEntryPointIOTypes(CloneContext& ctx) const {
|
||||
//
|
||||
// [[stage(fragment)]]
|
||||
// fn frag_main() {
|
||||
// let samples : FragmentInput(sample_index, sample_mask_in);
|
||||
// let samples : FragmentInput(sample_index, sample_mask);
|
||||
// var output : FragmentOutput = FragmentOutput(1.0,
|
||||
// samples.sample_mask_in);
|
||||
// samples.sample_mask);
|
||||
// frag_main_ret(output);
|
||||
// return;
|
||||
// }
|
||||
@@ -189,19 +189,19 @@ void Spirv::HandleEntryPointIOTypes(CloneContext& ctx) const {
|
||||
}
|
||||
|
||||
void Spirv::HandleSampleMaskBuiltins(CloneContext& ctx) const {
|
||||
// Find global variables decorated with [[builtin(sample_mask_{in,out})]] and
|
||||
// Find global variables decorated with [[builtin(sample_mask)]] and
|
||||
// change their type from `u32` to `array<u32, 1>`, as required by Vulkan.
|
||||
//
|
||||
// Before:
|
||||
// ```
|
||||
// [[builtin(sample_mask_out)]] var<out> mask_out : u32;
|
||||
// [[builtin(sample_mask)]] var<out> mask_out : u32;
|
||||
// fn main() {
|
||||
// mask_out = 1u;
|
||||
// }
|
||||
// ```
|
||||
// After:
|
||||
// ```
|
||||
// [[builtin(sample_mask_out)]] var<out> mask_out : array<u32, 1>;
|
||||
// [[builtin(sample_mask)]] var<out> mask_out : array<u32, 1>;
|
||||
// fn main() {
|
||||
// mask_out[0] = 1u;
|
||||
// }
|
||||
@@ -210,7 +210,8 @@ void Spirv::HandleSampleMaskBuiltins(CloneContext& ctx) const {
|
||||
for (auto* var : ctx.src->AST().GlobalVariables()) {
|
||||
for (auto* deco : var->decorations()) {
|
||||
if (auto* builtin = deco->As<ast::BuiltinDecoration>()) {
|
||||
if (builtin->value() != ast::Builtin::kSampleMaskIn &&
|
||||
if (builtin->value() != ast::Builtin::kSampleMask &&
|
||||
builtin->value() != ast::Builtin::kSampleMaskIn &&
|
||||
builtin->value() != ast::Builtin::kSampleMaskOut) {
|
||||
continue;
|
||||
}
|
||||
|
||||
@@ -487,9 +487,9 @@ TEST_F(SpirvTest, HandleSampleMaskBuiltins_Basic) {
|
||||
auto* src = R"(
|
||||
[[builtin(sample_index)]] var<in> sample_index : u32;
|
||||
|
||||
[[builtin(sample_mask_in)]] var<in> mask_in : u32;
|
||||
[[builtin(sample_mask)]] var<in> mask_in : u32;
|
||||
|
||||
[[builtin(sample_mask_out)]] var<out> mask_out : u32;
|
||||
[[builtin(sample_mask)]] var<out> mask_out : u32;
|
||||
|
||||
[[stage(fragment)]]
|
||||
fn main() {
|
||||
@@ -500,9 +500,9 @@ fn main() {
|
||||
auto* expect = R"(
|
||||
[[builtin(sample_index)]] var<in> sample_index : u32;
|
||||
|
||||
[[builtin(sample_mask_in)]] var<in> mask_in : array<u32, 1>;
|
||||
[[builtin(sample_mask)]] var<in> mask_in : array<u32, 1>;
|
||||
|
||||
[[builtin(sample_mask_out)]] var<out> mask_out : array<u32, 1>;
|
||||
[[builtin(sample_mask)]] var<out> mask_out : array<u32, 1>;
|
||||
|
||||
[[stage(fragment)]]
|
||||
fn main() {
|
||||
@@ -517,9 +517,9 @@ fn main() {
|
||||
|
||||
TEST_F(SpirvTest, HandleSampleMaskBuiltins_FunctionArg) {
|
||||
auto* src = R"(
|
||||
[[builtin(sample_mask_in)]] var<in> mask_in : u32;
|
||||
[[builtin(sample_mask)]] var<in> mask_in : u32;
|
||||
|
||||
[[builtin(sample_mask_out)]] var<out> mask_out : u32;
|
||||
[[builtin(sample_mask)]] var<out> mask_out : u32;
|
||||
|
||||
fn filter(mask: u32) -> u32 {
|
||||
return (mask & 3u);
|
||||
@@ -536,9 +536,9 @@ fn main() {
|
||||
)";
|
||||
|
||||
auto* expect = R"(
|
||||
[[builtin(sample_mask_in)]] var<in> mask_in : array<u32, 1>;
|
||||
[[builtin(sample_mask)]] var<in> mask_in : array<u32, 1>;
|
||||
|
||||
[[builtin(sample_mask_out)]] var<out> mask_out : array<u32, 1>;
|
||||
[[builtin(sample_mask)]] var<out> mask_out : array<u32, 1>;
|
||||
|
||||
fn filter(mask : u32) -> u32 {
|
||||
return (mask & 3u);
|
||||
@@ -578,8 +578,8 @@ TEST_F(SpirvTest, MultipleTransforms) {
|
||||
auto* src = R"(
|
||||
[[stage(fragment)]]
|
||||
fn main([[builtin(sample_index)]] sample_index : u32,
|
||||
[[builtin(sample_mask_in)]] mask_in : u32)
|
||||
-> [[builtin(sample_mask_out)]] u32 {
|
||||
[[builtin(sample_mask)]] mask_in : u32)
|
||||
-> [[builtin(sample_mask)]] u32 {
|
||||
return mask_in;
|
||||
}
|
||||
)";
|
||||
@@ -587,9 +587,9 @@ fn main([[builtin(sample_index)]] sample_index : u32,
|
||||
auto* expect = R"(
|
||||
[[builtin(sample_index)]] var<in> tint_symbol : u32;
|
||||
|
||||
[[builtin(sample_mask_in)]] var<in> tint_symbol_1 : array<u32, 1>;
|
||||
[[builtin(sample_mask)]] var<in> tint_symbol_1 : array<u32, 1>;
|
||||
|
||||
[[builtin(sample_mask_out)]] var<out> tint_symbol_3 : array<u32, 1>;
|
||||
[[builtin(sample_mask)]] var<out> tint_symbol_3 : array<u32, 1>;
|
||||
|
||||
fn tint_symbol_4(tint_symbol_2 : u32) {
|
||||
tint_symbol_3[0] = tint_symbol_2;
|
||||
|
||||
Reference in New Issue
Block a user