X-Git-Url: https://git.octo.it/?p=collectd.git;a=blobdiff_plain;f=src%2Fvirt.c;h=11481a4ca00b387e67eff2067de124863651c2fc;hp=d3d8c6a72823d1c5cf023a9d484ee00cbb7bd54f;hb=43d22c19485997e82d28a9ed7ba17965882dc27f;hpb=abaa1c8a24e8eff5632dd6052b1da5f6535caf19 diff --git a/src/virt.c b/src/virt.c index d3d8c6a7..11481a4c 100644 --- a/src/virt.c +++ b/src/virt.c @@ -1665,16 +1665,7 @@ static int get_pcpu_stats(virDomainPtr dom) { #endif /* HAVE_CPU_STATS */ #ifdef HAVE_DOM_REASON - -static void domain_state_submit(virDomainPtr dom, int state, int reason) { - value_t values[] = { - {.gauge = (gauge_t)state}, {.gauge = (gauge_t)reason}, - }; - - submit(dom, "domain_state", NULL, values, STATIC_ARRAY_SIZE(values)); -} - -static int get_domain_state(virDomainPtr domain) { +static int submit_domain_state(virDomainPtr domain) { int domain_state = 0; int domain_reason = 0; @@ -1685,9 +1676,13 @@ static int get_domain_state(virDomainPtr domain) { return status; } - domain_state_submit(domain, domain_state, domain_reason); + value_t values[] = { + {.gauge = (gauge_t)domain_state}, {.gauge = (gauge_t)domain_reason}, + }; + + submit(domain, "domain_state", NULL, values, STATIC_ARRAY_SIZE(values)); - return status; + return 0; } #ifdef HAVE_LIST_ALL_DOMAINS @@ -1702,8 +1697,7 @@ static int get_domain_state_notify(virDomainPtr domain) { return status; } - if (persistent_notification) - domain_state_submit_notif(domain, domain_state, domain_reason); + domain_state_submit_notif(domain, domain_state, domain_reason); return status; } @@ -1737,9 +1731,9 @@ static int get_memory_stats(virDomainPtr domain) { swap_in = minfo[i].val; else if (minfo[i].tag == VIR_DOMAIN_MEMORY_STAT_SWAP_OUT) swap_out = minfo[i].val; - else if (minfo[i].tag == VIR_DOMAIN_MEMORY_STAT_MAJOR_FAULT) - min_flt = minfo[i].val; else if (minfo[i].tag == VIR_DOMAIN_MEMORY_STAT_MINOR_FAULT) + min_flt = minfo[i].val; + else if (minfo[i].tag == VIR_DOMAIN_MEMORY_STAT_MAJOR_FAULT) maj_flt = minfo[i].val; #ifdef LIBVIR_CHECK_VERSION #if LIBVIR_CHECK_VERSION(2, 1, 0) @@ -2007,7 +2001,7 @@ static int get_domain_metrics(domain_t *domain) { * however it doesn't provide a reason for entering particular state. * We need to get it from virDomainGetState. */ - GET_STATS(get_domain_state, "domain reason", domain->ptr); + GET_STATS(submit_domain_state, "domain reason", domain->ptr); #endif } @@ -2363,8 +2357,8 @@ static int lv_read(user_data_t *ud) { if (dom->active) status = get_domain_metrics(dom); #ifdef HAVE_DOM_REASON - else - status = get_domain_state(dom->ptr); + else if (extra_stats & ex_stats_domain_state) + status = submit_domain_state(dom->ptr); #endif if (status != 0)