DAOS API (v2.0)
Loading...
Searching...
No Matches
daos_task.h
1
10#ifndef __DAOS_TASK_H__
11#define __DAOS_TASK_H__
12
13#if defined(__cplusplus)
14extern "C" {
15#endif
16
17#include <daos_types.h>
18#include <daos_obj.h>
19#include <daos_kv.h>
20#include <daos_array.h>
21#include <daos_errno.h>
22#include <daos_prop.h>
23#include <daos_cont.h>
24#include <daos_pool.h>
25#include <daos_mgmt.h>
26#include <daos/tse.h>
27
29typedef enum {
30 DAOS_OPC_INVALID = -1,
31
33 /* Starting at 0 will break Application Binary Interface backward
34 * compatibility */
35 DAOS_OPC_SET_PARAMS = 3,
36 DAOS_OPC_MGMT_GET_BS_STATE,
37
39 DAOS_OPC_POOL_CONNECT = 5,
40 DAOS_OPC_POOL_DISCONNECT,
41 DAOS_OPC_POOL_EXCLUDE,
42 DAOS_OPC_POOL_EXCLUDE_OUT,
43 DAOS_OPC_POOL_ADD,
44 DAOS_OPC_POOL_QUERY,
45 DAOS_OPC_POOL_QUERY_INFO,
46 DAOS_OPC_POOL_LIST_ATTR,
47 DAOS_OPC_POOL_GET_ATTR,
48 DAOS_OPC_POOL_SET_ATTR,
49 DAOS_OPC_POOL_DEL_ATTR,
50 DAOS_OPC_POOL_STOP_SVC,
51 DAOS_OPC_POOL_LIST_CONT,
52
54 DAOS_OPC_CONT_CREATE = 18,
55 DAOS_OPC_CONT_OPEN,
56 DAOS_OPC_CONT_CLOSE,
57 DAOS_OPC_CONT_DESTROY,
58 DAOS_OPC_CONT_QUERY,
59 DAOS_OPC_CONT_SET_PROP,
60 DAOS_OPC_CONT_UPDATE_ACL,
61 DAOS_OPC_CONT_DELETE_ACL,
62 DAOS_OPC_CONT_AGGREGATE,
63 DAOS_OPC_CONT_ROLLBACK,
64 DAOS_OPC_CONT_SUBSCRIBE,
65 DAOS_OPC_CONT_LIST_ATTR,
66 DAOS_OPC_CONT_GET_ATTR,
67 DAOS_OPC_CONT_SET_ATTR,
68 DAOS_OPC_CONT_DEL_ATTR,
69 DAOS_OPC_CONT_ALLOC_OIDS,
70 DAOS_OPC_CONT_LIST_SNAP,
71 DAOS_OPC_CONT_CREATE_SNAP,
72 DAOS_OPC_CONT_DESTROY_SNAP,
73
75 DAOS_OPC_TX_OPEN = 37,
76 DAOS_OPC_TX_COMMIT,
77 DAOS_OPC_TX_ABORT,
78 DAOS_OPC_TX_OPEN_SNAP,
79 DAOS_OPC_TX_CLOSE,
80 DAOS_OPC_TX_RESTART,
81
83 DAOS_OPC_OBJ_QUERY_CLASS = 44,
84 DAOS_OPC_OBJ_LIST_CLASS,
85 DAOS_OPC_OBJ_OPEN,
86 DAOS_OPC_OBJ_CLOSE,
87 DAOS_OPC_OBJ_PUNCH,
88 DAOS_OPC_OBJ_PUNCH_DKEYS,
89 DAOS_OPC_OBJ_PUNCH_AKEYS,
90 DAOS_OPC_OBJ_QUERY,
91 DAOS_OPC_OBJ_QUERY_KEY,
92 DAOS_OPC_OBJ_SYNC,
93 DAOS_OPC_OBJ_FETCH,
94 DAOS_OPC_OBJ_UPDATE,
95 DAOS_OPC_OBJ_LIST_DKEY,
96 DAOS_OPC_OBJ_LIST_AKEY,
97 DAOS_OPC_OBJ_LIST_RECX,
98 DAOS_OPC_OBJ_LIST_OBJ,
99
101 DAOS_OPC_ARRAY_CREATE = 60,
102 DAOS_OPC_ARRAY_OPEN,
103 DAOS_OPC_ARRAY_CLOSE,
104 DAOS_OPC_ARRAY_DESTROY,
105 DAOS_OPC_ARRAY_READ,
106 DAOS_OPC_ARRAY_WRITE,
107 DAOS_OPC_ARRAY_PUNCH,
108 DAOS_OPC_ARRAY_GET_SIZE,
109 DAOS_OPC_ARRAY_SET_SIZE,
110
112 DAOS_OPC_KV_OPEN = 69,
113 DAOS_OPC_KV_CLOSE,
114 DAOS_OPC_KV_DESTROY,
115 DAOS_OPC_KV_GET,
116 DAOS_OPC_KV_PUT,
117 DAOS_OPC_KV_REMOVE,
118 DAOS_OPC_KV_LIST,
119
120 DAOS_OPC_MAX
121} daos_opc_t;
122
124typedef struct {
126 const char *grp;
128 d_rank_t rank;
130 uint32_t key_id;
132 uint64_t value;
134 uint64_t value_extra;
136
138typedef struct {
143 uuid_t uuid;
145 const char *grp;
147 unsigned int flags;
153 const char *pool;
155
161
163typedef struct {
165 uuid_t uuid;
167 const char *grp;
169 d_rank_list_t *svc;
173
183
195
207
217
219typedef struct {
223 char *buf;
225 size_t *size;
227
229typedef struct {
233 int n;
235 char const *const *names;
237 void *const *values;
239 size_t *sizes;
241
243typedef struct {
247 int n;
249 char const *const *names;
251 void const *const *values;
253 size_t const *sizes;
255
257typedef struct {
261 int n;
263 char const *const *names;
265
267typedef struct {
269 uuid_t uuid;
271 const char *group;
273 d_rank_list_t *targets;
275 d_rank_list_t *failed;
277
279typedef struct {
280 const char *grp;
281 uuid_t uuid;
282 int *state;
284
290
305
307typedef struct {
314 uuid_t uuid;
316 unsigned int flags;
322 const char *cont;
324
330
332typedef struct {
339 uuid_t uuid;
341 int force;
343 const char *cont;
345
355
363
371
373typedef struct {
377 uint8_t type;
379 d_string_t name;
381
383typedef struct {
387 daos_epoch_t epoch;
389
391typedef struct {
395 daos_epoch_t epoch;
397
399typedef struct {
402 /*
403 * [in]: epoch of snapshot to wait for.
404 * [out]: epoch of persistent snapshot taken.
405 */
406 daos_epoch_t *epoch;
408
410typedef struct {
414 char *buf;
416 size_t *size;
418
420typedef struct {
424 int n;
426 char const *const *names;
428 void *const *values;
430 size_t *sizes;
432
434typedef struct {
438 int n;
440 char const *const *names;
442 void const *const *values;
444 size_t const *sizes;
446
448typedef struct {
452 int n;
454 char const *const *names;
456
458typedef struct {
462 daos_size_t num_oids;
464 uint64_t *oid;
466
468typedef struct {
471 /*
472 * [in]: Number of snapshots in epochs and names.
473 * [out]: Actual number of snapshots returned
474 */
475 int *nr;
477 daos_epoch_t *epochs;
479 char **names;
483
485typedef struct {
489 unsigned int opts;
491 daos_epoch_t *epoch;
493 char *name;
495
503
513
515typedef struct {
519 uint32_t flags;
521
523typedef struct {
527
537
539typedef struct {
543
545typedef struct {
549
551typedef struct {
555 daos_oclass_id_t cid;
559
569
581
583typedef struct {
587
588/*
589 * Object & Object Key Punch args.
590 * NB:
591 * - If @dkey is NULL, it is parameter for object punch.
592 * - If @akeys is NULL, it is parameter for dkey punch.
593 * - API allows user to punch multiple dkeys, in this case, client module needs
594 * to allocate multiple instances of this data structure.
595 */
596typedef struct {
602 daos_key_t *dkey;
604 daos_key_t *akeys;
606 uint64_t flags;
608 unsigned int akey_nr;
610
612typedef struct {
620 d_rank_list_t *ranks;
622
624typedef struct {
629 /*
630 * [in]: allocated integer dkey.
631 * [out]: max or min dkey (if flag includes dkey query).
632 */
633 daos_key_t *dkey;
634 /*
635 * [in]: allocated integer akey.
636 * [out]: max or min akey (if flag includes akey query).
637 */
638 daos_key_t *akey;
642 uint64_t flags;
644
646typedef struct {
652 uint64_t flags;
654 daos_key_t *dkey;
656 uint32_t nr;
658 uint32_t extra_flags;
662 d_sg_list_t *sgls;
670 d_iov_t *csum_iov;
672
677
683 daos_epoch_t epoch;
685 daos_epoch_t **epochs_p;
687 int *nr;
688};
689
691typedef struct {
697 daos_key_t *dkey;
699 daos_key_t *akey;
701 uint32_t *nr;
705 d_sg_list_t *sgl;
707 daos_size_t *size;
709 daos_iod_type_t type;
714 /* anchors for obj list -
715 * list_dkey uses dkey_anchor,
716 * list_akey uses akey_anchor,
717 * list_recx uses anchor,
718 * list_obj uses all the 3 anchors.
719 */
720 daos_anchor_t *anchor;
726 uint32_t *versions;
730 d_iov_t *csum;
734
745
757
774
794
810
830
836
848
858
868
876
888
890typedef struct {
894
902
904typedef struct {
910 uint64_t flags;
912 const char *key;
914 daos_size_t *buf_size;
916 void *buf;
918
920typedef struct {
926 uint64_t flags;
928 const char *key;
930 daos_size_t buf_size;
932 const void *buf;
934
936typedef struct {
942 uint64_t flags;
944 const char *key;
946
948typedef struct {
953 /*
954 * [in]: number of key descriptors in \a kds.
955 * [out]: number of returned key descriptors.
956 */
957 uint32_t *nr;
961 d_sg_list_t *sgl;
965
990int
991daos_task_create(daos_opc_t opc, tse_sched_t *sched,
992 unsigned int num_deps, tse_task_t *dep_tasks[],
993 tse_task_t **taskp);
994
1009int
1010daos_task_reset(tse_task_t *task, daos_opc_t opc);
1011
1022void *
1023daos_task_get_args(tse_task_t *task);
1024
1033void *
1034daos_task_get_priv(tse_task_t *task);
1035
1044void *
1045daos_task_set_priv(tse_task_t *task, void *priv);
1046
1060int
1061daos_progress(tse_sched_t *sched, int64_t timeout, bool *is_empty);
1062
1063#if defined(__cplusplus)
1064}
1065#endif
1066
1067#endif /* __DAOS_TASK_H__ */
daos_handle_t oh
Definition daos_task.h:834
daos_size_t chunk_size
Definition daos_task.h:806
daos_handle_t coh
Definition daos_task.h:798
daos_handle_t th
Definition daos_task.h:802
daos_obj_id_t oid
Definition daos_task.h:800
daos_size_t cell_size
Definition daos_task.h:804
daos_handle_t * oh
Definition daos_task.h:808
daos_handle_t th
Definition daos_task.h:874
daos_handle_t oh
Definition daos_task.h:872
daos_size_t * size
Definition daos_task.h:856
daos_handle_t th
Definition daos_task.h:854
daos_handle_t oh
Definition daos_task.h:852
d_sg_list_t * sgl
Definition daos_task.h:846
daos_handle_t th
Definition daos_task.h:842
daos_array_iod_t * iod
Definition daos_task.h:844
daos_handle_t oh
Definition daos_task.h:840
daos_size_t * chunk_size
Definition daos_task.h:826
daos_size_t * cell_size
Definition daos_task.h:824
daos_handle_t coh
Definition daos_task.h:814
daos_handle_t th
Definition daos_task.h:818
daos_obj_id_t oid
Definition daos_task.h:816
unsigned int open_with_attr
Definition daos_task.h:822
daos_handle_t * oh
Definition daos_task.h:828
unsigned int mode
Definition daos_task.h:820
daos_handle_t th
Definition daos_task.h:864
daos_handle_t oh
Definition daos_task.h:862
daos_epoch_t epoch
Definition daos_task.h:387
daos_handle_t coh
Definition daos_task.h:385
daos_handle_t coh
Definition daos_task.h:460
daos_handle_t coh
Definition daos_task.h:328
daos_epoch_t * epoch
Definition daos_task.h:491
daos_prop_t * prop
Definition daos_task.h:301
daos_handle_t poh
Definition daos_task.h:294
daos_handle_t coh
Definition daos_task.h:450
char const *const * names
Definition daos_task.h:454
daos_handle_t coh
Definition daos_task.h:375
daos_epoch_range_t epr
Definition daos_task.h:501
const char * cont
Definition daos_task.h:343
daos_handle_t poh
Definition daos_task.h:334
daos_handle_t coh
Definition daos_task.h:422
void *const * values
Definition daos_task.h:428
char const *const * names
Definition daos_task.h:426
daos_handle_t coh
Definition daos_task.h:412
daos_handle_t coh
Definition daos_task.h:470
daos_anchor_t * anchor
Definition daos_task.h:481
daos_epoch_t * epochs
Definition daos_task.h:477
const char * cont
Definition daos_task.h:322
daos_handle_t * coh
Definition daos_task.h:318
unsigned int flags
Definition daos_task.h:316
daos_handle_t poh
Definition daos_task.h:309
daos_cont_info_t * info
Definition daos_task.h:320
daos_handle_t coh
Definition daos_task.h:349
daos_prop_t * prop
Definition daos_task.h:353
daos_cont_info_t * info
Definition daos_task.h:351
daos_epoch_t epoch
Definition daos_task.h:395
daos_handle_t coh
Definition daos_task.h:393
daos_handle_t coh
Definition daos_task.h:436
void const *const * values
Definition daos_task.h:442
size_t const * sizes
Definition daos_task.h:444
char const *const * names
Definition daos_task.h:440
daos_handle_t coh
Definition daos_task.h:359
daos_prop_t * prop
Definition daos_task.h:361
daos_handle_t coh
Definition daos_task.h:401
daos_handle_t coh
Definition daos_task.h:367
struct daos_acl * acl
Definition daos_task.h:369
daos_handle_t oh
Definition daos_task.h:892
daos_handle_t th
Definition daos_task.h:900
daos_handle_t oh
Definition daos_task.h:898
daos_size_t * buf_size
Definition daos_task.h:914
uint64_t flags
Definition daos_task.h:910
daos_handle_t th
Definition daos_task.h:908
const char * key
Definition daos_task.h:912
daos_handle_t oh
Definition daos_task.h:906
d_sg_list_t * sgl
Definition daos_task.h:961
daos_handle_t th
Definition daos_task.h:952
daos_anchor_t * anchor
Definition daos_task.h:963
daos_key_desc_t * kds
Definition daos_task.h:959
daos_handle_t oh
Definition daos_task.h:950
daos_handle_t coh
Definition daos_task.h:880
daos_obj_id_t oid
Definition daos_task.h:882
daos_handle_t * oh
Definition daos_task.h:886
unsigned int mode
Definition daos_task.h:884
const void * buf
Definition daos_task.h:932
uint64_t flags
Definition daos_task.h:926
daos_handle_t th
Definition daos_task.h:924
const char * key
Definition daos_task.h:928
daos_handle_t oh
Definition daos_task.h:922
daos_size_t buf_size
Definition daos_task.h:930
daos_handle_t th
Definition daos_task.h:940
const char * key
Definition daos_task.h:944
daos_handle_t oh
Definition daos_task.h:938
daos_handle_t oh
Definition daos_task.h:585
struct daos_oclass_list * clist
Definition daos_task.h:565
daos_handle_t coh
Definition daos_task.h:563
daos_anchor_t * anchor
Definition daos_task.h:567
d_sg_list_t * sgl
Definition daos_task.h:705
uint32_t * nr
Definition daos_task.h:701
d_iov_t * csum
Definition daos_task.h:730
daos_size_t * size
Definition daos_task.h:707
daos_recx_t * recxs
Definition daos_task.h:711
uint32_t * versions
Definition daos_task.h:726
daos_anchor_t * dkey_anchor
Definition daos_task.h:722
daos_handle_t th
Definition daos_task.h:695
daos_key_t * akey
Definition daos_task.h:699
daos_key_t * dkey
Definition daos_task.h:697
daos_epoch_range_t * eprs
Definition daos_task.h:713
daos_iod_type_t type
Definition daos_task.h:709
daos_key_desc_t * kds
Definition daos_task.h:703
daos_anchor_t * akey_anchor
Definition daos_task.h:724
daos_handle_t oh
Definition daos_task.h:693
daos_handle_t coh
Definition daos_task.h:573
daos_obj_id_t oid
Definition daos_task.h:575
daos_handle_t * oh
Definition daos_task.h:579
unsigned int mode
Definition daos_task.h:577
unsigned int akey_nr
Definition daos_task.h:608
daos_handle_t th
Definition daos_task.h:598
daos_key_t * dkey
Definition daos_task.h:602
daos_key_t * akeys
Definition daos_task.h:604
daos_handle_t oh
Definition daos_task.h:600
daos_oclass_id_t cid
Definition daos_task.h:555
daos_handle_t coh
Definition daos_task.h:553
struct daos_oclass_attr * cattr
Definition daos_task.h:557
daos_handle_t th
Definition daos_task.h:628
daos_recx_t * recx
Definition daos_task.h:640
daos_handle_t oh
Definition daos_task.h:626
struct daos_obj_attr * oa
Definition daos_task.h:618
d_rank_list_t * ranks
Definition daos_task.h:620
daos_handle_t th
Definition daos_task.h:616
daos_handle_t oh
Definition daos_task.h:614
daos_oclass_id_t cid
Definition daos_task.h:179
struct daos_oclass_attr * cattr
Definition daos_task.h:181
daos_iod_t * iods
Definition daos_task.h:660
uint32_t nr
Definition daos_task.h:656
d_iov_t * csum_iov
Definition daos_task.h:670
void * extra_arg
Definition daos_task.h:666
uint64_t flags
Definition daos_task.h:652
daos_handle_t th
Definition daos_task.h:648
daos_iom_t * ioms
Definition daos_task.h:664
daos_key_t * dkey
Definition daos_task.h:654
uint32_t extra_flags
Definition daos_task.h:658
daos_handle_t oh
Definition daos_task.h:650
d_sg_list_t * sgls
Definition daos_task.h:662
daos_epoch_t epoch
Definition daos_task.h:683
daos_handle_t oh
Definition daos_task.h:681
daos_epoch_t ** epochs_p
Definition daos_task.h:685
const char * pool
Definition daos_task.h:153
const char * grp
Definition daos_task.h:145
daos_handle_t * poh
Definition daos_task.h:149
daos_pool_info_t * info
Definition daos_task.h:151
unsigned int flags
Definition daos_task.h:147
char const *const * names
Definition daos_task.h:263
daos_handle_t poh
Definition daos_task.h:259
daos_handle_t poh
Definition daos_task.h:159
void *const * values
Definition daos_task.h:237
char const *const * names
Definition daos_task.h:235
daos_handle_t poh
Definition daos_task.h:231
daos_handle_t poh
Definition daos_task.h:221
struct daos_pool_cont_info * cont_buf
Definition daos_task.h:215
daos_size_t * ncont
Definition daos_task.h:213
daos_handle_t poh
Definition daos_task.h:211
daos_prop_t * prop
Definition daos_task.h:193
d_rank_list_t * tgts
Definition daos_task.h:189
daos_pool_info_t * info
Definition daos_task.h:191
daos_handle_t poh
Definition daos_task.h:187
daos_target_info_t * info
Definition daos_task.h:205
d_rank_list_t * failed
Definition daos_task.h:275
const char * group
Definition daos_task.h:271
d_rank_list_t * targets
Definition daos_task.h:273
void const *const * values
Definition daos_task.h:251
size_t const * sizes
Definition daos_task.h:253
char const *const * names
Definition daos_task.h:249
daos_handle_t poh
Definition daos_task.h:245
daos_handle_t poh
Definition daos_task.h:288
struct d_tgt_list * tgts
Definition daos_task.h:171
const char * grp
Definition daos_task.h:167
d_rank_list_t * svc
Definition daos_task.h:169
const char * grp
Definition daos_task.h:126
uint64_t value_extra
Definition daos_task.h:134
daos_handle_t th
Definition daos_task.h:525
daos_handle_t th
Definition daos_task.h:541
daos_handle_t th
Definition daos_task.h:517
daos_epoch_t epoch
Definition daos_task.h:533
daos_handle_t coh
Definition daos_task.h:531
daos_handle_t * th
Definition daos_task.h:535
daos_handle_t coh
Definition daos_task.h:507
uint64_t flags
Definition daos_task.h:511
daos_handle_t * th
Definition daos_task.h:509
daos_handle_t th
Definition daos_task.h:547