diff options
author | Ton Voon <tonvoon@users.sourceforge.net> | 2006-12-07 16:07:42 +0000 |
---|---|---|
committer | Ton Voon <tonvoon@users.sourceforge.net> | 2006-12-07 16:07:42 +0000 |
commit | df3662bf3ac0d071b6f0b2d4e5bd45942667e75e (patch) | |
tree | f168820b481cad2b9a37325efb7382f26b9e85a7 /plugins | |
parent | 26725ccd159105e38e5ab4ddc9ef848a5253e6d2 (diff) | |
download | monitoring-plugins-df3662bf3ac0d071b6f0b2d4e5bd45942667e75e.tar.gz |
Fix coredump on 64bit Solaris. Also adds more error conditions and moves
swap specific includes out of common.h (Duncan Ferguson - 1588031)
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@1546 f882894a-f735-0410-b71e-b25c423dba1c
Diffstat (limited to 'plugins')
-rw-r--r-- | plugins/check_disk.c | 3 | ||||
-rw-r--r-- | plugins/check_swap.c | 37 | ||||
-rw-r--r-- | plugins/common.h | 27 | ||||
-rw-r--r-- | plugins/netutils.h | 1 |
4 files changed, 41 insertions, 27 deletions
diff --git a/plugins/check_disk.c b/plugins/check_disk.c index 8f980a49..51e8e850 100644 --- a/plugins/check_disk.c +++ b/plugins/check_disk.c @@ -39,6 +39,9 @@ const char *email = "nagiosplug-devel@lists.sourceforge.net"; #include "common.h" +#ifdef HAVE_SYS_STAT_H +# include <sys/stat.h> +#endif #if HAVE_INTTYPES_H # include <inttypes.h> #endif diff --git a/plugins/check_swap.c b/plugins/check_swap.c index db8ebf95..59c1ecf6 100644 --- a/plugins/check_swap.c +++ b/plugins/check_swap.c @@ -41,6 +41,22 @@ const char *email = "nagiosplug-devel@lists.sourceforge.net"; #include "popen.h" #include "utils.h" +#ifdef HAVE_DECL_SWAPCTL +# ifdef HAVE_SYS_SWAP_H +# include <sys/swap.h> +# endif +# ifdef HAVE_SYS_STAT_H +# include <sys/stat.h> +# endif +# ifdef HAVE_SYS_PARAM_H +# include <sys/param.h> +# endif +#endif + +#ifndef SWAP_CONVERSION +# define SWAP_CONVERSION 1 +#endif + int check_swap (int usp, float free_swap_mb); int process_arguments (int argc, char **argv); int validate_arguments (void); @@ -236,22 +252,33 @@ main (int argc, char **argv) # ifdef CHECK_SWAP_SWAPCTL_SVR4 /* get the number of active swap devices */ - nswaps=swapctl(SC_GETNSWP, NULL); + if((nswaps=swapctl(SC_GETNSWP, NULL))== -1) + die(STATE_UNKNOWN, _("Error getting swap devices\n") ); + + if(nswaps == 0) + die(STATE_OK, _("SWAP OK: No swap devices defined\n")); + + if(verbose >= 3) + printf("Found %d swap device(s)\n", nswaps); /* initialize swap table + entries */ tbl=(swaptbl_t*)malloc(sizeof(swaptbl_t)+(sizeof(swapent_t)*nswaps)); + + if(tbl==NULL) + die(STATE_UNKNOWN, _("malloc() failed!\n")); + memset(tbl, 0, sizeof(swaptbl_t)+(sizeof(swapent_t)*nswaps)); tbl->swt_n=nswaps; for(i=0;i<nswaps;i++){ - ent=&tbl->swt_ent[i]; - ent->ste_path=(char*)malloc(sizeof(char)*MAXPATHLEN); + if((tbl->swt_ent[i].ste_path=(char*)malloc(sizeof(char)*MAXPATHLEN)) == NULL) + die(STATE_UNKNOWN, _("malloc() failed!\n")); } /* and now, tally 'em up */ swapctl_res=swapctl(SC_LIST, tbl); if(swapctl_res < 0){ perror(_("swapctl failed: ")); - result = STATE_WARNING; + die(STATE_UNKNOWN, _("Error in swapctl call\n")); } for(i=0;i<nswaps;i++){ @@ -293,7 +320,7 @@ main (int argc, char **argv) swapctl_res=swapctl(SWAP_STATS, ent, nswaps); if(swapctl_res < 0){ perror(_("swapctl failed: ")); - result = STATE_WARNING; + die(STATE_UNKNOWN, _("Error in swapctl call\n")); } for(i=0;i<nswaps;i++){ diff --git a/plugins/common.h b/plugins/common.h index ac3b8339..b3357431 100644 --- a/plugins/common.h +++ b/plugins/common.h @@ -36,6 +36,12 @@ #define _COMMON_H_ #include "config.h" +/* This needs to be removed for Solaris servers, where 64 bit files, but 32 bit architecture + This needs to be done early on because subsequent system includes use _FILE_OFFSET_BITS + Cannot remove from config.h because is included by regex.c from lib/ */ +#if __sun__ && !defined(_LP64) && _FILE_OFFSET_BITS == 64 +#undef _FILE_OFFSET_BITS +#endif #ifdef HAVE_FEATURES_H #include <features.h> @@ -114,27 +120,6 @@ #include <locale.h> #endif -/* Fixes "Cannot use swapctl in the large files compilation environment" error on Solaris */ -#ifdef _FILE_OFFSET_BITS -#undef _FILE_OFFSET_BITS -#endif - -#ifdef HAVE_DECL_SWAPCTL -# ifdef HAVE_SYS_SWAP_H -# include <sys/swap.h> -# endif -# ifdef HAVE_SYS_STAT_H -# include <sys/stat.h> -# endif -# ifdef HAVE_SYS_PARAM_H -# include <sys/param.h> -# endif -#endif - -#ifndef SWAP_CONVERSION -# define SWAP_CONVERSION 1 -#endif - #ifdef HAVE_SYS_POLL_H # include "sys/poll.h" #endif diff --git a/plugins/netutils.h b/plugins/netutils.h index 1168f9f8..3fc4ef80 100644 --- a/plugins/netutils.h +++ b/plugins/netutils.h @@ -35,7 +35,6 @@ #ifndef _NETUTILS_H_ #define _NETUTILS_H_ -#include "config.h" #include "common.h" #include "utils.h" #include <netinet/in.h> |