Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
69f5d9c8
TDengine
项目概览
taosdata
/
TDengine
接近 2 年 前同步成功
通知
1191
Star
22018
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看板
提交
69f5d9c8
编写于
3月 11, 2022
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more TDB
上级
3ac540f2
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
12 addition
and
7 deletion
+12
-7
source/libs/tdb/src/db/tdbPage.c
source/libs/tdb/src/db/tdbPage.c
+11
-6
source/libs/tdb/src/inc/tdbPage.h
source/libs/tdb/src/inc/tdbPage.h
+1
-1
未找到文件。
source/libs/tdb/src/db/tdbPage.c
浏览文件 @
69f5d9c8
...
...
@@ -22,6 +22,8 @@ int tdbPageCreate(int pageSize, SPage **ppPage, void *(*xMalloc)(void *, size_t)
u8
*
ptr
;
int
size
;
ASSERT
(
TDB_IS_PGSIZE_VLD
(
pageSize
));
*
ppPage
=
NULL
;
size
=
pageSize
+
sizeof
(
*
pPage
);
...
...
@@ -35,6 +37,11 @@ int tdbPageCreate(int pageSize, SPage **ppPage, void *(*xMalloc)(void *, size_t)
pPage
->
pData
=
ptr
;
pPage
->
pageSize
=
pageSize
;
if
(
pageSize
<
65536
)
{
pPage
->
szOffset
=
2
;
}
else
{
pPage
->
szOffset
=
3
;
}
TDB_INIT_PAGE_LOCK
(
pPage
);
/* TODO */
...
...
@@ -56,7 +63,7 @@ int tdbPageInsertCell(SPage *pPage, int idx, SCell *pCell, int szCell) {
int
ret
;
SCell
*
pTarget
;
if
(
pPage
->
nOverflow
||
szCell
+
TDB_PAGE_CELL_OFFSET_SIZE
(
pPage
)
>
pPage
->
nFree
)
{
if
(
pPage
->
nOverflow
||
szCell
+
pPage
->
szOffset
>
pPage
->
nFree
)
{
// TODO
}
else
{
ret
=
tdbPageAllocate
(
pPage
,
szCell
,
&
pTarget
);
...
...
@@ -75,14 +82,12 @@ int tdbPageDropCell(SPage *pPage, int idx) {
static
int
tdbPageAllocate
(
SPage
*
pPage
,
int
size
,
SCell
**
ppCell
)
{
SCell
*
pCell
;
int
szOffset
;
szOffset
=
TDB_PAGE_CELL_OFFSET_SIZE
(
pPage
);
ASSERT
(
pPage
->
nFree
>
size
+
szOffset
);
ASSERT
(
pPage
->
nFree
>
size
+
pPage
->
szOffset
);
if
(
pPage
->
pFreeEnd
-
pPage
->
pFreeStart
>
size
+
szOffset
)
{
if
(
pPage
->
pFreeEnd
-
pPage
->
pFreeStart
>
size
+
pPage
->
szOffset
)
{
pPage
->
pFreeEnd
-=
size
;
pPage
->
pFreeStart
+=
szOffset
;
pPage
->
pFreeStart
+=
pPage
->
szOffset
;
pCell
=
pPage
->
pFreeEnd
;
}
else
{
...
...
source/libs/tdb/src/inc/tdbPage.h
浏览文件 @
69f5d9c8
...
...
@@ -39,6 +39,7 @@ struct SPage {
pthread_spinlock_t
lock
;
u8
*
pData
;
int
pageSize
;
u8
szOffset
;
// Fields below used by pager and am
SPgid
pgid
;
SPageHdr
*
pPageHdr
;
...
...
@@ -59,7 +60,6 @@ struct SPage {
};
// Macros
#define TDB_PAGE_CELL_OFFSET_SIZE(pPage) (((pPage)->pageSize < 65536) ? 2 : 3)
#define TDB_PAGE_CELL_OFFSET_AT(pPage, idx) ((pPage)->aCellIdx[idx])
#define TDB_PAGE_CELL_AT(pPage, idx) ((pPage)->pData + TDB_PAGE_CELL_OFFSET_AT(pPage, idx))
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录