Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
4a648032
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
4a648032
编写于
10月 09, 2022
作者:
M
Minglei Jin
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(tdb): subtract payload size with cell header size
上级
de3e8861
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
12 addition
and
14 deletion
+12
-14
source/libs/tdb/src/db/tdbBtree.c
source/libs/tdb/src/db/tdbBtree.c
+12
-14
未找到文件。
source/libs/tdb/src/db/tdbBtree.c
浏览文件 @
4a648032
...
...
@@ -1003,14 +1003,14 @@ static int tdbBtreeEncodePayload(SPage *pPage, SCell *pCell, int nHeader, const
int
nLeft
=
nPayload
;
int
bytes
;
int
lastPage
=
0
;
if
(
nLocal
>=
kLen
+
4
)
{
if
(
nLocal
>=
nHeader
+
kLen
+
sizeof
(
SPgno
)
)
{
// pack key to local
memcpy
(
pCell
+
nHeader
,
pKey
,
kLen
);
nLeft
-=
kLen
;
// pack partial val to local if any space left
if
(
nLocal
>
kLen
+
4
)
{
memcpy
(
pCell
+
nHeader
+
kLen
,
pVal
,
nLocal
-
kLen
-
sizeof
(
SPgno
));
nLeft
-=
nLocal
-
kLen
-
sizeof
(
SPgno
);
if
(
nLocal
>
nHeader
+
kLen
+
sizeof
(
SPgno
)
)
{
memcpy
(
pCell
+
nHeader
+
kLen
,
pVal
,
nLocal
-
nHeader
-
kLen
-
sizeof
(
SPgno
));
nLeft
-=
nLocal
-
nHeader
-
kLen
-
sizeof
(
SPgno
);
}
// pack nextPgno
...
...
@@ -1150,9 +1150,7 @@ static int tdbBtreeEncodePayload(SPage *pPage, SCell *pCell, int nHeader, const
// free local buffer
tdbFree
(
pBuf
);
*
szPayload
=
nLocal
;
// ASSERT(0);
*
szPayload
=
nLocal
-
nHeader
;
}
return
0
;
...
...
@@ -1246,10 +1244,10 @@ static int tdbBtreeDecodePayload(SPage *pPage, const SCell *pCell, int nHeader,
int
bytes
;
int
lastPage
=
0
;
if
(
nLocal
>=
pDecoder
->
kLen
+
4
)
{
if
(
nLocal
>=
pDecoder
->
kLen
+
nHeader
+
sizeof
(
SPgno
)
)
{
pDecoder
->
pKey
=
(
SCell
*
)
pCell
+
nHeader
;
nLeft
-=
kLen
;
if
(
nLocal
>
kLen
+
4
)
{
if
(
nLocal
>
kLen
+
nHeader
+
sizeof
(
SPgno
)
)
{
// read partial val to local
pDecoder
->
pVal
=
tdbRealloc
(
pDecoder
->
pVal
,
vLen
);
if
(
pDecoder
->
pVal
==
NULL
)
{
...
...
@@ -1259,9 +1257,9 @@ static int tdbBtreeDecodePayload(SPage *pPage, const SCell *pCell, int nHeader,
tdbDebug
(
"tdb btc decoder: %p/0x%x pVal: %p "
,
pDecoder
,
pDecoder
->
freeKV
,
pDecoder
->
pVal
);
memcpy
(
pDecoder
->
pVal
,
pCell
+
nHeader
+
kLen
,
nLocal
-
kLen
-
sizeof
(
SPgno
));
memcpy
(
pDecoder
->
pVal
,
pCell
+
nHeader
+
kLen
,
nLocal
-
nHeader
-
kLen
-
sizeof
(
SPgno
));
nLeft
-=
nLocal
-
kLen
-
sizeof
(
SPgno
);
nLeft
-=
nLocal
-
nHeader
-
kLen
-
sizeof
(
SPgno
);
}
memcpy
(
&
pgno
,
pCell
+
nHeader
+
nPayload
-
nLeft
,
sizeof
(
pgno
));
...
...
@@ -1474,7 +1472,7 @@ static int tdbBtreeCellSize(const SPage *pPage, SCell *pCell, int dropOfp, TXN *
int
nPayload
=
kLen
+
vLen
;
if
(
nHeader
+
nPayload
<=
pPage
->
maxLocal
)
{
return
nHeader
+
kLen
+
vLen
;
return
nHeader
+
nPayload
;
}
else
{
int
maxLocal
=
pPage
->
maxLocal
;
...
...
@@ -1486,7 +1484,7 @@ static int tdbBtreeCellSize(const SPage *pPage, SCell *pCell, int dropOfp, TXN *
// free ofp pages' cells
if
(
dropOfp
)
{
int
ret
=
0
;
SPgno
pgno
=
*
(
SPgno
*
)(
pCell
+
n
Header
+
n
Local
-
sizeof
(
SPgno
));
SPgno
pgno
=
*
(
SPgno
*
)(
pCell
+
nLocal
-
sizeof
(
SPgno
));
int
nLeft
=
nPayload
-
nLocal
+
sizeof
(
SPgno
);
SPage
*
ofp
;
int
bytes
;
...
...
@@ -1513,7 +1511,7 @@ static int tdbBtreeCellSize(const SPage *pPage, SCell *pCell, int dropOfp, TXN *
}
}
return
n
Header
+
n
Local
;
return
nLocal
;
}
}
// TDB_BTREE_CELL
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录