dawn-cmake/test/tint/builtins/gen/firstTrailingBit/45eb10.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;
uint2 tint_first_trailing_bit(uint2 v) {
uint2 x = uint2(v);
uint2 const b16 = select(uint2(16u), uint2(0u), bool2((x & uint2(65535u))));
x = (x >> b16);
uint2 const b8 = select(uint2(8u), uint2(0u), bool2((x & uint2(255u))));
x = (x >> b8);
uint2 const b4 = select(uint2(4u), uint2(0u), bool2((x & uint2(15u))));
x = (x >> b4);
uint2 const b2 = select(uint2(2u), uint2(0u), bool2((x & uint2(3u))));
x = (x >> b2);
uint2 const b1 = select(uint2(1u), uint2(0u), bool2((x & uint2(1u))));
uint2 const is_zero = select(uint2(0u), uint2(4294967295u), (x == uint2(0u)));
return uint2((((((b16 | b8) | b4) | b2) | b1) | is_zero));
}
void firstTrailingBit_45eb10() {
uint2 res = tint_first_trailing_bit(uint2());
}
struct tint_symbol {
float4 value [[position]];
};
float4 vertex_main_inner() {
firstTrailingBit_45eb10();
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_45eb10();
return;
}
kernel void compute_main() {
firstTrailingBit_45eb10();
return;
}