pacemaker 2.1.1-77db578727
Scalable High-Availability cluster resource manager
Loading...
Searching...
No Matches
internal.h
Go to the documentation of this file.
1/*
2 * Copyright 2004-2021 the Pacemaker project contributors
3 *
4 * The version control history for this file may have further details.
5 *
6 * This source code is licensed under the GNU Lesser General Public License
7 * version 2.1 or later (LGPLv2.1+) WITHOUT ANY WARRANTY.
8 */
9
10#ifndef PE_INTERNAL__H
11# define PE_INTERNAL__H
12# include <string.h>
13# include <crm/pengine/status.h>
15# include <crm/common/internal.h>
17
18# define pe_rsc_info(rsc, fmt, args...) crm_log_tag(LOG_INFO, rsc ? rsc->id : "<NULL>", fmt, ##args)
19# define pe_rsc_debug(rsc, fmt, args...) crm_log_tag(LOG_DEBUG, rsc ? rsc->id : "<NULL>", fmt, ##args)
20# define pe_rsc_trace(rsc, fmt, args...) crm_log_tag(LOG_TRACE, rsc ? rsc->id : "<NULL>", fmt, ##args)
21
22# define pe_err(fmt...) do { \
23 was_processing_error = TRUE; \
24 pcmk__config_err(fmt); \
25 } while (0)
26
27# define pe_warn(fmt...) do { \
28 was_processing_warning = TRUE; \
29 pcmk__config_warn(fmt); \
30 } while (0)
31
32# define pe_proc_err(fmt...) { was_processing_error = TRUE; crm_err(fmt); }
33# define pe_proc_warn(fmt...) { was_processing_warning = TRUE; crm_warn(fmt); }
34
35#define pe__set_working_set_flags(working_set, flags_to_set) do { \
36 (working_set)->flags = pcmk__set_flags_as(__func__, __LINE__, \
37 LOG_TRACE, "Working set", crm_system_name, \
38 (working_set)->flags, (flags_to_set), #flags_to_set); \
39 } while (0)
40
41#define pe__clear_working_set_flags(working_set, flags_to_clear) do { \
42 (working_set)->flags = pcmk__clear_flags_as(__func__, __LINE__, \
43 LOG_TRACE, "Working set", crm_system_name, \
44 (working_set)->flags, (flags_to_clear), #flags_to_clear); \
45 } while (0)
46
47#define pe__set_resource_flags(resource, flags_to_set) do { \
48 (resource)->flags = pcmk__set_flags_as(__func__, __LINE__, \
49 LOG_TRACE, "Resource", (resource)->id, (resource)->flags, \
50 (flags_to_set), #flags_to_set); \
51 } while (0)
52
53#define pe__clear_resource_flags(resource, flags_to_clear) do { \
54 (resource)->flags = pcmk__clear_flags_as(__func__, __LINE__, \
55 LOG_TRACE, "Resource", (resource)->id, (resource)->flags, \
56 (flags_to_clear), #flags_to_clear); \
57 } while (0)
58
59#define pe__set_action_flags(action, flags_to_set) do { \
60 (action)->flags = pcmk__set_flags_as(__func__, __LINE__, \
61 LOG_TRACE, \
62 "Action", (action)->uuid, \
63 (action)->flags, \
64 (flags_to_set), \
65 #flags_to_set); \
66 } while (0)
67
68#define pe__clear_action_flags(action, flags_to_clear) do { \
69 (action)->flags = pcmk__clear_flags_as(__func__, __LINE__, \
70 LOG_TRACE, \
71 "Action", (action)->uuid, \
72 (action)->flags, \
73 (flags_to_clear), \
74 #flags_to_clear); \
75 } while (0)
76
77#define pe__set_raw_action_flags(action_flags, action_name, flags_to_set) do { \
78 action_flags = pcmk__set_flags_as(__func__, __LINE__, \
79 LOG_TRACE, "Action", action_name, \
80 (action_flags), \
81 (flags_to_set), #flags_to_set); \
82 } while (0)
83
84#define pe__clear_raw_action_flags(action_flags, action_name, flags_to_clear) do { \
85 action_flags = pcmk__clear_flags_as(__func__, __LINE__, \
86 LOG_TRACE, \
87 "Action", action_name, \
88 (action_flags), \
89 (flags_to_clear), \
90 #flags_to_clear); \
91 } while (0)
92
93#define pe__set_action_flags_as(function, line, action, flags_to_set) do { \
94 (action)->flags = pcmk__set_flags_as((function), (line), \
95 LOG_TRACE, \
96 "Action", (action)->uuid, \
97 (action)->flags, \
98 (flags_to_set), \
99 #flags_to_set); \
100 } while (0)
101
102#define pe__clear_action_flags_as(function, line, action, flags_to_clear) do { \
103 (action)->flags = pcmk__clear_flags_as((function), (line), \
104 LOG_TRACE, \
105 "Action", (action)->uuid, \
106 (action)->flags, \
107 (flags_to_clear), \
108 #flags_to_clear); \
109 } while (0)
110
111#define pe__set_order_flags(order_flags, flags_to_set) do { \
112 order_flags = pcmk__set_flags_as(__func__, __LINE__, LOG_TRACE, \
113 "Ordering", "constraint", \
114 order_flags, (flags_to_set), \
115 #flags_to_set); \
116 } while (0)
117
118#define pe__clear_order_flags(order_flags, flags_to_clear) do { \
119 order_flags = pcmk__clear_flags_as(__func__, __LINE__, LOG_TRACE, \
120 "Ordering", "constraint", \
121 order_flags, (flags_to_clear), \
122 #flags_to_clear); \
123 } while (0)
124
125#define pe__set_graph_flags(graph_flags, gr_action, flags_to_set) do { \
126 graph_flags = pcmk__set_flags_as(__func__, __LINE__, \
127 LOG_TRACE, "Graph", \
128 (gr_action)->uuid, graph_flags, \
129 (flags_to_set), #flags_to_set); \
130 } while (0)
131
132#define pe__clear_graph_flags(graph_flags, gr_action, flags_to_clear) do { \
133 graph_flags = pcmk__clear_flags_as(__func__, __LINE__, \
134 LOG_TRACE, "Graph", \
135 (gr_action)->uuid, graph_flags, \
136 (flags_to_clear), #flags_to_clear); \
137 } while (0)
138
139// Some warnings we don't want to print every transition
140
151
152extern uint32_t pe_wo;
153
154#define pe_warn_once(pe_wo_bit, fmt...) do { \
155 if (!pcmk_is_set(pe_wo, pe_wo_bit)) { \
156 if (pe_wo_bit == pe_wo_blind) { \
157 crm_warn(fmt); \
158 } else { \
159 pe_warn(fmt); \
160 } \
161 pe_wo = pcmk__set_flags_as(__func__, __LINE__, LOG_TRACE, \
162 "Warn-once", "logging", pe_wo, \
163 (pe_wo_bit), #pe_wo_bit); \
164 } \
165 } while (0);
166
167
169 char *id; // Constraint XML ID
170 pe_resource_t *rsc_lh; // Resource being located
171 enum rsc_role_e role_filter; // Role to locate
172 enum pe_discover_e discover_mode; // Resource discovery
173 GList *node_list_rh; // List of pe_node_t*
175
190
191typedef struct notify_data_s {
192 GSList *keys; // Environment variable name/value pairs
193
194 const char *action;
195
200
201 GList *active; /* notify_entry_t* */
202 GList *inactive; /* notify_entry_t* */
203 GList *start; /* notify_entry_t* */
204 GList *stop; /* notify_entry_t* */
205 GList *demote; /* notify_entry_t* */
206 GList *promote; /* notify_entry_t* */
207 GList *promoted; /* notify_entry_t* */
208 GList *unpromoted; /* notify_entry_t* */
209 GHashTable *allowed_nodes;
210
212
213bool pe_can_fence(pe_working_set_t *data_set, pe_node_t *node);
214
215int pe__add_scores(int score1, int score2);
216void add_hash_param(GHashTable * hash, const char *name, const char *value);
217
218char *native_parameter(pe_resource_t * rsc, pe_node_t * node, gboolean create, const char *name,
219 pe_working_set_t * data_set);
220pe_node_t *native_location(const pe_resource_t *rsc, GList **list, int current);
221
222void pe_metadata(void);
223void verify_pe_options(GHashTable * options);
224
225void common_update_score(pe_resource_t * rsc, const char *id, int score);
226void native_add_running(pe_resource_t * rsc, pe_node_t * node, pe_working_set_t * data_set, gboolean failed);
227
228gboolean native_unpack(pe_resource_t * rsc, pe_working_set_t * data_set);
229gboolean group_unpack(pe_resource_t * rsc, pe_working_set_t * data_set);
230gboolean clone_unpack(pe_resource_t * rsc, pe_working_set_t * data_set);
231gboolean pe__unpack_bundle(pe_resource_t *rsc, pe_working_set_t *data_set);
232
233pe_resource_t *native_find_rsc(pe_resource_t *rsc, const char *id, const pe_node_t *node,
234 int flags);
235
236gboolean native_active(pe_resource_t * rsc, gboolean all);
237gboolean group_active(pe_resource_t * rsc, gboolean all);
238gboolean clone_active(pe_resource_t * rsc, gboolean all);
239gboolean pe__bundle_active(pe_resource_t *rsc, gboolean all);
240
241void native_print(pe_resource_t * rsc, const char *pre_text, long options, void *print_data);
242void group_print(pe_resource_t * rsc, const char *pre_text, long options, void *print_data);
243void clone_print(pe_resource_t * rsc, const char *pre_text, long options, void *print_data);
244void pe__print_bundle(pe_resource_t *rsc, const char *pre_text, long options,
245 void *print_data);
246
247gchar * pcmk__native_output_string(pe_resource_t *rsc, const char *name, pe_node_t *node,
248 unsigned long show_opts, const char *target_role, bool show_nodes);
249
250int pe__name_and_nvpairs_xml(pcmk__output_t *out, bool is_list, const char *tag_name
251 , size_t pairs_count, ...);
252char *pe__node_display_name(pe_node_t *node, bool print_detail);
253
254static inline const char *
255pe__rsc_bool_str(pe_resource_t *rsc, uint64_t rsc_flag)
256{
257 return pcmk__btoa(pcmk_is_set(rsc->flags, rsc_flag));
258}
259
260int pe__clone_xml(pcmk__output_t *out, va_list args);
261int pe__clone_default(pcmk__output_t *out, va_list args);
262int pe__group_xml(pcmk__output_t *out, va_list args);
263int pe__group_default(pcmk__output_t *out, va_list args);
264int pe__bundle_xml(pcmk__output_t *out, va_list args);
265int pe__bundle_html(pcmk__output_t *out, va_list args);
266int pe__bundle_text(pcmk__output_t *out, va_list args);
267int pe__node_html(pcmk__output_t *out, va_list args);
268int pe__node_text(pcmk__output_t *out, va_list args);
269int pe__node_xml(pcmk__output_t *out, va_list args);
270int pe__resource_xml(pcmk__output_t *out, va_list args);
271int pe__resource_html(pcmk__output_t *out, va_list args);
272int pe__resource_text(pcmk__output_t *out, va_list args);
273
274void native_free(pe_resource_t * rsc);
275void group_free(pe_resource_t * rsc);
276void clone_free(pe_resource_t * rsc);
278
279enum rsc_role_e native_resource_state(const pe_resource_t * rsc, gboolean current);
280enum rsc_role_e group_resource_state(const pe_resource_t * rsc, gboolean current);
281enum rsc_role_e clone_resource_state(const pe_resource_t * rsc, gboolean current);
283 gboolean current);
284
287
288gboolean common_unpack(xmlNode * xml_obj, pe_resource_t ** rsc, pe_resource_t * parent,
289 pe_working_set_t * data_set);
290void common_free(pe_resource_t * rsc);
291
292pe_node_t *pe__copy_node(const pe_node_t *this_node);
293extern time_t get_effective_time(pe_working_set_t * data_set);
294
295/* Failure handling utilities (from failcounts.c) */
296
297// bit flags for fail count handling options
299 pe_fc_default = (1 << 0),
300 pe_fc_effective = (1 << 1), // don't count expired failures
301 pe_fc_fillers = (1 << 2), // if container, include filler failures in count
302};
303
304int pe_get_failcount(pe_node_t *node, pe_resource_t *rsc, time_t *last_failure,
305 uint32_t flags, xmlNode *xml_op,
306 pe_working_set_t *data_set);
307
309 const char *reason,
310 pe_working_set_t *data_set);
311
312/* Functions for finding/counting a resource's active nodes */
313
315 unsigned int *count_all,
316 unsigned int *count_clean);
318 unsigned int *count);
319
320static inline pe_node_t *
321pe__current_node(const pe_resource_t *rsc)
322{
323 return pe__find_active_on(rsc, NULL, NULL);
324}
325
326
327/* Binary like operators for lists of nodes */
328extern void node_list_exclude(GHashTable * list, GList *list2, gboolean merge_scores);
329
330GHashTable *pe__node_list2table(GList *list);
331
332static inline gpointer
333pe_hash_table_lookup(GHashTable * hash, gconstpointer key)
334{
335 if (hash) {
336 return g_hash_table_lookup(hash, key);
337 }
338 return NULL;
339}
340
341extern pe_action_t *get_pseudo_op(const char *name, pe_working_set_t * data_set);
342extern gboolean order_actions(pe_action_t * lh_action, pe_action_t * rh_action, enum pe_ordering order);
343
344/* Printing functions for debug */
345extern void print_str_str(gpointer key, gpointer value, gpointer user_data);
346extern void pe__output_node(pe_node_t * node, gboolean details, pcmk__output_t *out);
347
348void pe__show_node_weights_as(const char *file, const char *function,
349 int line, bool to_log, pe_resource_t *rsc,
350 const char *comment, GHashTable *nodes,
351 pe_working_set_t *data_set);
352
353#define pe__show_node_weights(level, rsc, text, nodes, data_set) \
354 pe__show_node_weights_as(__FILE__, __func__, __LINE__, \
355 (level), (rsc), (text), (nodes), (data_set))
356
357/* Sorting functions */
358extern gint sort_rsc_priority(gconstpointer a, gconstpointer b);
359extern gint sort_rsc_index(gconstpointer a, gconstpointer b);
360
361extern xmlNode *find_rsc_op_entry(pe_resource_t * rsc, const char *key);
362
363extern pe_action_t *custom_action(pe_resource_t * rsc, char *key, const char *task, pe_node_t * on_node,
364 gboolean optional, gboolean foo, pe_working_set_t * data_set);
365
366# define delete_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_DELETE, 0)
367# define delete_action(rsc, node, optional) custom_action( \
368 rsc, delete_key(rsc), CRMD_ACTION_DELETE, node, \
369 optional, TRUE, data_set);
370
371# define stopped_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_STOPPED, 0)
372# define stopped_action(rsc, node, optional) custom_action( \
373 rsc, stopped_key(rsc), CRMD_ACTION_STOPPED, node, \
374 optional, TRUE, data_set);
375
376# define stop_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_STOP, 0)
377# define stop_action(rsc, node, optional) custom_action( \
378 rsc, stop_key(rsc), CRMD_ACTION_STOP, node, \
379 optional, TRUE, data_set);
380
381# define reload_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_RELOAD_AGENT, 0)
382# define start_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_START, 0)
383# define start_action(rsc, node, optional) custom_action( \
384 rsc, start_key(rsc), CRMD_ACTION_START, node, \
385 optional, TRUE, data_set)
386
387# define started_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_STARTED, 0)
388# define started_action(rsc, node, optional) custom_action( \
389 rsc, started_key(rsc), CRMD_ACTION_STARTED, node, \
390 optional, TRUE, data_set)
391
392# define promote_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_PROMOTE, 0)
393# define promote_action(rsc, node, optional) custom_action( \
394 rsc, promote_key(rsc), CRMD_ACTION_PROMOTE, node, \
395 optional, TRUE, data_set)
396
397# define promoted_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_PROMOTED, 0)
398# define promoted_action(rsc, node, optional) custom_action( \
399 rsc, promoted_key(rsc), CRMD_ACTION_PROMOTED, node, \
400 optional, TRUE, data_set)
401
402# define demote_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_DEMOTE, 0)
403# define demote_action(rsc, node, optional) custom_action( \
404 rsc, demote_key(rsc), CRMD_ACTION_DEMOTE, node, \
405 optional, TRUE, data_set)
406
407# define demoted_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_DEMOTED, 0)
408# define demoted_action(rsc, node, optional) custom_action( \
409 rsc, demoted_key(rsc), CRMD_ACTION_DEMOTED, node, \
410 optional, TRUE, data_set)
411
412extern int pe_get_configured_timeout(pe_resource_t *rsc, const char *action,
413 pe_working_set_t *data_set);
414
415extern pe_action_t *find_first_action(GList *input, const char *uuid, const char *task,
416 pe_node_t * on_node);
417extern enum action_tasks get_complex_task(pe_resource_t * rsc, const char *name,
418 gboolean allow_non_atomic);
419
420extern GList *find_actions(GList *input, const char *key, const pe_node_t *on_node);
421GList *find_actions_exact(GList *input, const char *key,
422 const pe_node_t *on_node);
423extern GList *find_recurring_actions(GList *input, pe_node_t * not_on_node);
424GList *pe__resource_actions(const pe_resource_t *rsc, const pe_node_t *node,
425 const char *task, bool require_node);
426
427extern void pe_free_action(pe_action_t * action);
428
429extern void resource_location(pe_resource_t * rsc, pe_node_t * node, int score, const char *tag,
430 pe_working_set_t * data_set);
431
432extern gint sort_op_by_callid(gconstpointer a, gconstpointer b);
433extern gboolean get_target_role(pe_resource_t * rsc, enum rsc_role_e *role);
434void pe__set_next_role(pe_resource_t *rsc, enum rsc_role_e role,
435 const char *why);
436
437extern pe_resource_t *find_clone_instance(pe_resource_t * rsc, const char *sub_id,
438 pe_working_set_t * data_set);
439
440extern void destroy_ticket(gpointer data);
441extern pe_ticket_t *ticket_new(const char *ticket_id, pe_working_set_t * data_set);
442
443// Resources for manipulating resource names
444const char *pe_base_name_end(const char *id);
445char *clone_strip(const char *last_rsc_id);
446char *clone_zero(const char *last_rsc_id);
447
448static inline bool
449pe_base_name_eq(pe_resource_t *rsc, const char *id)
450{
451 if (id && rsc && rsc->id) {
452 // Number of characters in rsc->id before any clone suffix
453 size_t base_len = pe_base_name_end(rsc->id) - rsc->id + 1;
454
455 return (strlen(id) == base_len) && !strncmp(id, rsc->id, base_len);
456 }
457 return FALSE;
458}
459
460int pe__target_rc_from_xml(xmlNode *xml_op);
461
462gint sort_node_uname(gconstpointer a, gconstpointer b);
463bool is_set_recursive(pe_resource_t * rsc, long long flag, bool any);
464
476
486
488 guint *interval_ms, pe_node_t *node,
489 xmlNode *xml_op, GHashTable *overrides,
490 bool calc_secure,
491 pe_working_set_t *data_set);
492
493void pe__free_digests(gpointer ptr);
494
495op_digest_cache_t *rsc_action_digest_cmp(pe_resource_t * rsc, xmlNode * xml_op, pe_node_t * node,
496 pe_working_set_t * data_set);
497
498pe_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);
500 pe_resource_t * rsc, pe_node_t *node, const char *reason, pe_action_t *dependency, pe_working_set_t * data_set);
501
502void pe_action_set_reason(pe_action_t *action, const char *reason, bool overwrite);
503void 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);
504
505#define pe_action_required(action, reason, text) \
506 pe_action_set_flag_reason(__func__, __LINE__, action, reason, text, \
507 pe_action_optional, FALSE)
508#define pe_action_implies(action, reason, flag) \
509 pe_action_set_flag_reason(__func__, __LINE__, action, reason, NULL, \
510 flag, FALSE)
511
514void pe__clear_resource_flags_on_all(pe_working_set_t *data_set, uint64_t flag);
515
516gboolean add_tag_ref(GHashTable * tags, const char * tag_name, const char * obj_ref);
517
518void print_rscs_brief(GList *rsc_list, const char * pre_text, long options,
519 void * print_data, gboolean print_all);
520int pe__rscs_brief_output(pcmk__output_t *out, GList *rsc_list, unsigned int options);
521void pe_fence_node(pe_working_set_t * data_set, pe_node_t * node, const char *reason, bool priority_delay);
522
523pe_node_t *pe_create_node(const char *id, const char *uname, const char *type,
524 const char *score, pe_working_set_t * data_set);
525void common_print(pe_resource_t * rsc, const char *pre_text, const char *name, pe_node_t *node, long options, void *print_data);
526int pe__common_output_text(pcmk__output_t *out, pe_resource_t * rsc, const char *name, pe_node_t *node, unsigned int options);
527int pe__common_output_html(pcmk__output_t *out, pe_resource_t * rsc, const char *name, pe_node_t *node, unsigned int options);
529 const pe_node_t *node);
531 pe_working_set_t *data_set);
533 pe_working_set_t *data_set,
534 xmlNode *xml, const char *field);
535const char *pe_node_attribute_calculated(const pe_node_t *node,
536 const char *name,
537 const pe_resource_t *rsc);
538const char *pe_node_attribute_raw(pe_node_t *node, const char *name);
540 pe_working_set_t *data_set);
541void pe__add_param_check(xmlNode *rsc_op, pe_resource_t *rsc, pe_node_t *node,
542 enum pe_check_parameters, pe_working_set_t *data_set);
544 void (*cb)(pe_resource_t*, pe_node_t*, xmlNode*,
548
550void pe__update_recheck_time(time_t recheck, pe_working_set_t *data_set);
551
557
558void pe__unpack_dataset_nvpairs(xmlNode *xml_obj, const char *set_name,
559 pe_rule_eval_data_t *rule_data, GHashTable *hash,
560 const char *always_first, gboolean overwrite,
561 pe_working_set_t *data_set);
562
565 pe_working_set_t *data_set);
566
567GList *pe__rscs_with_tag(pe_working_set_t *data_set, const char *tag_name);
568GList *pe__unames_with_tag(pe_working_set_t *data_set, const char *tag_name);
569bool pe__rsc_has_tag(pe_working_set_t *data_set, const char *rsc, const char *tag);
570bool pe__uname_has_tag(pe_working_set_t *data_set, const char *node, const char *tag);
571
572bool pe__rsc_running_on_any(pe_resource_t *rsc, GList *node_list);
573GList *pe__filter_rsc_list(GList *rscs, GList *filter);
574GList * pe__build_node_name_list(pe_working_set_t *data_set, const char *s);
575GList * pe__build_rsc_list(pe_working_set_t *data_set, const char *s);
576
577bool pcmk__rsc_filtered_by_node(pe_resource_t *rsc, GList *only_node);
578
579gboolean pe__bundle_is_filtered(pe_resource_t *rsc, GList *only_rsc, gboolean check_parent);
580gboolean pe__clone_is_filtered(pe_resource_t *rsc, GList *only_rsc, gboolean check_parent);
581gboolean pe__group_is_filtered(pe_resource_t *rsc, GList *only_rsc, gboolean check_parent);
582gboolean pe__native_is_filtered(pe_resource_t *rsc, GList *only_rsc, gboolean check_parent);
583
584#endif
uint64_t flags
Definition remote.c:3
#define pcmk_is_set(g, f)
Convenience alias for pcmk_all_flags_set(), to check single flag.
Definition util.h:114
action_tasks
Definition common.h:62
rsc_role_e
Possible roles that a resource can be in.
Definition common.h:92
enum crm_ais_msg_types type
Definition cpg.c:3
char uname[MAX_NAME]
Definition cpg.c:5
char data[0]
Definition cpg.c:10
Formatted output for pacemaker tools.
char * name
Definition pcmk_fence.c:31
const char * action
Definition pcmk_fence.c:30
pe_check_parameters
Definition pe_types.h:195
pe_ordering
Definition pe_types.h:484
pe_discover_e
Definition pe_types.h:477
pe_action_flags
Definition pe_types.h:291
int pe__common_output_text(pcmk__output_t *out, pe_resource_t *rsc, const char *name, pe_node_t *node, unsigned int options)
Definition native.c:733
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.
Definition utils.c:1546
void verify_pe_options(GHashTable *options)
Definition common.c:302
GList * pe__build_rsc_list(pe_working_set_t *data_set, const char *s)
Definition utils.c:2470
int pe__clone_xml(pcmk__output_t *out, va_list args)
Definition clone.c:644
int pe__name_and_nvpairs_xml(pcmk__output_t *out, bool is_list, const char *tag_name, size_t pairs_count,...)
Definition pe_output.c:543
int pe__target_rc_from_xml(xmlNode *xml_op)
Definition unpack.c:3508
pe_resource_t * native_find_rsc(pe_resource_t *rsc, const char *id, const pe_node_t *node, int flags)
Definition native.c:268
void node_list_exclude(GHashTable *list, GList *list2, gboolean merge_scores)
Definition utils.c:161
bool pe__uname_has_tag(pe_working_set_t *data_set, const char *node, const char *tag)
Definition tags.c:99
GList * find_actions_exact(GList *input, const char *key, const pe_node_t *on_node)
Definition utils.c:1498
GList * find_actions(GList *input, const char *key, const pe_node_t *on_node)
Definition utils.c:1458
pe_resource_t * pe__find_bundle_replica(const pe_resource_t *bundle, const pe_node_t *node)
Definition bundle.c:1387
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)
Definition utils.c:415
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.
Definition unpack.c:97
pe_action_t * pe__clear_resource_history(pe_resource_t *rsc, pe_node_t *node, pe_working_set_t *data_set)
Definition utils.c:2387
void pe__free_bundle(pe_resource_t *rsc)
Definition bundle.c:1958
const char * pe__add_bundle_remote_name(pe_resource_t *rsc, pe_working_set_t *data_set, xmlNode *xml, const char *field)
Definition bundle.c:968
bool pe__is_universal_clone(pe_resource_t *rsc, pe_working_set_t *data_set)
Definition clone.c:1012
pe_node_t * pe__find_active_on(const pe_resource_t *rsc, unsigned int *count_all, unsigned int *count_clean)
Definition complex.c:999
gboolean pe__native_is_filtered(pe_resource_t *rsc, GList *only_rsc, gboolean check_parent)
Definition native.c:1356
void pe__set_resource_flags_recursive(pe_resource_t *rsc, uint64_t flags)
Definition utils.c:1944
pe_action_t * find_first_action(GList *input, const char *uuid, const char *task, pe_node_t *on_node)
Definition utils.c:1428
bool pe__rsc_running_on_any(pe_resource_t *rsc, GList *node_list)
Definition utils.c:2399
void clone_print(pe_resource_t *rsc, const char *pre_text, long options, void *print_data)
Definition clone.c:428
void destroy_ticket(gpointer data)
Definition utils.c:1870
bool is_set_recursive(pe_resource_t *rsc, long long flag, bool any)
Definition clone.c:397
op_digest_cache_t * pe__calculate_digests(pe_resource_t *rsc, const char *task, guint *interval_ms, pe_node_t *node, xmlNode *xml_op, GHashTable *overrides, bool calc_secure, pe_working_set_t *data_set)
Definition pe_digest.c:321
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)
Definition utils.c:2220
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)
Definition pe_digest.c:392
gboolean group_active(pe_resource_t *rsc, gboolean all)
Definition group.c:164
const char * pe_base_name_end(const char *id)
Definition unpack.c:1594
char * pe__node_display_name(pe_node_t *node, bool print_detail)
Definition pe_output.c:491
GHashTable * pe__node_list2table(GList *list)
Definition utils.c:204
void pe__clear_resource_flags_on_all(pe_working_set_t *data_set, uint64_t flag)
Definition utils.c:1935
GList * pe__unames_with_tag(pe_working_set_t *data_set, const char *tag_name)
Definition tags.c:51
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 *))
Definition remote.c:246
int pe__node_text(pcmk__output_t *out, va_list args)
bool pcmk__rsc_filtered_by_node(pe_resource_t *rsc, GList *only_node)
Definition utils.c:2412
gchar * pcmk__native_output_string(pe_resource_t *rsc, const char *name, pe_node_t *node, unsigned long show_opts, const char *target_role, bool show_nodes)
Definition native.c:545
const char * pe_node_attribute_raw(pe_node_t *node, const char *name)
Definition common.c:635
void pe__count_common(pe_resource_t *rsc)
Definition complex.c:1088
void trigger_unfencing(pe_resource_t *rsc, pe_node_t *node, const char *reason, pe_action_t *dependency, pe_working_set_t *data_set)
Definition utils.c:2149
struct pe__order_constraint_s pe__ordering_t
gboolean group_unpack(pe_resource_t *rsc, pe_working_set_t *data_set)
Definition group.c:97
int pe__bundle_xml(pcmk__output_t *out, va_list args)
Definition bundle.c:1475
int pe__group_xml(pcmk__output_t *out, va_list args)
Definition group.c:259
bool pe__resource_is_disabled(pe_resource_t *rsc)
Definition utils.c:2359
void pe__count_bundle(pe_resource_t *rsc)
Definition bundle.c:2019
bool pe__rsc_has_tag(pe_working_set_t *data_set, const char *rsc, const char *tag)
Definition tags.c:84
char * native_parameter(pe_resource_t *rsc, pe_node_t *node, gboolean create, const char *name, pe_working_set_t *data_set)
Definition native.c:324
gboolean clone_active(pe_resource_t *rsc, gboolean all)
Definition clone.c:295
struct notify_data_s notify_data_t
enum rsc_role_e clone_resource_state(const pe_resource_t *rsc, gboolean current)
Definition clone.c:986
pe_action_t * get_pseudo_op(const char *name, pe_working_set_t *data_set)
Definition utils.c:1854
int pe__bundle_html(pcmk__output_t *out, va_list args)
Definition bundle.c:1599
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)
Definition failcounts.c:251
void clone_free(pe_resource_t *rsc)
Definition clone.c:952
int pe__clone_default(pcmk__output_t *out, va_list args)
Definition clone.c:706
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, pe_working_set_t *data_set)
Definition utils.c:304
void pe__set_next_role(pe_resource_t *rsc, enum rsc_role_e role, const char *why)
Definition complex.c:1116
gboolean get_target_role(pe_resource_t *rsc, enum rsc_role_e *role)
Definition utils.c:1770
GList * pe__build_node_name_list(pe_working_set_t *data_set, const char *s)
Definition utils.c:2438
gboolean pe__clone_is_filtered(pe_resource_t *rsc, GList *only_rsc, gboolean check_parent)
Definition clone.c:1027
GList * pe__filter_rsc_list(GList *rscs, GList *filter)
Definition utils.c:2418
pe_node_t * pe__find_active_requires(const pe_resource_t *rsc, unsigned int *count)
Definition complex.c:1079
gboolean pe__bundle_is_filtered(pe_resource_t *rsc, GList *only_rsc, gboolean check_parent)
Definition bundle.c:2043
bool pe__bundle_needs_remote_name(pe_resource_t *rsc, pe_working_set_t *data_set)
Definition bundle.c:950
GList * pe__rscs_with_tag(pe_working_set_t *data_set, const char *tag_name)
Definition tags.c:20
void pe__free_param_checks(pe_working_set_t *data_set)
Definition remote.c:261
gint sort_node_uname(gconstpointer a, gconstpointer b)
Definition utils.c:218
int pe__bundle_text(pcmk__output_t *out, va_list args)
Definition bundle.c:1727
enum action_tasks get_complex_task(pe_resource_t *rsc, const char *name, gboolean allow_non_atomic)
Definition utils.c:1405
void pe__free_digests(gpointer ptr)
Definition pe_digest.c:34
char * clone_zero(const char *last_rsc_id)
Definition unpack.c:1656
pe_warn_once_e
Definition internal.h:141
@ pe_wo_role_after
Definition internal.h:144
@ pe_wo_order_score
Definition internal.h:147
@ pe_wo_blind
Definition internal.h:142
@ pe_wo_poweroff
Definition internal.h:145
@ pe_wo_remove_after
Definition internal.h:149
@ pe_wo_require_all
Definition internal.h:146
@ pe_wo_neg_threshold
Definition internal.h:148
@ pe_wo_restart_type
Definition internal.h:143
void common_update_score(pe_resource_t *rsc, const char *id, int score)
Definition complex.c:864
gboolean common_unpack(xmlNode *xml_obj, pe_resource_t **rsc, pe_resource_t *parent, pe_working_set_t *data_set)
Definition complex.c:493
void pe_free_action(pe_action_t *action)
Definition utils.c:1344
void pe__register_messages(pcmk__output_t *out)
Definition pe_output.c:2732
gboolean clone_unpack(pe_resource_t *rsc, pe_working_set_t *data_set)
Definition clone.c:154
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)
Definition remote.c:220
gboolean order_actions(pe_action_t *lh_action, pe_action_t *rh_action, enum pe_ordering order)
Definition utils.c:1808
gint sort_rsc_priority(gconstpointer a, gconstpointer b)
Definition utils.c:362
int pe__add_scores(int score1, int score2)
Definition common.c:516
gboolean pe__group_is_filtered(pe_resource_t *rsc, GList *only_rsc, gboolean check_parent)
Definition group.c:401
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.
Definition failcounts.c:364
void common_print(pe_resource_t *rsc, const char *pre_text, const char *name, pe_node_t *node, long options, void *print_data)
Definition native.c:764
rsc_digest_cmp_val
Definition internal.h:465
@ RSC_DIGEST_ALL
Definition internal.h:471
@ RSC_DIGEST_UNKNOWN
Definition internal.h:474
@ RSC_DIGEST_RESTART
Definition internal.h:469
@ RSC_DIGEST_MATCH
Definition internal.h:467
struct op_digest_cache_s op_digest_cache_t
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)
Definition utils.c:2041
gboolean native_active(pe_resource_t *rsc, gboolean all)
Definition native.c:348
void print_str_str(gpointer key, gpointer value, gpointer user_data)
Definition utils.c:1336
void group_free(pe_resource_t *rsc)
Definition group.c:361
void native_add_running(pe_resource_t *rsc, pe_node_t *node, pe_working_set_t *data_set, gboolean failed)
Definition native.c:90
pe_node_t * native_location(const pe_resource_t *rsc, GList **list, int current)
Definition native.c:1052
void native_print(pe_resource_t *rsc, const char *pre_text, long options, void *print_data)
Definition native.c:879
void print_rscs_brief(GList *rsc_list, const char *pre_text, long options, void *print_data, gboolean print_all)
Definition native.c:1184
bool pe__shutdown_requested(pe_node_t *node)
Definition utils.c:2312
gint sort_op_by_callid(gconstpointer a, gconstpointer b)
Definition utils.c:1638
void resource_location(pe_resource_t *rsc, pe_node_t *node, int score, const char *tag, pe_working_set_t *data_set)
Definition utils.c:1594
int pe__node_xml(pcmk__output_t *out, va_list args)
time_t get_effective_time(pe_working_set_t *data_set)
Definition utils.c:1755
gboolean pe__bundle_active(pe_resource_t *rsc, gboolean all)
Definition bundle.c:1339
void pe__unpack_dataset_nvpairs(xmlNode *xml_obj, const char *set_name, pe_rule_eval_data_t *rule_data, GHashTable *hash, const char *always_first, gboolean overwrite, pe_working_set_t *data_set)
Definition utils.c:2341
gboolean native_unpack(pe_resource_t *rsc, pe_working_set_t *data_set)
Definition native.c:198
void native_free(pe_resource_t *rsc)
Definition native.c:1022
gint sort_rsc_index(gconstpointer a, gconstpointer b)
Definition utils.c:335
int pe__rscs_brief_output(pcmk__output_t *out, GList *rsc_list, unsigned int options)
Definition native.c:1263
enum rsc_role_e native_resource_state(const pe_resource_t *rsc, gboolean current)
Definition native.c:1029
int pe__node_html(pcmk__output_t *out, va_list args)
pe_ticket_t * ticket_new(const char *ticket_id, pe_working_set_t *data_set)
Definition utils.c:1882
const char * pe_node_attribute_calculated(const pe_node_t *node, const char *name, const pe_resource_t *rsc)
Definition common.c:596
uint32_t pe_wo
Definition unpack.c:68
enum rsc_role_e group_resource_state(const pe_resource_t *rsc, gboolean current)
Definition group.c:382
char * clone_strip(const char *last_rsc_id)
Definition unpack.c:1634
pe_resource_t * find_clone_instance(pe_resource_t *rsc, const char *sub_id, pe_working_set_t *data_set)
Definition clone.c:84
void pe__output_node(pe_node_t *node, gboolean details, pcmk__output_t *out)
Definition pe_output.c:2737
void pe_metadata(void)
Definition common.c:292
void pe__update_recheck_time(time_t recheck, pe_working_set_t *data_set)
Definition utils.c:2327
GList * find_recurring_actions(GList *input, pe_node_t *not_on_node)
Definition utils.c:1371
pe_fc_flags_e
Definition internal.h:298
@ pe_fc_effective
Definition internal.h:300
@ pe_fc_default
Definition internal.h:299
@ pe_fc_fillers
Definition internal.h:301
enum rsc_role_e pe__bundle_resource_state(const pe_resource_t *rsc, gboolean current)
Definition bundle.c:1992
int pe__resource_xml(pcmk__output_t *out, va_list args)
Definition native.c:901
void pe_action_set_reason(pe_action_t *action, const char *reason, bool overwrite)
Definition utils.c:2278
gboolean pe__unpack_bundle(pe_resource_t *rsc, pe_working_set_t *data_set)
Definition bundle.c:1014
pe_node_t * pe__copy_node(const pe_node_t *this_node)
Definition utils.c:142
int pe_get_configured_timeout(pe_resource_t *rsc, const char *action, pe_working_set_t *data_set)
Definition utils.c:853
void group_print(pe_resource_t *rsc, const char *pre_text, long options, void *print_data)
Definition group.c:209
struct pe__location_constraint_s pe__location_t
int pe__common_output_html(pcmk__output_t *out, pe_resource_t *rsc, const char *name, pe_node_t *node, unsigned int options)
Definition native.c:677
int pe__group_default(pcmk__output_t *out, va_list args)
Definition group.c:309
void pe__print_bundle(pe_resource_t *rsc, const char *pre_text, long options, void *print_data)
Definition bundle.c:1856
gboolean add_tag_ref(GHashTable *tags, const char *tag_name, const char *obj_ref)
Definition utils.c:2184
void pe__clear_resource_flags_recursive(pe_resource_t *rsc, uint64_t flags)
Definition utils.c:1926
int pe__resource_text(pcmk__output_t *out, va_list args)
Definition native.c:999
void common_free(pe_resource_t *rsc)
Definition complex.c:917
int pe__resource_html(pcmk__output_t *out, va_list args)
Definition native.c:975
bool pe_can_fence(pe_working_set_t *data_set, pe_node_t *node)
Definition utils.c:90
void add_hash_param(GHashTable *hash, const char *name, const char *value)
Definition common.c:579
xmlNode * find_rsc_op_entry(pe_resource_t *rsc, const char *key)
Definition utils.c:1327
pe_node_t * pe_create_node(const char *id, const char *uname, const char *type, const char *score, pe_working_set_t *data_set)
Definition unpack.c:390
Cluster status and scheduling.
const char * action
Definition internal.h:194
GHashTable * allowed_nodes
Definition internal.h:209
GList * promote
Definition internal.h:206
GList * unpromoted
Definition internal.h:208
GList * active
Definition internal.h:201
GList * inactive
Definition internal.h:202
GList * promoted
Definition internal.h:207
GList * start
Definition internal.h:203
pe_action_t * post
Definition internal.h:197
pe_action_t * pre_done
Definition internal.h:198
pe_action_t * pre
Definition internal.h:196
GList * stop
Definition internal.h:204
GSList * keys
Definition internal.h:192
pe_action_t * post_done
Definition internal.h:199
GList * demote
Definition internal.h:205
char * digest_all_calc
Definition internal.h:482
xmlNode * params_secure
Definition internal.h:480
char * digest_secure_calc
Definition internal.h:483
char * digest_restart_calc
Definition internal.h:484
xmlNode * params_restart
Definition internal.h:481
enum rsc_digest_cmp_val rc
Definition internal.h:478
xmlNode * params_all
Definition internal.h:479
This structure contains everything that makes up a single output formatter.
enum pe_discover_e discover_mode
Definition internal.h:172
pe_resource_t * rsc_lh
Definition internal.h:170
enum rsc_role_e role_filter
Definition internal.h:171
pe_action_t * rh_action
Definition internal.h:187
pe_resource_t * rh_rsc
Definition internal.h:186
enum pe_ordering type
Definition internal.h:178
pe_resource_t * lh_rsc
Definition internal.h:181
pe_action_t * lh_action
Definition internal.h:182
unsigned long long flags
Definition pe_types.h:349