tdbPFile.c 3.8 KB
Newer Older
H
Hongze Cheng 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13
/*
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
 *
 * This program is free software: you can use, redistribute, and/or modify
 * it under the terms of the GNU Affero General Public License, version 3
 * or later ("AGPL"), as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
H
refact  
Hongze Cheng 已提交
14 15
 */

H
Hongze Cheng 已提交
16 17
#include "tdbInt.h"

H
more  
Hongze Cheng 已提交
18 19 20
struct SPFile {
  char *   dbFileName;
  char *   jFileName;
H
Hongze Cheng 已提交
21
  int      pageSize;
H
more  
Hongze Cheng 已提交
22 23 24 25 26 27
  uint8_t  fid[TDB_FILE_ID_LEN];
  int      fd;
  int      jfd;
  SPCache *pCache;
  SPgno    dbFileSize;
  SPgno    dbOrigSize;
H
more  
Hongze Cheng 已提交
28 29 30
  int      nDirty;
  SPage *  pDirty;
  SPage *  pDirtyTail;
H
more  
Hongze Cheng 已提交
31 32
};

H
refact  
Hongze Cheng 已提交
33
static int tdbPFileReadPage(SPFile *pFile, SPage *pPage);
H
Hongze Cheng 已提交
34

H
more  
Hongze Cheng 已提交
35 36 37 38 39
int tdbPFileOpen(SPCache *pCache, const char *fileName, SPFile **ppFile) {
  uint8_t *pPtr;
  SPFile * pFile;
  int      fsize;
  int      zsize;
H
Hongze Cheng 已提交
40
  int      ret;
H
more  
Hongze Cheng 已提交
41 42 43 44 45 46 47 48 49 50 51 52 53 54

  *ppFile = NULL;

  fsize = strlen(fileName);
  zsize = sizeof(*pFile)   /* SPFile */
          + fsize + 1      /* dbFileName */
          + fsize + 8 + 1; /* jFileName */
  pPtr = (uint8_t *)calloc(1, zsize);
  if (pPtr == NULL) {
    return -1;
  }

  pFile = (SPFile *)pPtr;
  pPtr += sizeof(*pFile);
H
more  
Hongze Cheng 已提交
55
  // pFile->dbFileName
H
more  
Hongze Cheng 已提交
56 57 58 59
  pFile->dbFileName = (char *)pPtr;
  memcpy(pFile->dbFileName, fileName, fsize);
  pFile->dbFileName[fsize] = '\0';
  pPtr += fsize + 1;
H
more  
Hongze Cheng 已提交
60
  // pFile->jFileName
H
more  
Hongze Cheng 已提交
61 62 63 64
  pFile->jFileName = (char *)pPtr;
  memcpy(pFile->jFileName, fileName, fsize);
  memcpy(pFile->jFileName + fsize, "-journal", 8);
  pFile->jFileName[fsize + 8] = '\0';
H
more  
Hongze Cheng 已提交
65 66
  // pFile->pCache
  pFile->pCache = pCache;
H
more  
Hongze Cheng 已提交
67 68 69 70 71 72

  pFile->fd = open(pFile->dbFileName, O_RDWR | O_CREAT, 0755);
  if (pFile->fd < 0) {
    return -1;
  }

H
Hongze Cheng 已提交
73 74 75 76 77
  ret = tdbGnrtFileID(pFile->dbFileName, pFile->fid, false);
  if (ret < 0) {
    return -1;
  }

H
more  
Hongze Cheng 已提交
78 79 80 81 82 83 84 85 86 87 88
  pFile->jfd = -1;

  *ppFile = pFile;
  return 0;
}

int tdbPFileClose(SPFile *pFile) {
  // TODO
  return 0;
}

H
refact  
Hongze Cheng 已提交
89 90 91
SPage *tdbPFileGet(SPFile *pFile, SPgno pgno) {
  SPgid  pgid;
  SPage *pPage;
H
more  
Hongze Cheng 已提交
92

H
more  
Hongze Cheng 已提交
93 94 95
  memcpy(pgid.fileid, pFile->fid, TDB_FILE_ID_LEN);
  pgid.pgno = pgno;

H
more  
Hongze Cheng 已提交
96 97 98 99 100 101
  pPage = tdbPCacheFetch(pFile->pCache, &pgid, 1);
  if (pPage == NULL) {
    // TODO
    ASSERT(0);
  }
  tdbPCacheFetchFinish(pFile->pCache, pPage);
H
more  
Hongze Cheng 已提交
102

H
more  
Hongze Cheng 已提交
103 104 105 106 107 108 109 110
  if (!(pPage->isLoad)) {
    if (pgno > pFile->dbFileSize /*TODO*/) {
      memset(pPage->pData, 0, pFile->pageSize);
    } else {
      if (tdbPFileReadPage(pFile, pPage) < 0) {
        // TODO: handle error
        return NULL;
      }
H
Hongze Cheng 已提交
111
    }
H
more  
Hongze Cheng 已提交
112 113

    pPage->isLoad = 1;
H
more  
Hongze Cheng 已提交
114
  }
H
more  
Hongze Cheng 已提交
115

H
more  
Hongze Cheng 已提交
116 117
  ASSERT(pPage->isLoad);

H
more  
Hongze Cheng 已提交
118
  return pPage;
H
more  
Hongze Cheng 已提交
119
}
H
Hongze Cheng 已提交
120

H
Hongze Cheng 已提交
121 122 123 124 125 126
int tdbPFileWrite(SPFile *pFile, SPage *pPage) {
  // TODO: if the page is not in journal, write to journal
  // mark the page as dirty
  return 0;
}

H
Hongze Cheng 已提交
127
int tdbPFileAllocPage(SPFile *pFile, SPage **ppPage, SPgno *ppgno) {
H
Hongze Cheng 已提交
128 129 130 131 132 133 134 135
  SPage *pPage;
  SPgno  pgno;

  if (1 /*TODO: no free page*/) {
    pgno = ++pFile->dbFileSize;
    pPage = tdbPFileGet(pFile, pgno);
    ASSERT(pPage != NULL);
  } else {
H
Hongze Cheng 已提交
136
    /* TODO: allocate from the free list */
H
Hongze Cheng 已提交
137 138 139 140
    ASSERT(0);
  }

  *ppPage = pPage;
H
Hongze Cheng 已提交
141
  *ppgno = pgno;
H
Hongze Cheng 已提交
142 143 144
  return 0;
}

H
more  
Hongze Cheng 已提交
145 146 147 148 149 150 151 152 153 154 155 156 157
int tdbPFileBegin(SPFile *pFile) {
  // TODO
  return 0;
}

int tdbPFileCommit(SPFile *pFile) {
  // TODO
  return 0;
}

int tdbPFileRollback(SPFile *pFile) {
  // TODO
  return 0;
H
Hongze Cheng 已提交
158 159
}

H
refact  
Hongze Cheng 已提交
160
static int tdbPFileReadPage(SPFile *pFile, SPage *pPage) {
H
Hongze Cheng 已提交
161 162 163 164 165 166 167 168 169 170 171 172
  i64 offset;
  int ret;

  ASSERT(memcmp(pFile->fid, pPage->pgid.fileid, TDB_FILE_ID_LEN) == 0);

  offset = (pPage->pgid.pgno - 1) * (i64)(pFile->pageSize);
  ret = tdbPRead(pFile->fd, pPage->pData, pFile->pageSize, offset);
  if (ret < 0) {
    // TODO: handle error
    return -1;
  }
  return 0;
H
more  
Hongze Cheng 已提交
173
}