You've already forked mariadb-columnstore-engine
							
							
				mirror of
				https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
				synced 2025-10-31 18:30:33 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			211 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			211 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* Copyright (C) 2014 InfiniDB, Inc.
 | |
| 
 | |
|    This program is free software; you can redistribute it and/or
 | |
|    modify it under the terms of the GNU General Public License
 | |
|    as published by the Free Software Foundation; version 2 of
 | |
|    the License.
 | |
| 
 | |
|    This program is distributed in the hope that it will be useful,
 | |
|    but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|    GNU General Public License for more details.
 | |
| 
 | |
|    You should have received a copy of the GNU General Public License
 | |
|    along with this program; if not, write to the Free Software
 | |
|    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
 | |
|    MA 02110-1301, USA. */
 | |
| 
 | |
| /******************************************************************************************
 | |
|  * $Id: we_cache.h 33 2006-10-30 13:45:13Z wzhou $
 | |
|  *
 | |
|  ******************************************************************************************/
 | |
| /** @file */
 | |
| 
 | |
| #pragma once
 | |
| #include <iostream>
 | |
| #include <unordered_map>
 | |
| #include <map>
 | |
| 
 | |
| #include <we_obj.h>
 | |
| #include <we_convertor.h>
 | |
| 
 | |
| #define EXPORT
 | |
| /** Namespace WriteEngine */
 | |
| namespace WriteEngine
 | |
