summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorpmalhaire <7273249+pmalhaire@users.noreply.github.com>2018-03-25 22:04:16 +0200
committerHisham Muhammad <hisham@gobolinux.org>2018-04-06 11:14:09 -0300
commitd4c4c02b97e3ec5ef82ad11a2ebcd294543bf97d (patch)
tree88bdd837743cd5137fbb373567355bf9fdf99224
parent1ef20d1f141ab121f572b3b68358f45271e1e8ab (diff)
macOS: keep scanning thread for versions before High Sierra (#728)
Keep scanning threads for versions before High Sierra 13.0.0 and after 13.3.0.
-rw-r--r--darwin/DarwinProcessList.c38
1 files changed, 35 insertions, 3 deletions
diff --git a/darwin/DarwinProcessList.c b/darwin/DarwinProcessList.c
index 9aad8b4a..b4e26347 100644
--- a/darwin/DarwinProcessList.c
+++ b/darwin/DarwinProcessList.c
@@ -18,6 +18,34 @@ in the source distribution for its full text.
#include <sys/mman.h>
#include <utmpx.h>
#include <err.h>
+#include <sys/sysctl.h>
+#include <stdbool.h>
+
+struct kern {
+ short int version[3];
+};
+
+void GetKernelVersion(struct kern *k) {
+ static short int version_[3] = {0};
+ if (!version_[0]) {
+ // just in case it fails someday
+ version_[0] = version_[1] = version_[2] = -1;
+ char str[256] = {0};
+ size_t size = sizeof(str);
+ int ret = sysctlbyname("kern.osrelease", str, &size, NULL, 0);
+ if (ret == 0) sscanf(str, "%hd.%hd.%hd", &version_[0], &version_[1], &version_[2]);
+ }
+ memcpy(k->version, version_, sizeof(version_));
+}
+
+int CompareKernelVersion(short int major, short int minor, short int component) {
+ struct kern k;
+ GetKernelVersion(&k);
+ if ( k.version[0] != major) return major - k.version[0];
+ if ( k.version[1] != minor) return minor - k.version[1];
+ if ( k.version[2] != component) return component - k.version[2];
+ return 0;
+}
/*{
#include "ProcessList.h"
@@ -170,9 +198,13 @@ void ProcessList_goThroughEntries(ProcessList* super) {
DarwinProcess_setFromKInfoProc(&proc->super, &ps[i], tv.tv_sec, preExisting);
DarwinProcess_setFromLibprocPidinfo(proc, dpl);
-
- // Disabled due to bug in macOS High Sierra
- // DarwinProcess_scanThreads(proc);
+
+ // Disabled for High Sierra due to bug in macOS High Sierra
+ bool isScanThreadSupported = ! ( CompareKernelVersion(17, 0, 0) >= 0 && CompareKernelVersion(17, 5, 0) < 0);
+
+ if (isScanThreadSupported){
+ DarwinProcess_scanThreads(proc);
+ }
super->totalTasks += 1;

© 2014-2024 Faster IT GmbH | imprint | privacy policy