OLD | NEW |
1 // Copyright (c) 1994-2006 Sun Microsystems Inc. | 1 // Copyright (c) 1994-2006 Sun Microsystems Inc. |
2 // All Rights Reserved. | 2 // All Rights Reserved. |
3 // | 3 // |
4 // Redistribution and use in source and binary forms, with or without | 4 // Redistribution and use in source and binary forms, with or without |
5 // modification, are permitted provided that the following conditions are | 5 // modification, are permitted provided that the following conditions are |
6 // met: | 6 // met: |
7 // | 7 // |
8 // - Redistributions of source code must retain the above copyright notice, | 8 // - Redistributions of source code must retain the above copyright notice, |
9 // this list of conditions and the following disclaimer. | 9 // this list of conditions and the following disclaimer. |
10 // | 10 // |
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
73 bool serializer_enabled() const { return serializer_enabled_; } | 73 bool serializer_enabled() const { return serializer_enabled_; } |
74 void enable_serializer() { serializer_enabled_ = true; } | 74 void enable_serializer() { serializer_enabled_ = true; } |
75 | 75 |
76 bool predictable_code_size() const { return predictable_code_size_; } | 76 bool predictable_code_size() const { return predictable_code_size_; } |
77 void set_predictable_code_size(bool value) { predictable_code_size_ = value; } | 77 void set_predictable_code_size(bool value) { predictable_code_size_ = value; } |
78 | 78 |
79 uint64_t enabled_cpu_features() const { return enabled_cpu_features_; } | 79 uint64_t enabled_cpu_features() const { return enabled_cpu_features_; } |
80 void set_enabled_cpu_features(uint64_t features) { | 80 void set_enabled_cpu_features(uint64_t features) { |
81 enabled_cpu_features_ = features; | 81 enabled_cpu_features_ = features; |
82 } | 82 } |
| 83 // Features are usually enabled by CpuFeatureScope, which also asserts that |
| 84 // the features are supported before they are enabled. |
83 bool IsEnabled(CpuFeature f) { | 85 bool IsEnabled(CpuFeature f) { |
84 return (enabled_cpu_features_ & (static_cast<uint64_t>(1) << f)) != 0; | 86 return (enabled_cpu_features_ & (static_cast<uint64_t>(1) << f)) != 0; |
85 } | 87 } |
| 88 void EnableCpuFeature(CpuFeature f) { |
| 89 enabled_cpu_features_ |= (static_cast<uint64_t>(1) << f); |
| 90 } |
86 | 91 |
87 bool is_constant_pool_available() const { | 92 bool is_constant_pool_available() const { |
88 if (FLAG_enable_embedded_constant_pool) { | 93 if (FLAG_enable_embedded_constant_pool) { |
89 return constant_pool_available_; | 94 return constant_pool_available_; |
90 } else { | 95 } else { |
91 // Embedded constant pool not supported on this architecture. | 96 // Embedded constant pool not supported on this architecture. |
92 UNREACHABLE(); | 97 UNREACHABLE(); |
93 return false; | 98 return false; |
94 } | 99 } |
95 } | 100 } |
(...skipping 81 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
177 AssemblerBase* assembler_; | 182 AssemblerBase* assembler_; |
178 int expected_size_; | 183 int expected_size_; |
179 int start_offset_; | 184 int start_offset_; |
180 bool old_value_; | 185 bool old_value_; |
181 }; | 186 }; |
182 | 187 |
183 | 188 |
184 // Enable a specified feature within a scope. | 189 // Enable a specified feature within a scope. |
185 class CpuFeatureScope BASE_EMBEDDED { | 190 class CpuFeatureScope BASE_EMBEDDED { |
186 public: | 191 public: |
| 192 enum CheckPolicy { |
| 193 kCheckSupported, |
| 194 kDontCheckSupported, |
| 195 }; |
| 196 |
187 #ifdef DEBUG | 197 #ifdef DEBUG |
188 CpuFeatureScope(AssemblerBase* assembler, CpuFeature f); | 198 CpuFeatureScope(AssemblerBase* assembler, CpuFeature f, |
| 199 CheckPolicy check = kCheckSupported); |
189 ~CpuFeatureScope(); | 200 ~CpuFeatureScope(); |
190 | 201 |
191 private: | 202 private: |
192 AssemblerBase* assembler_; | 203 AssemblerBase* assembler_; |
193 uint64_t old_enabled_; | 204 uint64_t old_enabled_; |
194 #else | 205 #else |
195 CpuFeatureScope(AssemblerBase* assembler, CpuFeature f) {} | 206 CpuFeatureScope(AssemblerBase* assembler, CpuFeature f, |
| 207 CheckPolicy check = kCheckSupported) {} |
196 #endif | 208 #endif |
197 }; | 209 }; |
198 | 210 |
199 | 211 |
200 // CpuFeatures keeps track of which features are supported by the target CPU. | 212 // CpuFeatures keeps track of which features are supported by the target CPU. |
201 // Supported features must be enabled by a CpuFeatureScope before use. | 213 // Supported features must be enabled by a CpuFeatureScope before use. |
202 // Example: | 214 // Example: |
203 // if (assembler->IsSupported(SSE3)) { | 215 // if (assembler->IsSupported(SSE3)) { |
204 // CpuFeatureScope fscope(assembler, SSE3); | 216 // CpuFeatureScope fscope(assembler, SSE3); |
205 // // Generate code containing SSE3 instructions. | 217 // // Generate code containing SSE3 instructions. |
(...skipping 1066 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1272 std::vector<ConstantPoolEntry> shared_entries; | 1284 std::vector<ConstantPoolEntry> shared_entries; |
1273 }; | 1285 }; |
1274 | 1286 |
1275 Label emitted_label_; // Records pc_offset of emitted pool | 1287 Label emitted_label_; // Records pc_offset of emitted pool |
1276 PerTypeEntryInfo info_[ConstantPoolEntry::NUMBER_OF_TYPES]; | 1288 PerTypeEntryInfo info_[ConstantPoolEntry::NUMBER_OF_TYPES]; |
1277 }; | 1289 }; |
1278 | 1290 |
1279 } // namespace internal | 1291 } // namespace internal |
1280 } // namespace v8 | 1292 } // namespace v8 |
1281 #endif // V8_ASSEMBLER_H_ | 1293 #endif // V8_ASSEMBLER_H_ |
OLD | NEW |