aboutsummaryrefslogtreecommitdiff
path: root/src/ARMeilleure/CodeGen/Arm64/ArmCondition.cs
blob: 5db89859188bf8273dd0fe477e5841bae99521ab (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
using ARMeilleure.IntermediateRepresentation;
using System;

namespace ARMeilleure.CodeGen.Arm64
{
    enum ArmCondition
    {
        Eq = 0,
        Ne = 1,
        GeUn = 2,
        LtUn = 3,
        Mi = 4,
        Pl = 5,
        Vs = 6,
        Vc = 7,
        GtUn = 8,
        LeUn = 9,
        Ge = 10,
        Lt = 11,
        Gt = 12,
        Le = 13,
        Al = 14,
        Nv = 15,
    }

    static class ComparisonArm64Extensions
    {
        public static ArmCondition ToArmCondition(this Comparison comp)
        {
            return comp switch
            {
#pragma warning disable IDE0055 // Disable formatting
                Comparison.Equal            => ArmCondition.Eq,
                Comparison.NotEqual         => ArmCondition.Ne,
                Comparison.Greater          => ArmCondition.Gt,
                Comparison.LessOrEqual      => ArmCondition.Le,
                Comparison.GreaterUI        => ArmCondition.GtUn,
                Comparison.LessOrEqualUI    => ArmCondition.LeUn,
                Comparison.GreaterOrEqual   => ArmCondition.Ge,
                Comparison.Less             => ArmCondition.Lt,
                Comparison.GreaterOrEqualUI => ArmCondition.GeUn,
                Comparison.LessUI           => ArmCondition.LtUn,
#pragma warning restore IDE0055

                _ => throw new ArgumentException(null, nameof(comp)),
            };
        }
    }
}