annotate lib/Target/Lanai/LanaiCondCode.h @ 120:1172e4bd9c6f

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