pacemaker  2.0.5-ba59be7122
Scalable High-Availability cluster resource manager
internal.h
Go to the documentation of this file.
1 /*
2  * Copyright 2004-2020 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 
142  pe_wo_blind = 0x0001,
145  pe_wo_poweroff = 0x0008,
149 };
150 
151 extern uint32_t pe_wo;
152 
153 #define pe_warn_once(pe_wo_bit, fmt...) do { \
154  if (!pcmk_is_set(pe_wo, pe_wo_bit)) { \
155  if (pe_wo_bit == pe_wo_blind) { \
156  crm_warn(fmt); \
157  } else { \
158  pe_warn(fmt); \
159  } \
160  pe_wo = pcmk__set_flags_as(__func__, __LINE__, LOG_TRACE, \
161  "Warn-once", "logging", pe_wo, \
162  (pe_wo_bit), #pe_wo_bit); \
163  } \
164  } while (0);
165 
166 
168  char *id; // Constraint XML ID
169  pe_resource_t *rsc_lh; // Resource being located
170  enum rsc_role_e role_filter; // Role to locate
171  enum pe_discover_e discover_mode; // Resource discovery
172  GListPtr node_list_rh; // List of pe_node_t*
174 
175 typedef struct pe__order_constraint_s {
176  int id;
177  enum pe_ordering type;
178 
179  void *lh_opaque;
183 
184  void *rh_opaque;
189 
190 typedef struct notify_data_s {
191  GSList *keys; // Environment variable name/value pairs
192 
193  const char *action;
194 
199 
200  GListPtr active; /* notify_entry_t* */
201  GListPtr inactive; /* notify_entry_t* */
202  GListPtr start; /* notify_entry_t* */
203  GListPtr stop; /* notify_entry_t* */
204  GListPtr demote; /* notify_entry_t* */
205  GListPtr promote; /* notify_entry_t* */
206  GListPtr master; /* notify_entry_t* */
207  GListPtr slave; /* notify_entry_t* */
208  GHashTable *allowed_nodes;
209 
211 
212 bool pe_can_fence(pe_working_set_t *data_set, pe_node_t *node);
213 
214 int pe__add_scores(int score1, int score2);
215 void add_hash_param(GHashTable * hash, const char *name, const char *value);
216 
217 char *native_parameter(pe_resource_t * rsc, pe_node_t * node, gboolean create, const char *name,
218  pe_working_set_t * data_set);
219 pe_node_t *native_location(const pe_resource_t *rsc, GList **list, int current);
220 
221 void pe_metadata(void);
222 void verify_pe_options(GHashTable * options);
223 
224 void common_update_score(pe_resource_t * rsc, const char *id, int score);
225 void native_add_running(pe_resource_t * rsc, pe_node_t * node, pe_working_set_t * data_set);
226 
227 gboolean native_unpack(pe_resource_t * rsc, pe_working_set_t * data_set);
228 gboolean group_unpack(pe_resource_t * rsc, pe_working_set_t * data_set);
229 gboolean clone_unpack(pe_resource_t * rsc, pe_working_set_t * data_set);
230 gboolean pe__unpack_bundle(pe_resource_t *rsc, pe_working_set_t *data_set);
231 
232 pe_resource_t *native_find_rsc(pe_resource_t *rsc, const char *id, const pe_node_t *node,
233  int flags);
234 
235 gboolean native_active(pe_resource_t * rsc, gboolean all);
236 gboolean group_active(pe_resource_t * rsc, gboolean all);
237 gboolean clone_active(pe_resource_t * rsc, gboolean all);
238 gboolean pe__bundle_active(pe_resource_t *rsc, gboolean all);
239 
240 void native_print(pe_resource_t * rsc, const char *pre_text, long options, void *print_data);
241 void group_print(pe_resource_t * rsc, const char *pre_text, long options, void *print_data);
242 void clone_print(pe_resource_t * rsc, const char *pre_text, long options, void *print_data);
243 void pe__print_bundle(pe_resource_t *rsc, const char *pre_text, long options,
244  void *print_data);
245 
246 int pe__name_and_nvpairs_xml(pcmk__output_t *out, bool is_list, const char *tag_name
247  , size_t pairs_count, ...);
248 char *pe__node_display_name(pe_node_t *node, bool print_detail);
249 
250 static inline const char *
251 pe__rsc_bool_str(pe_resource_t *rsc, uint64_t rsc_flag)
252 {
253  return pcmk__btoa(pcmk_is_set(rsc->flags, rsc_flag));
254 }
255 
256 int pe__ban_html(pcmk__output_t *out, va_list args);
257 int pe__ban_text(pcmk__output_t *out, va_list args);
258 int pe__ban_xml(pcmk__output_t *out, va_list args);
259 int pe__clone_xml(pcmk__output_t *out, va_list args);
260 int pe__clone_html(pcmk__output_t *out, va_list args);
261 int pe__clone_text(pcmk__output_t *out, va_list args);
262 int pe__cluster_counts_html(pcmk__output_t *out, va_list args);
263 int pe__cluster_counts_text(pcmk__output_t *out, va_list args);
264 int pe__cluster_counts_xml(pcmk__output_t *out, va_list args);
265 int pe__cluster_dc_html(pcmk__output_t *out, va_list args);
266 int pe__cluster_dc_text(pcmk__output_t *out, va_list args);
267 int pe__cluster_dc_xml(pcmk__output_t *out, va_list args);
269 int pe__cluster_maint_mode_text(pcmk__output_t *out, va_list args);
270 int pe__cluster_options_html(pcmk__output_t *out, va_list args);
271 int pe__cluster_options_log(pcmk__output_t *out, va_list args);
272 int pe__cluster_options_text(pcmk__output_t *out, va_list args);
273 int pe__cluster_options_xml(pcmk__output_t *out, va_list args);
274 int pe__cluster_stack_html(pcmk__output_t *out, va_list args);
275 int pe__cluster_stack_text(pcmk__output_t *out, va_list args);
276 int pe__cluster_stack_xml(pcmk__output_t *out, va_list args);
277 int pe__cluster_summary(pcmk__output_t *out, va_list args);
278 int pe__cluster_summary_html(pcmk__output_t *out, va_list args);
279 int pe__cluster_times_html(pcmk__output_t *out, va_list args);
280 int pe__cluster_times_xml(pcmk__output_t *out, va_list args);
281 int pe__cluster_times_text(pcmk__output_t *out, va_list args);
282 int pe__failed_action_text(pcmk__output_t *out, va_list args);
283 int pe__failed_action_xml(pcmk__output_t *out, va_list args);
284 int pe__group_xml(pcmk__output_t *out, va_list args);
285 int pe__group_html(pcmk__output_t *out, va_list args);
286 int pe__group_text(pcmk__output_t *out, va_list args);
287 int pe__bundle_xml(pcmk__output_t *out, va_list args);
288 int pe__bundle_html(pcmk__output_t *out, va_list args);
289 int pe__bundle_text(pcmk__output_t *out, va_list args);
290 int pe__node_html(pcmk__output_t *out, va_list args);
291 int pe__node_text(pcmk__output_t *out, va_list args);
292 int pe__node_xml(pcmk__output_t *out, va_list args);
293 int pe__node_attribute_html(pcmk__output_t *out, va_list args);
294 int pe__node_attribute_text(pcmk__output_t *out, va_list args);
295 int pe__node_attribute_xml(pcmk__output_t *out, va_list args);
296 int pe__node_list_html(pcmk__output_t *out, va_list args);
297 int pe__node_list_text(pcmk__output_t *out, va_list args);
298 int pe__node_list_xml(pcmk__output_t *out, va_list args);
299 int pe__op_history_text(pcmk__output_t *out, va_list args);
300 int pe__op_history_xml(pcmk__output_t *out, va_list args);
301 int pe__resource_history_text(pcmk__output_t *out, va_list args);
302 int pe__resource_history_xml(pcmk__output_t *out, va_list args);
303 int pe__resource_xml(pcmk__output_t *out, va_list args);
304 int pe__resource_html(pcmk__output_t *out, va_list args);
305 int pe__resource_text(pcmk__output_t *out, va_list args);
306 int pe__resource_list(pcmk__output_t *out, va_list args);
307 int pe__ticket_html(pcmk__output_t *out, va_list args);
308 int pe__ticket_text(pcmk__output_t *out, va_list args);
309 int pe__ticket_xml(pcmk__output_t *out, va_list args);
310 
311 void native_free(pe_resource_t * rsc);
312 void group_free(pe_resource_t * rsc);
313 void clone_free(pe_resource_t * rsc);
314 void pe__free_bundle(pe_resource_t *rsc);
315 
316 enum rsc_role_e native_resource_state(const pe_resource_t * rsc, gboolean current);
317 enum rsc_role_e group_resource_state(const pe_resource_t * rsc, gboolean current);
318 enum rsc_role_e clone_resource_state(const pe_resource_t * rsc, gboolean current);
320  gboolean current);
321 
324 
325 gboolean common_unpack(xmlNode * xml_obj, pe_resource_t ** rsc, pe_resource_t * parent,
326  pe_working_set_t * data_set);
327 void common_free(pe_resource_t * rsc);
328 
329 pe_node_t *pe__copy_node(const pe_node_t *this_node);
330 extern time_t get_effective_time(pe_working_set_t * data_set);
331 
332 /* Failure handling utilities (from failcounts.c) */
333 
334 // bit flags for fail count handling options
337  pe_fc_effective = 0x01, // don't count expired failures
338  pe_fc_fillers = 0x02, // if container, include filler failures in count
339 };
340 
341 int pe_get_failcount(pe_node_t *node, pe_resource_t *rsc, time_t *last_failure,
342  uint32_t flags, xmlNode *xml_op,
343  pe_working_set_t *data_set);
344 
346  const char *reason,
347  pe_working_set_t *data_set);
348 
349 /* Functions for finding/counting a resource's active nodes */
350 
352  unsigned int *count_all,
353  unsigned int *count_clean);
355  unsigned int *count);
356 
357 static inline pe_node_t *
358 pe__current_node(const pe_resource_t *rsc)
359 {
360  return pe__find_active_on(rsc, NULL, NULL);
361 }
362 
363 
364 /* Binary like operators for lists of nodes */
365 extern void node_list_exclude(GHashTable * list, GListPtr list2, gboolean merge_scores);
366 
367 GHashTable *pe__node_list2table(GList *list);
368 
369 static inline gpointer
370 pe_hash_table_lookup(GHashTable * hash, gconstpointer key)
371 {
372  if (hash) {
373  return g_hash_table_lookup(hash, key);
374  }
375  return NULL;
376 }
377 
378 extern pe_action_t *get_pseudo_op(const char *name, pe_working_set_t * data_set);
379 extern gboolean order_actions(pe_action_t * lh_action, pe_action_t * rh_action, enum pe_ordering order);
380 
381 /* Printing functions for debug */
382 extern void print_node(const char *pre_text, pe_node_t * node, gboolean details);
383 extern void print_str_str(gpointer key, gpointer value, gpointer user_data);
384 extern void pe__output_node(pe_node_t * node, gboolean details, pcmk__output_t *out);
385 
386 extern void dump_node_capacity(int level, const char *comment, pe_node_t * node);
387 extern void dump_rsc_utilization(int level, const char *comment, pe_resource_t * rsc, pe_node_t * node);
388 
389 void pe__show_node_weights_as(const char *file, const char *function,
390  int line, bool to_log, pe_resource_t *rsc,
391  const char *comment, GHashTable *nodes);
392 
393 #define pe__show_node_weights(level, rsc, text, nodes) \
394  pe__show_node_weights_as(__FILE__, __func__, __LINE__, \
395  (level), (rsc), (text), (nodes))
396 
397 /* Sorting functions */
398 extern gint sort_rsc_priority(gconstpointer a, gconstpointer b);
399 extern gint sort_rsc_index(gconstpointer a, gconstpointer b);
400 
401 extern xmlNode *find_rsc_op_entry(pe_resource_t * rsc, const char *key);
402 
403 extern pe_action_t *custom_action(pe_resource_t * rsc, char *key, const char *task, pe_node_t * on_node,
404  gboolean optional, gboolean foo, pe_working_set_t * data_set);
405 
406 # define delete_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_DELETE, 0)
407 # define delete_action(rsc, node, optional) custom_action( \
408  rsc, delete_key(rsc), CRMD_ACTION_DELETE, node, \
409  optional, TRUE, data_set);
410 
411 # define stopped_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_STOPPED, 0)
412 # define stopped_action(rsc, node, optional) custom_action( \
413  rsc, stopped_key(rsc), CRMD_ACTION_STOPPED, node, \
414  optional, TRUE, data_set);
415 
416 # define stop_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_STOP, 0)
417 # define stop_action(rsc, node, optional) custom_action( \
418  rsc, stop_key(rsc), CRMD_ACTION_STOP, node, \
419  optional, TRUE, data_set);
420 
421 # define reload_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_RELOAD, 0)
422 # define start_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_START, 0)
423 # define start_action(rsc, node, optional) custom_action( \
424  rsc, start_key(rsc), CRMD_ACTION_START, node, \
425  optional, TRUE, data_set)
426 
427 # define started_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_STARTED, 0)
428 # define started_action(rsc, node, optional) custom_action( \
429  rsc, started_key(rsc), CRMD_ACTION_STARTED, node, \
430  optional, TRUE, data_set)
431 
432 # define promote_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_PROMOTE, 0)
433 # define promote_action(rsc, node, optional) custom_action( \
434  rsc, promote_key(rsc), CRMD_ACTION_PROMOTE, node, \
435  optional, TRUE, data_set)
436 
437 # define promoted_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_PROMOTED, 0)
438 # define promoted_action(rsc, node, optional) custom_action( \
439  rsc, promoted_key(rsc), CRMD_ACTION_PROMOTED, node, \
440  optional, TRUE, data_set)
441 
442 # define demote_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_DEMOTE, 0)
443 # define demote_action(rsc, node, optional) custom_action( \
444  rsc, demote_key(rsc), CRMD_ACTION_DEMOTE, node, \
445  optional, TRUE, data_set)
446 
447 # define demoted_key(rsc) pcmk__op_key(rsc->id, CRMD_ACTION_DEMOTED, 0)
448 # define demoted_action(rsc, node, optional) custom_action( \
449  rsc, demoted_key(rsc), CRMD_ACTION_DEMOTED, node, \
450  optional, TRUE, data_set)
451 
452 extern int pe_get_configured_timeout(pe_resource_t *rsc, const char *action,
453  pe_working_set_t *data_set);
454 
455 extern pe_action_t *find_first_action(GListPtr input, const char *uuid, const char *task,
456  pe_node_t * on_node);
457 extern enum action_tasks get_complex_task(pe_resource_t * rsc, const char *name,
458  gboolean allow_non_atomic);
459 
460 extern GListPtr find_actions(GListPtr input, const char *key, const pe_node_t *on_node);
461 GList *find_actions_exact(GList *input, const char *key,
462  const pe_node_t *on_node);
463 extern GListPtr find_recurring_actions(GListPtr input, pe_node_t * not_on_node);
464 GList *pe__resource_actions(const pe_resource_t *rsc, const pe_node_t *node,
465  const char *task, bool require_node);
466 
467 extern void pe_free_action(pe_action_t * action);
468 
469 extern void resource_location(pe_resource_t * rsc, pe_node_t * node, int score, const char *tag,
470  pe_working_set_t * data_set);
471 
472 extern gint sort_op_by_callid(gconstpointer a, gconstpointer b);
473 extern gboolean get_target_role(pe_resource_t * rsc, enum rsc_role_e *role);
474 
475 extern pe_resource_t *find_clone_instance(pe_resource_t * rsc, const char *sub_id,
476  pe_working_set_t * data_set);
477 
478 extern void destroy_ticket(gpointer data);
479 extern pe_ticket_t *ticket_new(const char *ticket_id, pe_working_set_t * data_set);
480 
481 // Resources for manipulating resource names
482 const char *pe_base_name_end(const char *id);
483 char *clone_strip(const char *last_rsc_id);
484 char *clone_zero(const char *last_rsc_id);
485 
486 static inline bool
487 pe_base_name_eq(pe_resource_t *rsc, const char *id)
488 {
489  if (id && rsc && rsc->id) {
490  // Number of characters in rsc->id before any clone suffix
491  size_t base_len = pe_base_name_end(rsc->id) - rsc->id + 1;
492 
493  return (strlen(id) == base_len) && !strncmp(id, rsc->id, base_len);
494  }
495  return FALSE;
496 }
497 
498 int pe__target_rc_from_xml(xmlNode *xml_op);
499 
500 gint sort_node_uname(gconstpointer a, gconstpointer b);
501 bool is_set_recursive(pe_resource_t * rsc, long long flag, bool any);
502 
513 };
514 
515 typedef struct op_digest_cache_s {
516  enum rsc_digest_cmp_val rc;
517  xmlNode *params_all;
518  xmlNode *params_secure;
519  xmlNode *params_restart;
524 
525 op_digest_cache_t *rsc_action_digest_cmp(pe_resource_t * rsc, xmlNode * xml_op, pe_node_t * node,
526  pe_working_set_t * data_set);
527 
528 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);
529 void trigger_unfencing(
530  pe_resource_t * rsc, pe_node_t *node, const char *reason, pe_action_t *dependency, pe_working_set_t * data_set);
531 
532 void pe_action_set_reason(pe_action_t *action, const char *reason, bool overwrite);
533 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);
534 
535 #define pe_action_required(action, reason, text) \
536  pe_action_set_flag_reason(__func__, __LINE__, action, reason, text, \
537  pe_action_optional, FALSE)
538 #define pe_action_implies(action, reason, flag) \
539  pe_action_set_flag_reason(__func__, __LINE__, action, reason, NULL, \
540  flag, FALSE)
541 
544 
545 gboolean add_tag_ref(GHashTable * tags, const char * tag_name, const char * obj_ref);
546 
547 void print_rscs_brief(GListPtr rsc_list, const char * pre_text, long options,
548  void * print_data, gboolean print_all);
549 int pe__rscs_brief_output(pcmk__output_t *out, GListPtr rsc_list, long options, gboolean print_all);
550 void pe_fence_node(pe_working_set_t * data_set, pe_node_t * node, const char *reason, bool priority_delay);
551 
552 pe_node_t *pe_create_node(const char *id, const char *uname, const char *type,
553  const char *score, pe_working_set_t * data_set);
554 void common_print(pe_resource_t * rsc, const char *pre_text, const char *name, pe_node_t *node, long options, void *print_data);
555 int pe__common_output_text(pcmk__output_t *out, pe_resource_t * rsc, const char *name, pe_node_t *node, long options);
556 int pe__common_output_html(pcmk__output_t *out, pe_resource_t * rsc, const char *name, pe_node_t *node, long options);
558  const pe_node_t *node);
560 const char *pe__add_bundle_remote_name(pe_resource_t *rsc, xmlNode *xml,
561  const char *field);
562 const char *pe_node_attribute_calculated(const pe_node_t *node,
563  const char *name,
564  const pe_resource_t *rsc);
565 const char *pe_node_attribute_raw(pe_node_t *node, const char *name);
567  pe_working_set_t *data_set);
568 void pe__add_param_check(xmlNode *rsc_op, pe_resource_t *rsc, pe_node_t *node,
569  enum pe_check_parameters, pe_working_set_t *data_set);
571  void (*cb)(pe_resource_t*, pe_node_t*, xmlNode*,
572  enum pe_check_parameters,
573  pe_working_set_t*));
575 
577 void pe__update_recheck_time(time_t recheck, pe_working_set_t *data_set);
578 
584 
585 void pe__unpack_dataset_nvpairs(xmlNode *xml_obj, const char *set_name,
586  pe_rule_eval_data_t *rule_data, GHashTable *hash,
587  const char *always_first, gboolean overwrite,
588  pe_working_set_t *data_set);
589 
592  pe_working_set_t *data_set);
593 
594 GListPtr pe__rscs_with_tag(pe_working_set_t *data_set, const char *tag_name);
595 GListPtr pe__unames_with_tag(pe_working_set_t *data_set, const char *tag_name);
596 bool pe__rsc_has_tag(pe_working_set_t *data_set, const char *rsc, const char *tag);
597 bool pe__uname_has_tag(pe_working_set_t *data_set, const char *node, const char *tag);
598 
601 
603 
604 gboolean pe__bundle_is_filtered(pe_resource_t *rsc, GListPtr only_rsc, gboolean check_parent);
605 gboolean pe__clone_is_filtered(pe_resource_t *rsc, GListPtr only_rsc, gboolean check_parent);
606 gboolean pe__group_is_filtered(pe_resource_t *rsc, GListPtr only_rsc, gboolean check_parent);
607 gboolean pe__native_is_filtered(pe_resource_t *rsc, GListPtr only_rsc, gboolean check_parent);
608 
609 #endif
pe_action_flags
pe_action_flags
Definition: pe_types.h:279
find_actions_exact
GList * find_actions_exact(GList *input, const char *key, const pe_node_t *on_node)
Definition: utils.c:1573
pe__node_display_name
char * pe__node_display_name(pe_node_t *node, bool print_detail)
Definition: pe_output.c:346
pe_base_name_end
const char * pe_base_name_end(const char *id)
Definition: unpack.c:1536
RSC_DIGEST_RESTART
@ RSC_DIGEST_RESTART
Definition: internal.h:507
pe__cluster_times_xml
int pe__cluster_times_xml(pcmk__output_t *out, va_list args)
Definition: pe_output.c:915
GListPtr
GList * GListPtr
Definition: crm.h:214
remote_internal.h
pe_wo_poweroff
@ pe_wo_poweroff
Definition: internal.h:145
find_rsc_op_entry
xmlNode * find_rsc_op_entry(pe_resource_t *rsc, const char *key)
Definition: utils.c:1366
pe__bundle_resource_state
enum rsc_role_e pe__bundle_resource_state(const pe_resource_t *rsc, gboolean current)
Definition: bundle.c:2038
pe__clone_html
int pe__clone_html(pcmk__output_t *out, va_list args)
Definition: clone.c:640
pe_rule_eval_data
Definition: common.h:172
pe__cluster_options_text
int pe__cluster_options_text(pcmk__output_t *out, va_list args)
Definition: pe_output.c:782
pe__op_history_xml
int pe__op_history_xml(pcmk__output_t *out, va_list args)
Definition: pe_output.c:1523
pe_get_failcount
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
rsc_digest_cmp_val
rsc_digest_cmp_val
Definition: internal.h:503
pe__set_resource_flags_recursive
void pe__set_resource_flags_recursive(pe_resource_t *rsc, uint64_t flags)
Definition: utils.c:2347
pe_fc_default
@ pe_fc_default
Definition: internal.h:336
clone_unpack
gboolean clone_unpack(pe_resource_t *rsc, pe_working_set_t *data_set)
Definition: clone.c:112
pe__node_list_html
int pe__node_list_html(pcmk__output_t *out, va_list args)
Definition: pe_output.c:1310
pe__order_constraint_s::lh_action
pe_action_t * lh_action
Definition: internal.h:181
pe__location_constraint_s::rsc_lh
pe_resource_t * rsc_lh
Definition: internal.h:169
rsc_action_digest_cmp
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: utils.c:2148
op_digest_cache_s::rc
enum rsc_digest_cmp_val rc
Definition: internal.h:516
pe__ticket_html
int pe__ticket_html(pcmk__output_t *out, va_list args)
Definition: pe_output.c:1754
op_digest_cache_s::digest_secure_calc
char * digest_secure_calc
Definition: internal.h:521
notify_data_s::action
const char * action
Definition: internal.h:193
flags
uint64_t flags
Definition: remote.c:3
pe__count_common
void pe__count_common(pe_resource_t *rsc)
Definition: complex.c:984
pe_free_action
void pe_free_action(pe_action_t *action)
Definition: utils.c:1419
group_active
gboolean group_active(pe_resource_t *rsc, gboolean all)
Definition: group.c:90
pe__order_constraint_s::rh_action
pe_action_t * rh_action
Definition: internal.h:186
pe__common_output_html
int pe__common_output_html(pcmk__output_t *out, pe_resource_t *rsc, const char *name, pe_node_t *node, long options)
Definition: native.c:717
pe__cluster_counts_html
int pe__cluster_counts_html(pcmk__output_t *out, va_list args)
Definition: pe_output.c:488
data
char data[0]
Definition: internal.h:10
print_node
void print_node(const char *pre_text, pe_node_t *node, gboolean details)
Definition: utils.c:1372
pe_node_attribute_calculated
const char * pe_node_attribute_calculated(const pe_node_t *node, const char *name, const pe_resource_t *rsc)
Definition: common.c:590
pe__location_t
struct pe__location_constraint_s pe__location_t
pe__cluster_stack_html
int pe__cluster_stack_html(pcmk__output_t *out, va_list args)
Definition: pe_output.c:860
pcmk_is_set
#define pcmk_is_set(g, f)
Convenience alias for pcmk_all_flags_set(), to check single flag.
Definition: util.h:196
sort_rsc_index
gint sort_rsc_index(gconstpointer a, gconstpointer b)
Definition: utils.c:386
pe__unames_with_tag
GListPtr pe__unames_with_tag(pe_working_set_t *data_set, const char *tag_name)
Definition: tags.c:49
pe__rsc_has_tag
bool pe__rsc_has_tag(pe_working_set_t *data_set, const char *rsc, const char *tag)
Definition: tags.c:82
pe__ticket_xml
int pe__ticket_xml(pcmk__output_t *out, va_list args)
Definition: pe_output.c:1796
native_add_running
void native_add_running(pe_resource_t *rsc, pe_node_t *node, pe_working_set_t *data_set)
Definition: native.c:83
pe_resource_s::id
char * id
Definition: pe_types.h:308
op_digest_cache_s::params_secure
xmlNode * params_secure
Definition: internal.h:518
pe__order_constraint_s::rh_opaque
void * rh_opaque
Definition: internal.h:184
pe__clone_xml
int pe__clone_xml(pcmk__output_t *out, va_list args)
Definition: clone.c:582
pe_fc_fillers
@ pe_fc_fillers
Definition: internal.h:338
rsc_role_e
rsc_role_e
Definition: common.h:91
pe__location_constraint_s::id
char * id
Definition: internal.h:168
sort_rsc_priority
gint sort_rsc_priority(gconstpointer a, gconstpointer b)
Definition: utils.c:413
pe_fc_effective
@ pe_fc_effective
Definition: internal.h:337
pe_wo
uint32_t pe_wo
Definition: unpack.c:68
common_free
void common_free(pe_resource_t *rsc)
Definition: complex.c:813
pe__resource_list
int pe__resource_list(pcmk__output_t *out, va_list args)
pe__cluster_summary
int pe__cluster_summary(pcmk__output_t *out, va_list args)
print_rscs_brief
void print_rscs_brief(GListPtr rsc_list, const char *pre_text, long options, void *print_data, gboolean print_all)
Definition: native.c:1334
pe__output_node
void pe__output_node(pe_node_t *node, gboolean details, pcmk__output_t *out)
Definition: pe_output.c:1896
notify_data_s::master
GListPtr master
Definition: internal.h:206
type
enum crm_ais_msg_types type
Definition: internal.h:3
group_resource_state
enum rsc_role_e group_resource_state(const pe_resource_t *rsc, gboolean current)
Definition: group.c:366
pe__ban_html
int pe__ban_html(pcmk__output_t *out, va_list args)
Definition: pe_output.c:430
pe__update_recheck_time
void pe__update_recheck_time(time_t recheck, pe_working_set_t *data_set)
Definition: utils.c:2727
native_free
void native_free(pe_resource_t *rsc)
Definition: native.c:1178
pe__op_history_text
int pe__op_history_text(pcmk__output_t *out, va_list args)
Definition: pe_output.c:1506
RSC_DIGEST_MATCH
@ RSC_DIGEST_MATCH
Definition: internal.h:505
native_location
pe_node_t * native_location(const pe_resource_t *rsc, GList **list, int current)
Definition: native.c:1207
output_internal.h
Formatted output for pacemaker tools.
pcmk__rsc_filtered_by_node
bool pcmk__rsc_filtered_by_node(pe_resource_t *rsc, GListPtr only_node)
Definition: utils.c:2812
pe_ticket_s
Definition: pe_types.h:437
notify_data_s::active
GListPtr active
Definition: internal.h:200
pe__unpack_dataset_nvpairs
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:2741
pe__count_bundle
void pe__count_bundle(pe_resource_t *rsc)
Definition: bundle.c:2065
pe_action_set_flag_reason
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:2620
pe__group_xml
int pe__group_xml(pcmk__output_t *out, va_list args)
Definition: group.c:185
pe__node_list_text
int pe__node_list_text(pcmk__output_t *out, va_list args)
Definition: pe_output.c:1340
op_digest_cache_s::params_all
xmlNode * params_all
Definition: internal.h:517
pe__clone_is_filtered
gboolean pe__clone_is_filtered(pe_resource_t *rsc, GListPtr only_rsc, gboolean check_parent)
Definition: clone.c:1185
action
const char * action
Definition: pcmk_fence.c:30
pe__rscs_with_tag
GListPtr pe__rscs_with_tag(pe_working_set_t *data_set, const char *tag_name)
Definition: tags.c:18
pe__bundle_text
int pe__bundle_text(pcmk__output_t *out, va_list args)
Definition: bundle.c:1770
clone_active
gboolean clone_active(pe_resource_t *rsc, gboolean all)
Definition: clone.c:237
pe__resource_html
int pe__resource_html(pcmk__output_t *out, va_list args)
Definition: native.c:1131
pe__resource_history_xml
int pe__resource_history_xml(pcmk__output_t *out, va_list args)
Definition: pe_output.c:1610
pe_discover_e
pe_discover_e
Definition: pe_types.h:457
pe_wo_role_after
@ pe_wo_role_after
Definition: internal.h:144
native_parameter
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:316
is_set_recursive
bool is_set_recursive(pe_resource_t *rsc, long long flag, bool any)
Definition: clone.c:339
pe__cluster_maint_mode_text
int pe__cluster_maint_mode_text(pcmk__output_t *out, va_list args)
Definition: pe_output.c:691
group_free
void group_free(pe_resource_t *rsc)
Definition: group.c:345
find_recurring_actions
GListPtr find_recurring_actions(GListPtr input, pe_node_t *not_on_node)
Definition: utils.c:1446
find_actions
GListPtr find_actions(GListPtr input, const char *key, const pe_node_t *on_node)
Definition: utils.c:1533
pe__group_text
int pe__group_text(pcmk__output_t *out, va_list args)
Definition: group.c:291
pe__unpack_bundle
gboolean pe__unpack_bundle(pe_resource_t *rsc, pe_working_set_t *data_set)
Definition: bundle.c:1032
pe__failed_action_text
int pe__failed_action_text(pcmk__output_t *out, va_list args)
Definition: pe_output.c:953
get_target_role
gboolean get_target_role(pe_resource_t *rsc, enum rsc_role_e *role)
Definition: utils.c:1845
native_find_rsc
pe_resource_t * native_find_rsc(pe_resource_t *rsc, const char *id, const pe_node_t *node, int flags)
Definition: native.c:261
pe__resource_is_disabled
bool pe__resource_is_disabled(pe_resource_t *rsc)
Definition: utils.c:2759
pe_fence_node
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_s
Definition: pe_types.h:387
pe__failed_action_xml
int pe__failed_action_xml(pcmk__output_t *out, va_list args)
Definition: pe_output.c:964
pe__print_bundle
void pe__print_bundle(pe_resource_t *rsc, const char *pre_text, long options, void *print_data)
Definition: bundle.c:1902
pe__resource_history_text
int pe__resource_history_text(pcmk__output_t *out, va_list args)
Definition: pe_output.c:1588
native_unpack
gboolean native_unpack(pe_resource_t *rsc, pe_working_set_t *data_set)
Definition: native.c:191
notify_data_s::inactive
GListPtr inactive
Definition: internal.h:201
pe_fc_flags_e
pe_fc_flags_e
Definition: internal.h:335
pe__order_constraint_s::id
int id
Definition: internal.h:176
pe__order_constraint_s::rh_action_task
char * rh_action_task
Definition: internal.h:187
pe__location_constraint_s::role_filter
enum rsc_role_e role_filter
Definition: internal.h:170
pe__bundle_html
int pe__bundle_html(pcmk__output_t *out, va_list args)
Definition: bundle.c:1628
pe__find_bundle_replica
pe_resource_t * pe__find_bundle_replica(const pe_resource_t *bundle, const pe_node_t *node)
Definition: bundle.c:1417
pe__free_bundle
void pe__free_bundle(pe_resource_t *rsc)
Definition: bundle.c:2004
notify_data_s::start
GListPtr start
Definition: internal.h:202
pe__node_attribute_xml
int pe__node_attribute_xml(pcmk__output_t *out, va_list args)
Definition: pe_output.c:1289
uname
char uname[MAX_NAME]
Definition: internal.h:5
pe_action_set_reason
void pe_action_set_reason(pe_action_t *action, const char *reason, bool overwrite)
Definition: utils.c:2678
pe__node_xml
int pe__node_xml(pcmk__output_t *out, va_list args)
pe__native_is_filtered
gboolean pe__native_is_filtered(pe_resource_t *rsc, GListPtr only_rsc, gboolean check_parent)
Definition: native.c:1492
op_digest_cache_s::digest_all_calc
char * digest_all_calc
Definition: internal.h:520
pe__cluster_options_log
int pe__cluster_options_log(pcmk__output_t *out, va_list args)
Definition: pe_output.c:766
clone_print
void clone_print(pe_resource_t *rsc, const char *pre_text, long options, void *print_data)
Definition: clone.c:370
op_digest_cache_s::params_restart
xmlNode * params_restart
Definition: internal.h:519
pe_wo_order_score
@ pe_wo_order_score
Definition: internal.h:147
common_update_score
void common_update_score(pe_resource_t *rsc, const char *id, int score)
Definition: complex.c:760
get_pseudo_op
pe_action_t * get_pseudo_op(const char *name, pe_working_set_t *data_set)
Definition: utils.c:1929
custom_action
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:465
native_print
void native_print(pe_resource_t *rsc, const char *pre_text, long options, void *print_data)
Definition: native.c:1030
pe__cluster_summary_html
int pe__cluster_summary_html(pcmk__output_t *out, va_list args)
notify_data_s::promote
GListPtr promote
Definition: internal.h:205
pe__register_messages
void pe__register_messages(pcmk__output_t *out)
Definition: pe_output.c:1891
pe__foreach_param_check
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
pe__copy_node
pe_node_t * pe__copy_node(const pe_node_t *this_node)
Definition: utils.c:139
pe__resource_xml
int pe__resource_xml(pcmk__output_t *out, va_list args)
Definition: native.c:1052
pe__cluster_dc_text
int pe__cluster_dc_text(pcmk__output_t *out, va_list args)
Definition: pe_output.c:648
pe__clear_resource_flags_recursive
void pe__clear_resource_flags_recursive(pe_resource_t *rsc, uint64_t flags)
Definition: utils.c:2338
sort_op_by_callid
gint sort_op_by_callid(gconstpointer a, gconstpointer b)
Definition: utils.c:1713
pe__order_constraint_s::lh_action_task
char * lh_action_task
Definition: internal.h:182
pe__node_html
int pe__node_html(pcmk__output_t *out, va_list args)
pe__cluster_counts_xml
int pe__cluster_counts_xml(pcmk__output_t *out, va_list args)
Definition: pe_output.c:584
notify_data_t
struct notify_data_s notify_data_t
get_effective_time
time_t get_effective_time(pe_working_set_t *data_set)
Definition: utils.c:1830
pe__location_constraint_s::discover_mode
enum pe_discover_e discover_mode
Definition: internal.h:171
clone_strip
char * clone_strip(const char *last_rsc_id)
Definition: unpack.c:1576
pe__bundle_xml
int pe__bundle_xml(pcmk__output_t *out, va_list args)
Definition: bundle.c:1505
pe_wo_restart_type
@ pe_wo_restart_type
Definition: internal.h:143
pe__cluster_dc_html
int pe__cluster_dc_html(pcmk__output_t *out, va_list args)
Definition: pe_output.c:614
pe__ban_text
int pe__ban_text(pcmk__output_t *out, va_list args)
Definition: pe_output.c:450
pe__group_is_filtered
gboolean pe__group_is_filtered(pe_resource_t *rsc, GListPtr only_rsc, gboolean check_parent)
Definition: group.c:385
pe__cluster_options_xml
int pe__cluster_options_xml(pcmk__output_t *out, va_list args)
Definition: pe_output.c:819
pe_working_set_s
Definition: pe_types.h:127
pe__node_attribute_html
int pe__node_attribute_html(pcmk__output_t *out, va_list args)
Definition: pe_output.c:1259
pe__shutdown_requested
bool pe__shutdown_requested(pe_node_t *node)
Definition: utils.c:2712
find_clone_instance
pe_resource_t * find_clone_instance(pe_resource_t *rsc, const char *sub_id, pe_working_set_t *data_set)
Definition: clone.c:42
find_first_action
pe_action_t * find_first_action(GListPtr input, const char *uuid, const char *task, pe_node_t *on_node)
Definition: utils.c:1503
pe_metadata
void pe_metadata(void)
Definition: common.c:296
pe__group_html
int pe__group_html(pcmk__output_t *out, va_list args)
Definition: group.c:236
pe__node_text
int pe__node_text(pcmk__output_t *out, va_list args)
get_complex_task
enum action_tasks get_complex_task(pe_resource_t *rsc, const char *name, gboolean allow_non_atomic)
Definition: utils.c:1480
RSC_DIGEST_ALL
@ RSC_DIGEST_ALL
Definition: internal.h:509
pe__find_active_on
pe_node_t * pe__find_active_on(const pe_resource_t *rsc, unsigned int *count_all, unsigned int *count_clean)
Definition: complex.c:895
pe__rsc_running_on_any_node_in_list
bool pe__rsc_running_on_any_node_in_list(pe_resource_t *rsc, GListPtr node_list)
Definition: utils.c:2799
pe__bundle_is_filtered
gboolean pe__bundle_is_filtered(pe_resource_t *rsc, GListPtr only_rsc, gboolean check_parent)
Definition: bundle.c:2089
pe__rscs_brief_output
int pe__rscs_brief_output(pcmk__output_t *out, GListPtr rsc_list, long options, gboolean print_all)
Definition: native.c:1414
native_resource_state
enum rsc_role_e native_resource_state(const pe_resource_t *rsc, gboolean current)
Definition: native.c:1185
op_digest_cache_s::digest_restart_calc
char * digest_restart_calc
Definition: internal.h:522
sort_node_uname
gint sort_node_uname(gconstpointer a, gconstpointer b)
Definition: utils.c:215
notify_data_s::pre
pe_action_t * pre
Definition: internal.h:195
pe__cluster_maint_mode_html
int pe__cluster_maint_mode_html(pcmk__output_t *out, va_list args)
order_actions
gboolean order_actions(pe_action_t *lh_action, pe_action_t *rh_action, enum pe_ordering order)
Definition: utils.c:1883
pe__cluster_stack_xml
int pe__cluster_stack_xml(pcmk__output_t *out, va_list args)
Definition: pe_output.c:880
add_hash_param
void add_hash_param(GHashTable *hash, const char *name, const char *value)
Definition: common.c:573
add_tag_ref
gboolean add_tag_ref(GHashTable *tags, const char *tag_name, const char *obj_ref)
Definition: utils.c:2584
pe__location_constraint_s::node_list_rh
GListPtr node_list_rh
Definition: internal.h:172
pcmk__output_s
This structure contains everything that makes up a single output formatter.
Definition: output_internal.h:169
dump_rsc_utilization
void dump_rsc_utilization(int level, const char *comment, pe_resource_t *rsc, pe_node_t *node)
Definition: utils.c:367
pe__ordering_t
struct pe__order_constraint_s pe__ordering_t
group_unpack
gboolean group_unpack(pe_resource_t *rsc, pe_working_set_t *data_set)
Definition: group.c:23
pe__cluster_stack_text
int pe__cluster_stack_text(pcmk__output_t *out, va_list args)
Definition: pe_output.c:872
common_print
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:876
pe_wo_require_all
@ pe_wo_require_all
Definition: internal.h:146
clone_resource_state
enum rsc_role_e clone_resource_state(const pe_resource_t *rsc, gboolean current)
Definition: clone.c:1144
verify_pe_options
void verify_pe_options(GHashTable *options)
Definition: common.c:306
notify_data_s::slave
GListPtr slave
Definition: internal.h:207
native_active
gboolean native_active(pe_resource_t *rsc, gboolean all)
Definition: native.c:361
pe__cluster_counts_text
int pe__cluster_counts_text(pcmk__output_t *out, va_list args)
Definition: pe_output.c:550
pe_wo_blind
@ pe_wo_blind
Definition: internal.h:142
pe_can_fence
bool pe_can_fence(pe_working_set_t *data_set, pe_node_t *node)
Definition: utils.c:87
notify_data_s::allowed_nodes
GHashTable * allowed_nodes
Definition: internal.h:208
pe_resource_s::flags
unsigned long long flags
Definition: pe_types.h:335
pe_warn_once_e
pe_warn_once_e
Definition: internal.h:141
pe__free_param_checks
void pe__free_param_checks(pe_working_set_t *data_set)
Definition: remote.c:261
resource_location
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:1669
pe__ticket_text
int pe__ticket_text(pcmk__output_t *out, va_list args)
Definition: pe_output.c:1775
notify_data_s::stop
GListPtr stop
Definition: internal.h:203
pe_check_parameters
pe_check_parameters
Definition: pe_types.h:184
pe__clone_text
int pe__clone_text(pcmk__output_t *out, va_list args)
Definition: clone.c:877
pe__order_constraint_s::lh_opaque
void * lh_opaque
Definition: internal.h:179
pe__add_param_check
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
pe__resource_text
int pe__resource_text(pcmk__output_t *out, va_list args)
Definition: native.c:1155
pe__bundle_needs_remote_name
bool pe__bundle_needs_remote_name(pe_resource_t *rsc)
Definition: bundle.c:957
pe__resource_actions
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:1621
print_str_str
void print_str_str(gpointer key, gpointer value, gpointer user_data)
Definition: utils.c:1411
pe__order_constraint_s::rh_rsc
pe_resource_t * rh_rsc
Definition: internal.h:185
dump_node_capacity
void dump_node_capacity(int level, const char *comment, pe_node_t *node)
Definition: utils.c:350
pe__cluster_times_html
int pe__cluster_times_html(pcmk__output_t *out, va_list args)
Definition: pe_output.c:891
notify_data_s::pre_done
pe_action_t * pre_done
Definition: internal.h:197
notify_data_s::post
pe_action_t * post
Definition: internal.h:196
pe__order_constraint_s::lh_rsc
pe_resource_t * lh_rsc
Definition: internal.h:180
pe__uname_has_tag
bool pe__uname_has_tag(pe_working_set_t *data_set, const char *node, const char *tag)
Definition: tags.c:97
pe__clear_failcount
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:360
pe__find_active_requires
pe_node_t * pe__find_active_requires(const pe_resource_t *rsc, unsigned int *count)
Definition: complex.c:975
node_list_exclude
void node_list_exclude(GHashTable *list, GListPtr list2, gboolean merge_scores)
Definition: utils.c:158
internal.h
clone_free
void clone_free(pe_resource_t *rsc)
Definition: clone.c:1110
trigger_unfencing
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:2549
pe__ban_xml
int pe__ban_xml(pcmk__output_t *out, va_list args)
Definition: pe_output.c:467
pe__common_output_text
int pe__common_output_text(pcmk__output_t *out, pe_resource_t *rsc, const char *name, pe_node_t *node, long options)
Definition: native.c:809
pe_fence_op
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:2443
pe__add_scores
int pe__add_scores(int score1, int score2)
Definition: common.c:510
pe_node_attribute_raw
const char * pe_node_attribute_raw(pe_node_t *node, const char *name)
Definition: common.c:629
RSC_DIGEST_UNKNOWN
@ RSC_DIGEST_UNKNOWN
Definition: internal.h:512
op_digest_cache_t
struct op_digest_cache_s op_digest_cache_t
pe__node_list_xml
int pe__node_list_xml(pcmk__output_t *out, va_list args)
Definition: pe_output.c:1479
pe__node_attribute_text
int pe__node_attribute_text(pcmk__output_t *out, va_list args)
Definition: pe_output.c:1233
pe_resource_s
Definition: pe_types.h:307
notify_data_s::demote
GListPtr demote
Definition: internal.h:204
pe__location_constraint_s
Definition: internal.h:167
pe__cluster_dc_xml
int pe__cluster_dc_xml(pcmk__output_t *out, va_list args)
Definition: pe_output.c:667
clone_zero
char * clone_zero(const char *last_rsc_id)
Definition: unpack.c:1598
pe__cluster_times_text
int pe__cluster_times_text(pcmk__output_t *out, va_list args)
Definition: pe_output.c:936
pe__order_constraint_s
Definition: internal.h:175
pe_get_configured_timeout
int pe_get_configured_timeout(pe_resource_t *rsc, const char *action, pe_working_set_t *data_set)
Definition: utils.c:892
pe__bundle_active
gboolean pe__bundle_active(pe_resource_t *rsc, gboolean all)
Definition: bundle.c:1369
pe__filter_rsc_list
GListPtr pe__filter_rsc_list(GListPtr rscs, GListPtr filter)
Definition: utils.c:2818
destroy_ticket
void destroy_ticket(gpointer data)
Definition: utils.c:1945
notify_data_s::keys
GSList * keys
Definition: internal.h:191
notify_data_s
Definition: internal.h:190
pe_wo_neg_threshold
@ pe_wo_neg_threshold
Definition: internal.h:148
pe__show_node_weights_as
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)
Definition: utils.c:305
action_tasks
action_tasks
Definition: common.h:62
pe_node_s
Definition: pe_types.h:229
name
char * name
Definition: pcmk_fence.c:31
pe__order_constraint_s::type
enum pe_ordering type
Definition: internal.h:177
pe__is_universal_clone
bool pe__is_universal_clone(pe_resource_t *rsc, pe_working_set_t *data_set)
Definition: clone.c:1170
pe_create_node
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:396
pe__cluster_options_html
int pe__cluster_options_html(pcmk__output_t *out, va_list args)
Definition: pe_output.c:711
group_print
void group_print(pe_resource_t *rsc, const char *pre_text, long options, void *print_data)
Definition: group.c:135
status.h
Cluster status and scheduling.
pe__name_and_nvpairs_xml
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:398
pe__add_bundle_remote_name
const char * pe__add_bundle_remote_name(pe_resource_t *rsc, xmlNode *xml, const char *field)
Definition: bundle.c:987
pe__node_list2table
GHashTable * pe__node_list2table(GList *list)
Definition: utils.c:201
ticket_new
pe_ticket_t * ticket_new(const char *ticket_id, pe_working_set_t *data_set)
Definition: utils.c:1957
pe__target_rc_from_xml
int pe__target_rc_from_xml(xmlNode *xml_op)
Definition: unpack.c:3424
common_unpack
gboolean common_unpack(xmlNode *xml_obj, pe_resource_t **rsc, pe_resource_t *parent, pe_working_set_t *data_set)
Definition: complex.c:396
notify_data_s::post_done
pe_action_t * post_done
Definition: internal.h:198
op_digest_cache_s
Definition: internal.h:515
pe__clear_resource_history
pe_action_t * pe__clear_resource_history(pe_resource_t *rsc, pe_node_t *node, pe_working_set_t *data_set)
Definition: utils.c:2787
pe_ordering
pe_ordering
Definition: pe_types.h:464