1
0
mirror of https://github.com/samba-team/samba.git synced 2024-12-24 21:34:56 +03:00
samba-mirror/ctdb/libctdb/libctdb_private.h
Volker Lendecke 85bc1ccb7e libctdb: "unpack_reply_control" does not need the ctdb_connection parameter
Signed-off-by: Michael Adam <obnox@samba.org>

(This used to be ctdb commit bb8f68f0256c43fe0671fe45023d1c88e340ad96)
2011-08-22 17:11:07 +02:00

108 lines
2.8 KiB
C

#ifndef _LIBCTDB_PRIVATE_H
#define _LIBCTDB_PRIVATE_H
#include <dlinklist.h>
#include <stdbool.h>
#include <stdint.h>
#include <stdlib.h>
#include <ctdb.h>
#include <ctdb_protocol.h>
#include <syslog.h>
#include <tdb.h>
#include <stddef.h>
#ifndef offsetof
#define offsetof(t,f) ((unsigned int)&((t *)0)->f)
#endif
#ifndef COLD_ATTRIBUTE
#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 3)
#define COLD_ATTRIBUTE __attribute__((cold))
#else
#define COLD_ATTRIBUTE
#endif
#endif /* COLD_ATTRIBUTE */
#define DEBUG(ctdb, lvl, format, args...) do { if (lvl <= ctdb_log_level) { ctdb_do_debug(ctdb, lvl, format , ## args ); }} while(0)
struct message_handler_info;
struct ctdb_reply_call;
struct ctdb_request {
struct ctdb_connection *ctdb;
struct ctdb_request *next, *prev;
bool cancelled;
struct io_elem *io;
union {
struct ctdb_req_header *hdr;
struct ctdb_req_call *call;
struct ctdb_req_control *control;
struct ctdb_req_message *message;
} hdr;
struct io_elem *reply;
ctdb_callback_t callback;
void *priv_data;
/* Extra per-request info. */
void (*extra_destructor)(struct ctdb_connection *,
struct ctdb_request *);
void *extra;
};
struct ctdb_connection {
/* Socket to ctdbd. */
int fd;
/* Currently our failure mode is simple; return -1 from ctdb_service */
bool broken;
/* Linked list of pending outgoings. */
struct ctdb_request *outq;
/* Finished outgoings (awaiting response) */
struct ctdb_request *doneq;
/* Current incoming. */
struct io_elem *in;
/* Queue of received pdus */
struct io_elem *inqueue;
/* Guess at a good reqid to try next. */
uint32_t next_id;
/* List of messages */
struct message_handler_info *message_handlers;
/* PNN of this ctdb: valid by the time we do our first db connection. */
uint32_t pnn;
/* Chain of locks we hold. */
struct ctdb_lock *locks;
/* Extra logging. */
ctdb_log_fn_t log;
void *log_priv;
};
/* ctdb.c */
struct ctdb_request *new_ctdb_request(struct ctdb_connection *ctdb, size_t len,
ctdb_callback_t cb, void *cbdata);
struct ctdb_request *new_ctdb_control_request(struct ctdb_connection *ctdb,
uint32_t opcode,
uint32_t destnode,
const void *extra_data,
size_t extra,
ctdb_callback_t, void *);
uint32_t new_reqid(struct ctdb_connection *ctdb);
struct ctdb_reply_control *unpack_reply_control(struct ctdb_request *req,
enum ctdb_controls control);
void ctdb_cancel_callback(struct ctdb_connection *ctdb,
struct ctdb_request *req,
void *unused);
/* logging.c */
void ctdb_tdb_log_bridge(struct tdb_context *tdb,
enum tdb_debug_level level,
const char *format, ...) PRINTF_ATTRIBUTE(3, 4);
void ctdb_do_debug(struct ctdb_connection *, int, const char *format, ...)
PRINTF_ATTRIBUTE(3, 4) COLD_ATTRIBUTE;
#endif /* _LIBCTDB_PRIVATE_H */