regulator: Convert anatop to use a struct to pass in regulator runtime configuration
[firefly-linux-kernel-4.4.55.git] / drivers / regulator / ab3100.c
index 042271aace6a65b8a2f40cdc3be75934ae081ff4..ce6192592ca20a77312f3f6ddff7eb4d0bb736a4 100644 (file)
@@ -338,20 +338,12 @@ static int ab3100_get_best_voltage_index(struct regulator_dev *reg,
        return bestindex;
 }
 
-static int ab3100_set_voltage_regulator(struct regulator_dev *reg,
-                                       int min_uV, int max_uV,
-                                       unsigned *selector)
+static int ab3100_set_voltage_regulator_sel(struct regulator_dev *reg,
+                                           unsigned selector)
 {
        struct ab3100_regulator *abreg = reg->reg_data;
        u8 regval;
        int err;
-       int bestindex;
-
-       bestindex = ab3100_get_best_voltage_index(reg, min_uV, max_uV);
-       if (bestindex < 0)
-               return bestindex;
-
-       *selector = bestindex;
 
        err = abx500_get_register_interruptible(abreg->dev, 0,
                                                abreg->regreg, &regval);
@@ -364,7 +356,7 @@ static int ab3100_set_voltage_regulator(struct regulator_dev *reg,
 
        /* The highest three bits control the variable regulators */
        regval &= ~0xE0;
-       regval |= (bestindex << 5);
+       regval |= (selector << 5);
 
        err = abx500_set_register_interruptible(abreg->dev, 0,
                                                abreg->regreg, regval);
@@ -464,7 +456,7 @@ static struct regulator_ops regulator_ops_variable = {
        .disable     = ab3100_disable_regulator,
        .is_enabled  = ab3100_is_enabled_regulator,
        .get_voltage = ab3100_get_voltage_regulator,
-       .set_voltage = ab3100_set_voltage_regulator,
+       .set_voltage_sel = ab3100_set_voltage_regulator_sel,
        .list_voltage = ab3100_list_voltage_regulator,
        .enable_time = ab3100_enable_time_regulator,
 };
@@ -474,7 +466,7 @@ static struct regulator_ops regulator_ops_variable_sleepable = {
        .disable     = ab3100_disable_regulator,
        .is_enabled  = ab3100_is_enabled_regulator,
        .get_voltage = ab3100_get_voltage_regulator,
-       .set_voltage = ab3100_set_voltage_regulator,
+       .set_voltage_sel = ab3100_set_voltage_regulator_sel,
        .set_suspend_voltage = ab3100_set_suspend_voltage_regulator,
        .list_voltage = ab3100_list_voltage_regulator,
        .enable_time = ab3100_enable_time_regulator,
@@ -582,6 +574,7 @@ ab3100_regulator_desc[AB3100_NUM_REGULATORS] = {
 static int __devinit ab3100_regulators_probe(struct platform_device *pdev)
 {
        struct ab3100_platform_data *plfdata = pdev->dev.platform_data;
+       struct regulator_config config = { };
        int err = 0;
        u8 data;
        int i;
@@ -627,15 +620,15 @@ static int __devinit ab3100_regulators_probe(struct platform_device *pdev)
                reg->dev = &pdev->dev;
                reg->plfdata = plfdata;
 
+               config.dev = &pdev->dev;
+               config.driver_data = reg;
+               config.init_data = &plfdata->reg_constraints[i];
+
                /*
                 * Register the regulator, pass around
                 * the ab3100_regulator struct
                 */
-               rdev = regulator_register(&ab3100_regulator_desc[i],
-                                         &pdev->dev,
-                                         &plfdata->reg_constraints[i],
-                                         reg, NULL);
-
+               rdev = regulator_register(&ab3100_regulator_desc[i], &config);
                if (IS_ERR(rdev)) {
                        err = PTR_ERR(rdev);
                        dev_err(&pdev->dev,