| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 |
- using ChocolArm64.Memory;
- using Ryujinx.Graphics.Gal;
- using System;
- namespace Ryujinx.Core.Gpu
- {
- public static class TextureReader
- {
- public static byte[] Read(IAMemory Memory, Texture Texture)
- {
- switch (Texture.Format)
- {
- case GalTextureFormat.A8B8G8R8: return Read4Bpp (Memory, Texture);
- case GalTextureFormat.A1B5G5R5: return Read2Bpp (Memory, Texture);
- case GalTextureFormat.B5G6R5: return Read2Bpp (Memory, Texture);
- case GalTextureFormat.BC1: return Read8Bpt4x4 (Memory, Texture);
- case GalTextureFormat.BC2: return Read16Bpt4x4(Memory, Texture);
- case GalTextureFormat.BC3: return Read16Bpt4x4(Memory, Texture);
- case GalTextureFormat.BC4: return Read8Bpt4x4 (Memory, Texture);
- case GalTextureFormat.BC5: return Read16Bpt4x4(Memory, Texture);
- }
- throw new NotImplementedException(Texture.Format.ToString());
- }
- private unsafe static byte[] Read2Bpp(IAMemory Memory, Texture Texture)
- {
- int Width = Texture.Width;
- int Height = Texture.Height;
- byte[] Output = new byte[Width * Height * 2];
- ISwizzle Swizzle = TextureHelper.GetSwizzle(Texture, Width, 2);
- (AMemory CpuMem, long Position) = TextureHelper.GetMemoryAndPosition(
- Memory,
- Texture.Position);
- fixed (byte* BuffPtr = Output)
- {
- long OutOffs = 0;
- for (int Y = 0; Y < Height; Y++)
- for (int X = 0; X < Width; X++)
- {
- long Offset = (uint)Swizzle.GetSwizzleOffset(X, Y);
- short Pixel = CpuMem.ReadInt16Unchecked(Position + Offset);
- *(short*)(BuffPtr + OutOffs) = Pixel;
- OutOffs += 2;
- }
- }
- return Output;
- }
- private unsafe static byte[] Read4Bpp(IAMemory Memory, Texture Texture)
- {
- int Width = Texture.Width;
- int Height = Texture.Height;
- byte[] Output = new byte[Width * Height * 4];
- ISwizzle Swizzle = TextureHelper.GetSwizzle(Texture, Width, 4);
- (AMemory CpuMem, long Position) = TextureHelper.GetMemoryAndPosition(
- Memory,
- Texture.Position);
- fixed (byte* BuffPtr = Output)
- {
- long OutOffs = 0;
- for (int Y = 0; Y < Height; Y++)
- for (int X = 0; X < Width; X++)
- {
- long Offset = (uint)Swizzle.GetSwizzleOffset(X, Y);
- int Pixel = CpuMem.ReadInt32Unchecked(Position + Offset);
- *(int*)(BuffPtr + OutOffs) = Pixel;
- OutOffs += 4;
- }
- }
- return Output;
- }
- private unsafe static byte[] Read8Bpt4x4(IAMemory Memory, Texture Texture)
- {
- int Width = (Texture.Width + 3) / 4;
- int Height = (Texture.Height + 3) / 4;
- byte[] Output = new byte[Width * Height * 8];
- ISwizzle Swizzle = TextureHelper.GetSwizzle(Texture, Width, 8);
- (AMemory CpuMem, long Position) = TextureHelper.GetMemoryAndPosition(
- Memory,
- Texture.Position);
- fixed (byte* BuffPtr = Output)
- {
- long OutOffs = 0;
- for (int Y = 0; Y < Height; Y++)
- for (int X = 0; X < Width; X++)
- {
- long Offset = (uint)Swizzle.GetSwizzleOffset(X, Y);
- long Tile = CpuMem.ReadInt64Unchecked(Position + Offset);
- *(long*)(BuffPtr + OutOffs) = Tile;
- OutOffs += 8;
- }
- }
- return Output;
- }
- private unsafe static byte[] Read16Bpt4x4(IAMemory Memory, Texture Texture)
- {
- int Width = (Texture.Width + 3) / 4;
- int Height = (Texture.Height + 3) / 4;
- byte[] Output = new byte[Width * Height * 16];
- ISwizzle Swizzle = TextureHelper.GetSwizzle(Texture, Width, 16);
- (AMemory CpuMem, long Position) = TextureHelper.GetMemoryAndPosition(
- Memory,
- Texture.Position);
- fixed (byte* BuffPtr = Output)
- {
- long OutOffs = 0;
- for (int Y = 0; Y < Height; Y++)
- for (int X = 0; X < Width; X++)
- {
- long Offset = (uint)Swizzle.GetSwizzleOffset(X, Y);
- long Tile0 = CpuMem.ReadInt64Unchecked(Position + Offset + 0);
- long Tile1 = CpuMem.ReadInt64Unchecked(Position + Offset + 8);
- *(long*)(BuffPtr + OutOffs + 0) = Tile0;
- *(long*)(BuffPtr + OutOffs + 8) = Tile1;
- OutOffs += 16;
- }
- }
- return Output;
- }
- }
- }
|