X-Git-Url: https://arthur.barton.de/gitweb/?a=blobdiff_plain;f=src%2Fplugin_freebsd.c;h=3490e70edef2f587d758ce0bb1adf61ecb6a77db;hb=2954bc0b419e75fbfcf2b5081cb3e6e03a850049;hp=47a18613727bffc4b37d876deb79b2d3b82ef876;hpb=61915b30f361df12378c6c9b9eaa942190a6d26a;p=netdata.git diff --git a/src/plugin_freebsd.c b/src/plugin_freebsd.c index 47a18613..3490e70e 100644 --- a/src/plugin_freebsd.c +++ b/src/plugin_freebsd.c @@ -1,8 +1,7 @@ #include "common.h" -void *freebsd_main(void *ptr) -{ - (void)ptr; +void *freebsd_main(void *ptr) { + struct netdata_static_thread *static_thread = (struct netdata_static_thread *)ptr; info("FREEBSD Plugin thread created with task id %d", gettid()); @@ -12,12 +11,6 @@ void *freebsd_main(void *ptr) if(pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, NULL) != 0) error("Cannot set pthread cancel state to ENABLE."); - // disable (by default) various interface that are not needed - /* - config_get_boolean("plugin:proc:/proc/net/dev:lo", "enabled", 0); - config_get_boolean("plugin:proc:/proc/net/dev:fireqos_monitor", "enabled", 0); - */ - // when ZERO, attempt to do it int vdo_cpu_netdata = !config_get_boolean("plugin:freebsd", "netdata server resources", 1); int vdo_freebsd_sysctl = !config_get_boolean("plugin:freebsd", "sysctl", 1); @@ -25,15 +18,11 @@ void *freebsd_main(void *ptr) // keep track of the time each module was called unsigned long long sutime_freebsd_sysctl = 0ULL; - unsigned long long step = rrd_update_every * 1000000ULL; + usec_t step = localhost->rrd_update_every * USEC_PER_SEC; + heartbeat_t hb; + heartbeat_init(&hb); for(;;) { - unsigned long long now = time_usec(); - unsigned long long next = now - (now % step) + step; - - while(now < next) { - sleep_usec(next - now); - now = time_usec(); - } + usec_t hb_dt = heartbeat_next(&hb, step); if(unlikely(netdata_exit)) break; @@ -41,9 +30,7 @@ void *freebsd_main(void *ptr) if(!vdo_freebsd_sysctl) { debug(D_PROCNETDEV_LOOP, "FREEBSD: calling do_freebsd_sysctl()."); - now = time_usec(); - vdo_freebsd_sysctl = do_freebsd_sysctl(rrd_update_every, (sutime_freebsd_sysctl > 0)?now - sutime_freebsd_sysctl:0ULL); - sutime_freebsd_sysctl = now; + vdo_freebsd_sysctl = do_freebsd_sysctl(localhost->rrd_update_every, hb_dt); } if(unlikely(netdata_exit)) break; @@ -59,21 +46,7 @@ void *freebsd_main(void *ptr) info("FREEBSD thread exiting"); + static_thread->enabled = 0; pthread_exit(NULL); return NULL; } - -int getsysctl(const char *name, void *ptr, size_t len) -{ - size_t nlen = len; - - if (unlikely(sysctlbyname(name, ptr, &nlen, NULL, 0) == -1)) { - error("FREEBSD: sysctl(%s...) failed: %s", name, strerror(errno)); - return 1; - } - if (unlikely(nlen != len)) { - error("FREEBSD: sysctl(%s...) expected %lu, got %lu", name, (unsigned long)len, (unsigned long)nlen); - return 1; - } - return 0; -}