mirror of
				https://gitlab.winehq.org/wine/vkd3d.git
				synced 2025-09-12 18:50:22 -07:00 
			
		
		
		
	
		
			
				
	
	
		
			97 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| [pixel shader todo(sm<4)]
 | |
| uniform float4 f;
 | |
| 
 | |
| float4 main() : sv_target
 | |
| {
 | |
|     float4 result;
 | |
|     float n = f.x/f.w;
 | |
| 
 | |
|     /* '!(condition)' in SM6 forces use of the unordered instruction variant. */
 | |
| 
 | |
|     result.x  = (f.y > f.x)   ?        1.0 : 0.0;
 | |
|     result.x += (f.y < f.x)   ?       10.0 : 0.0;
 | |
|     result.x += (f.y >= f.x)  ?      100.0 : 0.0;
 | |
|     result.x += (f.y <= f.x)  ?     1000.0 : 0.0;
 | |
|     result.x += !(f.y <= f.x) ?    10000.0 : 0.0;
 | |
|     result.x += !(f.y >= f.x) ?   100000.0 : 0.0;
 | |
|     result.x += !(f.y < f.x)  ?  1000000.0 : 0.0;
 | |
|     result.x += !(f.y > f.x)  ? 10000000.0 : 0.0;
 | |
|     result.y  = (n > f.x)   ?        1.0 : 0.0;
 | |
|     result.y += (n < f.x)   ?       10.0 : 0.0;
 | |
|     result.y += (n >= f.x)  ?      100.0 : 0.0;
 | |
|     result.y += (n <= f.x)  ?     1000.0 : 0.0;
 | |
|     result.y += !(n <= f.x) ?    10000.0 : 0.0;
 | |
|     result.y += !(n >= f.x) ?   100000.0 : 0.0;
 | |
|     result.y += !(n < f.x)  ?  1000000.0 : 0.0;
 | |
|     result.y += !(n > f.x)  ? 10000000.0 : 0.0;
 | |
|     result.z  = (f.z == f.y)  ?        1.0 : 0.0;
 | |
|     result.z += (f.z != f.y)  ?       10.0 : 0.0;
 | |
|     result.z += !(f.z == f.y) ?      100.0 : 0.0;
 | |
|     result.z += !(f.z != f.y) ?     1000.0 : 0.0;
 | |
|     result.z += (n == f.y)    ?    10000.0 : 0.0;
 | |
|     result.z += (n != f.y)    ?   100000.0 : 0.0;
 | |
|     result.z += !(n == f.y)   ?  1000000.0 : 0.0;
 | |
|     result.z += !(n != f.y)   ? 10000000.0 : 0.0;
 | |
|     /* It doesn't seem possible to generate DXIL instructions for 'is ordered' or 'is unordered'.
 | |
|      * Expressions 'isnan(n)' and '(isnan(n) || isnan(f.x))' compile into intrinsics. */
 | |
|     result.w = 0;
 | |
|     return result;
 | |
| }
 | |
| 
 | |
| % SM1-3 apparently treats '0/0' as zero.
 | |
| [require]
 | |
| shader model < 4.0
 | |
| 
 | |
| [test]
 | |
| uniform 0 float4 0.0 1.5 1.5 0.0
 | |
| todo(sm<4) draw quad
 | |
| todo probe all rgba (1010101.0, 11001100.0, 1101001.0, 0.0)
 | |
| 
 | |
| % SM4-5 optimises away the 'not' by inverting the condition, even though this is invalid for NaN.
 | |
| [require]
 | |
| shader model >= 4.0
 | |
| shader model < 6.0
 | |
| 
 | |
| [test]
 | |
| uniform 0 float4 0.0 1.5 1.5 0.0
 | |
| draw quad
 | |
| todo probe all rgba (1010101.0, 0.0, 1101001.0, 0.0)
 | |
| 
 | |
| % SM6 emits the correct ordered/unordered instructions, so comparisons are false for NaN, and are made true with 'not'.
 | |
| [require]
 | |
| shader model >= 6.0
 | |
| 
 | |
| [test]
 | |
| uniform 0 float4 0.0 1.5 1.5 0.0
 | |
| draw quad
 | |
| probe all rgba (1010101.0, 11110000.0, 1101001.0, 0.0)
 | |
| 
 | |
| 
 | |
| [pixel shader]
 | |
| uniform float4 f;
 | |
| 
 | |
| float4 main() : sv_target
 | |
| {
 | |
|     float4 result = float4(isinf(f.x / f.y), isnan(sqrt(f.w)), isinf(sqrt(f.w)), isnan(f.x / f.y));
 | |
|     return result + float4(isinf(f.x / f.z), isnan(sqrt(f.y)), isinf(f.y / f.z), isnan(sqrt(f.z))) * 10.0;
 | |
| }
 | |
| 
 | |
| [test]
 | |
| uniform 0 float4 1.5 0.0 1.0 -1.0
 | |
| todo draw quad
 | |
| probe all rgba (1.0, 1.0, 0.0, 0.0)
 | |
| 
 | |
| 
 | |
| [pixel shader]
 | |
| uniform float4 f;
 | |
| 
 | |
| float4 main() : sv_target
 | |
| {
 | |
|     return float4(isfinite(f.x / f.y), isfinite(sqrt(f.w)), isfinite(f.x / f.z), 0.0);
 | |
| }
 | |
| 
 | |
| [test]
 | |
| uniform 0 float4 1.5 0.0 1.0 -1.0
 | |
| draw quad
 | |
| probe all rgba (0.0, 0.0, 1.0, 0.0)
 |