aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.Graphics/Shader/Decoders/DecoderHelper.cs
blob: fd0a45e82b7ee4f7f025bd7bdf68b6164825ab80 (plain) (blame)
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
using System;

namespace Ryujinx.Graphics.Shader.Decoders
{
    static class DecoderHelper
    {
        public static int DecodeS20Immediate(long opCode)
        {
            int imm = opCode.Extract(20, 19);

            bool negate = opCode.Extract(56);

            if (negate)
            {
                imm = -imm;
            }

            return imm;
        }

        public static int Decode2xF10Immediate(long opCode)
        {
            int immH0 = opCode.Extract(20, 9);
            int immH1 = opCode.Extract(30, 9);

            bool negateH0 = opCode.Extract(29);
            bool negateH1 = opCode.Extract(56);

            if (negateH0)
            {
                immH0 |= 1 << 9;
            }

            if (negateH1)
            {
                immH1 |= 1 << 9;
            }

            return immH1 << 22 | immH0 << 6;
        }

        public static float DecodeF20Immediate(long opCode)
        {
            int imm = opCode.Extract(20, 19);

            bool negate = opCode.Extract(56);

            imm <<= 12;

            if (negate)
            {
                imm |= 1 << 31;
            }

            return BitConverter.Int32BitsToSingle(imm);
        }
    }
}