2019-12-01 02:53:09 +00:00
|
|
|
using Ryujinx.Graphics.Shader.IntermediateRepresentation;
|
|
|
|
|
|
|
|
namespace Ryujinx.Graphics.Shader.Translation
|
|
|
|
{
|
|
|
|
static class GlobalMemory
|
|
|
|
{
|
|
|
|
private const int StorageDescsBaseOffset = 0x44; // In words.
|
|
|
|
|
|
|
|
public const int StorageDescSize = 4; // In words.
|
|
|
|
public const int StorageMaxCount = 16;
|
|
|
|
|
2020-01-06 01:04:37 +00:00
|
|
|
public const int StorageDescsSize = StorageDescSize * StorageMaxCount;
|
2019-12-01 02:53:09 +00:00
|
|
|
|
2020-02-11 00:10:05 +00:00
|
|
|
public const int UbeBaseOffset = 0x98; // In words.
|
|
|
|
public const int UbeMaxCount = 9;
|
|
|
|
public const int UbeDescsSize = StorageDescSize * UbeMaxCount;
|
|
|
|
public const int UbeFirstCbuf = 8;
|
|
|
|
|
2019-12-01 02:53:09 +00:00
|
|
|
public static bool UsesGlobalMemory(Instruction inst)
|
|
|
|
{
|
|
|
|
return (inst.IsAtomic() && IsGlobalMr(inst)) ||
|
|
|
|
inst == Instruction.LoadGlobal ||
|
2021-10-19 00:24:15 +01:00
|
|
|
inst == Instruction.StoreGlobal ||
|
|
|
|
inst == Instruction.StoreGlobal16 ||
|
|
|
|
inst == Instruction.StoreGlobal8;
|
2019-12-01 02:53:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
private static bool IsGlobalMr(Instruction inst)
|
|
|
|
{
|
|
|
|
return (inst & Instruction.MrMask) == Instruction.MrGlobal;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static int GetStorageCbOffset(ShaderStage stage, int slot)
|
|
|
|
{
|
|
|
|
return GetStorageBaseCbOffset(stage) + slot * StorageDescSize;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static int GetStorageBaseCbOffset(ShaderStage stage)
|
|
|
|
{
|
2020-02-11 00:10:05 +00:00
|
|
|
return stage switch
|
2019-12-01 02:53:09 +00:00
|
|
|
{
|
2020-02-11 00:10:05 +00:00
|
|
|
ShaderStage.Compute => StorageDescsBaseOffset + 2 * StorageDescsSize,
|
|
|
|
ShaderStage.Vertex => StorageDescsBaseOffset,
|
|
|
|
ShaderStage.TessellationControl => StorageDescsBaseOffset + 1 * StorageDescsSize,
|
|
|
|
ShaderStage.TessellationEvaluation => StorageDescsBaseOffset + 2 * StorageDescsSize,
|
|
|
|
ShaderStage.Geometry => StorageDescsBaseOffset + 3 * StorageDescsSize,
|
|
|
|
ShaderStage.Fragment => StorageDescsBaseOffset + 4 * StorageDescsSize,
|
|
|
|
_ => 0
|
|
|
|
};
|
2019-12-01 02:53:09 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|