forked from eden-emu/eden
		
	Merge pull request #10699 from liamwhite/conditional-barrier
shader_recompiler: remove barriers in conditional control flow when device lacks support
This commit is contained in:
		
						commit
						42b2bc204f
					
				
					 10 changed files with 65 additions and 0 deletions
				
			
		|  | @ -201,6 +201,7 @@ Device::Device(Core::Frontend::EmuWindow& emu_window) { | |||
|     use_asynchronous_shaders = Settings::values.use_asynchronous_shaders.GetValue() && | ||||
|                                !(is_amd || (is_intel && !is_linux)) && !strict_context_required; | ||||
|     use_driver_cache = is_nvidia; | ||||
|     supports_conditional_barriers = !is_intel; | ||||
| 
 | ||||
|     LOG_INFO(Render_OpenGL, "Renderer_VariableAOFFI: {}", has_variable_aoffi); | ||||
|     LOG_INFO(Render_OpenGL, "Renderer_ComponentIndexingBug: {}", has_component_indexing_bug); | ||||
|  |  | |||
|  | @ -188,6 +188,10 @@ public: | |||
|         return strict_context_required; | ||||
|     } | ||||
| 
 | ||||
|     bool SupportsConditionalBarriers() const { | ||||
|         return supports_conditional_barriers; | ||||
|     } | ||||
| 
 | ||||
| private: | ||||
|     static bool TestVariableAoffi(); | ||||
|     static bool TestPreciseBug(); | ||||
|  | @ -233,6 +237,7 @@ private: | |||
|     bool has_bool_ref_bug{}; | ||||
|     bool can_report_memory{}; | ||||
|     bool strict_context_required{}; | ||||
|     bool supports_conditional_barriers{}; | ||||
| 
 | ||||
|     std::string vendor_name; | ||||
| }; | ||||
|  |  | |||
|  | @ -239,6 +239,7 @@ ShaderCache::ShaderCache(RasterizerOpenGL& rasterizer_, Core::Frontend::EmuWindo | |||
|           .support_snorm_render_buffer = false, | ||||
|           .support_viewport_index_layer = device.HasVertexViewportLayer(), | ||||
|           .support_geometry_shader_passthrough = device.HasGeometryShaderPassthrough(), | ||||
|           .support_conditional_barrier = device.SupportsConditionalBarriers(), | ||||
|       } { | ||||
|     if (use_asynchronous_shaders) { | ||||
|         workers = CreateWorkers(); | ||||
|  |  | |||
|  | @ -386,6 +386,8 @@ Device::Device(VkInstance instance_, vk::PhysicalDevice physical_, VkSurfaceKHR | |||
|         IsFormatSupported(VK_FORMAT_D24_UNORM_S8_UINT, | ||||
|                           VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT, FormatType::Optimal); | ||||
| 
 | ||||
|     supports_conditional_barriers = !(is_intel_anv || is_intel_windows); | ||||
| 
 | ||||
|     CollectPhysicalMemoryInfo(); | ||||
|     CollectToolingInfo(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -585,6 +585,10 @@ public: | |||
|         return properties.properties.limits.maxVertexInputBindings; | ||||
|     } | ||||
| 
 | ||||
|     bool SupportsConditionalBarriers() const { | ||||
|         return supports_conditional_barriers; | ||||
|     } | ||||
| 
 | ||||
| private: | ||||
|     /// Checks if the physical device is suitable and configures the object state
 | ||||
|     /// with all necessary info about its properties.
 | ||||
|  | @ -688,6 +692,7 @@ private: | |||
|     bool must_emulate_bgr565{};             ///< Emulates BGR565 by swizzling RGB565 format.
 | ||||
|     bool dynamic_state3_blending{};         ///< Has all blending features of dynamic_state3.
 | ||||
|     bool dynamic_state3_enables{};          ///< Has all enables features of dynamic_state3.
 | ||||
|     bool supports_conditional_barriers{};   ///< Allows barriers in conditional control flow.
 | ||||
|     u64 device_access_memory{};             ///< Total size of device local memory in bytes.
 | ||||
|     u32 sets_per_pool{};                    ///< Sets per Description Pool
 | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Matías Locatti
						Matías Locatti