mirror of
https://git.proxmox.com/git/mirror_corosync
synced 2025-10-20 09:01:02 +00:00

Previously node id was logged ether as a %d (most often), %u, %x or PRI.32 and ring id ether as %lld, %llx with various separators (., :, /) between rep nodeid and seq. This seems to cause confusion. This patch adds macros CS_PRI_NODE_ID, CS_PRI_RING_ID and CS_PRI_RING_ID_SEQ (CS prefix = corosync, PRI modeled in spirit of inttypes.h PRIx32) and makes code use them. Signed-off-by: Jan Friesse <jfriesse@redhat.com> Reviewed-by: Christine Caulfield <ccaulfie@redhat.com>
66 lines
1.6 KiB
C
66 lines
1.6 KiB
C
#include <config.h>
|
|
|
|
#include <sys/types.h>
|
|
#include <stdio.h>
|
|
#include <inttypes.h>
|
|
#include <stdint.h>
|
|
#include <stdlib.h>
|
|
#include <unistd.h>
|
|
#include <corosync/corotypes.h>
|
|
#include <corosync/quorum.h>
|
|
|
|
static quorum_handle_t g_handle;
|
|
|
|
static void quorum_notification_fn(
|
|
quorum_handle_t handle,
|
|
uint32_t quorate,
|
|
uint64_t ring_id,
|
|
uint32_t view_list_entries,
|
|
uint32_t *view_list)
|
|
{
|
|
int i;
|
|
|
|
printf("quorum notification called \n");
|
|
printf(" quorate = %lu\n", (long unsigned int) quorate);
|
|
printf(" ring id = " CS_PRI_RING_ID_SEQ "\n", ring_id);
|
|
printf(" num nodes = %lu ", (long unsigned int) view_list_entries);
|
|
|
|
for (i=0; i<view_list_entries; i++) {
|
|
printf(" " CS_PRI_NODE_ID, view_list[i]);
|
|
}
|
|
printf("\n");
|
|
}
|
|
|
|
|
|
int main(int argc, char *argv[])
|
|
{
|
|
int quorate;
|
|
quorum_callbacks_t callbacks;
|
|
uint32_t quorum_type;
|
|
int err;
|
|
|
|
callbacks.quorum_notify_fn = quorum_notification_fn;
|
|
if ( (err=quorum_initialize(&g_handle, &callbacks, &quorum_type)) != CS_OK)
|
|
fprintf(stderr, "quorum_initialize FAILED: %d\n", err);
|
|
|
|
if ( (err=quorum_trackstart(g_handle, CS_TRACK_CHANGES)) != CS_OK)
|
|
fprintf(stderr, "quorum_trackstart FAILED: %d\n", err);
|
|
|
|
if ( (err=quorum_getquorate(g_handle, &quorate)) != CS_OK)
|
|
fprintf(stderr, "quorum_getquorate FAILED: %d\n", err);
|
|
else {
|
|
printf("quorate %d\n", quorate);
|
|
}
|
|
|
|
printf("Waiting for quorum events, press ^C to finish\n");
|
|
printf("-------------------\n");
|
|
|
|
while (1)
|
|
if (quorum_dispatch(g_handle, CS_DISPATCH_ALL) != CS_OK) {
|
|
fprintf(stderr, "Error from quorum_dispatch\n");
|
|
return -1;
|
|
}
|
|
|
|
return 0;
|
|
}
|