dawn-cmake/test/tint/builtins/insertBits/scalar/i32.spvasm.expected.fxc.hlsl
Zhaoming Jiang 4f3f45c00f Tint/transform: Fix insertBits polyfill for HLSL
This CL fix insertBits polyfill to handle with the left-shifting
behavior in HLSL, i.e. `(1u << 32u) == (1u << 0u) == 1u` where we want
the result to be `0u`.

Fixed: tint:1743
Change-Id: Ibb82abe4ab2f76dbb0fa06057fb19f15f961d969
Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/108166
Commit-Queue: Zhaoming Jiang <zhaoming.jiang@intel.com>
Reviewed-by: Ben Clayton <bclayton@google.com>
Kokoro: Kokoro <noreply+kokoro@google.com>
2022-11-09 01:54:08 +00:00

25 lines
600 B
HLSL

int tint_insert_bits(int v, int n, uint offset, uint count) {
const uint e = (offset + count);
const uint mask = ((((offset < 32u) ? (1u << offset) : 0u) - 1u) ^ (((e < 32u) ? (1u << e) : 0u) - 1u));
return ((((offset < 32u) ? (n << offset) : 0) & int(mask)) | (v & int(~(mask))));
}
void f_1() {
int v = 0;
int n = 0;
uint offset_1 = 0u;
uint count = 0u;
const int x_17 = v;
const int x_18 = n;
const uint x_19 = offset_1;
const uint x_20 = count;
const int x_15 = tint_insert_bits(x_17, x_18, x_19, x_20);
return;
}
[numthreads(1, 1, 1)]
void f() {
f_1();
return;
}