115645ee9b
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>
22 lines
978 B
Metal
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;
|
|
}
|