skia2/tests/sksl/intrinsics/MatrixCompMult.metal

33 lines
839 B
Metal
Raw Normal View History

#include <metal_stdlib>
#include <simd/simd.h>
using namespace metal;
struct Inputs {
};
struct Outputs {
float4 sk_FragColor [[color(0)]];
};
struct Globals {
float3x3 a;
float3x3 b;
float4x4 c;
float4x4 d;
};
template <int C, int R>
matrix<float, C, R> matrixCompMult(matrix<float, C, R> a, matrix<float, C, R> b) {
matrix<float, C, R> result;
for (int c = 0; c < C; ++c) {
result[c] = a[c] * b[c];
}
return result;
}
fragment Outputs fragmentMain(Inputs _in [[stage_in]], bool _frontFacing [[front_facing]], float4 _fragCoord [[position]]) {
Globals _globals{{}, {}, {}, {}};
(void)_globals;
Outputs _out;
(void)_out;
_out.sk_FragColor.xyz = matrixCompMult(_globals.a, _globals.b)[0];
_out.sk_FragColor = matrixCompMult(_globals.c, _globals.d)[0];
return _out;
}