MSL writer: make signed int overflow defined behaviour

Bug: tint:124
Change-Id: Icf545b633d6390ceb7f639e80111390005e311a1
Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/60100
Kokoro: Kokoro <noreply+kokoro@google.com>
Commit-Queue: Antonio Maiorano <amaiorano@google.com>
Reviewed-by: David Neto <dneto@google.com>
This commit is contained in:
Antonio Maiorano
2021-07-29 13:51:47 +00:00
committed by Tint LUCI CQ
parent 1f0200a3ff
commit e5dbe24e94
651 changed files with 3963 additions and 3048 deletions

View File

@@ -5,7 +5,7 @@ void main_1() {
int i = 0;
i = 123;
int const x_10 = i;
int const x_12 = (x_10 + 1);
int const x_12 = as_type<int>((as_type<uint>(x_10) + as_type<uint>(1)));
return;
}

View File

@@ -3,7 +3,7 @@
using namespace metal;
kernel void tint_symbol() {
int i = 123;
int const use = (i + 1);
int const use = as_type<int>((as_type<uint>(i) + as_type<uint>(1)));
return;
}

View File

@@ -3,7 +3,7 @@
using namespace metal;
kernel void tint_symbol() {
int i = 123;
int const use = (i + 1);
int const use = as_type<int>((as_type<uint>(i) + as_type<uint>(1)));
return;
}

View File

@@ -3,7 +3,7 @@
using namespace metal;
kernel void tint_symbol() {
thread int tint_symbol_1 = 123;
int const use = (tint_symbol_1 + 1);
int const use = as_type<int>((as_type<uint>(tint_symbol_1) + as_type<uint>(1)));
return;
}

View File

@@ -6,7 +6,7 @@ struct S {
};
kernel void tint_symbol(device S& v [[buffer(0)]]) {
int const use = (v.a + 1);
int const use = as_type<int>((as_type<uint>(v.a) + as_type<uint>(1)));
return;
}

View File

@@ -6,7 +6,7 @@ struct S {
};
kernel void tint_symbol(constant S& v [[buffer(0)]]) {
int const use = (v.a + 1);
int const use = as_type<int>((as_type<uint>(v.a) + as_type<uint>(1)));
return;
}

View File

@@ -8,7 +8,7 @@ kernel void tint_symbol(uint local_invocation_index [[thread_index_in_threadgrou
}
threadgroup_barrier(mem_flags::mem_threadgroup);
tint_symbol_2 = 123;
int const use = (tint_symbol_2 + 1);
int const use = as_type<int>((as_type<uint>(tint_symbol_2) + as_type<uint>(1)));
return;
}