summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: eca20aa)
raw | patch | inline | side by side (parent: eca20aa)
author | Holger Weiss <hweiss@users.sourceforge.net> | |
Mon, 2 Apr 2007 12:39:30 +0000 (12:39 +0000) | ||
committer | Holger Weiss <hweiss@users.sourceforge.net> | |
Mon, 2 Apr 2007 12:39:30 +0000 (12:39 +0000) |
multiple of sizeof(ntp_assoc_status_pair).
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@1673 f882894a-f735-0410-b71e-b25c423dba1c
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@1673 f882894a-f735-0410-b71e-b25c423dba1c
plugins/check_ntp.c | patch | blob | history |
diff --git a/plugins/check_ntp.c b/plugins/check_ntp.c
index 99fa9a2eb9225f6ba6de760b6b27e685b3d22e85..8a08af5019da89ad7ad66b97f109332b3cb33074 100644 (file)
--- a/plugins/check_ntp.c
+++ b/plugins/check_ntp.c
double jitter_request(const char *host, int *status){
int conn=-1, i, npeers=0, num_candidates=0, syncsource_found=0;
int run=0, min_peer_sel=PEER_INCLUDED, num_selected=0, num_valid=0;
- int peer_offset=0;
+ int peers_size=0, peer_offset=0;
ntp_assoc_status_pair *peers=NULL;
ntp_control_message req;
double rval = 0.0, jitter = -1.0;
/* Each peer identifier is 4 bytes in the data section, which
* we represent as a ntp_assoc_status_pair datatype.
*/
- npeers+=(ntohs(req.count)/sizeof(ntp_assoc_status_pair));
- if((tmp=realloc(peers, sizeof(ntp_assoc_status_pair)*npeers)) == NULL)
+ peers_size+=ntohs(req.count);
+ if((tmp=realloc(peers, peers_size)) == NULL)
free(peers), die(STATE_UNKNOWN, "can not (re)allocate 'peers' buffer\n");
peers=tmp;
memcpy((void*)((ptrdiff_t)peers+peer_offset), (void*)req.data, ntohs(req.count));
+ npeers=peers_size/sizeof(ntp_assoc_status_pair);
peer_offset+=ntohs(req.count);
} while(req.op&REM_MORE);
printf("parsing jitter from peer %.2x: ", ntohs(peers[i].assoc));
}
startofvalue = strchr(req.data, '=');
- if(startofvalue != NULL) startofvalue++;
if(startofvalue != NULL) {
+ startofvalue++;
jitter = strtod(startofvalue, &nptr);
}
if(startofvalue == NULL || startofvalue==nptr){
rval = num_valid ? rval / num_valid : -1.0;
close(conn);
- free(peers);
+ if(peers!=NULL) free(peers);
/* If we return -1.0, it means no synchronization source was found */
return rval;
}