aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorYadwinder Singh Brar <yadi.brar@samsung.com>2013-06-29 08:51:16 -0400
committerMark Brown <broonie@linaro.org>2013-07-15 13:31:12 -0400
commit939c02777a27ea7915764ecca5263dbb60c664f3 (patch)
tree4df08e2c4e78e0f2afc3d08c6498fffb39751984
parent92d8ecae7eda0820663933e568915dbf7ef79127 (diff)
regulator: s2mps11: Implement set_ramp_rate callback for bucks
Implementing set_ramp_rate() and using standard constraints for getting ramp_delay and ramp_disable, instead of getting it as s2mps11 specific data through platform data, makes driver more compliant with framework and reduces the complexity for adding DT support. Signed-off-by: Yadwinder Singh Brar <yadi.brar@samsung.com> Signed-off-by: Mark Brown <broonie@linaro.org>
-rw-r--r--drivers/regulator/s2mps11.c117
-rw-r--r--include/linux/mfd/samsung/s2mps11.h11
2 files changed, 128 insertions, 0 deletions
diff --git a/drivers/regulator/s2mps11.c b/drivers/regulator/s2mps11.c
index a671eb63a4e5..4b84e7660637 100644
--- a/drivers/regulator/s2mps11.c
+++ b/drivers/regulator/s2mps11.c
@@ -16,6 +16,7 @@
16#include <linux/gpio.h> 16#include <linux/gpio.h>
17#include <linux/slab.h> 17#include <linux/slab.h>
18#include <linux/module.h> 18#include <linux/module.h>
19#include <linux/regmap.h>
19#include <linux/platform_device.h> 20#include <linux/platform_device.h>
20#include <linux/regulator/driver.h> 21#include <linux/regulator/driver.h>
21#include <linux/regulator/machine.h> 22#include <linux/regulator/machine.h>
@@ -104,6 +105,121 @@ static int s2mps11_regulator_set_voltage_time_sel(struct regulator_dev *rdev,
104 return DIV_ROUND_UP(abs(new_volt - old_volt), ramp_delay); 105 return DIV_ROUND_UP(abs(new_volt - old_volt), ramp_delay);
105} 106}
106 107
108static int s2mps11_set_ramp_delay(struct regulator_dev *rdev, int ramp_delay)
109{
110 struct s2mps11_info *s2mps11 = rdev_get_drvdata(rdev);
111 unsigned int ramp_val, ramp_shift, ramp_reg = S2MPS11_REG_RAMP_BUCK;
112 unsigned int ramp_enable = 1, enable_shift = 0;
113 int ret;
114
115 switch (rdev->desc->id) {
116 case S2MPS11_BUCK1:
117 if (ramp_delay > s2mps11->ramp_delay16)
118 s2mps11->ramp_delay16 = ramp_delay;
119 else
120 ramp_delay = s2mps11->ramp_delay16;
121
122 ramp_shift = S2MPS11_BUCK16_RAMP_SHIFT;
123 break;
124 case S2MPS11_BUCK2:
125 enable_shift = S2MPS11_BUCK2_RAMP_EN_SHIFT;
126 if (!ramp_delay) {
127 ramp_enable = 0;
128 break;
129 }
130
131 s2mps11->ramp_delay2 = ramp_delay;
132 ramp_shift = S2MPS11_BUCK2_RAMP_SHIFT;
133 ramp_reg = S2MPS11_REG_RAMP;
134 break;
135 case S2MPS11_BUCK3:
136 enable_shift = S2MPS11_BUCK3_RAMP_EN_SHIFT;
137 if (!ramp_delay) {
138 ramp_enable = 0;
139 break;
140 }
141
142 if (ramp_delay > s2mps11->ramp_delay34)
143 s2mps11->ramp_delay34 = ramp_delay;
144 else
145 ramp_delay = s2mps11->ramp_delay34;
146
147 ramp_shift = S2MPS11_BUCK34_RAMP_SHIFT;
148 ramp_reg = S2MPS11_REG_RAMP;
149 break;
150 case S2MPS11_BUCK4:
151 enable_shift = S2MPS11_BUCK4_RAMP_EN_SHIFT;
152 if (!ramp_delay) {
153 ramp_enable = 0;
154 break;
155 }
156
157 if (ramp_delay > s2mps11->ramp_delay34)
158 s2mps11->ramp_delay34 = ramp_delay;
159 else
160 ramp_delay = s2mps11->ramp_delay34;
161
162 ramp_shift = S2MPS11_BUCK34_RAMP_SHIFT;
163 ramp_reg = S2MPS11_REG_RAMP;
164 break;
165 case S2MPS11_BUCK5:
166 s2mps11->ramp_delay5 = ramp_delay;
167 ramp_shift = S2MPS11_BUCK5_RAMP_SHIFT;
168 break;
169 case S2MPS11_BUCK6:
170 enable_shift = S2MPS11_BUCK6_RAMP_EN_SHIFT;
171 if (!ramp_delay) {
172 ramp_enable = 0;
173 break;
174 }
175
176 if (ramp_delay > s2mps11->ramp_delay16)
177 s2mps11->ramp_delay16 = ramp_delay;
178 else
179 ramp_delay = s2mps11->ramp_delay16;
180
181 ramp_shift = S2MPS11_BUCK16_RAMP_SHIFT;
182 break;
183 case S2MPS11_BUCK7:
184 case S2MPS11_BUCK8:
185 case S2MPS11_BUCK10:
186 if (ramp_delay > s2mps11->ramp_delay7810)
187 s2mps11->ramp_delay7810 = ramp_delay;
188 else
189 ramp_delay = s2mps11->ramp_delay7810;
190
191 ramp_shift = S2MPS11_BUCK7810_RAMP_SHIFT;
192 break;
193 case S2MPS11_BUCK9:
194 s2mps11->ramp_delay9 = ramp_delay;
195 ramp_shift = S2MPS11_BUCK9_RAMP_SHIFT;
196 break;
197 default:
198 return 0;
199 }
200
201 if (!ramp_enable)
202 goto ramp_disable;
203
204 if (enable_shift) {
205 ret = regmap_update_bits(rdev->regmap, S2MPS11_REG_RAMP,
206 1 << enable_shift, 1 << enable_shift);
207 if (ret) {
208 dev_err(&rdev->dev, "failed to enable ramp rate\n");
209 return ret;
210 }
211 }
212
213 ramp_val = get_ramp_delay(ramp_delay);
214
215 return regmap_update_bits(rdev->regmap, ramp_reg,
216 ramp_val << ramp_shift, 1 << ramp_shift);
217
218ramp_disable:
219 return regmap_update_bits(rdev->regmap, S2MPS11_REG_RAMP, 0,
220 1 << enable_shift);
221}
222
107static struct regulator_ops s2mps11_ldo_ops = { 223static struct regulator_ops s2mps11_ldo_ops = {
108 .list_voltage = regulator_list_voltage_linear, 224 .list_voltage = regulator_list_voltage_linear,
109 .map_voltage = regulator_map_voltage_linear, 225 .map_voltage = regulator_map_voltage_linear,
@@ -124,6 +240,7 @@ static struct regulator_ops s2mps11_buck_ops = {
124 .get_voltage_sel = regulator_get_voltage_sel_regmap, 240 .get_voltage_sel = regulator_get_voltage_sel_regmap,
125 .set_voltage_sel = regulator_set_voltage_sel_regmap, 241 .set_voltage_sel = regulator_set_voltage_sel_regmap,
126 .set_voltage_time_sel = s2mps11_regulator_set_voltage_time_sel, 242 .set_voltage_time_sel = s2mps11_regulator_set_voltage_time_sel,
243 .set_ramp_delay = s2mps11_set_ramp_delay,
127}; 244};
128 245
129#define regulator_desc_ldo1(num) { \ 246#define regulator_desc_ldo1(num) { \
diff --git a/include/linux/mfd/samsung/s2mps11.h b/include/linux/mfd/samsung/s2mps11.h
index 4e94dc65f987..d0d52ea60074 100644
--- a/include/linux/mfd/samsung/s2mps11.h
+++ b/include/linux/mfd/samsung/s2mps11.h
@@ -191,6 +191,17 @@ enum s2mps11_regulators {
191#define S2MPS11_BUCK_N_VOLTAGES (S2MPS11_BUCK_VSEL_MASK + 1) 191#define S2MPS11_BUCK_N_VOLTAGES (S2MPS11_BUCK_VSEL_MASK + 1)
192#define S2MPS11_RAMP_DELAY 25000 /* uV/us */ 192#define S2MPS11_RAMP_DELAY 25000 /* uV/us */
193 193
194
195#define S2MPS11_BUCK2_RAMP_SHIFT 6
196#define S2MPS11_BUCK34_RAMP_SHIFT 4
197#define S2MPS11_BUCK5_RAMP_SHIFT 6
198#define S2MPS11_BUCK16_RAMP_SHIFT 4
199#define S2MPS11_BUCK7810_RAMP_SHIFT 2
200#define S2MPS11_BUCK9_RAMP_SHIFT 0
201#define S2MPS11_BUCK2_RAMP_EN_SHIFT 3
202#define S2MPS11_BUCK3_RAMP_EN_SHIFT 2
203#define S2MPS11_BUCK4_RAMP_EN_SHIFT 1
204#define S2MPS11_BUCK6_RAMP_EN_SHIFT 0
194#define S2MPS11_PMIC_EN_SHIFT 6 205#define S2MPS11_PMIC_EN_SHIFT 6
195#define S2MPS11_REGULATOR_MAX (S2MPS11_REG_MAX - 3) 206#define S2MPS11_REGULATOR_MAX (S2MPS11_REG_MAX - 3)
196 207