mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-12-21 18:59:21 +00:00
Add const-eval for ceil
This CL adds const-eval for the `ceil` builtin Bug: tint:1581 Change-Id: I32957d17000df1a8a59ce37f49b6177d1087406c Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/108342 Reviewed-by: Antonio Maiorano <amaiorano@google.com> Kokoro: Kokoro <noreply+kokoro@google.com> Commit-Queue: Dan Sinclair <dsinclair@chromium.org>
This commit is contained in:
committed by
Dawn LUCI CQ
parent
465df13196
commit
abd6a7d9d4
@@ -1700,6 +1700,18 @@ ConstEval::Result ConstEval::atan2(const sem::Type* ty,
|
||||
return TransformElements(builder, ty, transform, args[0], args[1]);
|
||||
}
|
||||
|
||||
ConstEval::Result ConstEval::ceil(const sem::Type* ty,
|
||||
utils::VectorRef<const sem::Constant*> args,
|
||||
const Source&) {
|
||||
auto transform = [&](const sem::Constant* c0) {
|
||||
auto create = [&](auto e) {
|
||||
return CreateElement(builder, c0->Type(), decltype(e)(std::ceil(e)));
|
||||
};
|
||||
return Dispatch_fa_f32_f16(create, c0);
|
||||
};
|
||||
return TransformElements(builder, ty, transform, args[0]);
|
||||
}
|
||||
|
||||
ConstEval::Result ConstEval::clamp(const sem::Type* ty,
|
||||
utils::VectorRef<const sem::Constant*> args,
|
||||
const Source&) {
|
||||
|
||||
@@ -458,6 +458,15 @@ class ConstEval {
|
||||
utils::VectorRef<const sem::Constant*> args,
|
||||
const Source& source);
|
||||
|
||||
/// ceil builtin
|
||||
/// @param ty the expression type
|
||||
/// @param args the input arguments
|
||||
/// @param source the source location of the conversion
|
||||
/// @return the result value, or null if the value cannot be calculated
|
||||
Result ceil(const sem::Type* ty,
|
||||
utils::VectorRef<const sem::Constant*> args,
|
||||
const Source& source);
|
||||
|
||||
/// clamp builtin
|
||||
/// @param ty the expression type
|
||||
/// @param args the input arguments
|
||||
|
||||
@@ -594,6 +594,37 @@ INSTANTIATE_TEST_SUITE_P( //
|
||||
AsinhCases<f32, false>(),
|
||||
AsinhCases<f16, false>()))));
|
||||
|
||||
template <typename T, bool finite_only>
|
||||
std::vector<Case> CeilCases() {
|
||||
std::vector<Case> cases = {
|
||||
C({T(0)}, T(0)),
|
||||
C({-T(0)}, -T(0)),
|
||||
C({-T(1.5)}, -T(1.0)),
|
||||
C({T(1.5)}, T(2.0)),
|
||||
C({T::Lowest()}, T::Lowest()),
|
||||
C({T::Highest()}, T::Highest()),
|
||||
|
||||
C({Vec(T(0), T(1.5), -T(1.5))}, Vec(T(0), T(2.0), -T(1.0))),
|
||||
};
|
||||
|
||||
ConcatIntoIf<!finite_only>(
|
||||
cases, std::vector<Case>{
|
||||
C({-T::Inf()}, -T::Inf()),
|
||||
C({T::Inf()}, T::Inf()),
|
||||
C({T::NaN()}, T::NaN()),
|
||||
C({Vec(-T::Inf(), T::Inf(), T::NaN())}, Vec(-T::Inf(), T::Inf(), T::NaN())),
|
||||
});
|
||||
|
||||
return cases;
|
||||
}
|
||||
INSTANTIATE_TEST_SUITE_P( //
|
||||
Ceil,
|
||||
ResolverConstEvalBuiltinTest,
|
||||
testing::Combine(testing::Values(sem::BuiltinType::kCeil),
|
||||
testing::ValuesIn(Concat(CeilCases<AFloat, true>(),
|
||||
CeilCases<f32, false>(),
|
||||
CeilCases<f16, false>()))));
|
||||
|
||||
template <typename T>
|
||||
std::vector<Case> ClampCases() {
|
||||
return {
|
||||
|
||||
@@ -13161,24 +13161,24 @@ constexpr OverloadInfo kOverloads[] = {
|
||||
/* num parameters */ 1,
|
||||
/* num template types */ 1,
|
||||
/* num template numbers */ 0,
|
||||
/* template types */ &kTemplateTypes[22],
|
||||
/* template types */ &kTemplateTypes[23],
|
||||
/* template numbers */ &kTemplateNumbers[10],
|
||||
/* parameters */ &kParameters[978],
|
||||
/* return matcher indices */ &kMatcherIndices[1],
|
||||
/* flags */ OverloadFlags(OverloadFlag::kIsBuiltin, OverloadFlag::kSupportsVertexPipeline, OverloadFlag::kSupportsFragmentPipeline, OverloadFlag::kSupportsComputePipeline),
|
||||
/* const eval */ nullptr,
|
||||
/* const eval */ &ConstEval::ceil,
|
||||
},
|
||||
{
|
||||
/* [403] */
|
||||
/* num parameters */ 1,
|
||||
/* num template types */ 1,
|
||||
/* num template numbers */ 1,
|
||||
/* template types */ &kTemplateTypes[22],
|
||||
/* template types */ &kTemplateTypes[23],
|
||||
/* template numbers */ &kTemplateNumbers[6],
|
||||
/* parameters */ &kParameters[977],
|
||||
/* return matcher indices */ &kMatcherIndices[30],
|
||||
/* flags */ OverloadFlags(OverloadFlag::kIsBuiltin, OverloadFlag::kSupportsVertexPipeline, OverloadFlag::kSupportsFragmentPipeline, OverloadFlag::kSupportsComputePipeline),
|
||||
/* const eval */ nullptr,
|
||||
/* const eval */ &ConstEval::ceil,
|
||||
},
|
||||
{
|
||||
/* [404] */
|
||||
@@ -14089,8 +14089,8 @@ constexpr IntrinsicInfo kBuiltins[] = {
|
||||
},
|
||||
{
|
||||
/* [11] */
|
||||
/* fn ceil<T : f32_f16>(T) -> T */
|
||||
/* fn ceil<N : num, T : f32_f16>(vec<N, T>) -> vec<N, T> */
|
||||
/* fn ceil<T : fa_f32_f16>(@test_value(1.5) T) -> T */
|
||||
/* fn ceil<N : num, T : fa_f32_f16>(@test_value(1.5) vec<N, T>) -> vec<N, T> */
|
||||
/* num overloads */ 2,
|
||||
/* overloads */ &kOverloads[402],
|
||||
},
|
||||
|
||||
Reference in New Issue
Block a user