From 1e98a9ba4a64301e0ab932e22ce989688f6cdf6c Mon Sep 17 00:00:00 2001 From: Zhaoming Jiang Date: Thu, 21 Jul 2022 19:55:35 +0000 Subject: [PATCH] tint: Normalizing type matcher's name in intrinsics.def This patch normalize the abstract interger and abstract float type name to `ia` and `fa` and the type matcher name to `fia_fiu32_f16` format in intrinsics.def, and also rename `aiu32Dispatch` and `afi32f16Dispatch` in resolver/const_eval.cc to `Dispatch_ia_iu32` and `Dispatch_fia_fi32_f16`. Bug: tint:1581 Change-Id: Ia48e150d6028e4a7b999f72e57508df369b3e2d7 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/96721 Reviewed-by: Ben Clayton Commit-Queue: Antonio Maiorano Kokoro: Kokoro Reviewed-by: Antonio Maiorano --- src/tint/intrinsics.def | 175 ++- src/tint/resolver/const_eval.cc | 8 +- src/tint/resolver/intrinsic_table.cc | 8 +- src/tint/resolver/intrinsic_table.inl | 1039 +++++++++--------- src/tint/resolver/intrinsic_table_test.cc | 20 +- tools/src/cmd/intrinsic-gen/gen/permutate.go | 2 +- 6 files changed, 607 insertions(+), 645 deletions(-) diff --git a/src/tint/intrinsics.def b/src/tint/intrinsics.def index 16f2ff4327..137558b8f6 100644 --- a/src/tint/intrinsics.def +++ b/src/tint/intrinsics.def @@ -71,8 +71,8 @@ enum texel_format { // https://gpuweb.github.io/gpuweb/wgsl/#plain-types-section type bool -@precedence(5) @display("abstract-float") type af -@precedence(4) @display("abstract-int") type ai +@precedence(5) @display("abstract-float") type fa +@precedence(4) @display("abstract-int") type ia @precedence(3) type i32 @precedence(2) type u32 @precedence(1) type f32 @@ -127,23 +127,22 @@ type __atomic_compare_exchange_result // A type matcher that can match one or more types. // //////////////////////////////////////////////////////////////////////////////// -match f32f16: f32 | f16 -match fiu32: f32 | i32 | u32 -match fiu32f16: f32 | f16 | i32 | u32 -match fi32: f32 | i32 -match fi32f16: f32 | f16 | i32 -match iu32: i32 | u32 -match aiu32: ai | i32 | u32 -match afi32f16: ai | af | f32 | i32 | f16 +match abstract_or_scalar: ia | fa | f32 | f16 | i32 | u32 | bool match scalar: f32 | f16 | i32 | u32 | bool -match abstract_or_scalar: ai | af | f32 | f16 | i32 | u32 | bool -match af_f32: af | f32 -match af_f32f16: af | f32 | f16 match scalar_no_f32: i32 | f16 | u32 | bool match scalar_no_f16: f32 | i32 | u32 | bool match scalar_no_i32: f32 | f16 | u32 | bool match scalar_no_u32: f32 | f16 | i32 | bool match scalar_no_bool: f32 | f16 | i32 | u32 +match fia_fi32_f16: fa | ia | f32 | i32 | f16 +match fa_f32_f16: fa | f32 | f16 +match ia_iu32: ia | i32 | u32 +match fiu32_f16: f32 | i32 | u32 | f16 +match fiu32: f32 | i32 | u32 +match fi32_f16: f32 | i32 | f16 +match fi32: f32 | i32 +match f32_f16: f32 | f16 +match iu32: i32 | u32 //////////////////////////////////////////////////////////////////////////////// // Enum matchers // @@ -648,15 +647,15 @@ fn textureLoad(texture: texture_external, coords: vec2) -> vec4 @const("Zero") ctor vec2() -> vec2 @const("Zero") ctor vec3() -> vec3 @const("Zero") ctor vec4() -> vec4 -@const("Zero") ctor mat2x2() -> mat2x2 -@const("Zero") ctor mat2x3() -> mat2x3 -@const("Zero") ctor mat2x4() -> mat2x4 -@const("Zero") ctor mat3x2() -> mat3x2 -@const("Zero") ctor mat3x3() -> mat3x3 -@const("Zero") ctor mat3x4() -> mat3x4 -@const("Zero") ctor mat4x2() -> mat4x2 -@const("Zero") ctor mat4x3() -> mat4x3 -@const("Zero") ctor mat4x4() -> mat4x4 +@const("Zero") ctor mat2x2() -> mat2x2 +@const("Zero") ctor mat2x3() -> mat2x3 +@const("Zero") ctor mat2x4() -> mat2x4 +@const("Zero") ctor mat3x2() -> mat3x2 +@const("Zero") ctor mat3x3() -> mat3x3 +@const("Zero") ctor mat3x4() -> mat3x4 +@const("Zero") ctor mat4x2() -> mat4x2 +@const("Zero") ctor mat4x3() -> mat4x3 +@const("Zero") ctor mat4x4() -> mat4x4 // Identity constructors @const("Identity") ctor i32(i32) -> i32 @@ -667,15 +666,15 @@ fn textureLoad(texture: texture_external, coords: vec2) -> vec4 @const("Identity") ctor vec2(vec2) -> vec2 @const("Identity") ctor vec3(vec3) -> vec3 @const("Identity") ctor vec4(vec4) -> vec4 -@const("Identity") ctor mat2x2(mat2x2) -> mat2x2 -@const("Identity") ctor mat2x3(mat2x3) -> mat2x3 -@const("Identity") ctor mat2x4(mat2x4) -> mat2x4 -@const("Identity") ctor mat3x2(mat3x2) -> mat3x2 -@const("Identity") ctor mat3x3(mat3x3) -> mat3x3 -@const("Identity") ctor mat3x4(mat3x4) -> mat3x4 -@const("Identity") ctor mat4x2(mat4x2) -> mat4x2 -@const("Identity") ctor mat4x3(mat4x3) -> mat4x3 -@const("Identity") ctor mat4x4(mat4x4) -> mat4x4 +@const("Identity") ctor mat2x2(mat2x2) -> mat2x2 +@const("Identity") ctor mat2x3(mat2x3) -> mat2x3 +@const("Identity") ctor mat2x4(mat2x4) -> mat2x4 +@const("Identity") ctor mat3x2(mat3x2) -> mat3x2 +@const("Identity") ctor mat3x3(mat3x3) -> mat3x3 +@const("Identity") ctor mat3x4(mat3x4) -> mat3x4 +@const("Identity") ctor mat4x2(mat4x2) -> mat4x2 +@const("Identity") ctor mat4x3(mat4x3) -> mat4x3 +@const("Identity") ctor mat4x4(mat4x4) -> mat4x4 // Vector constructors (splat) @const("VecSplat") ctor vec2(T) -> vec2 @@ -699,61 +698,61 @@ fn textureLoad(texture: texture_external, coords: vec2) -> vec4 // Matrix constructors (scalar) @const("MatCtorS") -ctor mat2x2(T, T, +ctor mat2x2(T, T, T, T) -> mat2x2 @const("MatCtorS") -ctor mat2x3(T, T, T, +ctor mat2x3(T, T, T, T, T, T) -> mat2x3 @const("MatCtorS") -ctor mat2x4(T, T, T, T, +ctor mat2x4(T, T, T, T, T, T, T, T) -> mat2x4 @const("MatCtorS") -ctor mat3x2(T, T, +ctor mat3x2(T, T, T, T, T, T) -> mat3x2 @const("MatCtorS") -ctor mat3x3(T, T, T, +ctor mat3x3(T, T, T, T, T, T, T, T, T) -> mat3x3 @const("MatCtorS") -ctor mat3x4(T, T, T, T, +ctor mat3x4(T, T, T, T, T, T, T, T, T, T, T, T) -> mat3x4 @const("MatCtorS") -ctor mat4x2(T, T, +ctor mat4x2(T, T, T, T, T, T, T, T) -> mat4x2 @const("MatCtorS") -ctor mat4x3(T, T, T, +ctor mat4x3(T, T, T, T, T, T, T, T, T, T, T, T) -> mat4x3 @const("MatCtorS") -ctor mat4x4(T, T, T, T, +ctor mat4x4(T, T, T, T, T, T, T, T, T, T, T, T, T, T, T, T) -> mat4x4 // Matrix constructors (column vectors) @const("MatCtorV") -ctor mat2x2(vec2, vec2) -> mat2x2 +ctor mat2x2(vec2, vec2) -> mat2x2 @const("MatCtorV") -ctor mat2x3(vec3, vec3) -> mat2x3 +ctor mat2x3(vec3, vec3) -> mat2x3 @const("MatCtorV") -ctor mat2x4(vec4, vec4) -> mat2x4 +ctor mat2x4(vec4, vec4) -> mat2x4 @const("MatCtorV") -ctor mat3x2(vec2, vec2, vec2) -> mat3x2 +ctor mat3x2(vec2, vec2, vec2) -> mat3x2 @const("MatCtorV") -ctor mat3x3(vec3, vec3, vec3) -> mat3x3 +ctor mat3x3(vec3, vec3, vec3) -> mat3x3 @const("MatCtorV") -ctor mat3x4(vec4, vec4, vec4) -> mat3x4 +ctor mat3x4(vec4, vec4, vec4) -> mat3x4 @const("MatCtorV") -ctor mat4x2(vec2, vec2, vec2, vec2) -> mat4x2 +ctor mat4x2(vec2, vec2, vec2, vec2) -> mat4x2 @const("MatCtorV") -ctor mat4x3(vec3, vec3, vec3, vec3) -> mat4x3 +ctor mat4x3(vec3, vec3, vec3, vec3) -> mat4x3 @const("MatCtorV") -ctor mat4x4(vec4, vec4, vec4, vec4) -> mat4x4 +ctor mat4x4(vec4, vec4, vec4, vec4) -> mat4x4 //////////////////////////////////////////////////////////////////////////////// // Type conversions // @@ -820,46 +819,46 @@ ctor mat4x4(vec4, vec4, vec4, vec4) -> mat4x4 op ! (bool) -> bool op ! (vec) -> vec -@const op ~ (T) -> T -@const op ~ (vec) -> vec +@const op ~ (T) -> T +@const op ~ (vec) -> vec -@const op - (T) -> T -@const op - (vec) -> vec +@const op - (T) -> T +@const op - (vec) -> vec //////////////////////////////////////////////////////////////////////////////// // Binary Operators // //////////////////////////////////////////////////////////////////////////////// -op + (T, T) -> T -op + (vec, vec) -> vec -op + (vec, T) -> vec -op + (T, vec) -> vec -op + (mat, mat) -> mat +op + (T, T) -> T +op + (vec, vec) -> vec +op + (vec, T) -> vec +op + (T, vec) -> vec +op + (mat, mat) -> mat -op - (T, T) -> T -op - (vec, vec) -> vec -op - (vec, T) -> vec -op - (T, vec) -> vec -op - (mat, mat) -> mat +op - (T, T) -> T +op - (vec, vec) -> vec +op - (vec, T) -> vec +op - (T, vec) -> vec +op - (mat, mat) -> mat -op * (T, T) -> T -op * (vec, vec) -> vec -op * (vec, T) -> vec -op * (T, vec) -> vec -op * (T, mat) -> mat -op * (mat, T) -> mat -op * (mat, vec) -> vec -op * (vec, mat) -> vec -op * (mat, mat) -> mat +op * (T, T) -> T +op * (vec, vec) -> vec +op * (vec, T) -> vec +op * (T, vec) -> vec +op * (T, mat) -> mat +op * (mat, T) -> mat +op * (mat, vec) -> vec +op * (vec, mat) -> vec +op * (mat, mat) -> mat -op / (T, T) -> T -op / (vec, vec) -> vec -op / (vec, T) -> vec -op / (T, vec) -> vec +op / (T, T) -> T +op / (vec, vec) -> vec +op / (vec, T) -> vec +op / (T, vec) -> vec -op % (T, T) -> T -op % (vec, vec) -> vec -op % (vec, T) -> vec -op % (T, vec) -> vec +op % (T, T) -> T +op % (vec, vec) -> vec +op % (vec, T) -> vec +op % (T, vec) -> vec op ^ (T, T) -> T op ^ (vec, vec) -> vec @@ -883,17 +882,17 @@ op == (vec, vec) -> vec op != (T, T) -> bool op != (vec, vec) -> vec -op < (T, T) -> bool -op < (vec, vec) -> vec +op < (T, T) -> bool +op < (vec, vec) -> vec -op > (T, T) -> bool -op > (vec, vec) -> vec +op > (T, T) -> bool +op > (vec, vec) -> vec -op <= (T, T) -> bool -op <= (vec, vec) -> vec +op <= (T, T) -> bool +op <= (vec, vec) -> vec -op >= (T, T) -> bool -op >= (vec, vec) -> vec +op >= (T, T) -> bool +op >= (vec, vec) -> vec op << (T, u32) -> T op << (vec, vec) -> vec diff --git a/src/tint/resolver/const_eval.cc b/src/tint/resolver/const_eval.cc index e2b16b5dde..c5ee387821 100644 --- a/src/tint/resolver/const_eval.cc +++ b/src/tint/resolver/const_eval.cc @@ -48,7 +48,7 @@ namespace { /// Helper that calls 'f' passing in `c`'s value template -auto aiu32Dispatch(const sem::Constant* c, F&& f) { +auto Dispatch_ia_iu32(const sem::Constant* c, F&& f) { return Switch( c->Type(), [&](const sem::AbstractInt*) { return f(c->As()); }, [&](const sem::I32*) { return f(c->As()); }, @@ -57,7 +57,7 @@ auto aiu32Dispatch(const sem::Constant* c, F&& f) { /// Helper that calls 'f' passing in `c`'s value template -auto afi32f16Dispatch(const sem::Constant* c, F&& f) { +auto Dispatch_fia_fi32_f16(const sem::Constant* c, F&& f) { return Switch( c->Type(), [&](const sem::AbstractInt*) { return f(c->As()); }, [&](const sem::AbstractFloat*) { return f(c->As()); }, @@ -654,7 +654,7 @@ const sem::Constant* ConstEval::OpComplement(const sem::Type*, sem::Expression const* const* args, size_t) { return TransformElements(builder, args[0]->ConstantValue(), [&](const sem::Constant* c) { - return aiu32Dispatch(c, [&](auto i) { // + return Dispatch_ia_iu32(c, [&](auto i) { // return CreateElement(builder, c->Type(), decltype(i)(~i.value)); }); }); @@ -664,7 +664,7 @@ const sem::Constant* ConstEval::OpMinus(const sem::Type*, sem::Expression const* const* args, size_t) { return TransformElements(builder, args[0]->ConstantValue(), [&](const sem::Constant* c) { - return afi32f16Dispatch(c, [&](auto i) { // + return Dispatch_fia_fi32_f16(c, [&](auto i) { // // For signed integrals, avoid C++ UB by not negating the smallest negative number. In // WGSL, this operation is well defined to return the same value, see: // https://gpuweb.github.io/gpuweb/wgsl/#arithmetic-expr. diff --git a/src/tint/resolver/intrinsic_table.cc b/src/tint/resolver/intrinsic_table.cc index 730e2cd163..b874df1f3f 100644 --- a/src/tint/resolver/intrinsic_table.cc +++ b/src/tint/resolver/intrinsic_table.cc @@ -322,19 +322,19 @@ bool match_bool(const sem::Type* ty) { return ty->IsAnyOf(); } -const sem::AbstractFloat* build_af(MatchState& state) { +const sem::AbstractFloat* build_fa(MatchState& state) { return state.builder.create(); } -bool match_af(const sem::Type* ty) { +bool match_fa(const sem::Type* ty) { return ty->IsAnyOf(); } -const sem::AbstractInt* build_ai(MatchState& state) { +const sem::AbstractInt* build_ia(MatchState& state) { return state.builder.create(); } -bool match_ai(const sem::Type* ty) { +bool match_ia(const sem::Type* ty) { return ty->IsAnyOf(); } diff --git a/src/tint/resolver/intrinsic_table.inl b/src/tint/resolver/intrinsic_table.inl index 811aa3495d..f5769f1f84 100644 --- a/src/tint/resolver/intrinsic_table.inl +++ b/src/tint/resolver/intrinsic_table.inl @@ -51,9 +51,9 @@ std::string Bool::String(MatchState*) const { return "bool"; } -/// TypeMatcher for 'type af' +/// TypeMatcher for 'type fa' /// @see src/tint/intrinsics.def:74:48 -class Af : public TypeMatcher { +class Fa : public TypeMatcher { public: /// Checks whether the given type matches the matcher rules. /// Match may define and refine the template types and numbers in state. @@ -67,22 +67,22 @@ class Af : public TypeMatcher { std::string String(MatchState* state) const override; }; -const sem::Type* Af::Match(MatchState& state, const sem::Type* ty) const { - if (!match_af(ty)) { +const sem::Type* Fa::Match(MatchState& state, const sem::Type* ty) const { + if (!match_fa(ty)) { return nullptr; } - return build_af(state); + return build_fa(state); } -std::string Af::String(MatchState*) const { +std::string Fa::String(MatchState*) const { std::stringstream ss; ss << "abstract-float"; return ss.str(); } -/// TypeMatcher for 'type ai' +/// TypeMatcher for 'type ia' /// @see src/tint/intrinsics.def:75:48 -class Ai : public TypeMatcher { +class Ia : public TypeMatcher { public: /// Checks whether the given type matches the matcher rules. /// Match may define and refine the template types and numbers in state. @@ -96,14 +96,14 @@ class Ai : public TypeMatcher { std::string String(MatchState* state) const override; }; -const sem::Type* Ai::Match(MatchState& state, const sem::Type* ty) const { - if (!match_ai(ty)) { +const sem::Type* Ia::Match(MatchState& state, const sem::Type* ty) const { + if (!match_ia(ty)) { return nullptr; } - return build_ai(state); + return build_ia(state); } -std::string Ai::String(MatchState*) const { +std::string Ia::String(MatchState*) const { std::stringstream ss; ss << "abstract-int"; return ss.str(); @@ -1572,9 +1572,9 @@ std::string AtomicCompareExchangeResult::String(MatchState* state) const { return "__atomic_compare_exchange_result<" + T + ">"; } -/// TypeMatcher for 'match f32f16' +/// TypeMatcher for 'match abstract_or_scalar' /// @see src/tint/intrinsics.def:130:7 -class F32F16 : public TypeMatcher { +class AbstractOrScalar : public TypeMatcher { public: /// Checks whether the given type matches the matcher rules, and returns the /// expected, canonicalized type on success. @@ -1589,80 +1589,13 @@ class F32F16 : public TypeMatcher { std::string String(MatchState* state) const override; }; -const sem::Type* F32F16::Match(MatchState& state, const sem::Type* ty) const { - if (match_f32(ty)) { - return build_f32(state); +const sem::Type* AbstractOrScalar::Match(MatchState& state, const sem::Type* ty) const { + if (match_fa(ty)) { + return build_fa(state); } - if (match_f16(ty)) { - return build_f16(state); + if (match_ia(ty)) { + return build_ia(state); } - return nullptr; -} - -std::string F32F16::String(MatchState*) const { - std::stringstream ss; - // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support - // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. - ss << F32().String(nullptr) << " or " << F16().String(nullptr); - return ss.str(); -} - -/// TypeMatcher for 'match fiu32' -/// @see src/tint/intrinsics.def:131:7 -class Fiu32 : public TypeMatcher { - public: - /// Checks whether the given type matches the matcher rules, and returns the - /// expected, canonicalized type on success. - /// Match may define and refine the template types and numbers in state. - /// @param state the MatchState - /// @param type the type to match - /// @returns the canonicalized type on match, otherwise nullptr - const sem::Type* Match(MatchState& state, - const sem::Type* type) const override; - /// @param state the MatchState - /// @return a string representation of the matcher. - std::string String(MatchState* state) const override; -}; - -const sem::Type* Fiu32::Match(MatchState& state, const sem::Type* ty) const { - if (match_i32(ty)) { - return build_i32(state); - } - if (match_u32(ty)) { - return build_u32(state); - } - if (match_f32(ty)) { - return build_f32(state); - } - return nullptr; -} - -std::string Fiu32::String(MatchState*) const { - std::stringstream ss; - // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support - // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. - ss << F32().String(nullptr) << ", " << I32().String(nullptr) << " or " << U32().String(nullptr); - return ss.str(); -} - -/// TypeMatcher for 'match fiu32f16' -/// @see src/tint/intrinsics.def:132:7 -class Fiu32F16 : public TypeMatcher { - public: - /// Checks whether the given type matches the matcher rules, and returns the - /// expected, canonicalized type on success. - /// Match may define and refine the template types and numbers in state. - /// @param state the MatchState - /// @param type the type to match - /// @returns the canonicalized type on match, otherwise nullptr - const sem::Type* Match(MatchState& state, - const sem::Type* type) const override; - /// @param state the MatchState - /// @return a string representation of the matcher. - std::string String(MatchState* state) const override; -}; - -const sem::Type* Fiu32F16::Match(MatchState& state, const sem::Type* ty) const { if (match_i32(ty)) { return build_i32(state); } @@ -1675,209 +1608,22 @@ const sem::Type* Fiu32F16::Match(MatchState& state, const sem::Type* ty) const { if (match_f16(ty)) { return build_f16(state); } - return nullptr; -} - -std::string Fiu32F16::String(MatchState*) const { - std::stringstream ss; - // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support - // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. - ss << F32().String(nullptr) << ", " << F16().String(nullptr) << ", " << I32().String(nullptr) << " or " << U32().String(nullptr); - return ss.str(); -} - -/// TypeMatcher for 'match fi32' -/// @see src/tint/intrinsics.def:133:7 -class Fi32 : public TypeMatcher { - public: - /// Checks whether the given type matches the matcher rules, and returns the - /// expected, canonicalized type on success. - /// Match may define and refine the template types and numbers in state. - /// @param state the MatchState - /// @param type the type to match - /// @returns the canonicalized type on match, otherwise nullptr - const sem::Type* Match(MatchState& state, - const sem::Type* type) const override; - /// @param state the MatchState - /// @return a string representation of the matcher. - std::string String(MatchState* state) const override; -}; - -const sem::Type* Fi32::Match(MatchState& state, const sem::Type* ty) const { - if (match_i32(ty)) { - return build_i32(state); - } - if (match_f32(ty)) { - return build_f32(state); + if (match_bool(ty)) { + return build_bool(state); } return nullptr; } -std::string Fi32::String(MatchState*) const { +std::string AbstractOrScalar::String(MatchState*) const { std::stringstream ss; // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. - ss << F32().String(nullptr) << " or " << I32().String(nullptr); - return ss.str(); -} - -/// TypeMatcher for 'match fi32f16' -/// @see src/tint/intrinsics.def:134:7 -class Fi32F16 : public TypeMatcher { - public: - /// Checks whether the given type matches the matcher rules, and returns the - /// expected, canonicalized type on success. - /// Match may define and refine the template types and numbers in state. - /// @param state the MatchState - /// @param type the type to match - /// @returns the canonicalized type on match, otherwise nullptr - const sem::Type* Match(MatchState& state, - const sem::Type* type) const override; - /// @param state the MatchState - /// @return a string representation of the matcher. - std::string String(MatchState* state) const override; -}; - -const sem::Type* Fi32F16::Match(MatchState& state, const sem::Type* ty) const { - if (match_i32(ty)) { - return build_i32(state); - } - if (match_f32(ty)) { - return build_f32(state); - } - if (match_f16(ty)) { - return build_f16(state); - } - return nullptr; -} - -std::string Fi32F16::String(MatchState*) const { - std::stringstream ss; - // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support - // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. - ss << F32().String(nullptr) << ", " << F16().String(nullptr) << " or " << I32().String(nullptr); - return ss.str(); -} - -/// TypeMatcher for 'match iu32' -/// @see src/tint/intrinsics.def:135:7 -class Iu32 : public TypeMatcher { - public: - /// Checks whether the given type matches the matcher rules, and returns the - /// expected, canonicalized type on success. - /// Match may define and refine the template types and numbers in state. - /// @param state the MatchState - /// @param type the type to match - /// @returns the canonicalized type on match, otherwise nullptr - const sem::Type* Match(MatchState& state, - const sem::Type* type) const override; - /// @param state the MatchState - /// @return a string representation of the matcher. - std::string String(MatchState* state) const override; -}; - -const sem::Type* Iu32::Match(MatchState& state, const sem::Type* ty) const { - if (match_i32(ty)) { - return build_i32(state); - } - if (match_u32(ty)) { - return build_u32(state); - } - return nullptr; -} - -std::string Iu32::String(MatchState*) const { - std::stringstream ss; - // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support - // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. - ss << I32().String(nullptr) << " or " << U32().String(nullptr); - return ss.str(); -} - -/// TypeMatcher for 'match aiu32' -/// @see src/tint/intrinsics.def:136:7 -class Aiu32 : public TypeMatcher { - public: - /// Checks whether the given type matches the matcher rules, and returns the - /// expected, canonicalized type on success. - /// Match may define and refine the template types and numbers in state. - /// @param state the MatchState - /// @param type the type to match - /// @returns the canonicalized type on match, otherwise nullptr - const sem::Type* Match(MatchState& state, - const sem::Type* type) const override; - /// @param state the MatchState - /// @return a string representation of the matcher. - std::string String(MatchState* state) const override; -}; - -const sem::Type* Aiu32::Match(MatchState& state, const sem::Type* ty) const { - if (match_ai(ty)) { - return build_ai(state); - } - if (match_i32(ty)) { - return build_i32(state); - } - if (match_u32(ty)) { - return build_u32(state); - } - return nullptr; -} - -std::string Aiu32::String(MatchState*) const { - std::stringstream ss; - // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support - // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. - ss << Ai().String(nullptr) << ", " << I32().String(nullptr) << " or " << U32().String(nullptr); - return ss.str(); -} - -/// TypeMatcher for 'match afi32f16' -/// @see src/tint/intrinsics.def:137:7 -class Afi32F16 : public TypeMatcher { - public: - /// Checks whether the given type matches the matcher rules, and returns the - /// expected, canonicalized type on success. - /// Match may define and refine the template types and numbers in state. - /// @param state the MatchState - /// @param type the type to match - /// @returns the canonicalized type on match, otherwise nullptr - const sem::Type* Match(MatchState& state, - const sem::Type* type) const override; - /// @param state the MatchState - /// @return a string representation of the matcher. - std::string String(MatchState* state) const override; -}; - -const sem::Type* Afi32F16::Match(MatchState& state, const sem::Type* ty) const { - if (match_af(ty)) { - return build_af(state); - } - if (match_ai(ty)) { - return build_ai(state); - } - if (match_i32(ty)) { - return build_i32(state); - } - if (match_f32(ty)) { - return build_f32(state); - } - if (match_f16(ty)) { - return build_f16(state); - } - return nullptr; -} - -std::string Afi32F16::String(MatchState*) const { - std::stringstream ss; - // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support - // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. - ss << Ai().String(nullptr) << ", " << Af().String(nullptr) << ", " << F32().String(nullptr) << ", " << I32().String(nullptr) << " or " << F16().String(nullptr); + ss << Ia().String(nullptr) << ", " << Fa().String(nullptr) << ", " << F32().String(nullptr) << ", " << F16().String(nullptr) << ", " << I32().String(nullptr) << ", " << U32().String(nullptr) << " or " << Bool().String(nullptr); return ss.str(); } /// TypeMatcher for 'match scalar' -/// @see src/tint/intrinsics.def:138:7 +/// @see src/tint/intrinsics.def:131:7 class Scalar : public TypeMatcher { public: /// Checks whether the given type matches the matcher rules, and returns the @@ -1920,131 +1666,8 @@ std::string Scalar::String(MatchState*) const { return ss.str(); } -/// TypeMatcher for 'match abstract_or_scalar' -/// @see src/tint/intrinsics.def:139:7 -class AbstractOrScalar : public TypeMatcher { - public: - /// Checks whether the given type matches the matcher rules, and returns the - /// expected, canonicalized type on success. - /// Match may define and refine the template types and numbers in state. - /// @param state the MatchState - /// @param type the type to match - /// @returns the canonicalized type on match, otherwise nullptr - const sem::Type* Match(MatchState& state, - const sem::Type* type) const override; - /// @param state the MatchState - /// @return a string representation of the matcher. - std::string String(MatchState* state) const override; -}; - -const sem::Type* AbstractOrScalar::Match(MatchState& state, const sem::Type* ty) const { - if (match_af(ty)) { - return build_af(state); - } - if (match_ai(ty)) { - return build_ai(state); - } - if (match_i32(ty)) { - return build_i32(state); - } - if (match_u32(ty)) { - return build_u32(state); - } - if (match_f32(ty)) { - return build_f32(state); - } - if (match_f16(ty)) { - return build_f16(state); - } - if (match_bool(ty)) { - return build_bool(state); - } - return nullptr; -} - -std::string AbstractOrScalar::String(MatchState*) const { - std::stringstream ss; - // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support - // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. - ss << Ai().String(nullptr) << ", " << Af().String(nullptr) << ", " << F32().String(nullptr) << ", " << F16().String(nullptr) << ", " << I32().String(nullptr) << ", " << U32().String(nullptr) << " or " << Bool().String(nullptr); - return ss.str(); -} - -/// TypeMatcher for 'match af_f32' -/// @see src/tint/intrinsics.def:140:7 -class AfF32 : public TypeMatcher { - public: - /// Checks whether the given type matches the matcher rules, and returns the - /// expected, canonicalized type on success. - /// Match may define and refine the template types and numbers in state. - /// @param state the MatchState - /// @param type the type to match - /// @returns the canonicalized type on match, otherwise nullptr - const sem::Type* Match(MatchState& state, - const sem::Type* type) const override; - /// @param state the MatchState - /// @return a string representation of the matcher. - std::string String(MatchState* state) const override; -}; - -const sem::Type* AfF32::Match(MatchState& state, const sem::Type* ty) const { - if (match_af(ty)) { - return build_af(state); - } - if (match_f32(ty)) { - return build_f32(state); - } - return nullptr; -} - -std::string AfF32::String(MatchState*) const { - std::stringstream ss; - // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support - // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. - ss << Af().String(nullptr) << " or " << F32().String(nullptr); - return ss.str(); -} - -/// TypeMatcher for 'match af_f32f16' -/// @see src/tint/intrinsics.def:141:7 -class AfF32F16 : public TypeMatcher { - public: - /// Checks whether the given type matches the matcher rules, and returns the - /// expected, canonicalized type on success. - /// Match may define and refine the template types and numbers in state. - /// @param state the MatchState - /// @param type the type to match - /// @returns the canonicalized type on match, otherwise nullptr - const sem::Type* Match(MatchState& state, - const sem::Type* type) const override; - /// @param state the MatchState - /// @return a string representation of the matcher. - std::string String(MatchState* state) const override; -}; - -const sem::Type* AfF32F16::Match(MatchState& state, const sem::Type* ty) const { - if (match_af(ty)) { - return build_af(state); - } - if (match_f32(ty)) { - return build_f32(state); - } - if (match_f16(ty)) { - return build_f16(state); - } - return nullptr; -} - -std::string AfF32F16::String(MatchState*) const { - std::stringstream ss; - // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support - // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. - ss << Af().String(nullptr) << ", " << F32().String(nullptr) << " or " << F16().String(nullptr); - return ss.str(); -} - /// TypeMatcher for 'match scalar_no_f32' -/// @see src/tint/intrinsics.def:142:7 +/// @see src/tint/intrinsics.def:132:7 class ScalarNoF32 : public TypeMatcher { public: /// Checks whether the given type matches the matcher rules, and returns the @@ -2085,7 +1708,7 @@ std::string ScalarNoF32::String(MatchState*) const { } /// TypeMatcher for 'match scalar_no_f16' -/// @see src/tint/intrinsics.def:143:7 +/// @see src/tint/intrinsics.def:133:7 class ScalarNoF16 : public TypeMatcher { public: /// Checks whether the given type matches the matcher rules, and returns the @@ -2126,7 +1749,7 @@ std::string ScalarNoF16::String(MatchState*) const { } /// TypeMatcher for 'match scalar_no_i32' -/// @see src/tint/intrinsics.def:144:7 +/// @see src/tint/intrinsics.def:134:7 class ScalarNoI32 : public TypeMatcher { public: /// Checks whether the given type matches the matcher rules, and returns the @@ -2167,7 +1790,7 @@ std::string ScalarNoI32::String(MatchState*) const { } /// TypeMatcher for 'match scalar_no_u32' -/// @see src/tint/intrinsics.def:145:7 +/// @see src/tint/intrinsics.def:135:7 class ScalarNoU32 : public TypeMatcher { public: /// Checks whether the given type matches the matcher rules, and returns the @@ -2208,7 +1831,7 @@ std::string ScalarNoU32::String(MatchState*) const { } /// TypeMatcher for 'match scalar_no_bool' -/// @see src/tint/intrinsics.def:146:7 +/// @see src/tint/intrinsics.def:136:7 class ScalarNoBool : public TypeMatcher { public: /// Checks whether the given type matches the matcher rules, and returns the @@ -2248,8 +1871,350 @@ std::string ScalarNoBool::String(MatchState*) const { return ss.str(); } +/// TypeMatcher for 'match fia_fi32_f16' +/// @see src/tint/intrinsics.def:137:7 +class FiaFi32F16 : public TypeMatcher { + public: + /// Checks whether the given type matches the matcher rules, and returns the + /// expected, canonicalized type on success. + /// Match may define and refine the template types and numbers in state. + /// @param state the MatchState + /// @param type the type to match + /// @returns the canonicalized type on match, otherwise nullptr + const sem::Type* Match(MatchState& state, + const sem::Type* type) const override; + /// @param state the MatchState + /// @return a string representation of the matcher. + std::string String(MatchState* state) const override; +}; + +const sem::Type* FiaFi32F16::Match(MatchState& state, const sem::Type* ty) const { + if (match_fa(ty)) { + return build_fa(state); + } + if (match_ia(ty)) { + return build_ia(state); + } + if (match_i32(ty)) { + return build_i32(state); + } + if (match_f32(ty)) { + return build_f32(state); + } + if (match_f16(ty)) { + return build_f16(state); + } + return nullptr; +} + +std::string FiaFi32F16::String(MatchState*) const { + std::stringstream ss; + // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support + // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. + ss << Fa().String(nullptr) << ", " << Ia().String(nullptr) << ", " << F32().String(nullptr) << ", " << I32().String(nullptr) << " or " << F16().String(nullptr); + return ss.str(); +} + +/// TypeMatcher for 'match fa_f32_f16' +/// @see src/tint/intrinsics.def:138:7 +class FaF32F16 : public TypeMatcher { + public: + /// Checks whether the given type matches the matcher rules, and returns the + /// expected, canonicalized type on success. + /// Match may define and refine the template types and numbers in state. + /// @param state the MatchState + /// @param type the type to match + /// @returns the canonicalized type on match, otherwise nullptr + const sem::Type* Match(MatchState& state, + const sem::Type* type) const override; + /// @param state the MatchState + /// @return a string representation of the matcher. + std::string String(MatchState* state) const override; +}; + +const sem::Type* FaF32F16::Match(MatchState& state, const sem::Type* ty) const { + if (match_fa(ty)) { + return build_fa(state); + } + if (match_f32(ty)) { + return build_f32(state); + } + if (match_f16(ty)) { + return build_f16(state); + } + return nullptr; +} + +std::string FaF32F16::String(MatchState*) const { + std::stringstream ss; + // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support + // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. + ss << Fa().String(nullptr) << ", " << F32().String(nullptr) << " or " << F16().String(nullptr); + return ss.str(); +} + +/// TypeMatcher for 'match ia_iu32' +/// @see src/tint/intrinsics.def:139:7 +class IaIu32 : public TypeMatcher { + public: + /// Checks whether the given type matches the matcher rules, and returns the + /// expected, canonicalized type on success. + /// Match may define and refine the template types and numbers in state. + /// @param state the MatchState + /// @param type the type to match + /// @returns the canonicalized type on match, otherwise nullptr + const sem::Type* Match(MatchState& state, + const sem::Type* type) const override; + /// @param state the MatchState + /// @return a string representation of the matcher. + std::string String(MatchState* state) const override; +}; + +const sem::Type* IaIu32::Match(MatchState& state, const sem::Type* ty) const { + if (match_ia(ty)) { + return build_ia(state); + } + if (match_i32(ty)) { + return build_i32(state); + } + if (match_u32(ty)) { + return build_u32(state); + } + return nullptr; +} + +std::string IaIu32::String(MatchState*) const { + std::stringstream ss; + // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support + // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. + ss << Ia().String(nullptr) << ", " << I32().String(nullptr) << " or " << U32().String(nullptr); + return ss.str(); +} + +/// TypeMatcher for 'match fiu32_f16' +/// @see src/tint/intrinsics.def:140:7 +class Fiu32F16 : public TypeMatcher { + public: + /// Checks whether the given type matches the matcher rules, and returns the + /// expected, canonicalized type on success. + /// Match may define and refine the template types and numbers in state. + /// @param state the MatchState + /// @param type the type to match + /// @returns the canonicalized type on match, otherwise nullptr + const sem::Type* Match(MatchState& state, + const sem::Type* type) const override; + /// @param state the MatchState + /// @return a string representation of the matcher. + std::string String(MatchState* state) const override; +}; + +const sem::Type* Fiu32F16::Match(MatchState& state, const sem::Type* ty) const { + if (match_i32(ty)) { + return build_i32(state); + } + if (match_u32(ty)) { + return build_u32(state); + } + if (match_f32(ty)) { + return build_f32(state); + } + if (match_f16(ty)) { + return build_f16(state); + } + return nullptr; +} + +std::string Fiu32F16::String(MatchState*) const { + std::stringstream ss; + // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support + // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. + ss << F32().String(nullptr) << ", " << I32().String(nullptr) << ", " << U32().String(nullptr) << " or " << F16().String(nullptr); + return ss.str(); +} + +/// TypeMatcher for 'match fiu32' +/// @see src/tint/intrinsics.def:141:7 +class Fiu32 : public TypeMatcher { + public: + /// Checks whether the given type matches the matcher rules, and returns the + /// expected, canonicalized type on success. + /// Match may define and refine the template types and numbers in state. + /// @param state the MatchState + /// @param type the type to match + /// @returns the canonicalized type on match, otherwise nullptr + const sem::Type* Match(MatchState& state, + const sem::Type* type) const override; + /// @param state the MatchState + /// @return a string representation of the matcher. + std::string String(MatchState* state) const override; +}; + +const sem::Type* Fiu32::Match(MatchState& state, const sem::Type* ty) const { + if (match_i32(ty)) { + return build_i32(state); + } + if (match_u32(ty)) { + return build_u32(state); + } + if (match_f32(ty)) { + return build_f32(state); + } + return nullptr; +} + +std::string Fiu32::String(MatchState*) const { + std::stringstream ss; + // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support + // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. + ss << F32().String(nullptr) << ", " << I32().String(nullptr) << " or " << U32().String(nullptr); + return ss.str(); +} + +/// TypeMatcher for 'match fi32_f16' +/// @see src/tint/intrinsics.def:142:7 +class Fi32F16 : public TypeMatcher { + public: + /// Checks whether the given type matches the matcher rules, and returns the + /// expected, canonicalized type on success. + /// Match may define and refine the template types and numbers in state. + /// @param state the MatchState + /// @param type the type to match + /// @returns the canonicalized type on match, otherwise nullptr + const sem::Type* Match(MatchState& state, + const sem::Type* type) const override; + /// @param state the MatchState + /// @return a string representation of the matcher. + std::string String(MatchState* state) const override; +}; + +const sem::Type* Fi32F16::Match(MatchState& state, const sem::Type* ty) const { + if (match_i32(ty)) { + return build_i32(state); + } + if (match_f32(ty)) { + return build_f32(state); + } + if (match_f16(ty)) { + return build_f16(state); + } + return nullptr; +} + +std::string Fi32F16::String(MatchState*) const { + std::stringstream ss; + // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support + // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. + ss << F32().String(nullptr) << ", " << I32().String(nullptr) << " or " << F16().String(nullptr); + return ss.str(); +} + +/// TypeMatcher for 'match fi32' +/// @see src/tint/intrinsics.def:143:7 +class Fi32 : public TypeMatcher { + public: + /// Checks whether the given type matches the matcher rules, and returns the + /// expected, canonicalized type on success. + /// Match may define and refine the template types and numbers in state. + /// @param state the MatchState + /// @param type the type to match + /// @returns the canonicalized type on match, otherwise nullptr + const sem::Type* Match(MatchState& state, + const sem::Type* type) const override; + /// @param state the MatchState + /// @return a string representation of the matcher. + std::string String(MatchState* state) const override; +}; + +const sem::Type* Fi32::Match(MatchState& state, const sem::Type* ty) const { + if (match_i32(ty)) { + return build_i32(state); + } + if (match_f32(ty)) { + return build_f32(state); + } + return nullptr; +} + +std::string Fi32::String(MatchState*) const { + std::stringstream ss; + // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support + // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. + ss << F32().String(nullptr) << " or " << I32().String(nullptr); + return ss.str(); +} + +/// TypeMatcher for 'match f32_f16' +/// @see src/tint/intrinsics.def:144:7 +class F32F16 : public TypeMatcher { + public: + /// Checks whether the given type matches the matcher rules, and returns the + /// expected, canonicalized type on success. + /// Match may define and refine the template types and numbers in state. + /// @param state the MatchState + /// @param type the type to match + /// @returns the canonicalized type on match, otherwise nullptr + const sem::Type* Match(MatchState& state, + const sem::Type* type) const override; + /// @param state the MatchState + /// @return a string representation of the matcher. + std::string String(MatchState* state) const override; +}; + +const sem::Type* F32F16::Match(MatchState& state, const sem::Type* ty) const { + if (match_f32(ty)) { + return build_f32(state); + } + if (match_f16(ty)) { + return build_f16(state); + } + return nullptr; +} + +std::string F32F16::String(MatchState*) const { + std::stringstream ss; + // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support + // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. + ss << F32().String(nullptr) << " or " << F16().String(nullptr); + return ss.str(); +} + +/// TypeMatcher for 'match iu32' +/// @see src/tint/intrinsics.def:145:7 +class Iu32 : public TypeMatcher { + public: + /// Checks whether the given type matches the matcher rules, and returns the + /// expected, canonicalized type on success. + /// Match may define and refine the template types and numbers in state. + /// @param state the MatchState + /// @param type the type to match + /// @returns the canonicalized type on match, otherwise nullptr + const sem::Type* Match(MatchState& state, + const sem::Type* type) const override; + /// @param state the MatchState + /// @return a string representation of the matcher. + std::string String(MatchState* state) const override; +}; + +const sem::Type* Iu32::Match(MatchState& state, const sem::Type* ty) const { + if (match_i32(ty)) { + return build_i32(state); + } + if (match_u32(ty)) { + return build_u32(state); + } + return nullptr; +} + +std::string Iu32::String(MatchState*) const { + std::stringstream ss; + // Note: We pass nullptr to the TypeMatcher::String() functions, as 'matcher's do not support + // template arguments, nor can they match sub-types. As such, they have no use for the MatchState. + ss << I32().String(nullptr) << " or " << U32().String(nullptr); + return ss.str(); +} + /// EnumMatcher for 'match f32_texel_format' -/// @see src/tint/intrinsics.def:157:7 +/// @see src/tint/intrinsics.def:156:7 class F32TexelFormat : public NumberMatcher { public: /// Checks whether the given number matches the enum matcher rules. @@ -2282,7 +2247,7 @@ std::string F32TexelFormat::String(MatchState*) const { } /// EnumMatcher for 'match i32_texel_format' -/// @see src/tint/intrinsics.def:159:7 +/// @see src/tint/intrinsics.def:158:7 class I32TexelFormat : public NumberMatcher { public: /// Checks whether the given number matches the enum matcher rules. @@ -2314,7 +2279,7 @@ std::string I32TexelFormat::String(MatchState*) const { } /// EnumMatcher for 'match u32_texel_format' -/// @see src/tint/intrinsics.def:161:7 +/// @see src/tint/intrinsics.def:160:7 class U32TexelFormat : public NumberMatcher { public: /// Checks whether the given number matches the enum matcher rules. @@ -2346,7 +2311,7 @@ std::string U32TexelFormat::String(MatchState*) const { } /// EnumMatcher for 'match write_only' -/// @see src/tint/intrinsics.def:164:7 +/// @see src/tint/intrinsics.def:163:7 class WriteOnly : public NumberMatcher { public: /// Checks whether the given number matches the enum matcher rules. @@ -2372,7 +2337,7 @@ std::string WriteOnly::String(MatchState*) const { } /// EnumMatcher for 'match function_private_workgroup' -/// @see src/tint/intrinsics.def:166:7 +/// @see src/tint/intrinsics.def:165:7 class FunctionPrivateWorkgroup : public NumberMatcher { public: /// Checks whether the given number matches the enum matcher rules. @@ -2402,7 +2367,7 @@ std::string FunctionPrivateWorkgroup::String(MatchState*) const { } /// EnumMatcher for 'match workgroup_or_storage' -/// @see src/tint/intrinsics.def:167:7 +/// @see src/tint/intrinsics.def:166:7 class WorkgroupOrStorage : public NumberMatcher { public: /// Checks whether the given number matches the enum matcher rules. @@ -2514,8 +2479,8 @@ class Matchers { TemplateNumberMatcher template_number_1_{1}; TemplateNumberMatcher template_number_2_{2}; Bool Bool_; - Af Af_; - Ai Ai_; + Fa Fa_; + Ia Ia_; I32 I32_; U32 U32_; F32 F32_; @@ -2561,23 +2526,22 @@ class Matchers { FrexpResult FrexpResult_; FrexpResultVec FrexpResultVec_; AtomicCompareExchangeResult AtomicCompareExchangeResult_; - F32F16 F32F16_; - Fiu32 Fiu32_; - Fiu32F16 Fiu32F16_; - Fi32 Fi32_; - Fi32F16 Fi32F16_; - Iu32 Iu32_; - Aiu32 Aiu32_; - Afi32F16 Afi32F16_; - Scalar Scalar_; AbstractOrScalar AbstractOrScalar_; - AfF32 AfF32_; - AfF32F16 AfF32F16_; + Scalar Scalar_; ScalarNoF32 ScalarNoF32_; ScalarNoF16 ScalarNoF16_; ScalarNoI32 ScalarNoI32_; ScalarNoU32 ScalarNoU32_; ScalarNoBool ScalarNoBool_; + FiaFi32F16 FiaFi32F16_; + FaF32F16 FaF32F16_; + IaIu32 IaIu32_; + Fiu32F16 Fiu32F16_; + Fiu32 Fiu32_; + Fi32F16 Fi32F16_; + Fi32 Fi32_; + F32F16 F32F16_; + Iu32 Iu32_; F32TexelFormat F32TexelFormat_; I32TexelFormat I32TexelFormat_; U32TexelFormat U32TexelFormat_; @@ -2595,12 +2559,12 @@ class Matchers { ~Matchers(); /// The template types, types, and type matchers - TypeMatcher const* const type[67] = { + TypeMatcher const* const type[66] = { /* [0] */ &template_type_0_, /* [1] */ &template_type_1_, /* [2] */ &Bool_, - /* [3] */ &Af_, - /* [4] */ &Ai_, + /* [3] */ &Fa_, + /* [4] */ &Ia_, /* [5] */ &I32_, /* [6] */ &U32_, /* [7] */ &F32_, @@ -2646,23 +2610,22 @@ class Matchers { /* [47] */ &FrexpResult_, /* [48] */ &FrexpResultVec_, /* [49] */ &AtomicCompareExchangeResult_, - /* [50] */ &F32F16_, - /* [51] */ &Fiu32_, - /* [52] */ &Fiu32F16_, - /* [53] */ &Fi32_, - /* [54] */ &Fi32F16_, - /* [55] */ &Iu32_, - /* [56] */ &Aiu32_, - /* [57] */ &Afi32F16_, - /* [58] */ &Scalar_, - /* [59] */ &AbstractOrScalar_, - /* [60] */ &AfF32_, - /* [61] */ &AfF32F16_, - /* [62] */ &ScalarNoF32_, - /* [63] */ &ScalarNoF16_, - /* [64] */ &ScalarNoI32_, - /* [65] */ &ScalarNoU32_, - /* [66] */ &ScalarNoBool_, + /* [50] */ &AbstractOrScalar_, + /* [51] */ &Scalar_, + /* [52] */ &ScalarNoF32_, + /* [53] */ &ScalarNoF16_, + /* [54] */ &ScalarNoI32_, + /* [55] */ &ScalarNoU32_, + /* [56] */ &ScalarNoBool_, + /* [57] */ &FiaFi32F16_, + /* [58] */ &FaF32F16_, + /* [59] */ &IaIu32_, + /* [60] */ &Fiu32F16_, + /* [61] */ &Fiu32_, + /* [62] */ &Fi32F16_, + /* [63] */ &Fi32_, + /* [64] */ &F32F16_, + /* [65] */ &Iu32_, }; /// The template numbers, and number matchers @@ -7960,7 +7923,7 @@ constexpr TemplateTypeInfo kTemplateTypes[] = { { /* [1] */ /* name */ "U", - /* matcher index */ 66, + /* matcher index */ 56, }, { /* [2] */ @@ -7970,7 +7933,7 @@ constexpr TemplateTypeInfo kTemplateTypes[] = { { /* [3] */ /* name */ "U", - /* matcher index */ 62, + /* matcher index */ 52, }, { /* [4] */ @@ -7980,7 +7943,7 @@ constexpr TemplateTypeInfo kTemplateTypes[] = { { /* [5] */ /* name */ "U", - /* matcher index */ 63, + /* matcher index */ 53, }, { /* [6] */ @@ -7990,7 +7953,7 @@ constexpr TemplateTypeInfo kTemplateTypes[] = { { /* [7] */ /* name */ "U", - /* matcher index */ 64, + /* matcher index */ 54, }, { /* [8] */ @@ -8000,37 +7963,37 @@ constexpr TemplateTypeInfo kTemplateTypes[] = { { /* [9] */ /* name */ "U", - /* matcher index */ 65, + /* matcher index */ 55, }, { /* [10] */ /* name */ "T", - /* matcher index */ 55, + /* matcher index */ 65, }, { /* [11] */ /* name */ "T", - /* matcher index */ 61, + /* matcher index */ 58, }, { /* [12] */ /* name */ "T", - /* matcher index */ 50, + /* matcher index */ 64, }, { /* [13] */ /* name */ "T", - /* matcher index */ 51, + /* matcher index */ 61, }, { /* [14] */ /* name */ "T", - /* matcher index */ 59, + /* matcher index */ 50, }, { /* [15] */ /* name */ "T", - /* matcher index */ 58, + /* matcher index */ 51, }, { /* [16] */ @@ -8040,32 +8003,32 @@ constexpr TemplateTypeInfo kTemplateTypes[] = { { /* [17] */ /* name */ "T", - /* matcher index */ 66, + /* matcher index */ 56, }, { /* [18] */ /* name */ "T", - /* matcher index */ 63, + /* matcher index */ 53, }, { /* [19] */ /* name */ "T", - /* matcher index */ 62, + /* matcher index */ 52, }, { /* [20] */ /* name */ "T", - /* matcher index */ 65, + /* matcher index */ 55, }, { /* [21] */ /* name */ "T", - /* matcher index */ 64, + /* matcher index */ 54, }, { /* [22] */ /* name */ "T", - /* matcher index */ 52, + /* matcher index */ 60, }, { /* [23] */ @@ -8075,7 +8038,7 @@ constexpr TemplateTypeInfo kTemplateTypes[] = { { /* [24] */ /* name */ "T", - /* matcher index */ 56, + /* matcher index */ 59, }, }; @@ -14560,15 +14523,15 @@ constexpr IntrinsicInfo kUnaryOperators[] = { }, { /* [1] */ - /* op ~(T) -> T */ - /* op ~(vec) -> vec */ + /* op ~(T) -> T */ + /* op ~(vec) -> vec */ /* num overloads */ 2, /* overloads */ &kOverloads[284], }, { /* [2] */ - /* op -(T) -> T */ - /* op -(vec) -> vec */ + /* op -(T) -> T */ + /* op -(vec) -> vec */ /* num overloads */ 2, /* overloads */ &kOverloads[422], }, @@ -14580,53 +14543,53 @@ constexpr uint8_t kUnaryOperatorMinus = 2; constexpr IntrinsicInfo kBinaryOperators[] = { { /* [0] */ - /* op +(T, T) -> T */ - /* op +(vec, vec) -> vec */ - /* op +(vec, T) -> vec */ - /* op +(T, vec) -> vec */ - /* op +(mat, mat) -> mat */ + /* op +(T, T) -> T */ + /* op +(vec, vec) -> vec */ + /* op +(vec, T) -> vec */ + /* op +(T, vec) -> vec */ + /* op +(mat, mat) -> mat */ /* num overloads */ 5, /* overloads */ &kOverloads[242], }, { /* [1] */ - /* op -(T, T) -> T */ - /* op -(vec, vec) -> vec */ - /* op -(vec, T) -> vec */ - /* op -(T, vec) -> vec */ - /* op -(mat, mat) -> mat */ + /* op -(T, T) -> T */ + /* op -(vec, vec) -> vec */ + /* op -(vec, T) -> vec */ + /* op -(T, vec) -> vec */ + /* op -(mat, mat) -> mat */ /* num overloads */ 5, /* overloads */ &kOverloads[232], }, { /* [2] */ - /* op *(T, T) -> T */ - /* op *(vec, vec) -> vec */ - /* op *(vec, T) -> vec */ - /* op *(T, vec) -> vec */ - /* op *(T, mat) -> mat */ - /* op *(mat, T) -> mat */ - /* op *(mat, vec) -> vec */ - /* op *(vec, mat) -> vec */ - /* op *(mat, mat) -> mat */ + /* op *(T, T) -> T */ + /* op *(vec, vec) -> vec */ + /* op *(vec, T) -> vec */ + /* op *(T, vec) -> vec */ + /* op *(T, mat) -> mat */ + /* op *(mat, T) -> mat */ + /* op *(mat, vec) -> vec */ + /* op *(vec, mat) -> vec */ + /* op *(mat, mat) -> mat */ /* num overloads */ 9, /* overloads */ &kOverloads[117], }, { /* [3] */ - /* op /(T, T) -> T */ - /* op /(vec, vec) -> vec */ - /* op /(vec, T) -> vec */ - /* op /(T, vec) -> vec */ + /* op /(T, T) -> T */ + /* op /(vec, vec) -> vec */ + /* op /(vec, T) -> vec */ + /* op /(T, vec) -> vec */ /* num overloads */ 4, /* overloads */ &kOverloads[259], }, { /* [4] */ - /* op %(T, T) -> T */ - /* op %(vec, vec) -> vec */ - /* op %(vec, T) -> vec */ - /* op %(T, vec) -> vec */ + /* op %(T, T) -> T */ + /* op %(vec, vec) -> vec */ + /* op %(vec, T) -> vec */ + /* op %(T, vec) -> vec */ /* num overloads */ 4, /* overloads */ &kOverloads[247], }, @@ -14683,29 +14646,29 @@ constexpr IntrinsicInfo kBinaryOperators[] = { }, { /* [12] */ - /* op <(T, T) -> bool */ - /* op <(vec, vec) -> vec */ + /* op <(T, T) -> bool */ + /* op <(vec, vec) -> vec */ /* num overloads */ 2, /* overloads */ &kOverloads[388], }, { /* [13] */ - /* op >(T, T) -> bool */ - /* op >(vec, vec) -> vec */ + /* op >(T, T) -> bool */ + /* op >(vec, vec) -> vec */ /* num overloads */ 2, /* overloads */ &kOverloads[372], }, { /* [14] */ - /* op <=(T, T) -> bool */ - /* op <=(vec, vec) -> vec */ + /* op <=(T, T) -> bool */ + /* op <=(vec, vec) -> vec */ /* num overloads */ 2, /* overloads */ &kOverloads[370], }, { /* [15] */ - /* op >=(T, T) -> bool */ - /* op >=(vec, vec) -> vec */ + /* op >=(T, T) -> bool */ + /* op >=(vec, vec) -> vec */ /* num overloads */ 2, /* overloads */ &kOverloads[368], }, @@ -14836,10 +14799,10 @@ constexpr IntrinsicInfo kConstructorsAndConverters[] = { }, { /* [8] */ - /* ctor mat2x2() -> mat2x2 */ - /* ctor mat2x2(mat2x2) -> mat2x2 */ - /* ctor mat2x2(T, T, T, T) -> mat2x2 */ - /* ctor mat2x2(vec2, vec2) -> mat2x2 */ + /* ctor mat2x2() -> mat2x2 */ + /* ctor mat2x2(mat2x2) -> mat2x2 */ + /* ctor mat2x2(T, T, T, T) -> mat2x2 */ + /* ctor mat2x2(vec2, vec2) -> mat2x2 */ /* conv mat2x2(mat2x2) -> mat2x2 */ /* conv mat2x2(mat2x2) -> mat2x2 */ /* num overloads */ 6, @@ -14847,10 +14810,10 @@ constexpr IntrinsicInfo kConstructorsAndConverters[] = { }, { /* [9] */ - /* ctor mat2x3() -> mat2x3 */ - /* ctor mat2x3(mat2x3) -> mat2x3 */ - /* ctor mat2x3(T, T, T, T, T, T) -> mat2x3 */ - /* ctor mat2x3(vec3, vec3) -> mat2x3 */ + /* ctor mat2x3() -> mat2x3 */ + /* ctor mat2x3(mat2x3) -> mat2x3 */ + /* ctor mat2x3(T, T, T, T, T, T) -> mat2x3 */ + /* ctor mat2x3(vec3, vec3) -> mat2x3 */ /* conv mat2x3(mat2x3) -> mat2x3 */ /* conv mat2x3(mat2x3) -> mat2x3 */ /* num overloads */ 6, @@ -14858,10 +14821,10 @@ constexpr IntrinsicInfo kConstructorsAndConverters[] = { }, { /* [10] */ - /* ctor mat2x4() -> mat2x4 */ - /* ctor mat2x4(mat2x4) -> mat2x4 */ - /* ctor mat2x4(T, T, T, T, T, T, T, T) -> mat2x4 */ - /* ctor mat2x4(vec4, vec4) -> mat2x4 */ + /* ctor mat2x4() -> mat2x4 */ + /* ctor mat2x4(mat2x4) -> mat2x4 */ + /* ctor mat2x4(T, T, T, T, T, T, T, T) -> mat2x4 */ + /* ctor mat2x4(vec4, vec4) -> mat2x4 */ /* conv mat2x4(mat2x4) -> mat2x4 */ /* conv mat2x4(mat2x4) -> mat2x4 */ /* num overloads */ 6, @@ -14869,10 +14832,10 @@ constexpr IntrinsicInfo kConstructorsAndConverters[] = { }, { /* [11] */ - /* ctor mat3x2() -> mat3x2 */ - /* ctor mat3x2(mat3x2) -> mat3x2 */ - /* ctor mat3x2(T, T, T, T, T, T) -> mat3x2 */ - /* ctor mat3x2(vec2, vec2, vec2) -> mat3x2 */ + /* ctor mat3x2() -> mat3x2 */ + /* ctor mat3x2(mat3x2) -> mat3x2 */ + /* ctor mat3x2(T, T, T, T, T, T) -> mat3x2 */ + /* ctor mat3x2(vec2, vec2, vec2) -> mat3x2 */ /* conv mat3x2(mat3x2) -> mat3x2 */ /* conv mat3x2(mat3x2) -> mat3x2 */ /* num overloads */ 6, @@ -14880,10 +14843,10 @@ constexpr IntrinsicInfo kConstructorsAndConverters[] = { }, { /* [12] */ - /* ctor mat3x3() -> mat3x3 */ - /* ctor mat3x3(mat3x3) -> mat3x3 */ - /* ctor mat3x3(T, T, T, T, T, T, T, T, T) -> mat3x3 */ - /* ctor mat3x3(vec3, vec3, vec3) -> mat3x3 */ + /* ctor mat3x3() -> mat3x3 */ + /* ctor mat3x3(mat3x3) -> mat3x3 */ + /* ctor mat3x3(T, T, T, T, T, T, T, T, T) -> mat3x3 */ + /* ctor mat3x3(vec3, vec3, vec3) -> mat3x3 */ /* conv mat3x3(mat3x3) -> mat3x3 */ /* conv mat3x3(mat3x3) -> mat3x3 */ /* num overloads */ 6, @@ -14891,10 +14854,10 @@ constexpr IntrinsicInfo kConstructorsAndConverters[] = { }, { /* [13] */ - /* ctor mat3x4() -> mat3x4 */ - /* ctor mat3x4(mat3x4) -> mat3x4 */ - /* ctor mat3x4(T, T, T, T, T, T, T, T, T, T, T, T) -> mat3x4 */ - /* ctor mat3x4(vec4, vec4, vec4) -> mat3x4 */ + /* ctor mat3x4() -> mat3x4 */ + /* ctor mat3x4(mat3x4) -> mat3x4 */ + /* ctor mat3x4(T, T, T, T, T, T, T, T, T, T, T, T) -> mat3x4 */ + /* ctor mat3x4(vec4, vec4, vec4) -> mat3x4 */ /* conv mat3x4(mat3x4) -> mat3x4 */ /* conv mat3x4(mat3x4) -> mat3x4 */ /* num overloads */ 6, @@ -14902,10 +14865,10 @@ constexpr IntrinsicInfo kConstructorsAndConverters[] = { }, { /* [14] */ - /* ctor mat4x2() -> mat4x2 */ - /* ctor mat4x2(mat4x2) -> mat4x2 */ - /* ctor mat4x2(T, T, T, T, T, T, T, T) -> mat4x2 */ - /* ctor mat4x2(vec2, vec2, vec2, vec2) -> mat4x2 */ + /* ctor mat4x2() -> mat4x2 */ + /* ctor mat4x2(mat4x2) -> mat4x2 */ + /* ctor mat4x2(T, T, T, T, T, T, T, T) -> mat4x2 */ + /* ctor mat4x2(vec2, vec2, vec2, vec2) -> mat4x2 */ /* conv mat4x2(mat4x2) -> mat4x2 */ /* conv mat4x2(mat4x2) -> mat4x2 */ /* num overloads */ 6, @@ -14913,10 +14876,10 @@ constexpr IntrinsicInfo kConstructorsAndConverters[] = { }, { /* [15] */ - /* ctor mat4x3() -> mat4x3 */ - /* ctor mat4x3(mat4x3) -> mat4x3 */ - /* ctor mat4x3(T, T, T, T, T, T, T, T, T, T, T, T) -> mat4x3 */ - /* ctor mat4x3(vec3, vec3, vec3, vec3) -> mat4x3 */ + /* ctor mat4x3() -> mat4x3 */ + /* ctor mat4x3(mat4x3) -> mat4x3 */ + /* ctor mat4x3(T, T, T, T, T, T, T, T, T, T, T, T) -> mat4x3 */ + /* ctor mat4x3(vec3, vec3, vec3, vec3) -> mat4x3 */ /* conv mat4x3(mat4x3) -> mat4x3 */ /* conv mat4x3(mat4x3) -> mat4x3 */ /* num overloads */ 6, @@ -14924,10 +14887,10 @@ constexpr IntrinsicInfo kConstructorsAndConverters[] = { }, { /* [16] */ - /* ctor mat4x4() -> mat4x4 */ - /* ctor mat4x4(mat4x4) -> mat4x4 */ - /* ctor mat4x4(T, T, T, T, T, T, T, T, T, T, T, T, T, T, T, T) -> mat4x4 */ - /* ctor mat4x4(vec4, vec4, vec4, vec4) -> mat4x4 */ + /* ctor mat4x4() -> mat4x4 */ + /* ctor mat4x4(mat4x4) -> mat4x4 */ + /* ctor mat4x4(T, T, T, T, T, T, T, T, T, T, T, T, T, T, T, T) -> mat4x4 */ + /* ctor mat4x4(vec4, vec4, vec4, vec4) -> mat4x4 */ /* conv mat4x4(mat4x4) -> mat4x4 */ /* conv mat4x4(mat4x4) -> mat4x4 */ /* num overloads */ 6, diff --git a/src/tint/resolver/intrinsic_table_test.cc b/src/tint/resolver/intrinsic_table_test.cc index affcc765f4..c246dd9cb0 100644 --- a/src/tint/resolver/intrinsic_table_test.cc +++ b/src/tint/resolver/intrinsic_table_test.cc @@ -604,8 +604,8 @@ TEST_F(IntrinsicTableTest, MismatchUnaryOp) { EXPECT_EQ(Diagnostics().str(), R"(12:34 error: no matching overload for operator - (bool) 2 candidate operators: - operator - (T) -> T where: T is abstract-int, abstract-float, f32, i32 or f16 - operator - (vecN) -> vecN where: T is abstract-int, abstract-float, f32, i32 or f16 + operator - (T) -> T where: T is abstract-float, abstract-int, f32, i32 or f16 + operator - (vecN) -> vecN where: T is abstract-float, abstract-int, f32, i32 or f16 )"); } @@ -629,12 +629,12 @@ TEST_F(IntrinsicTableTest, MismatchBinaryOp) { EXPECT_EQ(Diagnostics().str(), R"(12:34 error: no matching overload for operator * (f32, bool) 9 candidate operators: - operator * (T, T) -> T where: T is f32, f16, i32 or u32 - operator * (vecN, T) -> vecN where: T is f32, f16, i32 or u32 - operator * (T, vecN) -> vecN where: T is f32, f16, i32 or u32 + operator * (T, T) -> T where: T is f32, i32, u32 or f16 + operator * (vecN, T) -> vecN where: T is f32, i32, u32 or f16 + operator * (T, vecN) -> vecN where: T is f32, i32, u32 or f16 operator * (T, matNxM) -> matNxM where: T is f32 or f16 operator * (matNxM, T) -> matNxM where: T is f32 or f16 - operator * (vecN, vecN) -> vecN where: T is f32, f16, i32 or u32 + operator * (vecN, vecN) -> vecN where: T is f32, i32, u32 or f16 operator * (matCxR, vecC) -> vecR where: T is f32 or f16 operator * (vecR, matCxR) -> vecC where: T is f32 or f16 operator * (matKxR, matCxK) -> matCxR where: T is f32 or f16 @@ -661,12 +661,12 @@ TEST_F(IntrinsicTableTest, MismatchCompoundOp) { EXPECT_EQ(Diagnostics().str(), R"(12:34 error: no matching overload for operator *= (f32, bool) 9 candidate operators: - operator *= (T, T) -> T where: T is f32, f16, i32 or u32 - operator *= (vecN, T) -> vecN where: T is f32, f16, i32 or u32 - operator *= (T, vecN) -> vecN where: T is f32, f16, i32 or u32 + operator *= (T, T) -> T where: T is f32, i32, u32 or f16 + operator *= (vecN, T) -> vecN where: T is f32, i32, u32 or f16 + operator *= (T, vecN) -> vecN where: T is f32, i32, u32 or f16 operator *= (T, matNxM) -> matNxM where: T is f32 or f16 operator *= (matNxM, T) -> matNxM where: T is f32 or f16 - operator *= (vecN, vecN) -> vecN where: T is f32, f16, i32 or u32 + operator *= (vecN, vecN) -> vecN where: T is f32, i32, u32 or f16 operator *= (matCxR, vecC) -> vecR where: T is f32 or f16 operator *= (vecR, matCxR) -> vecC where: T is f32 or f16 operator *= (matKxR, matCxK) -> matCxR where: T is f32 or f16 diff --git a/tools/src/cmd/intrinsic-gen/gen/permutate.go b/tools/src/cmd/intrinsic-gen/gen/permutate.go index fbc390b395..7efca36770 100644 --- a/tools/src/cmd/intrinsic-gen/gen/permutate.go +++ b/tools/src/cmd/intrinsic-gen/gen/permutate.go @@ -332,7 +332,7 @@ func validate(fqn sem.FullyQualifiedName, uses *sem.StageUses) bool { strings.Contains(elTyName, "sampler"), strings.Contains(elTyName, "texture"): return false // Not storable - case elTyName == "af" || elTyName == "ai": + case elTyName == "fa" || elTyName == "ia": return false // Abstract types are not typeable nor supported by arrays } case "ptr":