mirror of
https://git.proxmox.com/git/mirror_corosync
synced 2025-07-16 21:26:19 +00:00

IPC: return 0/-ENOBUFS from message handler IPC: use the new rate_limit API to improve perf. CPG: add send_async API & hook up flow control IPC: Fix flow control getting stuck. IPC: Port the remaining libs to use libqb IPC IPC: remove libqb flowcontrol API TEST: put cpg_dispatch() in it's own thread IPC: cleanup ipc_glue.c name everything cs_ipcs_*() IPC: add back statistics IPC: remove coroipcc_ symbols from lib*.versions IPC: init each se's IPC as it is loaded. IPC: use the new connection_closed() event to free the context. IPC: re-add zero copy functionality back IPC: remove cpg_mcast_joined_async() and make it the default -> now cpg_mcast_joined() == cpg_mcast_joined_async() libqb: expose a libqb error converter libqb: add missing error conversions libqb: remove repeat try loop in lib/cpg.c CPG: fix zero copy mcast CPG: use newer return codes Add ENOTCONN to qb_to_cs_error() libqb: fix error conversion from errno to cs_error_t in confdb libqb: change errno_to_cs to qb_to_cs_error libqb: add a cs_strerror() to get a more meaningful message libqb: fix some confusing error conversions. libqb: set the timeout on recv's to -1 (wait forever) Signed-off-by: Angus Salkeld <asalkeld@redhat.com> Reviewed-by: Steven Dake <sdake@redhat.com>
127 lines
3.9 KiB
C
127 lines
3.9 KiB
C
/*
|
|
* Copyright (c) 2002-2006 MontaVista Software, Inc.
|
|
* Copyright (c) 2006-2009 Red Hat, Inc.
|
|
*
|
|
* All rights reserved.
|
|
*
|
|
* Author: Steven Dake (sdake@redhat.com)
|
|
*
|
|
* This software licensed under BSD license, the text of which follows:
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions are met:
|
|
*
|
|
* - Redistributions of source code must retain the above copyright notice,
|
|
* this list of conditions and the following disclaimer.
|
|
* - Redistributions in binary form must reproduce the above copyright notice,
|
|
* this list of conditions and the following disclaimer in the documentation
|
|
* and/or other materials provided with the distribution.
|
|
* - Neither the name of the MontaVista Software, Inc. nor the names of its
|
|
* contributors may be used to endorse or promote products derived from this
|
|
* software without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
|
|
* THE POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|
|
|
|
/**
|
|
* @file
|
|
*
|
|
* @warning DO NOT USE SYMBOLS IN THIS FILE
|
|
*/
|
|
|
|
#ifndef MAIN_H_DEFINED
|
|
#define MAIN_H_DEFINED
|
|
|
|
#define TRUE 1
|
|
#define FALSE 0
|
|
#include <corosync/corotypes.h>
|
|
#include <corosync/hdb.h>
|
|
#include <qb/qbloop.h>
|
|
#include <corosync/totem/totempg.h>
|
|
#include <corosync/engine/objdb.h>
|
|
#include <corosync/engine/config.h>
|
|
#include <corosync/engine/coroapi.h>
|
|
|
|
extern unsigned long long *(*main_clm_get_by_nodeid) (unsigned int node_id);
|
|
|
|
extern void main_get_config_modules(struct config_iface_ver0 ***modules, int *num);
|
|
|
|
extern int main_mcast (
|
|
const struct iovec *iovec,
|
|
unsigned int iov_len,
|
|
unsigned int guarantee);
|
|
|
|
extern void message_source_set (mar_message_source_t *source, void *conn);
|
|
|
|
extern int message_source_is_local (const mar_message_source_t *source);
|
|
|
|
extern void corosync_shutdown_request (void);
|
|
|
|
extern void corosync_state_dump (void);
|
|
|
|
extern qb_loop_t *cs_poll_handle_get (void);
|
|
|
|
extern int cs_poll_dispatch_add (qb_loop_t * handle,
|
|
int fd,
|
|
int events,
|
|
void *data,
|
|
|
|
int (*dispatch_fn) (int fd,
|
|
int revents,
|
|
void *data));
|
|
|
|
extern int cs_poll_dispatch_delete (
|
|
qb_loop_t * handle,
|
|
int fd);
|
|
|
|
|
|
extern int corosync_sending_allowed (
|
|
unsigned int service,
|
|
unsigned int id,
|
|
const void *msg,
|
|
void *sending_allowed_private_data);
|
|
|
|
extern void corosync_sending_allowed_release (void *sending_allowed_private_data);
|
|
|
|
extern void corosync_recheck_the_q_level(void *data);
|
|
|
|
extern void cs_ipcs_init(void);
|
|
|
|
extern void cs_ipcs_service_init(struct corosync_service_engine *service);
|
|
|
|
extern void cs_ipcs_stats_update(void);
|
|
|
|
extern int32_t cs_ipcs_service_destroy(int32_t service_id);
|
|
|
|
extern int32_t cs_ipcs_q_level_get(void);
|
|
|
|
extern int cs_ipcs_dispatch_send(void *conn, const void *msg, size_t mlen);
|
|
extern int cs_ipcs_dispatch_iov_send (void *conn,
|
|
const struct iovec *iov,
|
|
unsigned int iov_len);
|
|
|
|
extern int cs_ipcs_response_send(void *conn, const void *msg, size_t mlen);
|
|
extern int cs_ipcs_response_iov_send (void *conn,
|
|
const struct iovec *iov,
|
|
unsigned int iov_len);
|
|
|
|
extern void cs_ipcs_sync_state_changed(int32_t sync_in_process);
|
|
|
|
extern void *cs_ipcs_private_data_get(void *conn);
|
|
|
|
extern void cs_ipc_refcnt_inc(void *conn);
|
|
|
|
extern void cs_ipc_refcnt_dec(void *conn);
|
|
|
|
#endif /* MAIN_H_DEFINED */
|