xref: /aosp_15_r20/external/llvm/lib/Target/Lanai/LanaiCondCode.h (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker // The encoding used for conditional codes used in BR instructions
2*9880d681SAndroid Build Coastguard Worker 
3*9880d681SAndroid Build Coastguard Worker #ifndef LLVM_LIB_TARGET_LANAI_LANAICONDCODE_H
4*9880d681SAndroid Build Coastguard Worker #define LLVM_LIB_TARGET_LANAI_LANAICONDCODE_H
5*9880d681SAndroid Build Coastguard Worker 
6*9880d681SAndroid Build Coastguard Worker #include "llvm/ADT/StringSwitch.h"
7*9880d681SAndroid Build Coastguard Worker 
8*9880d681SAndroid Build Coastguard Worker namespace llvm {
9*9880d681SAndroid Build Coastguard Worker namespace LPCC {
10*9880d681SAndroid Build Coastguard Worker enum CondCode {
11*9880d681SAndroid Build Coastguard Worker   ICC_T = 0,   //  true
12*9880d681SAndroid Build Coastguard Worker   ICC_F = 1,   //  false
13*9880d681SAndroid Build Coastguard Worker   ICC_HI = 2,  //  high
14*9880d681SAndroid Build Coastguard Worker   ICC_UGT = 2, //  unsigned greater than
15*9880d681SAndroid Build Coastguard Worker   ICC_LS = 3,  //  low or same
16*9880d681SAndroid Build Coastguard Worker   ICC_ULE = 3, //  unsigned less than or equal
17*9880d681SAndroid Build Coastguard Worker   ICC_CC = 4,  //  carry cleared
18*9880d681SAndroid Build Coastguard Worker   ICC_ULT = 4, //  unsigned less than
19*9880d681SAndroid Build Coastguard Worker   ICC_CS = 5,  //  carry set
20*9880d681SAndroid Build Coastguard Worker   ICC_UGE = 5, //  unsigned greater than or equal
21*9880d681SAndroid Build Coastguard Worker   ICC_NE = 6,  //  not equal
22*9880d681SAndroid Build Coastguard Worker   ICC_EQ = 7,  //  equal
23*9880d681SAndroid Build Coastguard Worker   ICC_VC = 8,  //  oVerflow cleared
24*9880d681SAndroid Build Coastguard Worker   ICC_VS = 9,  //  oVerflow set
25*9880d681SAndroid Build Coastguard Worker   ICC_PL = 10, //  plus
26*9880d681SAndroid Build Coastguard Worker   ICC_MI = 11, //  minus
27*9880d681SAndroid Build Coastguard Worker   ICC_GE = 12, //  greater than or equal
28*9880d681SAndroid Build Coastguard Worker   ICC_LT = 13, //  less than
29*9880d681SAndroid Build Coastguard Worker   ICC_GT = 14, //  greater than
30*9880d681SAndroid Build Coastguard Worker   ICC_LE = 15, //  less than or equal
31*9880d681SAndroid Build Coastguard Worker   UNKNOWN
32*9880d681SAndroid Build Coastguard Worker };
33*9880d681SAndroid Build Coastguard Worker 
lanaiCondCodeToString(LPCC::CondCode CC)34*9880d681SAndroid Build Coastguard Worker inline static StringRef lanaiCondCodeToString(LPCC::CondCode CC) {
35*9880d681SAndroid Build Coastguard Worker   switch (CC) {
36*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_T:
37*9880d681SAndroid Build Coastguard Worker     return "t"; // true
38*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_F:
39*9880d681SAndroid Build Coastguard Worker     return "f"; // false
40*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_NE:
41*9880d681SAndroid Build Coastguard Worker     return "ne"; // not equal
42*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_EQ:
43*9880d681SAndroid Build Coastguard Worker     return "eq"; // equal
44*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_VC:
45*9880d681SAndroid Build Coastguard Worker     return "vc"; // oVerflow cleared
46*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_VS:
47*9880d681SAndroid Build Coastguard Worker     return "vs"; // oVerflow set
48*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_PL:
49*9880d681SAndroid Build Coastguard Worker     return "pl"; // plus
50*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_MI:
51*9880d681SAndroid Build Coastguard Worker     return "mi"; // minus
52*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_GE:
53*9880d681SAndroid Build Coastguard Worker     return "ge"; // greater than or equal
54*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_LT:
55*9880d681SAndroid Build Coastguard Worker     return "lt"; // less than
56*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_GT:
57*9880d681SAndroid Build Coastguard Worker     return "gt"; // greater than
58*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_LE:
59*9880d681SAndroid Build Coastguard Worker     return "le"; // less than or equal
60*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_UGT:
61*9880d681SAndroid Build Coastguard Worker     return "ugt"; // high | unsigned greater than
62*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_ULE:
63*9880d681SAndroid Build Coastguard Worker     return "ule"; // low or same | unsigned less or equal
64*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_ULT:
65*9880d681SAndroid Build Coastguard Worker     return "ult"; // carry cleared | unsigned less than
66*9880d681SAndroid Build Coastguard Worker   case LPCC::ICC_UGE:
67*9880d681SAndroid Build Coastguard Worker     return "uge"; // carry set | unsigned than or equal
68*9880d681SAndroid Build Coastguard Worker   default:
69*9880d681SAndroid Build Coastguard Worker     llvm_unreachable("Invalid cond code");
70*9880d681SAndroid Build Coastguard Worker   }
71*9880d681SAndroid Build Coastguard Worker }
72*9880d681SAndroid Build Coastguard Worker 
suffixToLanaiCondCode(StringRef S)73*9880d681SAndroid Build Coastguard Worker inline static CondCode suffixToLanaiCondCode(StringRef S) {
74*9880d681SAndroid Build Coastguard Worker   return StringSwitch<CondCode>(S)
75*9880d681SAndroid Build Coastguard Worker       .EndsWith("f", LPCC::ICC_F)
76*9880d681SAndroid Build Coastguard Worker       .EndsWith("hi", LPCC::ICC_HI)
77*9880d681SAndroid Build Coastguard Worker       .EndsWith("ugt", LPCC::ICC_UGT)
78*9880d681SAndroid Build Coastguard Worker       .EndsWith("ls", LPCC::ICC_LS)
79*9880d681SAndroid Build Coastguard Worker       .EndsWith("ule", LPCC::ICC_ULE)
80*9880d681SAndroid Build Coastguard Worker       .EndsWith("cc", LPCC::ICC_CC)
81*9880d681SAndroid Build Coastguard Worker       .EndsWith("ult", LPCC::ICC_ULT)
82*9880d681SAndroid Build Coastguard Worker       .EndsWith("cs", LPCC::ICC_CS)
83*9880d681SAndroid Build Coastguard Worker       .EndsWith("uge", LPCC::ICC_UGE)
84*9880d681SAndroid Build Coastguard Worker       .EndsWith("ne", LPCC::ICC_NE)
85*9880d681SAndroid Build Coastguard Worker       .EndsWith("eq", LPCC::ICC_EQ)
86*9880d681SAndroid Build Coastguard Worker       .EndsWith("vc", LPCC::ICC_VC)
87*9880d681SAndroid Build Coastguard Worker       .EndsWith("vs", LPCC::ICC_VS)
88*9880d681SAndroid Build Coastguard Worker       .EndsWith("pl", LPCC::ICC_PL)
89*9880d681SAndroid Build Coastguard Worker       .EndsWith("mi", LPCC::ICC_MI)
90*9880d681SAndroid Build Coastguard Worker       .EndsWith("ge", LPCC::ICC_GE)
91*9880d681SAndroid Build Coastguard Worker       .EndsWith("lt", LPCC::ICC_LT)
92*9880d681SAndroid Build Coastguard Worker       .EndsWith("gt", LPCC::ICC_GT)
93*9880d681SAndroid Build Coastguard Worker       .EndsWith("le", LPCC::ICC_LE)
94*9880d681SAndroid Build Coastguard Worker       .EndsWith("t", LPCC::ICC_T) // Has to be after others with suffix t
95*9880d681SAndroid Build Coastguard Worker       .Default(LPCC::UNKNOWN);
96*9880d681SAndroid Build Coastguard Worker }
97*9880d681SAndroid Build Coastguard Worker } // namespace LPCC
98*9880d681SAndroid Build Coastguard Worker } // namespace llvm
99*9880d681SAndroid Build Coastguard Worker 
100*9880d681SAndroid Build Coastguard Worker #endif // LLVM_LIB_TARGET_LANAI_LANAICONDCODE_H
101