aboutsummaryrefslogtreecommitdiff
path: root/ChocolArm64/IntermediateRepresentation/RegisterMask.cs
blob: aea6ab361766c81ea0f865fdc1afb398011875f8 (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
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
using System;

namespace ChocolArm64.IntermediateRepresentation
{
    struct RegisterMask : IEquatable<RegisterMask>
    {
        public long IntMask { get; set; }
        public long VecMask { get; set; }

        public RegisterMask(long intMask, long vecMask)
        {
            IntMask = intMask;
            VecMask = vecMask;
        }

        public static RegisterMask operator &(RegisterMask x, RegisterMask y)
        {
            return new RegisterMask(x.IntMask & y.IntMask, x.VecMask & y.VecMask);
        }

        public static RegisterMask operator |(RegisterMask x, RegisterMask y)
        {
            return new RegisterMask(x.IntMask | y.IntMask, x.VecMask | y.VecMask);
        }

        public static RegisterMask operator ~(RegisterMask x)
        {
            return new RegisterMask(~x.IntMask, ~x.VecMask);
        }

        public static bool operator ==(RegisterMask x, RegisterMask y)
        {
            return x.Equals(y);
        }

        public static bool operator !=(RegisterMask x, RegisterMask y)
        {
            return !x.Equals(y);
        }

        public override bool Equals(object obj)
        {
            return obj is RegisterMask regMask && Equals(regMask);
        }

        public bool Equals(RegisterMask other)
        {
            return IntMask == other.IntMask && VecMask == other.VecMask;
        }

        public override int GetHashCode()
        {
            return HashCode.Combine(IntMask, VecMask);
        }
    }
}