Main Page | Modules | Namespace List | Class Hierarchy | Alphabetical List | Class List | File List | Namespace Members | Class Members | File Members | Related Pages

ShLinearAllocator.hpp

00001 // Sh: A GPU metaprogramming language. 00002 // 00003 // Copyright (c) 2003 University of Waterloo Computer Graphics Laboratory 00004 // Project administrator: Michael D. McCool 00005 // Authors: Zheng Qin, Stefanus Du Toit, Kevin Moule, Tiberiu S. Popa, 00006 // Michael D. McCool 00007 // 00008 // This software is provided 'as-is', without any express or implied 00009 // warranty. In no event will the authors be held liable for any damages 00010 // arising from the use of this software. 00011 // 00012 // Permission is granted to anyone to use this software for any purpose, 00013 // including commercial applications, and to alter it and redistribute it 00014 // freely, subject to the following restrictions: 00015 // 00016 // 1. The origin of this software must not be misrepresented; you must 00017 // not claim that you wrote the original software. If you use this 00018 // software in a product, an acknowledgment in the product documentation 00019 // would be appreciated but is not required. 00020 // 00021 // 2. Altered source versions must be plainly marked as such, and must 00022 // not be misrepresented as being the original software. 00023 // 00024 // 3. This notice may not be removed or altered from any source 00025 // distribution. 00027 #ifndef SHLINEARALLOCATOR_HPP 00028 #define SHLINEARALLOCATOR_HPP 00029 00030 #include <map> 00031 #include "ShDllExport.hpp" 00032 #include "ShVariableNode.hpp" 00033 #include "ShBackend.hpp" 00034 00035 namespace SH { 00036 00037 struct 00038 SH_DLLEXPORT ShLifeTime { 00039 ShLifeTime() 00040 { 00041 } 00042 00043 ShLifeTime(const ShVariableNodePtr& var, int first) 00044 : var(var), first(first), last(first) 00045 { 00046 } 00047 00048 SH::ShVariableNodePtr var; 00049 int first, last; 00050 00051 void mark(int index) 00052 { 00053 if (first > index) first = index; 00054 if (last < index) last = index; 00055 } 00056 00057 bool operator<(const ShLifeTime& other) const 00058 { 00059 return first < other.first; 00060 } 00061 }; 00062 00065 class 00066 SH_DLLEXPORT ShLinearAllocator { 00067 public: 00068 ShLinearAllocator(ShBackendCodePtr backendCode); 00069 00070 // Mark that a variable is alive at a given index. 00071 void mark(const ShVariableNodePtr& var, int index); 00072 00073 // Dump the life times to stderr 00074 void debugDump(); 00075 00076 // Calls back the backend with register allocation/deallocation requests. 00077 void allocate(); 00078 00079 private: 00080 ShBackendCodePtr m_backendCode; 00081 typedef std::map<ShVariableNodePtr, ShLifeTime> LifetimeMap; 00082 LifetimeMap m_lifetimes; 00083 }; 00084 00085 }; 00086 00087 #endif

Generated on Mon Oct 18 14:17:39 2004 for Sh by doxygen 1.3.7