skia2/tests/sksl/intrinsics/Trunc.metal
John Stiles 115645ee9b Evaluate various single-argument float intrinsics at compile time.
This CL only handles a subset of our intrinsics. In particular, it
avoids changing the behavior of `sqrt` as many of our tests use sqrt as
an optimization barrier.

The transcendental test inputs are intentionally kept very simple to
avoid putting numbers in the test outputs which could round differently
on various platforms and cause Housekeeper to complain.

Change-Id: I539f918294332310dcd6fe12fab163c0b6216f65
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/405398
Commit-Queue: John Stiles <johnstiles@google.com>
Commit-Queue: Ethan Nicholas <ethannicholas@google.com>
Auto-Submit: John Stiles <johnstiles@google.com>
Reviewed-by: Ethan Nicholas <ethannicholas@google.com>
2021-05-07 14:37:18 +00:00

22 lines
978 B
Metal

#include <metal_stdlib>
#include <simd/simd.h>
using namespace metal;
struct Uniforms {
float4 input;
float4 expected;
float4 colorGreen;
float4 colorRed;
};
struct Inputs {
};
struct Outputs {
float4 sk_FragColor [[color(0)]];
};
fragment Outputs fragmentMain(Inputs _in [[stage_in]], constant Uniforms& _uniforms [[buffer(0)]], bool _frontFacing [[front_facing]], float4 _fragCoord [[position]]) {
Outputs _out;
(void)_out;
_out.sk_FragColor = ((((((trunc(_uniforms.input.x) == _uniforms.expected.x && all(trunc(_uniforms.input.xy) == _uniforms.expected.xy)) && all(trunc(_uniforms.input.xyz) == _uniforms.expected.xyz)) && all(trunc(_uniforms.input) == _uniforms.expected)) && -1.0 == _uniforms.expected.x) && all(float2(-1.0, -0.0) == _uniforms.expected.xy)) && all(float3(-1.0, -0.0, 0.0) == _uniforms.expected.xyz)) && all(float4(-1.0, -0.0, 0.0, 1.0) == _uniforms.expected) ? _uniforms.colorGreen : _uniforms.colorRed;
return _out;
}