tfs.h 2.8 KB
Newer Older
H
Hongze Cheng 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
/*
 * 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/>.
 */

#ifndef TD_TFS_H
#define TD_TFS_H

#include "tglobal.h"

#ifdef __cplusplus
extern "C" {
#endif

H
refact  
Hongze Cheng 已提交
25 26 27 28 29
typedef struct {
  int level;
  int id;
} SDiskID;

H
Hongze Cheng 已提交
30 31
#define TFS_UNDECIDED_LEVEL -1
#define TFS_UNDECIDED_ID -1
H
Hongze Cheng 已提交
32 33
#define TFS_PRIMARY_LEVEL 0
#define TFS_PRIMARY_ID 0
H
Hongze Cheng 已提交
34 35
#define TFS_MIN_LEVEL 0
#define TFS_MAX_LEVEL (TSDB_MAX_TIERS - 1)
H
Hongze Cheng 已提交
36

H
Hongze Cheng 已提交
37
// FS APIs ====================================
H
Hongze Cheng 已提交
38 39
typedef struct {
  int64_t tsize;
40
  int64_t used;
H
Hongze Cheng 已提交
41 42 43
  int64_t avail;
} SFSMeta;

44 45 46 47 48 49 50
typedef struct {
  int64_t size;
  int64_t used;
  int64_t free;
  int16_t nAvailDisks;  // # of Available disks
} STierMeta;

H
Hongze Cheng 已提交
51
int  tfsInit(SDiskCfg *pDiskCfg, int ndisk);
S
Shengliang Guan 已提交
52
void tfsCleanup();
53
void tfsUpdateInfo(SFSMeta *pFSMeta, STierMeta *tierMetas, int8_t numLevels);
H
Hongze Cheng 已提交
54 55
void tfsGetMeta(SFSMeta *pMeta);
void tfsAllocDisk(int expLevel, int *level, int *id);
H
Hongze Cheng 已提交
56

H
Hongze Cheng 已提交
57 58 59
const char *TFS_PRIMARY_PATH();
const char *TFS_DISK_PATH(int level, int id);

H
Hongze Cheng 已提交
60 61
// TFILE APIs ====================================
typedef struct {
H
Hongze Cheng 已提交
62 63 64 65
  int  level;
  int  id;
  char rname[TSDB_FILENAME_LEN];  // REL name
  char aname[TSDB_FILENAME_LEN];  // ABS name
H
Hongze Cheng 已提交
66
} TFILE;
H
Hongze Cheng 已提交
67

H
Hongze Cheng 已提交
68 69 70
#define TFILE_LEVEL(pf) ((pf)->level)
#define TFILE_ID(pf) ((pf)->id)
#define TFILE_NAME(pf) ((pf)->aname)
H
Hongze Cheng 已提交
71
#define TFILE_REL_NAME(pf) ((pf)->rname)
H
Hongze Cheng 已提交
72

H
Hongze Cheng 已提交
73 74 75 76
#define tfsopen(pf, flags) open(TFILE_NAME(pf), flags)
#define tfsclose(fd) close(fd)
#define tfsremove(pf) remove(TFILE_NAME(pf))
#define tfscopy(sf, df) taosCopy(TFILE_NAME(sf), TFILE_NAME(df))
S
Shengliang Guan 已提交
77
#define tfsrename(sf, df) taosRename(TFILE_NAME(sf), TFILE_NAME(df))
H
Hongze Cheng 已提交
78

H
Hongze Cheng 已提交
79
void  tfsInitFile(TFILE *pf, int level, int id, const char *bname);
80
bool  tfsIsSameFile(const TFILE *pf1, const TFILE *pf2);
H
Hongze Cheng 已提交
81 82 83 84
int   tfsEncodeFile(void **buf, TFILE *pf);
void *tfsDecodeFile(void *buf, TFILE *pf);
void  tfsbasename(const TFILE *pf, char *dest);
void  tfsdirname(const TFILE *pf, char *dest);
H
Hongze Cheng 已提交
85 86

// DIR APIs ====================================
H
Hongze Cheng 已提交
87
int tfsMkdirAt(const char *rname, int level, int id);
H
Hongze Cheng 已提交
88
int tfsMkdirRecurAt(const char *rname, int level, int id);
H
Hongze Cheng 已提交
89 90 91
int tfsMkdir(const char *rname);
int tfsRmdir(const char *rname);
int tfsRename(char *orname, char *nrname);
H
refact  
Hongze Cheng 已提交
92

H
Hongze Cheng 已提交
93
typedef struct TDIR TDIR;
H
refact  
Hongze Cheng 已提交
94

H
Hongze Cheng 已提交
95 96 97
TDIR *       tfsOpendir(const char *rname);
const TFILE *tfsReaddir(TDIR *tdir);
void         tfsClosedir(TDIR *tdir);
H
Hongze Cheng 已提交
98

H
Hongze Cheng 已提交
99 100 101 102
#ifdef __cplusplus
}
#endif

103
#endif