3 void *macos_main(void *ptr) {
4 struct netdata_static_thread *static_thread = (struct netdata_static_thread *)ptr;
6 info("MACOS Plugin thread created with task id %d", gettid());
8 if(pthread_setcanceltype(PTHREAD_CANCEL_DEFERRED, NULL) != 0)
9 error("Cannot set pthread cancel type to DEFERRED.");
11 if(pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, NULL) != 0)
12 error("Cannot set pthread cancel state to ENABLE.");
14 // when ZERO, attempt to do it
15 int vdo_cpu_netdata = !config_get_boolean("plugin:macos", "netdata server resources", 1);
16 int vdo_macos_sysctl = !config_get_boolean("plugin:macos", "sysctl", 1);
17 int vdo_macos_mach_smi = !config_get_boolean("plugin:macos", "mach system management interface", 1);
18 int vdo_macos_iokit = !config_get_boolean("plugin:macos", "iokit", 1);
20 // keep track of the time each module was called
21 unsigned long long sutime_macos_sysctl = 0ULL;
22 unsigned long long sutime_macos_mach_smi = 0ULL;
23 unsigned long long sutime_macos_iokit = 0ULL;
25 usec_t step = rrd_update_every * USEC_PER_SEC;
29 usec_t hb_dt = heartbeat_next(&hb, step);
31 if(unlikely(netdata_exit)) break;
33 // BEGIN -- the job to be done
35 if(!vdo_macos_sysctl) {
36 debug(D_PROCNETDEV_LOOP, "MACOS: calling do_macos_sysctl().");
37 vdo_macos_sysctl = do_macos_sysctl(rrd_update_every, hb_dt);
39 if(unlikely(netdata_exit)) break;
41 if(!vdo_macos_mach_smi) {
42 debug(D_PROCNETDEV_LOOP, "MACOS: calling do_macos_mach_smi().");
43 vdo_macos_mach_smi = do_macos_mach_smi(rrd_update_every, hb_dt);
45 if(unlikely(netdata_exit)) break;
47 if(!vdo_macos_iokit) {
48 debug(D_PROCNETDEV_LOOP, "MACOS: calling do_macos_iokit().");
49 vdo_macos_iokit = do_macos_iokit(rrd_update_every, hb_dt);
51 if(unlikely(netdata_exit)) break;
53 // END -- the job is done
55 // --------------------------------------------------------------------
57 if(!vdo_cpu_netdata) {
58 global_statistics_charts();
59 registry_statistics();
63 info("MACOS thread exiting");
65 static_thread->enabled = 0;