mbox series

[0/2] Add a generic virtual thermal sensor

Message ID 20210906190454.114751-1-abailon@baylibre.com
Headers show
Series Add a generic virtual thermal sensor | expand

Message

Alexandre Bailon Sept. 6, 2021, 7:04 p.m. UTC
This series add a virtual thermal sensor.
It could be used to get a temperature using some thermal sensors.
Currently, the supported operations are max, min and avg.
The virtual sensor could be easily extended to support others operations.

Note:
Currently, thermal drivers must explicitly register their sensors to make them
available to the virtual sensor.
This doesn't seem a good solution to me and I think it would be preferable to
update the framework to register the list of each available sensors.

Alexandre Bailon (2):
  dt-bindings: Add bindings for the virtual thermal sensor
  thermal: add a virtual sensor to aggregate temperatures

 .../thermal/virtual,thermal-sensor.yaml       |  67 +++
 drivers/thermal/Kconfig                       |   8 +
 drivers/thermal/Makefile                      |   1 +
 drivers/thermal/virtual-sensor.h              |  51 +++
 drivers/thermal/virtual_sensor.c              | 400 ++++++++++++++++++
 include/dt-bindings/thermal/virtual-sensor.h  |  15 +
 6 files changed, 542 insertions(+)
 create mode 100644 Documentation/devicetree/bindings/thermal/virtual,thermal-sensor.yaml
 create mode 100644 drivers/thermal/virtual-sensor.h
 create mode 100644 drivers/thermal/virtual_sensor.c
 create mode 100644 include/dt-bindings/thermal/virtual-sensor.h

Comments

Rafael J. Wysocki Oct. 7, 2021, 3:56 p.m. UTC | #1
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 */

> --