Re: [PATCH 1/2] dt-bindings: Add bindings for the virtual thermal sensor
From: Rafael J. Wysocki
Date: Thu Oct 07 2021 - 11:56:21 EST
On Mon, Sep 6, 2021 at 9:05 PM Alexandre Bailon <abailon@xxxxxxxxxxxx> 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@xxxxxxxxxxxx>
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 */
> --