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>,
Sudeep Holla <sudeep.holla@arm.com>
Subject: Re: [PATCH v2 07/10] hwmon: Support sensors exported via ARM SCP interface
Date: Tue, 04 Aug 2015 14:32:10 -0700 [thread overview]
Message-ID: <55C12F5A.5080705@roeck-us.net> (raw)
In-Reply-To: <1438615378-14241-8-git-send-email-punit.agrawal@arm.com>
On 08/03/2015 08:22 AM, Punit Agrawal wrote:
> Create a driver to add support for SoC sensors exported by the System
> Control Processor (SCP) via the System Control and Power Interface
> (SCPI). The supported sensor types is one of voltage, temperature,
> current, and power.
>
> The sensor labels and values provided by the SCP are exported via the
> hwmon sysfs interface.
>
> Signed-off-by: Punit Agrawal <punit.agrawal@arm.com>
> Cc: Jean Delvare <jdelvare@suse.de>
> Cc: Guenter Roeck <linux@roeck-us.net>
> Cc: Sudeep Holla <sudeep.holla@arm.com>
Looks good for the most part. Single comment below.
Assuming you fix it up, feel free to add
Acked-by: Guenter Roeck <linux@roeck-us.net>
for v3.
Thanks,
Guenter
> ---
> Documentation/hwmon/scpi-hwmon | 33 ++++++++
> drivers/hwmon/Kconfig | 8 ++
> drivers/hwmon/Makefile | 1 +
> drivers/hwmon/scpi-hwmon.c | 183 +++++++++++++++++++++++++++++++++++++++++
> 4 files changed, 225 insertions(+)
> create mode 100644 Documentation/hwmon/scpi-hwmon
> create mode 100644 drivers/hwmon/scpi-hwmon.c
>
> diff --git a/Documentation/hwmon/scpi-hwmon b/Documentation/hwmon/scpi-hwmon
> new file mode 100644
> index 0000000..4cfcdf2d
> --- /dev/null
> +++ b/Documentation/hwmon/scpi-hwmon
> @@ -0,0 +1,33 @@
> +Kernel driver scpi-hwmon
> +========================
> +
> +Supported chips:
> + * Chips based on ARM System Control Processor Interface
> + Addresses scanned: -
> + Datasheet: http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.dui0922b/index.html
> +
> +Author: Punit Agrawal <punit.agrawal@arm.com>
> +
> +Description
> +-----------
> +
> +This driver supports hardware monitoring for SoC's based on the ARM
> +System Control Processor (SCP) implementing the System Control
> +Processor Interface (SCPI). The following sensor types are supported
> +by the SCP -
> +
> + * temperature
> + * voltage
> + * current
> + * power
> +
> +The SCP interface provides an API to query the available sensors and
> +their values which are then exported to userspace by this driver.
> +
> +Usage Notes
> +-----------
> +
> +The driver relies on device tree node to indicate the presence of SCPI
> +support in the kernel. See
> +Documentation/devicetree/bindings/arm/arm,scpi.txt for details of the
> +devicetree node.
> \ No newline at end of file
> diff --git a/drivers/hwmon/Kconfig b/drivers/hwmon/Kconfig
> index 4943c3c..c9714b0 100644
> --- a/drivers/hwmon/Kconfig
> +++ b/drivers/hwmon/Kconfig
> @@ -1551,6 +1551,14 @@ config SENSORS_VEXPRESS
> the ARM Ltd's Versatile Express platform. It can provide wide
> range of information like temperature, power, energy.
>
> +config SENSORS_ARM_SCPI
> + tristate "ARM SCPI Sensors"
> + depends on ARM_SCPI_PROTOCOL
> + help
> + This driver provides support for temperature, voltage, current
> + and power sensors available on ARM Ltd's SCP based platforms. The
> + actual number and type of sensors exported depend the platform.
> +
> config SENSORS_VIA_CPUTEMP
> tristate "VIA CPU temperature sensor"
> depends on X86
> diff --git a/drivers/hwmon/Makefile b/drivers/hwmon/Makefile
> index 8aba87f..4961710 100644
> --- a/drivers/hwmon/Makefile
> +++ b/drivers/hwmon/Makefile
> @@ -150,6 +150,7 @@ obj-$(CONFIG_SENSORS_TMP421) += tmp421.o
> obj-$(CONFIG_SENSORS_TWL4030_MADC)+= twl4030-madc-hwmon.o
> obj-$(CONFIG_SENSORS_V2M_JUNO) += v2m-juno.o
> obj-$(CONFIG_SENSORS_VEXPRESS) += vexpress.o
> +obj-$(CONFIG_SENSORS_ARM_SCPI) += scpi-hwmon.o
> obj-$(CONFIG_SENSORS_VIA_CPUTEMP)+= via-cputemp.o
> obj-$(CONFIG_SENSORS_VIA686A) += via686a.o
> obj-$(CONFIG_SENSORS_VT1211) += vt1211.o
> diff --git a/drivers/hwmon/scpi-hwmon.c b/drivers/hwmon/scpi-hwmon.c
> new file mode 100644
> index 0000000..7e7e06b
> --- /dev/null
> +++ b/drivers/hwmon/scpi-hwmon.c
> @@ -0,0 +1,183 @@
> +/*
> + * System Control and Power Interface(SCPI) based hwmon sensor driver
> + *
> + * Copyright (C) 2015 ARM Ltd.
> + * Punit Agrawal <punit.agrawal@arm.com>
> + *
> + * This program is free software; you can redistribute it and/or modify
> + * it under the terms of the GNU General Public License version 2 as
> + * published by the Free Software Foundation.
> + *
> + * This program is distributed "as is" WITHOUT ANY WARRANTY of any
> + * kind, whether express or implied; without even the implied warranty
> + * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
> + * GNU General Public License for more details.
> + */
> +
> +#include <linux/hwmon.h>
> +#include <linux/module.h>
> +#include <linux/platform_device.h>
> +#include <linux/scpi_protocol.h>
> +#include <linux/slab.h>
> +#include <linux/sysfs.h>
> +
> +struct sensor_data {
> + struct scpi_sensor_info info;
> + struct device_attribute dev_attr_input;
> + struct device_attribute dev_attr_label;
> + char input[20];
> + char label[20];
> +};
> +
> +struct scpi_sensors {
> + struct scpi_ops *scpi_ops;
> + struct sensor_data *data;
> + struct attribute **attrs;
> + struct attribute_group group;
> + const struct attribute_group *groups[2];
> +};
> +
> +/* hwmon callback functions */
> +static ssize_t
> +scpi_show_sensor(struct device *dev, struct device_attribute *attr, char *buf)
> +{
> + struct scpi_sensors *scpi_sensors = dev_get_drvdata(dev);
> + struct scpi_ops *scpi_ops = scpi_sensors->scpi_ops;
> + struct sensor_data *sensor;
> + u32 value;
> + int ret;
> +
> + sensor = container_of(attr, struct sensor_data, dev_attr_input);
> +
> + ret = scpi_ops->sensor_get_value(sensor->info.sensor_id, &value);
> + if (ret)
> + return ret;
> +
> + return sprintf(buf, "%u\n", value);
> +}
> +
> +static ssize_t
> +scpi_show_label(struct device *dev, struct device_attribute *attr, char *buf)
> +{
> + struct sensor_data *sensor;
> +
> + sensor = container_of(attr, struct sensor_data, dev_attr_label);
> +
> + return sprintf(buf, "%s\n", sensor->info.name);
> +}
> +
> +static int scpi_hwmon_probe(struct platform_device *pdev)
> +{
> + u16 nr_sensors, i;
> + int num_temp = 0, num_volt = 0, num_current = 0, num_power = 0;
> + struct scpi_ops *scpi_ops;
> + struct device *hwdev, *dev = &pdev->dev;
> + struct scpi_sensors *scpi_sensors;
> + int ret;
> +
> + scpi_ops = get_scpi_ops();
> + if (!scpi_ops)
> + return -EPROBE_DEFER;
> +
> + ret = scpi_ops->sensor_get_capability(&nr_sensors);
> + if (ret || !nr_sensors)
> + return ret;
> +
This will return 0 if nr_sensors == 0. Should it be -ENODEV ?
> + scpi_sensors = devm_kzalloc(dev, sizeof(*scpi_sensors), GFP_KERNEL);
> + if (!scpi_sensors)
> + return -ENOMEM;
> +
> + scpi_sensors->data = devm_kcalloc(dev, nr_sensors,
> + sizeof(*scpi_sensors->data), GFP_KERNEL);
> + if (!scpi_sensors->data)
> + return -ENOMEM;
> +
> + scpi_sensors->attrs = devm_kcalloc(dev, (nr_sensors * 2) + 1,
> + sizeof(*scpi_sensors->attrs), GFP_KERNEL);
> + if (!scpi_sensors->attrs)
> + return -ENOMEM;
> +
> + scpi_sensors->scpi_ops = scpi_ops;
> +
> + for (i = 0; i < nr_sensors; i++) {
> + struct sensor_data *sensor = &scpi_sensors->data[i];
> +
> + ret = scpi_ops->sensor_get_info(i, &sensor->info);
> + if (ret)
> + return ret;
> +
> + switch (sensor->info.class) {
> + case TEMPERATURE:
> + snprintf(sensor->input, sizeof(sensor->input),
> + "temp%d_input", num_temp + 1);
> + snprintf(sensor->label, sizeof(sensor->input),
> + "temp%d_label", num_temp + 1);
> + num_temp++;
> + break;
> + case VOLTAGE:
> + snprintf(sensor->input, sizeof(sensor->input),
> + "in%d_input", num_volt);
> + snprintf(sensor->label, sizeof(sensor->input),
> + "in%d_label", num_volt);
> + num_volt++;
> + break;
> + case CURRENT:
> + snprintf(sensor->input, sizeof(sensor->input),
> + "curr%d_input", num_current + 1);
> + snprintf(sensor->label, sizeof(sensor->input),
> + "curr%d_label", num_current + 1);
> + num_current++;
> + break;
> + case POWER:
> + snprintf(sensor->input, sizeof(sensor->input),
> + "power%d_input", num_power + 1);
> + snprintf(sensor->label, sizeof(sensor->input),
> + "power%d_label", num_power + 1);
> + num_power++;
> + break;
> + default:
> + break;
> + }
> +
> + sensor->dev_attr_input.attr.mode = S_IRUGO;
> + sensor->dev_attr_input.show = scpi_show_sensor;
> + sensor->dev_attr_input.attr.name = sensor->input;
> +
> + sensor->dev_attr_label.attr.mode = S_IRUGO;
> + sensor->dev_attr_label.show = scpi_show_label;
> + sensor->dev_attr_label.attr.name = sensor->label;
> +
> + scpi_sensors->attrs[i << 1] = &sensor->dev_attr_input.attr;
> + scpi_sensors->attrs[(i << 1) + 1] = &sensor->dev_attr_label.attr;
> +
> + sysfs_attr_init(scpi_sensors->attrs[i << 1]);
> + sysfs_attr_init(scpi_sensors->attrs[(i << 1) + 1]);
> + }
> +
> + scpi_sensors->group.attrs = scpi_sensors->attrs;
> + scpi_sensors->groups[0] = &scpi_sensors->group;
> +
> + hwdev = devm_hwmon_device_register_with_groups(dev,
> + "scpi_sensors", scpi_sensors, scpi_sensors->groups);
> +
> + return PTR_ERR_OR_ZERO(hwdev);
> +}
> +
> +static const struct of_device_id scpi_of_match[] = {
> + {.compatible = "arm,scpi-sensors"},
> + {},
> +};
> +
> +static struct platform_driver scpi_hwmon_platdrv = {
> + .driver = {
> + .name = "scpi-hwmon",
> + .owner = THIS_MODULE,
> + .of_match_table = scpi_of_match,
> + },
> + .probe = scpi_hwmon_probe,
> +};
> +module_platform_driver(scpi_hwmon_platdrv);
> +
> +MODULE_AUTHOR("Punit Agrawal <punit.agrawal@arm.com>");
> +MODULE_DESCRIPTION("ARM SCPI HWMON interface driver");
> +MODULE_LICENSE("GPL v2");
>
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>,
Sudeep Holla <sudeep.holla@arm.com>
Subject: Re: [lm-sensors] [PATCH v2 07/10] hwmon: Support sensors exported via ARM SCP interface
Date: Tue, 04 Aug 2015 21:32:10 +0000 [thread overview]
Message-ID: <55C12F5A.5080705@roeck-us.net> (raw)
In-Reply-To: <1438615378-14241-8-git-send-email-punit.agrawal@arm.com>
On 08/03/2015 08:22 AM, Punit Agrawal wrote:
> Create a driver to add support for SoC sensors exported by the System
> Control Processor (SCP) via the System Control and Power Interface
> (SCPI). The supported sensor types is one of voltage, temperature,
> current, and power.
>
> The sensor labels and values provided by the SCP are exported via the
> hwmon sysfs interface.
>
> Signed-off-by: Punit Agrawal <punit.agrawal@arm.com>
> Cc: Jean Delvare <jdelvare@suse.de>
> Cc: Guenter Roeck <linux@roeck-us.net>
> Cc: Sudeep Holla <sudeep.holla@arm.com>
Looks good for the most part. Single comment below.
Assuming you fix it up, feel free to add
Acked-by: Guenter Roeck <linux@roeck-us.net>
for v3.
Thanks,
Guenter
> ---
> Documentation/hwmon/scpi-hwmon | 33 ++++++++
> drivers/hwmon/Kconfig | 8 ++
> drivers/hwmon/Makefile | 1 +
> drivers/hwmon/scpi-hwmon.c | 183 +++++++++++++++++++++++++++++++++++++++++
> 4 files changed, 225 insertions(+)
> create mode 100644 Documentation/hwmon/scpi-hwmon
> create mode 100644 drivers/hwmon/scpi-hwmon.c
>
> diff --git a/Documentation/hwmon/scpi-hwmon b/Documentation/hwmon/scpi-hwmon
> new file mode 100644
> index 0000000..4cfcdf2d
> --- /dev/null
> +++ b/Documentation/hwmon/scpi-hwmon
> @@ -0,0 +1,33 @@
> +Kernel driver scpi-hwmon
> +============
> +
> +Supported chips:
> + * Chips based on ARM System Control Processor Interface
> + Addresses scanned: -
> + Datasheet: http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.dui0922b/index.html
> +
> +Author: Punit Agrawal <punit.agrawal@arm.com>
> +
> +Description
> +-----------
> +
> +This driver supports hardware monitoring for SoC's based on the ARM
> +System Control Processor (SCP) implementing the System Control
> +Processor Interface (SCPI). The following sensor types are supported
> +by the SCP -
> +
> + * temperature
> + * voltage
> + * current
> + * power
> +
> +The SCP interface provides an API to query the available sensors and
> +their values which are then exported to userspace by this driver.
> +
> +Usage Notes
> +-----------
> +
> +The driver relies on device tree node to indicate the presence of SCPI
> +support in the kernel. See
> +Documentation/devicetree/bindings/arm/arm,scpi.txt for details of the
> +devicetree node.
> \ No newline at end of file
> diff --git a/drivers/hwmon/Kconfig b/drivers/hwmon/Kconfig
> index 4943c3c..c9714b0 100644
> --- a/drivers/hwmon/Kconfig
> +++ b/drivers/hwmon/Kconfig
> @@ -1551,6 +1551,14 @@ config SENSORS_VEXPRESS
> the ARM Ltd's Versatile Express platform. It can provide wide
> range of information like temperature, power, energy.
>
> +config SENSORS_ARM_SCPI
> + tristate "ARM SCPI Sensors"
> + depends on ARM_SCPI_PROTOCOL
> + help
> + This driver provides support for temperature, voltage, current
> + and power sensors available on ARM Ltd's SCP based platforms. The
> + actual number and type of sensors exported depend the platform.
> +
> config SENSORS_VIA_CPUTEMP
> tristate "VIA CPU temperature sensor"
> depends on X86
> diff --git a/drivers/hwmon/Makefile b/drivers/hwmon/Makefile
> index 8aba87f..4961710 100644
> --- a/drivers/hwmon/Makefile
> +++ b/drivers/hwmon/Makefile
> @@ -150,6 +150,7 @@ obj-$(CONFIG_SENSORS_TMP421) += tmp421.o
> obj-$(CONFIG_SENSORS_TWL4030_MADC)+= twl4030-madc-hwmon.o
> obj-$(CONFIG_SENSORS_V2M_JUNO) += v2m-juno.o
> obj-$(CONFIG_SENSORS_VEXPRESS) += vexpress.o
> +obj-$(CONFIG_SENSORS_ARM_SCPI) += scpi-hwmon.o
> obj-$(CONFIG_SENSORS_VIA_CPUTEMP)+= via-cputemp.o
> obj-$(CONFIG_SENSORS_VIA686A) += via686a.o
> obj-$(CONFIG_SENSORS_VT1211) += vt1211.o
> diff --git a/drivers/hwmon/scpi-hwmon.c b/drivers/hwmon/scpi-hwmon.c
> new file mode 100644
> index 0000000..7e7e06b
> --- /dev/null
> +++ b/drivers/hwmon/scpi-hwmon.c
> @@ -0,0 +1,183 @@
> +/*
> + * System Control and Power Interface(SCPI) based hwmon sensor driver
> + *
> + * Copyright (C) 2015 ARM Ltd.
> + * Punit Agrawal <punit.agrawal@arm.com>
> + *
> + * This program is free software; you can redistribute it and/or modify
> + * it under the terms of the GNU General Public License version 2 as
> + * published by the Free Software Foundation.
> + *
> + * This program is distributed "as is" WITHOUT ANY WARRANTY of any
> + * kind, whether express or implied; without even the implied warranty
> + * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
> + * GNU General Public License for more details.
> + */
> +
> +#include <linux/hwmon.h>
> +#include <linux/module.h>
> +#include <linux/platform_device.h>
> +#include <linux/scpi_protocol.h>
> +#include <linux/slab.h>
> +#include <linux/sysfs.h>
> +
> +struct sensor_data {
> + struct scpi_sensor_info info;
> + struct device_attribute dev_attr_input;
> + struct device_attribute dev_attr_label;
> + char input[20];
> + char label[20];
> +};
> +
> +struct scpi_sensors {
> + struct scpi_ops *scpi_ops;
> + struct sensor_data *data;
> + struct attribute **attrs;
> + struct attribute_group group;
> + const struct attribute_group *groups[2];
> +};
> +
> +/* hwmon callback functions */
> +static ssize_t
> +scpi_show_sensor(struct device *dev, struct device_attribute *attr, char *buf)
> +{
> + struct scpi_sensors *scpi_sensors = dev_get_drvdata(dev);
> + struct scpi_ops *scpi_ops = scpi_sensors->scpi_ops;
> + struct sensor_data *sensor;
> + u32 value;
> + int ret;
> +
> + sensor = container_of(attr, struct sensor_data, dev_attr_input);
> +
> + ret = scpi_ops->sensor_get_value(sensor->info.sensor_id, &value);
> + if (ret)
> + return ret;
> +
> + return sprintf(buf, "%u\n", value);
> +}
> +
> +static ssize_t
> +scpi_show_label(struct device *dev, struct device_attribute *attr, char *buf)
> +{
> + struct sensor_data *sensor;
> +
> + sensor = container_of(attr, struct sensor_data, dev_attr_label);
> +
> + return sprintf(buf, "%s\n", sensor->info.name);
> +}
> +
> +static int scpi_hwmon_probe(struct platform_device *pdev)
> +{
> + u16 nr_sensors, i;
> + int num_temp = 0, num_volt = 0, num_current = 0, num_power = 0;
> + struct scpi_ops *scpi_ops;
> + struct device *hwdev, *dev = &pdev->dev;
> + struct scpi_sensors *scpi_sensors;
> + int ret;
> +
> + scpi_ops = get_scpi_ops();
> + if (!scpi_ops)
> + return -EPROBE_DEFER;
> +
> + ret = scpi_ops->sensor_get_capability(&nr_sensors);
> + if (ret || !nr_sensors)
> + return ret;
> +
This will return 0 if nr_sensors = 0. Should it be -ENODEV ?
> + scpi_sensors = devm_kzalloc(dev, sizeof(*scpi_sensors), GFP_KERNEL);
> + if (!scpi_sensors)
> + return -ENOMEM;
> +
> + scpi_sensors->data = devm_kcalloc(dev, nr_sensors,
> + sizeof(*scpi_sensors->data), GFP_KERNEL);
> + if (!scpi_sensors->data)
> + return -ENOMEM;
> +
> + scpi_sensors->attrs = devm_kcalloc(dev, (nr_sensors * 2) + 1,
> + sizeof(*scpi_sensors->attrs), GFP_KERNEL);
> + if (!scpi_sensors->attrs)
> + return -ENOMEM;
> +
> + scpi_sensors->scpi_ops = scpi_ops;
> +
> + for (i = 0; i < nr_sensors; i++) {
> + struct sensor_data *sensor = &scpi_sensors->data[i];
> +
> + ret = scpi_ops->sensor_get_info(i, &sensor->info);
> + if (ret)
> + return ret;
> +
> + switch (sensor->info.class) {
> + case TEMPERATURE:
> + snprintf(sensor->input, sizeof(sensor->input),
> + "temp%d_input", num_temp + 1);
> + snprintf(sensor->label, sizeof(sensor->input),
> + "temp%d_label", num_temp + 1);
> + num_temp++;
> + break;
> + case VOLTAGE:
> + snprintf(sensor->input, sizeof(sensor->input),
> + "in%d_input", num_volt);
> + snprintf(sensor->label, sizeof(sensor->input),
> + "in%d_label", num_volt);
> + num_volt++;
> + break;
> + case CURRENT:
> + snprintf(sensor->input, sizeof(sensor->input),
> + "curr%d_input", num_current + 1);
> + snprintf(sensor->label, sizeof(sensor->input),
> + "curr%d_label", num_current + 1);
> + num_current++;
> + break;
> + case POWER:
> + snprintf(sensor->input, sizeof(sensor->input),
> + "power%d_input", num_power + 1);
> + snprintf(sensor->label, sizeof(sensor->input),
> + "power%d_label", num_power + 1);
> + num_power++;
> + break;
> + default:
> + break;
> + }
> +
> + sensor->dev_attr_input.attr.mode = S_IRUGO;
> + sensor->dev_attr_input.show = scpi_show_sensor;
> + sensor->dev_attr_input.attr.name = sensor->input;
> +
> + sensor->dev_attr_label.attr.mode = S_IRUGO;
> + sensor->dev_attr_label.show = scpi_show_label;
> + sensor->dev_attr_label.attr.name = sensor->label;
> +
> + scpi_sensors->attrs[i << 1] = &sensor->dev_attr_input.attr;
> + scpi_sensors->attrs[(i << 1) + 1] = &sensor->dev_attr_label.attr;
> +
> + sysfs_attr_init(scpi_sensors->attrs[i << 1]);
> + sysfs_attr_init(scpi_sensors->attrs[(i << 1) + 1]);
> + }
> +
> + scpi_sensors->group.attrs = scpi_sensors->attrs;
> + scpi_sensors->groups[0] = &scpi_sensors->group;
> +
> + hwdev = devm_hwmon_device_register_with_groups(dev,
> + "scpi_sensors", scpi_sensors, scpi_sensors->groups);
> +
> + return PTR_ERR_OR_ZERO(hwdev);
> +}
> +
> +static const struct of_device_id scpi_of_match[] = {
> + {.compatible = "arm,scpi-sensors"},
> + {},
> +};
> +
> +static struct platform_driver scpi_hwmon_platdrv = {
> + .driver = {
> + .name = "scpi-hwmon",
> + .owner = THIS_MODULE,
> + .of_match_table = scpi_of_match,
> + },
> + .probe = scpi_hwmon_probe,
> +};
> +module_platform_driver(scpi_hwmon_platdrv);
> +
> +MODULE_AUTHOR("Punit Agrawal <punit.agrawal@arm.com>");
> +MODULE_DESCRIPTION("ARM SCPI HWMON interface driver");
> +MODULE_LICENSE("GPL v2");
>
_______________________________________________
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:32 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 ` [PATCH v2 08/10] hwmon: Support registration of thermal zones for SCP temperature sensors Guenter Roeck
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 [this message]
2015-08-04 21:32 ` 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=55C12F5A.5080705@roeck-us.net \
--to=linux@roeck-us.net \
--cc=devicetree@vger.kernel.org \
--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 \
--cc=sudeep.holla@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.