forked from eden-emu/eden
		
	gl_shader_cache: Fix texture view for cubemaps as cubemap arrays
Cubemaps are considered layered and to create a texture view the texture mustn't be a layered texture, resulting in cubemaps being bound as cubemap arrays. To fix this issue this commit introduces an extra surface parameter called "is_array" and uses this to query for texture view creation. Now that texture views for cubemaps are actually being created, this also fixes the number of layers created for the texture view (since they have to be 6 to create a texture view of cubemaps).
This commit is contained in:
		
							parent
							
								
									ce50c06bfc
								
							
						
					
					
						commit
						2a94d36231
					
				
					 4 changed files with 28 additions and 3 deletions
				
			
		|  | @ -50,6 +50,24 @@ bool SurfaceTargetIsLayered(SurfaceTarget target) { | |||
|     } | ||||
| } | ||||
| 
 | ||||
| bool SurfaceTargetIsArray(SurfaceTarget target) { | ||||
|     switch (target) { | ||||
|     case SurfaceTarget::Texture1D: | ||||
|     case SurfaceTarget::Texture2D: | ||||
|     case SurfaceTarget::Texture3D: | ||||
|     case SurfaceTarget::TextureCubemap: | ||||
|         return false; | ||||
|     case SurfaceTarget::Texture1DArray: | ||||
|     case SurfaceTarget::Texture2DArray: | ||||
|     case SurfaceTarget::TextureCubeArray: | ||||
|         return true; | ||||
|     default: | ||||
|         LOG_CRITICAL(HW_GPU, "Unimplemented surface_target={}", static_cast<u32>(target)); | ||||
|         UNREACHABLE(); | ||||
|         return false; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| PixelFormat PixelFormatFromDepthFormat(Tegra::DepthFormat format) { | ||||
|     switch (format) { | ||||
|     case Tegra::DepthFormat::S8_Z24_UNORM: | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 ReinUsesLisp
						ReinUsesLisp