dawn-cmake/test/tint/builtins/gen/firstTrailingBit/110f2c.wgsl.expected.msl
Ben Clayton df3630c194 builtins: Add firstTrailingBit
Currently polyfilled for all backends.
HLSL should be able to map this to 'firstbitlow', but there might need
to be some special case handling for 0 (undocumented behavior). For now
just polyfill.

CTS tests: https://github.com/gpuweb/cts/pull/1003

Bug: tint:1367
Bug: tint:1449
Change-Id: I8125b32687196678906e5a9d056b4f2efd885073
Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/81502
Kokoro: Kokoro <noreply+kokoro@google.com>
Reviewed-by: David Neto <dneto@google.com>
Commit-Queue: Ben Clayton <bclayton@google.com>
2022-02-23 14:32:14 +00:00

49 lines
1.2 KiB
Plaintext

#include <metal_stdlib>
using namespace metal;
uint4 tint_first_trailing_bit(uint4 v) {
uint4 x = uint4(v);
uint4 const b16 = select(uint4(16u), uint4(0u), bool4((x & uint4(65535u))));
x = (x >> b16);
uint4 const b8 = select(uint4(8u), uint4(0u), bool4((x & uint4(255u))));
x = (x >> b8);
uint4 const b4 = select(uint4(4u), uint4(0u), bool4((x & uint4(15u))));
x = (x >> b4);
uint4 const b2 = select(uint4(2u), uint4(0u), bool4((x & uint4(3u))));
x = (x >> b2);
uint4 const b1 = select(uint4(1u), uint4(0u), bool4((x & uint4(1u))));
uint4 const is_zero = select(uint4(0u), uint4(4294967295u), (x == uint4(0u)));
return uint4((((((b16 | b8) | b4) | b2) | b1) | is_zero));
}
void firstTrailingBit_110f2c() {
uint4 res = tint_first_trailing_bit(uint4());
}
struct tint_symbol {
float4 value [[position]];
};
float4 vertex_main_inner() {
firstTrailingBit_110f2c();
return float4();
}
vertex tint_symbol vertex_main() {
float4 const inner_result = vertex_main_inner();
tint_symbol wrapper_result = {};
wrapper_result.value = inner_result;
return wrapper_result;
}
fragment void fragment_main() {
firstTrailingBit_110f2c();
return;
}
kernel void compute_main() {
firstTrailingBit_110f2c();
return;
}