1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18#ifndef __XFS_FS_H__
19#define __XFS_FS_H__
20
21
22
23
24
25
26
27
28
29
30#ifndef HAVE_DIOATTR
31struct dioattr {
32 __u32 d_mem;
33 __u32 d_miniosz;
34 __u32 d_maxiosz;
35};
36#endif
37
38
39
40
41#ifndef HAVE_FSXATTR
42struct fsxattr {
43 __u32 fsx_xflags;
44 __u32 fsx_extsize;
45 __u32 fsx_nextents;
46 __u32 fsx_projid;
47 unsigned char fsx_pad[12];
48};
49#endif
50
51
52
53
54
55
56#define XFS_XFLAG_REALTIME 0x00000001
57#define XFS_XFLAG_PREALLOC 0x00000002
58#define XFS_XFLAG_IMMUTABLE 0x00000008
59#define XFS_XFLAG_APPEND 0x00000010
60#define XFS_XFLAG_SYNC 0x00000020
61#define XFS_XFLAG_NOATIME 0x00000040
62#define XFS_XFLAG_NODUMP 0x00000080
63#define XFS_XFLAG_RTINHERIT 0x00000100
64#define XFS_XFLAG_PROJINHERIT 0x00000200
65#define XFS_XFLAG_NOSYMLINKS 0x00000400
66#define XFS_XFLAG_EXTSIZE 0x00000800
67#define XFS_XFLAG_EXTSZINHERIT 0x00001000
68#define XFS_XFLAG_NODEFRAG 0x00002000
69#define XFS_XFLAG_FILESTREAM 0x00004000
70#define XFS_XFLAG_HASATTR 0x80000000
71
72
73
74
75
76
77
78
79#ifndef HAVE_GETBMAP
80struct getbmap {
81 __s64 bmv_offset;
82 __s64 bmv_block;
83 __s64 bmv_length;
84 __s32 bmv_count;
85 __s32 bmv_entries;
86};
87#endif
88
89
90
91
92
93
94
95
96
97
98#ifndef HAVE_GETBMAPX
99struct getbmapx {
100 __s64 bmv_offset;
101 __s64 bmv_block;
102 __s64 bmv_length;
103 __s32 bmv_count;
104 __s32 bmv_entries;
105 __s32 bmv_iflags;
106 __s32 bmv_oflags;
107 __s32 bmv_unused1;
108 __s32 bmv_unused2;
109};
110#endif
111
112
113#define BMV_IF_ATTRFORK 0x1
114#define BMV_IF_NO_DMAPI_READ 0x2
115#define BMV_IF_PREALLOC 0x4
116#define BMV_IF_DELALLOC 0x8
117#define BMV_IF_NO_HOLES 0x10
118#define BMV_IF_VALID \
119 (BMV_IF_ATTRFORK|BMV_IF_NO_DMAPI_READ|BMV_IF_PREALLOC| \
120 BMV_IF_DELALLOC|BMV_IF_NO_HOLES)
121
122
123#define BMV_OF_PREALLOC 0x1
124#define BMV_OF_DELALLOC 0x2
125#define BMV_OF_LAST 0x4
126
127
128
129
130
131
132
133
134#ifndef HAVE_FSDMIDATA
135struct fsdmidata {
136 __u32 fsd_dmevmask;
137 __u16 fsd_padding;
138 __u16 fsd_dmstate;
139};
140#endif
141
142
143
144
145
146typedef struct xfs_flock64 {
147 __s16 l_type;
148 __s16 l_whence;
149 __s64 l_start;
150 __s64 l_len;
151 __s32 l_sysid;
152 __u32 l_pid;
153 __s32 l_pad[4];
154} xfs_flock64_t;
155
156
157
158
159typedef struct xfs_fsop_geom_v1 {
160 __u32 blocksize;
161 __u32 rtextsize;
162 __u32 agblocks;
163 __u32 agcount;
164 __u32 logblocks;
165 __u32 sectsize;
166 __u32 inodesize;
167 __u32 imaxpct;
168 __u64 datablocks;
169 __u64 rtblocks;
170 __u64 rtextents;
171 __u64 logstart;
172 unsigned char uuid[16];
173 __u32 sunit;
174 __u32 swidth;
175 __s32 version;
176 __u32 flags;
177 __u32 logsectsize;
178 __u32 rtsectsize;
179 __u32 dirblocksize;
180} xfs_fsop_geom_v1_t;
181
182
183
184
185typedef struct xfs_fsop_geom {
186 __u32 blocksize;
187 __u32 rtextsize;
188 __u32 agblocks;
189 __u32 agcount;
190 __u32 logblocks;
191 __u32 sectsize;
192 __u32 inodesize;
193 __u32 imaxpct;
194 __u64 datablocks;
195 __u64 rtblocks;
196 __u64 rtextents;
197 __u64 logstart;
198 unsigned char uuid[16];
199 __u32 sunit;
200 __u32 swidth;
201 __s32 version;
202 __u32 flags;
203 __u32 logsectsize;
204 __u32 rtsectsize;
205 __u32 dirblocksize;
206 __u32 logsunit;
207} xfs_fsop_geom_t;
208
209
210typedef struct xfs_fsop_counts {
211 __u64 freedata;
212 __u64 freertx;
213 __u64 freeino;
214 __u64 allocino;
215} xfs_fsop_counts_t;
216
217
218typedef struct xfs_fsop_resblks {
219 __u64 resblks;
220 __u64 resblks_avail;
221} xfs_fsop_resblks_t;
222
223#define XFS_FSOP_GEOM_VERSION 0
224
225#define XFS_FSOP_GEOM_FLAGS_ATTR 0x0001
226#define XFS_FSOP_GEOM_FLAGS_NLINK 0x0002
227#define XFS_FSOP_GEOM_FLAGS_QUOTA 0x0004
228#define XFS_FSOP_GEOM_FLAGS_IALIGN 0x0008
229#define XFS_FSOP_GEOM_FLAGS_DALIGN 0x0010
230#define XFS_FSOP_GEOM_FLAGS_SHARED 0x0020
231#define XFS_FSOP_GEOM_FLAGS_EXTFLG 0x0040
232#define XFS_FSOP_GEOM_FLAGS_DIRV2 0x0080
233#define XFS_FSOP_GEOM_FLAGS_LOGV2 0x0100
234#define XFS_FSOP_GEOM_FLAGS_SECTOR 0x0200
235#define XFS_FSOP_GEOM_FLAGS_ATTR2 0x0400
236#define XFS_FSOP_GEOM_FLAGS_PROJID32 0x0800
237#define XFS_FSOP_GEOM_FLAGS_DIRV2CI 0x1000
238#define XFS_FSOP_GEOM_FLAGS_LAZYSB 0x4000
239#define XFS_FSOP_GEOM_FLAGS_V5SB 0x8000
240
241
242
243
244
245
246
247#define XFS_MIN_AG_BLOCKS 64
248#define XFS_MIN_LOG_BLOCKS 512ULL
249#define XFS_MAX_LOG_BLOCKS (1024 * 1024ULL)
250#define XFS_MIN_LOG_BYTES (10 * 1024 * 1024ULL)
251
252
253#define XFS_MAX_LOG_BYTES \
254 ((2 * 1024 * 1024 * 1024ULL) - XFS_MIN_LOG_BYTES)
255
256
257#define XFS_MAX_DBLOCKS(s) ((xfs_drfsbno_t)(s)->sb_agcount * (s)->sb_agblocks)
258#define XFS_MIN_DBLOCKS(s) ((xfs_drfsbno_t)((s)->sb_agcount - 1) * \
259 (s)->sb_agblocks + XFS_MIN_AG_BLOCKS)
260
261
262
263
264typedef struct xfs_growfs_data {
265 __u64 newblocks;
266 __u32 imaxpct;
267} xfs_growfs_data_t;
268
269typedef struct xfs_growfs_log {
270 __u32 newblocks;
271 __u32 isint;
272} xfs_growfs_log_t;
273
274typedef struct xfs_growfs_rt {
275 __u64 newblocks;
276 __u32 extsize;
277} xfs_growfs_rt_t;
278
279
280
281
282
283typedef struct xfs_bstime {
284 time_t tv_sec;
285 __s32 tv_nsec;
286} xfs_bstime_t;
287
288typedef struct xfs_bstat {
289 __u64 bs_ino;
290 __u16 bs_mode;
291 __u16 bs_nlink;
292 __u32 bs_uid;
293 __u32 bs_gid;
294 __u32 bs_rdev;
295 __s32 bs_blksize;
296 __s64 bs_size;
297 xfs_bstime_t bs_atime;
298 xfs_bstime_t bs_mtime;
299 xfs_bstime_t bs_ctime;
300 int64_t bs_blocks;
301 __u32 bs_xflags;
302 __s32 bs_extsize;
303 __s32 bs_extents;
304 __u32 bs_gen;
305 __u16 bs_projid_lo;
306#define bs_projid bs_projid_lo
307 __u16 bs_forkoff;
308 __u16 bs_projid_hi;
309 unsigned char bs_pad[10];
310 __u32 bs_dmevmask;
311 __u16 bs_dmstate;
312 __u16 bs_aextents;
313} xfs_bstat_t;
314
315
316
317
318
319
320static inline __uint32_t
321bstat_get_projid(struct xfs_bstat *bs)
322{
323 return (__uint32_t)bs->bs_projid_hi << 16 | bs->bs_projid_lo;
324}
325
326
327
328
329typedef struct xfs_fsop_bulkreq {
330 __u64 __user *lastip;
331 __s32 icount;
332 void __user *ubuffer;
333 __s32 __user *ocount;
334} xfs_fsop_bulkreq_t;
335
336
337
338
339
340typedef struct xfs_inogrp {
341 __u64 xi_startino;
342 __s32 xi_alloccount;
343 __u64 xi_allocmask;
344} xfs_inogrp_t;
345
346
347
348
349
350typedef struct xfs_error_injection {
351 __s32 fd;
352 __s32 errtag;
353} xfs_error_injection_t;
354
355
356
357
358
359#define XFS_EOFBLOCKS_VERSION 1
360struct xfs_fs_eofblocks {
361 __u32 eof_version;
362 __u32 eof_flags;
363 uid_t eof_uid;
364 gid_t eof_gid;
365 prid_t eof_prid;
366 __u32 pad32;
367 __u64 eof_min_file_size;
368 __u64 pad64[12];
369};
370
371
372#define XFS_EOF_FLAGS_SYNC (1 << 0)
373#define XFS_EOF_FLAGS_UID (1 << 1)
374#define XFS_EOF_FLAGS_GID (1 << 2)
375#define XFS_EOF_FLAGS_PRID (1 << 3)
376#define XFS_EOF_FLAGS_MINFILESIZE (1 << 4)
377#define XFS_EOF_FLAGS_VALID \
378 (XFS_EOF_FLAGS_SYNC | \
379 XFS_EOF_FLAGS_UID | \
380 XFS_EOF_FLAGS_GID | \
381 XFS_EOF_FLAGS_PRID | \
382 XFS_EOF_FLAGS_MINFILESIZE)
383
384
385
386
387
388typedef struct xfs_fsop_handlereq {
389 __u32 fd;
390 void __user *path;
391 __u32 oflags;
392 void __user *ihandle;
393 __u32 ihandlen;
394 void __user *ohandle;
395 __u32 __user *ohandlen;
396} xfs_fsop_handlereq_t;
397
398
399
400
401
402
403
404
405typedef struct xfs_fsop_setdm_handlereq {
406 struct xfs_fsop_handlereq hreq;
407 struct fsdmidata __user *data;
408} xfs_fsop_setdm_handlereq_t;
409
410typedef struct xfs_attrlist_cursor {
411 __u32 opaque[4];
412} xfs_attrlist_cursor_t;
413
414typedef struct xfs_fsop_attrlist_handlereq {
415 struct xfs_fsop_handlereq hreq;
416 struct xfs_attrlist_cursor pos;
417 __u32 flags;
418 __u32 buflen;
419 void __user *buffer;
420} xfs_fsop_attrlist_handlereq_t;
421
422typedef struct xfs_attr_multiop {
423 __u32 am_opcode;
424#define ATTR_OP_GET 1
425#define ATTR_OP_SET 2
426#define ATTR_OP_REMOVE 3
427 __s32 am_error;
428 void __user *am_attrname;
429 void __user *am_attrvalue;
430 __u32 am_length;
431 __u32 am_flags;
432} xfs_attr_multiop_t;
433
434typedef struct xfs_fsop_attrmulti_handlereq {
435 struct xfs_fsop_handlereq hreq;
436 __u32 opcount;
437 struct xfs_attr_multiop __user *ops;
438} xfs_fsop_attrmulti_handlereq_t;
439
440
441
442
443typedef struct { __u32 val[2]; } xfs_fsid_t;
444
445typedef struct xfs_fid {
446 __u16 fid_len;
447 __u16 fid_pad;
448 __u32 fid_gen;
449 __u64 fid_ino;
450} xfs_fid_t;
451
452typedef struct xfs_handle {
453 union {
454 __s64 align;
455 xfs_fsid_t _ha_fsid;
456 } ha_u;
457 xfs_fid_t ha_fid;
458} xfs_handle_t;
459#define ha_fsid ha_u._ha_fsid
460
461#define XFS_HSIZE(handle) (((char *) &(handle).ha_fid.fid_pad \
462 - (char *) &(handle)) \
463 + (handle).ha_fid.fid_len)
464
465
466
467
468typedef struct xfs_swapext
469{
470 __int64_t sx_version;
471#define XFS_SX_VERSION 0
472 __int64_t sx_fdtarget;
473 __int64_t sx_fdtmp;
474 xfs_off_t sx_offset;
475 xfs_off_t sx_length;
476 char sx_pad[16];
477 xfs_bstat_t sx_stat;
478} xfs_swapext_t;
479
480
481
482
483#define XFS_FSOP_GOING_FLAGS_DEFAULT 0x0
484#define XFS_FSOP_GOING_FLAGS_LOGFLUSH 0x1
485#define XFS_FSOP_GOING_FLAGS_NOLOGFLUSH 0x2
486
487
488
489
490#define XFS_IOC_GETXFLAGS FS_IOC_GETFLAGS
491#define XFS_IOC_SETXFLAGS FS_IOC_SETFLAGS
492#define XFS_IOC_GETVERSION FS_IOC_GETVERSION
493
494
495
496
497
498
499#define XFS_IOC_ALLOCSP _IOW ('X', 10, struct xfs_flock64)
500#define XFS_IOC_FREESP _IOW ('X', 11, struct xfs_flock64)
501#define XFS_IOC_DIOINFO _IOR ('X', 30, struct dioattr)
502#define XFS_IOC_FSGETXATTR _IOR ('X', 31, struct fsxattr)
503#define XFS_IOC_FSSETXATTR _IOW ('X', 32, struct fsxattr)
504#define XFS_IOC_ALLOCSP64 _IOW ('X', 36, struct xfs_flock64)
505#define XFS_IOC_FREESP64 _IOW ('X', 37, struct xfs_flock64)
506#define XFS_IOC_GETBMAP _IOWR('X', 38, struct getbmap)
507#define XFS_IOC_FSSETDM _IOW ('X', 39, struct fsdmidata)
508#define XFS_IOC_RESVSP _IOW ('X', 40, struct xfs_flock64)
509#define XFS_IOC_UNRESVSP _IOW ('X', 41, struct xfs_flock64)
510#define XFS_IOC_RESVSP64 _IOW ('X', 42, struct xfs_flock64)
511#define XFS_IOC_UNRESVSP64 _IOW ('X', 43, struct xfs_flock64)
512#define XFS_IOC_GETBMAPA _IOWR('X', 44, struct getbmap)
513#define XFS_IOC_FSGETXATTRA _IOR ('X', 45, struct fsxattr)
514
515
516#define XFS_IOC_GETBMAPX _IOWR('X', 56, struct getbmap)
517#define XFS_IOC_ZERO_RANGE _IOW ('X', 57, struct xfs_flock64)
518#define XFS_IOC_FREE_EOFBLOCKS _IOR ('X', 58, struct xfs_fs_eofblocks)
519
520
521
522
523#define XFS_IOC_FSGEOMETRY_V1 _IOR ('X', 100, struct xfs_fsop_geom_v1)
524#define XFS_IOC_FSBULKSTAT _IOWR('X', 101, struct xfs_fsop_bulkreq)
525#define XFS_IOC_FSBULKSTAT_SINGLE _IOWR('X', 102, struct xfs_fsop_bulkreq)
526#define XFS_IOC_FSINUMBERS _IOWR('X', 103, struct xfs_fsop_bulkreq)
527#define XFS_IOC_PATH_TO_FSHANDLE _IOWR('X', 104, struct xfs_fsop_handlereq)
528#define XFS_IOC_PATH_TO_HANDLE _IOWR('X', 105, struct xfs_fsop_handlereq)
529#define XFS_IOC_FD_TO_HANDLE _IOWR('X', 106, struct xfs_fsop_handlereq)
530#define XFS_IOC_OPEN_BY_HANDLE _IOWR('X', 107, struct xfs_fsop_handlereq)
531#define XFS_IOC_READLINK_BY_HANDLE _IOWR('X', 108, struct xfs_fsop_handlereq)
532#define XFS_IOC_SWAPEXT _IOWR('X', 109, struct xfs_swapext)
533#define XFS_IOC_FSGROWFSDATA _IOW ('X', 110, struct xfs_growfs_data)
534#define XFS_IOC_FSGROWFSLOG _IOW ('X', 111, struct xfs_growfs_log)
535#define XFS_IOC_FSGROWFSRT _IOW ('X', 112, struct xfs_growfs_rt)
536#define XFS_IOC_FSCOUNTS _IOR ('X', 113, struct xfs_fsop_counts)
537#define XFS_IOC_SET_RESBLKS _IOWR('X', 114, struct xfs_fsop_resblks)
538#define XFS_IOC_GET_RESBLKS _IOR ('X', 115, struct xfs_fsop_resblks)
539#define XFS_IOC_ERROR_INJECTION _IOW ('X', 116, struct xfs_error_injection)
540#define XFS_IOC_ERROR_CLEARALL _IOW ('X', 117, struct xfs_error_injection)
541
542
543
544
545#ifndef FIFREEZE
546#define XFS_IOC_FREEZE _IOWR('X', 119, int)
547#define XFS_IOC_THAW _IOWR('X', 120, int)
548#endif
549
550#define XFS_IOC_FSSETDM_BY_HANDLE _IOW ('X', 121, struct xfs_fsop_setdm_handlereq)
551#define XFS_IOC_ATTRLIST_BY_HANDLE _IOW ('X', 122, struct xfs_fsop_attrlist_handlereq)
552#define XFS_IOC_ATTRMULTI_BY_HANDLE _IOW ('X', 123, struct xfs_fsop_attrmulti_handlereq)
553#define XFS_IOC_FSGEOMETRY _IOR ('X', 124, struct xfs_fsop_geom)
554#define XFS_IOC_GOINGDOWN _IOR ('X', 125, __uint32_t)
555
556
557
558#ifndef HAVE_BBMACROS
559
560
561
562
563
564#define BBSHIFT 9
565#define BBSIZE (1<<BBSHIFT)
566#define BBMASK (BBSIZE-1)
567#define BTOBB(bytes) (((__u64)(bytes) + BBSIZE - 1) >> BBSHIFT)
568#define BTOBBT(bytes) ((__u64)(bytes) >> BBSHIFT)
569#define BBTOB(bbs) ((bbs) << BBSHIFT)
570#endif
571
572#endif
573