NvServices refactoring (#120)
* Initial implementation of NvMap/NvHostCtrl
* More work on NvHostCtrl
* Refactoring of nvservices, move GPU Vmm, make Vmm per-process, refactor most gpu devices, move Gpu to Core, fix CbBind
* Implement GetGpuTime, support CancelSynchronization, fix issue on InsertWaitingMutex, proper double buffering support (again, not working properly for commercial games, only hb)
* Try to fix perf regression reading/writing textures, moved syncpts and events to a UserCtx class, delete global state when the process exits, other minor tweaks
* Remove now unused code, add comment about probably wrong result codes
2018-05-07 20:53:23 +02:00
|
|
|
using ChocolArm64.Memory;
|
2018-06-09 02:15:56 +02:00
|
|
|
using Ryujinx.Graphics.Gal;
|
2018-04-26 04:11:26 +02:00
|
|
|
using System;
|
|
|
|
|
2018-06-16 03:20:48 +02:00
|
|
|
namespace Ryujinx.HLE.Gpu
|
2018-04-26 04:11:26 +02:00
|
|
|
{
|
|
|
|
static class TextureHelper
|
|
|
|
{
|
|
|
|
public static ISwizzle GetSwizzle(Texture Texture, int Width, int Bpp)
|
|
|
|
{
|
|
|
|
switch (Texture.Swizzle)
|
|
|
|
{
|
|
|
|
case TextureSwizzle.Pitch:
|
|
|
|
case TextureSwizzle.PitchColorKey:
|
|
|
|
return new LinearSwizzle(Texture.Pitch, Bpp);
|
|
|
|
|
|
|
|
case TextureSwizzle.BlockLinear:
|
|
|
|
case TextureSwizzle.BlockLinearColorKey:
|
|
|
|
return new BlockLinearSwizzle(Width, Bpp, Texture.BlockHeight);
|
|
|
|
}
|
|
|
|
|
|
|
|
throw new NotImplementedException(Texture.Swizzle.ToString());
|
|
|
|
}
|
NvServices refactoring (#120)
* Initial implementation of NvMap/NvHostCtrl
* More work on NvHostCtrl
* Refactoring of nvservices, move GPU Vmm, make Vmm per-process, refactor most gpu devices, move Gpu to Core, fix CbBind
* Implement GetGpuTime, support CancelSynchronization, fix issue on InsertWaitingMutex, proper double buffering support (again, not working properly for commercial games, only hb)
* Try to fix perf regression reading/writing textures, moved syncpts and events to a UserCtx class, delete global state when the process exits, other minor tweaks
* Remove now unused code, add comment about probably wrong result codes
2018-05-07 20:53:23 +02:00
|
|
|
|
2018-06-09 02:15:56 +02:00
|
|
|
public static int GetTextureSize(GalTexture Texture)
|
|
|
|
{
|
|
|
|
switch (Texture.Format)
|
|
|
|
{
|
|
|
|
case GalTextureFormat.R32G32B32A32: return Texture.Width * Texture.Height * 16;
|
|
|
|
case GalTextureFormat.R16G16B16A16: return Texture.Width * Texture.Height * 8;
|
|
|
|
case GalTextureFormat.A8B8G8R8: return Texture.Width * Texture.Height * 4;
|
|
|
|
case GalTextureFormat.R32: return Texture.Width * Texture.Height * 4;
|
|
|
|
case GalTextureFormat.A1B5G5R5: return Texture.Width * Texture.Height * 2;
|
|
|
|
case GalTextureFormat.B5G6R5: return Texture.Width * Texture.Height * 2;
|
|
|
|
case GalTextureFormat.G8R8: return Texture.Width * Texture.Height * 2;
|
2018-06-16 03:20:48 +02:00
|
|
|
case GalTextureFormat.R16: return Texture.Width * Texture.Height * 2;
|
2018-06-09 02:15:56 +02:00
|
|
|
case GalTextureFormat.R8: return Texture.Width * Texture.Height;
|
|
|
|
|
|
|
|
case GalTextureFormat.BC1:
|
|
|
|
case GalTextureFormat.BC4:
|
|
|
|
{
|
|
|
|
int W = (Texture.Width + 3) / 4;
|
|
|
|
int H = (Texture.Height + 3) / 4;
|
|
|
|
|
|
|
|
return W * H * 8;
|
|
|
|
}
|
|
|
|
|
2018-06-16 03:20:48 +02:00
|
|
|
case GalTextureFormat.BC7U:
|
2018-06-09 02:15:56 +02:00
|
|
|
case GalTextureFormat.BC2:
|
|
|
|
case GalTextureFormat.BC3:
|
|
|
|
case GalTextureFormat.BC5:
|
|
|
|
case GalTextureFormat.Astc2D4x4:
|
|
|
|
{
|
|
|
|
int W = (Texture.Width + 3) / 4;
|
|
|
|
int H = (Texture.Height + 3) / 4;
|
|
|
|
|
|
|
|
return W * H * 16;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
throw new NotImplementedException(Texture.Format.ToString());
|
|
|
|
}
|
|
|
|
|
NvServices refactoring (#120)
* Initial implementation of NvMap/NvHostCtrl
* More work on NvHostCtrl
* Refactoring of nvservices, move GPU Vmm, make Vmm per-process, refactor most gpu devices, move Gpu to Core, fix CbBind
* Implement GetGpuTime, support CancelSynchronization, fix issue on InsertWaitingMutex, proper double buffering support (again, not working properly for commercial games, only hb)
* Try to fix perf regression reading/writing textures, moved syncpts and events to a UserCtx class, delete global state when the process exits, other minor tweaks
* Remove now unused code, add comment about probably wrong result codes
2018-05-07 20:53:23 +02:00
|
|
|
public static (AMemory Memory, long Position) GetMemoryAndPosition(
|
|
|
|
IAMemory Memory,
|
|
|
|
long Position)
|
|
|
|
{
|
|
|
|
if (Memory is NvGpuVmm Vmm)
|
|
|
|
{
|
|
|
|
return (Vmm.Memory, Vmm.GetPhysicalAddress(Position));
|
|
|
|
}
|
|
|
|
|
|
|
|
return ((AMemory)Memory, Position);
|
|
|
|
}
|
2018-04-26 04:11:26 +02:00
|
|
|
}
|
|
|
|
}
|