diff --git a/src/df.c b/src/df.c
index 371a7fc3db9973b676322a75362d14b633b45a81..abb6418ae00c8dd13f20219a32c6ab57aca1b2d3 100644 (file)
--- a/src/df.c
+++ b/src/df.c
"IgnoreSelected",
"ReportByDevice",
"ReportReserved",
- "ReportInodes"
+ "ReportInodes",
+ "FreePercentage"
};
static int config_keys_num = STATIC_ARRAY_SIZE (config_keys);
static _Bool by_device = 0;
static _Bool report_inodes = 0;
+static _Bool report_free_percentage = 0;
static int df_init (void)
{
return (0);
}
+ else if (strcasecmp (key, "FreePercentage") == 0)
+ {
+ if (IS_TRUE (value))
+ report_free_percentage = 1;
+ else
+ report_free_percentage = 0;
+
+ return (0);
+ }
return (-1);
}
uint64_t blk_free;
uint64_t blk_reserved;
uint64_t blk_used;
+ float blk_free_percentage;
if (ignorelist_match (il_device,
(mnt_ptr->spec_device != NULL)
{
if (strcmp (mnt_ptr->dir, "/") == 0)
{
+ if (strcmp (mnt_ptr->type, "rootfs") == 0)
+ continue;
sstrncpy (disk_name, "root", sizeof (disk_name));
}
else
* report negative free space for user. Notice. blk_reserved
* will start to diminish after this. */
#if HAVE_STATVFS
- /* Cast is needed to avoid compiler warnings.
+ /* Cast and temporary variable are needed to avoid
+ * compiler warnings.
* ((struct statvfs).f_bavail is unsigned (POSIX)) */
- if (((int64_t) statbuf.f_bavail) < 0)
+ int64_t signed_bavail = (int64_t) statbuf.f_bavail;
+ if (signed_bavail < 0)
statbuf.f_bavail = 0;
#elif HAVE_STATFS
if (statbuf.f_bavail < 0)
df_submit_one (disk_name, "df_complex", "used",
(gauge_t) (blk_used * blocksize));
+
+ if (report_free_percentage)
+ {
+ blk_free_percentage = (float)((statbuf.f_blocks - statbuf.f_bfree) / statbuf.f_blocks * 100);
+ float diff = statbuf.f_blocks - statbuf.f_bfree;
+ float div = diff/statbuf.f_blocks ;
+
+ df_submit_one (disk_name, "df_complex", "free_percentage",
+ (gauge_t) (div * 100));
+ }
/* inode handling */
if (report_inodes)
{