10#ifndef __DAOS_PROP_H__
11#define __DAOS_PROP_H__
13#if defined(__cplusplus)
18#include <daos_types.h>
42 DAOS_PROP_PO_SPACE_RB,
48 DAOS_PROP_PO_SELF_HEAL,
65 DAOS_PROP_PO_OWNER_GROUP,
69 DAOS_PROP_PO_SVC_LIST,
73 DAOS_PROP_PO_EC_CELL_SZ,
77 DAOS_PROP_PO_DATA_THRESH,
81 DAOS_PROP_PO_REDUN_FAC,
96 DAOS_PROP_PO_GLOBAL_VERSION,
100 DAOS_PROP_PO_UPGRADE_STATUS,
107 DAOS_PROP_PO_SCRUB_MODE,
113 DAOS_PROP_PO_SCRUB_FREQ,
119 DAOS_PROP_PO_SCRUB_THRESH,
123 DAOS_PROP_PO_SVC_REDUN_FAC,
125 DAOS_PROP_PO_OBJ_VERSION,
129 DAOS_PROP_PO_PERF_DOMAIN,
131 DAOS_PROP_PO_CHECKPOINT_MODE,
133 DAOS_PROP_PO_CHECKPOINT_FREQ,
135 DAOS_PROP_PO_CHECKPOINT_THRESH,
137 DAOS_PROP_PO_REINT_MODE,
139 DAOS_PROP_PO_SVC_OPS_ENABLED,
141 DAOS_PROP_PO_SVC_OPS_ENTRY_AGE,
145#define DAOS_PROP_PO_EC_CELL_SZ_MIN (1UL << 10)
146#define DAOS_PROP_PO_EC_CELL_SZ_MAX (1UL << 30)
148#define DAOS_PROP_PO_REDUN_FAC_MAX 4
149#define DAOS_PROP_PO_REDUN_FAC_DEFAULT 0
152daos_rf_is_valid(
unsigned long long rf)
154 return rf <= DAOS_PROP_PO_REDUN_FAC_MAX;
157#define DAOS_PROP_PDA_MAX ((uint32_t)-1)
164#define DAOS_PROP_PO_RP_PDA_DEFAULT DAOS_PROP_PDA_MAX
169#define DAOS_PROP_PO_EC_PDA_DEFAULT ((uint32_t)1)
173 DAOS_UPGRADE_STATUS_NOT_STARTED = 0,
174 DAOS_UPGRADE_STATUS_IN_PROGRESS = 1,
175 DAOS_UPGRADE_STATUS_COMPLETED = 2,
176 DAOS_UPGRADE_STATUS_FAILED = 3,
179#define DAOS_PROP_PO_SVC_REDUN_FAC_MAX 4
180#define DAOS_PROP_PO_SVC_REDUN_FAC_DEFAULT 2
183daos_svc_rf_is_valid(uint64_t svc_rf)
185 return svc_rf <= DAOS_PROP_PO_SVC_REDUN_FAC_MAX;
192 DAOS_PROP_PERF_DOMAIN_ROOT = 255,
193 DAOS_PROP_PERF_DOMAIN_GROUP = 3,
199#define DAOS_PROP_PO_PERF_DOMAIN_DEFAULT DAOS_PROP_PERF_DOMAIN_ROOT
200#define DAOS_PROP_CO_PERF_DOMAIN_DEFAULT DAOS_PROP_PERF_DOMAIN_ROOT
205#define DAOS_PROP_PO_NUM (DAOS_PROP_PO_MAX - DAOS_PROP_PO_MIN - 1)
209 DAOS_RECLAIM_DISABLED = 0,
211 DAOS_RECLAIM_SNAPSHOT,
217 DAOS_REINT_MODE_DATA_SYNC = 0,
218 DAOS_REINT_MODE_NO_DATA_SYNC = 1,
224#define DAOS_PROP_PO_REINT_MODE_DEFAULT DAOS_REINT_MODE_DATA_SYNC
231 DAOS_SCRUB_MODE_OFF = 0,
232 DAOS_SCRUB_MODE_LAZY = 1,
233 DAOS_SCRUB_MODE_TIMED = 2,
234 DAOS_SCRUB_MODE_INVALID = 3,
238#define DAOS_PROP_PO_SCRUB_MODE_DEFAULT DAOS_SCRUB_MODE_OFF
240#define DAOS_PROP_PO_SCRUB_FREQ_DEFAULT 604800
241#define DAOS_PROP_PO_SCRUB_THRESH_DEFAULT 0
245 DAOS_CHECKPOINT_DISABLED = 0,
246 DAOS_CHECKPOINT_TIMED,
247 DAOS_CHECKPOINT_LAZY,
250#define DAOS_PROP_PO_CHECKPOINT_MODE_DEFAULT DAOS_CHECKPOINT_TIMED
251#define DAOS_PROP_PO_CHECKPOINT_FREQ_DEFAULT 5
252#define DAOS_PROP_PO_CHECKPOINT_FREQ_MIN 1
253#define DAOS_PROP_PO_CHECKPOINT_FREQ_MAX (1 << 20)
254#define DAOS_PROP_PO_CHECKPOINT_THRESH_DEFAULT 50
255#define DAOS_PROP_PO_CHECKPOINT_THRESH_MAX 75
256#define DAOS_PROP_PO_CHECKPOINT_THRESH_MIN 10
257#define DAOS_PROP_PO_SVC_OPS_ENABLED_DEFAULT 1
258#define DAOS_PROP_PO_SVC_OPS_ENTRY_AGE_DEFAULT 300
259#define DAOS_PROP_PO_SVC_OPS_ENTRY_AGE_MIN 60
260#define DAOS_PROP_PO_SVC_OPS_ENTRY_AGE_MAX 600
263#define DAOS_SELF_HEAL_AUTO_EXCLUDE (1U << 0)
264#define DAOS_SELF_HEAL_AUTO_REBUILD (1U << 1)
265#define DAOS_SELF_HEAL_DELAY_REBUILD (1U << 2)
271enum daos_cont_props {
272 DAOS_PROP_CO_MIN = 0x1000,
282 DAOS_PROP_CO_LAYOUT_TYPE,
287 DAOS_PROP_CO_LAYOUT_VER,
297 DAOS_PROP_CO_CSUM_CHUNK_SIZE,
302 DAOS_PROP_CO_CSUM_SERVER_VERIFY,
308 DAOS_PROP_CO_REDUN_FAC,
313 DAOS_PROP_CO_REDUN_LVL,
317 DAOS_PROP_CO_SNAPSHOT_MAX,
330 DAOS_PROP_CO_COMPRESS,
340 DAOS_PROP_CO_ENCRYPT,
350 DAOS_PROP_CO_OWNER_GROUP,
362 DAOS_PROP_CO_DEDUP_THRESHOLD,
371 DAOS_PROP_CO_ALLOCED_OID,
373 DAOS_PROP_CO_EC_CELL_SZ,
379 DAOS_PROP_CO_GLOBAL_VERSION,
381 DAOS_PROP_CO_SCRUBBER_DISABLED,
383 DAOS_PROP_CO_OBJ_VERSION,
385 DAOS_PROP_CO_PERF_DOMAIN,
398#define DAOS_PROP_CO_NUM (DAOS_PROP_CO_MAX - DAOS_PROP_CO_MIN - 1)
400typedef uint16_t daos_cont_layout_t;
404 DAOS_PROP_CO_LAYOUT_UNKNOWN,
405 DAOS_PROP_CO_LAYOUT_UNKOWN = DAOS_PROP_CO_LAYOUT_UNKNOWN,
406 DAOS_PROP_CO_LAYOUT_POSIX,
407 DAOS_PROP_CO_LAYOUT_HDF5,
408 DAOS_PROP_CO_LAYOUT_PYTHON,
409 DAOS_PROP_CO_LAYOUT_SPARK,
410 DAOS_PROP_CO_LAYOUT_DATABASE,
411 DAOS_PROP_CO_LAYOUT_ROOT,
412 DAOS_PROP_CO_LAYOUT_SEISMIC,
413 DAOS_PROP_CO_LAYOUT_METEO,
414 DAOS_PROP_CO_LAYOUT_MAX
419 DAOS_PROP_CO_CSUM_OFF,
420 DAOS_PROP_CO_CSUM_CRC16,
421 DAOS_PROP_CO_CSUM_CRC32,
422 DAOS_PROP_CO_CSUM_CRC64,
423 DAOS_PROP_CO_CSUM_SHA1,
424 DAOS_PROP_CO_CSUM_SHA256,
425 DAOS_PROP_CO_CSUM_SHA512,
426 DAOS_PROP_CO_CSUM_ADLER32
431 DAOS_PROP_CO_CSUM_SV_OFF,
432 DAOS_PROP_CO_CSUM_SV_ON
437 DAOS_PROP_CO_DEDUP_OFF,
438 DAOS_PROP_CO_DEDUP_MEMCMP,
439 DAOS_PROP_CO_DEDUP_HASH
444 DAOS_PROP_CO_COMPRESS_OFF,
445 DAOS_PROP_CO_COMPRESS_LZ4,
446 DAOS_PROP_CO_COMPRESS_DEFLATE,
447 DAOS_PROP_CO_COMPRESS_DEFLATE1,
448 DAOS_PROP_CO_COMPRESS_DEFLATE2,
449 DAOS_PROP_CO_COMPRESS_DEFLATE3,
450 DAOS_PROP_CO_COMPRESS_DEFLATE4,
455 DAOS_PROP_CO_ENCRYPT_OFF,
456 DAOS_PROP_CO_ENCRYPT_AES_XTS128,
457 DAOS_PROP_CO_ENCRYPT_AES_XTS256,
458 DAOS_PROP_CO_ENCRYPT_AES_CBC128,
459 DAOS_PROP_CO_ENCRYPT_AES_CBC192,
460 DAOS_PROP_CO_ENCRYPT_AES_CBC256,
461 DAOS_PROP_CO_ENCRYPT_AES_GCM128,
462 DAOS_PROP_CO_ENCRYPT_AES_GCM256
467 DAOS_PROP_CO_REDUN_RF0,
468 DAOS_PROP_CO_REDUN_RF1,
469 DAOS_PROP_CO_REDUN_RF2,
470 DAOS_PROP_CO_REDUN_RF3,
471 DAOS_PROP_CO_REDUN_RF4,
479 DAOS_PROP_CO_REDUN_MIN = 1,
481 DAOS_PROP_CO_REDUN_RANK = 1,
483 DAOS_PROP_CO_REDUN_NODE = 2,
484 DAOS_PROP_CO_REDUN_MAX = 254,
488#define DAOS_PROP_CO_REDUN_DEFAULT DAOS_PROP_CO_REDUN_NODE
493 DAOS_PROP_CO_HEALTHY,
499 DAOS_PROP_CO_UNCLEAN,
503#define DAOS_PROP_CO_CLEAR (0x1)
515#define DAOS_PROP_CO_STATUS_VAL(status, flag, pm_ver) \
516 ((((uint64_t)(flag)) << 48) | \
517 (((uint64_t)(status) & 0xFFFF) << 32) | \
518 ((uint64_t)(pm_ver)))
520static inline uint64_t
523 return DAOS_PROP_CO_STATUS_VAL(co_status->
dcs_status,
529daos_prop_val_2_co_status(uint64_t val,
struct daos_co_status *co_status)
531 co_status->
dcs_flags = (uint16_t)(val >> 48);
532 co_status->
dcs_status = (uint16_t)((val >> 32) & 0xFFFF);
533 co_status->
dcs_pm_ver = (uint32_t)(val & 0xFFFFFFFF);
537 DAOS_PROP_ENTRY_NOT_SET = (1 << 0),
560#define DAOS_PROP_ENTRIES_MAX_NR (128)
563#define DAOS_PROP_LABEL_MAX_LEN (127)
565#define DAOS_PROP_MAX_LABEL_BUF_LEN (DAOS_PROP_LABEL_MAX_LEN + 1)
568#define DAOS_PROP_CO_LABEL_DEFAULT "container_label_not_set"
569#define DAOS_PROP_PO_LABEL_DEFAULT "pool_label_not_set"
583daos_label_is_valid(
const char *label)
587 bool maybe_uuid =
false;
594 len = strnlen(label, DAOS_PROP_LABEL_MAX_LEN + 1);
595 if (len == 0 || len > DAOS_PROP_LABEL_MAX_LEN)
599 for (i = 0; i < len; i++) {
602 if (isalnum(c) || c ==
'.' || c ==
'_' || c ==
':')
613 if (maybe_uuid && daos_is_valid_uuid_string(label))
620#define DAOS_PROP_PO_DATA_THRESH_DEFAULT (1UL << 12)
623#define DAOS_PROP_NO_PO_LABEL "pool_label_not_set"
626#define DEFAULT_CONT_LABEL "container_label_not_set"
629#define DAOS_PROP_NO_CO_LABEL DEFAULT_CONT_LABEL
636daos_perf_domain_is_valid(
const char *perf_domain)
638 return daos_label_is_valid(perf_domain);
659daos_prop_alloc(uint32_t entries_nr);
691daos_prop_from_str(
const char *str, daos_size_t len,
daos_prop_t **prop);
726daos_prop_entry_get(
daos_prop_t *prop, uint32_t type);
741daos_prop_set_str(
daos_prop_t *prop, uint32_t type,
const char *str, daos_size_t len);
752daos_prop_entry_set_str(
struct daos_prop_entry *entry,
const char *str, daos_size_t len);
767daos_prop_set_ptr(
daos_prop_t *prop, uint32_t type,
const void *ptr, daos_size_t size);
778daos_prop_entry_set_ptr(
struct daos_prop_entry *entry,
const void *ptr, daos_size_t size);
855 if (entry->
dpe_flags & DAOS_PROP_ENTRY_NOT_SET)
861#if defined(__cplusplus)
struct daos_prop_entry * dpp_entries