Main Page | Modules | Namespace List | Class Hierarchy | Alphabetical List | Class List | Directories | 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 Jan 24 18:36:33 2005 for Sh by  doxygen 1.4.1