2009-07-28 18:46:53 +04:00
/*
Copyright Red Hat , Inc . 2006
This program is free software ; you can redistribute it and / or modify it
under the terms of the GNU General Public License as published by the
Free Software Foundation ; either version 2 , or ( at your option ) any
later version .
This program is distributed in the hope that it will be useful , but
WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
General Public License for more details .
You should have received a copy of the GNU General Public License
along with this program ; see the file COPYING . If not , write to the
Free Software Foundation , Inc . , 675 Mass Ave , Cambridge ,
MA 0213 9 , USA .
*/
/*
* @ file fence_virtd . c : Implementation of server daemon for Xen virtual
* machine fencing . This uses SA AIS CKPT b .1 .0 checkpointing API to
* store virtual machine states .
*
* Author : Lon Hohberger < lhh at redhat . com >
*/
# include <stdio.h>
# include <stdlib.h>
# include <string.h>
# include <unistd.h>
# include <signal.h>
# include <sys/types.h>
# include <sys/stat.h>
# include <sys/wait.h>
# include <sys/ioctl.h>
# include <arpa/inet.h>
# include <net/if.h>
# include <netinet/in.h>
# include <sys/time.h>
# include <errno.h>
# include <pthread.h>
# include <libgen.h>
/* Local includes */
# include "xvm.h"
# include "options.h"
# include "debug.h"
# include <client.h>
int
main ( int argc , char * * argv )
{
fence_virt_args_t args ;
2010-01-09 22:20:59 +03:00
const char * my_options ;
2010-01-13 17:26:32 +03:00
int ret = 0 ;
2009-07-28 18:46:53 +04:00
args_init ( & args ) ;
if ( ! strcmp ( basename ( argv [ 0 ] ) , " fence_xvm " ) ) {
2010-01-09 22:20:59 +03:00
my_options = " di:a:p:r:C:c:k:M:H:uo:t:?hV " ;
2009-07-28 18:46:53 +04:00
args . mode = MODE_MULTICAST ;
} else {
2010-01-09 22:20:59 +03:00
my_options = " dD:P:M:H:o:t:?hV " ;
2009-07-28 18:46:53 +04:00
args . mode = MODE_SERIAL ;
}
if ( argc = = 1 ) {
args_get_stdin ( my_options , & args ) ;
} else {
args_get_getopt ( argc , argv , my_options , & args ) ;
}
if ( args . flags & F_HELP ) {
args_usage ( argv [ 0 ] , my_options , 0 ) ;
printf ( " With no command line argument, arguments are "
" read from standard input. \n " ) ;
printf ( " Arguments read from standard input take "
" the form of: \n \n " ) ;
printf ( " arg1=value1 \n " ) ;
printf ( " arg2=value2 \n \n " ) ;
args_usage ( argv [ 0 ] , my_options , 1 ) ;
exit ( 0 ) ;
}
if ( args . flags & F_VERSION ) {
printf ( " %s %s \n " , basename ( argv [ 0 ] ) , XVM_VERSION ) ;
# ifdef FENCE_RELEASE_NAME
printf ( " fence release %s \n " , FENCE_RELEASE_NAME ) ;
# endif
exit ( 0 ) ;
}
args_finalize ( & args ) ;
dset ( args . debug ) ;
if ( args . debug > 0 )
args_print ( & args ) ;
/* Additional validation here */
2009-12-07 20:55:48 +03:00
if ( ! args . domain & & ( args . op ! = FENCE_DEVSTATUS & &
args . op ! = FENCE_HOSTLIST ) ) {
2009-07-28 18:46:53 +04:00
printf ( " No domain specified! \n " ) ;
args . flags | = F_ERR ;
}
if ( args . flags & F_ERR ) {
args_usage ( argv [ 0 ] , my_options , ( argc = = 1 ) ) ;
exit ( 1 ) ;
}
switch ( args . mode ) {
case MODE_MULTICAST :
2010-01-13 17:26:32 +03:00
ret = mcast_fence_virt ( & args ) ;
break ;
2009-07-28 18:46:53 +04:00
case MODE_SERIAL :
2010-01-13 17:26:32 +03:00
ret = serial_fence_virt ( & args ) ;
break ;
default :
return 1 ;
}
switch ( ret ) {
case 0 :
break ;
case RESP_FAIL :
printf ( " Operation failed \n " ) ;
break ;
case RESP_PERM :
printf ( " Permission denied \n " ) ;
break ;
2009-07-28 18:46:53 +04:00
default :
2010-01-13 17:26:32 +03:00
printf ( " Unknown response (%d) \n " , ret ) ;
2009-07-28 18:46:53 +04:00
break ;
}
2010-01-13 17:26:32 +03:00
return ret ;
2009-07-28 18:46:53 +04:00
}