Re: [PATCH] thermal: add support to disable thermal zone from DTS

From: Eduardo Valentin
Date: Tue Jul 29 2014 - 09:47:40 EST


On Fri, Jul 25, 2014 at 03:31:58PM +0530, Laxman Dewangan wrote:
> Add support to check status of the thermal zone before registering the
> zone. This will help on disabling some non-existing thermal zone from
> the top level DTS file out of common dtsi thermalzone file.
>
> For example,
> we have 3 platforms almost same but thermal zones on this platform are
> little bit different. Platform 1 and 2 have three thermal zones and
> platform 3 has two thermal zones. To avoid duplication of the thermal
> zones entries on each DTS file of platforms,we created one common
> dtsi file for thermal zone and included this dtsi file from these
> 3 platform's top level dts file.
>
> On common thermal zone com dtsi file, all thermal zone are enabled and
> need to disable one of thermal zone on platform 3 dts file. For this, we
> just added entry status = "disabled" for that thermal zone on platform 3
> dts file and along with this change to make it work.
>
> This way, we reuse the common file and control the enable/disable of the
> thermal zone from top level dts file.
>
> Signed-off-by: Laxman Dewangan <ldewangan@xxxxxxxxxx>

This patch looks sane to me.

Applied. Thanks.

> ---
> drivers/thermal/of-thermal.c | 12 ++++++++++++
> 1 file changed, 12 insertions(+)
>
> diff --git a/drivers/thermal/of-thermal.c b/drivers/thermal/of-thermal.c
> index 4b2b999..f8eb625 100644
> --- a/drivers/thermal/of-thermal.c
> +++ b/drivers/thermal/of-thermal.c
> @@ -401,6 +401,10 @@ thermal_zone_of_sensor_register(struct device *dev, int sensor_id,
> struct of_phandle_args sensor_specs;
> int ret, id;
>
> + /* Check whether child is enabled or not */
> + if (!of_device_is_available(child))
> + continue;
> +
> /* For now, thermal framework supports only 1 sensor per zone */
> ret = of_parse_phandle_with_args(child, "thermal-sensors",
> "#thermal-sensor-cells",
> @@ -771,6 +775,10 @@ int __init of_parse_thermal_zones(void)
> struct thermal_zone_device *zone;
> struct thermal_zone_params *tzp;
>
> + /* Check whether child is enabled or not */
> + if (!of_device_is_available(child))
> + continue;
> +
> tz = thermal_of_build_thermal_zone(child);
> if (IS_ERR(tz)) {
> pr_err("failed to build thermal zone %s: %ld\n",
> @@ -838,6 +846,10 @@ void of_thermal_destroy_zones(void)
> for_each_child_of_node(np, child) {
> struct thermal_zone_device *zone;
>
> + /* Check whether child is enabled or not */
> + if (!of_device_is_available(child))
> + continue;
> +
> zone = thermal_zone_get_zone_by_name(child->name);
> if (IS_ERR(zone))
> continue;
> --
> 1.8.1.5
>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/