TDengine/include/util/tqueue.h

120 lines
4 KiB
C
Raw Normal View History

2020-02-25 07:26:29 +00:00
/*
* Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
*
* 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 <http://www.gnu.org/licenses/>.
*/
2022-02-28 06:16:50 +00:00
#ifndef _TD_UTIL_QUEUE_H_
#define _TD_UTIL_QUEUE_H_
2022-01-25 08:40:07 +00:00
#include "os.h"
2020-02-25 07:26:29 +00:00
#ifdef __cplusplus
extern "C" {
#endif
2020-11-10 13:00:31 +00:00
/*
This set of API for queue is designed specially for vnode/mnode. The main purpose is to
consume all the items instead of one item from a queue by one single read. Also, it can
combine multiple queues into a queue set, a consumer thread can consume a queue set via
2020-11-10 13:00:31 +00:00
a single API instead of looping every queue by itself.
Notes:
1: taosOpenQueue/taosCloseQueue, taosOpenQset/taosCloseQset is NOT multi-thread safe
2020-11-10 13:00:31 +00:00
2: after taosCloseQueue/taosCloseQset is called, read/write operation APIs are not safe.
3: read/write operation APIs are multi-thread safe
To remove the limitation and make this set of queue APIs multi-thread safe, REF(tref.c)
shall be used to set up the protection.
2020-11-10 13:00:31 +00:00
*/
typedef struct STaosQueue STaosQueue;
typedef struct STaosQset STaosQset;
typedef struct STaosQall STaosQall;
2022-03-22 08:10:26 +00:00
typedef struct {
void *ahandle;
void *fp;
void *queue;
2022-03-22 08:10:26 +00:00
int32_t workerId;
int32_t threadNum;
2022-05-28 14:13:26 +00:00
int64_t timestamp;
void *workerCb;
fix: memory leak and trigger redeploy issue (#32398) * enh: add operator reset func * fix: merge join reset issue * fix: memory issues * fix: add debug assert * fix: memory issues * fix: memory leak * fix: memory issues * fix taos log miss * fix: case issue * fix: case issue * fix: case issues * fix: drop dnode issue * fix: memory issues * fix: memory issues * fix: memory leak issues * fix: recalculate time range issue * fix: add debug log * fix: memory issues * fix: enable case asan * Update streamlist_for_ci.task * fix: case asan issue * fix: stream name issue * fix: external window compile issues * fix: deploy memory issue * fix: ahandle issue * fix: ahandle issue * fix: ahandle issue * fix: virtual table reader list issue * fix: log info * fix: msg error * fix: virtual table addr list issue * fix: memory issues * fix: memory leak issue * fix: memory issues * fix: memory free issues * fix: memory issues * fix: snode deploy issue * fix: mnode reader issue * fix: memory issues * fix: add debug test * enh: add ignore nodata trigger * fix: memory leaks * fix: configuration issue * fix: memory issue * fix: external window issue * fix: external window issues * fix: external window placeholder issue * fix: placeholder function init issues * fix: memory leak issue * fix: add debug log * fix: compile issues * fix: double free issue * fix: runner addr update issue * fix: msg rsp issue * fix: external window reset issue * fix: configuration issue * fix: deploy msg issue * fix: compile issue * fix: external window idx issue * fix: ci issues * fix: ci case issues * fix: drop dnode issue * fix: add debug log * fix: conflict * fix: create stream if not exists issue * fix: ahandle memory leak * fix: case issue * fix: exchange issues * fix: crash issue * fix: exchange prefetch issue * fix: snode quit issue * enh: support indef rows func * fix: crash issues * Fix external window collect vector function * fix: external window indef rows issues * fix: external window issue * enh: support count always return value in external window * fix: force output when has more result block * fix: runner block retrieve issue * fix: crash issue * fix: count cases issue * fix: reader deploy message issue * fix: task deploy issue * fix: external window scalar issue * fix: compile issue * fix: group cache reset issue * fix: add protection check * fix: add grant check * fix: add disableStream config * fix: notify free issue * fix: case issue * fix: grant issues * fix: memory leak issue * fix: memory leak issue * fix: memory leak issue * fix: stbJoin issue * fix: rpc send issue * fix: rsp stream group id issue * fix: redeploy stream issue * fix: cases issues * fix: memory leak issue * fix: snode quit issue * fix: invalid read issue * fix: memory leak issue * fix: split dead loop issue * fix: crash issue * fix: acquire task issue * fix: memory leak and trigger redeploy issue * fix: taosd crash issue * fix: return code issues * fix: return code issues * fix: return code issue * fix: return code issues * fix: return code issue * fix: mnode crash and dead lock issue * fix: memory and crash issues --------- Co-authored-by: huohong <sallyhuo@taosdata.com> Co-authored-by: Jing Sima <simondominic9997@outlook.com> Co-authored-by: facetosea <285808407@qq.com>
2025-08-12 00:39:14 +00:00
bool exit;
2022-03-22 08:10:26 +00:00
} SQueueInfo;
typedef enum {
DEF_QITEM = 0,
RPC_QITEM = 1,
APPLY_QITEM = 2,
} EQItype;
2022-03-22 08:10:26 +00:00
typedef void (*FItem)(SQueueInfo *pInfo, void *pItem);
typedef void (*FItems)(SQueueInfo *pInfo, STaosQall *qall, int32_t numOfItems);
2022-11-04 02:27:36 +00:00
typedef struct STaosQnode STaosQnode;
2023-04-03 10:20:35 +00:00
struct STaosQnode {
2022-11-04 02:27:36 +00:00
STaosQnode *next;
STaosQueue *queue;
int64_t timestamp;
2022-12-10 07:09:55 +00:00
int64_t dataSize;
2022-11-04 02:27:36 +00:00
int32_t size;
int8_t itype;
int8_t reserved[3];
char item[];
2023-04-03 10:20:35 +00:00
};
2022-11-04 02:27:36 +00:00
2024-07-16 09:30:32 +00:00
int32_t taosOpenQueue(STaosQueue **queue);
void taosCloseQueue(STaosQueue *queue);
void taosSetQueueFp(STaosQueue *queue, FItem itemFp, FItems itemsFp);
int32_t taosAllocateQitem(int32_t size, EQItype itype, int64_t dataSize, void **item);
void taosFreeQitem(void *pItem);
int32_t taosWriteQitem(STaosQueue *queue, void *pItem);
2024-09-12 06:17:14 +00:00
void taosReadQitem(STaosQueue *queue, void **ppItem);
2024-07-16 09:30:32 +00:00
bool taosQueueEmpty(STaosQueue *queue);
void taosUpdateItemSize(STaosQueue *queue, int32_t items);
int32_t taosQueueItemSize(STaosQueue *queue);
int64_t taosQueueMemorySize(STaosQueue *queue);
void taosSetQueueCapacity(STaosQueue *queue, int64_t size);
void taosSetQueueMemoryCapacity(STaosQueue *queue, int64_t mem);
int32_t taosAllocateQall(STaosQall **qall);
void taosFreeQall(STaosQall *qall);
int32_t taosReadAllQitems(STaosQueue *queue, STaosQall *qall);
int32_t taosGetQitem(STaosQall *qall, void **ppItem);
void taosResetQitems(STaosQall *qall);
int32_t taosQallItemSize(STaosQall *qall);
int64_t taosQallMemSize(STaosQall *qll);
int64_t taosQallUnAccessedItemSize(STaosQall *qall);
int64_t taosQallUnAccessedMemSize(STaosQall *qall);
int32_t taosOpenQset(STaosQset **qset);
void taosCloseQset(STaosQset *qset);
void taosQsetThreadResume(STaosQset *qset);
int32_t taosAddIntoQset(STaosQset *qset, STaosQueue *queue, void *ahandle);
void taosRemoveFromQset(STaosQset *qset, STaosQueue *queue);
int32_t taosGetQueueNumber(STaosQset *qset);
int32_t taosReadQitemFromQset(STaosQset *qset, void **ppItem, SQueueInfo *qinfo);
int32_t taosReadAllQitemsFromQset(STaosQset *qset, STaosQall *qall, SQueueInfo *qinfo);
2022-01-25 09:14:24 +00:00
void taosResetQsetThread(STaosQset *qset, void *pItem);
2024-02-27 08:27:59 +00:00
void taosQueueSetThreadId(STaosQueue *pQueue, int64_t threadId);
int64_t taosQueueGetThreadId(STaosQueue *pQueue);
2020-02-25 07:26:29 +00:00
#ifdef __cplusplus
}
#endif
2022-02-28 06:16:50 +00:00
#endif /*_TD_UTIL_QUEUE_H_*/