OLD | NEW |
1 //===- subzero/src/IceCfg.h - Control flow graph ----------------*- C++ -*-===// | 1 //===- subzero/src/IceCfg.h - Control flow graph ----------------*- 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 /// \file | 10 /// \file |
(...skipping 209 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
220 /// @} | 220 /// @} |
221 | 221 |
222 /// Get the total amount of memory held by the per-Cfg allocator. This is | 222 /// Get the total amount of memory held by the per-Cfg allocator. This is |
223 /// mostly meant for use inside a debugger. | 223 /// mostly meant for use inside a debugger. |
224 static size_t getTotalMemoryMB(); | 224 static size_t getTotalMemoryMB(); |
225 | 225 |
226 void emit(); | 226 void emit(); |
227 void emitIAS(); | 227 void emitIAS(); |
228 static void emitTextHeader(const IceString &Name, GlobalContext *Ctx, | 228 static void emitTextHeader(const IceString &Name, GlobalContext *Ctx, |
229 const Assembler *Asm); | 229 const Assembler *Asm); |
230 void dump(const IceString &Message = ""); | 230 void dump(const char *Message = ""); |
231 | 231 |
232 /// Allocate data of type T using the per-Cfg allocator. | 232 /// Allocate data of type T using the per-Cfg allocator. |
233 template <typename T> T *allocate() { return Allocator->Allocate<T>(); } | 233 template <typename T> T *allocate() { return Allocator->Allocate<T>(); } |
234 | 234 |
235 /// Allocate an array of data of type T using the per-Cfg allocator. | 235 /// Allocate an array of data of type T using the per-Cfg allocator. |
236 template <typename T> T *allocateArrayOf(size_t NumElems) { | 236 template <typename T> T *allocateArrayOf(size_t NumElems) { |
237 return Allocator->Allocate<T>(NumElems); | 237 return Allocator->Allocate<T>(NumElems); |
238 } | 238 } |
239 | 239 |
240 /// Deallocate data that was allocated via allocate<T>(). | 240 /// Deallocate data that was allocated via allocate<T>(). |
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
311 | 311 |
312 public: | 312 public: |
313 static void TlsInit() { CfgAllocatorTraits::init(); } | 313 static void TlsInit() { CfgAllocatorTraits::init(); } |
314 }; | 314 }; |
315 | 315 |
316 template <> Variable *Cfg::makeVariable<Variable>(Type Ty); | 316 template <> Variable *Cfg::makeVariable<Variable>(Type Ty); |
317 | 317 |
318 } // end of namespace Ice | 318 } // end of namespace Ice |
319 | 319 |
320 #endif // SUBZERO_SRC_ICECFG_H | 320 #endif // SUBZERO_SRC_ICECFG_H |
OLD | NEW |