11#ifndef __DAOS_PROP_H__
12#define __DAOS_PROP_H__
14#if defined(__cplusplus)
19#include <daos_types.h>
43 DAOS_PROP_PO_SPACE_RB,
49 DAOS_PROP_PO_SELF_HEAL,
66 DAOS_PROP_PO_OWNER_GROUP,
70 DAOS_PROP_PO_SVC_LIST,
74 DAOS_PROP_PO_EC_CELL_SZ,
78 DAOS_PROP_PO_DATA_THRESH,
82 DAOS_PROP_PO_REDUN_FAC,
97 DAOS_PROP_PO_GLOBAL_VERSION,
101 DAOS_PROP_PO_UPGRADE_STATUS,
108 DAOS_PROP_PO_SCRUB_MODE,
114 DAOS_PROP_PO_SCRUB_FREQ,
120 DAOS_PROP_PO_SCRUB_THRESH,
124 DAOS_PROP_PO_SVC_REDUN_FAC,
126 DAOS_PROP_PO_OBJ_VERSION,
130 DAOS_PROP_PO_PERF_DOMAIN,
132 DAOS_PROP_PO_CHECKPOINT_MODE,
134 DAOS_PROP_PO_CHECKPOINT_FREQ,
136 DAOS_PROP_PO_CHECKPOINT_THRESH,
138 DAOS_PROP_PO_REINT_MODE,
140 DAOS_PROP_PO_SVC_OPS_ENABLED,
142 DAOS_PROP_PO_SVC_OPS_ENTRY_AGE,
146#define DAOS_PROP_PO_NUM (DAOS_PROP_PO_MAX - DAOS_PROP_PO_MIN - 1)
148#define DAOS_PROP_PO_EC_CELL_SZ_MIN (1UL << 10)
149#define DAOS_PROP_PO_EC_CELL_SZ_MAX (1UL << 30)
151#define DAOS_PROP_PO_REDUN_FAC_MAX 4
152#define DAOS_PROP_PO_REDUN_FAC_DEFAULT 0
155daos_rf_is_valid(
unsigned long long rf)
157 return rf <= DAOS_PROP_PO_REDUN_FAC_MAX;
160#define DAOS_PROP_PDA_MAX ((uint32_t)-1)
167#define DAOS_PROP_PO_RP_PDA_DEFAULT DAOS_PROP_PDA_MAX
172#define DAOS_PROP_PO_EC_PDA_DEFAULT ((uint32_t)1)
176 DAOS_UPGRADE_STATUS_NOT_STARTED = 0,
177 DAOS_UPGRADE_STATUS_IN_PROGRESS = 1,
178 DAOS_UPGRADE_STATUS_COMPLETED = 2,
179 DAOS_UPGRADE_STATUS_FAILED = 3,
182#define DAOS_PROP_PO_SVC_REDUN_FAC_MAX 4
183#define DAOS_PROP_PO_SVC_REDUN_FAC_DEFAULT 2
186daos_svc_rf_is_valid(uint64_t svc_rf)
188 return svc_rf <= DAOS_PROP_PO_SVC_REDUN_FAC_MAX;
195 DAOS_PROP_PERF_DOMAIN_ROOT = 255,
196 DAOS_PROP_PERF_DOMAIN_GROUP = 3,
202#define DAOS_PROP_PO_PERF_DOMAIN_DEFAULT DAOS_PROP_PERF_DOMAIN_ROOT
203#define DAOS_PROP_CO_PERF_DOMAIN_DEFAULT DAOS_PROP_PERF_DOMAIN_ROOT
208#define DAOS_PROP_PO_NUM (DAOS_PROP_PO_MAX - DAOS_PROP_PO_MIN - 1)
212 DAOS_RECLAIM_DISABLED = 0,
214 DAOS_RECLAIM_SNAPSHOT,
220 DAOS_REINT_MODE_DATA_SYNC = 0,
221 DAOS_REINT_MODE_NO_DATA_SYNC = 1,
227#define DAOS_PROP_PO_REINT_MODE_DEFAULT DAOS_REINT_MODE_DATA_SYNC
234 DAOS_SCRUB_MODE_OFF = 0,
235 DAOS_SCRUB_MODE_LAZY = 1,
236 DAOS_SCRUB_MODE_TIMED = 2,
237 DAOS_SCRUB_MODE_INVALID = 3,
241#define DAOS_PROP_PO_SCRUB_MODE_DEFAULT DAOS_SCRUB_MODE_OFF
243#define DAOS_PROP_PO_SCRUB_FREQ_DEFAULT 604800
244#define DAOS_PROP_PO_SCRUB_THRESH_DEFAULT 0
248 DAOS_CHECKPOINT_DISABLED = 0,
249 DAOS_CHECKPOINT_TIMED,
250 DAOS_CHECKPOINT_LAZY,
253#define DAOS_PROP_PO_CHECKPOINT_MODE_DEFAULT DAOS_CHECKPOINT_TIMED
254#define DAOS_PROP_PO_CHECKPOINT_FREQ_DEFAULT 5
255#define DAOS_PROP_PO_CHECKPOINT_FREQ_MIN 1
256#define DAOS_PROP_PO_CHECKPOINT_FREQ_MAX (1 << 20)
257#define DAOS_PROP_PO_CHECKPOINT_THRESH_DEFAULT 50
258#define DAOS_PROP_PO_CHECKPOINT_THRESH_MAX 75
259#define DAOS_PROP_PO_CHECKPOINT_THRESH_MIN 10
260#define DAOS_PROP_PO_SVC_OPS_ENABLED_DEFAULT 1
261#define DAOS_PROP_PO_SVC_OPS_ENTRY_AGE_DEFAULT 300
262#define DAOS_PROP_PO_SVC_OPS_ENTRY_AGE_MIN 60
263#define DAOS_PROP_PO_SVC_OPS_ENTRY_AGE_MAX 600
266#define DAOS_SELF_HEAL_AUTO_EXCLUDE (1U << 0)
267#define DAOS_SELF_HEAL_AUTO_REBUILD (1U << 1)
268#define DAOS_SELF_HEAL_DELAY_REBUILD (1U << 2)
274enum daos_cont_props {
275 DAOS_PROP_CO_MIN = 0x1000,
285 DAOS_PROP_CO_LAYOUT_TYPE,
290 DAOS_PROP_CO_LAYOUT_VER,
300 DAOS_PROP_CO_CSUM_CHUNK_SIZE,
305 DAOS_PROP_CO_CSUM_SERVER_VERIFY,
311 DAOS_PROP_CO_REDUN_FAC,
316 DAOS_PROP_CO_REDUN_LVL,
320 DAOS_PROP_CO_SNAPSHOT_MAX,
333 DAOS_PROP_CO_COMPRESS,
343 DAOS_PROP_CO_ENCRYPT,
353 DAOS_PROP_CO_OWNER_GROUP,
365 DAOS_PROP_CO_DEDUP_THRESHOLD,
374 DAOS_PROP_CO_ALLOCED_OID,
376 DAOS_PROP_CO_EC_CELL_SZ,
382 DAOS_PROP_CO_GLOBAL_VERSION,
384 DAOS_PROP_CO_SCRUBBER_DISABLED,
386 DAOS_PROP_CO_OBJ_VERSION,
388 DAOS_PROP_CO_PERF_DOMAIN,
401#define DAOS_PROP_CO_NUM (DAOS_PROP_CO_MAX - DAOS_PROP_CO_MIN - 1)
403typedef uint16_t daos_cont_layout_t;
407 DAOS_PROP_CO_LAYOUT_UNKNOWN,
408 DAOS_PROP_CO_LAYOUT_UNKOWN = DAOS_PROP_CO_LAYOUT_UNKNOWN,
409 DAOS_PROP_CO_LAYOUT_POSIX,
410 DAOS_PROP_CO_LAYOUT_HDF5,
411 DAOS_PROP_CO_LAYOUT_PYTHON,
412 DAOS_PROP_CO_LAYOUT_SPARK,
413 DAOS_PROP_CO_LAYOUT_DATABASE,
414 DAOS_PROP_CO_LAYOUT_ROOT,
415 DAOS_PROP_CO_LAYOUT_SEISMIC,
416 DAOS_PROP_CO_LAYOUT_METEO,
417 DAOS_PROP_CO_LAYOUT_MAX
422 DAOS_PROP_CO_CSUM_OFF,
423 DAOS_PROP_CO_CSUM_CRC16,
424 DAOS_PROP_CO_CSUM_CRC32,
425 DAOS_PROP_CO_CSUM_CRC64,
426 DAOS_PROP_CO_CSUM_SHA1,
427 DAOS_PROP_CO_CSUM_SHA256,
428 DAOS_PROP_CO_CSUM_SHA512,
429 DAOS_PROP_CO_CSUM_ADLER32
434 DAOS_PROP_CO_CSUM_SV_OFF,
435 DAOS_PROP_CO_CSUM_SV_ON
440 DAOS_PROP_CO_DEDUP_OFF,
441 DAOS_PROP_CO_DEDUP_MEMCMP,
442 DAOS_PROP_CO_DEDUP_HASH
447 DAOS_PROP_CO_COMPRESS_OFF,
448 DAOS_PROP_CO_COMPRESS_LZ4,
449 DAOS_PROP_CO_COMPRESS_DEFLATE,
450 DAOS_PROP_CO_COMPRESS_DEFLATE1,
451 DAOS_PROP_CO_COMPRESS_DEFLATE2,
452 DAOS_PROP_CO_COMPRESS_DEFLATE3,
453 DAOS_PROP_CO_COMPRESS_DEFLATE4,
458 DAOS_PROP_CO_ENCRYPT_OFF,
459 DAOS_PROP_CO_ENCRYPT_AES_XTS128,
460 DAOS_PROP_CO_ENCRYPT_AES_XTS256,
461 DAOS_PROP_CO_ENCRYPT_AES_CBC128,
462 DAOS_PROP_CO_ENCRYPT_AES_CBC192,
463 DAOS_PROP_CO_ENCRYPT_AES_CBC256,
464 DAOS_PROP_CO_ENCRYPT_AES_GCM128,
465 DAOS_PROP_CO_ENCRYPT_AES_GCM256
470 DAOS_PROP_CO_REDUN_RF0 = 0,
471 DAOS_PROP_CO_REDUN_RF1 = 1,
472 DAOS_PROP_CO_REDUN_RF2 = 2,
473 DAOS_PROP_CO_REDUN_RF3 = 3,
474 DAOS_PROP_CO_REDUN_RF4 = 4,
483 DAOS_PROP_CO_REDUN_MIN = 1,
485 DAOS_PROP_CO_REDUN_RANK = 1,
487 DAOS_PROP_CO_REDUN_NODE = 2,
488 DAOS_PROP_CO_REDUN_MAX = 254,
492#define DAOS_PROP_CO_REDUN_DEFAULT DAOS_PROP_CO_REDUN_NODE
497 DAOS_PROP_CO_HEALTHY,
503 DAOS_PROP_CO_UNCLEAN,
507#define DAOS_PROP_CO_CLEAR (0x1)
519#define DAOS_PROP_CO_STATUS_VAL(status, flag, pm_ver) \
520 ((((uint64_t)(flag)) << 48) | \
521 (((uint64_t)(status) & 0xFFFF) << 32) | \
522 ((uint64_t)(pm_ver)))
524static inline uint64_t
527 return DAOS_PROP_CO_STATUS_VAL(co_status->
dcs_status,
533daos_prop_val_2_co_status(uint64_t val,
struct daos_co_status *co_status)
535 co_status->
dcs_flags = (uint16_t)(val >> 48);
536 co_status->
dcs_status = (uint16_t)((val >> 32) & 0xFFFF);
537 co_status->
dcs_pm_ver = (uint32_t)(val & 0xFFFFFFFF);
541 DAOS_PROP_ENTRY_NOT_SET = (1 << 0),
564#define DAOS_PROP_ENTRIES_MAX_NR (128)
567#define DAOS_PROP_LABEL_MAX_LEN (127)
569#define DAOS_PROP_MAX_LABEL_BUF_LEN (DAOS_PROP_LABEL_MAX_LEN + 1)
572#define DAOS_PROP_CO_LABEL_DEFAULT "container_label_not_set"
573#define DAOS_PROP_PO_LABEL_DEFAULT "pool_label_not_set"
587daos_label_is_valid(
const char *label)
591 bool maybe_uuid =
false;
598 len = strnlen(label, DAOS_PROP_LABEL_MAX_LEN + 1);
599 if (len == 0 || len > DAOS_PROP_LABEL_MAX_LEN)
603 for (i = 0; i < len; i++) {
606 if (isalnum(c) || c ==
'.' || c ==
'_' || c ==
':')
617 if (maybe_uuid && daos_is_valid_uuid_string(label))
624#define DAOS_PROP_PO_DATA_THRESH_DEFAULT (1UL << 12)
627#define DAOS_PROP_NO_PO_LABEL "pool_label_not_set"
630#define DEFAULT_CONT_LABEL "container_label_not_set"
633#define DAOS_PROP_NO_CO_LABEL DEFAULT_CONT_LABEL
640daos_perf_domain_is_valid(
const char *perf_domain)
642 return daos_label_is_valid(perf_domain);
663daos_prop_alloc(uint32_t entries_nr);
695daos_prop_from_str(
const char *str, daos_size_t len,
daos_prop_t **prop);
730daos_prop_entry_get(
daos_prop_t *prop, uint32_t type);
745daos_prop_set_str(
daos_prop_t *prop, uint32_t type,
const char *str, daos_size_t len);
756daos_prop_entry_set_str(
struct daos_prop_entry *entry,
const char *str, daos_size_t len);
771daos_prop_set_ptr(
daos_prop_t *prop, uint32_t type,
const void *ptr, daos_size_t size);
782daos_prop_entry_set_ptr(
struct daos_prop_entry *entry,
const void *ptr, daos_size_t size);
859 if (entry->
dpe_flags & DAOS_PROP_ENTRY_NOT_SET)
865#if defined(__cplusplus)
struct daos_prop_entry * dpp_entries