mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-08-06 04:05:40 +00:00
Change tint's `--fxc` flag to take the path of the FXC compiler DLL. Have tint attempt to validate with both FXC and DXC if `--validate` is passed. Fix the 'dirsWithNoPassExpectations' logic which looks like it got broken with the tint -> dawn merge. It also incorrectly applied filepath.FromSlash() on windows. Change-Id: I0f46aa5c21bc48a2abc48402c41f846aff4a8633 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/96800 Reviewed-by: Antonio Maiorano <amaiorano@google.com> Commit-Queue: Ben Clayton <bclayton@chromium.org>
46 lines
1.2 KiB
HLSL
46 lines
1.2 KiB
HLSL
int3 tint_first_leading_bit(int3 v) {
|
|
uint3 x = ((v < (0).xxx) ? uint3(~(v)) : uint3(v));
|
|
const uint3 b16 = (bool3((x & (4294901760u).xxx)) ? (16u).xxx : (0u).xxx);
|
|
x = (x >> b16);
|
|
const uint3 b8 = (bool3((x & (65280u).xxx)) ? (8u).xxx : (0u).xxx);
|
|
x = (x >> b8);
|
|
const uint3 b4 = (bool3((x & (240u).xxx)) ? (4u).xxx : (0u).xxx);
|
|
x = (x >> b4);
|
|
const uint3 b2 = (bool3((x & (12u).xxx)) ? (2u).xxx : (0u).xxx);
|
|
x = (x >> b2);
|
|
const uint3 b1 = (bool3((x & (2u).xxx)) ? (1u).xxx : (0u).xxx);
|
|
const uint3 is_zero = ((x == (0u).xxx) ? (4294967295u).xxx : (0u).xxx);
|
|
return int3((((((b16 | b8) | b4) | b2) | b1) | is_zero));
|
|
}
|
|
|
|
void firstLeadingBit_35053e() {
|
|
int3 res = tint_first_leading_bit((0).xxx);
|
|
}
|
|
|
|
struct tint_symbol {
|
|
float4 value : SV_Position;
|
|
};
|
|
|
|
float4 vertex_main_inner() {
|
|
firstLeadingBit_35053e();
|
|
return (0.0f).xxxx;
|
|
}
|
|
|
|
tint_symbol vertex_main() {
|
|
const float4 inner_result = vertex_main_inner();
|
|
tint_symbol wrapper_result = (tint_symbol)0;
|
|
wrapper_result.value = inner_result;
|
|
return wrapper_result;
|
|
}
|
|
|
|
void fragment_main() {
|
|
firstLeadingBit_35053e();
|
|
return;
|
|
}
|
|
|
|
[numthreads(1, 1, 1)]
|
|
void compute_main() {
|
|
firstLeadingBit_35053e();
|
|
return;
|
|
}
|