summaryrefslogtreecommitdiff
path: root/components/uptime.c
diff options
context:
space:
mode:
authorTobias Tschinkowitz <tobias@he4d.net>2018-06-01 20:10:34 +0200
committerAaron Marcher <me@drkhsh.at>2018-06-01 20:17:25 +0200
commit005b5417179de9eff56a9ac5f2ed818ae9ad5817 (patch)
tree5405653c0511725f47db2c5d2e52fed46e04c88c /components/uptime.c
parent8c8091f4f165974c44d75dd9ccc7cc4dcd1d1c96 (diff)
uptime: unification of the uptime function for linux/openbsd
Diffstat (limited to 'components/uptime.c')
-rw-r--r--components/uptime.c60
1 files changed, 10 insertions, 50 deletions
diff --git a/components/uptime.c b/components/uptime.c
index 8f15d71..274b41b 100644
--- a/components/uptime.c
+++ b/components/uptime.c
@@ -1,59 +1,19 @@
/* See LICENSE file for copyright and license details. */
+#include <time.h>
#include <stdio.h>
#include "../util.h"
-static const char *
-format(int uptime)
+const char *
+uptime(void)
{
int h, m;
-
- h = uptime / 3600;
- m = (uptime - h * 3600) / 60;
-
+ struct timespec uptime;
+ if (clock_gettime(CLOCK_BOOTTIME, &uptime) < 0) {
+ warn("clock_gettime 'CLOCK_BOOTTIME'");
+ return NULL;
+ }
+ h = uptime.tv_sec / 3600;
+ m = uptime.tv_sec % 3600 / 60;
return bprintf("%dh %dm", h, m);
}
-
-#if defined(__linux__)
- #include <sys/sysinfo.h>
-
- const char *
- uptime(void)
- {
- int uptime;
- struct sysinfo info;
-
- sysinfo(&info);
- uptime = info.uptime;
-
- return format(uptime);
- }
-#elif defined(__OpenBSD__)
- #include <sys/sysctl.h>
- #include <sys/time.h>
-
- const char *
- uptime(void)
- {
- int mib[2], uptime;
- size_t size;
- time_t now;
- struct timeval boottime;
-
- time(&now);
-
- mib[0] = CTL_KERN;
- mib[1] = KERN_BOOTTIME;
-
- size = sizeof(boottime);
-
- if (sysctl(mib, 2, &boottime, &size, NULL, 0) < 0) {
- warn("sysctl 'KERN_BOOTTIME':");
- return NULL;
- }
-
- uptime = now - boottime.tv_sec;
-
- return format(uptime);
- }
-#endif