mirror of
				https://github.com/encounter/dawn-cmake.git
				synced 2025-10-25 03:00:29 +00:00 
			
		
		
		
	GLSL has the same behavior as MSL, in that -2147483648 is parsed as a unary minus on '2147483648'. 2147483648 overflows an i32, so this actually gets treated as -0. Change-Id: Ibebd8b78a8840f18c438ed1d3d24dee486a65816 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/123202 Reviewed-by: Stephen White <senorblanco@chromium.org> Commit-Queue: Ben Clayton <bclayton@google.com> Commit-Queue: Ben Clayton <bclayton@chromium.org> Kokoro: Kokoro <noreply+kokoro@google.com>
		
			
				
	
	
		
			28 lines
		
	
	
		
			583 B
		
	
	
	
		
			GLSL
		
	
	
	
	
	
			
		
		
	
	
			28 lines
		
	
	
		
			583 B
		
	
	
	
		
			GLSL
		
	
	
	
	
	
| #version 310 es
 | |
| 
 | |
| layout(local_size_x = 1, local_size_y = 1, local_size_z = 1) in;
 | |
| void unused_entry_point() {
 | |
|   return;
 | |
| }
 | |
| struct S {
 | |
|   int a;
 | |
| };
 | |
| 
 | |
| layout(binding = 0, std430) buffer v_block_ssbo {
 | |
|   S inner;
 | |
| } v;
 | |
| 
 | |
| int tint_mod(int lhs, int rhs) {
 | |
|   int rhs_or_one = (bool(uint((rhs == 0)) | uint(bool(uint((lhs == (-2147483647 - 1))) & uint((rhs == -1))))) ? 1 : rhs);
 | |
|   if (((uint((lhs | rhs_or_one)) & 2147483648u) != 0u)) {
 | |
|     return (lhs - ((lhs / rhs_or_one) * rhs_or_one));
 | |
|   } else {
 | |
|     return (lhs % rhs_or_one);
 | |
|   }
 | |
| }
 | |
| 
 | |
| void foo() {
 | |
|   v.inner.a = tint_mod(v.inner.a, 2);
 | |
| }
 | |
| 
 |