From: Guenter Roeck <linux@roeck-us.net>
To: Punit Agrawal <punit.agrawal@arm.com>, linux-pm@vger.kernel.org
Cc: lm-sensors@lm-sensors.org, linux-kernel@vger.kernel.org,
devicetree@vger.kernel.org, liviu.dudau@arm.com,
Jean Delvare <jdelvare@suse.de>,
Eduardo Valentin <edubezval@gmail.com>
Subject: Re: [PATCH v2 08/10] hwmon: Support registration of thermal zones for SCP temperature sensors
Date: Tue, 04 Aug 2015 14:39:17 -0700 [thread overview]
Message-ID: <55C13105.9070509@roeck-us.net> (raw)
In-Reply-To: <1438615378-14241-9-git-send-email-punit.agrawal@arm.com>
On 08/03/2015 08:22 AM, Punit Agrawal wrote:
> Add support to create thermal zones based on the temperature sensors
> provided by the SCP. The thermal zones can be defined using the
> thermal DT bindings and should refer to the SCP sensor id to select
> the sensor.
>
> Signed-off-by: Punit Agrawal <punit.agrawal@arm.com>
> Cc: Jean Delvare <jdelvare@suse.de>
> Cc: Guenter Roeck <linux@roeck-us.net>
> Cc: Eduardo Valentin <edubezval@gmail.com>
Hi,
assuming you fix up the nitpicks below,
Acked-by: Guenter Roeck <linux@roeck-us.net>
> ---
> drivers/hwmon/scpi-hwmon.c | 103 ++++++++++++++++++++++++++++++++++++++++++++-
> 1 file changed, 102 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/hwmon/scpi-hwmon.c b/drivers/hwmon/scpi-hwmon.c
> index 7e7e06b..d96a3e5 100644
> --- a/drivers/hwmon/scpi-hwmon.c
> +++ b/drivers/hwmon/scpi-hwmon.c
> @@ -20,6 +20,7 @@
> #include <linux/scpi_protocol.h>
> #include <linux/slab.h>
> #include <linux/sysfs.h>
> +#include <linux/thermal.h>
>
> struct sensor_data {
> struct scpi_sensor_info info;
> @@ -29,14 +30,39 @@ struct sensor_data {
> char label[20];
> };
>
> +struct scpi_thermal_zone {
> + struct list_head list;
> + int sensor_id;
> + struct scpi_sensors *scpi_sensors;
> + struct thermal_zone_device *tzd;
> +};
> +
> struct scpi_sensors {
> struct scpi_ops *scpi_ops;
> struct sensor_data *data;
> + struct list_head thermal_zones;
> struct attribute **attrs;
> struct attribute_group group;
> const struct attribute_group *groups[2];
> };
>
> +static int scpi_read_temp(void *dev, long *temp)
> +{
> + struct scpi_thermal_zone *zone = dev;
> + struct scpi_sensors *scpi_sensors = zone->scpi_sensors;
> + struct scpi_ops *scpi_ops = scpi_sensors->scpi_ops;
> + struct sensor_data *sensor = &scpi_sensors->data[zone->sensor_id];
> + u32 value;
> + int ret;
> +
> + ret = scpi_ops->sensor_get_value(sensor->info.sensor_id, &value);
> + if (ret)
> + return ret;
> +
> + *temp = value;
> + return 0;
> +}
> +
> /* hwmon callback functions */
> static ssize_t
> scpi_show_sensor(struct device *dev, struct device_attribute *attr, char *buf)
> @@ -66,6 +92,24 @@ scpi_show_label(struct device *dev, struct device_attribute *attr, char *buf)
> return sprintf(buf, "%s\n", sensor->info.name);
> }
>
> +static void
> +unregister_thermal_zones(struct platform_device *pdev,
> + struct scpi_sensors *scpi_sensors)
> +{
> + struct list_head *pos;
> +
> + list_for_each(pos, &scpi_sensors->thermal_zones) {
> + struct scpi_thermal_zone *zone;
> +
> + zone = list_entry(pos, struct scpi_thermal_zone, list);
> + thermal_zone_of_sensor_unregister(&pdev->dev, zone->tzd);
> + }
> +}
> +
> +static struct thermal_zone_of_device_ops scpi_sensor_ops = {
> + .get_temp = scpi_read_temp,
> +};
> +
> static int scpi_hwmon_probe(struct platform_device *pdev)
> {
> u16 nr_sensors, i;
> @@ -157,10 +201,66 @@ static int scpi_hwmon_probe(struct platform_device *pdev)
> scpi_sensors->group.attrs = scpi_sensors->attrs;
> scpi_sensors->groups[0] = &scpi_sensors->group;
>
> + platform_set_drvdata(pdev, scpi_sensors);
> +
> hwdev = devm_hwmon_device_register_with_groups(dev,
> "scpi_sensors", scpi_sensors, scpi_sensors->groups);
>
> - return PTR_ERR_OR_ZERO(hwdev);
> + if (IS_ERR(hwdev))
> + return PTR_ERR(hwdev);
> +
> + /*
> + * Register the temperature sensors with the thermal framework
> + * to allow their usage in setting up the thermal zones from
> + * device tree.
> + *
> + * NOTE: Not all temperature sensors maybe used for thermal
> + * control
> + */
> + INIT_LIST_HEAD(&scpi_sensors->thermal_zones);
> + for (i = 0; i < nr_sensors; i++) {
> + struct sensor_data *sensor = &scpi_sensors->data[i];
> + struct scpi_thermal_zone *zone;
> +
> + if (sensor->info.class != TEMPERATURE)
> + continue;
> +
> + zone = devm_kzalloc(&pdev->dev, sizeof(*zone), GFP_KERNEL);
devm_kzalloc(dev, ...);
for consistency.
> + if (!zone) {
> + ret = -ENOMEM;
> + goto unregister_tzd;
> + }
> +
> + zone->sensor_id = i;
> + zone->scpi_sensors = scpi_sensors;
> + zone->tzd = thermal_zone_of_sensor_register(dev, i, zone,
> + &scpi_sensor_ops);
> + /*
> + * The call to thermal_zone_of_sensor_register returns
> + * an error for sensors that are not associated with
> + * any thermal zones.
... or if the thermal subsystem is not configured.
> + */
> + if (IS_ERR(zone->tzd)) {
> + devm_kfree(dev, zone);
> + continue;
> + }
> + list_add(&zone->list, &scpi_sensors->thermal_zones);
> + }
> +
> + return 0;
> +
> +unregister_tzd:
> + unregister_thermal_zones(pdev, scpi_sensors);
> + return ret;
> +}
> +
> +static int scpi_hwmon_remove(struct platform_device *pdev)
> +{
> + struct scpi_sensors *scpi_sensors = platform_get_drvdata(pdev);
> +
> + unregister_thermal_zones(pdev, scpi_sensors);
> +
> + return 0;
> }
>
> static const struct of_device_id scpi_of_match[] = {
> @@ -175,6 +275,7 @@ static struct platform_driver scpi_hwmon_platdrv = {
> .of_match_table = scpi_of_match,
> },
> .probe = scpi_hwmon_probe,
> + .remove = scpi_hwmon_remove,
> };
> module_platform_driver(scpi_hwmon_platdrv);
>
>
WARNING: multiple messages have this Message-ID (diff)
From: Guenter Roeck <linux@roeck-us.net>
To: Punit Agrawal <punit.agrawal@arm.com>, linux-pm@vger.kernel.org
Cc: lm-sensors@lm-sensors.org, linux-kernel@vger.kernel.org,
devicetree@vger.kernel.org, liviu.dudau@arm.com,
Jean Delvare <jdelvare@suse.de>,
Eduardo Valentin <edubezval@gmail.com>
Subject: Re: [lm-sensors] [PATCH v2 08/10] hwmon: Support registration of thermal zones for SCP temperature s
Date: Tue, 04 Aug 2015 21:39:17 +0000 [thread overview]
Message-ID: <55C13105.9070509@roeck-us.net> (raw)
In-Reply-To: <1438615378-14241-9-git-send-email-punit.agrawal@arm.com>
On 08/03/2015 08:22 AM, Punit Agrawal wrote:
> Add support to create thermal zones based on the temperature sensors
> provided by the SCP. The thermal zones can be defined using the
> thermal DT bindings and should refer to the SCP sensor id to select
> the sensor.
>
> Signed-off-by: Punit Agrawal <punit.agrawal@arm.com>
> Cc: Jean Delvare <jdelvare@suse.de>
> Cc: Guenter Roeck <linux@roeck-us.net>
> Cc: Eduardo Valentin <edubezval@gmail.com>
Hi,
assuming you fix up the nitpicks below,
Acked-by: Guenter Roeck <linux@roeck-us.net>
> ---
> drivers/hwmon/scpi-hwmon.c | 103 ++++++++++++++++++++++++++++++++++++++++++++-
> 1 file changed, 102 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/hwmon/scpi-hwmon.c b/drivers/hwmon/scpi-hwmon.c
> index 7e7e06b..d96a3e5 100644
> --- a/drivers/hwmon/scpi-hwmon.c
> +++ b/drivers/hwmon/scpi-hwmon.c
> @@ -20,6 +20,7 @@
> #include <linux/scpi_protocol.h>
> #include <linux/slab.h>
> #include <linux/sysfs.h>
> +#include <linux/thermal.h>
>
> struct sensor_data {
> struct scpi_sensor_info info;
> @@ -29,14 +30,39 @@ struct sensor_data {
> char label[20];
> };
>
> +struct scpi_thermal_zone {
> + struct list_head list;
> + int sensor_id;
> + struct scpi_sensors *scpi_sensors;
> + struct thermal_zone_device *tzd;
> +};
> +
> struct scpi_sensors {
> struct scpi_ops *scpi_ops;
> struct sensor_data *data;
> + struct list_head thermal_zones;
> struct attribute **attrs;
> struct attribute_group group;
> const struct attribute_group *groups[2];
> };
>
> +static int scpi_read_temp(void *dev, long *temp)
> +{
> + struct scpi_thermal_zone *zone = dev;
> + struct scpi_sensors *scpi_sensors = zone->scpi_sensors;
> + struct scpi_ops *scpi_ops = scpi_sensors->scpi_ops;
> + struct sensor_data *sensor = &scpi_sensors->data[zone->sensor_id];
> + u32 value;
> + int ret;
> +
> + ret = scpi_ops->sensor_get_value(sensor->info.sensor_id, &value);
> + if (ret)
> + return ret;
> +
> + *temp = value;
> + return 0;
> +}
> +
> /* hwmon callback functions */
> static ssize_t
> scpi_show_sensor(struct device *dev, struct device_attribute *attr, char *buf)
> @@ -66,6 +92,24 @@ scpi_show_label(struct device *dev, struct device_attribute *attr, char *buf)
> return sprintf(buf, "%s\n", sensor->info.name);
> }
>
> +static void
> +unregister_thermal_zones(struct platform_device *pdev,
> + struct scpi_sensors *scpi_sensors)
> +{
> + struct list_head *pos;
> +
> + list_for_each(pos, &scpi_sensors->thermal_zones) {
> + struct scpi_thermal_zone *zone;
> +
> + zone = list_entry(pos, struct scpi_thermal_zone, list);
> + thermal_zone_of_sensor_unregister(&pdev->dev, zone->tzd);
> + }
> +}
> +
> +static struct thermal_zone_of_device_ops scpi_sensor_ops = {
> + .get_temp = scpi_read_temp,
> +};
> +
> static int scpi_hwmon_probe(struct platform_device *pdev)
> {
> u16 nr_sensors, i;
> @@ -157,10 +201,66 @@ static int scpi_hwmon_probe(struct platform_device *pdev)
> scpi_sensors->group.attrs = scpi_sensors->attrs;
> scpi_sensors->groups[0] = &scpi_sensors->group;
>
> + platform_set_drvdata(pdev, scpi_sensors);
> +
> hwdev = devm_hwmon_device_register_with_groups(dev,
> "scpi_sensors", scpi_sensors, scpi_sensors->groups);
>
> - return PTR_ERR_OR_ZERO(hwdev);
> + if (IS_ERR(hwdev))
> + return PTR_ERR(hwdev);
> +
> + /*
> + * Register the temperature sensors with the thermal framework
> + * to allow their usage in setting up the thermal zones from
> + * device tree.
> + *
> + * NOTE: Not all temperature sensors maybe used for thermal
> + * control
> + */
> + INIT_LIST_HEAD(&scpi_sensors->thermal_zones);
> + for (i = 0; i < nr_sensors; i++) {
> + struct sensor_data *sensor = &scpi_sensors->data[i];
> + struct scpi_thermal_zone *zone;
> +
> + if (sensor->info.class != TEMPERATURE)
> + continue;
> +
> + zone = devm_kzalloc(&pdev->dev, sizeof(*zone), GFP_KERNEL);
devm_kzalloc(dev, ...);
for consistency.
> + if (!zone) {
> + ret = -ENOMEM;
> + goto unregister_tzd;
> + }
> +
> + zone->sensor_id = i;
> + zone->scpi_sensors = scpi_sensors;
> + zone->tzd = thermal_zone_of_sensor_register(dev, i, zone,
> + &scpi_sensor_ops);
> + /*
> + * The call to thermal_zone_of_sensor_register returns
> + * an error for sensors that are not associated with
> + * any thermal zones.
... or if the thermal subsystem is not configured.
> + */
> + if (IS_ERR(zone->tzd)) {
> + devm_kfree(dev, zone);
> + continue;
> + }
> + list_add(&zone->list, &scpi_sensors->thermal_zones);
> + }
> +
> + return 0;
> +
> +unregister_tzd:
> + unregister_thermal_zones(pdev, scpi_sensors);
> + return ret;
> +}
> +
> +static int scpi_hwmon_remove(struct platform_device *pdev)
> +{
> + struct scpi_sensors *scpi_sensors = platform_get_drvdata(pdev);
> +
> + unregister_thermal_zones(pdev, scpi_sensors);
> +
> + return 0;
> }
>
> static const struct of_device_id scpi_of_match[] = {
> @@ -175,6 +275,7 @@ static struct platform_driver scpi_hwmon_platdrv = {
> .of_match_table = scpi_of_match,
> },
> .probe = scpi_hwmon_probe,
> + .remove = scpi_hwmon_remove,
> };
> module_platform_driver(scpi_hwmon_platdrv);
>
>
_______________________________________________
lm-sensors mailing list
lm-sensors@lm-sensors.org
http://lists.lm-sensors.org/mailman/listinfo/lm-sensors
next prev parent reply other threads:[~2015-08-04 21:39 UTC|newest]
Thread overview: 55+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-08-03 15:22 [PATCH v2 00/10] Platform support for thermal management on Juno Punit Agrawal
2015-08-03 15:22 ` [lm-sensors] " Punit Agrawal
[not found] ` <1438615378-14241-1-git-send-email-punit.agrawal-5wv7dgnIgG8@public.gmane.org>
2015-08-03 15:22 ` [PATCH v2 01/10] devicetree: bindings: Add optional dynamic-power-coefficient property Punit Agrawal
2015-08-03 15:22 ` Punit Agrawal
2015-08-03 15:22 ` [lm-sensors] " Punit Agrawal
2015-08-03 15:22 ` [PATCH v2 08/10] hwmon: Support registration of thermal zones for SCP temperature sensors Punit Agrawal
2015-08-03 15:22 ` Punit Agrawal
2015-08-03 15:22 ` [lm-sensors] [PATCH v2 08/10] hwmon: Support registration of thermal zones for SCP temperature senso Punit Agrawal
2015-08-04 21:39 ` Guenter Roeck [this message]
2015-08-04 21:39 ` [lm-sensors] [PATCH v2 08/10] hwmon: Support registration of thermal zones for SCP temperature s Guenter Roeck
[not found] ` <55C13105.9070509-0h96xk9xTtrk1uMJSBkQmQ@public.gmane.org>
2015-08-05 10:17 ` [PATCH v2 08/10] hwmon: Support registration of thermal zones for SCP temperature sensors Punit Agrawal
2015-08-05 10:17 ` Punit Agrawal
2015-08-05 10:17 ` [lm-sensors] [PATCH v2 08/10] hwmon: Support registration of thermal zones for SCP temperature s Punit Agrawal
2015-08-03 15:22 ` [PATCH v2 02/10] cpufreq-dt: Supply power coefficient when registering cooling devices Punit Agrawal
2015-08-03 15:22 ` [lm-sensors] " Punit Agrawal
2015-08-03 15:22 ` [PATCH v2 03/10] cpufreq: arm_big_little: Add support to register a cpufreq cooling device Punit Agrawal
2015-08-03 15:22 ` Punit Agrawal
2015-08-03 15:22 ` [lm-sensors] [PATCH v2 03/10] cpufreq: arm_big_little: Add support to register a cpufreq cooling dev Punit Agrawal
2015-08-03 15:22 ` [PATCH v2 04/10] thermal: Fix thermal_zone_of_sensor_register to match documentation Punit Agrawal
2015-08-03 15:22 ` [lm-sensors] " Punit Agrawal
[not found] ` <1438615378-14241-5-git-send-email-punit.agrawal-5wv7dgnIgG8@public.gmane.org>
2015-08-03 15:56 ` Guenter Roeck
2015-08-03 15:56 ` Guenter Roeck
2015-08-03 15:56 ` [lm-sensors] [PATCH v2 04/10] thermal: Fix thermal_zone_of_sensor_register to match documentatio Guenter Roeck
2015-08-04 11:00 ` [PATCH v2 04/10] thermal: Fix thermal_zone_of_sensor_register to match documentation Punit Agrawal
2015-08-04 11:00 ` [lm-sensors] [PATCH v2 04/10] thermal: Fix thermal_zone_of_sensor_register to match documentatio Punit Agrawal
2015-08-05 9:57 ` [PATCH v3] thermal: Fix thermal_zone_of_sensor_register to match documentation Punit Agrawal
2015-08-05 14:51 ` Guenter Roeck
2015-08-03 15:22 ` [PATCH v2 05/10] Documentation: add DT bindings for ARM SCPI sensors Punit Agrawal
2015-08-03 15:22 ` [lm-sensors] " Punit Agrawal
2015-09-03 15:08 ` Punit Agrawal
2015-09-03 15:08 ` [lm-sensors] " Punit Agrawal
2015-08-03 15:22 ` [PATCH v2 06/10] firmware: arm_scpi: Extend to support sensors Punit Agrawal
2015-08-03 15:22 ` [lm-sensors] " Punit Agrawal
2015-08-03 15:22 ` [PATCH v2 07/10] hwmon: Support sensors exported via ARM SCP interface Punit Agrawal
2015-08-03 15:22 ` [lm-sensors] " Punit Agrawal
2015-08-04 21:32 ` Guenter Roeck
2015-08-04 21:32 ` [lm-sensors] " Guenter Roeck
2015-08-05 10:17 ` Punit Agrawal
2015-08-05 10:17 ` [lm-sensors] " Punit Agrawal
2015-08-03 15:22 ` [PATCH v2 09/10] arm64: dts: Add sensor node to Juno dt Punit Agrawal
2015-08-03 15:22 ` [lm-sensors] " Punit Agrawal
2015-08-03 15:22 ` [PATCH v2 10/10] arm64: dts: Create SoC thermal zone for Juno Punit Agrawal
2015-08-03 15:22 ` [lm-sensors] " Punit Agrawal
[not found] ` <1438615378-14241-11-git-send-email-punit.agrawal-5wv7dgnIgG8@public.gmane.org>
2015-08-12 15:55 ` Liviu Dudau
2015-08-12 15:55 ` Liviu Dudau
2015-08-12 15:55 ` [lm-sensors] " Liviu Dudau
2015-08-13 14:28 ` Punit Agrawal
2015-08-13 14:28 ` Punit Agrawal
2015-08-13 14:28 ` [lm-sensors] " Punit Agrawal
2015-08-14 12:38 ` Punit Agrawal
2015-08-14 12:38 ` Punit Agrawal
2015-08-14 12:38 ` [lm-sensors] " Punit Agrawal
[not found] ` <9hhsi7mgi44.fsf-Z9gB6HwUD+TZROr8t4l/smS4ubULX0JqMm0uRHvK7Nw@public.gmane.org>
2015-08-14 12:44 ` Punit Agrawal
2015-08-14 12:44 ` Punit Agrawal
2015-08-14 12:44 ` [lm-sensors] " Punit Agrawal
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=55C13105.9070509@roeck-us.net \
--to=linux@roeck-us.net \
--cc=devicetree@vger.kernel.org \
--cc=edubezval@gmail.com \
--cc=jdelvare@suse.de \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pm@vger.kernel.org \
--cc=liviu.dudau@arm.com \
--cc=lm-sensors@lm-sensors.org \
--cc=punit.agrawal@arm.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.