DAOS API (v2.1 - dev)
Loading...
Searching...
No Matches
daos_array.h
Go to the documentation of this file.
1/*
2 * (C) Copyright 2016-2022 Intel Corporation.
3 *
4 * SPDX-License-Identifier: BSD-2-Clause-Patent
5 */
15#ifndef __DAOS_ARRAY_H__
16#define __DAOS_ARRAY_H__
17
18#if defined(__cplusplus)
19extern "C" {
20#endif
21
23typedef struct {
25 daos_off_t rg_idx;
27 daos_size_t rg_len;
29
31typedef struct {
33 daos_size_t arr_nr;
40 daos_size_t arr_nr_short_read;
42 daos_size_t arr_nr_read;
44
46typedef struct {
48 daos_size_t st_size;
50 daos_epoch_t st_max_epoch;
52
75static inline int
76daos_array_generate_oid(daos_handle_t coh, daos_obj_id_t *oid, bool add_attr, daos_oclass_id_t cid,
77 daos_oclass_hints_t hints, uint32_t args)
78{
79 enum daos_otype_t type;
80
81 type = DAOS_OT_ARRAY_ATTR;
82
83 if (add_attr)
84 type = DAOS_OT_ARRAY;
85
86 return daos_obj_generate_oid(coh, oid, type, cid, hints, args);
87}
88
123int
125 daos_size_t cell_size, daos_size_t chunk_size,
126 daos_handle_t *oh, daos_event_t *ev);
127
156int
158 unsigned int mode, daos_size_t *cell_size,
159 daos_size_t *chunk_size, daos_handle_t *oh, daos_event_t *ev);
160
189int
191 daos_handle_t th, unsigned int mode,
192 daos_size_t cell_size, daos_size_t chunk_size,
193 daos_handle_t *oh, daos_event_t *ev);
194
215int
217
235int
236daos_array_global2local(daos_handle_t coh, d_iov_t glob, unsigned int mode,
237 daos_handle_t *oh);
238
251int
253
276int
278 d_sg_list_t *sgl, daos_event_t *ev);
279
301int
303 d_sg_list_t *sgl, daos_event_t *ev);
304
321int
323
340int
342
362int
364 daos_event_t *ev);
365
387int
389
406int
408 daos_event_t *ev);
409
425int
426daos_array_get_attr(daos_handle_t oh, daos_size_t *chunk_size,
427 daos_size_t *cell_size);
428
429#if defined(__cplusplus)
430}
431#endif
432
433#endif /* __DAOS_ARRAY_H__ */
int daos_array_read(daos_handle_t oh, daos_handle_t th, daos_array_iod_t *iod, d_sg_list_t *sgl, daos_event_t *ev)
int daos_array_local2global(daos_handle_t oh, d_iov_t *glob)
int daos_array_close(daos_handle_t oh, daos_event_t *ev)
int daos_array_open(daos_handle_t coh, daos_obj_id_t oid, daos_handle_t th, unsigned int mode, daos_size_t *cell_size, daos_size_t *chunk_size, daos_handle_t *oh, daos_event_t *ev)
int daos_array_get_attr(daos_handle_t oh, daos_size_t *chunk_size, daos_size_t *cell_size)
int daos_array_set_size(daos_handle_t oh, daos_handle_t th, daos_size_t size, daos_event_t *ev)
int daos_array_get_size(daos_handle_t oh, daos_handle_t th, daos_size_t *size, daos_event_t *ev)
int daos_array_global2local(daos_handle_t coh, d_iov_t glob, unsigned int mode, daos_handle_t *oh)
int daos_array_open_with_attr(daos_handle_t coh, daos_obj_id_t oid, daos_handle_t th, unsigned int mode, daos_size_t cell_size, daos_size_t chunk_size, daos_handle_t *oh, daos_event_t *ev)
int daos_array_punch(daos_handle_t oh, daos_handle_t th, daos_array_iod_t *iod, daos_event_t *ev)
int daos_array_write(daos_handle_t oh, daos_handle_t th, daos_array_iod_t *iod, d_sg_list_t *sgl, daos_event_t *ev)
int daos_array_stat(daos_handle_t oh, daos_handle_t th, daos_array_stbuf_t *stbuf, daos_event_t *ev)
int daos_array_destroy(daos_handle_t oh, daos_handle_t th, daos_event_t *ev)
int daos_array_create(daos_handle_t coh, daos_obj_id_t oid, daos_handle_t th, daos_size_t cell_size, daos_size_t chunk_size, daos_handle_t *oh, daos_event_t *ev)
daos_range_t * arr_rgs
Definition daos_array.h:35
daos_size_t arr_nr
Definition daos_array.h:33
daos_size_t arr_nr_short_read
Definition daos_array.h:40
daos_size_t arr_nr_read
Definition daos_array.h:42
daos_epoch_t st_max_epoch
Definition daos_array.h:50
daos_size_t st_size
Definition daos_array.h:48
daos_size_t rg_len
Definition daos_array.h:27
daos_off_t rg_idx
Definition daos_array.h:25