Markus Wick 
								
							 
						 
						
							
							
							
							
								
							
							
								062d95753f 
								
							 
						 
						
							
							
								
								shader_recompiler/LOP3: Use brute force python results within switch/case.  
							
							... 
							
							
							
							Thanks to @asLody for optimizing this function. This raised the focus that this function should be optimized more.
The current table assumes that the host GPU is able to invert for free, so only AND,OR,XOR are accumulated in the performance metrik.
Performance results:
Instructions
0: 8
1: 30
2: 114
3: 80
4: 24
Latency
0: 8
1: 30
2: 194
3: 24 
							
						 
						
							2022-03-08 09:44:28 +01:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ameerj 
								
							 
						 
						
							
							
							
							
								
							
							
								4ee80ce807 
								
							 
						 
						
							
							
								
								video_minimum_maximum: Implement src operand selectors  
							
							... 
							
							
							
							Used by Pokemon Legends: Arceus 
							
						 
						
							2022-01-27 14:55:08 -05:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Lioncash 
								
							 
						 
						
							
							
							
							
								
							
							
								4ea21f074d 
								
							 
						 
						
							
							
								
								shader_recompiler: Remove unnecessary [[nodiscard]]  
							
							... 
							
							
							
							Since ConvertLegacyToGeneric has a void return value, there's nothing
that is actually returned by the function. 
							
						 
						
							2022-01-25 12:16:09 -05:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									vonchenplus 
								
							 
						 
						
							
							
							
							
								
							
							
								8fe519b656 
								
							 
						 
						
							
							
								
								Address format clang  
							
							
							
						 
						
							2021-12-18 14:27:07 +08:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Feng Chen 
								
							 
						 
						
							
							
							
							
								
							
							
								dbfa89c40b 
								
							 
						 
						
							
							
								
								Implement convert legacy to generic  
							
							
							
						 
						
							2021-11-19 22:53:58 +08:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ameerj 
								
							 
						 
						
							
							
							
							
								
							
							
								63465c24e1 
								
							 
						 
						
							
							
								
								rescaling_pass: Logic simplification and minor style cleanup  
							
							
							
						 
						
							2021-11-16 22:11:30 +01:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Fernando Sahmkow 
								
							 
						 
						
							
							
							
							
								
							
							
								4535feac87 
								
							 
						 
						
							
							
								
								Shader: Don't rescale FragCoord if used by Shuffle  
							
							
							
						 
						
							2021-11-16 22:11:30 +01:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								e63fc7a4bb 
								
							 
						 
						
							
							
								
								spirv: Implement rescaling patching  
							
							
							
						 
						
							2021-11-16 22:11:28 +01:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Fernando Sahmkow 
								
							 
						 
						
							
							
							
							
								
							
							
								c9bee9e96e 
								
							 
						 
						
							
							
								
								ShaderCache: Order Phi Arguments from farthest away to nearest.  
							
							
							
						 
						
							2021-10-31 19:34:15 +01:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ameerj 
								
							 
						 
						
							
							
							
							
								
							
							
								8485bb3dcb 
								
							 
						 
						
							
							
								
								structured_control_flow: Skip reordering nested demote branches.  
							
							... 
							
							
							
							Nested demote branches add complexity with combining the condition if it has not been initialized yet. Skip them for the time being. 
							
						 
						
							2021-08-30 11:46:25 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ameerj 
								
							 
						 
						
							
							
							
							
								
							
							
								e9a8e011f6 
								
							 
						 
						
							
							
								
								structured_control_flow: Conditionally invoke demote reorder pass  
							
							... 
							
							
							
							This is only needed on select drivers when a fragment shader discards/demotes. 
							
						 
						
							2021-08-30 11:46:24 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ameerj 
								
							 
						 
						
							
							
							
							
								
							
							
								8c687b3a91 
								
							 
						 
						
							
							
								
								structured_control_flow: Add DemoteCombinationPass  
							
							... 
							
							
							
							Some drivers misread data when demotes are interleaved in the program. This moves demote branches to be checked at the end of the program.
Fixes "wireframe" issue in Pokemon SwSh on some drivers 
							
						 
						
							2021-08-28 11:35:25 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Lioncash 
								
							 
						 
						
							
							
							
							
								
							
							
								9d5aa3d65a 
								
							 
						 
						
							
							
								
								control_flow: Fix duplicate switch case in OpcodeToken  
							
							... 
							
							
							
							This previously duplicated the case of the PBK case above it. 
							
						 
						
							2021-07-26 04:16:34 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								ba89444667 
								
							 
						 
						
							
							
								
								shader: Support out of bound local memory reads and immediate writes  
							
							... 
							
							
							
							Support ignoring immediate out of bound writes. Writing dynamically out
