10#ifndef __DAOS_ERRNO_H__
11#define __DAOS_ERRNO_H__
13#if defined(__cplusplus)
27#define D_FOREACH_GURT_ERR(ACTION) \
29 ACTION(DER_NO_PERM, (DER_ERR_GURT_BASE + 1), \
30 Operation not permitted) \
32 ACTION(DER_NO_HDL, (DER_ERR_GURT_BASE + 2), \
35 ACTION(DER_INVAL, (DER_ERR_GURT_BASE + 3), \
38 ACTION(DER_EXIST, (DER_ERR_GURT_BASE + 4), \
39 Entity already exists) \
41 ACTION(DER_NONEXIST, (DER_ERR_GURT_BASE + 5), \
42 The specified entity does not exist) \
44 ACTION(DER_UNREACH, (DER_ERR_GURT_BASE + 6), \
47 ACTION(DER_NOSPACE, (DER_ERR_GURT_BASE + 7), \
48 No space on storage target) \
50 ACTION(DER_ALREADY, (DER_ERR_GURT_BASE + 8), \
51 Operation already performed) \
53 ACTION(DER_NOMEM, (DER_ERR_GURT_BASE + 9), \
56 ACTION(DER_NOSYS, (DER_ERR_GURT_BASE + 10), \
57 Function not implemented) \
59 ACTION(DER_TIMEDOUT, (DER_ERR_GURT_BASE + 11), \
62 ACTION(DER_BUSY, (DER_ERR_GURT_BASE + 12), \
63 Device or resource busy) \
65 ACTION(DER_AGAIN, (DER_ERR_GURT_BASE + 13), \
68 ACTION(DER_PROTO, (DER_ERR_GURT_BASE + 14), \
69 Incompatible protocol) \
71 ACTION(DER_UNINIT, (DER_ERR_GURT_BASE + 15), \
72 Device or resource not initialized) \
74 ACTION(DER_TRUNC, (DER_ERR_GURT_BASE + 16), \
77 ACTION(DER_OVERFLOW, (DER_ERR_GURT_BASE + 17), \
78 Data too long for defined data type or buffer size) \
80 ACTION(DER_CANCELED, (DER_ERR_GURT_BASE + 18), \
83 ACTION(DER_OOG, (DER_ERR_GURT_BASE + 19), \
84 Out of group or member list) \
86 ACTION(DER_HG, (DER_ERR_GURT_BASE + 20), \
87 Transport layer mercury error) \
89 ACTION(DER_UNREG, (DER_ERR_GURT_BASE + 21), \
90 RPC or protocol version not registered) \
92 ACTION(DER_ADDRSTR_GEN, (DER_ERR_GURT_BASE + 22), \
93 Failed to generate an address string) \
95 ACTION(DER_PMIX, (DER_ERR_GURT_BASE + 23), \
98 ACTION(DER_IVCB_FORWARD, (DER_ERR_GURT_BASE + 24), \
99 Incast variable unavailable locally. Must forward) \
101 ACTION(DER_MISC, (DER_ERR_GURT_BASE + 25), \
102 Miscellaneous error) \
104 ACTION(DER_BADPATH, (DER_ERR_GURT_BASE + 26), \
107 ACTION(DER_NOTDIR, (DER_ERR_GURT_BASE + 27), \
110 ACTION(DER_CORPC_INCOMPLETE, (DER_ERR_GURT_BASE + 28), \
111 Collective RPC failed) \
113 ACTION(DER_NO_RAS_RANK, (DER_ERR_GURT_BASE + 29), \
114 No rank is subscribed to RAS) \
116 ACTION(DER_NOTATTACH, (DER_ERR_GURT_BASE + 30), \
117 Service group not attached) \
119 ACTION(DER_MISMATCH, (DER_ERR_GURT_BASE + 31), \
122 ACTION(DER_EXCLUDED, (DER_ERR_GURT_BASE + 32), \
123 Rank has been excluded) \
125 ACTION(DER_NOREPLY, (DER_ERR_GURT_BASE + 33), \
126 User provided RPC handler did not send reply back) \
128 ACTION(DER_DOS, (DER_ERR_GURT_BASE + 34), \
131 ACTION(DER_BAD_TARGET, (DER_ERR_GURT_BASE + 35), \
132 Incorrect target for the RPC) \
134 ACTION(DER_GRPVER, (DER_ERR_GURT_BASE + 36), \
135 Group versioning mismatch) \
137 ACTION(DER_HLC_SYNC, (DER_ERR_GURT_BASE + 37), \
138 HLC synchronization error) \
140 ACTION(DER_NO_SHMEM, (DER_ERR_GURT_BASE + 38), \
141 Not enough shared memory free) \
143 ACTION(DER_ADD_METRIC_FAILED, (DER_ERR_GURT_BASE + 39), \
144 Failed to add the specified metric) \
146 ACTION(DER_DURATION_MISMATCH, (DER_ERR_GURT_BASE + 40), \
147 Duration end not paired with duration start) \
149 ACTION(DER_OP_NOT_PERMITTED, (DER_ERR_GURT_BASE + 41), \
150 Operation not permitted for metric type provided) \
152 ACTION(DER_EXCEEDS_PATH_LEN, (DER_ERR_GURT_BASE + 42), \
153 Path name exceeds permitted length) \
155 ACTION(DER_METRIC_NOT_FOUND, (DER_ERR_GURT_BASE + 43), \
156 Read failed because metric not found) \
158 ACTION(DER_SHMEM_PERMS, (DER_ERR_GURT_BASE + 44), \
159 Unable to access shared memory segment due to \
160 incompatible user or group permissions)
163#define D_FOREACH_DAOS_ERR(ACTION) \
165 ACTION(DER_IO, (DER_ERR_DAOS_BASE + 1), \
168 ACTION(DER_FREE_MEM, (DER_ERR_DAOS_BASE + 2), \
171 ACTION(DER_ENOENT, (DER_ERR_DAOS_BASE + 3), \
174 ACTION(DER_NOTYPE, (DER_ERR_DAOS_BASE + 4), \
175 Unknown object type) \
177 ACTION(DER_NOSCHEMA, (DER_ERR_DAOS_BASE + 5), \
178 Unknown object schema) \
180 ACTION(DER_NOLOCAL, (DER_ERR_DAOS_BASE + 6), \
181 Object is not local) \
183 ACTION(DER_STALE, (DER_ERR_DAOS_BASE + 7), \
184 Stale pool map version) \
186 ACTION(DER_NOTLEADER, (DER_ERR_DAOS_BASE + 8), \
187 Not service leader) \
189 ACTION(DER_TGT_CREATE, (DER_ERR_DAOS_BASE + 9), \
190 Target create error) \
192 ACTION(DER_EP_RO, (DER_ERR_DAOS_BASE + 10), \
193 Epoch is read only) \
195 ACTION(DER_EP_OLD, (DER_ERR_DAOS_BASE + 11), \
196 Epoch is too old. All data have been recycled) \
198 ACTION(DER_KEY2BIG, (DER_ERR_DAOS_BASE + 12), \
201 ACTION(DER_REC2BIG, (DER_ERR_DAOS_BASE + 13), \
202 Record is too large) \
204 ACTION(DER_IO_INVAL, (DER_ERR_DAOS_BASE + 14), \
205 I/O buffers do not match object extents) \
207 ACTION(DER_EQ_BUSY, (DER_ERR_DAOS_BASE + 15), \
208 Event queue is busy) \
210 ACTION(DER_DOMAIN, (DER_ERR_DAOS_BASE + 16), \
211 Domain of cluster component do not match) \
213 ACTION(DER_SHUTDOWN, (DER_ERR_DAOS_BASE + 17), \
214 Service should shut down) \
216 ACTION(DER_INPROGRESS, (DER_ERR_DAOS_BASE + 18), \
217 Operation now in progress) \
219 ACTION(DER_NOTAPPLICABLE, (DER_ERR_DAOS_BASE + 19), \
222 ACTION(DER_NOTREPLICA, (DER_ERR_DAOS_BASE + 20), \
223 Not a service replica) \
225 ACTION(DER_CSUM, (DER_ERR_DAOS_BASE + 21), \
228 ACTION(DER_DF_INVAL, (DER_ERR_DAOS_BASE + 22), \
229 Unsupported durable format) \
231 ACTION(DER_DF_INCOMPT, (DER_ERR_DAOS_BASE + 23), \
232 Incompatible durable format version) \
234 ACTION(DER_REC_SIZE, (DER_ERR_DAOS_BASE + 24), \
237 ACTION(DER_TX_RESTART, (DER_ERR_DAOS_BASE + 25), \
238 Transaction should restart) \
240 ACTION(DER_DATA_LOSS, (DER_ERR_DAOS_BASE + 26), \
241 Data lost or not recoverable) \
243 ACTION(DER_OP_CANCELED, (DER_ERR_DAOS_BASE + 27), \
244 Operation canceled) \
246 ACTION(DER_TX_BUSY, (DER_ERR_DAOS_BASE + 28), \
247 TX is not committed) \
249 ACTION(DER_AGENT_INCOMPAT, (DER_ERR_DAOS_BASE + 29), \
250 Agent is incompatible with libdaos) \
252 ACTION(DER_SHARDS_OVERLAP, (DER_ERR_DAOS_BASE + 30), \
255 ACTION(DER_RF, (DER_ERR_DAOS_BASE + 31), \
256 Failures exceed RF) \
258 ACTION(DER_FETCH_AGAIN, (DER_ERR_DAOS_BASE + 32), \
261 ACTION(DER_TX_UNCERTAIN, (DER_ERR_DAOS_BASE + 33), \
262 TX status is uncertaion) \
264 ACTION(DER_AGENT_COMM, (DER_ERR_DAOS_BASE + 34), \
265 Agent communication error) \
267 ACTION(DER_ID_MISMATCH, (DER_ERR_DAOS_BASE + 35), \
270 ACTION(DER_TGT_RETRY, (DER_ERR_DAOS_BASE + 36), \
271 Retry with other target) \
272 ACTION(DER_NOTSUPPORTED, (DER_ERR_DAOS_BASE + 37), \
273 Operation not supported) \
274 ACTION(DER_CONTROL_INCOMPAT, (DER_ERR_DAOS_BASE + 38), \
275 One or more control plane components are incompatible) \
277 ACTION(DER_NO_SERVICE, (DER_ERR_DAOS_BASE + 39), \
278 No service available)
281#define D_FOREACH_ERR_RANGE(ACTION) \
285#define D_DEFINE_ERRNO(name, value, desc) name = value,
286#define D_DEFINE_ERRSTR(name, value, desc) #name,
287#define D_DEFINE_ERRDESC(name, value, desc) #desc,
289#define D_DEFINE_RANGE_ERRNO(name, base) \
291 DER_ERR_##name##_BASE = (base), \
292 D_FOREACH_##name##_ERR(D_DEFINE_ERRNO) \
293 DER_ERR_##name##_LIMIT, \
296#define D_DEFINE_RANGE_ERRSTR(name) \
297 static const char * const g_##name##_error_strings[] = {\
298 D_FOREACH_##name##_ERR(D_DEFINE_ERRSTR) \
300 static const char * const g_##name##_strerror[] = { \
301 D_FOREACH_##name##_ERR(D_DEFINE_ERRDESC) \
307#define D_REGISTER_RANGE(name) \
308 d_errno_register_range(DER_ERR_##name##_BASE, \
309 DER_ERR_##name##_LIMIT, \
310 g_##name##_error_strings,\
314#define D_DEREGISTER_RANGE(name) \
315 d_errno_deregister_range(DER_ERR_##name##_BASE)
318#define DER_UNKNOWN (DER_ERR_GURT_BASE + 500000)
342 const char *
const *error_strings,
343 const char *
const *strerror);
363#define DO_PRAGMA(str) _Pragma(#str)
364#define DEPRECATE_ERROR(olde, newe) \
366 DO_PRAGMA(message(#olde " is deprecated, use " #newe)); \
369#define DER_EVICTED DEPRECATE_ERROR(DER_EVICTED, DER_EXCLUDED)
372#define DF_RC "%s(%d): '%s'"
373#define DP_RC(rc) d_errstr(rc), rc, d_errdesc(rc)
376#if defined(__cplusplus)
const char * d_errstr(int rc)
const char * d_errdesc(int errnum)
void d_errno_deregister_range(int start)
int d_errno_register_range(int start, int end, const char *const *error_strings, const char *const *strerror)
#define D_FOREACH_ERR_RANGE(ACTION)