/* * Copyright (c) 2019 TAOS Data, Inc. * * This program is free software: you can use, redistribute, and/or modify * it under the terms of the GNU Affero General Public License, version 3 * or later ("AGPL"), as published by the Free Software Foundation. * * 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. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ #ifndef _TD_VNODE_DEF_H_ #define _TD_VNODE_DEF_H_ #include "tmallocator.h" // #include "sync.h" #include "tcoding.h" #include "tfs.h" #include "tlist.h" #include "tlockfree.h" #include "tmacro.h" #include "tq.h" #include "wal.h" #include "vnode.h" #include "vnodeQuery.h" #ifdef __cplusplus extern "C" { #endif typedef struct SVState SVState; typedef struct SVBufPool SVBufPool; typedef struct SVnodeTask { TD_DLIST_NODE(SVnodeTask); void* arg; int (*execute)(void*); } SVnodeTask; typedef struct SVnodeMgr { td_mode_flag_t vnodeInitFlag; // For commit bool stop; uint16_t nthreads; pthread_t* threads; pthread_mutex_t mutex; pthread_cond_t hasTask; TD_DLIST(SVnodeTask) queue; // For vnode Mgmt VndPutToQueryQFp putToQueryQFp; VndSendReqFp sendReqFp; } SVnodeMgr; extern SVnodeMgr vnodeMgr; // SVState struct SVState { int64_t processed; int64_t committed; int64_t applied; }; struct SVnode { int32_t vgId; char* path; SVnodeCfg config; SVState state; SVBufPool* pBufPool; SMeta* pMeta; STsdb* pTsdb; STQ* pTq; SWal* pWal; tsem_t canCommit; SQHandle* pQuery; void* pMgmt; STfs* pTfs; }; int vnodeScheduleTask(SVnodeTask* task); int32_t vnodePutReqToVQueryQ(SVnode* pVnode, struct SRpcMsg* pReq); void vnodeSendReqToDnode(SVnode* pVnode, struct SEpSet* epSet, struct SRpcMsg* pReq); #define vFatal(...) \ do { \ if (vDebugFlag & DEBUG_FATAL) { \ taosPrintLog("VND FATAL ", DEBUG_FATAL, 255, __VA_ARGS__); \ } \ } while (0) #define vError(...) \ do { \ if (vDebugFlag & DEBUG_ERROR) { \ taosPrintLog("VND ERROR ", DEBUG_ERROR, 255, __VA_ARGS__); \ } \ } while (0) #define vWarn(...) \ do { \ if (vDebugFlag & DEBUG_WARN) { \ taosPrintLog("VND WARN ", DEBUG_WARN, 255, __VA_ARGS__); \ } \ } while (0) #define vInfo(...) \ do { \ if (vDebugFlag & DEBUG_INFO) { \ taosPrintLog("VND ", DEBUG_INFO, 255, __VA_ARGS__); \ } \ } while (0) #define vDebug(...) \ do { \ if (vDebugFlag & DEBUG_DEBUG) { \ taosPrintLog("VND ", DEBUG_DEBUG, tsdbDebugFlag, __VA_ARGS__); \ } \ } while (0) #define vTrace(...) \ do { \ if (vDebugFlag & DEBUG_TRACE) { \ taosPrintLog("VND ", DEBUG_TRACE, tsdbDebugFlag, __VA_ARGS__); \ } \ } while (0) // vnodeCfg.h extern const SVnodeCfg defaultVnodeOptions; int vnodeValidateOptions(const SVnodeCfg*); void vnodeOptionsCopy(SVnodeCfg* pDest, const SVnodeCfg* pSrc); // For commit #define vnodeShouldCommit vnodeBufPoolIsFull int vnodeSyncCommit(SVnode* pVnode); int vnodeAsyncCommit(SVnode* pVnode); // SVBufPool int vnodeOpenBufPool(SVnode* pVnode); void vnodeCloseBufPool(SVnode* pVnode); int vnodeBufPoolSwitch(SVnode* pVnode); int vnodeBufPoolRecycle(SVnode* pVnode); void* vnodeMalloc(SVnode* pVnode, uint64_t size); bool vnodeBufPoolIsFull(SVnode* pVnode); SMemAllocatorFactory* vBufPoolGetMAF(SVnode* pVnode); // SVMemAllocator typedef struct SVArenaNode { TD_SLIST_NODE(SVArenaNode); uint64_t size; // current node size void* ptr; char data[]; } SVArenaNode; typedef struct SVMemAllocator { T_REF_DECLARE() TD_DLIST_NODE(SVMemAllocator); uint64_t capacity; uint64_t ssize; uint64_t lsize; SVArenaNode* pNode; TD_SLIST(SVArenaNode) nlist; } SVMemAllocator; SVMemAllocator* vmaCreate(uint64_t capacity, uint64_t ssize, uint64_t lsize); void vmaDestroy(SVMemAllocator* pVMA); void vmaReset(SVMemAllocator* pVMA); void* vmaMalloc(SVMemAllocator* pVMA, uint64_t size); void vmaFree(SVMemAllocator* pVMA, void* ptr); bool vmaIsFull(SVMemAllocator* pVMA); #ifdef __cplusplus } #endif #endif /*_TD_VNODE_DEF_H_*/