forked from eden-emu/eden
		
	Merge pull request #3434 from namkazt/patch-2
vk_shader: Implement ImageLoad
This commit is contained in:
		
						commit
						291a7850a3
					
				
					 3 changed files with 25 additions and 2 deletions
				
			
		|  | @ -107,6 +107,8 @@ bool VKDevice::Create(const vk::DispatchLoaderDynamic& dldi, vk::Instance instan | ||||||
|     features.occlusionQueryPrecise = true; |     features.occlusionQueryPrecise = true; | ||||||
|     features.fragmentStoresAndAtomics = true; |     features.fragmentStoresAndAtomics = true; | ||||||
|     features.shaderImageGatherExtended = true; |     features.shaderImageGatherExtended = true; | ||||||
|  |     features.shaderStorageImageReadWithoutFormat = | ||||||
|  |         is_shader_storage_img_read_without_format_supported; | ||||||
|     features.shaderStorageImageWriteWithoutFormat = true; |     features.shaderStorageImageWriteWithoutFormat = true; | ||||||
|     features.textureCompressionASTC_LDR = is_optimal_astc_supported; |     features.textureCompressionASTC_LDR = is_optimal_astc_supported; | ||||||
| 
 | 
 | ||||||
|  | @ -465,6 +467,8 @@ void VKDevice::SetupFamilies(const vk::DispatchLoaderDynamic& dldi, vk::SurfaceK | ||||||
| 
 | 
 | ||||||
| void VKDevice::SetupFeatures(const vk::DispatchLoaderDynamic& dldi) { | void VKDevice::SetupFeatures(const vk::DispatchLoaderDynamic& dldi) { | ||||||
|     const auto supported_features{physical.getFeatures(dldi)}; |     const auto supported_features{physical.getFeatures(dldi)}; | ||||||
|  |     is_shader_storage_img_read_without_format_supported = | ||||||
|  |         supported_features.shaderStorageImageReadWithoutFormat; | ||||||
|     is_optimal_astc_supported = IsOptimalAstcSupported(supported_features, dldi); |     is_optimal_astc_supported = IsOptimalAstcSupported(supported_features, dldi); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -122,6 +122,11 @@ public: | ||||||
|         return properties.limits.maxPushConstantsSize; |         return properties.limits.maxPushConstantsSize; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /// Returns true if Shader storage Image Read Without Format supported.
 | ||||||
|  |     bool IsShaderStorageImageReadWithoutFormatSupported() const { | ||||||
|  |         return is_shader_storage_img_read_without_format_supported; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     /// Returns true if ASTC is natively supported.
 |     /// Returns true if ASTC is natively supported.
 | ||||||
|     bool IsOptimalAstcSupported() const { |     bool IsOptimalAstcSupported() const { | ||||||
|         return is_optimal_astc_supported; |         return is_optimal_astc_supported; | ||||||
|  | @ -227,6 +232,8 @@ private: | ||||||
|     bool ext_depth_range_unrestricted{};       ///< Support for VK_EXT_depth_range_unrestricted.
 |     bool ext_depth_range_unrestricted{};       ///< Support for VK_EXT_depth_range_unrestricted.
 | ||||||
|     bool ext_shader_viewport_index_layer{};    ///< Support for VK_EXT_shader_viewport_index_layer.
 |     bool ext_shader_viewport_index_layer{};    ///< Support for VK_EXT_shader_viewport_index_layer.
 | ||||||
|     bool nv_device_diagnostic_checkpoints{};   ///< Support for VK_NV_device_diagnostic_checkpoints.
 |     bool nv_device_diagnostic_checkpoints{};   ///< Support for VK_NV_device_diagnostic_checkpoints.
 | ||||||
|  |     bool is_shader_storage_img_read_without_format_supported{}; ///< Support for shader storage
 | ||||||
|  |                                                                 ///< image read without format
 | ||||||
| 
 | 
 | ||||||
|     // Telemetry parameters
 |     // Telemetry parameters
 | ||||||
|     std::string vendor_name;                      ///< Device's driver name.
 |     std::string vendor_name;                      ///< Device's driver name.
 | ||||||
|  |  | ||||||
|  | @ -292,6 +292,10 @@ public: | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         if (device.IsShaderStorageImageReadWithoutFormatSupported()) { | ||||||
|  |             AddCapability(spv::Capability::StorageImageReadWithoutFormat); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         if (device.IsFloat16Supported()) { |         if (device.IsFloat16Supported()) { | ||||||
|             AddCapability(spv::Capability::Float16); |             AddCapability(spv::Capability::Float16); | ||||||
|         } |         } | ||||||
|  | @ -1755,8 +1759,16 @@ private: | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     Expression ImageLoad(Operation operation) { |     Expression ImageLoad(Operation operation) { | ||||||
|         UNIMPLEMENTED(); |         if (!device.IsShaderStorageImageReadWithoutFormatSupported()) { | ||||||
|         return {}; |             return {v_float_zero, Type::Float}; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         const auto& meta{std::get<MetaImage>(operation.GetMeta())}; | ||||||
|  | 
 | ||||||
|  |         const Id coords = GetCoordinates(operation, Type::Int); | ||||||
|  |         const Id texel = OpImageRead(t_uint4, GetImage(operation), coords); | ||||||
|  | 
 | ||||||
|  |         return {OpCompositeExtract(t_uint, texel, meta.element), Type::Uint}; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     Expression ImageStore(Operation operation) { |     Expression ImageStore(Operation operation) { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Rodrigo Locatti
						Rodrigo Locatti