regulator: act8945a-regulator: add shutdown function

Implement shutdown method to make sure the PMIC will not enter the suspend
state when the system is shutdown.

This work is based on work done by Borris Brezillon on [1].

[1] https://www.spinics.net/lists/kernel/msg2942960.html

Signed-off-by: Claudiu Beznea <claudiu.beznea@microchip.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
Claudiu Beznea 2018-12-11 15:56:50 +00:00 committed by Mark Brown
parent 03ffbf9c08
commit b5ebba46e6
No known key found for this signature in database
GPG Key ID: 24D68B725D5487D0
1 changed files with 11 additions and 0 deletions

View File

@ -339,12 +339,23 @@ static int act8945a_suspend(struct device *pdev)
SIMPLE_DEV_PM_OPS(act8945a_pm, act8945a_suspend, NULL); SIMPLE_DEV_PM_OPS(act8945a_pm, act8945a_suspend, NULL);
static void act8945a_pmic_shutdown(struct platform_device *pdev)
{
struct act8945a_pmic *act8945a = platform_get_drvdata(pdev);
/*
* Ask the PMIC to shutdown everything on the next PWRHLD transition.
*/
regmap_write(act8945a->regmap, ACT8945A_SYS_CTRL, 0x0);
}
static struct platform_driver act8945a_pmic_driver = { static struct platform_driver act8945a_pmic_driver = {
.driver = { .driver = {
.name = "act8945a-regulator", .name = "act8945a-regulator",
.pm = &act8945a_pm, .pm = &act8945a_pm,
}, },
.probe = act8945a_pmic_probe, .probe = act8945a_pmic_probe,
.shutdown = act8945a_pmic_shutdown,
}; };
module_platform_driver(act8945a_pmic_driver); module_platform_driver(act8945a_pmic_driver);