From: octo Date: Sun, 9 Apr 2006 12:48:14 +0000 (+0000) Subject: Corrected `getfsstat' part of `utils_mount.c': The buffer size needs to be passed... X-Git-Tag: liboping-0.1.0~111 X-Git-Url: https://git.tokkee.org/?a=commitdiff_plain;h=c652136e3e717b54caf112bb4df71cee4022a532;p=collectd.git Corrected `getfsstat' part of `utils_mount.c': The buffer size needs to be passed in bytes, not elements. --- diff --git a/src/utils_mount.c b/src/utils_mount.c index 176040aa..30a155f4 100644 --- a/src/utils_mount.c +++ b/src/utils_mount.c @@ -429,15 +429,21 @@ static cu_mount_t *cu_mount_getfsstat (void) /* Get the number of mounted file systems */ if ((bufsize = getfsstat (NULL, 0, MNT_NOWAIT)) < 1) + { + DBG ("getfsstat failed: %s", strerror (errno)); return (NULL); + } - if ((buf = (struct statfs *) malloc (bufsize * sizeof (struct statfs))) == NULL) + if ((buf = (struct statfs *) malloc (bufsize * sizeof (struct statfs))) + == NULL) return (NULL); memset (buf, '\0', bufsize * sizeof (struct statfs)); - /* FIXME: If `bufsize' in bytes or structures? */ - if ((num = getfsstat (buf, bufsize, MNT_NOWAIT)) < 1) + /* The bufsize needs to be passed in bytes. Really. This is not in the + * manpage.. -octo */ + if ((num = getfsstat (buf, bufsize * sizeof (struct statfs), MNT_NOWAIT)) < 1) { + DBG ("getfsstat failed: %s", strerror (errno)); free (buf); return (NULL); }