11
11
#define LLVM_LIB_TARGET_MIPS_MCTARGETDESC_MIPSABIFLAGSSECTION_H
12
12
13
13
#include " llvm/MC/MCStreamer.h"
14
+ #include " llvm/Support/MipsABIFlags.h"
14
15
15
16
namespace llvm {
16
17
17
18
class MCStreamer ;
18
19
19
20
struct MipsABIFlagsSection {
20
- // Values for the xxx_size bytes of an ABI flags structure.
21
- enum AFL_REG {
22
- AFL_REG_NONE = 0x00 , // No registers.
23
- AFL_REG_32 = 0x01 , // 32-bit registers.
24
- AFL_REG_64 = 0x02 , // 64-bit registers.
25
- AFL_REG_128 = 0x03 // 128-bit registers.
26
- };
27
-
28
- // Masks for the ases word of an ABI flags structure.
29
- enum AFL_ASE {
30
- AFL_ASE_DSP = 0x00000001 , // DSP ASE.
31
- AFL_ASE_DSPR2 = 0x00000002 , // DSP R2 ASE.
32
- AFL_ASE_EVA = 0x00000004 , // Enhanced VA Scheme.
33
- AFL_ASE_MCU = 0x00000008 , // MCU (MicroController) ASE.
34
- AFL_ASE_MDMX = 0x00000010 , // MDMX ASE.
35
- AFL_ASE_MIPS3D = 0x00000020 , // MIPS-3D ASE.
36
- AFL_ASE_MT = 0x00000040 , // MT ASE.
37
- AFL_ASE_SMARTMIPS = 0x00000080 , // SmartMIPS ASE.
38
- AFL_ASE_VIRT = 0x00000100 , // VZ ASE.
39
- AFL_ASE_MSA = 0x00000200 , // MSA ASE.
40
- AFL_ASE_MIPS16 = 0x00000400 , // MIPS16 ASE.
41
- AFL_ASE_MICROMIPS = 0x00000800 , // MICROMIPS ASE.
42
- AFL_ASE_XPA = 0x00001000 // XPA ASE.
43
- };
44
-
45
- // Values for the isa_ext word of an ABI flags structure.
46
- enum AFL_EXT {
47
- AFL_EXT_XLR = 1 , // RMI Xlr instruction.
48
- AFL_EXT_OCTEON2 = 2 , // Cavium Networks Octeon2.
49
- AFL_EXT_OCTEONP = 3 , // Cavium Networks OcteonP.
50
- AFL_EXT_LOONGSON_3A = 4 , // Loongson 3A.
51
- AFL_EXT_OCTEON = 5 , // Cavium Networks Octeon.
52
- AFL_EXT_5900 = 6 , // MIPS R5900 instruction.
53
- AFL_EXT_4650 = 7 , // MIPS R4650 instruction.
54
- AFL_EXT_4010 = 8 , // LSI R4010 instruction.
55
- AFL_EXT_4100 = 9 , // NEC VR4100 instruction.
56
- AFL_EXT_3900 = 10 , // Toshiba R3900 instruction.
57
- AFL_EXT_10000 = 11 , // MIPS R10000 instruction.
58
- AFL_EXT_SB1 = 12 , // Broadcom SB-1 instruction.
59
- AFL_EXT_4111 = 13 , // NEC VR4111/VR4181 instruction.
60
- AFL_EXT_4120 = 14 , // NEC VR4120 instruction.
61
- AFL_EXT_5400 = 15 , // NEC VR5400 instruction.
62
- AFL_EXT_5500 = 16 , // NEC VR5500 instruction.
63
- AFL_EXT_LOONGSON_2E = 17 , // ST Microelectronics Loongson 2E.
64
- AFL_EXT_LOONGSON_2F = 18 // ST Microelectronics Loongson 2F.
65
- };
66
-
67
- // Values for the fp_abi word of an ABI flags structure.
68
- enum Val_GNU_MIPS_ABI {
69
- Val_GNU_MIPS_ABI_FP_ANY = 0 ,
70
- Val_GNU_MIPS_ABI_FP_DOUBLE = 1 ,
71
- Val_GNU_MIPS_ABI_FP_SOFT = 3 ,
72
- Val_GNU_MIPS_ABI_FP_XX = 5 ,
73
- Val_GNU_MIPS_ABI_FP_64 = 6 ,
74
- Val_GNU_MIPS_ABI_FP_64A = 7
75
- };
76
-
77
- enum AFL_FLAGS1 {
78
- AFL_FLAGS1_ODDSPREG = 1
79
- };
80
-
81
21
// Internal representation of the fp_abi related values used in .module.
82
22
enum class FpABIKind { ANY, XX, S32, S64, SOFT };
83
23
@@ -88,11 +28,11 @@ struct MipsABIFlagsSection {
88
28
// The revision of ISA: 0 for MIPS V and below, 1-n otherwise.
89
29
uint8_t ISARevision;
90
30
// The size of general purpose registers.
91
- AFL_REG GPRSize;
31
+ Mips:: AFL_REG GPRSize;
92
32
// The size of co-processor 1 registers.
93
- AFL_REG CPR1Size;
33
+ Mips:: AFL_REG CPR1Size;
94
34
// The size of co-processor 2 registers.
95
- AFL_REG CPR2Size;
35
+ Mips:: AFL_REG CPR2Size;
96
36
// Processor-specific extension.
97
37
uint32_t ISAExtensionSet;
98
38
// Mask of ASEs used.
@@ -108,9 +48,10 @@ struct MipsABIFlagsSection {
108
48
109
49
public:
110
50
MipsABIFlagsSection ()
111
- : Version(0 ), ISALevel(0 ), ISARevision(0 ), GPRSize(AFL_REG_NONE),
112
- CPR1Size (AFL_REG_NONE), CPR2Size(AFL_REG_NONE), ISAExtensionSet(0 ),
113
- ASESet(0 ), OddSPReg(false ), Is32BitABI(false ), FpABI(FpABIKind::ANY) {}
51
+ : Version(0 ), ISALevel(0 ), ISARevision(0 ), GPRSize(Mips::AFL_REG_NONE),
52
+ CPR1Size (Mips::AFL_REG_NONE), CPR2Size(Mips::AFL_REG_NONE),
53
+ ISAExtensionSet(0 ), ASESet(0 ), OddSPReg(false ), Is32BitABI(false ),
54
+ FpABI(FpABIKind::ANY) {}
114
55
115
56
uint16_t getVersionValue () { return (uint16_t )Version; }
116
57
uint8_t getISALevelValue () { return (uint8_t )ISALevel; }
@@ -126,7 +67,7 @@ struct MipsABIFlagsSection {
126
67
uint32_t Value = 0 ;
127
68
128
69
if (OddSPReg)
129
- Value |= (uint32_t )AFL_FLAGS1_ODDSPREG;
70
+ Value |= (uint32_t )Mips:: AFL_FLAGS1_ODDSPREG;
130
71
131
72
return Value;
132
73
}
@@ -185,32 +126,32 @@ struct MipsABIFlagsSection {
185
126
186
127
template <class PredicateLibrary >
187
128
void setGPRSizeFromPredicates (const PredicateLibrary &P) {
188
- GPRSize = P.isGP64bit () ? AFL_REG_64 : AFL_REG_32;
129
+ GPRSize = P.isGP64bit () ? Mips:: AFL_REG_64 : Mips:: AFL_REG_32;
189
130
}
190
131
191
132
template <class PredicateLibrary >
192
133
void setCPR1SizeFromPredicates (const PredicateLibrary &P) {
193
134
if (P.abiUsesSoftFloat ())
194
- CPR1Size = AFL_REG_NONE;
135
+ CPR1Size = Mips:: AFL_REG_NONE;
195
136
else if (P.hasMSA ())
196
- CPR1Size = AFL_REG_128;
137
+ CPR1Size = Mips:: AFL_REG_128;
197
138
else
198
- CPR1Size = P.isFP64bit () ? AFL_REG_64 : AFL_REG_32;
139
+ CPR1Size = P.isFP64bit () ? Mips:: AFL_REG_64 : Mips:: AFL_REG_32;
199
140
}
200
141
201
142
template <class PredicateLibrary >
202
143
void setASESetFromPredicates (const PredicateLibrary &P) {
203
144
ASESet = 0 ;
204
145
if (P.hasDSP ())
205
- ASESet |= AFL_ASE_DSP;
146
+ ASESet |= Mips:: AFL_ASE_DSP;
206
147
if (P.hasDSPR2 ())
207
- ASESet |= AFL_ASE_DSPR2;
148
+ ASESet |= Mips:: AFL_ASE_DSPR2;
208
149
if (P.hasMSA ())
209
- ASESet |= AFL_ASE_MSA;
150
+ ASESet |= Mips:: AFL_ASE_MSA;
210
151
if (P.inMicroMipsMode ())
211
- ASESet |= AFL_ASE_MICROMIPS;
152
+ ASESet |= Mips:: AFL_ASE_MICROMIPS;
212
153
if (P.inMips16Mode ())
213
- ASESet |= AFL_ASE_MIPS16;
154
+ ASESet |= Mips:: AFL_ASE_MIPS16;
214
155
}
215
156
216
157
template <class PredicateLibrary >
0 commit comments