mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-05-14 19:31:25 +00:00
This reverts commit 11d09f2fe7c006b78f7319e876e4ced43f0c1a60. Reason for revert: Failing roll of Tint to Dawn: https://dawn-review.googlesource.com/c/dawn/+/70100 Original change's description: > HLSL: force FXC to never unroll loops > > Emit the "[loop]" attribute on "for" and "while" so that FXC does not > attempt to unroll them. This is to work around an FXC bug where it fails > to unroll loops with gradient operations. > > FXC ostensibly unrolls such loops because gradient operations require > uniform control flow, and loops that have varying iterations may > possibly not be uniform. Tint will eventually validate that control flow > is indeed uniform, so forcing FXC to avoid unrolling in these cases > should be fine. > > Bug: tint:1112 > Change-Id: I10077f8b62fbbb230a0003f3864c75a8fe0e1d18 > Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/69880 > Kokoro: Kokoro <noreply+kokoro@google.com> > Reviewed-by: Ben Clayton <bclayton@google.com> > Commit-Queue: Antonio Maiorano <amaiorano@google.com> # Not skipping CQ checks because original CL landed > 1 day ago. Bug: tint:1112 Change-Id: I8e8f3c0abfa6e6bc5d0e67af9428a46ef867d5c1 Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/70540 Reviewed-by: Antonio Maiorano <amaiorano@google.com> Reviewed-by: Ben Clayton <bclayton@google.com> Kokoro: Kokoro <noreply+kokoro@google.com> Commit-Queue: Antonio Maiorano <amaiorano@google.com>
50 lines
1.5 KiB
HLSL
50 lines
1.5 KiB
HLSL
struct Inner {
|
|
int x;
|
|
};
|
|
struct tint_padded_array_element {
|
|
Inner el;
|
|
};
|
|
|
|
RWByteAddressBuffer s : register(u0, space0);
|
|
|
|
void tint_symbol_6(RWByteAddressBuffer buffer, uint offset, float2x3 value) {
|
|
buffer.Store3((offset + 0u), asuint(value[0u]));
|
|
buffer.Store3((offset + 16u), asuint(value[1u]));
|
|
}
|
|
|
|
void tint_symbol_7(RWByteAddressBuffer buffer, uint offset, float3x2 value) {
|
|
buffer.Store2((offset + 0u), asuint(value[0u]));
|
|
buffer.Store2((offset + 8u), asuint(value[1u]));
|
|
buffer.Store2((offset + 16u), asuint(value[2u]));
|
|
}
|
|
|
|
void tint_symbol_9(RWByteAddressBuffer buffer, uint offset, Inner value) {
|
|
buffer.Store((offset + 0u), asuint(value.x));
|
|
}
|
|
|
|
void tint_symbol_10(RWByteAddressBuffer buffer, uint offset, tint_padded_array_element value[4]) {
|
|
tint_padded_array_element array[4] = value;
|
|
{
|
|
for(uint i_1 = 0u; (i_1 < 4u); i_1 = (i_1 + 1u)) {
|
|
tint_symbol_9(buffer, (offset + (i_1 * 16u)), array[i_1].el);
|
|
}
|
|
}
|
|
}
|
|
|
|
[numthreads(1, 1, 1)]
|
|
void main() {
|
|
s.Store3(0u, asuint(int3(0, 0, 0)));
|
|
s.Store(12u, asuint(0));
|
|
s.Store3(16u, asuint(uint3(0u, 0u, 0u)));
|
|
s.Store(28u, asuint(0u));
|
|
s.Store3(32u, asuint(float3(0.0f, 0.0f, 0.0f)));
|
|
s.Store(44u, asuint(0.0f));
|
|
tint_symbol_6(s, 48u, float2x3(0.0f, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f));
|
|
tint_symbol_7(s, 80u, float3x2(0.0f, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f));
|
|
const Inner tint_symbol_11 = (Inner)0;
|
|
tint_symbol_9(s, 104u, tint_symbol_11);
|
|
const tint_padded_array_element tint_symbol_12[4] = (tint_padded_array_element[4])0;
|
|
tint_symbol_10(s, 108u, tint_symbol_12);
|
|
return;
|
|
}
|