[hackers] [slstatus] temp: Port to OpenBSD || Aaron Marcher

From: <git_AT_suckless.org>
Date: Sun, 29 Apr 2018 18:35:37 +0200 (CEST)

commit 489c6f87d1d19831a7d43840dd76b111d657750b
Author: Aaron Marcher <me_AT_drkhsh.at>
AuthorDate: Sun Apr 29 18:35:41 2018 +0200
Commit: Aaron Marcher <me_AT_drkhsh.at>
CommitDate: Sun Apr 29 18:35:41 2018 +0200

    temp: Port to OpenBSD
    
    In OpenBSD temperature gets fetched using sysctl now.

diff --git a/README b/README
index 6753c35..14544dc 100644
--- a/README
+++ b/README
_AT_@ -66,4 +66,3 @@ The following functions are not portable at the moment:
 - entropy
 - swap_{free,perc,total,used}
 - battery_{power,state}
-- temp
diff --git a/components/temperature.c b/components/temperature.c
index 4a447e5..a5df012 100644
--- a/components/temperature.c
+++ b/components/temperature.c
_AT_@ -1,9 +1,16 @@
 /* See LICENSE file for copyright and license details. */
-#if defined(__linux__)
+#include <errno.h>
 #include <stdio.h>
+#include <string.h>
+#if defined(__OpenBSD__)
+#include <sys/sysctl.h>
+#include <sys/time.h>
+#include <sys/sensors.h>
+#endif
 
 #include "../util.h"
 
+#if defined(__linux__)
 const char *
 temp(const char *file)
 {
_AT_@ -12,4 +19,27 @@ temp(const char *file)
         return (pscanf(file, "%d", &temp) == 1) ?
                bprintf("%d", temp / 1000) : NULL;
 }
+#elif defined(__OpenBSD__)
+const char *
+temp(const char *null)
+{
+ int mib[5];
+ size_t size;
+ struct sensor temp;
+
+ mib[0] = CTL_HW;
+ mib[1] = HW_SENSORS;
+ mib[2] = 0; /* cpu0 */
+ mib[3] = SENSOR_TEMP;
+ mib[4] = 0; /* temp0 */
+
+ size = sizeof(temp);
+
+ if (sysctl(mib, 5, &temp, &sz, NULL, 0) == -1) {
+ fprintf(stderr, "sysctl 'SENSOR_TEMP': %s\n", strerror(errno));
+ return NULL;
+ }
+
+ return bprintf("%d", (temp.value - 273150000) / 1000000); /* kelvin to celsius */
+}
 #endif
Received on Sun Apr 29 2018 - 18:35:37 CEST

This archive was generated by hypermail 2.3.0 : Sun Apr 29 2018 - 18:36:32 CEST