corosync 3.1.7
include/corosync/quorum.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2008-2020 Red Hat, Inc.
3 *
4 * All rights reserved.
5 *
6 * Author: Christine Caulfield (ccaulfi@redhat.com)
7 *
8 * This software licensed under BSD license, the text of which follows:
9 *
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions are met:
12 *
13 * - Redistributions of source code must retain the above copyright notice,
14 * this list of conditions and the following disclaimer.
15 * - Redistributions in binary form must reproduce the above copyright notice,
16 * this list of conditions and the following disclaimer in the documentation
17 * and/or other materials provided with the distribution.
18 * - Neither the name of the Red Hat, Inc. nor the names of its
19 * contributors may be used to endorse or promote products derived from this
20 * software without specific prior written permission.
21 *
22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
23 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
26 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
27 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
28 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
29 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
30 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
31 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
32 * THE POSSIBILITY OF SUCH DAMAGE.
33 */
34#ifndef COROSYNC_QUORUM_H_DEFINED
35#define COROSYNC_QUORUM_H_DEFINED
36
37#include <corosync/corotypes.h>
38
39#ifdef __cplusplus
40extern "C" {
41#endif
42
43typedef enum {
47
51typedef uint64_t quorum_handle_t;
52
54 uint32_t nodeid;
55 uint64_t seq;
56};
57
61typedef void (*quorum_notification_fn_t) (
62 quorum_handle_t handle,
63 uint32_t quorate,
64 uint64_t ring_seq,
65 uint32_t view_list_entries,
66 uint32_t *view_list
67 );
68
70 quorum_handle_t handle,
71 uint32_t quorate,
73 uint32_t member_list_entries, const uint32_t *member_list
74);
75
77 quorum_handle_t handle,
79 uint32_t member_list_entries, const uint32_t *member_list,
80 uint32_t joined_list_entries, const uint32_t *joined_list,
81 uint32_t left_list_entries, const uint32_t *left_list
82);
83
87typedef struct {
90
91typedef struct {
94
95typedef struct {
99
100typedef struct {
105
106#define QUORUM_FREE 0
107#define QUORUM_SET 1
108
117 quorum_handle_t *handle,
118 quorum_callbacks_t *callbacks,
119 uint32_t *quorum_type);
120
122 quorum_handle_t *handle,
123 quorum_model_t model,
124 quorum_model_data_t *model_data,
125 uint32_t *quorum_type,
126 void *context);
127
134 quorum_handle_t handle);
135
146 quorum_handle_t handle,
147 int *fd);
148
156 quorum_handle_t handle,
157 cs_dispatch_flags_t dispatch_types);
158
166 quorum_handle_t handle,
167 int *quorate);
168
176 quorum_handle_t handle,
177 unsigned int flags );
178
185 quorum_handle_t handle);
186
194 quorum_handle_t handle,
195 const void *context);
196
204 quorum_handle_t handle,
205 const void **context);
206
207#ifdef __cplusplus
208}
209#endif
210
211#endif /* COROSYNC_QUORUM_H_DEFINED */
cs_dispatch_flags_t
The cs_dispatch_flags_t enum.
Definition: corotypes.h:84
cs_error_t
The cs_error_t enum.
Definition: corotypes.h:98
uint32_t flags
cs_error_t quorum_context_get(quorum_handle_t handle, const void **context)
quorum_context_get
Definition: lib/quorum.c:299
uint64_t quorum_handle_t
quorum_handle_t
@ QUORUM_MODEL_V1
@ QUORUM_MODEL_V0
cs_error_t quorum_trackstop(quorum_handle_t handle)
quorum_trackstop
Definition: lib/quorum.c:379
cs_error_t quorum_initialize(quorum_handle_t *handle, quorum_callbacks_t *callbacks, uint32_t *quorum_type)
Create a new quorum connection.
Definition: lib/quorum.c:73
cs_error_t quorum_fd_get(quorum_handle_t handle, int *fd)
Get a file descriptor on which to poll.
Definition: lib/quorum.c:279
void(* quorum_notification_fn_t)(quorum_handle_t handle, uint32_t quorate, uint64_t ring_seq, uint32_t view_list_entries, uint32_t *view_list)
The quorum_notification_fn_t callback.
cs_error_t quorum_trackstart(quorum_handle_t handle, unsigned int flags)
Track node and quorum changes.
Definition: lib/quorum.c:338
cs_error_t quorum_model_initialize(quorum_handle_t *handle, quorum_model_t model, quorum_model_data_t *model_data, uint32_t *quorum_type, void *context)
Definition: lib/quorum.c:90
cs_error_t quorum_finalize(quorum_handle_t handle)
Close the quorum handle.
Definition: lib/quorum.c:209
cs_error_t quorum_getquorate(quorum_handle_t handle, int *quorate)
Get quorum information.
Definition: lib/quorum.c:237
void(* quorum_v1_nodelist_notification_fn_t)(quorum_handle_t handle, struct quorum_ring_id ring_id, uint32_t member_list_entries, const uint32_t *member_list, uint32_t joined_list_entries, const uint32_t *joined_list, uint32_t left_list_entries, const uint32_t *left_list)
cs_error_t quorum_context_set(quorum_handle_t handle, const void *context)
quorum_context_set
Definition: lib/quorum.c:318
cs_error_t quorum_dispatch(quorum_handle_t handle, cs_dispatch_flags_t dispatch_types)
Dispatch messages and configuration changes.
Definition: lib/quorum.c:418
void(* quorum_v1_quorum_notification_fn_t)(quorum_handle_t handle, uint32_t quorate, struct quorum_ring_id ring_id, uint32_t member_list_entries, const uint32_t *member_list)
uint32_t quorate
Definition: sam.c:134
The quorum_callbacks_t struct.
quorum_notification_fn_t quorum_notify_fn
quorum_notification_fn_t quorum_notify_fn
quorum_v1_quorum_notification_fn_t quorum_notify_fn
quorum_v1_nodelist_notification_fn_t nodelist_notify_fn
unsigned long long ring_seq
Definition: totemsrp.c:4
struct memb_ring_id ring_id
Definition: totemsrp.c:4