regulator: gpio: Add input_supply support in gpio_regulator_config

This is simillar as fixed-regulator.
Used to extract regulator parent from the device tree.

Without that property used, the parent regulator can be shut down (if not an always on).
Thus leading to inappropriate behavior:
On am62-SP-SK this fix is required to avoid tps65219 ldo1 (SDMMC rail) to be shut down after boot completion.

Signed-off-by: Jerome Neanne <jneanne@baylibre.com>
Link: https://lore.kernel.org/r/20220929132526.29427-2-jneanne@baylibre.com
Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
Jerome Neanne 2022-09-29 15:25:25 +02:00 committed by Mark Brown
parent 947934e389
commit adfdfcbdbd
No known key found for this signature in database
GPG Key ID: 24D68B725D5487D0
2 changed files with 17 additions and 0 deletions

View File

@ -220,6 +220,9 @@ of_get_gpio_regulator_config(struct device *dev, struct device_node *np,
regtype); regtype);
} }
if (of_find_property(np, "vin-supply", NULL))
config->input_supply = "vin";
return config; return config;
} }
@ -259,6 +262,18 @@ static int gpio_regulator_probe(struct platform_device *pdev)
drvdata->gpiods = devm_kzalloc(dev, sizeof(struct gpio_desc *), drvdata->gpiods = devm_kzalloc(dev, sizeof(struct gpio_desc *),
GFP_KERNEL); GFP_KERNEL);
if (config->input_supply) {
drvdata->desc.supply_name = devm_kstrdup(&pdev->dev,
config->input_supply,
GFP_KERNEL);
if (!drvdata->desc.supply_name) {
dev_err(&pdev->dev,
"Failed to allocate input supply\n");
return -ENOMEM;
}
}
if (!drvdata->gpiods) if (!drvdata->gpiods)
return -ENOMEM; return -ENOMEM;
for (i = 0; i < config->ngpios; i++) { for (i = 0; i < config->ngpios; i++) {

View File

@ -42,6 +42,7 @@ struct gpio_regulator_state {
/** /**
* struct gpio_regulator_config - config structure * struct gpio_regulator_config - config structure
* @supply_name: Name of the regulator supply * @supply_name: Name of the regulator supply
* @input_supply: Name of the input regulator supply
* @enabled_at_boot: Whether regulator has been enabled at * @enabled_at_boot: Whether regulator has been enabled at
* boot or not. 1 = Yes, 0 = No * boot or not. 1 = Yes, 0 = No
* This is used to keep the regulator at * This is used to keep the regulator at
@ -62,6 +63,7 @@ struct gpio_regulator_state {
*/ */
struct gpio_regulator_config { struct gpio_regulator_config {
const char *supply_name; const char *supply_name;
const char *input_supply;
unsigned enabled_at_boot:1; unsigned enabled_at_boot:1;
unsigned startup_delay; unsigned startup_delay;