mirror of
https://github.com/samba-team/samba.git
synced 2025-01-12 09:18:10 +03:00
85bc1ccb7e
Signed-off-by: Michael Adam <obnox@samba.org> (This used to be ctdb commit bb8f68f0256c43fe0671fe45023d1c88e340ad96)
108 lines
2.8 KiB
C
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 */
|