aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/regulator/wm8400-regulator.c
diff options
context:
space:
mode:
authorMark Brown <broonie@opensource.wolfsonmicro.com>2012-04-03 19:50:22 -0400
committerMark Brown <broonie@opensource.wolfsonmicro.com>2012-04-09 07:37:09 -0400
commitc172708d38a401b2f3f841dfcd862b469fa0b670 (patch)
tree75e89c63fd0c76a2c69bb5ad6e45b3762bceb6b6 /drivers/regulator/wm8400-regulator.c
parent1474e4dbcae04125ed6e503eadcef266846f4675 (diff)
regulator: core: Use a struct to pass in regulator runtime configuration
Rather than adding new arguments to regulator_register() every time we want to add a new bit of dynamic information at runtime change the function to take these via a struct. By doing this we avoid needing to do further changes like the recent addition of device tree support which required each regulator driver to be updated to take an additional parameter. The regulator_desc which should (mostly) be static data is still passed separately as most drivers are able to configure this statically at build time. Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Diffstat (limited to 'drivers/regulator/wm8400-regulator.c')
-rw-r--r--drivers/regulator/wm8400-regulator.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/drivers/regulator/wm8400-regulator.c b/drivers/regulator/wm8400-regulator.c
index 8477153780b..4408b7802e7 100644
--- a/drivers/regulator/wm8400-regulator.c
+++ b/drivers/regulator/wm8400-regulator.c
@@ -323,11 +323,14 @@ static struct regulator_desc regulators[] = {
323static int __devinit wm8400_regulator_probe(struct platform_device *pdev) 323static int __devinit wm8400_regulator_probe(struct platform_device *pdev)
324{ 324{
325 struct wm8400 *wm8400 = container_of(pdev, struct wm8400, regulators[pdev->id]); 325 struct wm8400 *wm8400 = container_of(pdev, struct wm8400, regulators[pdev->id]);
326 struct regulator_config config = { };
326 struct regulator_dev *rdev; 327 struct regulator_dev *rdev;
327 328
328 rdev = regulator_register(&regulators[pdev->id], &pdev->dev, 329 config.dev = &pdev->dev;
329 pdev->dev.platform_data, wm8400, NULL); 330 config.init_data = pdev->dev.platform_data;
331 config.driver_data = wm8400;
330 332
333 rdev = regulator_register(&regulators[pdev->id], &config);
331 if (IS_ERR(rdev)) 334 if (IS_ERR(rdev))
332 return PTR_ERR(rdev); 335 return PTR_ERR(rdev);
333 336