forked from eden-emu/eden
		
	shader_ir/memory: Reduce severity of ST_L cache management and log it
This commit is contained in:
		
							parent
							
								
									a6d5ff05dc
								
							
						
					
					
						commit
						24abeb9a67
					
				
					 2 changed files with 11 additions and 3 deletions
				
			
		|  | @ -387,6 +387,13 @@ enum class IpaSampleMode : u64 { | ||||||
|     Offset = 2, |     Offset = 2, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | enum class LmemStoreCacheManagement : u64 { | ||||||
|  |     Default = 0, | ||||||
|  |     CG = 1, | ||||||
|  |     CS = 2, | ||||||
|  |     WT = 3, | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| struct IpaMode { | struct IpaMode { | ||||||
|     IpaInterpMode interpolation_mode; |     IpaInterpMode interpolation_mode; | ||||||
|     IpaSampleMode sampling_mode; |     IpaSampleMode sampling_mode; | ||||||
|  | @ -782,7 +789,7 @@ union Instruction { | ||||||
|     } ld_l; |     } ld_l; | ||||||
| 
 | 
 | ||||||
|     union { |     union { | ||||||
|         BitField<44, 2, u64> unknown; |         BitField<44, 2, LmemStoreCacheManagement> cache_management; | ||||||
|     } st_l; |     } st_l; | ||||||
| 
 | 
 | ||||||
|     union { |     union { | ||||||
|  |  | ||||||
|  | @ -8,6 +8,7 @@ | ||||||
| 
 | 
 | ||||||
| #include "common/assert.h" | #include "common/assert.h" | ||||||
| #include "common/common_types.h" | #include "common/common_types.h" | ||||||
|  | #include "common/logging/log.h" | ||||||
| #include "video_core/engines/shader_bytecode.h" | #include "video_core/engines/shader_bytecode.h" | ||||||
| #include "video_core/shader/shader_ir.h" | #include "video_core/shader/shader_ir.h" | ||||||
| 
 | 
 | ||||||
|  | @ -205,8 +206,8 @@ u32 ShaderIR::DecodeMemory(NodeBlock& bb, u32 pc) { | ||||||
|         break; |         break; | ||||||
|     } |     } | ||||||
|     case OpCode::Id::ST_L: { |     case OpCode::Id::ST_L: { | ||||||
|         UNIMPLEMENTED_IF_MSG(instr.st_l.unknown == 0, "ST_L Unhandled mode: {}", |         LOG_DEBUG(HW_GPU, "ST_L cache management mode: {}", | ||||||
|                              static_cast<u32>(instr.st_l.unknown.Value())); |                   static_cast<u64>(instr.st_l.cache_management.Value())); | ||||||
| 
 | 
 | ||||||
|         const auto GetLmemAddr = [&](s32 offset) { |         const auto GetLmemAddr = [&](s32 offset) { | ||||||
|             ASSERT(offset % 4 == 0); |             ASSERT(offset % 4 == 0); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 ReinUsesLisp
						ReinUsesLisp