1 // SPDX-License-Identifier: GPL-2.0
2 /*
3 * Copyright (c) 2000-2003,2005 Silicon Graphics, Inc.
4 * All Rights Reserved.
5 */
6 #ifndef __XFS_RTALLOC_H__
7 #define __XFS_RTALLOC_H__
8
9 /* kernel only definitions and functions */
10
11 struct xfs_mount;
12 struct xfs_trans;
13
14 /*
15 * XXX: Most of the realtime allocation functions deal in units of realtime
16 * extents, not realtime blocks. This looks funny when paired with the type
17 * name and screams for a larger cleanup.
18 */
19 struct xfs_rtalloc_rec {
20 xfs_rtblock_t ar_startext;
21 xfs_rtblock_t ar_extcount;
22 };
23
24 typedef int (*xfs_rtalloc_query_range_fn)(
25 struct xfs_trans *tp,
26 struct xfs_rtalloc_rec *rec,
27 void *priv);
28
29 #ifdef CONFIG_XFS_RT
30 /*
31 * Function prototypes for exported functions.
32 */
33
34 /*
35 * Allocate an extent in the realtime subvolume, with the usual allocation
36 * parameters. The length units are all in realtime extents, as is the
37 * result block number.
38 */
39 int /* error */
40 xfs_rtallocate_extent(
41 struct xfs_trans *tp, /* transaction pointer */
42 xfs_rtblock_t bno, /* starting block number to allocate */
43 xfs_extlen_t minlen, /* minimum length to allocate */
44 xfs_extlen_t maxlen, /* maximum length to allocate */
45 xfs_extlen_t *len, /* out: actual length allocated */
46 int wasdel, /* was a delayed allocation extent */
47 xfs_extlen_t prod, /* extent product factor */
48 xfs_rtblock_t *rtblock); /* out: start block allocated */
49
50 /*
51 * Free an extent in the realtime subvolume. Length is expressed in
52 * realtime extents, as is the block number.
53 */
54 int /* error */
55 xfs_rtfree_extent(
56 struct xfs_trans *tp, /* transaction pointer */
57 xfs_rtblock_t bno, /* starting block number to free */
58 xfs_extlen_t len); /* length of extent freed */
59
60 /*
61 * Initialize realtime fields in the mount structure.
62 */
63 int /* error */
64 xfs_rtmount_init(
65 struct xfs_mount *mp); /* file system mount structure */
66 void
67 xfs_rtunmount_inodes(
68 struct xfs_mount *mp);
69
70 /*
71 * Get the bitmap and summary inodes into the mount structure
72 * at mount time.
73 */
74 int /* error */
75 xfs_rtmount_inodes(
76 struct xfs_mount *mp); /* file system mount structure */
77
78 /*
79 * Pick an extent for allocation at the start of a new realtime file.
80 * Use the sequence number stored in the atime field of the bitmap inode.
81 * Translate this to a fraction of the rtextents, and return the product
82 * of rtextents and the fraction.
83 * The fraction sequence is 0, 1/2, 1/4, 3/4, 1/8, ..., 7/8, 1/16, ...
84 */
85 int /* error */
86 xfs_rtpick_extent(
87 struct xfs_mount *mp, /* file system mount point */
88 struct xfs_trans *tp, /* transaction pointer */
89 xfs_extlen_t len, /* allocation length (rtextents) */
90 xfs_rtblock_t *pick); /* result rt extent */
91
92 /*
93 * Grow the realtime area of the filesystem.
94 */
95 int
96 xfs_growfs_rt(
97 struct xfs_mount *mp, /* file system mount structure */
98 xfs_growfs_rt_t *in); /* user supplied growfs struct */
99
100 /*
101 * From xfs_rtbitmap.c
102 */
103 int xfs_rtbuf_get(struct xfs_mount *mp, struct xfs_trans *tp,
104 xfs_rtblock_t block, int issum, struct xfs_buf **bpp);
105 int xfs_rtcheck_range(struct xfs_mount *mp, struct xfs_trans *tp,
106 xfs_rtblock_t start, xfs_extlen_t len, int val,
107 xfs_rtblock_t *new, int *stat);
108 int xfs_rtfind_back(struct xfs_mount *mp, struct xfs_trans *tp,
109 xfs_rtblock_t start, xfs_rtblock_t limit,
110 xfs_rtblock_t *rtblock);
111 int xfs_rtfind_forw(struct xfs_mount *mp, struct xfs_trans *tp,
112 xfs_rtblock_t start, xfs_rtblock_t limit,
113 xfs_rtblock_t *rtblock);
114 int xfs_rtmodify_range(struct xfs_mount *mp, struct xfs_trans *tp,
115 xfs_rtblock_t start, xfs_extlen_t len, int val);
116 int xfs_rtmodify_summary_int(struct xfs_mount *mp, struct xfs_trans *tp,
117 int log, xfs_rtblock_t bbno, int delta,
118 xfs_buf_t **rbpp, xfs_fsblock_t *rsb,
119 xfs_suminfo_t *sum);
120 int xfs_rtmodify_summary(struct xfs_mount *mp, struct xfs_trans *tp, int log,
121 xfs_rtblock_t bbno, int delta, xfs_buf_t **rbpp,
122 xfs_fsblock_t *rsb);
123 int xfs_rtfree_range(struct xfs_mount *mp, struct xfs_trans *tp,
124 xfs_rtblock_t start, xfs_extlen_t len,
125 struct xfs_buf **rbpp, xfs_fsblock_t *rsb);
126 int xfs_rtalloc_query_range(struct xfs_trans *tp,
127 struct xfs_rtalloc_rec *low_rec,
128 struct xfs_rtalloc_rec *high_rec,
129 xfs_rtalloc_query_range_fn fn,
130 void *priv);
131 int xfs_rtalloc_query_all(struct xfs_trans *tp,
132 xfs_rtalloc_query_range_fn fn,
133 void *priv);
134 bool xfs_verify_rtbno(struct xfs_mount *mp, xfs_rtblock_t rtbno);
135 int xfs_rtalloc_extent_is_free(struct xfs_mount *mp, struct xfs_trans *tp,
136 xfs_rtblock_t start, xfs_extlen_t len,
137 bool *is_free);
138 #else
139 # define xfs_rtallocate_extent(t,b,min,max,l,f,p,rb) (ENOSYS)
140 # define xfs_rtfree_extent(t,b,l) (ENOSYS)
141 # define xfs_rtpick_extent(m,t,l,rb) (ENOSYS)
142 # define xfs_growfs_rt(mp,in) (ENOSYS)
143 # define xfs_rtalloc_query_range(t,l,h,f,p) (ENOSYS)
144 # define xfs_rtalloc_query_all(t,f,p) (ENOSYS)
145 # define xfs_rtbuf_get(m,t,b,i,p) (ENOSYS)
146 # define xfs_verify_rtbno(m, r) (false)
147 # define xfs_rtalloc_extent_is_free(m,t,s,l,i) (ENOSYS)
148 static inline int /* error */
xfs_rtmount_init(xfs_mount_t * mp)149 xfs_rtmount_init(
150 xfs_mount_t *mp) /* file system mount structure */
151 {
152 if (mp->m_sb.sb_rblocks == 0)
153 return 0;
154
155 xfs_warn(mp, "Not built with CONFIG_XFS_RT");
156 return -ENOSYS;
157 }
158 # define xfs_rtmount_inodes(m) (((mp)->m_sb.sb_rblocks == 0)? 0 : (ENOSYS))
159 # define xfs_rtunmount_inodes(m)
160 #endif /* CONFIG_XFS_RT */
161
162 #endif /* __XFS_RTALLOC_H__ */
163