]> arthur.barton.de Git - netdata.git/blob - src/plugin_macos.c
Merge remote-tracking branch 't-h-e/master'
[netdata.git] / src / plugin_macos.c
1 #include "common.h"
2
3 void *macos_main(void *ptr) {
4     struct netdata_static_thread *static_thread = (struct netdata_static_thread *)ptr;
5
6     info("MACOS Plugin thread created with task id %d", gettid());
7
8     if(pthread_setcanceltype(PTHREAD_CANCEL_DEFERRED, NULL) != 0)
9         error("Cannot set pthread cancel type to DEFERRED.");
10
11     if(pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, NULL) != 0)
12         error("Cannot set pthread cancel state to ENABLE.");
13
14     // disable (by default) various interface that are not needed
15     /*
16     config_get_boolean("plugin:proc:/proc/net/dev:lo", "enabled", 0);
17     config_get_boolean("plugin:proc:/proc/net/dev:fireqos_monitor", "enabled", 0);
18     */
19
20     // when ZERO, attempt to do it
21     int vdo_cpu_netdata             = !config_get_boolean("plugin:macos", "netdata server resources", 1);
22     int vdo_macos_sysctl            = !config_get_boolean("plugin:macos", "sysctl", 1);
23     int vdo_macos_mach_smi          = !config_get_boolean("plugin:macos", "mach system management interface", 1);
24     int vdo_macos_iokit             = !config_get_boolean("plugin:macos", "iokit", 1);
25
26     // keep track of the time each module was called
27     unsigned long long sutime_macos_sysctl = 0ULL;
28     unsigned long long sutime_macos_mach_smi = 0ULL;
29     unsigned long long sutime_macos_iokit = 0ULL;
30
31     usec_t step = rrd_update_every * USEC_PER_SEC;
32     heartbeat_t hb;
33     heartbeat_init(&hb);
34     for(;;) {
35         usec_t hb_dt = heartbeat_next(&hb, step);
36
37         if(unlikely(netdata_exit)) break;
38
39         // BEGIN -- the job to be done
40
41         if(!vdo_macos_sysctl) {
42             debug(D_PROCNETDEV_LOOP, "MACOS: calling do_macos_sysctl().");
43             vdo_macos_sysctl = do_macos_sysctl(rrd_update_every, hb_dt);
44         }
45         if(unlikely(netdata_exit)) break;
46
47         if(!vdo_macos_mach_smi) {
48             debug(D_PROCNETDEV_LOOP, "MACOS: calling do_macos_mach_smi().");
49             vdo_macos_mach_smi = do_macos_mach_smi(rrd_update_every, hb_dt);
50         }
51         if(unlikely(netdata_exit)) break;
52
53         if(!vdo_macos_iokit) {
54             debug(D_PROCNETDEV_LOOP, "MACOS: calling do_macos_iokit().");
55             vdo_macos_iokit = do_macos_iokit(rrd_update_every, hb_dt);
56         }
57         if(unlikely(netdata_exit)) break;
58
59         // END -- the job is done
60
61         // --------------------------------------------------------------------
62
63         if(!vdo_cpu_netdata) {
64             global_statistics_charts();
65             registry_statistics();
66         }
67     }
68
69     info("MACOS thread exiting");
70
71     static_thread->enabled = 0;
72     pthread_exit(NULL);
73     return NULL;
74 }