hc
2024-03-22 f63cd4c03ea42695d5f9b0e1798edd196923aae6
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
/* SPDX-License-Identifier: GPL-2.0 */
/*
 *    Definitions of structures and functions for quota formats using trie
 */
 
#ifndef _LINUX_DQBLK_QTREE_H
#define _LINUX_DQBLK_QTREE_H
 
#include <linux/types.h>
 
/* Numbers of blocks needed for updates - we count with the smallest
 * possible block size (1024) */
#define QTREE_INIT_ALLOC 4
#define QTREE_INIT_REWRITE 2
#define QTREE_DEL_ALLOC 0
#define QTREE_DEL_REWRITE 6
 
struct dquot;
struct kqid;
 
/* Operations */
struct qtree_fmt_operations {
   void (*mem2disk_dqblk)(void *disk, struct dquot *dquot);    /* Convert given entry from in memory format to disk one */
   void (*disk2mem_dqblk)(struct dquot *dquot, void *disk);    /* Convert given entry from disk format to in memory one */
   int (*is_id)(void *disk, struct dquot *dquot);    /* Is this structure for given id? */
};
 
/* Inmemory copy of version specific information */
struct qtree_mem_dqinfo {
   struct super_block *dqi_sb;    /* Sb quota is on */
   int dqi_type;            /* Quota type */
   unsigned int dqi_blocks;    /* # of blocks in quota file */
   unsigned int dqi_free_blk;    /* First block in list of free blocks */
   unsigned int dqi_free_entry;    /* First block with free entry */
   unsigned int dqi_blocksize_bits;    /* Block size of quota file */
   unsigned int dqi_entry_size;    /* Size of quota entry in quota file */
   unsigned int dqi_usable_bs;    /* Space usable in block for quota data */
   unsigned int dqi_qtree_depth;    /* Precomputed depth of quota tree */
   const struct qtree_fmt_operations *dqi_ops; /* Operations for entry manipulation */
};
 
int qtree_write_dquot(struct qtree_mem_dqinfo *info, struct dquot *dquot);
int qtree_read_dquot(struct qtree_mem_dqinfo *info, struct dquot *dquot);
int qtree_delete_dquot(struct qtree_mem_dqinfo *info, struct dquot *dquot);
int qtree_release_dquot(struct qtree_mem_dqinfo *info, struct dquot *dquot);
int qtree_entry_unused(struct qtree_mem_dqinfo *info, char *disk);
static inline int qtree_depth(struct qtree_mem_dqinfo *info)
{
   unsigned int epb = info->dqi_usable_bs >> 2;
   unsigned long long entries = epb;
   int i;
 
   for (i = 1; entries < (1ULL << 32); i++)
       entries *= epb;
   return i;
}
int qtree_get_next_id(struct qtree_mem_dqinfo *info, struct kqid *qid);
 
#endif /* _LINUX_DQBLK_QTREE_H */