| {
 | |
| typedef std::vector<BlockBuffer*> FreeBufList; /** @brief Free buffer list */
 | |
| // typedef std::string                 CacheKey;         /** @brief Key definition */
 | |
| typedef uint64_t CacheKey; /** @brief Key definition */
 | |
| 
 | |
| // typedef std::map<CacheKey, BlockBuffer*, std::greater<CacheKey> >   CacheMap;      /** @brief Cache map */
 | |
| // typedef CacheMap::iterator          CacheMapIt;       /** @brief CacheMap iterator */
 | |
| 
 | |
| template <class T>
 | |
| struct hashCacheKey
 | |
| {
 | |
| };
 | |
| template <>
 | |
| struct hashCacheKey<CacheKey>
 | |
| {
 | |
|   size_t operator()(CacheKey __x) const
 | |
|   {
 | |
|     return __x;
 | |
|   }
 | |
| };
 | |
| 
 | |
| struct eqCacheKey
 | |
| {
 | |
|   bool operator()(const CacheKey k1, const CacheKey k2) const
 | |
|   {
 | |
|     return k1 == k2;
 | |
|   }
 | |
| };
 | |
| 
 | |
| typedef std::unordered_map<CacheKey, BlockBuffer*, hashCacheKey<CacheKey>, eqCacheKey> CacheMap;
 | |
| typedef CacheMap::iterator CacheMapIt;
 | |
| 
 | |
| // typedef CacheMap                    LRUBufList;       /** @brief Least Recent Used Buffer list */
 | |
| // typedef CacheMap                    WriteBufList;     /** @brief Write buffer list */
 | |
| 
 | |
| /** Class Cache */
 | |
| class Cache
 | |
| {
 | |
|  public:
 | |
|   /**
 | |
|    * @brief Constructor
 | |
|    */
 | |
|   Cache() = default;
 | |
| 
 | |
|   /**
 | |
|    * @brief Default Destructor
 | |
|    */
 | |
|   ~Cache() = default;
 | |
| 
 | |
|   /**
 | |
|    * @brief Check whether cache key exists
 | |
|    */
 | |
|   static bool cacheKeyExist(CacheMap* map, const OID oid, const uint64_t lbid)
 | |
|   {
 | |
|     CacheKey key = getCacheKey(oid, lbid);
 | |
|     return map->find(key) == map->end() ? false : true;
 | |
|   }
 | |
|   static bool cacheKeyExist(CacheMap* map, BlockBuffer* buffer)
 | |
|   {
 | |
|     return cacheKeyExist(map, (*buffer).cb.file.oid, (*buffer).block.lbid);
 | |
|   }
 | |
|   static bool cacheKeyExist(const OID oid, const uint64_t lbid)
 | |
|   {
 | |
|     return cacheKeyExist(m_lruList, oid, lbid) || cacheKeyExist(m_writeList, oid, lbid);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * @brief Clear the buffer
 | |
|    */
 | |
|   EXPORT static void clear();
 | |
| 
 | |
|   /**
 | |
|    * @brief Free the buffer memory
 | |
|    */
 | |
|   EXPORT static void freeMemory();
 | |
| 
 | |
|   /**
 | |
|    * @brief Flush the write cache
 | |
|    */
 | |
|   EXPORT static int flushCache();
 | |
| 
 | |
|   /**
 | |
|    * @brief Get the cache key
 | |
|    */
 | |
|   static CacheKey getCacheKey(const OID /*oid*/, const uint64_t lbid)
 | |
|   {
 | |
|     CacheKey key = lbid; /*Convertor::int2Str( oid ) + "|" + Convertor::int2Str(lbid)*/
 | |
|     ;
 | |
|     return key;
 | |
|   }
 | |
|   static CacheKey getCacheKey(const BlockBuffer* buffer)
 | |
|   {
 | |
|     return getCacheKey((*buffer).cb.file.oid, (*buffer).block.lbid);
 | |
|   }
 | |
| 
 | |
|   EXPORT static int getListSize(const CacheListType listType);
 | |
| 
 | |
|   /**
 | |
|    * @brief Init the buffers
 | |
|    */
 | |
|   EXPORT static void init(const int totalBlock, const int chkPoint, const int pctFree);
 | |
|   static void init()
 | |
|   {
 | |
|     init(DEFAULT_CACHE_BLOCK, DEFAULT_CHK_INTERVAL, DEFAULT_CACHE_PCT_FREE);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * @brief Insert into LRU list
 | |
|    */
 | |
|   EXPORT static int insertLRUList(CommBlock& cb, const uint64_t lbid, const uint64_t fbo,
 | |
|                                   const unsigned char* buf);
 | |
|   static int insertLRUList(CommBlock& cb, const uint64_t lbid, const uint64_t fbo, const DataBlock& block)
 | |
|   {
 | |
|     return insertLRUList(cb, lbid, fbo, block.data);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * @brief Insert into Write list
 | |
|    */
 | |
|   //   static const int     insertWriteList( const CacheKey& key );
 | |
| 
 | |
|   /**
 | |
|    * @brief Load cache block to a buffer
 | |
|    */
 | |
|   static int loadCacheBlock(const CacheKey& key, DataBlock& block)
 | |
|   {
 | |
|     return loadCacheBlock(key, block.data);
 | |
|   }
 | |
|   EXPORT static int loadCacheBlock(const CacheKey& key, unsigned char* buf);
 | |
| 
 | |
|   /**
 | |
|    * @brief Modify a cache block
 | |
|    */
 | |
|   static int modifyCacheBlock(const CacheKey& key, const DataBlock& block)
 | |
|   {
 | |
|     return modifyCacheBlock(key, block.data);
 | |
|   }
 | |
|   EXPORT static int modifyCacheBlock(const CacheKey& key, const unsigned char* buf);
 | |
| 
 | |
|   /**
 | |
|    * @brief Print
 | |
|    */
 | |
|   EXPORT static void printCacheMapList(const CacheMap* map);
 | |
|   EXPORT static void printCacheList();
 | |
| 
 | |
|   /**
 | |
|    * @brief Insert/Delete an element in cache map
 | |
|    */
 | |
|   EXPORT static int processCacheMap(CacheMap* map, BlockBuffer* buffer, OpType opType);
 | |
| 
 | |
|   // accessory
 | |
|   static int getTotalBlock()
 | |
|   {
 | |
|     return m_cacheParam->totalBlock;
 | |
|   }
 | |
|   static bool getUseCache()
 | |
|   {
 | |
|     return m_useCache;
 | |
|   }
 | |
|   static void setUseCache(const bool flag)
 | |
|   {
 | |
|     m_useCache = flag;
 | |
|   }
 | |
| 
 | |
|   static CacheControl* m_cacheParam;  // Cache parameters
 | |
|   static FreeBufList* m_freeList;     // free buffer list
 | |
|   static CacheMap* m_lruList;         // LRU buffer list
 | |
|   static CacheMap* m_writeList;       // Write buffer list
 | |
| 
 | |
|   EXPORT static bool m_useCache;  // Use cache flag
 | |
|  private:
 | |
| };
 | |
| 
 | |
| }  // namespace WriteEngine
 | |
| 
 | |
| #undef EXPORT
 |