X-Git-Url: https://git.octo.it/?p=collectd.git;a=blobdiff_plain;f=src%2Fvirt.c;h=dff8f71dcb9119c812ad9645f72ea2d5f010b824;hp=6118c0fdabddc541214294e9390f7d7112516e49;hb=0003c4d3c184f0f437499d6073cd023dc7b659c2;hpb=0e363577f4d0a94bef1929f9d9829fb94765ec1e diff --git a/src/virt.c b/src/virt.c index 6118c0fd..dff8f71d 100644 --- a/src/virt.c +++ b/src/virt.c @@ -547,6 +547,12 @@ lv_read (void) continue; } + if (info.state != VIR_DOMAIN_RUNNING) + { + /* only gather stats for running domains */ + continue; + } + cpu_submit (info.cpuTime, domains[i], "virt_cpu_total"); memory_submit ((gauge_t) info.memory * 1024, domains[i]); @@ -588,7 +594,7 @@ lv_read (void) } for (j = 0; j < status; j++) { - memory_stats_submit ((gauge_t) minfo[j].val, domains[i], minfo[j].tag); + memory_stats_submit ((gauge_t) minfo[j].val * 1024, domains[i], minfo[j].tag); } sfree (minfo); @@ -920,6 +926,9 @@ add_interface_device (virDomainPtr dom, const char *path, const char *address, u int new_size = sizeof (interface_devices[0]) * (nr_interface_devices+1); char *path_copy, *address_copy, number_string[15]; + if ((path == NULL) || (address == NULL)) + return EINVAL; + path_copy = strdup (path); if (!path_copy) return -1; @@ -955,6 +964,9 @@ ignore_device_match (ignorelist_t *il, const char *domname, const char *devpath) char *name; int n, r; + if ((domname == NULL) || (devpath == NULL)) + return 0; + n = sizeof (char) * (strlen (domname) + strlen (devpath) + 2); name = malloc (n); if (name == NULL) {