aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.Graphics.Shader/Decoders/OpCodeFArith.cs
blob: d262f1578f24de846c53ebabbfc1c43b9811a7fe (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
using Ryujinx.Graphics.Shader.Instructions;

namespace Ryujinx.Graphics.Shader.Decoders
{
    class OpCodeFArith : OpCodeAlu, IOpCodeFArith
    {
        public RoundingMode RoundingMode { get; }

        public FPMultiplyScale Scale { get; }

        public bool FlushToZero { get; }
        public bool AbsoluteA   { get; }

        public new static OpCode Create(InstEmitter emitter, ulong address, long opCode) => new OpCodeFArith(emitter, address, opCode);

        public OpCodeFArith(InstEmitter emitter, ulong address, long opCode) : base(emitter, address, opCode)
        {
            RoundingMode = (RoundingMode)opCode.Extract(39, 2);

            Scale = (FPMultiplyScale)opCode.Extract(41, 3);

            FlushToZero = opCode.Extract(44);
            AbsoluteA   = opCode.Extract(46);
        }
    }
}