提交 984b5a6b 编写于 作者: A Ashish Jangam 提交者: Mark Brown

regulator: Replace kzalloc with devm_kzalloc and if-else with a switch-case for da9052-regulator

Reported-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
Signed-off-by: NDavid Dajun Chen <dchen@diasemi.com>
Signed-off-by: NAshish Jangam <ashish.jangam@kpitcummins.com>
Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
上级 47aed92c
...@@ -505,18 +505,23 @@ static inline struct da9052_regulator_info *find_regulator_info(u8 chip_id, ...@@ -505,18 +505,23 @@ static inline struct da9052_regulator_info *find_regulator_info(u8 chip_id,
struct da9052_regulator_info *info; struct da9052_regulator_info *info;
int i; int i;
if (chip_id == DA9052) { switch (chip_id) {
case DA9052:
for (i = 0; i < ARRAY_SIZE(da9052_regulator_info); i++) { for (i = 0; i < ARRAY_SIZE(da9052_regulator_info); i++) {
info = &da9052_regulator_info[i]; info = &da9052_regulator_info[i];
if (info->reg_desc.id == id) if (info->reg_desc.id == id)
return info; return info;
} }
} else { break;
case DA9053_AA:
case DA9053_BA:
case DA9053_BB:
for (i = 0; i < ARRAY_SIZE(da9053_regulator_info); i++) { for (i = 0; i < ARRAY_SIZE(da9053_regulator_info); i++) {
info = &da9053_regulator_info[i]; info = &da9053_regulator_info[i];
if (info->reg_desc.id == id) if (info->reg_desc.id == id)
return info; return info;
} }
break;
} }
return NULL; return NULL;
...@@ -529,7 +534,8 @@ static int __devinit da9052_regulator_probe(struct platform_device *pdev) ...@@ -529,7 +534,8 @@ static int __devinit da9052_regulator_probe(struct platform_device *pdev)
struct da9052_pdata *pdata; struct da9052_pdata *pdata;
int ret; int ret;
regulator = kzalloc(sizeof(struct da9052_regulator), GFP_KERNEL); regulator = devm_kzalloc(&pdev->dev, sizeof(struct da9052_regulator),
GFP_KERNEL);
if (!regulator) if (!regulator)
return -ENOMEM; return -ENOMEM;
...@@ -559,7 +565,7 @@ static int __devinit da9052_regulator_probe(struct platform_device *pdev) ...@@ -559,7 +565,7 @@ static int __devinit da9052_regulator_probe(struct platform_device *pdev)
return 0; return 0;
err: err:
kfree(regulator); devm_kfree(&pdev->dev, regulator);
return ret; return ret;
} }
...@@ -568,7 +574,7 @@ static int __devexit da9052_regulator_remove(struct platform_device *pdev) ...@@ -568,7 +574,7 @@ static int __devexit da9052_regulator_remove(struct platform_device *pdev)
struct da9052_regulator *regulator = platform_get_drvdata(pdev); struct da9052_regulator *regulator = platform_get_drvdata(pdev);
regulator_unregister(regulator->rdev); regulator_unregister(regulator->rdev);
kfree(regulator); devm_kfree(&pdev->dev, regulator);
return 0; return 0;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册