of bounds is not yet supported (e.g. R0+0x4).
Reading out of bounds yields zero. This is supported checking for the
size from the IR; if the input is immediate, the optimization passes
will drop it. 
							
						 
						
							2021-07-22 21:51:41 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ameerj 
								
							 
						 
						
							
							
							
							
								
							
							
								ffe72f8d37 
								
							 
						 
						
							
							
								
								shader: Implement ISETP.X  
							
							
							
						 
						
							2021-07-22 21:51:40 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								2321666580 
								
							 
						 
						
							
							
								
								shader: Avoid usage of C++20 ranges to build in clang  
							
							
							
						 
						
							2021-07-22 21:51:40 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									lat9nq 
								
							 
						 
						
							
							
							
							
								
							
							
								b557314001 
								
							 
						 
						
							
							
								
								shader_recompiler, video_core: Resolve clang errors  
							
							... 
							
							
							
							Silences the following warnings-turned-errors:
-Wsign-conversion
-Wunused-private-field
-Wbraced-scalar-init
-Wunused-variable
And some other errors 
							
						 
						
							2021-07-22 21:51:40 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								cdb3837085 
								
							 
						 
						
							
							
								
								shader: Manually convert from array<u32> to bitset instead of using bit_cast  
							
							
							
						 
						
							2021-07-22 21:51:40 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									lat9nq 
								
							 
						 
						
							
							
							
							
								
							
							
								c969f6e678 
								
							 
						 
						
							
							
								
								shader: GCC fmt 8.0.0 fixes  
							
							
							
						 
						
							2021-07-22 21:51:40 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ameerj 
								
							 
						 
						
							
							
							
							
								
							
							
								79e317ad7d 
								
							 
						 
						
							
							
								
								shader: Account for 33-bit IADD3 scenario  
							
							
							
						 
						
							2021-07-22 21:51:40 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								611797a7c6 
								
							 
						 
						
							
							
								
								shader: Only apply shift on register mode for IADD3  
							
							
							
						 
						
							2021-07-22 21:51:39 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								41b2a991c4 
								
							 
						 
						
							
							
								
								shader: Use std::bit_cast instead of Common::BitCast for passthrough  
							
							
							
						 
						
							2021-07-22 21:51:39 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								b1df436cef 
								
							 
						 
						
							
							
								
								shader: Rework varyings and implement passthrough geometry shaders  
							
							... 
							
							
							
							Put all varyings into a single std::bitset with helpers to access it.
