OLD | NEW |
1 //===- subzero/src/IceClFlags.h - Cl Flags for translation ------*- C++ -*-===// | 1 //===- subzero/src/IceClFlags.h - Cl Flags for translation ------*- C++ -*-===// |
2 // | 2 // |
3 // The Subzero Code Generator | 3 // The Subzero Code Generator |
4 // | 4 // |
5 // This file is distributed under the University of Illinois Open Source | 5 // This file is distributed under the University of Illinois Open Source |
6 // License. See LICENSE.TXT for details. | 6 // License. See LICENSE.TXT for details. |
7 // | 7 // |
8 //===----------------------------------------------------------------------===// | 8 //===----------------------------------------------------------------------===// |
9 // | 9 // |
10 // This file declares command line flags controlling translation. | 10 // This file declares command line flags controlling translation. |
11 // | 11 // |
12 //===----------------------------------------------------------------------===// | 12 //===----------------------------------------------------------------------===// |
13 | 13 |
14 #ifndef SUBZERO_SRC_ICECLFLAGS_H | 14 #ifndef SUBZERO_SRC_ICECLFLAGS_H |
15 #define SUBZERO_SRC_ICECLFLAGS_H | 15 #define SUBZERO_SRC_ICECLFLAGS_H |
16 | 16 |
17 #include "IceTypes.def" | 17 #include "IceTypes.h" |
18 | 18 |
19 namespace Ice { | 19 namespace Ice { |
20 | 20 |
21 class ClFlags { | 21 class ClFlags { |
22 ClFlags(const ClFlags &) = delete; | 22 ClFlags(const ClFlags &) = delete; |
23 ClFlags &operator=(const ClFlags &) = delete; | 23 ClFlags &operator=(const ClFlags &) = delete; |
24 | 24 |
25 public: | 25 public: |
26 ClFlags() | 26 ClFlags() |
27 : // bool fields. | 27 : // bool fields. |
28 AllowErrorRecovery(false), | 28 AllowErrorRecovery(false), |
29 AllowUninitializedGlobals(false), DataSections(false), | 29 AllowUninitializedGlobals(false), DataSections(false), |
30 DecorateAsm(false), DisableInternal(false), DisableIRGeneration(false), | 30 DecorateAsm(false), DisableInternal(false), DisableIRGeneration(false), |
31 DisableTranslation(false), DumpStats(false), FunctionSections(false), | 31 DisableTranslation(false), DumpStats(false), FunctionSections(false), |
32 GenerateUnitTestMessages(false), PhiEdgeSplit(false), | 32 GenerateUnitTestMessages(false), PhiEdgeSplit(false), |
| 33 RandNopInsertion(false), RandRegAlloc(false), |
33 SubzeroTimingEnabled(false), TimeEachFunction(false), | 34 SubzeroTimingEnabled(false), TimeEachFunction(false), |
34 UseSandboxing(false), | 35 UseSandboxing(false), |
35 // FileType field | 36 // Enum and integer fields |
36 OutFileType(FT_Iasm), | 37 Opt(Opt_m1), OutFileType(FT_Iasm), RandMaxNopsPerInstruction(0), |
| 38 RandNopProbabilityAsPercentage(0), TArch(TargetArch_NUM), |
| 39 VMask(IceV_None), |
37 // IceString fields. | 40 // IceString fields. |
38 DefaultFunctionPrefix(""), DefaultGlobalPrefix(""), TimingFocusOn(""), | 41 DefaultFunctionPrefix(""), DefaultGlobalPrefix(""), TestPrefix(""), |
39 TranslateOnly(""), VerboseFocusOn(""), | 42 TimingFocusOn(""), TranslateOnly(""), VerboseFocusOn(""), |
40 // size_t fields. | 43 // size_t and 64-bit fields. |
41 NumTranslationThreads(0) {} | 44 NumTranslationThreads(0), RandomSeed(0) {} |
42 | 45 |
43 // bool accessors. | 46 // bool accessors. |
44 | 47 |
45 bool getAllowErrorRecovery() const { return AllowErrorRecovery; } | 48 bool getAllowErrorRecovery() const { return AllowErrorRecovery; } |
46 void setAllowErrorRecovery(bool NewValue) { AllowErrorRecovery = NewValue; } | 49 void setAllowErrorRecovery(bool NewValue) { AllowErrorRecovery = NewValue; } |
47 | 50 |
48 bool getAllowUninitializedGlobals() const { | 51 bool getAllowUninitializedGlobals() const { |
49 return AllowUninitializedGlobals; | 52 return AllowUninitializedGlobals; |
50 } | 53 } |
51 void setAllowUninitializedGlobals(bool NewValue) { | 54 void setAllowUninitializedGlobals(bool NewValue) { |
(...skipping 28 matching lines...) Expand all Loading... |
80 // will not be readable. Hence, turn off. | 83 // will not be readable. Hence, turn off. |
81 return !ALLOW_DUMP || GenerateUnitTestMessages; | 84 return !ALLOW_DUMP || GenerateUnitTestMessages; |
82 } | 85 } |
83 void setGenerateUnitTestMessages(bool NewValue) { | 86 void setGenerateUnitTestMessages(bool NewValue) { |
84 GenerateUnitTestMessages = NewValue; | 87 GenerateUnitTestMessages = NewValue; |
85 } | 88 } |
86 | 89 |
87 bool getPhiEdgeSplit() const { return PhiEdgeSplit; } | 90 bool getPhiEdgeSplit() const { return PhiEdgeSplit; } |
88 void setPhiEdgeSplit(bool NewValue) { PhiEdgeSplit = NewValue; } | 91 void setPhiEdgeSplit(bool NewValue) { PhiEdgeSplit = NewValue; } |
89 | 92 |
| 93 bool shouldDoNopInsertion() const { return RandNopInsertion; } |
| 94 void setShouldDoNopInsertion(bool NewValue) { RandNopInsertion = NewValue; } |
| 95 |
| 96 bool shouldRandomizeRegAlloc() const { return RandRegAlloc; } |
| 97 void setShouldRandomizeRegAlloc(bool NewValue) { RandRegAlloc = NewValue; } |
| 98 |
90 bool getSubzeroTimingEnabled() const { return SubzeroTimingEnabled; } | 99 bool getSubzeroTimingEnabled() const { return SubzeroTimingEnabled; } |
91 void setSubzeroTimingEnabled(bool NewValue) { | 100 void setSubzeroTimingEnabled(bool NewValue) { |
92 SubzeroTimingEnabled = NewValue; | 101 SubzeroTimingEnabled = NewValue; |
93 } | 102 } |
94 | 103 |
95 bool getTimeEachFunction() const { return ALLOW_DUMP && TimeEachFunction; } | 104 bool getTimeEachFunction() const { return ALLOW_DUMP && TimeEachFunction; } |
96 void setTimeEachFunction(bool NewValue) { TimeEachFunction = NewValue; } | 105 void setTimeEachFunction(bool NewValue) { TimeEachFunction = NewValue; } |
97 | 106 |
98 bool getUseSandboxing() const { return UseSandboxing; } | 107 bool getUseSandboxing() const { return UseSandboxing; } |
99 void setUseSandboxing(bool NewValue) { UseSandboxing = NewValue; } | 108 void setUseSandboxing(bool NewValue) { UseSandboxing = NewValue; } |
100 | 109 |
101 // FileType accessor. | 110 // Enum and integer accessors. |
| 111 OptLevel getOptLevel() const { return Opt; } |
| 112 void setOptLevel(OptLevel NewValue) { Opt = NewValue; } |
| 113 |
102 FileType getOutFileType() const { return OutFileType; } | 114 FileType getOutFileType() const { return OutFileType; } |
103 void setOutFileType(FileType NewValue) { OutFileType = NewValue; } | 115 void setOutFileType(FileType NewValue) { OutFileType = NewValue; } |
104 | 116 |
| 117 int getMaxNopsPerInstruction() const { return RandMaxNopsPerInstruction; } |
| 118 void setMaxNopsPerInstruction(int NewValue) { |
| 119 RandMaxNopsPerInstruction = NewValue; |
| 120 } |
| 121 |
| 122 int getNopProbabilityAsPercentage() const { |
| 123 return RandNopProbabilityAsPercentage; |
| 124 } |
| 125 void setNopProbabilityAsPercentage(int NewValue) { |
| 126 RandNopProbabilityAsPercentage = NewValue; |
| 127 } |
| 128 |
| 129 TargetArch getTargetArch() const { return TArch; } |
| 130 void setTargetArch(TargetArch NewValue) { TArch = NewValue; } |
| 131 |
| 132 TargetInstructionSet getTargetInstructionSet() const { return TInstrSet; } |
| 133 void setTargetInstructionSet(TargetInstructionSet NewValue) { |
| 134 TInstrSet = NewValue; |
| 135 } |
| 136 |
| 137 VerboseMask getVerbose() const { return ALLOW_DUMP ? VMask : IceV_None; } |
| 138 void setVerbose(VerboseMask NewValue) { VMask = NewValue; } |
| 139 |
105 // IceString accessors. | 140 // IceString accessors. |
106 | 141 |
107 const IceString &getDefaultFunctionPrefix() const { | 142 const IceString &getDefaultFunctionPrefix() const { |
108 return DefaultFunctionPrefix; | 143 return DefaultFunctionPrefix; |
109 } | 144 } |
110 void setDefaultFunctionPrefix(const IceString &NewValue) { | 145 void setDefaultFunctionPrefix(const IceString &NewValue) { |
111 DefaultFunctionPrefix = NewValue; | 146 DefaultFunctionPrefix = NewValue; |
112 } | 147 } |
113 | 148 |
114 const IceString &getDefaultGlobalPrefix() const { | 149 const IceString &getDefaultGlobalPrefix() const { |
115 return DefaultGlobalPrefix; | 150 return DefaultGlobalPrefix; |
116 } | 151 } |
117 void setDefaultGlobalPrefix(const IceString &NewValue) { | 152 void setDefaultGlobalPrefix(const IceString &NewValue) { |
118 DefaultGlobalPrefix = NewValue; | 153 DefaultGlobalPrefix = NewValue; |
119 } | 154 } |
120 | 155 |
| 156 const IceString &getTestPrefix() const { return TestPrefix; } |
| 157 void setTestPrefix(const IceString &NewValue) { TestPrefix = NewValue; } |
| 158 |
121 const IceString &getTimingFocusOn() const { return TimingFocusOn; } | 159 const IceString &getTimingFocusOn() const { return TimingFocusOn; } |
122 void setTimingFocusOn(const IceString &NewValue) { TimingFocusOn = NewValue; } | 160 void setTimingFocusOn(const IceString &NewValue) { TimingFocusOn = NewValue; } |
123 | 161 |
124 const IceString &getTranslateOnly() const { return TranslateOnly; } | 162 const IceString &getTranslateOnly() const { return TranslateOnly; } |
125 void setTranslateOnly(const IceString &NewValue) { TranslateOnly = NewValue; } | 163 void setTranslateOnly(const IceString &NewValue) { TranslateOnly = NewValue; } |
126 | 164 |
127 const IceString &getVerboseFocusOn() const { return VerboseFocusOn; } | 165 const IceString &getVerboseFocusOn() const { return VerboseFocusOn; } |
128 void setVerboseFocusOn(const IceString &NewValue) { | 166 void setVerboseFocusOn(const IceString &NewValue) { |
129 VerboseFocusOn = NewValue; | 167 VerboseFocusOn = NewValue; |
130 } | 168 } |
131 | 169 |
132 // size_t accessors. | 170 // size_t and 64-bit accessors. |
133 | 171 |
134 size_t getNumTranslationThreads() const { return NumTranslationThreads; } | 172 size_t getNumTranslationThreads() const { return NumTranslationThreads; } |
135 bool isSequential() const { return NumTranslationThreads == 0; } | 173 bool isSequential() const { return NumTranslationThreads == 0; } |
136 void setNumTranslationThreads(size_t NewValue) { | 174 void setNumTranslationThreads(size_t NewValue) { |
137 NumTranslationThreads = NewValue; | 175 NumTranslationThreads = NewValue; |
138 } | 176 } |
139 | 177 |
| 178 uint64_t getRandomSeed() const { return RandomSeed; } |
| 179 void setRandomSeed(size_t NewValue) { RandomSeed = NewValue; } |
| 180 |
140 private: | 181 private: |
141 bool AllowErrorRecovery; | 182 bool AllowErrorRecovery; |
142 bool AllowUninitializedGlobals; | 183 bool AllowUninitializedGlobals; |
143 bool DataSections; | 184 bool DataSections; |
144 bool DecorateAsm; | 185 bool DecorateAsm; |
145 bool DisableInternal; | 186 bool DisableInternal; |
146 bool DisableIRGeneration; | 187 bool DisableIRGeneration; |
147 bool DisableTranslation; | 188 bool DisableTranslation; |
148 bool DumpStats; | 189 bool DumpStats; |
149 bool FunctionSections; | 190 bool FunctionSections; |
150 bool GenerateUnitTestMessages; | 191 bool GenerateUnitTestMessages; |
151 bool PhiEdgeSplit; | 192 bool PhiEdgeSplit; |
| 193 bool RandNopInsertion; |
| 194 bool RandRegAlloc; |
152 bool SubzeroTimingEnabled; | 195 bool SubzeroTimingEnabled; |
153 bool TimeEachFunction; | 196 bool TimeEachFunction; |
154 bool UseSandboxing; | 197 bool UseSandboxing; |
155 | 198 |
| 199 OptLevel Opt; |
156 FileType OutFileType; | 200 FileType OutFileType; |
| 201 int RandMaxNopsPerInstruction; |
| 202 int RandNopProbabilityAsPercentage; |
| 203 TargetArch TArch; |
| 204 TargetInstructionSet TInstrSet; |
| 205 VerboseMask VMask; |
157 | 206 |
158 IceString DefaultFunctionPrefix; | 207 IceString DefaultFunctionPrefix; |
159 IceString DefaultGlobalPrefix; | 208 IceString DefaultGlobalPrefix; |
| 209 IceString TestPrefix; |
160 IceString TimingFocusOn; | 210 IceString TimingFocusOn; |
161 IceString TranslateOnly; | 211 IceString TranslateOnly; |
162 IceString VerboseFocusOn; | 212 IceString VerboseFocusOn; |
163 | 213 |
164 size_t NumTranslationThreads; // 0 means completely sequential | 214 size_t NumTranslationThreads; // 0 means completely sequential |
| 215 uint64_t RandomSeed; |
165 }; | 216 }; |
166 | 217 |
167 } // end of namespace Ice | 218 } // end of namespace Ice |
168 | 219 |
169 #endif // SUBZERO_SRC_ICECLFLAGS_H | 220 #endif // SUBZERO_SRC_ICECLFLAGS_H |
OLD | NEW |