10 #ifndef PE_INTERNAL__H
11 # define PE_INTERNAL__H
17 # define pe_rsc_info(rsc, fmt, args...) crm_log_tag(LOG_INFO, rsc ? rsc->id : "<NULL>", fmt, ##args)
18 # define pe_rsc_debug(rsc, fmt, args...) crm_log_tag(LOG_DEBUG, rsc ? rsc->id : "<NULL>", fmt, ##args)
19 # define pe_rsc_trace(rsc, fmt, args...) crm_log_tag(LOG_TRACE, rsc ? rsc->id : "<NULL>", fmt, ##args)
21 # define pe_err(fmt...) { was_processing_error = TRUE; crm_config_error = TRUE; crm_err(fmt); }
22 # define pe_warn(fmt...) { was_processing_warning = TRUE; crm_config_warning = TRUE; crm_warn(fmt); }
23 # define pe_proc_err(fmt...) { was_processing_error = TRUE; crm_err(fmt); }
24 # define pe_proc_warn(fmt...) { was_processing_warning = TRUE; crm_warn(fmt); }
25 # define pe_set_action_bit(action, bit) action->flags = crm_set_bit(__FUNCTION__, __LINE__, action->uuid, action->flags, bit)
26 # define pe_clear_action_bit(action, bit) action->flags = crm_clear_bit(__FUNCTION__, __LINE__, action->uuid, action->flags, bit)
40 extern uint32_t
pe_wo;
42 #define pe_warn_once(pe_wo_bit, fmt...) do { \
43 if (is_not_set(pe_wo, pe_wo_bit)) { \
44 if (pe_wo_bit == pe_wo_blind) { \
49 set_bit(pe_wo, pe_wo_bit); \
134 ,
size_t pairs_count, ...);
222 uint32_t
flags, xmlNode *xml_op,
232 unsigned int *count_all,
233 unsigned int *count_clean);
235 unsigned int *count);
249 static inline gpointer
250 pe_hash_table_lookup(GHashTable * hash, gconstpointer key)
253 return g_hash_table_lookup(hash, key);
263 extern void print_str_str(gpointer key, gpointer value, gpointer user_data);
271 const char *comment, GHashTable *nodes);
273 #define pe__show_node_weights(level, rsc, text, nodes) \
274 pe__show_node_weights_as(__FILE__, __FUNCTION__, __LINE__, \
275 (level), (rsc), (text), (nodes))
286 # define delete_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_DELETE, 0)
287 # define delete_action(rsc, node, optional) custom_action( \
288 rsc, delete_key(rsc), CRMD_ACTION_DELETE, node, \
289 optional, TRUE, data_set);
291 # define stopped_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_STOPPED, 0)
292 # define stopped_action(rsc, node, optional) custom_action( \
293 rsc, stopped_key(rsc), CRMD_ACTION_STOPPED, node, \
294 optional, TRUE, data_set);
296 # define stop_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_STOP, 0)
297 # define stop_action(rsc, node, optional) custom_action( \
298 rsc, stop_key(rsc), CRMD_ACTION_STOP, node, \
299 optional, TRUE, data_set);
301 # define reload_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_RELOAD, 0)
302 # define start_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_START, 0)
303 # define start_action(rsc, node, optional) custom_action( \
304 rsc, start_key(rsc), CRMD_ACTION_START, node, \
305 optional, TRUE, data_set)
307 # define started_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_STARTED, 0)
308 # define started_action(rsc, node, optional) custom_action( \
309 rsc, started_key(rsc), CRMD_ACTION_STARTED, node, \
310 optional, TRUE, data_set)
312 # define promote_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_PROMOTE, 0)
313 # define promote_action(rsc, node, optional) custom_action( \
314 rsc, promote_key(rsc), CRMD_ACTION_PROMOTE, node, \
315 optional, TRUE, data_set)
317 # define promoted_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_PROMOTED, 0)
318 # define promoted_action(rsc, node, optional) custom_action( \
319 rsc, promoted_key(rsc), CRMD_ACTION_PROMOTED, node, \
320 optional, TRUE, data_set)
322 # define demote_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_DEMOTE, 0)
323 # define demote_action(rsc, node, optional) custom_action( \
324 rsc, demote_key(rsc), CRMD_ACTION_DEMOTE, node, \
325 optional, TRUE, data_set)
327 # define demoted_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_DEMOTED, 0)
328 # define demoted_action(rsc, node, optional) custom_action( \
329 rsc, demoted_key(rsc), CRMD_ACTION_DEMOTED, node, \
330 optional, TRUE, data_set)
338 gboolean allow_non_atomic);
345 const char *task,
bool require_node);
369 if (
id && rsc && rsc->
id) {
373 return (strlen(
id) == base_len) && !strncmp(
id, rsc->
id, base_len);
415 #define pe_action_required(action, reason, text) pe_action_set_flag_reason(__FUNCTION__, __LINE__, action, reason, text, pe_action_optional, FALSE)
416 #define pe_action_implies(action, reason, flag) pe_action_set_flag_reason(__FUNCTION__, __LINE__, action, reason, NULL, flag, FALSE)
421 gboolean
add_tag_ref(GHashTable * tags,
const char * tag_name,
const char * obj_ref);
424 void * print_data, gboolean print_all);
455 #define BOOL2STR(x) ((x) ? "true" : "false")
463 GHashTable *node_hash, GHashTable *hash,
464 const char *always_first, gboolean overwrite,
void pe__foreach_param_check(pe_working_set_t *data_set, void(*cb)(pe_resource_t *, pe_node_t *, xmlNode *, enum pe_check_parameters, pe_working_set_t *))
int pe__ticket_html(pcmk__output_t *out, va_list args)
void verify_pe_options(GHashTable *options)
enum rsc_role_e role_filter
bool is_set_recursive(pe_resource_t *rsc, long long flag, bool any)
GHashTable * pe__node_list2table(GList *list)
int pe__common_output_html(pcmk__output_t *out, pe_resource_t *rsc, const char *name, pe_node_t *node, long options)
int pe__cluster_maint_mode_text(pcmk__output_t *out, va_list args)
int pe__target_rc_from_xml(xmlNode *xml_op)
const char * pe_node_attribute_calculated(const pe_node_t *node, const char *name, const pe_resource_t *rsc)
void group_free(pe_resource_t *rsc)
gint sort_rsc_priority(gconstpointer a, gconstpointer b)
gint sort_rsc_index(gconstpointer a, gconstpointer b)
int pe__failed_action_text(pcmk__output_t *out, va_list args)
void group_print(pe_resource_t *rsc, const char *pre_text, long options, void *print_data)
int pe__ticket_text(pcmk__output_t *out, va_list args)
Formatted output for pacemaker tools.
GHashTable * allowed_nodes
int pe__cluster_summary(pcmk__output_t *out, va_list args)
int pe__failed_action_xml(pcmk__output_t *out, va_list args)
void pe__add_param_check(xmlNode *rsc_op, pe_resource_t *rsc, pe_node_t *node, enum pe_check_parameters, pe_working_set_t *data_set)
pe_node_t * pe__find_active_on(const pe_resource_t *rsc, unsigned int *count_all, unsigned int *count_clean)
bool pe__rsc_running_on_any_node_in_list(pe_resource_t *rsc, GListPtr node_list)
void pe__update_recheck_time(time_t recheck, pe_working_set_t *data_set)
void pe__free_bundle(pe_resource_t *rsc)
enum rsc_role_e pe__bundle_resource_state(const pe_resource_t *rsc, gboolean current)
struct op_digest_cache_s op_digest_cache_t
void pe__count_common(pe_resource_t *rsc)
int pe__ban_xml(pcmk__output_t *out, va_list args)
int pe__cluster_options_text(pcmk__output_t *out, va_list args)
int pe__cluster_options_log(pcmk__output_t *out, va_list args)
gboolean group_active(pe_resource_t *rsc, gboolean all)
pe_node_t * native_location(const pe_resource_t *rsc, GList **list, int current)
void pe_action_set_flag_reason(const char *function, long line, pe_action_t *action, pe_action_t *reason, const char *text, enum pe_action_flags flags, bool overwrite)
pe_node_t * pe__copy_node(const pe_node_t *this_node)
int pe__cluster_times_text(pcmk__output_t *out, va_list args)
int pe__cluster_counts_text(pcmk__output_t *out, va_list args)
gint sort_op_by_callid(gconstpointer a, gconstpointer b)
void print_node(const char *pre_text, pe_node_t *node, gboolean details)
time_t get_effective_time(pe_working_set_t *data_set)
void resource_location(pe_resource_t *rsc, pe_node_t *node, int score, const char *tag, pe_working_set_t *data_set)
int pe__cluster_dc_html(pcmk__output_t *out, va_list args)
int pe__ban_text(pcmk__output_t *out, va_list args)
GListPtr pe__unames_with_tag(pe_working_set_t *data_set, const char *tag_name)
void clear_bit_recursive(pe_resource_t *rsc, unsigned long long flag)
int pe__resource_text(pcmk__output_t *out, va_list args)
void pe__print_bundle(pe_resource_t *rsc, const char *pre_text, long options, void *print_data)
void print_rscs_brief(GListPtr rsc_list, const char *pre_text, long options, void *print_data, gboolean print_all)
bool pe__bundle_needs_remote_name(pe_resource_t *rsc)
int pe__group_text(pcmk__output_t *out, va_list args)
gboolean pe__unpack_bundle(pe_resource_t *rsc, pe_working_set_t *data_set)
int pe__cluster_times_html(pcmk__output_t *out, va_list args)
char * pe__node_display_name(pe_node_t *node, bool print_detail)
int pe__bundle_html(pcmk__output_t *out, va_list args)
bool pe__uname_has_tag(pe_working_set_t *data_set, const char *node, const char *tag)
void native_free(pe_resource_t *rsc)
int pe__op_history_text(pcmk__output_t *out, va_list args)
void trigger_unfencing(pe_resource_t *rsc, pe_node_t *node, const char *reason, pe_action_t *dependency, pe_working_set_t *data_set)
void clone_free(pe_resource_t *rsc)
int pe__clone_html(pcmk__output_t *out, va_list args)
int pe__node_list_text(pcmk__output_t *out, va_list args)
enum rsc_role_e group_resource_state(const pe_resource_t *rsc, gboolean current)
pe_resource_t * pe__find_bundle_replica(const pe_resource_t *bundle, const pe_node_t *node)
enum rsc_role_e clone_resource_state(const pe_resource_t *rsc, gboolean current)
enum pe_discover_e discover_mode
void pe_action_set_reason(pe_action_t *action, const char *reason, bool overwrite)
struct pe__order_constraint_s pe__ordering_t
int pe__bundle_text(pcmk__output_t *out, va_list args)
pe_action_t * get_pseudo_op(const char *name, pe_working_set_t *data_set)
gboolean clone_active(pe_resource_t *rsc, gboolean all)
GListPtr find_recurring_actions(GListPtr input, pe_node_t *not_on_node)
char * clone_strip(const char *last_rsc_id)
int pe__name_and_nvpairs_xml(pcmk__output_t *out, bool is_list, const char *tag_name, size_t pairs_count,...)
pe_ticket_t * ticket_new(const char *ticket_id, pe_working_set_t *data_set)
int pe__ticket_xml(pcmk__output_t *out, va_list args)
char * native_parameter(pe_resource_t *rsc, pe_node_t *node, gboolean create, const char *name, pe_working_set_t *data_set)
const char * pe__add_bundle_remote_name(pe_resource_t *rsc, xmlNode *xml, const char *field)
int pe__group_html(pcmk__output_t *out, va_list args)
enum action_tasks get_complex_task(pe_resource_t *rsc, const char *name, gboolean allow_non_atomic)
enum rsc_digest_cmp_val rc
void pe_fence_node(pe_working_set_t *data_set, pe_node_t *node, const char *reason, bool priority_delay)
Schedule a fence action for a node.
int pe__clone_xml(pcmk__output_t *out, va_list args)
char * digest_secure_calc
GListPtr find_actions(GListPtr input, const char *key, const pe_node_t *on_node)
gboolean get_target_role(pe_resource_t *rsc, enum rsc_role_e *role)
int pe__node_attribute_html(pcmk__output_t *out, va_list args)
void pe__unpack_dataset_nvpairs(xmlNode *xml_obj, const char *set_name, GHashTable *node_hash, GHashTable *hash, const char *always_first, gboolean overwrite, pe_working_set_t *data_set)
bool pe__shutdown_requested(pe_node_t *node)
pe_resource_t * find_clone_instance(pe_resource_t *rsc, const char *sub_id, pe_working_set_t *data_set)
void common_free(pe_resource_t *rsc)
gboolean order_actions(pe_action_t *lh_action, pe_action_t *rh_action, enum pe_ordering order)
int pe__node_attribute_xml(pcmk__output_t *out, va_list args)
xmlNode * find_rsc_op_entry(pe_resource_t *rsc, const char *key)
int pe__cluster_times_xml(pcmk__output_t *out, va_list args)
gboolean add_tag_ref(GHashTable *tags, const char *tag_name, const char *obj_ref)
int pe__resource_history_text(pcmk__output_t *out, va_list args)
enum rsc_role_e native_resource_state(const pe_resource_t *rsc, gboolean current)
const char * pe_node_attribute_raw(pe_node_t *node, const char *name)
void clone_print(pe_resource_t *rsc, const char *pre_text, long options, void *print_data)
void native_print(pe_resource_t *rsc, const char *pre_text, long options, void *print_data)
int pe__node_list_html(pcmk__output_t *out, va_list args)
int pe__cluster_summary_html(pcmk__output_t *out, va_list args)
void pe__register_messages(pcmk__output_t *out)
int pe__cluster_dc_text(pcmk__output_t *out, va_list args)
int pe_get_configured_timeout(pe_resource_t *rsc, const char *action, pe_working_set_t *data_set)
void common_update_score(pe_resource_t *rsc, const char *id, int score)
void common_print(pe_resource_t *rsc, const char *pre_text, const char *name, pe_node_t *node, long options, void *print_data)
int pe__cluster_counts_html(pcmk__output_t *out, va_list args)
void pe__free_param_checks(pe_working_set_t *data_set)
int pe__cluster_stack_html(pcmk__output_t *out, va_list args)
int pe__resource_history_xml(pcmk__output_t *out, va_list args)
gboolean native_active(pe_resource_t *rsc, gboolean all)
int pe__resource_xml(pcmk__output_t *out, va_list args)
int pe__cluster_options_html(pcmk__output_t *out, va_list args)
int pe__cluster_options_xml(pcmk__output_t *out, va_list args)
void native_add_running(pe_resource_t *rsc, pe_node_t *node, pe_working_set_t *data_set)
bool pe_can_fence(pe_working_set_t *data_set, pe_node_t *node)
void dump_node_capacity(int level, const char *comment, pe_node_t *node)
int pe__bundle_xml(pcmk__output_t *out, va_list args)
Cluster status and scheduling.
pe_resource_t * native_find_rsc(pe_resource_t *rsc, const char *id, const pe_node_t *node, int flags)
int pe__clone_text(pcmk__output_t *out, va_list args)
int pe__node_text(pcmk__output_t *out, va_list args)
void add_hash_param(GHashTable *hash, const char *name, const char *value)
bool pcmk__rsc_is_filtered(pe_resource_t *rsc, GListPtr only_show)
int pe__add_scores(int score1, int score2)
gboolean clone_unpack(pe_resource_t *rsc, pe_working_set_t *data_set)
int pe__ban_html(pcmk__output_t *out, va_list args)
pe_action_t * pe__clear_failcount(pe_resource_t *rsc, pe_node_t *node, const char *reason, pe_working_set_t *data_set)
Schedule a controller operation to clear a fail count.
void node_list_exclude(GHashTable *list, GListPtr list2, gboolean merge_scores)
int pe__cluster_maint_mode_html(pcmk__output_t *out, va_list args)
op_digest_cache_t * rsc_action_digest_cmp(pe_resource_t *rsc, xmlNode *xml_op, pe_node_t *node, pe_working_set_t *data_set)
int pe__cluster_stack_text(pcmk__output_t *out, va_list args)
char * clone_zero(const char *last_rsc_id)
int pe__node_xml(pcmk__output_t *out, va_list args)
int pe__group_xml(pcmk__output_t *out, va_list args)
This structure contains everything that makes up a single output formatter.
void dump_rsc_utilization(int level, const char *comment, pe_resource_t *rsc, pe_node_t *node)
int pe__node_attribute_text(pcmk__output_t *out, va_list args)
int pe__resource_html(pcmk__output_t *out, va_list args)
int pe__cluster_dc_xml(pcmk__output_t *out, va_list args)
bool pe__is_universal_clone(pe_resource_t *rsc, pe_working_set_t *data_set)
pe_node_t * pe_create_node(const char *id, const char *uname, const char *type, const char *score, pe_working_set_t *data_set)
void destroy_ticket(gpointer data)
int pe__node_html(pcmk__output_t *out, va_list args)
gboolean common_unpack(xmlNode *xml_obj, pe_resource_t **rsc, pe_resource_t *parent, pe_working_set_t *data_set)
int pe__cluster_counts_xml(pcmk__output_t *out, va_list args)
void pe__show_node_weights_as(const char *file, const char *function, int line, bool to_log, pe_resource_t *rsc, const char *comment, GHashTable *nodes)
GList * find_actions_exact(GList *input, const char *key, const pe_node_t *on_node)
void set_bit_recursive(pe_resource_t *rsc, unsigned long long flag)
pe_node_t * pe__find_active_requires(const pe_resource_t *rsc, unsigned int *count)
struct notify_data_s notify_data_t
bool pe__resource_is_disabled(pe_resource_t *rsc)
pe_action_t * find_first_action(GListPtr input, const char *uuid, const char *task, pe_node_t *on_node)
void pe__output_node(pe_node_t *node, gboolean details, pcmk__output_t *out)
GList * pe__resource_actions(const pe_resource_t *rsc, const pe_node_t *node, const char *task, bool require_node)
Find all actions of given type for a resource.
pe_action_t * pe__clear_resource_history(pe_resource_t *rsc, pe_node_t *node, pe_working_set_t *data_set)
void print_str_str(gpointer key, gpointer value, gpointer user_data)
int pe__rscs_brief_output(pcmk__output_t *out, GListPtr rsc_list, long options, gboolean print_all)
gboolean native_unpack(pe_resource_t *rsc, pe_working_set_t *data_set)
int pe__op_history_xml(pcmk__output_t *out, va_list args)
int pe__common_output_text(pcmk__output_t *out, pe_resource_t *rsc, const char *name, pe_node_t *node, long options)
gint sort_node_uname(gconstpointer a, gconstpointer b)
const char * pe_base_name_end(const char *id)
int pe__node_list_xml(pcmk__output_t *out, va_list args)
struct pe__location_constraint_s pe__location_t
char * digest_restart_calc
int pe__cluster_stack_xml(pcmk__output_t *out, va_list args)
void pe__count_bundle(pe_resource_t *rsc)
int pe_get_failcount(pe_node_t *node, pe_resource_t *rsc, time_t *last_failure, uint32_t flags, xmlNode *xml_op, pe_working_set_t *data_set)
pe_action_t * pe_fence_op(pe_node_t *node, const char *op, bool optional, const char *reason, bool priority_delay, pe_working_set_t *data_set)
void pe_free_action(pe_action_t *action)
enum crm_ais_msg_types type
gboolean pe__bundle_active(pe_resource_t *rsc, gboolean all)
pe_action_t * custom_action(pe_resource_t *rsc, char *key, const char *task, pe_node_t *on_node, gboolean optional, gboolean foo, pe_working_set_t *data_set)
gboolean group_unpack(pe_resource_t *rsc, pe_working_set_t *data_set)