24G_DEFINE_QUARK(pcmk-rc-error-quark, pcmk__rc_error)
25G_DEFINE_QUARK(pcmk-exitc-error-quark, pcmk__exitc_error)
45 const char *code_name = NULL;
46 const char *code_desc = NULL;
127log_assertion_as(
const char *file,
const char *function,
int line,
128 const char *assert_condition)
133 crm_err(
"%s: Triggered fatal assertion at %s:%d : %s",
134 function, file, line, assert_condition);
151 const char *assert_condition)
153 log_assertion_as(file, function, line, assert_condition);
171fail_assert_as(
const char *file,
const char *function,
int line,
172 const char *assert_condition)
184 crm_warn(
"%s: Cannot dump core for non-fatal assertion at %s:%d "
185 ": %s", function, file, line, assert_condition);
193 crm_err(
"%s: Forked child [%d] to record non-fatal assertion at "
194 "%s:%d : %s", function,
pid, file, line, assert_condition);
197 if (waitpid(
pid, &status, 0) ==
pid) {
200 }
while (errno == EINTR);
201 if (errno == ECHILD) {
203 crm_trace(
"Cannot wait on forked child [%d] "
204 "(SIGCHLD is probably ignored)",
pid);
206 crm_err(
"Cannot wait on forked child [%d]: %s",
215crm_abort(
const char *file,
const char *function,
int line,
216 const char *assert_condition, gboolean do_core, gboolean do_fork)
220 }
else if (do_core) {
221 fail_assert_as(file, function, line, assert_condition);
223 log_assertion_as(file, function, line, assert_condition);
268static const struct pcmk__rc_info {
277 {
"pcmk_rc_unknown_format",
278 "Unknown output format",
281 {
"pcmk_rc_bad_nvpair",
282 "Bad name/value pair given",
286 "Already in requested state",
289 {
"pcmk_rc_node_unknown",
293 {
"pcmk_rc_multiple",
294 "Resource active on multiple nodes",
297 {
"pcmk_rc_cib_corrupt",
298 "Could not parse on-disk configuration",
301 {
"pcmk_rc_cib_save",
302 "Could not save new configuration to disk",
305 {
"pcmk_rc_cib_backup",
306 "Could not archive previous configuration",
309 {
"pcmk_rc_cib_modified",
310 "On-disk configuration was manually modified",
313 {
"pcmk_rc_diff_resync",
314 "Application of update diff failed, requesting full refresh",
317 {
"pcmk_rc_diff_failed",
318 "Application of update diff failed",
321 {
"pcmk_rc_old_data",
322 "Update was older than existing configuration",
325 {
"pcmk_rc_transform_failed",
326 "Schema transform failed",
329 {
"pcmk_rc_schema_unchanged",
330 "Schema is already the latest available",
333 {
"pcmk_rc_schema_validation",
334 "Update does not conform to the configured schema",
337 {
"pcmk_rc_no_quorum",
338 "Operation requires quorum",
341 {
"pcmk_rc_ipc_unauthorized",
342 "IPC server is blocked by unauthorized process",
345 {
"pcmk_rc_ipc_unresponsive",
346 "IPC server is unresponsive",
349 {
"pcmk_rc_ipc_pid_only",
350 "IPC server process is active but not accepting connections",
353 {
"pcmk_rc_op_unsatisfied",
354 "Not applicable under current conditions",
357 {
"pcmk_rc_undetermined",
358 "Result undetermined",
361 {
"pcmk_rc_before_range",
362 "Result occurs before given range",
365 {
"pcmk_rc_within_range",
366 "Result occurs within given range",
369 {
"pcmk_rc_after_range",
370 "Result occurs after given range",
373 {
"pcmk_rc_no_output",
374 "Output message produced no output",
377 {
"pcmk_rc_no_input",
378 "Input file not available",
381 {
"pcmk_rc_underflow",
382 "Value too small to be stored in data type",
385 {
"pcmk_rc_dot_error",
386 "Error writing dot(1) file",
389 {
"pcmk_rc_graph_error",
390 "Error writing graph file",
393 {
"pcmk_rc_invalid_transition",
394 "Cluster simulation produced invalid transition",
397 {
"pcmk_rc_unpack_error",
398 "Unable to parse CIB XML",
401 {
"pcmk_rc_duplicate_id",
402 "Two or more XML elements have the same ID",
405 {
"pcmk_rc_disabled",
409 {
"pcmk_rc_bad_input",
410 "Bad input value provided",
413 {
"pcmk_rc_bad_xml_patch",
414 "Bad XML patch format",
417 {
"pcmk_rc_no_transaction",
418 "No active transaction found",
421 {
"pcmk_rc_ns_resolution",
422 "Nameserver resolution error",
425 {
"pcmk_rc_compression",
426 "Compression/decompression error",
430 "DC is not yet elected",
433 {
"pcmk_rc_ipc_more",
434 "More IPC message fragments to send",
464 case E2BIG:
return "E2BIG";
465 case EACCES:
return "EACCES";
466 case EADDRINUSE:
return "EADDRINUSE";
467 case EADDRNOTAVAIL:
return "EADDRNOTAVAIL";
468 case EAFNOSUPPORT:
return "EAFNOSUPPORT";
469 case EAGAIN:
return "EAGAIN";
470 case EALREADY:
return "EALREADY";
471 case EBADF:
return "EBADF";
472 case EBADMSG:
return "EBADMSG";
473 case EBUSY:
return "EBUSY";
474 case ECANCELED:
return "ECANCELED";
475 case ECHILD:
return "ECHILD";
476 case ECOMM:
return "ECOMM";
477 case ECONNABORTED:
return "ECONNABORTED";
478 case ECONNREFUSED:
return "ECONNREFUSED";
479 case ECONNRESET:
return "ECONNRESET";
481 case EDESTADDRREQ:
return "EDESTADDRREQ";
482 case EDOM:
return "EDOM";
483 case EDQUOT:
return "EDQUOT";
484 case EEXIST:
return "EEXIST";
485 case EFAULT:
return "EFAULT";
486 case EFBIG:
return "EFBIG";
487 case EHOSTDOWN:
return "EHOSTDOWN";
488 case EHOSTUNREACH:
return "EHOSTUNREACH";
489 case EIDRM:
return "EIDRM";
490 case EILSEQ:
return "EILSEQ";
491 case EINPROGRESS:
return "EINPROGRESS";
492 case EINTR:
return "EINTR";
493 case EINVAL:
return "EINVAL";
494 case EIO:
return "EIO";
495 case EISCONN:
return "EISCONN";
496 case EISDIR:
return "EISDIR";
497 case ELIBACC:
return "ELIBACC";
498 case ELOOP:
return "ELOOP";
499 case EMFILE:
return "EMFILE";
500 case EMLINK:
return "EMLINK";
501 case EMSGSIZE:
return "EMSGSIZE";
503 case EMULTIHOP:
return "EMULTIHOP";
505 case ENAMETOOLONG:
return "ENAMETOOLONG";
506 case ENETDOWN:
return "ENETDOWN";
507 case ENETRESET:
return "ENETRESET";
508 case ENETUNREACH:
return "ENETUNREACH";
509 case ENFILE:
return "ENFILE";
510 case ENOBUFS:
return "ENOBUFS";
511 case ENODATA:
return "ENODATA";
512 case ENODEV:
return "ENODEV";
513 case ENOENT:
return "ENOENT";
514 case ENOEXEC:
return "ENOEXEC";
515 case ENOKEY:
return "ENOKEY";
516 case ENOLCK:
return "ENOLCK";
518 case ENOLINK:
return "ENOLINK";
520 case ENOMEM:
return "ENOMEM";
521 case ENOMSG:
return "ENOMSG";
522 case ENOPROTOOPT:
return "ENOPROTOOPT";
523 case ENOSPC:
return "ENOSPC";
525 case ENOSR:
return "ENOSR";
528 case ENOSTR:
return "ENOSTR";
530 case ENOSYS:
return "ENOSYS";
531 case ENOTBLK:
return "ENOTBLK";
532 case ENOTCONN:
return "ENOTCONN";
533 case ENOTDIR:
return "ENOTDIR";
534 case ENOTEMPTY:
return "ENOTEMPTY";
535 case ENOTSOCK:
return "ENOTSOCK";
536#if ENOTSUP != EOPNOTSUPP
537 case ENOTSUP:
return "ENOTSUP";
539 case ENOTTY:
return "ENOTTY";
541 case ENXIO:
return "ENXIO";
542 case EOPNOTSUPP:
return "EOPNOTSUPP";
543 case EOVERFLOW:
return "EOVERFLOW";
544 case EPERM:
return "EPERM";
545 case EPFNOSUPPORT:
return "EPFNOSUPPORT";
546 case EPIPE:
return "EPIPE";
547 case EPROTO:
return "EPROTO";
548 case EPROTONOSUPPORT:
return "EPROTONOSUPPORT";
549 case EPROTOTYPE:
return "EPROTOTYPE";
550 case ERANGE:
return "ERANGE";
551 case EREMOTE:
return "EREMOTE";
553 case EROFS:
return "EROFS";
554 case ESHUTDOWN:
return "ESHUTDOWN";
555 case ESPIPE:
return "ESPIPE";
556 case ESOCKTNOSUPPORT:
return "ESOCKTNOSUPPORT";
557 case ESRCH:
return "ESRCH";
558 case ESTALE:
return "ESTALE";
559 case ETIME:
return "ETIME";
560 case ETIMEDOUT:
return "ETIMEDOUT";
561 case ETXTBSY:
return "ETXTBSY";
563 case EUNATCH:
return "EUNATCH";
565 case EUSERS:
return "EUSERS";
567 case EXDEV:
return "EXDEV";
570 case EBADE:
return "EBADE";
571 case EBADFD:
return "EBADFD";
572 case EBADSLT:
return "EBADSLT";
573 case EDEADLOCK:
return "EDEADLOCK";
574 case EBADR:
return "EBADR";
575 case EBADRQC:
return "EBADRQC";
576 case ECHRNG:
return "ECHRNG";
578 case EISNAM:
return "EISNAM";
579 case EKEYEXPIRED:
return "EKEYEXPIRED";
580 case EKEYREVOKED:
return "EKEYREVOKED";
583 case EL2HLT:
return "EL2HLT";
584 case EL2NSYNC:
return "EL2NSYNC";
585 case EL3HLT:
return "EL3HLT";
586 case EL3RST:
return "EL3RST";
587 case ELIBBAD:
return "ELIBBAD";
588 case ELIBMAX:
return "ELIBMAX";
589 case ELIBSCN:
return "ELIBSCN";
590 case ELIBEXEC:
return "ELIBEXEC";
592 case ENOMEDIUM:
return "ENOMEDIUM";
593 case EMEDIUMTYPE:
return "EMEDIUMTYPE";
595 case ENONET:
return "ENONET";
596 case ENOPKG:
return "ENOPKG";
597 case EREMCHG:
return "EREMCHG";
598 case ERESTART:
return "ERESTART";
599 case ESTRPIPE:
return "ESTRPIPE";
601 case EUCLEAN:
return "EUCLEAN";
603 case EXFULL:
return "EXFULL";
605 default:
return "Unknown";
632 case ENOTUNIQ:
return "Name not unique on network";
635 case ECOMM:
return "Communication error on send";
638 case ELIBACC:
return "Can not access a needed shared library";
640#ifdef PCMK__EREMOTEIO
641 case EREMOTEIO:
return "Remote I/O error";
644 case ENOKEY:
return "Required key not available";
647 case ENODATA:
return "No data available";
650 case ETIME:
return "Timer expired";
652#ifdef PCMK__EKEYREJECTED
653 case EKEYREJECTED:
return "Key was rejected by service";
655 default:
return strerror(rc);
677 legacy_rc = abs(legacy_rc);
697 default:
return legacy_rc;
753 return "CRM_EX_UNKNOWN";
777 case CRM_EX_OSERR:
return "Operating system error occurred";
785 case CRM_EX_FATAL:
return "Fatal error occurred, will not respawn";
799 case CRM_EX_OLD:
return "Update was older than existing configuration";
803 case CRM_EX_NONE:
return "No exit status available";
806 if ((exit_code > 128) && (exit_code <
CRM_EX_MAX)) {
807 return "Interrupted by signal";
809 return "Unknown exit status";
859 case EPROTONOSUPPORT:
883#if EOPNOTSUPP != ENOTSUP
965#if EOPNOTSUPP != ENOTSUP
1001 return EAFNOSUPPORT;
1010 return ESOCKTNOSUPPORT;
1042 case BZ_DATA_ERROR_MAGIC:
1043 case BZ_UNEXPECTED_EOF:
1049 case BZ_OUTBUFF_FULL:
1063 if ((((
int) exit_status) < 0) || (((
int) exit_status) >
CRM_EX_MAX)) {
1067 crm_info(
"Exiting %s " QB_XS
" with status %d (%s: %s)",
1120 const
char *format, ...)
1124 char *reason = NULL;
1133 if (format != NULL) {
1134 va_start(ap, format);
1135 len = vasprintf(&reason, format, ap);
1203 CRM_CHECK((src != NULL) && (dst != NULL),
return);
void pcmk_common_cleanup(void)
Free all memory used by libcrmcommon.
enum pcmk_ipc_server type
#define crm_info(fmt, args...)
void crm_write_blackbox(int nsig, const struct qb_log_callsite *callsite)
#define crm_warn(fmt, args...)
void crm_enable_stderr(int enable)
#define CRM_CHECK(expr, failure_action)
#define crm_err(fmt, args...)
#define crm_trace(fmt, args...)
Wrappers for and extensions to glib mainloop.
pcmk__action_result_t result
const char * pcmk_rc_name(int rc)
Get a return code constant name as a string.
_Noreturn void pcmk__abort_as(const char *file, const char *function, int line, const char *assert_condition)
const char * pcmk_strerror(int rc)
void pcmk__set_result(pcmk__action_result_t *result, int exit_status, enum pcmk_exec_status exec_status, const char *exit_reason)
int pcmk__result_bounds(enum pcmk_result_type type, int *lower, int *upper)
const char * pcmk_rc_str(int rc)
Get a user-friendly description of a return code.
int pcmk_result_get_strings(int code, enum pcmk_result_type type, const char **name, const char **desc)
Get the name and description of a given result code.
enum ocf_exitcode pcmk_rc2ocf(int rc)
Map a function return code to the most similar OCF exit code.
int pcmk__gaierror2rc(int gai)
Map a getaddrinfo() return code to the most similar Pacemaker return code.
void pcmk__format_result(pcmk__action_result_t *result, int exit_status, enum pcmk_exec_status exec_status, const char *format,...)
void pcmk__copy_result(const pcmk__action_result_t *src, pcmk__action_result_t *dst)
const char * crm_exit_name(crm_exit_t exit_code)
int pcmk_rc2legacy(int rc)
const char * pcmk_errorname(int rc)
void crm_abort(const char *file, const char *function, int line, const char *assert_condition, gboolean do_core, gboolean do_fork)
const char * crm_exit_str(crm_exit_t exit_code)
void pcmk__reset_result(pcmk__action_result_t *result)
int pcmk_legacy2rc(int legacy_rc)
crm_exit_t crm_exit(crm_exit_t exit_status)
void pcmk__set_result_output(pcmk__action_result_t *result, char *out, char *err)
int pcmk__bzlib2rc(int bz2)
Map a bz2 return code to the most similar Pacemaker return code.
crm_exit_t pcmk_rc2exitc(int rc)
Map a function return code to the most similar exit code.
#define pcmk_err_cib_corrupt
#define pcmk_err_old_data
#define pcmk_err_node_unknown
#define pcmk_err_unknown_format
#define pcmk_err_cib_modified
#define pcmk_err_schema_unchanged
@ CRM_EX_IOERR
File I/O error.
@ CRM_EX_PANIC
Panic the local host.
@ CRM_EX_PROTOCOL
Protocol violated.
@ CRM_EX_NOSUCH
Requested item does not exist.
@ CRM_EX_DATAERR
User-supplied data incorrect.
@ CRM_EX_UNSATISFIED
Requested item does not satisfy constraints.
@ CRM_EX_UNSAFE
Requires –force or new conditions.
@ CRM_EX_EXISTS
Requested item already exists.
@ CRM_EX_TIMEOUT
Convention from timeout(1)
@ CRM_EX_NOT_RUNNING
Service safely stopped.
@ CRM_EX_MULTIPLE
Requested item has multiple matches.
@ CRM_EX_UNIMPLEMENT_FEATURE
Requested action not implemented.
@ CRM_EX_ERROR
Unspecified error.
@ CRM_EX_NOT_YET_IN_EFFECT
Requested item is not in effect.
@ CRM_EX_DEGRADED
Service active but more likely to fail soon.
@ CRM_EX_FAILED_PROMOTED
Service failed and possibly promoted.
@ CRM_EX_CANTCREAT
File couldn't be created.
@ CRM_EX_NONE
No exit status available.
@ CRM_EX_OLD
Update older than existing config.
@ CRM_EX_SOFTWARE
Internal software bug.
@ CRM_EX_OSFILE
System file not usable.
@ CRM_EX_NOHOST
Host unknown.
@ CRM_EX_CONFIG
Misconfiguration.
@ CRM_EX_NOPERM
Non-file permission issue.
@ CRM_EX_NOT_CONFIGURED
Parameter invalid (inherently)
@ CRM_EX_NOINPUT
Input file not available.
@ CRM_EX_NO_DC
DC is not yet elected, e.g. right after cluster restart.
@ CRM_EX_UNAVAILABLE
Needed service unavailable.
@ CRM_EX_OSERR
External (OS/environmental) problem.
@ CRM_EX_DISCONNECT
Lost connection to something.
@ CRM_EX_FATAL
Do not respawn.
@ CRM_EX_DIGEST
Digest comparison failed.
@ CRM_EX_PROMOTED
Service active and promoted.
@ CRM_EX_EXPIRED
Requested item has expired.
@ CRM_EX_NOUSER
User does not exist.
@ CRM_EX_DEGRADED_PROMOTED
Service promoted but more likely to fail soon.
@ CRM_EX_USAGE
Command line usage error.
@ CRM_EX_MAX
Ensure crm_exit_t can hold this.
@ CRM_EX_QUORUM
Local partition does not have quorum.
@ CRM_EX_NOT_INSTALLED
Dependencies not available locally.
@ CRM_EX_INVALID_PARAM
Parameter invalid (in local context)
@ CRM_EX_INSUFFICIENT_PRIV
Insufficient privileges.
@ CRM_EX_TEMPFAIL
Try again.
@ CRM_EX_INDETERMINATE
Could not determine status.
ocf_exitcode
Exit status codes for resource agents.
@ PCMK_OCF_INSUFFICIENT_PRIV
Insufficient privileges.
@ PCMK_OCF_UNIMPLEMENT_FEATURE
Requested action not implemented.
@ PCMK_OCF_UNKNOWN_ERROR
Unspecified error.
@ PCMK_OCF_INVALID_PARAM
Parameter invalid (in local context)
#define pcmk_err_schema_validation
@ pcmk_rc_transform_failed
@ pcmk_rc_schema_validation
@ pcmk_rc_schema_unchanged
#define pcmk_err_bad_nvpair
#define pcmk_err_multiple
#define pcmk_err_no_quorum
#define pcmk_err_cib_save
pcmk_result_type
Types of Pacemaker result codes.
@ pcmk_result_exitcode
Exit status code.
@ pcmk_result_legacy
Legacy API function return code.
@ pcmk_result_rc
Standard Pacemaker return code.
#define pcmk_err_diff_failed
pcmk_exec_status
Execution status.
#define pcmk_err_diff_resync
#define pcmk_err_transform_failed
enum crm_exit_e crm_exit_t
Exit status codes for tools and daemons.
#define pcmk_err_cib_backup
#define pcmk__assert(expr)
#define pcmk__str_copy(str)
enum pcmk_exec_status execution_status
Wrappers for and extensions to libxml2.