Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
096e7054
T
TDengine
项目概览
taosdata
/
TDengine
大约 2 年 前同步成功
通知
1193
Star
22018
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
096e7054
编写于
12月 08, 2022
作者:
K
kailixu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refact: tsma/rsma process
上级
74a253ea
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
15 addition
and
8 deletion
+15
-8
source/dnode/vnode/src/sma/smaRollup.c
source/dnode/vnode/src/sma/smaRollup.c
+9
-5
source/libs/executor/src/executor.c
source/libs/executor/src/executor.c
+6
-3
未找到文件。
source/dnode/vnode/src/sma/smaRollup.c
浏览文件 @
096e7054
...
...
@@ -750,12 +750,14 @@ _err:
*/
static
int32_t
tdExecuteRSmaImplAsync
(
SSma
*
pSma
,
const
void
*
pMsg
,
int32_t
len
,
int32_t
inputType
,
SRSmaInfo
*
pInfo
,
tb_uid_t
suid
)
{
void
*
qItem
=
taosAllocateQitem
(
len
,
DEF_QITEM
);
int32_t
size
=
sizeof
(
int32_t
)
+
len
;
void
*
qItem
=
taosAllocateQitem
(
size
,
DEF_QITEM
);
if
(
!
qItem
)
{
return
TSDB_CODE_FAILED
;
}
memcpy
(
qItem
,
pMsg
,
len
);
*
(
int32_t
*
)
qItem
=
len
;
memcpy
(
POINTER_SHIFT
(
qItem
,
sizeof
(
int32_t
)),
pMsg
,
len
);
taosWriteQitem
(
pInfo
->
queue
,
qItem
);
...
...
@@ -1367,7 +1369,8 @@ _end:
static
void
tdFreeRSmaSubmitItems
(
SArray
*
pItems
)
{
for
(
int32_t
i
=
0
;
i
<
taosArrayGetSize
(
pItems
);
++
i
)
{
taosFreeQitem
(
*
(
void
**
)
taosArrayGet
(
pItems
,
i
));
SPackedData
*
packData
=
taosArrayGet
(
pItems
,
i
);
taosFreeQitem
(
POINTER_SHIFT
(
packData
->
msgStr
,
-
sizeof
(
int32_t
)));
}
taosArrayClear
(
pItems
);
}
...
...
@@ -1436,7 +1439,8 @@ static int32_t tdRSmaBatchExec(SSma *pSma, SRSmaInfo *pInfo, STaosQall *qall, SA
void
*
msg
=
NULL
;
taosGetQitem
(
qall
,
(
void
**
)
&
msg
);
if
(
msg
)
{
if
(
!
taosArrayPush
(
pSubmitArr
,
&
msg
))
{
SPackedData
packData
=
{.
msgLen
=
*
(
int32_t
*
)
msg
,
.
msgStr
=
POINTER_SHIFT
(
msg
,
sizeof
(
int32_t
))};
if
(
!
taosArrayPush
(
pSubmitArr
,
&
packData
))
{
tdFreeRSmaSubmitItems
(
pSubmitArr
);
goto
_err
;
}
...
...
@@ -1491,7 +1495,7 @@ int32_t tdRSmaProcessExecImpl(SSma *pSma, ERsmaExecType type) {
}
if
(
!
(
pSubmitArr
=
taosArrayInit
(
TMIN
(
RSMA_SUBMIT_BATCH_SIZE
,
atomic_load_64
(
&
pRSmaStat
->
nBufItems
)),
POINTER_BYTES
)))
{
taosArrayInit
(
TMIN
(
RSMA_SUBMIT_BATCH_SIZE
,
atomic_load_64
(
&
pRSmaStat
->
nBufItems
)),
sizeof
(
SPackedData
)
)))
{
terrno
=
TSDB_CODE_OUT_OF_MEMORY
;
goto
_err
;
}
...
...
source/libs/executor/src/executor.c
浏览文件 @
096e7054
...
...
@@ -51,8 +51,8 @@ static int32_t doSetSMABlock(SOperatorInfo* pOperator, void* input, size_t numOf
if
(
type
==
STREAM_INPUT__MERGED_SUBMIT
)
{
for
(
int32_t
i
=
0
;
i
<
numOfBlocks
;
i
++
)
{
S
SubmitReq
*
pReq
=
*
(
void
**
)
POINTER_SHIFT
(
input
,
i
*
sizeof
(
void
*
));
taosArrayPush
(
pInfo
->
pBlockLists
,
&
pReq
);
S
PackedData
*
pReq
=
POINTER_SHIFT
(
input
,
i
*
sizeof
(
SPackedData
));
taosArrayPush
(
pInfo
->
pBlockLists
,
pReq
);
}
pInfo
->
blockType
=
STREAM_INPUT__DATA_SUBMIT
;
}
else
if
(
type
==
STREAM_INPUT__DATA_SUBMIT
)
{
...
...
@@ -61,7 +61,10 @@ static int32_t doSetSMABlock(SOperatorInfo* pOperator, void* input, size_t numOf
}
else
if
(
type
==
STREAM_INPUT__DATA_BLOCK
)
{
for
(
int32_t
i
=
0
;
i
<
numOfBlocks
;
++
i
)
{
SSDataBlock
*
pDataBlock
=
&
((
SSDataBlock
*
)
input
)[
i
];
taosArrayPush
(
pInfo
->
pBlockLists
,
&
pDataBlock
);
SPackedData
tmp
=
{
.
pDataBlock
=
pDataBlock
,
};
taosArrayPush
(
pInfo
->
pBlockLists
,
&
tmp
);
}
pInfo
->
blockType
=
STREAM_INPUT__DATA_BLOCK
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录