/usr/include/nilfs.h is in nilfs-tools 2.1.0-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 | /*
* nilfs.h - NILFS header file.
*
* Copyright (C) 2007-2010 Nippon Telegraph and Telephone Corporation.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published
* by the Free Software Foundation; either version 2.1 of the License, or
* (at your option) any later version.
*
* 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. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*
* Written by Koji Sato <koji@osrg.net>.
*
* Maintained by Ryusuke Konishi <ryusuke@osrg.net> from 2008.
*/
#ifndef NILFS_H
#define NILFS_H
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <fcntl.h>
#include <time.h>
#include <sys/ioctl.h>
#include <semaphore.h>
#include <linux/types.h>
#include <endian.h>
#include <byteswap.h>
/* FIX ME */
#ifndef __bitwise
typedef __u16 __le16;
typedef __u32 __le32;
typedef __u64 __le64;
typedef __u16 __be16;
typedef __u32 __be32;
typedef __u64 __be64;
#endif
#if __BYTE_ORDER == __LITTLE_ENDIAN
#define le16_to_cpu(x) ((__u16)(x))
#define le32_to_cpu(x) ((__u32)(x))
#define le64_to_cpu(x) ((__u64)(x))
#define cpu_to_le16(x) ((__u16)(x))
#define cpu_to_le32(x) ((__u32)(x))
#define cpu_to_le64(x) ((__u64)(x))
#define be16_to_cpu(x) bswap_16(x)
#define be32_to_cpu(x) bswap_32(x)
#define be64_to_cpu(x) bswap_64(x)
#define cpu_to_be16(x) bswap_16(x)
#define cpu_to_be32(x) bswap_32(x)
#define cpu_to_be64(x) bswap_64(x)
#elif __BYTE_ORDER == __BIG_ENDIAN
#define le16_to_cpu(x) bswap_16(x)
#define le32_to_cpu(x) bswap_32(x)
#define le64_to_cpu(x) bswap_64(x)
#define cpu_to_le16(x) bswap_16(x)
#define cpu_to_le32(x) bswap_32(x)
#define cpu_to_le64(x) bswap_64(x)
#define be16_to_cpu(x) ((__u16)(x))
#define be32_to_cpu(x) ((__u32)(x))
#define be64_to_cpu(x) ((__u64)(x))
#define cpu_to_be16(x) ((__u16)(x))
#define cpu_to_be32(x) ((__u32)(x))
#define cpu_to_be64(x) ((__u64)(x))
#else
#error "unknown endian"
#endif /* __BYTE_ORDER */
#ifndef BUG
#define BUG() abort()
#endif
#include "nilfs2_fs.h"
/* XXX: sector_t is not defined in user land */
typedef __u64 sector_t; // XXX: __u64 ??
typedef sector_t nilfs_blkoff_t;
typedef __u64 nilfs_cno_t;
#define NILFS_FSTYPE "nilfs2"
#define NILFS_CNO_MIN ((nilfs_cno_t)1)
#define NILFS_CNO_MAX (~(nilfs_cno_t)0)
#define NILFS_SB_LABEL 0x0001
#define NILFS_SB_UUID 0x0002
#define NILFS_SB_FEATURES 0x0004
#define NILFS_SB_COMMIT_INTERVAL 0x4000
#define NILFS_SB_BLOCK_MAX 0x8000
/**
* struct nilfs - nilfs object
* @n_sb: superblock
* @n_dev: device file
* @n_ioc: ioctl file
* @n_devfd: file descriptor of device file
* @n_iocfd: file descriptor of ioctl file
* @n_opts: options
* @n_mincno: the minimum of valid checkpoint numbers
* @n_sems: array of semaphores
* sems[0] protects garbage collection process
*/
struct nilfs {
struct nilfs_super_block *n_sb;
char *n_dev;
/* char *n_mnt; */
char *n_ioc;
int n_devfd;
int n_iocfd;
int n_opts;
nilfs_cno_t n_mincno;
sem_t *n_sems[1];
};
#define NILFS_OPEN_RAW 0x0001 /* Open RAW device */
#define NILFS_OPEN_RDONLY 0x0002 /* Open NILFS API in read only mode */
#define NILFS_OPEN_WRONLY 0x0004 /* Open NILFS API in write only mode */
#define NILFS_OPEN_RDWR 0x0008 /* Open NILFS API in read/write mode */
#define NILFS_OPEN_GCLK 0x1000 /* Open GC lock primitive */
#define NILFS_OPT_MMAP 0x01
struct nilfs *nilfs_open(const char *, const char *, int);
void nilfs_close(struct nilfs *);
const char *nilfs_get_dev(const struct nilfs *);
void nilfs_opt_clear_mmap(struct nilfs *);
int nilfs_opt_set_mmap(struct nilfs *);
int nilfs_opt_test_mmap(struct nilfs *);
nilfs_cno_t nilfs_get_oldest_cno(struct nilfs *);
struct nilfs_super_block *nilfs_get_sb(struct nilfs *);
#define NILFS_LOCK_FNS(name, index) \
static inline int nilfs_lock_##name(struct nilfs *nilfs) \
{ \
return sem_wait(nilfs->n_sems[index]); \
} \
static inline int nilfs_trylock_##name(struct nilfs *nilfs) \
{ \
return sem_trywait(nilfs->n_sems[index]); \
} \
static inline int nilfs_unlock_##name(struct nilfs *nilfs) \
{ \
return sem_post(nilfs->n_sems[index]); \
}
NILFS_LOCK_FNS(cleaner, 0)
/**
* struct nilfs_psegment - partial segment iterator
* @p_segnum: segment number
* @p_blocknr: block number of partial segment
* @p_segblocknr: block number of segment
* @p_nblocks: number of blocks in segment
* @p_maxblocks: maximum number of blocks in segment
* @p_blksize: block size
* @p_seed: CRC seed
*/
struct nilfs_psegment {
struct nilfs_segment_summary *p_segsum;
sector_t p_blocknr;
sector_t p_segblocknr;
size_t p_nblocks;
size_t p_maxblocks;
size_t p_blksize;
__u32 p_seed;
};
/**
* struct nilfs_file - file iterator
* @f_finfo: file information
* @f_blocknr: block number
* @f_offset: byte offset from the begining of segment
* @f_index: index
* @f_psegment: partial segment
*/
struct nilfs_file {
struct nilfs_finfo *f_finfo;
sector_t f_blocknr;
unsigned long f_offset;
int f_index;
const struct nilfs_psegment *f_psegment;
};
/**
* struct nilfs_block - block iterator
* @b_binfo: block information
* @b_blocknr: block number
* @b_offset: byte offset from the begining of segment
* @b_index: index
* @b_dsize: size of data block information
* @b_nsize: size of node block information
* @b_file: file
*/
struct nilfs_block {
void *b_binfo;
sector_t b_blocknr;
unsigned long b_offset;
int b_index;
size_t b_dsize;
size_t b_nsize;
const struct nilfs_file *b_file;
};
/* virtual block number and block offset */
#define NILFS_BINFO_DATA_SIZE (sizeof(__le64) + sizeof(__le64))
/* virtual block number */
#define NILFS_BINFO_NODE_SIZE sizeof(__le64)
/* block offset */
#define NILFS_BINFO_DAT_DATA_SIZE sizeof(__le64)
/* block offset and level */
#define NILFS_BINFO_DAT_NODE_SIZE (sizeof(__le64) + sizeof(__le64))
/* partial segment iterator */
void nilfs_psegment_init(struct nilfs_psegment *, __u64,
void *, size_t, const struct nilfs *);
int nilfs_psegment_is_end(const struct nilfs_psegment *);
void nilfs_psegment_next(struct nilfs_psegment *);
#define nilfs_psegment_for_each(pseg, segnum, seg, nblocks, nilfs) \
for (nilfs_psegment_init(pseg, segnum, seg, nblocks, nilfs); \
!nilfs_psegment_is_end(pseg); \
nilfs_psegment_next(pseg))
/* file iterator */
void nilfs_file_init(struct nilfs_file *, const struct nilfs_psegment *);
int nilfs_file_is_end(const struct nilfs_file *);
void nilfs_file_next(struct nilfs_file *);
static inline int nilfs_file_is_super(const struct nilfs_file *file)
{
__u64 ino;
ino = le64_to_cpu(file->f_finfo->fi_ino);
return ino == NILFS_DAT_INO;
}
#define nilfs_file_for_each(file, pseg) \
for (nilfs_file_init(file, pseg); \
!nilfs_file_is_end(file); \
nilfs_file_next(file))
/* block iterator */
void nilfs_block_init(struct nilfs_block *, const struct nilfs_file *);
int nilfs_block_is_end(const struct nilfs_block *);
void nilfs_block_next(struct nilfs_block *);
static inline int nilfs_block_is_data(const struct nilfs_block *blk)
{
return blk->b_index < le32_to_cpu(blk->b_file->f_finfo->fi_ndatablk);
}
static inline int nilfs_block_is_node(const struct nilfs_block *blk)
{
return blk->b_index >= le32_to_cpu(blk->b_file->f_finfo->fi_ndatablk);
}
#define nilfs_block_for_each(blk, file) \
for (nilfs_block_init(blk, file); \
!nilfs_block_is_end(blk); \
nilfs_block_next(blk))
#define NILFS_SB_BLOCK_SIZE_SHIFT 10
struct nilfs_super_block *nilfs_sb_read(int devfd);
int nilfs_sb_write(int devfd, struct nilfs_super_block *sbp, int mask);
int nilfs_read_sb(struct nilfs *);
ssize_t nilfs_get_segment(struct nilfs *, unsigned long, void **);
int nilfs_put_segment(struct nilfs *, void *);
size_t nilfs_get_block_size(struct nilfs *);
__u64 nilfs_get_segment_seqnum(const struct nilfs *, void *, __u64);
__u64 nilfs_get_reserved_segments(const struct nilfs *nilfs);
int nilfs_change_cpmode(struct nilfs *, nilfs_cno_t, int);
ssize_t nilfs_get_cpinfo(struct nilfs *, nilfs_cno_t, int,
struct nilfs_cpinfo *, size_t);
int nilfs_delete_checkpoint(struct nilfs *, nilfs_cno_t);
int nilfs_get_cpstat(const struct nilfs *, struct nilfs_cpstat *);
ssize_t nilfs_get_suinfo(const struct nilfs *, __u64, struct nilfs_suinfo *,
size_t);
int nilfs_get_sustat(const struct nilfs *, struct nilfs_sustat *);
ssize_t nilfs_get_vinfo(const struct nilfs *, struct nilfs_vinfo *, size_t);
ssize_t nilfs_get_bdescs(const struct nilfs *, struct nilfs_bdesc *, size_t);
int nilfs_clean_segments(struct nilfs *, struct nilfs_vdesc *, size_t,
struct nilfs_period *, size_t, __u64 *, size_t,
struct nilfs_bdesc *, size_t, __u64 *, size_t);
int nilfs_sync(const struct nilfs *, nilfs_cno_t *);
int nilfs_resize(struct nilfs *nilfs, off_t size);
int nilfs_set_alloc_range(struct nilfs *nilfs, off_t start, off_t end);
static inline __u64 nilfs_get_nsegments(const struct nilfs *nilfs)
{
return le64_to_cpu(nilfs->n_sb->s_nsegments);
}
static inline __u32 nilfs_get_blocks_per_segment(const struct nilfs *nilfs)
{
return le32_to_cpu(nilfs->n_sb->s_blocks_per_segment);
}
#endif /* NILFS_H */
|