/* 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 #if __GNUC__ == 4 && __GNUC_MINOR__ < 2 #include #else #include #endif #include #include #include #define EXPORT /** Namespace WriteEngine */ namespace WriteEngine { typedef std::vector FreeBufList; /** @brief Free buffer list */ // typedef std::string CacheKey; /** @brief Key definition */ typedef uint64_t CacheKey; /** @brief Key definition */ // typedef std::map > CacheMap; /** @brief Cache map */ // typedef CacheMap::iterator CacheMapIt; /** @brief CacheMap iterator */ template struct hashCacheKey { }; template <> struct hashCacheKey { size_t operator()(CacheKey __x) const { return __x; } }; struct eqCacheKey { bool operator()(const CacheKey k1, const CacheKey k2) const { return k1 == k2; } }; // typedef hash_map, eqSig> DCTNRYHASHMAP; #if __GNUC__ == 4 && __GNUC_MINOR__ < 2 typedef __gnu_cxx::hash_map, eqCacheKey> CacheMap; #else typedef std::tr1::unordered_map, eqCacheKey> CacheMap; #endif // typedef __gnu_cxx::hash_map 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() { } /** * @brief Default Destructor */ ~Cache() { } /** * @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