.f_json_print = json_print_pwr_in_stats,
.f_svg_print = svg_print_pwr_in_stats,
.f_raw_print = raw_print_pwr_in_stats,
+ .f_pcp_print = pcp_print_pwr_in_stats,
.f_count_new = NULL,
.item_list = NULL,
.desc = "Voltage inputs statistics",
#endif /* HAVE_PCP */
}
+/*
+ ***************************************************************************
+ * Define PCP metrics for voltage inputs statistics.
+ *
+ * IN:
+ * @a Activity structure with statistics.
+ ***************************************************************************
+ */
+void pcp_def_pwr_in_metrics(struct activity *a)
+{
+#ifdef HAVE_PCP
+ int inst = 0;
+ static pmInDom indom = PM_INDOM_NULL;
+ char buf[16];
+
+ if (indom == PM_INDOM_NULL) {
+ /* Create domain */
+ indom = pmInDom_build(0, PM_INDOM_IN);
+
+ for (inst = 0; inst < a->item_list_sz; inst++) {
+ sprintf(buf, "in%d", inst);
+ pmiAddInstance(indom, buf, inst);
+ }
+ }
+
+ pmiAddMetric("power.in.inV",
+ PM_IN_NULL, PM_TYPE_FLOAT, indom, PM_SEM_INSTANT,
+ pmiUnits(0, 0, 0, 0, 0, 0));
+
+ pmiAddMetric("power.in.in_pct",
+ PM_IN_NULL, PM_TYPE_FLOAT, indom, PM_SEM_INSTANT,
+ pmiUnits(0, 0, 0, 0, 0, 0));
+
+ pmiAddMetric("power.in.device",
+ PM_IN_NULL, PM_TYPE_STRING, indom, PM_SEM_DISCRETE,
+ pmiUnits(0, 0, 0, 0, 0, 0));
+#endif /* HAVE_PCP */
+}
+
/*
***************************************************************************
* Define PCP metrics for USB devices statistics.
void pcp_def_huge_metrics(void);
void pcp_def_pwr_fan_metrics(struct activity *);
void pcp_def_pwr_temp_metrics(struct activity *);
+void pcp_def_pwr_in_metrics(struct activity *);
void pcp_def_pwr_usb_metrics(struct activity *);
void pcp_def_filesystem_metrics(struct activity *);
void pcp_def_fchost_metrics(struct activity *);
#define PM_INDOM_DISK 8
#define PM_INDOM_FAN 9
#define PM_INDOM_TEMP 10
+#define PM_INDOM_IN 11
#endif /* _PCP_DEF_METRICS_H */
#endif /* HAVE_PCP */
}
+/*
+ ***************************************************************************
+ * Display voltage inputs statistics in PCP format.
+ *
+ * IN:
+ * @a Activity structure with statistics.
+ * @curr Index in array for current sample statistics.
+ * @itv Interval of time in 1/100th of a second.
+ * @record_hdr Record header for current sample.
+ ***************************************************************************
+ */
+__print_funct_t pcp_print_pwr_in_stats(struct activity *a, int curr, unsigned long long itv,
+ struct record_header *record_hdr)
+{
+#ifdef HAVE_PCP
+ int i;
+ struct stats_pwr_in *spc;
+ char buf[64], instance[32];
+
+ for (i = 0; i < a->nr[curr]; i++) {
+
+ spc = (struct stats_pwr_in *) ((char *) a->buf[curr] + i * a->msize);
+ sprintf(instance, "in%d", i);
+
+ snprintf(buf, sizeof(buf), "%f",
+ spc->in);
+ pmiPutValue("power.in.inV", instance, buf);
+
+ snprintf(buf, sizeof(buf), "%f",
+ (spc->in_max - spc->in_min) ?
+ (spc->in - spc->in_min) / (spc->in_max - spc->in_min) * 100 :
+ 0.0);
+ pmiPutValue("power.in.in_pct", instance, buf);
+
+ snprintf(buf, sizeof(buf), "%s",
+ spc->device);
+ pmiPutValue("power.in.device", instance, buf);
+ }
+#endif /* HAVE_PCP */
+}
+
/*
***************************************************************************
* Display huge pages statistics in PCP format.
(struct activity *, int, unsigned long long, struct record_header *);
__print_funct_t pcp_print_pwr_temp_stats
(struct activity *, int, unsigned long long, struct record_header *);
+__print_funct_t pcp_print_pwr_in_stats
+ (struct activity *, int, unsigned long long, struct record_header *);
__print_funct_t pcp_print_huge_stats
(struct activity *, int, unsigned long long, struct record_header *);
__print_funct_t pcp_print_pwr_usb_stats
pcp_def_pwr_temp_metrics(act[p]);
break;
+ case A_PWR_IN:
+ pcp_def_pwr_in_metrics(act[p]);
+ break;
+
case A_PWR_USB:
pcp_def_pwr_usb_metrics(act[p]);
break;