forked from daos-stack/daos
-
Notifications
You must be signed in to change notification settings - Fork 0
/
daos_fs.h
468 lines (436 loc) · 14.9 KB
/
daos_fs.h
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
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
/*
* (C) Copyright 2018 Intel Corporation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* GOVERNMENT LICENSE RIGHTS-OPEN SOURCE SOFTWARE
* The Government's rights to use, modify, reproduce, release, perform, display,
* or disclose this software are subject to the terms of the Apache License as
* provided in Contract No. B609815.
* Any reproduction of computer software, computer software documentation, or
* portions thereof marked with this legend must also reproduce the markings.
*/
/**
* \file
*
* DAOS File System API
*
* The DFS API provides an encapuslated namespace with a POSIX like API directly
* on top of the DAOS API. The namespace is encapsulated under a single DAOS
* container where directories and files are objects in that container.
*/
#ifndef __DAOS_FS_H__
#define __DAOS_FS_H__
#if defined(__cplusplus)
extern "C" {
#endif
#define DFS_MAX_PATH 128
#define DFS_MAX_FSIZE (~0ULL)
typedef struct dfs_obj dfs_obj_t;
typedef struct dfs dfs_t;
/**
* Mount a file system over DAOS. The pool and container handle must remain
* connected/open until after dfs_umount() is called; otherwise access to the
* dfs namespace will fail.
*
* The mount will create a root directory (DAOS object) for the file system. The
* user will associate the dfs object returned with a mount point.
*
* \param[in] poh Pool connection handle
* \param[in] coh Container open handle.
* \param[in] flags Mount flags (O_RDONLY or O_RDWR).
* \param[out] dfs Pointer to the file system object created.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_mount(daos_handle_t poh, daos_handle_t coh, int flags, dfs_t **dfs);
/**
* Unmount a DAOS file system. This closes open handles to the root object and
* commits the epoch at current timestamp. The internal dfs struct is freed, so
* further access to that dfs will be invalid.
*
* \param[in] dfs Pointer to the mounted file system.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_umount(dfs_t *dfs);
/**
* Lookup a path in the DFS and return the associated open object and mode.
* The object must be released with dfs_release().
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] path Path to lookup.
* \param[in] flags Access flags to open with (O_RDONLY or O_RDWR).
* \param[out] obj Pointer to the object looked up.
* \params[out] mode mode_t (permissions + type).
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_lookup(dfs_t *dfs, const char *path, int flags, dfs_obj_t **obj,
mode_t *mode);
/**
* Create/Open a directory, file, or Symlink.
* The object must be released with dfs_release().
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] parent Opened parent directory object. If NULL, use root obj.
* This is useful in cases where the creator/opener is
* working in a flat namespace and doesn't need to
* lookup/release the root object.
* \param[in] name Link name of the object to create/open.
* \param[in] mode mode_t (permissions + type).
* \param[in] flags Access flags (O_RDONLY, O_RDWR, O_EXCL, O_CREAT).
* \param[in] cid DAOS object class id (pass 0 for default MAX_RW).
* Valid on create only; ignored otherwise.
* \param[in] value Symlink value (NULL if not syml).
* \param[out] obj Pointer to object opened.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_open(dfs_t *dfs, dfs_obj_t *parent, const char *name, mode_t mode,
int flags, daos_oclass_id_t cid, const char *value, dfs_obj_t **obj);
/*
* Close/release open object.
*
* \param[in] obj Object to release.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_release(dfs_obj_t *obj);
/**
* Read data from the file object, and return actual data read.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] obj Opened file object.
* \param[in] sgl Scatter/Gather list for data buffer.
* \param[in] off Offset into the file to read from.
* \param[out] read_size
* How much data is actually read.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_read(dfs_t *dfs, dfs_obj_t *obj, daos_sg_list_t sgl, daos_off_t off,
daos_size_t *read_size);
/**
* Write data to the file object.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] obj Opened file object.
* \param[in] sgl Scatter/Gather list for data buffer.
* \param[in] off Offset into the file to write to.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_write(dfs_t *dfs, dfs_obj_t *obj, daos_sg_list_t sgl, daos_off_t off);
/**
* Query size of file data.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] obj Opened file object.
* \param[out] size Size of file.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_get_size(dfs_t *dfs, dfs_obj_t *obj, daos_size_t *size);
/**
* Punch a hole in the file starting at offset to len. If len is set to
* DFS_MAX_FSIZE, this will be a truncate operation to punch all bytes in the
* file above offset. If the file size is smaller than offset, the file is
* extended to offset and len is ignored.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] obj Opened file object.
* \param[in] offset offset of file to punch at.
* \param[in] len number of bytes to punch.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_punch(dfs_t *dfs, dfs_obj_t *obj, daos_off_t offset, daos_size_t len);
/**
* Query number of link in dir object.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] obj Opened directory object.
* \param[out] nlinks Number of links returned.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_nlinks(dfs_t *dfs, dfs_obj_t *obj, uint32_t *nlinks);
/**
* directory readdir.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] obj Opened directory object.
* \param[in,out]
* anchor Hash anchor for the next call, it should be set to
* zeroes for the first call, it should not be changed
* by caller between calls.
* \param[in,out]
* nr [in]: number of dirents allocated in \a dirs.
* [out]: number of returned dirents.
* \param[in,out]
* dirs [in] preallocated array of dirents.
* [out]: dirents returned with d_name filled only.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_readdir(dfs_t *dfs, dfs_obj_t *obj, daos_anchor_t *anchor,
uint32_t *nr, struct dirent *dirs);
/**
* Create a directory.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] parent Opened parent directory object. If NULL, use root obj.
* \param[in] name Link name of new dir.
* \param[in] mode mkdir mode.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_mkdir(dfs_t *dfs, dfs_obj_t *parent, const char *name, mode_t mode);
/**
* Remove an object from parent directory. If object is a directory and is
* non-empty; this will fail unless force option is true. If object is a
* symlink, the symlink is removed.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] parent Opened parent directory object. If NULL, use root obj.
* \param[in] name Name of object to remove in parent dir.
* \param[in] force If true, remove dir even if non-empty.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_remove(dfs_t *dfs, dfs_obj_t *parent, const char *name, bool force);
/**
* Move an object possible between different dirs with a new link name.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] parent Source parent directory object. If NULL, use root obj.
* \param[in] name Link name of object.
* \param[in] new_parent
* Target parent directory object. If NULL, use root obj.
* \param[in] name New link name of object.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_move(dfs_t *dfs, dfs_obj_t *parent, char *name, dfs_obj_t *new_parent,
char *new_name);
/**
* Exchange an object possible between different dirs with a new link name
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] parent1 Parent directory object of name1. If NULL, use root obj.
* \param[in] name1 Link name of first object.
* \param[in] parent2 Parent directory object of name2. If NULL, use root obj.
* \param[in] name2 link name of second object.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_exchange(dfs_t *dfs, dfs_obj_t *parent1, char *name1,
dfs_obj_t *parent2, char *name2);
/**
* Retrieve mode of an open object.
*
* \param[in] obj Open object to query.
* \param[out] mode mode_t (permissions + type).
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_get_mode(dfs_obj_t *obj, mode_t *mode);
/**
* Retrieve the DAOS open handle of a DFS file object. User should not close
* this handle. This is used in cases like MPI-IO where 1 rank creates the file
* with dfs, but wants to access the file with the array API directly rather
* than the DFS API.
*
* \param[in] obj Open object.
* \param[out] oh DAOS object open handle.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_get_file_oh(dfs_obj_t *obj, daos_handle_t *oh);
/**
* Retrieve Symlink value of object if it's a symlink. If the buffer size passed
* in is not large enough, we copy up to size of the buffer, and update the size
* to actual value size.
*
* \param[in] obj Open object to query.
* \param[in] buf user buffer to copy the symlink value in.
* \param[in,out]
* size [in]: Size of buffer pased in. [out]: Actual size of
* value.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_get_symlink_value(dfs_obj_t *obj, char *buf, daos_size_t *size);
/**
* stat attributes of an entry. If object is a symlink, the link itself is
* interogated. The following elements of the stat struct are populated
* (the rest are set to 0):
* mode_t st_mode;
* uid_t st_uid;
* gid_t st_gid;
* off_t st_size;
* blkcnt_t st_blocks
* struct timespec st_atim;
* struct timespec st_mtim;
* struct timespec st_ctim;
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] parent Opened parent directory object. If NULL, use root obj.
* \param[in] name Link name of the object. Can be NULL if parent is root,
* which means operation will be on root object.
* \param[out] stbuf Stat struct with the members above filled.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_stat(dfs_t *dfs, dfs_obj_t *parent, const char *name,
struct stat *stbuf);
/**
* Same as dfs_stat but works directly on an open object.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] obj Open object (File, dir or syml) to stat.
* \param[out] stbuf Stat struct with the members above filled.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_ostat(dfs_t *dfs, dfs_obj_t *obj, struct stat *stbuf);
/**
* Check access permissions on an object. Similar to Linux access(2).
* Symlinks are dereferenced.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] parent Opened parent directory object. If NULL, use root obj.
* \param[in] name Link name of the object. Can be NULL if parent is root,
* which means operation will be on root object.
* \param[in] mask accessibility check(s) to be performed.
* It should be either the value F_OK, or a mask with
* bitwise OR of one or more of R_OK, W_OK, and X_OK.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_access(dfs_t *dfs, dfs_obj_t *parent, const char *name, int mask);
/**
* Change permission access bits. Symlinks are dereferenced.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] parent Opened parent directory object. If NULL, use root obj.
* \param[in] name Link name of the object. Can be NULL if parent is root,
* which means operation will be on root object.
* \param[in] mode New permission access modes. For now, we don't support
* the sticky bit, setuid, and setgid.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_chmod(dfs_t *dfs, dfs_obj_t *parent, const char *name, mode_t mode);
/**
* Sync to commit the latest epoch on the container. This applies to the entire
* namespace and not to a particular file/directory.
*
* TODO: This should take a persistent snapshot at current timestamp.
*
* \param[in] dfs Pointer to the mounted file system.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_sync(dfs_t *dfs);
/**
* Set extended attribute on an open object (File, dir, syml). If object is a
* symlink, the value is set on the symlink itself.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] obj Open object where xattr will be added.
* \param[in] name Name of xattr to add.
* \param[in] value Value of xattr.
* \param[in] size Size in bytes of the value.
* \param[in] flags Set flags. passing 0 does not check for xattr existence.
* XATTR_CREATE: create or fail if xattr exists.
* XATTR_REPLACE: replace or fail if xattr does not exist.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_setxattr(dfs_t *dfs, dfs_obj_t *obj, const char *name,
const void *value, daos_size_t size, int flags);
/**
* Get extended attribute of an open object. If object is a symlink, the link
* itself is interogated.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] obj Open object where xattr is checked.
* \param[in] name Name of xattr to get.
* \param[out] value Buffer to place value of xattr.
* \param[in,out]
* size [in]: Size of buffer value. [out]: Actual size of xattr.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_getxattr(dfs_t *dfs, dfs_obj_t *obj, const char *name, void *value,
daos_size_t *size);
/**
* Remove extended attribute of an open object. If object is a symlink, the link
* itself is interogated.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] obj Open object where xattr will be removed.
* \param[in] name Name of xattr to remove.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_removexattr(dfs_t *dfs, dfs_obj_t *obj, const char *name);
/**
* list extended attributes of an open object and place them all in a buffer
* NULL terminated one after the other. If object is a symlink, the link itself
* is interogated.
*
* \param[in] dfs Pointer to the mounted file system.
* \param[in] obj Open object where xattrs will be listed.
* \param[in,out]
* list [in]: Allocated buffer for all xattr names.
* [out]: Names placed after each other (null terminated).
* \param[in,out]
* size [in]: Size of list. [out]: Actual size of list.
*
* \return 0 on Success. Negative on Failure.
*/
int
dfs_listxattr(dfs_t *dfs, dfs_obj_t *obj, char *list, daos_size_t *size);
#if defined(__cplusplus)
}
#endif
#endif /* __DAOS_FS_H__ */