diff mbox series

[3/3] ir38064: Expose a regulator

Message ID 20211213101902.146179-3-arthur.heymans@9elements.com (mailing list archive)
State Superseded
Headers show
Series [1/3] hwmon/ir38064: Add support for IR38060, IR38164 IR38263 | expand

Commit Message

Arthur Heymans Dec. 13, 2021, 10:19 a.m. UTC
From: Patrick Rudolph <patrick.rudolph@9elements.com>

Signed-off-by: Patrick Rudolph <patrick.rudolph@9elements.com>
---
 drivers/hwmon/pmbus/Kconfig   |  6 ++++++
 drivers/hwmon/pmbus/ir38064.c | 17 +++++++++++++++++
 2 files changed, 23 insertions(+)

Comments

Guenter Roeck Dec. 13, 2021, 1:35 p.m. UTC | #1
On 12/13/21 2:19 AM, arthur@aheymans.xyz wrote:
> From: Patrick Rudolph <patrick.rudolph@9elements.com>
> 
> Signed-off-by: Patrick Rudolph <patrick.rudolph@9elements.com>
> ---
>   drivers/hwmon/pmbus/Kconfig   |  6 ++++++
>   drivers/hwmon/pmbus/ir38064.c | 17 +++++++++++++++++
>   2 files changed, 23 insertions(+)
> 
> diff --git a/drivers/hwmon/pmbus/Kconfig b/drivers/hwmon/pmbus/Kconfig
> index d2b178a902f0..fdfe1cd54799 100644
> --- a/drivers/hwmon/pmbus/Kconfig
> +++ b/drivers/hwmon/pmbus/Kconfig
> @@ -131,6 +131,12 @@ config SENSORS_IR38064
>   	  This driver can also be built as a module. If so, the module will
>   	  be called ir38064.
>   
> +config SENSORS_IR38064_REGULATOR
> +	bool "Regulator support for IR38064 and compatibles"
> +	depends on SENSORS_IR38064 && REGULATOR
> +	help
> +	  Uses the IR38064 or compatible as regulator.
> +
>   config SENSORS_IRPS5401
>   	tristate "Infineon IRPS5401"
>   	help
> diff --git a/drivers/hwmon/pmbus/ir38064.c b/drivers/hwmon/pmbus/ir38064.c
> index 429577b027b4..61cbe5063688 100644
> --- a/drivers/hwmon/pmbus/ir38064.c
> +++ b/drivers/hwmon/pmbus/ir38064.c
> @@ -17,8 +17,15 @@
>   #include <linux/kernel.h>
>   #include <linux/module.h>
>   #include <linux/of_device.h>
> +#include <linux/regulator/driver.h>
>   #include "pmbus.h"
>   
> +#if IS_ENABLED(CONFIG_SENSORS_IR38064_REGULATOR)
> +static const struct regulator_desc ir38064_reg_desc[] = {
> +	PMBUS_REGULATOR("vout", 0),
> +};
> +#endif /* CONFIG_SENSORS_IR38064_REGULATOR */
> +
>   static struct pmbus_driver_info ir38064_info = {
>   	.pages = 1,
>   	.format[PSC_VOLTAGE_IN] = linear,
> @@ -33,9 +40,19 @@ static struct pmbus_driver_info ir38064_info = {
>   	    | PMBUS_HAVE_TEMP | PMBUS_HAVE_STATUS_TEMP
>   	    | PMBUS_HAVE_VOUT | PMBUS_HAVE_STATUS_VOUT
>   	    | PMBUS_HAVE_IOUT | PMBUS_HAVE_STATUS_IOUT
> +#if IS_ENABLED(CONFIG_SENSORS_IR38064_REGULATOR)
> +#ifdef PMBUS_HAVE_VOUT_COMMAND
> +		| PMBUS_HAVE_VOUT_COMMAND
> +#endif
> +#endif

Please drop. PMBUS_HAVE_VOUT_COMMAND is not defined in the upstream kernel.
Yes, code introducing it was suggested two years ago, and I rejected it.
The reasons are still valid. If you have out-of tree code which enables
setting voltages values and voltage margins with hwmon sysfs attributes,
please keep it out-of-tree.

Thanks,
Guenter

>   	    | PMBUS_HAVE_POUT,
> +#if IS_ENABLED(CONFIG_SENSORS_IR38064_REGULATOR)
> +	.num_regulators = 1,
> +	.reg_desc = ir38064_reg_desc,
> +#endif
>   };
>   
> +
>   static int ir38064_probe(struct i2c_client *client)
>   {
>   	return pmbus_do_probe(client, &ir38064_info);
>
diff mbox series

Patch

diff --git a/drivers/hwmon/pmbus/Kconfig b/drivers/hwmon/pmbus/Kconfig
index d2b178a902f0..fdfe1cd54799 100644
--- a/drivers/hwmon/pmbus/Kconfig
+++ b/drivers/hwmon/pmbus/Kconfig
@@ -131,6 +131,12 @@  config SENSORS_IR38064
 	  This driver can also be built as a module. If so, the module will
 	  be called ir38064.
 
+config SENSORS_IR38064_REGULATOR
+	bool "Regulator support for IR38064 and compatibles"
+	depends on SENSORS_IR38064 && REGULATOR
+	help
+	  Uses the IR38064 or compatible as regulator.
+
 config SENSORS_IRPS5401
 	tristate "Infineon IRPS5401"
 	help
diff --git a/drivers/hwmon/pmbus/ir38064.c b/drivers/hwmon/pmbus/ir38064.c
index 429577b027b4..61cbe5063688 100644
--- a/drivers/hwmon/pmbus/ir38064.c
+++ b/drivers/hwmon/pmbus/ir38064.c
@@ -17,8 +17,15 @@ 
 #include <linux/kernel.h>
 #include <linux/module.h>
 #include <linux/of_device.h>
+#include <linux/regulator/driver.h>
 #include "pmbus.h"
 
+#if IS_ENABLED(CONFIG_SENSORS_IR38064_REGULATOR)
+static const struct regulator_desc ir38064_reg_desc[] = {
+	PMBUS_REGULATOR("vout", 0),
+};
+#endif /* CONFIG_SENSORS_IR38064_REGULATOR */
+
 static struct pmbus_driver_info ir38064_info = {
 	.pages = 1,
 	.format[PSC_VOLTAGE_IN] = linear,
@@ -33,9 +40,19 @@  static struct pmbus_driver_info ir38064_info = {
 	    | PMBUS_HAVE_TEMP | PMBUS_HAVE_STATUS_TEMP
 	    | PMBUS_HAVE_VOUT | PMBUS_HAVE_STATUS_VOUT
 	    | PMBUS_HAVE_IOUT | PMBUS_HAVE_STATUS_IOUT
+#if IS_ENABLED(CONFIG_SENSORS_IR38064_REGULATOR)
+#ifdef PMBUS_HAVE_VOUT_COMMAND
+		| PMBUS_HAVE_VOUT_COMMAND
+#endif
+#endif
 	    | PMBUS_HAVE_POUT,
+#if IS_ENABLED(CONFIG_SENSORS_IR38064_REGULATOR)
+	.num_regulators = 1,
+	.reg_desc = ir38064_reg_desc,
+#endif
 };
 
+
 static int ir38064_probe(struct i2c_client *client)
 {
 	return pmbus_do_probe(client, &ir38064_info);