mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-07-13 08:36:08 +00:00
It appears that FXC and DXC do some validation post dead-code-elimination. These tests have been updated so that the return value is assigned to a storage buffer, ensuring that all validation is performed. Many DXC tests are affected by https://github.com/microsoft/DirectXShaderCompiler/issues/5082, which have been SKIP'ed. Fixed: tint:1859 Change-Id: I0001a9a9821846cd0855c3d8ce2bec79ab8e64ef Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/122662 Kokoro: Kokoro <noreply+kokoro@google.com> Reviewed-by: James Price <jrprice@google.com> Commit-Queue: James Price <jrprice@google.com> Auto-Submit: Ben Clayton <bclayton@google.com>
29 lines
661 B
HLSL
29 lines
661 B
HLSL
groupshared int arg_0;
|
|
RWByteAddressBuffer prevent_dce : register(u0, space2);
|
|
|
|
void atomicMax_a89cc3() {
|
|
int atomic_result = 0;
|
|
InterlockedMax(arg_0, 1, atomic_result);
|
|
int res = atomic_result;
|
|
prevent_dce.Store(0u, asuint(res));
|
|
}
|
|
|
|
struct tint_symbol_1 {
|
|
uint local_invocation_index : SV_GroupIndex;
|
|
};
|
|
|
|
void compute_main_inner(uint local_invocation_index) {
|
|
{
|
|
int atomic_result_1 = 0;
|
|
InterlockedExchange(arg_0, 0, atomic_result_1);
|
|
}
|
|
GroupMemoryBarrierWithGroupSync();
|
|
atomicMax_a89cc3();
|
|
}
|
|
|
|
[numthreads(1, 1, 1)]
|
|
void compute_main(tint_symbol_1 tint_symbol) {
|
|
compute_main_inner(tint_symbol.local_invocation_index);
|
|
return;
|
|
}
|