[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <c04c4bef-2773-41f7-b2e6-ea465cb9f164@ti.com>
Date: Thu, 19 Jun 2025 14:58:24 -0500
From: Shree Ramamoorthy <s-ramamoorthy@...com>
To: Dhruva Gole <d-gole@...com>, <lgirdwood@...il.com>, <broonie@...nel.org>,
<aaro.koskinen@....fi>, <andreas@...nade.info>, <khilman@...libre.com>,
<rogerq@...nel.org>, <tony@...mide.com>, <linux-omap@...r.kernel.org>,
<linux-kernel@...r.kernel.org>
CC: <m-leonard@...com>, <praneeth@...com>,
Robert Nelson
<robertcnelson@...il.com>
Subject: Re: [PATCH] Revert "regulator: tps65219: Add TI TPS65214 Regulator
Support"
Hi,
On 6/19/25 10:35 AM, Dhruva Gole wrote:
> This reverts commit f1471bc435afa31c8c0c58551922830dc8f4b06b.
I will be sending a patch soon with a fix regarding the devm_kmalloc use in the probe() function.
I'll keep looking into these bugs to see if there's anything else to fix.
> This was causing boot regressions [1] on many BeagleBoard platforms
> like the AM62x based BeaglePlay and PocketBeagle-2.
>
> [1] https://gist.github.com/DhruvaG2000/75b7d5ced6c09d508ee0ad5ab1f19707
>
> Signed-off-by: Dhruva Gole <d-gole@...com>
> ---
> drivers/regulator/Kconfig | 9 +---
> drivers/regulator/tps65219-regulator.c | 73 ++++----------------------
> 2 files changed, 13 insertions(+), 69 deletions(-)
>
> diff --git a/drivers/regulator/Kconfig b/drivers/regulator/Kconfig
> index 7423954153b0..fa9a9a5d1a03 100644
> --- a/drivers/regulator/Kconfig
> +++ b/drivers/regulator/Kconfig
> @@ -1601,16 +1601,11 @@ config REGULATOR_TPS65219
> tristate "TI TPS65219 Power regulators"
> depends on MFD_TPS65219 && OF
> help
> - This driver supports TPS65219, TPS65215, and TPS65214 voltage
> - regulator chips.
> + This driver supports TPS65219 series and TPS65215 voltage regulator chips.
> TPS65219 series of PMICs have 3 single phase BUCKs & 4 LDOs
> voltage regulators.
> TPS65215 PMIC has 3 single phase BUCKs & 2 LDOs.
> - TPS65214 PMIC has 3 synchronous stepdown DC-DC converters & 2
> - LDOs. One LDO supports a maximum output current of 300 mA and the
> - other a maximum of 500 mA
> - All 3 PMICs support software based voltage control for different
> - voltage domains.
> + Both PMICs support software based voltage control for different voltage domains.
>
> config REGULATOR_TPS6594
> tristate "TI TPS6594 Power regulators"
> diff --git a/drivers/regulator/tps65219-regulator.c b/drivers/regulator/tps65219-regulator.c
> index b16b300d7f45..d84ab9586ec4 100644
> --- a/drivers/regulator/tps65219-regulator.c
> +++ b/drivers/regulator/tps65219-regulator.c
> @@ -1,6 +1,6 @@
> // SPDX-License-Identifier: GPL-2.0
> //
> -// TPS65214/TPS65215/TPS65219 PMIC Regulator Driver
> +// Regulator driver for TPS65215/TPS65219 PMIC
> //
> // Copyright (C) 2022 BayLibre Incorporated - https://www.baylibre.com/
> // Copyright (C) 2024 Texas Instruments Incorporated - https://www.ti.com/
> @@ -29,11 +29,6 @@ struct tps65219_regulator_irq_type {
> unsigned long event;
> };
>
> -static struct tps65219_regulator_irq_type tps65215_regulator_irq_types[] = {
> - { "SENSOR_3_WARM", "SENSOR3", "warm temperature", REGULATOR_EVENT_OVER_TEMP_WARN},
> - { "SENSOR_3_HOT", "SENSOR3", "hot temperature", REGULATOR_EVENT_OVER_TEMP},
> -};
> -
> static struct tps65219_regulator_irq_type tps65219_regulator_irq_types[] = {
> { "LDO3_SCG", "LDO3", "short circuit to ground", REGULATOR_EVENT_REGULATION_OUT },
> { "LDO3_OC", "LDO3", "overcurrent", REGULATOR_EVENT_OVER_CURRENT },
> @@ -45,11 +40,9 @@ static struct tps65219_regulator_irq_type tps65219_regulator_irq_types[] = {
> { "LDO4_RV", "LDO4", "residual voltage", REGULATOR_EVENT_OVER_VOLTAGE_WARN },
> { "LDO3_RV_SD", "LDO3", "residual voltage on shutdown", REGULATOR_EVENT_OVER_VOLTAGE_WARN },
> { "LDO4_RV_SD", "LDO4", "residual voltage on shutdown", REGULATOR_EVENT_OVER_VOLTAGE_WARN },
> - { "SENSOR_3_WARM", "SENSOR3", "warm temperature", REGULATOR_EVENT_OVER_TEMP_WARN},
> - { "SENSOR_3_HOT", "SENSOR3", "hot temperature", REGULATOR_EVENT_OVER_TEMP},
> };
>
> -/* All of TPS65214's irq types are the same as common_regulator_irq_types */
> +/* All of TPS65215's irq types are the same as common_regulator_irq_types */
> static struct tps65219_regulator_irq_type common_regulator_irq_types[] = {
> { "LDO1_SCG", "LDO1", "short circuit to ground", REGULATOR_EVENT_REGULATION_OUT },
> { "LDO1_OC", "LDO1", "overcurrent", REGULATOR_EVENT_OVER_CURRENT },
> @@ -82,9 +75,11 @@ static struct tps65219_regulator_irq_type common_regulator_irq_types[] = {
> REGULATOR_EVENT_OVER_VOLTAGE_WARN },
> { "LDO1_RV_SD", "LDO1", "residual voltage on shutdown", REGULATOR_EVENT_OVER_VOLTAGE_WARN },
> { "LDO2_RV_SD", "LDO2", "residual voltage on shutdown", REGULATOR_EVENT_OVER_VOLTAGE_WARN },
> + { "SENSOR_3_WARM", "SENSOR3", "warm temperature", REGULATOR_EVENT_OVER_TEMP_WARN},
> { "SENSOR_2_WARM", "SENSOR2", "warm temperature", REGULATOR_EVENT_OVER_TEMP_WARN },
> { "SENSOR_1_WARM", "SENSOR1", "warm temperature", REGULATOR_EVENT_OVER_TEMP_WARN },
> { "SENSOR_0_WARM", "SENSOR0", "warm temperature", REGULATOR_EVENT_OVER_TEMP_WARN },
> + { "SENSOR_3_HOT", "SENSOR3", "hot temperature", REGULATOR_EVENT_OVER_TEMP},
> { "SENSOR_2_HOT", "SENSOR2", "hot temperature", REGULATOR_EVENT_OVER_TEMP },
> { "SENSOR_1_HOT", "SENSOR1", "hot temperature", REGULATOR_EVENT_OVER_TEMP },
> { "SENSOR_0_HOT", "SENSOR0", "hot temperature", REGULATOR_EVENT_OVER_TEMP },
> @@ -138,12 +133,6 @@ static const struct linear_range ldo_1_range[] = {
> REGULATOR_LINEAR_RANGE(3400000, 0x38, 0x3f, 0),
> };
>
> -static const struct linear_range tps65214_ldo_1_2_range[] = {
> - REGULATOR_LINEAR_RANGE(600000, 0x0, 0x2, 0),
> - REGULATOR_LINEAR_RANGE(650000, 0x3, 0x37, 50000),
> - REGULATOR_LINEAR_RANGE(3300000, 0x38, 0x3F, 0),
> -};
> -
> static const struct linear_range tps65215_ldo_2_range[] = {
> REGULATOR_LINEAR_RANGE(1200000, 0x0, 0xC, 50000),
> REGULATOR_LINEAR_RANGE(3300000, 0x36, 0x3F, 0),
> @@ -262,32 +251,6 @@ static const struct regulator_desc common_regs[] = {
> TPS65219_REG_ENABLE_CTRL,
> TPS65219_ENABLE_BUCK3_EN_MASK, 0, 0, bucks_ranges,
> 3, 0, 0, NULL, 0, 0),
> -};
> -
> -static const struct regulator_desc tps65214_regs[] = {
> - // TPS65214's LDO3 pin maps to TPS65219's LDO3 pin
> - TPS65219_REGULATOR("LDO1", "ldo1", TPS65214_LDO_1,
> - REGULATOR_VOLTAGE, ldos_3_4_ops, 64,
> - TPS65214_REG_LDO1_VOUT,
> - TPS65219_BUCKS_LDOS_VOUT_VSET_MASK,
> - TPS65219_REG_ENABLE_CTRL,
> - TPS65219_ENABLE_LDO3_EN_MASK, 0, 0, tps65214_ldo_1_2_range,
> - 3, 0, 0, NULL, 0, 0),
> - TPS65219_REGULATOR("LDO2", "ldo2", TPS65214_LDO_2,
> - REGULATOR_VOLTAGE, ldos_3_4_ops, 64,
> - TPS65214_REG_LDO2_VOUT,
> - TPS65219_BUCKS_LDOS_VOUT_VSET_MASK,
> - TPS65219_REG_ENABLE_CTRL,
> - TPS65219_ENABLE_LDO2_EN_MASK, 0, 0, tps65214_ldo_1_2_range,
> - 3, 0, 0, NULL, 0, 0),
> -};
> -
> -static const struct regulator_desc tps65215_regs[] = {
> - /*
> - * TPS65215's LDO1 is the same as TPS65219's LDO1. LDO1 is
> - * configurable as load switch and bypass-mode.
> - * TPS65215's LDO2 is the same as TPS65219's LDO3
> - */
> TPS65219_REGULATOR("LDO1", "ldo1", TPS65219_LDO_1,
> REGULATOR_VOLTAGE, ldos_1_2_ops, 64,
> TPS65219_REG_LDO1_VOUT,
> @@ -295,6 +258,10 @@ static const struct regulator_desc tps65215_regs[] = {
> TPS65219_REG_ENABLE_CTRL,
> TPS65219_ENABLE_LDO1_EN_MASK, 0, 0, ldo_1_range,
> 2, 0, 0, NULL, 0, TPS65219_LDOS_BYP_CONFIG_MASK),
> +};
> +
> +static const struct regulator_desc tps65215_regs[] = {
> + // TPS65215's LDO2 is the same as TPS65219's LDO3
> TPS65219_REGULATOR("LDO2", "ldo2", TPS65215_LDO_2,
> REGULATOR_VOLTAGE, ldos_3_4_ops, 64,
> TPS65215_REG_LDO2_VOUT,
> @@ -305,13 +272,6 @@ static const struct regulator_desc tps65215_regs[] = {
> };
>
> static const struct regulator_desc tps65219_regs[] = {
> - TPS65219_REGULATOR("LDO1", "ldo1", TPS65219_LDO_1,
> - REGULATOR_VOLTAGE, ldos_1_2_ops, 64,
> - TPS65219_REG_LDO1_VOUT,
> - TPS65219_BUCKS_LDOS_VOUT_VSET_MASK,
> - TPS65219_REG_ENABLE_CTRL,
> - TPS65219_ENABLE_LDO1_EN_MASK, 0, 0, ldo_1_range,
> - 2, 0, 0, NULL, 0, TPS65219_LDOS_BYP_CONFIG_MASK),
> TPS65219_REGULATOR("LDO2", "ldo2", TPS65219_LDO_2,
> REGULATOR_VOLTAGE, ldos_1_2_ops, 64,
> TPS65219_REG_LDO2_VOUT,
> @@ -366,23 +326,13 @@ struct tps65219_chip_data {
> };
>
> static struct tps65219_chip_data chip_info_table[] = {
> - [TPS65214] = {
> - .rdesc = tps65214_regs,
> - .rdesc_size = ARRAY_SIZE(tps65214_regs),
> - .common_rdesc = common_regs,
> - .common_rdesc_size = ARRAY_SIZE(common_regs),
> - .irq_types = NULL,
> - .dev_irq_size = 0,
> - .common_irq_types = common_regulator_irq_types,
> - .common_irq_size = ARRAY_SIZE(common_regulator_irq_types),
> - },
> [TPS65215] = {
> .rdesc = tps65215_regs,
> .rdesc_size = ARRAY_SIZE(tps65215_regs),
> .common_rdesc = common_regs,
> .common_rdesc_size = ARRAY_SIZE(common_regs),
> - .irq_types = tps65215_regulator_irq_types,
> - .dev_irq_size = ARRAY_SIZE(tps65215_regulator_irq_types),
> + .irq_types = NULL,
> + .dev_irq_size = 0,
> .common_irq_types = common_regulator_irq_types,
> .common_irq_size = ARRAY_SIZE(common_regulator_irq_types),
> },
> @@ -486,7 +436,6 @@ static int tps65219_regulator_probe(struct platform_device *pdev)
> }
>
> static const struct platform_device_id tps65219_regulator_id_table[] = {
> - { "tps65214-regulator", TPS65214 },
> { "tps65215-regulator", TPS65215 },
> { "tps65219-regulator", TPS65219 },
> { /* sentinel */ }
> @@ -505,5 +454,5 @@ static struct platform_driver tps65219_regulator_driver = {
> module_platform_driver(tps65219_regulator_driver);
>
> MODULE_AUTHOR("Jerome Neanne <j-neanne@...libre.com>");
> -MODULE_DESCRIPTION("TPS65214/TPS65215/TPS65219 Regulator driver");
> +MODULE_DESCRIPTION("TPS65215/TPS65219 voltage regulator driver");
> MODULE_LICENSE("GPL");
--
Best,
Shree Ramamoorthy
PMIC Software Engineer
Powered by blists - more mailing lists