mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-12-16 00:17:03 +00:00
validation: Allow interpolate(flat) on integral IO
Produce a warning if the attribute is missing for integral vertex outputs or fragment inputs. This will become an error in the future, as per the WGSL spec. Add the attribute to E2E tests. Bug: tint:1224 Change-Id: Ia1f353f36cb7db516cf9e8b4877423dec3b3e711 Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/67160 Auto-Submit: James Price <jrprice@google.com> Reviewed-by: Ben Clayton <bclayton@google.com> Commit-Queue: James Price <jrprice@google.com> Kokoro: Kokoro <noreply+kokoro@google.com>
This commit is contained in:
committed by
Tint LUCI CQ
parent
1aa98e62c0
commit
a41694e9a3
@@ -161,8 +161,11 @@ struct CanonicalizeEntryPointIO::State {
|
||||
if (cfg.shader_style == ShaderStyle::kSpirv) {
|
||||
// Vulkan requires that integer user-defined fragment inputs are
|
||||
// always decorated with `Flat`.
|
||||
// TODO(crbug.com/tint/1224): Remove this once a flat interpolation
|
||||
// attribute is required for integers.
|
||||
if (type->is_integer_scalar_or_vector() &&
|
||||
ast::HasDecoration<ast::LocationDecoration>(attributes) &&
|
||||
!ast::HasDecoration<ast::InterpolateDecoration>(attributes) &&
|
||||
func_ast->PipelineStage() == ast::PipelineStage::kFragment) {
|
||||
attributes.push_back(ctx.dst->Interpolate(
|
||||
ast::InterpolationType::kFlat, ast::InterpolationSampling::kNone));
|
||||
@@ -217,9 +220,12 @@ struct CanonicalizeEntryPointIO::State {
|
||||
const ast::Expression* value) {
|
||||
// Vulkan requires that integer user-defined vertex outputs are
|
||||
// always decorated with `Flat`.
|
||||
// TODO(crbug.com/tint/1224): Remove this once a flat interpolation
|
||||
// attribute is required for integers.
|
||||
if (cfg.shader_style == ShaderStyle::kSpirv &&
|
||||
type->is_integer_scalar_or_vector() &&
|
||||
ast::HasDecoration<ast::LocationDecoration>(attributes) &&
|
||||
!ast::HasDecoration<ast::InterpolateDecoration>(attributes) &&
|
||||
func_ast->PipelineStage() == ast::PipelineStage::kVertex) {
|
||||
attributes.push_back(ctx.dst->Interpolate(
|
||||
ast::InterpolationType::kFlat, ast::InterpolationSampling::kNone));
|
||||
|
||||
Reference in New Issue
Block a user