aboutsummaryrefslogtreecommitdiff
path: root/src/ARMeilleure/CodeGen/Arm64/ArmCondition.cs
blob: db27a810442c67eb78d5b4a48c0bd33e641ca1a2 (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
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
            {
                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,

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