forked from eden-emu/eden
		
	GPU: Texture format 8 and framebuffer format 0xD5 are actually ABGR8.
This commit is contained in:
		
							parent
							
								
									d3f9ea90e7
								
							
						
					
					
						commit
						b2c1672e10
					
				
					 2 changed files with 10 additions and 10 deletions
				
			
		|  | @ -52,7 +52,7 @@ static constexpr std::array<FormatTuple, 1> fb_format_tuples = {{ | |||
| }}; | ||||
| 
 | ||||
| static constexpr std::array<FormatTuple, 2> tex_format_tuples = {{ | ||||
|     {GL_RGBA8, GL_RGBA, GL_UNSIGNED_INT_8_8_8_8, false, 1},                       // RGBA8
 | ||||
|     {GL_RGBA8, GL_RGBA, GL_UNSIGNED_INT_8_8_8_8_REV, false, 1},                   // ABGR8
 | ||||
|     {GL_COMPRESSED_RGB_S3TC_DXT1_EXT, GL_RGB, GL_UNSIGNED_INT_8_8_8_8, true, 16}, // DXT1
 | ||||
| }}; | ||||
| 
 | ||||
|  | @ -123,13 +123,13 @@ void MortonCopy(u32 stride, u32 block_height, u32 height, u8* gl_buffer, VAddr b | |||
| 
 | ||||
| static constexpr std::array<void (*)(u32, u32, u32, u8*, VAddr, VAddr, VAddr), 2> morton_to_gl_fns = | ||||
|     { | ||||
|         MortonCopy<true, PixelFormat::RGBA8>, | ||||
|         MortonCopy<true, PixelFormat::ABGR8>, | ||||
|         MortonCopy<true, PixelFormat::DXT1>, | ||||
| }; | ||||
| 
 | ||||
| static constexpr std::array<void (*)(u32, u32, u32, u8*, VAddr, VAddr, VAddr), 2> gl_to_morton_fns = | ||||
|     { | ||||
|         MortonCopy<false, PixelFormat::RGBA8>, | ||||
|         MortonCopy<false, PixelFormat::ABGR8>, | ||||
|         // TODO(Subv): Swizzling the DXT1 format is not yet supported
 | ||||
|         nullptr, | ||||
| }; | ||||
|  |  | |||
|  | @ -52,7 +52,7 @@ enum class ScaleMatch { | |||
| 
 | ||||
| struct SurfaceParams { | ||||
|     enum class PixelFormat { | ||||
|         RGBA8 = 0, | ||||
|         ABGR8 = 0, | ||||
|         DXT1 = 1, | ||||
|         Invalid = 255, | ||||
|     }; | ||||
|  | @ -71,7 +71,7 @@ struct SurfaceParams { | |||
|             return 0; | ||||
| 
 | ||||
|         constexpr std::array<unsigned int, 2> bpp_table = { | ||||
|             32, // RGBA8
 | ||||
|             32, // ABGR8
 | ||||
|             64, // DXT1
 | ||||
|         }; | ||||
| 
 | ||||
|  | @ -85,7 +85,7 @@ struct SurfaceParams { | |||
|     static PixelFormat PixelFormatFromRenderTargetFormat(Tegra::RenderTargetFormat format) { | ||||
|         switch (format) { | ||||
|         case Tegra::RenderTargetFormat::RGBA8_UNORM: | ||||
|             return PixelFormat::RGBA8; | ||||
|             return PixelFormat::ABGR8; | ||||
|         default: | ||||
|             NGLOG_CRITICAL(HW_GPU, "Unimplemented format={}", static_cast<u32>(format)); | ||||
|             UNREACHABLE(); | ||||
|  | @ -95,7 +95,7 @@ struct SurfaceParams { | |||
|     static PixelFormat PixelFormatFromGPUPixelFormat(Tegra::FramebufferConfig::PixelFormat format) { | ||||
|         switch (format) { | ||||
|         case Tegra::FramebufferConfig::PixelFormat::ABGR8: | ||||
|             return PixelFormat::RGBA8; | ||||
|             return PixelFormat::ABGR8; | ||||
|         default: | ||||
|             NGLOG_CRITICAL(HW_GPU, "Unimplemented format={}", static_cast<u32>(format)); | ||||
|             UNREACHABLE(); | ||||
|  | @ -106,7 +106,7 @@ struct SurfaceParams { | |||
|         // TODO(Subv): Properly implement this
 | ||||
|         switch (format) { | ||||
|         case Tegra::Texture::TextureFormat::A8R8G8B8: | ||||
|             return PixelFormat::RGBA8; | ||||
|             return PixelFormat::ABGR8; | ||||
|         case Tegra::Texture::TextureFormat::DXT1: | ||||
|             return PixelFormat::DXT1; | ||||
|         default: | ||||
|  | @ -118,7 +118,7 @@ struct SurfaceParams { | |||
|     static Tegra::Texture::TextureFormat TextureFormatFromPixelFormat(PixelFormat format) { | ||||
|         // TODO(Subv): Properly implement this
 | ||||
|         switch (format) { | ||||
|         case PixelFormat::RGBA8: | ||||
|         case PixelFormat::ABGR8: | ||||
|             return Tegra::Texture::TextureFormat::A8R8G8B8; | ||||
|         case PixelFormat::DXT1: | ||||
|             return Tegra::Texture::TextureFormat::DXT1; | ||||
|  | @ -148,7 +148,7 @@ struct SurfaceParams { | |||
|     } | ||||
| 
 | ||||
|     static SurfaceType GetFormatType(PixelFormat pixel_format) { | ||||
|         if ((unsigned int)pixel_format <= static_cast<unsigned int>(PixelFormat::RGBA8)) { | ||||
|         if ((unsigned int)pixel_format <= static_cast<unsigned int>(PixelFormat::ABGR8)) { | ||||
|             return SurfaceType::Color; | ||||
|         } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Subv
						Subv