Add support for cpu and uptime components on FreeBSD
authorMichael Buch <michaelbuch12@gmail.com>
Tue, 5 Feb 2019 02:44:37 +0000 (02:44 +0000)
committerAaron Marcher <me@drkhsh.at>
Tue, 5 Feb 2019 08:31:06 +0000 (09:31 +0100)
components/cpu.c
components/uptime.c

index d4f80647191e8117dc3ea589dba04981d4b748e3..9a021d51537fe4a1dedca65e5be9e596001b7e86 100644 (file)
                        return NULL;
                }
 
+               return bprintf("%d", 100 *
+                              ((a[CP_USER] + a[CP_NICE] + a[CP_SYS] +
+                                a[CP_INTR]) -
+                               (b[CP_USER] + b[CP_NICE] + b[CP_SYS] +
+                                b[CP_INTR])) /
+                              ((a[CP_USER] + a[CP_NICE] + a[CP_SYS] +
+                                a[CP_INTR] + a[CP_IDLE]) -
+                               (b[CP_USER] + b[CP_NICE] + b[CP_SYS] +
+                                b[CP_INTR] + b[CP_IDLE])));
+       }
+#elif defined(__FreeBSD__)
+       #include <sys/param.h>
+       #include <sys/sysctl.h>
+       #include <devstat.h>
+
+       const char *
+       cpu_freq(void)
+       {
+               int freq;
+               size_t size;
+
+               size = sizeof(freq);
+               /* in MHz */
+               if (sysctlbyname("hw.clockrate", &freq, &size, NULL, 0) == -1
+                               || !size) {
+                       warn("sysctlbyname 'hw.clockrate':");
+                       return NULL;
+               }
+
+               return fmt_human(freq * 1E6, 1000);
+       }
+
+       const char *
+       cpu_perc(void)
+       {
+               size_t size;
+               static long a[CPUSTATES];
+               long b[CPUSTATES];
+
+               size = sizeof(a);
+               memcpy(b, a, sizeof(b));
+               if (sysctlbyname("kern.cp_time", &a, &size, NULL, 0) == -1
+                               || !size) {
+                       warn("sysctlbyname 'kern.cp_time':");
+                       return NULL;
+               }
+               if (b[0] == 0) {
+                       return NULL;
+               }
+
                return bprintf("%d", 100 *
                               ((a[CP_USER] + a[CP_NICE] + a[CP_SYS] +
                                 a[CP_INTR]) -
index 978f88fd33eb78c74866d4da454dd8ec6621f4bb..7c23c98dc23238a898bb737d3e79391334d61276 100644 (file)
@@ -5,14 +5,24 @@
 
 #include "../util.h"
 
+#if defined(CLOCK_BOOTTIME)
+       #define UPTIME_FLAG CLOCK_BOOTTIME
+#elif defined(CLOCK_UPTIME)
+       #define UPTIME_FLAG CLOCK_UPTIME
+#else
+       #define UPTIME_FLAG CLOCK_MONOTONIC
+#endif
+
 const char *
 uptime(void)
 {
+       char warn_buf[256];
        uintmax_t h, m;
        struct timespec uptime;
 
-       if (clock_gettime(CLOCK_BOOTTIME, &uptime) < 0) {
-               warn("clock_gettime 'CLOCK_BOOTTIME'");
+       if (clock_gettime(UPTIME_FLAG, &uptime) < 0) {
+               snprintf(warn_buf, 256, "clock_gettime %d", UPTIME_FLAG);
+               warn(warn_buf);
                return NULL;
        }