2018-05-17 13:25:42 -05:00
|
|
|
using System;
|
|
|
|
|
2018-04-08 14:17:35 -05:00
|
|
|
using static Ryujinx.Graphics.Gal.Shader.ShaderDecodeHelper;
|
|
|
|
|
|
|
|
namespace Ryujinx.Graphics.Gal.Shader
|
|
|
|
{
|
|
|
|
static partial class ShaderDecode
|
|
|
|
{
|
2018-05-17 13:25:42 -05:00
|
|
|
public static void Bra(ShaderIrBlock Block, long OpCode)
|
|
|
|
{
|
|
|
|
if ((OpCode & 0x20) != 0)
|
|
|
|
{
|
|
|
|
//This reads the target offset from the constant buffer.
|
|
|
|
//Almost impossible to support with GLSL.
|
|
|
|
throw new NotImplementedException();
|
|
|
|
}
|
|
|
|
|
2018-05-29 18:37:10 -05:00
|
|
|
int Target = ((int)(OpCode >> 20) << 8) >> 8;
|
2018-05-17 13:25:42 -05:00
|
|
|
|
2018-05-29 18:37:10 -05:00
|
|
|
ShaderIrOperImm Imm = new ShaderIrOperImm(Target);
|
2018-05-17 13:25:42 -05:00
|
|
|
|
2018-05-29 18:37:10 -05:00
|
|
|
Block.AddNode(GetPredNode(new ShaderIrOp(ShaderIrInst.Bra, Imm), OpCode));
|
2018-05-17 13:25:42 -05:00
|
|
|
}
|
|
|
|
|
2018-04-08 14:17:35 -05:00
|
|
|
public static void Exit(ShaderIrBlock Block, long OpCode)
|
|
|
|
{
|
2018-06-27 21:55:08 -05:00
|
|
|
int CCode = (int)OpCode & 0x1f;
|
|
|
|
|
|
|
|
//TODO: Figure out what the other condition codes mean...
|
|
|
|
if (CCode == 0xf)
|
|
|
|
{
|
|
|
|
Block.AddNode(GetPredNode(new ShaderIrOp(ShaderIrInst.Exit), OpCode));
|
|
|
|
}
|
|
|
|
|
2018-04-08 14:17:35 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
public static void Kil(ShaderIrBlock Block, long OpCode)
|
|
|
|
{
|
|
|
|
Block.AddNode(GetPredNode(new ShaderIrOp(ShaderIrInst.Kil), OpCode));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|