Implement passthrough geometry shaders using host's. 
							
						 
						
							2021-07-22 21:51:39 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								6db3ba6542 
								
							 
						 
						
							
							
								
								shader: Only verify shader when graphics debugging is enabled  
							
							
							
						 
						
							2021-07-22 21:51:39 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								0a75c400e3 
								
							 
						 
						
							
							
								
								shader: Emulate 64-bit integers when not supported  
							
							... 
							
							
							
							Useful for mobile and Intel Xe devices. 
							
						 
						
							2021-07-22 21:51:39 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ameerj 
								
							 
						 
						
							
							
							
							
								
							
							
								58a052072c 
								
							 
						 
						
							
							
								
								shader_recompiler: Fix IADD3 input partitioning  
							
							
							
						 
						
							2021-07-22 21:51:39 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								04c1dca457 
								
							 
						 
						
							
							
								
								shader: Move loop safety tests to code emission  
							
							
							
						 
						
							2021-07-22 21:51:39 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								d633ec4ecc 
								
							 
						 
						
							
							
								
								shader: Calibrate loop safety threshold  
							
							
							
						 
						
							2021-07-22 21:51:38 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								16d28031e7 
								
							 
						 
						
							
							
								
								shader: Simplify MergeDualVertexPrograms  
							
							
							
						 
						
							2021-07-22 21:51:38 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								c4a71824d5 
								
							 
						 
						
							
							
								
								shader: Properly manage attributes not written from previous stages  
							
							
							
						 
						
							2021-07-22 21:51:38 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								52be21495e 
								
							 
						 
						
							
							
								
								shader: Add support for native 16-bit floats  
							
							
							
						 
						
							2021-07-22 21:51:38 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								41c634a7a9 
								
							 
						 
						
							
							
								
								shader: Rename maxwell/program.h to translate_program.h  
							
							
							
						 
						
							2021-07-22 21:51:38 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								574a99b9b3 
								
							 
						 
						
							
							
								
								shader: Fix loop safety to SSA pass  
							
							
							
						 
						
							2021-07-22 21:51:35 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								f40daa777e 
								
							 
						 
						
							
							
								
								shader: Add logging  
							
							
							
						 
						
							2021-07-22 21:51:35 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									lat9nq 
								
							 
						 
						
							
							
							
							
								
							
							
								3a70b6c79b 
								
							 
						 
						
							
							
								
								shader: Add shader loop safety check settings  
							
							... 
							
							
							
							Also add a setting for enable Nsight Aftermath. 
							
						 
						
							2021-07-22 21:51:35 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								a56f9f4322 
								
							 
						 
						
							
							
								
								shader: Comment why the array component is not read in TMML  
							
							
							
						 
						
							2021-07-22 21:51:35 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ameerj 
								
							 
						 
						
							
							
							
							
								
							
							
								4c1067ef1c 
								
							 
						 
						
							
							
								
								tmml: Remove index component from coords vec  
							
							... 
							
							
							
							The lod query functions exposed by the rendering API's do not make use of the texturearray layer indexing. 
							
						 
						
							2021-07-22 21:51:35 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									FernandoS27 
								
							 
						 
						
							
							
							
							
								
							
							
								be4d1c9b95 
								
							 
						 
						
							
							
								
								shader: Fix VertexA Shaders.  
							
							
							
						 
						
							2021-07-22 21:51:34 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								64dfb4220f 
								
							 
						 
						
							
							
								
								shader: Add 2D and 3D variants to SUATOM and SURED  
							
							... 
							
							
							
							Used by Claybook. 
							
						 
						
							2021-07-22 21:51:34 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								1dd4302fac 
								
							 
						 
						
							
							
								
								shader: Avoid CPU side undefined behavior on I2F  
							
							
							
						 
						
							2021-07-22 21:51:34 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								4744a21bd4 
								
							 
						 
						
							
							
								
								shader: Add support for "negative" and unaligned offsets  
							
							... 
							
							
							
							"Negative" offsets don't exist. They are shown as such due to a bug in
nvdisasm.
Unaligned offsets have been proved to read the aligned offset. For
example, when reading an U32, if the offset is 6, the offset read will
be 4. 
							
						 
						
							2021-07-22 21:51:34 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								e3aedea124 
								
							 
						 
						
							
							
								
								shader: Implement ISCADD32I  
							
							
							
						 
						
							2021-07-22 21:51:34 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								142d4f3f6e 
								
							 
						 
						
							
							
								
								shader: Always initialize up reference in structure control flow  
							
							... 
							
							
							
							Fixes ubsan issue. 
							
						 
						
							2021-07-22 21:51:34 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								6e475617d5 
								
							 
						 
						
							
							
								
								shader: Fix ImageWrite indexing  
							
							
							
						 
						
							2021-07-22 21:51:34 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								8ea552e64e 
								
							 
						 
						
							
							
								
								shader: Fix TMML queries  
							
							
							
						 
						
							2021-07-22 21:51:34 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								672930b6c8 
								
							 
						 
						
							
							
								
								shader: Handle host exceptions  
							
							
							
						 
						
							2021-07-22 21:51:34 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								5c6dc51c69 
								
							 
						 
						
							
							
								
								shader: Read branch conditions from an instruction  
							
							... 
							
							
							
							Fixes the identity removal pass. 
							
						 
						
							2021-07-22 21:51:32 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								0b3a3f35e8 
								
							 
						 
						
							
							
								
								glasm: Implement TEX and TEXS instructions  
							
							... 
							
							
							
							Remove lod clamp from texture instructions with lod, as this is not
needed (nor supported). 
							
						 
						
							2021-07-22 21:51:31 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									lat9nq 
								
							 
						 
						
							
							
							
							
								
							
							
								69210028b4 
								
							 
						 
						
							
							
								
								shader_recompiler: GCC fixes  
							
							... 
							
							
							
							Fixes members of unnamed union not being accessible, and one function
without a declaration. 
							
						 
						
							2021-07-22 21:51:31 -04:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									ReinUsesLisp 
								
							 
						 
						
							
							
							
							
								
							
							
								f2ae32fa76 
								
							 
						 
						
							
							
								
								glasm: Initial implementation of phi nodes on GLASM  
							
							
							
						 
						
							2021-07-22 21:51:31 -04:00