提交 69f5d9c8 编写于 作者: H Hongze Cheng

more TDB

上级 3ac540f2
......@@ -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 {
......
......@@ -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.
先完成此消息的编辑!
想要评论请 注册