tint: fix undetected overflow in const-eval refract
Bug: oss-fuzz:58526 Change-Id: I59a2e9151036da6aba83c523605664b54002f3dc Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/131342 Commit-Queue: Ben Clayton <bclayton@google.com> Kokoro: Kokoro <noreply+kokoro@google.com> Reviewed-by: Ben Clayton <bclayton@google.com>
This commit is contained in:
parent
c81bc4521f
commit
f789854a94
|
@ -3318,7 +3318,7 @@ ConstEval::Result ConstEval::refract(const type::Type* ty,
|
||||||
return utils::Failure;
|
return utils::Failure;
|
||||||
}
|
}
|
||||||
auto e2_scaled = Mul(source, ty, e2_scale.Get(), e2);
|
auto e2_scaled = Mul(source, ty, e2_scale.Get(), e2);
|
||||||
if (!e1_scaled) {
|
if (!e2_scaled) {
|
||||||
return utils::Failure;
|
return utils::Failure;
|
||||||
}
|
}
|
||||||
return Sub(source, ty, e1_scaled.Get(), e2_scaled.Get());
|
return Sub(source, ty, e1_scaled.Get(), e2_scaled.Get());
|
||||||
|
|
|
@ -2288,6 +2288,14 @@ std::vector<Case> RefractCases() {
|
||||||
// Overflow the k^2 operation
|
// Overflow the k^2 operation
|
||||||
E({down_right, pos_y, Val(T::Highest())}, error_msg(T::Highest(), "*", T::Highest())),
|
E({down_right, pos_y, Val(T::Highest())}, error_msg(T::Highest(), "*", T::Highest())),
|
||||||
});
|
});
|
||||||
|
ConcatIntoIf<std::is_same_v<T, f32>>( //
|
||||||
|
r, std::vector<Case>{
|
||||||
|
// Overflow the final multiply by e2 operation
|
||||||
|
// From https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=58526
|
||||||
|
E({Vec(T(-2.22218755e-15), T(0)), Vec(T(-198225753253481323832809619456.0), T(0)),
|
||||||
|
Val(T(40.0313720703125))},
|
||||||
|
error_msg(T(35267222007971840.0), "*", T(-198225753253481323832809619456.0))),
|
||||||
|
});
|
||||||
|
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue