Message ID | 20210906190454.114751-1-abailon@baylibre.com |
---|---|
Headers | show |
Series | Add a generic virtual thermal sensor | expand |
On Mon, Sep 6, 2021 at 9:05 PM Alexandre Bailon <abailon@baylibre.com> wrote: > > This adds the device tree bidings for the virtual thermal sensor. I'm not sure what "the virtual thermal sensor" is. I'm guessing that you mean "DT bindings for the DT-based virtual sensor driver introduced by a subsequent patch" or something like this. I also guess that the purpose is to allow the platform designer to tell the kernel that some sensors need to be aggregated in order to get useful information from them and how to aggregate them. Otherwise it would be hard to say why the aggregation needed to take place in the kernel. Moreover, the aggregation functions supported by this series are somewhat simple and I'm not sure if they are really sufficient in practice. > The virtual sensor could be used to a temperature computed from > many thermal sensors. > > Signed-off-by: Alexandre Bailon <abailon@baylibre.com> Admittedly, I'm not a DT bindings expert, so if I say something blatantly silly below, sorry about that. > --- > .../thermal/virtual,thermal-sensor.yaml | 67 +++++++++++++++++++ > include/dt-bindings/thermal/virtual-sensor.h | 15 +++++ > 2 files changed, 82 insertions(+) > create mode 100644 Documentation/devicetree/bindings/thermal/virtual,thermal-sensor.yaml > create mode 100644 include/dt-bindings/thermal/virtual-sensor.h > > diff --git a/Documentation/devicetree/bindings/thermal/virtual,thermal-sensor.yaml b/Documentation/devicetree/bindings/thermal/virtual,thermal-sensor.yaml > new file mode 100644 > index 0000000000000..848b5912c79f1 > --- /dev/null > +++ b/Documentation/devicetree/bindings/thermal/virtual,thermal-sensor.yaml > @@ -0,0 +1,67 @@ > +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) > +# Copyright 2021 BayLibre > +%YAML 1.2 > +--- > +$id: http://devicetree.org/schemas/thermal/thermal-sensor.yaml# > +$schema: http://devicetree.org/meta-schemas/core.yaml# > + > +title: Virtual thermal sensor binding > + > +description: | > + The virtual thermal sensor devices provide temperature sensing capabilities > + based on hardware thermal sensors. Basically, this could be used to get the > + maximum, minimum or average temperature of the hardware thermal sensors. > +properties: > + "#thermal-sensor-cells": It isn't clear to me why this is needed. If the "thermal-sensors" property is required anyway, I'm not sure why it's still necessary to have another one to find out whether there is just one sensor or more of them. > + description: > + Used to uniquely identify a thermal sensor instance within an IC. Will be > + 0 on sensor nodes with only a single sensor and at least 1 on nodes > + containing several internal sensors. > + enum: [0, 1] > + > + type: > + $ref: /schemas/types.yaml#/definitions/uint32 > + description: > + Used to select the operations to perform on the sensors to get the virtual > + sensor temperature. > + enum: > + - VIRTUAL_SENSOR_MIN > + - VIRTUAL_SENSOR_MAX > + - VIRTUAL_SENSOR_AVG > + > + thermal-sensors: > + $ref: /schemas/types.yaml#/definitions/phandle-array > + description: > + The thermal sensor phandle and sensor specifier used to monitor this > + thermal zone. > + > +required: > + - "#thermal-sensor-cells" > + - type > + - thermal-sensors > + > +additionalProperties: true > + > +examples: > + - | > + #include <dt-bindings/thermal/thermal.h> > + #include <dt-bindings/thermal/virtual-sensor.h> > + #include <dt-bindings/interrupt-controller/arm-gic.h> > + #include <dt-bindings/clock/mt8192-clk.h> > + > + lvts: lvts@1100b000 { > + compatible = "mediatek,mt6873-lvts"; > + reg = <0x1100b000 0x1000>; > + clocks = <&infracfg CLK_INFRA_THERM>; > + clock-names = "lvts_clk"; > + #thermal-sensor-cells = <0>; > + interrupts = <GIC_SPI 147 IRQ_TYPE_LEVEL_HIGH>; > + }; > + > + soc_max_sensor: soc_max_sensor { > + compatible = "virtual,thermal-sensor"; Where/how is the above defined? > + #thermal-sensor-cells = <1>; > + type = <VIRTUAL_SENSOR_MAX>; > + thermal-sensors = <&lvts 0>, <&lvts 1>; > + }; > +... > diff --git a/include/dt-bindings/thermal/virtual-sensor.h b/include/dt-bindings/thermal/virtual-sensor.h > new file mode 100644 > index 0000000000000..b3e4032f6f62b > --- /dev/null > +++ b/include/dt-bindings/thermal/virtual-sensor.h > @@ -0,0 +1,15 @@ > +/* SPDX-License-Identifier: GPL-2.0-only */ > +/* > + * This header provides constants for virtual thermal sensor bindings. > + * > + * Copyright (C) 2021 BayLibre > + */ > + > +#ifndef _DT_BINDINGS_THERMAL_VIRTUAL_SENSOR_H > +#define _DT_BINDINGS_THERMAL_VIRTUAL_SENSOR_H > + It would be better to use an enum type here. > +#define VIRTUAL_SENSOR_MIN 0 > +#define VIRTUAL_SENSOR_MAX 1 > +#define VIRTUAL_SENSOR_AVG 2 Also note that the _MIN and _MAX symbols may be confused as limits, so it may be better to call them _MIN_VAL and _MAX_VAL, respectively. > + > +#endif /* _DT_BINDINGS_THERMAL_VIRTUAL_SENSOR_H */ > --