If regulator DT node doesn't exist, its of_parse_cb callback
function isn't called. Then all values for DT properties are
filled with zero. This leads to wrong register update for
FPS and POK settings.

Signed-off-by: Jinyoung Park <jinyou...@nvidia.com>
Signed-off-by: Mark Zhang <ma...@nvidia.com>
---
 drivers/regulator/max77620-regulator.c | 10 +++++++++-
 1 file changed, 9 insertions(+), 1 deletion(-)

diff --git a/drivers/regulator/max77620-regulator.c 
b/drivers/regulator/max77620-regulator.c
index b94e3a721721..cd93cf53e23c 100644
--- a/drivers/regulator/max77620-regulator.c
+++ b/drivers/regulator/max77620-regulator.c
@@ -1,7 +1,7 @@
 /*
  * Maxim MAX77620 Regulator driver
  *
- * Copyright (c) 2016, NVIDIA CORPORATION.  All rights reserved.
+ * Copyright (c) 2016-2018, NVIDIA CORPORATION.  All rights reserved.
  *
  * Author: Mallikarjun Kasoju <mkas...@nvidia.com>
  *     Laxman Dewangan <ldewan...@nvidia.com>
@@ -803,6 +803,14 @@ static int max77620_regulator_probe(struct platform_device 
*pdev)
                rdesc = &rinfo[id].desc;
                pmic->rinfo[id] = &max77620_regs_info[id];
                pmic->enable_power_mode[id] = MAX77620_POWER_MODE_NORMAL;
+               pmic->reg_pdata[id].active_fps_src = -1;
+               pmic->reg_pdata[id].active_fps_pd_slot = -1;
+               pmic->reg_pdata[id].active_fps_pu_slot = -1;
+               pmic->reg_pdata[id].suspend_fps_src = -1;
+               pmic->reg_pdata[id].suspend_fps_pd_slot = -1;
+               pmic->reg_pdata[id].suspend_fps_pu_slot = -1;
+               pmic->reg_pdata[id].power_ok = -1;
+               pmic->reg_pdata[id].ramp_rate_setting = -1;
 
                ret = max77620_read_slew_rate(pmic, id);
                if (ret < 0)
-- 
2.19.2

Reply via email to