diff options
author | Karl DeBisschop <kdebisschop@users.sourceforge.net> | 2004-02-28 04:54:32 +0000 |
---|---|---|
committer | Karl DeBisschop <kdebisschop@users.sourceforge.net> | 2004-02-28 04:54:32 +0000 |
commit | 0eda59afa1c95f2e11ae52925169a7c11bb6e352 (patch) | |
tree | 711765a77d619b440cf30410b9c3c69102ba45c5 | |
parent | db265d5590f08746d9375807551cb1effdcf941d (diff) | |
download | monitoring-plugins-0eda59afa1c95f2e11ae52925169a7c11bb6e352.tar.gz |
update to work with Linux 2.6 /proc/meminfo format
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@827 f882894a-f735-0410-b71e-b25c423dba1c
-rw-r--r-- | plugins/check_swap.c | 17 |
1 files changed, 14 insertions, 3 deletions
diff --git a/plugins/check_swap.c b/plugins/check_swap.c index 02b043e5..fe792e87 100644 --- a/plugins/check_swap.c +++ b/plugins/check_swap.c @@ -52,7 +52,7 @@ main (int argc, char **argv) { int percent_used, percent; unsigned long long total_swap = 0, used_swap = 0, free_swap = 0; - unsigned long long dsktotal, dskused, dskfree; + unsigned long long dsktotal, dskused, dskfree, tmp; int result = STATE_OK; char input_buffer[MAX_INPUT_BUFFER]; char *perf; @@ -82,8 +82,7 @@ main (int argc, char **argv) #ifdef HAVE_PROC_MEMINFO fp = fopen (PROC_MEMINFO, "r"); while (fgets (input_buffer, MAX_INPUT_BUFFER - 1, fp)) { - if (sscanf (input_buffer, " %s %llu %llu %llu", str, &dsktotal, &dskused, &dskfree) == 4 && - strstr (str, "Swap")) { + if (sscanf (input_buffer, "%*[S]%*[w]%*[a]%*[p]%*[:] %llu %llu %llu", &dsktotal, &dskused, &dskfree) == 3) { dsktotal = dsktotal / 1048576; dskused = dskused / 1048576; dskfree = dskfree / 1048576; @@ -97,8 +96,20 @@ main (int argc, char **argv) asprintf (&status, "%s [%llu (%d%%)]", status, dskfree, 100 - percent); } } + else if (sscanf (input_buffer, "%*[S]%*[w]%*[a]%*[p]%[TotalFre]%*[:] %llu %*[k]%*[B]", str, &tmp)) { + if (strcmp ("Total", str) == 0) { + dsktotal = tmp / 1024; + } + else if (strcmp ("Free", str) == 0) { + dskfree = tmp / 1024; + } + } } fclose(fp); + dskused = dsktotal - dskfree; + total_swap = dsktotal; + used_swap = dskused; + free_swap = dskfree; #else # ifdef HAVE_SWAP asprintf(&swap_command, "%s", SWAP_COMMAND); |