From 8de12dec298898d133256fdaac584a26adae2cc5 Mon Sep 17 00:00:00 2001 From: Florian Eckert Date: Wed, 17 Nov 2021 11:41:17 +0100 Subject: system: add diskfree infos to ubus This change adds the missing information about how much space is available on the root directory and in the temp directory. I took this implementation from the luci2 repository and adapted it for the procd service. Signed-off-by: Florian Eckert --- system.c | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/system.c b/system.c index c208e3e..5811d39 100644 --- a/system.c +++ b/system.c @@ -20,6 +20,7 @@ #include #include #include +#include #include #include #include @@ -312,6 +313,12 @@ static int system_board(struct ubus_context *ctx, struct ubus_object *obj, return UBUS_STATUS_OK; } +static unsigned long +kscale(unsigned long b, unsigned long bs) +{ + return (b * (unsigned long long) bs + 1024/2) / 1024; +} + static int system_info(struct ubus_context *ctx, struct ubus_object *obj, struct ubus_request_data *req, const char *method, struct blob_attr *msg) @@ -325,6 +332,12 @@ static int system_info(struct ubus_context *ctx, struct ubus_object *obj, char *key, *val; unsigned long long available, cached; FILE *f; + int i; + struct statvfs s; + const char *fslist[] = { + "/", "root", + "/tmp", "tmp", + }; if (sysinfo(&info)) return UBUS_STATUS_UNKNOWN_ERROR; @@ -384,6 +397,23 @@ static int system_info(struct ubus_context *ctx, struct ubus_object *obj, blobmsg_add_u64(&b, "cached", cached); blobmsg_close_table(&b, c); + for (i = 0; i < sizeof(fslist) / sizeof(fslist[0]); i += 2) { + if (statvfs(fslist[i], &s)) + continue; + + c = blobmsg_open_table(&b, fslist[i+1]); + + if (!s.f_frsize) + s.f_frsize = s.f_bsize; + + blobmsg_add_u64(&b, "total", kscale(s.f_blocks, s.f_frsize)); + blobmsg_add_u64(&b, "free", kscale(s.f_bfree, s.f_frsize)); + blobmsg_add_u64(&b, "used", kscale(s.f_blocks - s.f_bfree, s.f_frsize)); + blobmsg_add_u64(&b, "avail", kscale(s.f_bavail, s.f_frsize)); + + blobmsg_close_table(&b, c); + } + c = blobmsg_open_table(&b, "swap"); blobmsg_add_u64(&b, "total", (uint64_t)info.mem_unit * (uint64_t)info.totalswap); -- cgit v1.2.1