forked from eden-emu/eden
		
	video_core: Enforce safe memory reads for compute dispatch
- Modify DmaPusher to use safe memory reads when handling compute operations at High GPU accuracy - Prevent potential memory corruption issues that could lead to invalid dispatch parameters - Previously, unsafe reads could result in corrupted launch_description data in KeplerCompute::ProcessLaunch, causing invalid vkCmdDispatch calls - By enforcing safe reads specifically for compute operations, we maintain performance for other GPU tasks while ensuring compute dispatch stability This change requires >= High GPU accuracy level to take effect.
This commit is contained in:
		
							parent
							
								
									d5bb26bf3e
								
							
						
					
					
						commit
						0071e980b8
					
				
					 1 changed files with 9 additions and 6 deletions
				
			
		|  | @ -98,19 +98,22 @@ bool DmaPusher::Step() { | |||
|                         &command_headers); | ||||
|             ProcessCommands(headers); | ||||
|         }; | ||||
| 
 | ||||
|         // Only use unsafe reads for non-compute macro operations
 | ||||
|         if (Settings::IsGPULevelHigh()) { | ||||
|             if (dma_state.method >= MacroRegistersStart) { | ||||
|                 unsafe_process(); | ||||
|                 return true; | ||||
|             } | ||||
|             if (subchannel_type[dma_state.subchannel] == Engines::EngineTypes::KeplerCompute && | ||||
|                 dma_state.method == ComputeInline) { | ||||
|             const bool is_compute = (subchannel_type[dma_state.subchannel] == | ||||
|                                    Engines::EngineTypes::KeplerCompute); | ||||
| 
 | ||||
|             if (dma_state.method >= MacroRegistersStart && !is_compute) { | ||||
|                 unsafe_process(); | ||||
|                 return true; | ||||
|             } | ||||
| 
 | ||||
|             // Always use safe reads for compute operations
 | ||||
|             safe_process(); | ||||
|             return true; | ||||
|         } | ||||
| 
 | ||||
|         unsafe_process(); | ||||
|     } | ||||
|     return true; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Zephyron
						Zephyron