Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.sbin/envstat Allow to select raw output for a single dev...
details: https://anonhg.NetBSD.org/src/rev/30a30b0bd100
branches: trunk
changeset: 978229:30a30b0bd100
user: mlelstv <mlelstv%NetBSD.org@localhost>
date: Sat Nov 14 12:36:49 2020 +0000
description:
Allow to select raw output for a single device or a list of sensors.
diffstat:
usr.sbin/envstat/envstat.8 | 28 +++++++-
usr.sbin/envstat/envstat.c | 153 +++++++++++++++++++++++++++++++++++++++++++-
2 files changed, 174 insertions(+), 7 deletions(-)
diffs (261 lines):
diff -r 5a775a4d28a6 -r 30a30b0bd100 usr.sbin/envstat/envstat.8
--- a/usr.sbin/envstat/envstat.8 Sat Nov 14 11:51:58 2020 +0000
+++ b/usr.sbin/envstat/envstat.8 Sat Nov 14 12:36:49 2020 +0000
@@ -1,4 +1,4 @@
-.\" $NetBSD: envstat.8,v 1.63 2020/11/14 09:11:55 mlelstv Exp $
+.\" $NetBSD: envstat.8,v 1.64 2020/11/14 12:36:49 mlelstv Exp $
.\"
.\" Copyright (c) 2000, 2007, 2008, 2009, 2014 The NetBSD Foundation, Inc.
.\" All rights reserved.
@@ -35,12 +35,16 @@
.Nd utility to handle environmental sensors
.Sh SYNOPSIS
.Nm
-.Op Fl DfIklSTWx
+.Op Fl DfIklSTW
.Op Fl c Ar file
.Op Fl d Ar device
.Op Fl i Ar interval
.Op Fl s Ar "device:sensor,..."
.Op Fl w Ar width
+.Nm
+.Fl x
+.Op Fl d Ar device
+.Op Fl s Ar "device:sensor,..."
.Op Ar property...
.Sh DESCRIPTION
.Nm
@@ -143,6 +147,12 @@
If
.Ar property
is specified, the value of that property is printed.
+The property list can be filtered with the
+.Fl d or
+.Fl s
+options. If
+.Fl s is used with only a single sensor, only the properties
+of this sensor are returned, not a list of sensors.
.El
.Sh UNITS
The display mode may show some values with abbreviated units;
@@ -205,10 +215,22 @@
invalid states every second:
.Pp
.Dl $ envstat -ITi1
+.Pp
+To return a single temperature value:
+.Pp
+.Dl $ envstat -s vcmbox0:temperature -x /cur-value
+.Pp
+To return values of multiple temperature sensors from a single device
+.Pp
+.Dl $ envstat -s 'thinkpad0:temperature 0,thinkpad0:temperature 1' -x /thinkpad0/0/cur-value /thinkpad0/1/cur-value
+.Pp
+To return values of temperature sensors from multiple devices:
+.Pp
+.Dl $ envstat -s 'coretemp0:cpu0 temperature,coretemp1:cpu 2 temperature' -x /coretemp0/0/cur-value /coretemp1/0/cur-value
.Sh SEE ALSO
.Xr units 1 ,
.Xr proplib 3 ,
-.Xr acpiacad 4 ,
+.r acpiacad 4 ,
.Xr acpibat 4 ,
.Xr acpitz 4 ,
.Xr admtemp 4 ,
diff -r 5a775a4d28a6 -r 30a30b0bd100 usr.sbin/envstat/envstat.c
--- a/usr.sbin/envstat/envstat.c Sat Nov 14 11:51:58 2020 +0000
+++ b/usr.sbin/envstat/envstat.c Sat Nov 14 12:36:49 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: envstat.c,v 1.98 2020/11/14 09:11:55 mlelstv Exp $ */
+/* $NetBSD: envstat.c,v 1.99 2020/11/14 12:36:49 mlelstv Exp $ */
/*-
* Copyright (c) 2007, 2008 Juan Romero Pardines.
@@ -27,7 +27,7 @@
#include <sys/cdefs.h>
#ifndef lint
-__RCSID("$NetBSD: envstat.c,v 1.98 2020/11/14 09:11:55 mlelstv Exp $");
+__RCSID("$NetBSD: envstat.c,v 1.99 2020/11/14 12:36:49 mlelstv Exp $");
#endif /* not lint */
#include <stdio.h>
@@ -109,6 +109,7 @@
static u_int header_passes;
static int parse_dictionary(int);
+static int add_sensors(prop_dictionary_t, prop_dictionary_t, const char *, const char *);
static int send_dictionary(FILE *);
static int find_sensors(prop_array_t, const char *, dvprops_t);
static void print_sensors(void);
@@ -219,6 +220,61 @@
if (rval)
errx(EXIT_FAILURE, "%s", strerror(rval));
+ if (mydevname || sensors) {
+ prop_dictionary_t ndict;
+
+ ndict = prop_dictionary_create();
+ if (ndict == NULL)
+ err(EXIT_FAILURE, "prop_dictionary_create");
+
+ if (mydevname) {
+ if (add_sensors(ndict, dict, mydevname, NULL))
+ err(EXIT_FAILURE, "add_sensors");
+ }
+ if (sensors) {
+ char *dvstring, *sstring, *p, *last, *s;
+ unsigned count = 0;
+
+ s = strdup(sensors);
+ if (s == NULL)
+ err(EXIT_FAILURE, "strdup");
+
+ for ((p = strtok_r(s, ",", &last)); p;
+ (p = strtok_r(NULL, ",", &last))) {
+ /* get device name */
+ dvstring = strtok(p, ":");
+ if (dvstring == NULL)
+ errx(EXIT_FAILURE, "missing device name");
+
+ /* get sensor description */
+ sstring = strtok(NULL, ":");
+ if (sstring == NULL)
+ errx(EXIT_FAILURE, "missing sensor description");
+
+ if (add_sensors(ndict, dict, dvstring, sstring))
+ err(EXIT_FAILURE, "add_sensors");
+
+ ++count;
+ }
+ free(s);
+
+ /* in case we asked for a single sensor
+ * show only the sensor dictionary
+ */
+ if (count == 1) {
+ prop_object_t obj, obj2;
+
+ obj = prop_dictionary_get(ndict, dvstring);
+ obj2 = prop_array_get(obj, 0);
+ prop_object_release(ndict);
+ ndict = obj2;
+ }
+ }
+
+ prop_object_release(dict);
+ dict = ndict;
+ }
+
if (argc > 0) {
for (; argc > 0; ++argv, --argc)
config_dict_extract(dict, *argv, true);
@@ -350,6 +406,92 @@
}
static int
+add_sensors(prop_dictionary_t ndict, prop_dictionary_t dict, const char *dev, const char *sensor)
+{
+ prop_object_iterator_t iter, iter2;
+ prop_object_t obj, obj2, desc;
+ prop_array_t array, narray;
+ prop_dictionary_t sdict;
+ const char *dnp;
+ unsigned int capacity = 1;
+ uint64_t dummy;
+ bool found = false;
+
+ if (prop_dictionary_count(dict) == 0)
+ return 0;
+
+ narray = prop_dictionary_get(ndict, dev);
+ if (narray)
+ found = true;
+ else {
+ narray = prop_array_create_with_capacity(capacity);
+ if (!narray)
+ return -1;
+ if (!prop_dictionary_set(ndict, dev, narray)) {
+ prop_object_release(narray);
+ return -1;
+ }
+ }
+
+ iter = prop_dictionary_iterator(dict);
+ if (iter == NULL)
+ goto fail;
+ while ((obj = prop_object_iterator_next(iter)) != NULL) {
+ array = prop_dictionary_get_keysym(dict, obj);
+ if (prop_object_type(array) != PROP_TYPE_ARRAY)
+ break;
+
+ dnp = prop_dictionary_keysym_value(obj);
+ if (strcmp(dev, dnp))
+ continue;
+ found = true;
+
+ iter2 = prop_array_iterator(array);
+ while ((obj = prop_object_iterator_next(iter2)) != NULL) {
+ obj2 = prop_dictionary_get(obj, "device-properties");
+ if (obj2) {
+ if (!prop_dictionary_get_uint64(obj2,
+ "refresh-timeout", &dummy))
+ continue;
+ }
+
+ if (sensor) {
+ desc = prop_dictionary_get(obj, "description");
+ if (desc == NULL)
+ continue;
+
+ if (!prop_string_equals_string(desc, sensor))
+ continue;
+ }
+
+ if (!prop_array_ensure_capacity(narray, capacity))
+ goto fail;
+
+ sdict = prop_dictionary_copy(obj);
+ if (sdict == NULL)
+ goto fail;
+ prop_array_add(narray, sdict);
+ ++capacity;
+ }
+ prop_object_iterator_release(iter2);
+ }
+ prop_object_iterator_release(iter);
+
+ /* drop key and array when device wasn't found */
+ if (!found) {
+ prop_dictionary_remove(ndict, dev);
+ prop_object_release(narray);
+ }
+
+ return 0;
+
+fail:
+ prop_dictionary_remove(ndict, dev);
+ prop_object_release(narray);
+ return -1;
+}
+
+static int
parse_dictionary(int fd)
{
sensor_t sensor = NULL;
@@ -1099,10 +1241,13 @@
static int
usage(void)
{
- (void)fprintf(stderr, "Usage: %s [-DfIklrSTx] ", getprogname());
+ (void)fprintf(stderr, "Usage: %s [-DfIklrST] ", getprogname());
(void)fprintf(stderr, "[-c file] [-d device] [-i interval] ");
(void)fprintf(stderr, "[-s device:sensor,...] [-w width]\n");
- (void)fprintf(stderr, " %s -x [property]", getprogname());
+ (void)fprintf(stderr, " %s ", getprogname());
+ (void)fprintf(stderr, "[-d device] ");
+ (void)fprintf(stderr, "[-s device:sensor,...] ");
+ (void)fprintf(stderr, "-x [property]\n");
exit(EXIT_FAILURE);
/* NOTREACHED */
}
Home |
Main Index |
Thread Index |
Old Index