summaryrefslogtreecommitdiff
path: root/benchmarks/libcpucycles/files/patch-cpucycles_wrapper.c
blob: 703b4a0763c3f08f822df74526ab6d9905dc65bc (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
--- cpucycles/wrapper.c.orig	2024-03-18 00:15:33 UTC
+++ cpucycles/wrapper.c
@@ -16,6 +16,12 @@
 #include <inttypes.h>
 #include <signal.h>
 #include <setjmp.h>
+
+#ifdef __FreeBSD__
+#include <sched.h>
+#include <sys/sysctl.h>
+#endif
+
 #include "cpucycles.h"
 #include "cpucycles_internal.h"
 
@@ -26,7 +32,7 @@ void cpucycles_tracesetup(void)
   tracesetup = 1;
 }
 
-static jmp_buf crash_jmp;
+static sigjmp_buf crash_jmp;
 
 static void crash(int s)
 {
@@ -81,6 +87,21 @@ static double osfreq(void)
     if (s > 0) return result;
   }
 
+#ifdef __FreeBSD__
+  {
+    int freq;
+    size_t len = sizeof freq;
+    char *freqctl;
+
+    if (asprintf(&freqctl, "dev.cpu.%d.freq", sched_getcpu())) {
+      if (sysctlbyname(freqctl, &freq, &len, NULL, 0) == 0) {
+        free(freqctl);
+        return 1e6 * freq;
+      } else
+        free(freqctl);
+    }
+  }
+#else
   f = fopen("/sys/devices/system/cpu/cpu0/cpufreq/scaling_setspeed", "r");
   if (f) {
     s = fscanf(f,"%lf",&result);
@@ -163,6 +184,7 @@ static double osfreq(void)
     pclose(f);
     if (result) return 1000000.0 * result;
   }
+#endif /* defined(__FreeBSD__) */
 
   x = getenv("cpucyclespersecond");
   if (x) {