2011-05-13 08:07:28 +00:00
/*
* Copyright ( C ) 2011 Red Hat , Inc . All rights reserved .
*
* This file is part of LVM2 .
*
* This copyrighted material is made available to anyone wishing to use ,
* modify , copy , or redistribute it subject to the terms and conditions
* of the GNU Lesser General Public License v .2 .1 .
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program ; if not , write to the Free Software Foundation ,
* Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*/
2011-05-15 11:02:29 +00:00
# include "daemon-client.h"
2011-06-14 02:34:18 +00:00
# include "config.h" // XXX will be in libdevmapper.h later
2011-05-15 11:02:29 +00:00
# ifndef _LVM_DAEMON_COMMON_SERVER_H
# define _LVM_DAEMON_COMMON_SERVER_H
2011-05-13 08:07:28 +00:00
typedef struct {
int socket_fd ; /* the fd we use to talk to the client */
pthread_t thread_id ;
char * read_buf ;
void * private ; /* this holds per-client state */
} client_handle ;
typedef struct {
2011-06-27 13:46:45 +00:00
struct config_tree * cft ;
2011-06-14 02:34:18 +00:00
char * buffer ;
2011-05-15 11:02:29 +00:00
} request ;
typedef struct {
int error ;
2011-06-27 13:46:45 +00:00
struct config_tree * cft ;
2011-06-14 02:34:18 +00:00
char * buffer ;
2011-05-15 11:02:29 +00:00
} response ;
struct daemon_state ;
2011-06-27 13:58:11 +00:00
/*
* Craft a simple reply , without the need to construct a config_tree . See
* daemon_send_simple in daemon - client . h for the description of the parameters .
*/
response daemon_reply_simple ( char * id , . . . ) ;
2011-06-27 14:03:58 +00:00
static inline int daemon_request_int ( request r , const char * path , int def ) {
2011-07-18 14:46:54 +00:00
if ( ! r . cft )
return def ;
2011-06-27 14:03:58 +00:00
return find_config_int ( r . cft - > root , path , def ) ;
}
static inline const char * daemon_request_str ( request r , const char * path , const char * def ) {
2011-07-18 14:46:54 +00:00
if ( ! r . cft )
return def ;
2011-06-27 14:03:58 +00:00
return find_config_str ( r . cft - > root , path , def ) ;
}
2011-05-15 11:02:29 +00:00
/*
* The callback . Called once per request issued , in the respective client ' s
* thread . It is presented by a parsed request ( in the form of a config tree ) .
* The output is a new config tree that is serialised and sent back to the
* client . The client blocks until the request processing is done and reply is
* sent .
*/
typedef response ( * handle_request ) ( struct daemon_state s , client_handle h , request r ) ;
typedef struct daemon_state {
2011-05-13 08:45:46 +00:00
/*
* The maximal stack size for individual daemon threads . This is
* essential for daemons that need to be locked into memory , since
* pthread ' s default is 10 M per thread .
*/
int thread_stack_size ;
/* Flags & attributes affecting the behaviour of the daemon. */
unsigned avoid_oom : 1 ;
unsigned foreground : 1 ;
const char * name ;
const char * pidfile ;
2011-05-13 09:34:12 +00:00
const char * socket_path ;
2011-05-15 11:02:29 +00:00
int log_level ;
handle_request handler ;
2011-07-18 14:46:54 +00:00
int ( * daemon_init ) ( struct daemon_state * st ) ;
int ( * daemon_fini ) ( struct daemon_state * st ) ;
2011-05-13 09:34:12 +00:00
/* Global runtime info maintained by the framework. */
int socket_fd ;
2011-05-13 08:45:46 +00:00
2011-05-13 08:07:28 +00:00
void * private ; /* the global daemon state */
} daemon_state ;
/*
* Start serving the requests . This does all the daemonisation , socket setup
2011-05-13 08:45:46 +00:00
* work and so on . This function takes over the process , and upon failure , it
* will terminate execution . It may be called at most once .
2011-05-13 08:07:28 +00:00
*/
2011-05-15 11:02:29 +00:00
void daemon_start ( daemon_state s ) ;
2011-05-13 08:07:28 +00:00
/*
* Take over from an already running daemon . This function handles connecting
* to the running daemon and telling it we are going to take over . The takeover
* request may be customised by passing in a non - NULL request .
*
* The takeover sequence : the old daemon stops accepting new clients , then it
* waits until all current client connections are closed . When that happens , it
* serializes its current state and sends that as a reply , which is then
* returned by this function ( therefore , this function won ' t return until the
* previous instance has shut down ) .
*
* The daemon , after calling daemon_takeover is expected to set up its
* daemon_state using the reply from this function and call daemon_start as
* usual .
*/
daemon_reply daemon_takeover ( daemon_info i , daemon_request r ) ;
/* Call this to request a clean shutdown of the daemon. Async safe. */
void daemon_stop ( ) ;
# endif