Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
d8ac17f5
T
TDengine
项目概览
taosdata
/
TDengine
接近 2 年 前同步成功
通知
1192
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看板
提交
d8ac17f5
编写于
3月 04, 2022
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more TDB
上级
4ac1fca0
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
55 addition
and
33 deletion
+55
-33
source/libs/tdb/src/db/tdbBtree.c
source/libs/tdb/src/db/tdbBtree.c
+2
-2
source/libs/tdb/src/db/tdbPager.c
source/libs/tdb/src/db/tdbPager.c
+46
-31
source/libs/tdb/src/inc/tdbPage.h
source/libs/tdb/src/inc/tdbPage.h
+7
-0
未找到文件。
source/libs/tdb/src/db/tdbBtree.c
浏览文件 @
d8ac17f5
...
...
@@ -299,8 +299,8 @@ static int tdbBtreeOpenImpl(SBTree *pBt) {
// return -1;
// }
ASSERT
(
pgno
!=
0
);
pBt
->
root
=
pgno
;
//
ASSERT(pgno != 0);
//
pBt->root = pgno;
return
0
;
}
...
...
source/libs/tdb/src/db/tdbPager.c
浏览文件 @
d8ac17f5
...
...
@@ -41,8 +41,11 @@ typedef struct __attribute__((__packed__)) {
TDB_STATIC_ASSERT
(
sizeof
(
SFileHdr
)
==
128
,
"Size of file header is not correct"
);
#define TDB_PAGE_INITIALIZED(pPage) ((pPage)->pPager != NULL)
static
int
tdbPagerReadPage
(
SPager
*
pPager
,
SPage
*
pPage
);
static
int
tdbPagerAllocPage
(
SPager
*
pPager
,
SPgno
*
ppgno
);
static
int
tdbPagerInitPage
(
SPager
*
pPager
,
SPage
*
pPage
,
int
(
*
initPage
)(
SPage
*
,
void
*
),
void
*
arg
);
int
tdbPagerOpen
(
SPCache
*
pCache
,
const
char
*
fileName
,
SPager
**
ppPager
)
{
uint8_t
*
pPtr
;
...
...
@@ -240,30 +243,17 @@ int tdbPagerFetchPage(SPager *pPager, SPgno pgno, SPage **ppPage, int (*initPage
return
-
1
;
}
if
(
pPage
->
pPager
==
NULL
)
{
ASSERT
(
pgno
<
pPager
->
dbOrigSize
);
// tdbWLockPage(pPage);
if
(
pPage
->
pPager
==
NULL
)
{
ret
=
tdbPagerReadPage
(
pPager
,
pPage
);
if
(
ret
<
0
)
{
return
-
1
;
}
ret
=
(
*
initPage
)(
pPage
,
arg
);
if
(
ret
<
0
)
{
return
-
1
;
}
pPage
->
pPager
=
pPager
;
// Initialize the page if need
if
(
!
TDB_PAGE_INITIALIZED
(
pPage
))
{
ret
=
tdbPagerInitPage
(
pPager
,
pPage
,
initPage
,
arg
);
if
(
ret
<
0
)
{
return
-
1
;
}
// tdbWUnlockPage(pPage);
}
else
{
ASSERT
(
pPage
->
pPager
==
pPager
);
}
ASSERT
(
TDB_PAGE_INITIALIZED
(
pPage
));
ASSERT
(
pPage
->
pPager
==
pPager
);
*
ppPage
=
pPage
;
return
0
;
}
...
...
@@ -289,18 +279,16 @@ int tdbPagerNewPage(SPager *pPager, SPgno *ppgno, SPage **ppPage, int (*initPage
return
-
1
;
}
ASSERT
(
pPage
->
pPager
==
NULL
);
// TODO: a race condition problem may occur here
// tdbWLockPage(pPage);
// TODO: zero init the new page
(
*
initPage
)(
pPage
,
arg
);
ASSERT
(
!
TDB_PAGE_INITIALIZED
(
pPage
));
pPage
->
pPager
=
NULL
;
// Initialize the page if need
ret
=
tdbPagerInitPage
(
pPager
,
pPage
,
initPage
,
arg
);
if
(
ret
<
0
)
{
return
-
1
;
}
// tdbWunlockPage(pPage);
ASSERT
(
TDB_PAGE_INITIALIZED
(
pPage
));
ASSERT
(
pPage
->
pPager
==
pPager
);
*
ppPage
=
pPage
;
return
0
;
...
...
@@ -337,5 +325,32 @@ static int tdbPagerAllocPage(SPager *pPager, SPgno *ppgno) {
ASSERT
(
*
ppgno
!=
0
);
return
0
;
}
static
int
tdbPagerInitPage
(
SPager
*
pPager
,
SPage
*
pPage
,
int
(
*
initPage
)(
SPage
*
,
void
*
),
void
*
arg
)
{
int
ret
;
ret
=
TDB_TRY_LOCK_PAGE
(
pPage
);
if
(
ret
==
0
)
{
if
(
TDB_PAGE_INITIALIZED
(
pPage
))
{
TDB_UNLOCK_PAGE
(
pPage
);
return
0
;
}
ret
=
(
*
initPage
)(
pPage
,
arg
);
if
(
ret
<
0
)
{
TDB_UNLOCK_PAGE
(
pPage
);
return
-
1
;
}
pPage
->
pPager
=
pPager
;
TDB_UNLOCK_PAGE
(
pPage
);
}
else
{
while
(
!
TDB_PAGE_INITIALIZED
(
pPage
))
;
}
return
0
;
}
\ No newline at end of file
source/libs/tdb/src/inc/tdbPage.h
浏览文件 @
d8ac17f5
...
...
@@ -30,6 +30,7 @@ typedef struct __attribute__((__packed__)) {
typedef
struct
SPage
SPage
;
struct
SPage
{
pthread_spinlock_t
lock
;
// Fields below used by page cache
void
*
pData
;
SPgid
pgid
;
...
...
@@ -53,6 +54,12 @@ struct SPage {
int
minLocal
;
};
#define TDB_INIT_PAGE_LOCK(pPage) pthread_spin_init(&((pPage)->lock), 0) // TODO: use the macros
#define TDB_DESTROY_PAGE_LOCK(pPage) pthread_spin_destroy(&((pPage)->lock))
#define TDB_LOCK_PAGE(pPage) pthread_spin_lock(&((pPage)->lock))
#define TDB_TRY_LOCK_PAGE(pPage) pthread_spin_trylock(&((pPage)->lock))
#define TDB_UNLOCK_PAGE(pPage) pthread_spin_unlock(&((pPage)->lock))
#ifdef __cplusplus
}
#endif
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录