blob: 52cc77d69ec24d14cbef99715fecc98d7b31c215 [file] [log] [blame]
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -07001/*
2 * Copyright (c) 2011, Code Aurora Forum. All rights reserved.
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 and
6 * only version 2 as published by the Free Software Foundation.
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 */
13
14#define pr_fmt(fmt) "%s: " fmt, __func__
15
16#include <linux/module.h>
17#include <linux/err.h>
18#include <linux/kernel.h>
19#include <linux/init.h>
20#include <linux/slab.h>
21#include <linux/spinlock.h>
22#include <linux/platform_device.h>
23#include <linux/regulator/driver.h>
24#include <mach/rpm.h>
25#include <mach/rpm-regulator.h>
David Collins6ea0dcb2011-08-16 16:44:43 -070026#include <mach/socinfo.h>
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070027
28#include "rpm_resources.h"
29
30/* Debug Definitions */
31
32enum {
33 MSM_RPM_VREG_DEBUG_REQUEST = BIT(0),
34 MSM_RPM_VREG_DEBUG_VOTE = BIT(1),
35 MSM_RPM_VREG_DEBUG_DUPLICATE = BIT(2),
36 MSM_RPM_VREG_DEBUG_IGNORE_VDD_MEM_DIG = BIT(3),
37};
38
39static int msm_rpm_vreg_debug_mask;
40module_param_named(
41 debug_mask, msm_rpm_vreg_debug_mask, int, S_IRUSR | S_IWUSR
42);
43
44#define REGULATOR_TYPE_LDO 0
45#define REGULATOR_TYPE_SMPS 1
46#define REGULATOR_TYPE_VS 2
47#define REGULATOR_TYPE_NCP 3
48
49#define MICRO_TO_MILLI(uV) ((uV) / 1000)
50#define MILLI_TO_MICRO(mV) ((mV) * 1000)
51
52#define SET_PART(_vreg, _part, _val) \
53 _vreg->req[_vreg->part->_part.word].value \
54 = (_vreg->req[_vreg->part->_part.word].value \
55 & ~vreg->part->_part.mask) \
56 | (((_val) << vreg->part->_part.shift) & vreg->part->_part.mask)
57
58#define GET_PART(_vreg, _part) \
59 ((_vreg->req[_vreg->part->_part.word].value & vreg->part->_part.mask) \
60 >> vreg->part->_part.shift)
61
62struct request_member {
63 int word;
64 unsigned int mask;
65 int shift;
66};
67
68struct rpm_vreg_parts {
69 struct request_member mV; /* voltage: used if voltage is in mV */
70 struct request_member uV; /* voltage: used if voltage is in uV */
71 struct request_member ip; /* peak current in mA */
72 struct request_member pd; /* pull down enable */
73 struct request_member ia; /* average current in mA */
74 struct request_member fm; /* force mode */
75 struct request_member pm; /* power mode */
76 struct request_member pc; /* pin control */
77 struct request_member pf; /* pin function */
78 struct request_member enable_state; /* NCP and switch */
79 struct request_member comp_mode; /* NCP */
80 struct request_member freq; /* frequency: NCP and SMPS */
81 struct request_member freq_clk_src; /* clock source: SMPS */
82 struct request_member hpm; /* switch: control OCP ans SS */
83 int request_len;
84};
85
86#define REQUEST_MEMBER(_word, _mask, _shift) \
87 { \
88 .word = _word, \
89 .mask = _mask, \
90 .shift = _shift, \
91 }
92
93struct rpm_vreg_parts ldo_parts = {
94 .request_len = 2,
95 .uV = REQUEST_MEMBER(0, 0x007FFFFF, 0),
96 .pd = REQUEST_MEMBER(0, 0x00800000, 23),
David Collinsd0903892011-07-14 16:08:30 -070097 .pc = REQUEST_MEMBER(0, 0x0F000000, 24),
98 .pf = REQUEST_MEMBER(0, 0xF0000000, 28),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070099 .ip = REQUEST_MEMBER(1, 0x000003FF, 0),
David Collinsd0903892011-07-14 16:08:30 -0700100 .ia = REQUEST_MEMBER(1, 0x000FFC00, 10),
101 .fm = REQUEST_MEMBER(1, 0x00700000, 20),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700102};
103
104struct rpm_vreg_parts smps_parts = {
105 .request_len = 2,
106 .uV = REQUEST_MEMBER(0, 0x007FFFFF, 0),
107 .pd = REQUEST_MEMBER(0, 0x00800000, 23),
David Collinsd0903892011-07-14 16:08:30 -0700108 .pc = REQUEST_MEMBER(0, 0x0F000000, 24),
109 .pf = REQUEST_MEMBER(0, 0xF0000000, 28),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700110 .ip = REQUEST_MEMBER(1, 0x000003FF, 0),
David Collinsd0903892011-07-14 16:08:30 -0700111 .ia = REQUEST_MEMBER(1, 0x000FFC00, 10),
112 .fm = REQUEST_MEMBER(1, 0x00700000, 20),
113 .pm = REQUEST_MEMBER(1, 0x00800000, 23),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700114 .freq = REQUEST_MEMBER(1, 0x1F000000, 24),
115 .freq_clk_src = REQUEST_MEMBER(1, 0x60000000, 29),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700116};
117
118struct rpm_vreg_parts switch_parts = {
119 .request_len = 1,
120 .enable_state = REQUEST_MEMBER(0, 0x00000001, 0),
121 .pd = REQUEST_MEMBER(0, 0x00000002, 1),
122 .pc = REQUEST_MEMBER(0, 0x0000003C, 2),
123 .pf = REQUEST_MEMBER(0, 0x000003C0, 6),
124 .hpm = REQUEST_MEMBER(0, 0x00000C00, 10),
125};
126
127struct rpm_vreg_parts ncp_parts = {
128 .request_len = 1,
129 .uV = REQUEST_MEMBER(0, 0x007FFFFF, 0),
130 .enable_state = REQUEST_MEMBER(0, 0x00800000, 23),
131 .comp_mode = REQUEST_MEMBER(0, 0x01000000, 24),
132 .freq = REQUEST_MEMBER(0, 0x3E000000, 25),
133};
134
135struct vreg_range {
136 int min_uV;
137 int max_uV;
138 int step_uV;
139 unsigned n_voltages;
140};
141
142struct vreg_set_points {
143 struct vreg_range *range;
144 int count;
145 unsigned n_voltages;
146};
147
148#define VOLTAGE_RANGE(_min_uV, _max_uV, _step_uV) \
149 { \
150 .min_uV = _min_uV, \
151 .max_uV = _max_uV, \
152 .step_uV = _step_uV, \
153 }
154
155static struct vreg_range pldo_ranges[] = {
156 VOLTAGE_RANGE( 750000, 1487500, 12500),
157 VOLTAGE_RANGE(1500000, 3075000, 25000),
158 VOLTAGE_RANGE(3100000, 4900000, 50000),
159};
160
161static struct vreg_range nldo_ranges[] = {
162 VOLTAGE_RANGE( 750000, 1537500, 12500),
163};
164
165static struct vreg_range nldo1200_ranges[] = {
166 VOLTAGE_RANGE( 375000, 743750, 6250),
167 VOLTAGE_RANGE( 750000, 1537500, 12500),
168};
169
170static struct vreg_range smps_ranges[] = {
171 VOLTAGE_RANGE( 375000, 737500, 12500),
172 VOLTAGE_RANGE( 750000, 1487500, 12500),
173 VOLTAGE_RANGE(1500000, 3075000, 25000),
174};
175
176static struct vreg_range ftsmps_ranges[] = {
177 VOLTAGE_RANGE( 350000, 650000, 50000),
178 VOLTAGE_RANGE( 700000, 1400000, 12500),
179 VOLTAGE_RANGE(1500000, 3300000, 50000),
180};
181
182static struct vreg_range ncp_ranges[] = {
183 VOLTAGE_RANGE(1500000, 3050000, 50000),
184};
185
186#define SET_POINTS(_ranges) \
187{ \
188 .range = _ranges, \
189 .count = ARRAY_SIZE(_ranges), \
190};
191
192static struct vreg_set_points pldo_set_points = SET_POINTS(pldo_ranges);
193static struct vreg_set_points nldo_set_points = SET_POINTS(nldo_ranges);
194static struct vreg_set_points nldo1200_set_points = SET_POINTS(nldo1200_ranges);
195static struct vreg_set_points smps_set_points = SET_POINTS(smps_ranges);
196static struct vreg_set_points ftsmps_set_points = SET_POINTS(ftsmps_ranges);
197static struct vreg_set_points ncp_set_points = SET_POINTS(ncp_ranges);
198
199/*
200 * This is used when voting for LPM or HPM by subtracting or adding to the
201 * hpm_min_load of a regulator. It has units of uA.
202 */
203#define LOAD_THRESHOLD_STEP 1000
204
205/* This is the maximum uA load that can be passed to the RPM. */
206#define MAX_POSSIBLE_LOAD (MILLI_TO_MICRO(0xFFF))
207
208struct vreg {
209 struct msm_rpm_iv_pair req[2];
210 struct msm_rpm_iv_pair prev_active_req[2];
211 struct msm_rpm_iv_pair prev_sleep_req[2];
212 struct rpm_regulator_init_data pdata;
213 struct regulator_dev *rdev;
214 struct regulator_dev *rdev_pc;
215 const char *name;
216 struct vreg_set_points *set_points;
217 struct rpm_vreg_parts *part;
218 int type;
219 enum rpm_vreg_id id;
220 struct mutex pc_lock;
221 int save_uV;
222 int mode;
223 bool is_enabled;
224 bool is_enabled_pc;
225 const int hpm_min_load;
226 int active_min_uV_vote[RPM_VREG_VOTER_COUNT];
227 int sleep_min_uV_vote[RPM_VREG_VOTER_COUNT];
228
229};
230
231#define LDO(_id, _ranges, _hpm_min_load) \
232 [RPM_VREG_ID_PM8921_##_id] = { \
233 .req = { \
234 [0] = { .id = MSM_RPM_ID_PM8921_##_id##_0, }, \
235 [1] = { .id = MSM_RPM_ID_PM8921_##_id##_1, }, \
236 }, \
237 .hpm_min_load = RPM_VREG_##_hpm_min_load##_HPM_MIN_LOAD, \
238 .type = REGULATOR_TYPE_LDO, \
239 .set_points = &_ranges##_set_points, \
240 .part = &ldo_parts, \
241 .id = RPM_VREG_ID_PM8921_##_id, \
242 }
243
244#define SMPS(_id, _ranges, _hpm_min_load) \
245 [RPM_VREG_ID_PM8921_##_id] = { \
246 .req = { \
247 [0] = { .id = MSM_RPM_ID_PM8921_##_id##_0, }, \
248 [1] = { .id = MSM_RPM_ID_PM8921_##_id##_1, }, \
249 }, \
250 .hpm_min_load = RPM_VREG_##_hpm_min_load##_HPM_MIN_LOAD, \
251 .type = REGULATOR_TYPE_SMPS, \
252 .set_points = &_ranges##_set_points, \
253 .part = &smps_parts, \
254 .id = RPM_VREG_ID_PM8921_##_id, \
255 }
256
257#define LVS(_id) \
258 [RPM_VREG_ID_PM8921_##_id] = { \
259 .req = { \
260 [0] = { .id = MSM_RPM_ID_PM8921_##_id, }, \
261 [1] = { .id = -1, }, \
262 }, \
263 .type = REGULATOR_TYPE_VS, \
264 .part = &switch_parts, \
265 .id = RPM_VREG_ID_PM8921_##_id, \
266 }
267
268#define MVS(_vreg_id, _rpm_id) \
269 [RPM_VREG_ID_PM8921_##_vreg_id] = { \
270 .req = { \
271 [0] = { .id = MSM_RPM_ID_##_rpm_id, }, \
272 [1] = { .id = -1, }, \
273 }, \
274 .type = REGULATOR_TYPE_VS, \
275 .part = &switch_parts, \
276 .id = RPM_VREG_ID_PM8921_##_vreg_id, \
277 }
278
279#define NCP(_id) \
280 [RPM_VREG_ID_PM8921_##_id] = { \
281 .req = { \
282 [0] = { .id = MSM_RPM_ID_##_id##_0, }, \
283 [1] = { .id = MSM_RPM_ID_##_id##_1, }, \
284 }, \
285 .type = REGULATOR_TYPE_NCP, \
286 .set_points = &ncp_set_points, \
287 .part = &ncp_parts, \
288 .id = RPM_VREG_ID_PM8921_##_id, \
289 }
290
291static struct vreg vregs[] = {
292 LDO(L1, nldo, LDO_150),
293 LDO(L2, nldo, LDO_150),
294 LDO(L3 , pldo, LDO_150),
295 LDO(L4, pldo, LDO_50),
296 LDO(L5, pldo, LDO_300),
297 LDO(L6, pldo, LDO_600),
298 LDO(L7, pldo, LDO_150),
299 LDO(L8, pldo, LDO_300),
300 LDO(L9, pldo, LDO_300),
301 LDO(L10, pldo, LDO_600),
302 LDO(L11, pldo, LDO_150),
303 LDO(L12, nldo, LDO_150),
304 LDO(L14, pldo, LDO_50),
305 LDO(L15, pldo, LDO_150),
306 LDO(L16, pldo, LDO_300),
307 LDO(L17, pldo, LDO_150),
308 LDO(L18, nldo, LDO_150),
309 LDO(L21, pldo, LDO_150),
310 LDO(L22, pldo, LDO_150),
311 LDO(L23, pldo, LDO_150),
312 LDO(L24, nldo1200, LDO_1200),
313 LDO(L25, nldo1200, LDO_1200),
314 LDO(L26, nldo1200, LDO_1200),
315 LDO(L27, nldo1200, LDO_1200),
316 LDO(L28, nldo1200, LDO_1200),
317 LDO(L29, pldo, LDO_150),
318
319 SMPS(S1, smps, SMPS_1500),
320 SMPS(S2, smps, SMPS_1500),
321 SMPS(S3, smps, SMPS_1500),
322 SMPS(S4, smps, SMPS_1500),
323 SMPS(S5, ftsmps, SMPS_2000),
324 SMPS(S6, ftsmps, SMPS_2000),
325 SMPS(S7, smps, SMPS_1500),
326 SMPS(S8, smps, SMPS_1500),
327
328 LVS(LVS1),
329 LVS(LVS2),
330 LVS(LVS3),
331 LVS(LVS4),
332 LVS(LVS5),
333 LVS(LVS6),
334 LVS(LVS7),
335 MVS(USB_OTG, USB_OTG_SWITCH),
336 MVS(HDMI_MVS, HDMI_SWITCH),
337
338 NCP(NCP),
339};
340
341#define vreg_err(vreg, fmt, ...) \
342 pr_err("%s: " fmt, vreg->name, ##__VA_ARGS__)
343
344#define VREG_ID_IS_VDD_MEM_OR_DIG(id) \
345 ((id == RPM_VREG_ID_PM8921_L24) || (id == RPM_VREG_ID_PM8921_S3))
346
347const char *pin_func_label[] = {
348 [RPM_VREG_PIN_FN_DONT_CARE] = "don't care",
349 [RPM_VREG_PIN_FN_ENABLE] = "on/off",
350 [RPM_VREG_PIN_FN_MODE] = "HPM/LPM",
351 [RPM_VREG_PIN_FN_SLEEP_B] = "sleep_b",
352 [RPM_VREG_PIN_FN_NONE] = "none",
353};
354
355const char *force_mode_label[] = {
356 [RPM_VREG_FORCE_MODE_NONE] = "none",
357 [RPM_VREG_FORCE_MODE_LPM] = "LPM",
358 [RPM_VREG_FORCE_MODE_AUTO] = "auto",
359 [RPM_VREG_FORCE_MODE_HPM] = "HPM",
360 [RPM_VREG_FORCE_MODE_BYPASS] = "BYP",
361};
362
363const char *power_mode_label[] = {
364 [RPM_VREG_POWER_MODE_HYSTERETIC] = "HYS",
365 [RPM_VREG_POWER_MODE_PWM] = "PWM",
366};
367
368static void rpm_regulator_req(struct vreg *vreg, int set)
369{
370 int uV, ip, fm, pm, pc, pf, pd, ia, freq, clk, state, hpm, comp_mode;
371 const char *pf_label = "", *fm_label = "", *pc_total = "";
372 const char *pc_en0 = "", *pc_en1 = "", *pc_en2 = "", *pc_en3 = "";
373 const char *pm_label = "";
374
375 /* Suppress VDD_MEM and VDD_DIG printing. */
376 if ((msm_rpm_vreg_debug_mask & MSM_RPM_VREG_DEBUG_IGNORE_VDD_MEM_DIG)
377 && VREG_ID_IS_VDD_MEM_OR_DIG(vreg->id))
378 return;
379
380 if (vreg->part->uV.mask)
381 uV = GET_PART(vreg, uV);
382 else
383 uV = MILLI_TO_MICRO(GET_PART(vreg, mV));
384
385 ip = GET_PART(vreg, ip);
386 fm = GET_PART(vreg, fm);
387 pm = GET_PART(vreg, pm);
388 pc = GET_PART(vreg, pc);
389 pf = GET_PART(vreg, pf);
390 pd = GET_PART(vreg, pd);
391 ia = GET_PART(vreg, ia);
392 freq = GET_PART(vreg, freq);
393 clk = GET_PART(vreg, freq_clk_src);
394 state = GET_PART(vreg, enable_state);
395 hpm = GET_PART(vreg, hpm);
396 comp_mode = GET_PART(vreg, comp_mode);
397
398 if (pf >= 0 && pf < ARRAY_SIZE(pin_func_label))
399 pf_label = pin_func_label[pf];
400
401 if (fm >= 0 && fm < ARRAY_SIZE(force_mode_label))
402 fm_label = force_mode_label[fm];
403
404 if (pm >= 0 && pm < ARRAY_SIZE(power_mode_label))
405 pm_label = power_mode_label[pm];
406
407 if (pc & RPM_VREG_PIN_CTRL_EN0)
408 pc_en0 = " D1";
409 if (pc & RPM_VREG_PIN_CTRL_EN1)
410 pc_en1 = " A0";
411 if (pc & RPM_VREG_PIN_CTRL_EN2)
412 pc_en2 = " A1";
413 if (pc & RPM_VREG_PIN_CTRL_EN3)
414 pc_en3 = " A2";
415 if (pc == RPM_VREG_PIN_CTRL_NONE)
416 pc_total = " none";
417
418 switch (vreg->type) {
419 case REGULATOR_TYPE_LDO:
420 pr_info("%s %-9s: s=%c, v=%7d uV, ip=%4d mA, fm=%s (%d), "
421 "pc=%s%s%s%s%s (%d), pf=%s (%d), pd=%s (%d), "
422 "ia=%4d mA; req[0]={%d, 0x%08X}, req[1]={%d, 0x%08X}\n",
423 (set == MSM_RPM_CTX_SET_0 ? "sending " : "buffered"),
424 vreg->name,
425 (set == MSM_RPM_CTX_SET_0 ? 'A' : 'S'), uV, ip,
426 fm_label, fm, pc_en0, pc_en1, pc_en2, pc_en3, pc_total,
427 pc, pf_label, pf, (pd == 1 ? "Y" : "N"), pd, ia,
428 vreg->req[0].id, vreg->req[0].value,
429 vreg->req[1].id, vreg->req[1].value);
430 break;
431 case REGULATOR_TYPE_SMPS:
432 pr_info("%s %-9s: s=%c, v=%7d uV, ip=%4d mA, fm=%s (%d), "
433 "pc=%s%s%s%s%s (%d), pf=%s (%d), pd=%s (%d), "
434 "ia=%4d mA, freq=%2d, pm=%s (%d), clk_src=%d; "
435 "req[0]={%d, 0x%08X}, req[1]={%d, 0x%08X}\n",
436 (set == MSM_RPM_CTX_SET_0 ? "sending " : "buffered"),
437 vreg->name,
438 (set == MSM_RPM_CTX_SET_0 ? 'A' : 'S'), uV, ip,
439 fm_label, fm, pc_en0, pc_en1, pc_en2, pc_en3, pc_total,
440 pc, pf_label, pf, (pd == 1 ? "Y" : "N"), pd, ia, freq,
441 pm_label, pm, clk, vreg->req[0].id, vreg->req[0].value,
442 vreg->req[1].id, vreg->req[1].value);
443 break;
444 case REGULATOR_TYPE_VS:
445 pr_info("%s %-9s: s=%c, state=%s (%d), pd=%s (%d), "
446 "pc =%s%s%s%s%s (%d), pf=%s (%d), hpm=%d; "
447 "req[0]={%d, 0x%08X}\n",
448 (set == MSM_RPM_CTX_SET_0 ? "sending " : "buffered"),
449 vreg->name, (set == MSM_RPM_CTX_SET_0 ? 'A' : 'S'),
450 (state == 1 ? "on" : "off"), state,
451 (pd == 1 ? "Y" : "N"), pd, pc_en0, pc_en1, pc_en2,
452 pc_en3, pc_total, pc, pf_label, pf, hpm,
453 vreg->req[0].id, vreg->req[0].value);
454 break;
455 case REGULATOR_TYPE_NCP:
456 pr_info("%s %-9s: s=%c, v=-%7d uV, state=%s (%d), freq=%2d, "
457 "comp=%d; req[0]={%d, 0x%08X}\n",
458 (set == MSM_RPM_CTX_SET_0 ? "sending " : "buffered"),
459 vreg->name, (set == MSM_RPM_CTX_SET_0 ? 'A' : 'S'),
460 uV, (state == 1 ? "on" : "off"), state, freq, comp_mode,
461 vreg->req[0].id, vreg->req[0].value);
462 break;
463 }
464}
465
466static void rpm_regulator_vote(struct vreg *vreg, enum rpm_vreg_voter voter,
467 int set, int voter_uV, int aggregate_uV)
468{
469 /* Suppress VDD_MEM and VDD_DIG printing. */
470 if ((msm_rpm_vreg_debug_mask & MSM_RPM_VREG_DEBUG_IGNORE_VDD_MEM_DIG)
471 && VREG_ID_IS_VDD_MEM_OR_DIG(vreg->id))
472 return;
473
474 pr_info("vote received %-9s: voter=%d, set=%c, v_voter=%7d uV, "
475 "v_aggregate=%7d uV\n", vreg->name, voter,
476 (set == 0 ? 'A' : 'S'), voter_uV, aggregate_uV);
477}
478
479static void rpm_regulator_duplicate(struct vreg *vreg, int set, int cnt)
480{
481 /* Suppress VDD_MEM and VDD_DIG printing. */
482 if ((msm_rpm_vreg_debug_mask & MSM_RPM_VREG_DEBUG_IGNORE_VDD_MEM_DIG)
483 && VREG_ID_IS_VDD_MEM_OR_DIG(vreg->id))
484 return;
485
486 if (cnt == 2)
487 pr_info("ignored request %-9s: set=%c; req[0]={%d, 0x%08X}, "
488 "req[1]={%d, 0x%08X}\n", vreg->name,
489 (set == 0 ? 'A' : 'S'),
490 vreg->req[0].id, vreg->req[0].value,
491 vreg->req[1].id, vreg->req[1].value);
492 else if (cnt == 1)
493 pr_info("ignored request %-9s: set=%c; req[0]={%d, 0x%08X}\n",
494 vreg->name, (set == 0 ? 'A' : 'S'),
495 vreg->req[0].id, vreg->req[0].value);
496}
497
498/* Spin lock needed for sleep-selectable regulators. */
499static DEFINE_SPINLOCK(pm8921_noirq_lock);
500
501static int voltage_from_req(struct vreg *vreg)
502{
503 int uV = 0;
504
505 if (vreg->part->uV.mask)
506 uV = GET_PART(vreg, uV);
507 else
508 uV = MILLI_TO_MICRO(GET_PART(vreg, mV));
509
510 return uV;
511}
512
513static void voltage_to_req(int uV, struct vreg *vreg)
514{
515 if (vreg->part->uV.mask)
516 SET_PART(vreg, uV, uV);
517 else
518 SET_PART(vreg, mV, MICRO_TO_MILLI(uV));
519}
520
521static int vreg_send_request(struct vreg *vreg, enum rpm_vreg_voter voter,
522 int set, unsigned mask0, unsigned val0,
523 unsigned mask1, unsigned val1, unsigned cnt,
524 int update_voltage)
525{
526 struct msm_rpm_iv_pair *prev_req;
527 int rc = 0, max_uV_vote = 0;
528 unsigned prev0, prev1;
529 int *min_uV_vote;
530 int i;
531
532 if (set == MSM_RPM_CTX_SET_0) {
533 min_uV_vote = vreg->active_min_uV_vote;
534 prev_req = vreg->prev_active_req;
535 } else {
536 min_uV_vote = vreg->sleep_min_uV_vote;
537 prev_req = vreg->prev_sleep_req;
538 }
539
540 prev0 = vreg->req[0].value;
541 vreg->req[0].value &= ~mask0;
542 vreg->req[0].value |= val0 & mask0;
543
544 prev1 = vreg->req[1].value;
545 vreg->req[1].value &= ~mask1;
546 vreg->req[1].value |= val1 & mask1;
547
548 if (update_voltage)
549 min_uV_vote[voter] = voltage_from_req(vreg);
550
551 /* Find the highest voltage voted for and use it. */
552 for (i = 0; i < RPM_VREG_VOTER_COUNT; i++)
553 max_uV_vote = max(max_uV_vote, min_uV_vote[i]);
554 voltage_to_req(max_uV_vote, vreg);
555
556 if (msm_rpm_vreg_debug_mask & MSM_RPM_VREG_DEBUG_VOTE)
557 rpm_regulator_vote(vreg, voter, set, min_uV_vote[voter],
558 max_uV_vote);
559
560 /* Ignore duplicate requests */
561 if (vreg->req[0].value != prev_req[0].value ||
562 vreg->req[1].value != prev_req[1].value) {
563 rc = msm_rpmrs_set_noirq(set, vreg->req, cnt);
564 if (rc) {
565 vreg->req[0].value = prev0;
566 vreg->req[1].value = prev1;
567
568 vreg_err(vreg, "msm_rpmrs_set_noirq failed - "
569 "set=%s, id=%d, rc=%d\n",
570 (set == MSM_RPM_CTX_SET_0 ? "active" : "sleep"),
571 vreg->req[0].id, rc);
572 } else {
573 /* Only save if nonzero and active set. */
574 if (max_uV_vote && (set == MSM_RPM_CTX_SET_0))
575 vreg->save_uV = max_uV_vote;
576 if (msm_rpm_vreg_debug_mask
577 & MSM_RPM_VREG_DEBUG_REQUEST)
578 rpm_regulator_req(vreg, set);
579 prev_req[0].value = vreg->req[0].value;
580 prev_req[1].value = vreg->req[1].value;
581 }
582 } else if (msm_rpm_vreg_debug_mask & MSM_RPM_VREG_DEBUG_DUPLICATE) {
583 rpm_regulator_duplicate(vreg, set, cnt);
584 }
585
586 return rc;
587}
588
589static int vreg_set_noirq(struct vreg *vreg, enum rpm_vreg_voter voter,
590 int sleep, unsigned mask0, unsigned val0,
591 unsigned mask1, unsigned val1, unsigned cnt,
592 int update_voltage)
593{
594 unsigned int s_mask[2] = {mask0, mask1}, s_val[2] = {val0, val1};
595 unsigned long flags;
596 int rc;
597
598 if (voter < 0 || voter >= RPM_VREG_VOTER_COUNT)
599 return -EINVAL;
600
601 spin_lock_irqsave(&pm8921_noirq_lock, flags);
602
603 /*
604 * Send sleep set request first so that subsequent set_mode, etc calls
605 * use the voltage from the active set.
606 */
607 if (sleep)
608 rc = vreg_send_request(vreg, voter, MSM_RPM_CTX_SET_SLEEP,
609 mask0, val0, mask1, val1, cnt, update_voltage);
610 else {
611 /*
612 * Vote for 0 V in the sleep set when active set-only is
613 * specified. This ensures that a disable vote will be issued
614 * at some point for the sleep set of the regulator.
615 */
616 if (vreg->part->uV.mask) {
617 s_val[vreg->part->uV.word] = 0 << vreg->part->uV.shift;
618 s_mask[vreg->part->uV.word] = vreg->part->uV.mask;
619 } else {
620 s_val[vreg->part->mV.word] = 0 << vreg->part->mV.shift;
621 s_mask[vreg->part->mV.word] = vreg->part->mV.mask;
622 }
623
624 rc = vreg_send_request(vreg, voter, MSM_RPM_CTX_SET_SLEEP,
625 s_mask[0], s_val[0], s_mask[1], s_val[1],
626 cnt, update_voltage);
627 }
628
629 rc = vreg_send_request(vreg, voter, MSM_RPM_CTX_SET_0, mask0, val0,
630 mask1, val1, cnt, update_voltage);
631
632 spin_unlock_irqrestore(&pm8921_noirq_lock, flags);
633
634 return rc;
635}
636
637/**
638 * rpm_vreg_set_voltage - vote for a min_uV value of specified regualtor
639 * @vreg: ID for regulator
640 * @voter: ID for the voter
641 * @min_uV: minimum acceptable voltage (in uV) that is voted for
642 * @max_uV: maximum acceptable voltage (in uV) that is voted for
643 * @sleep_also: 0 for active set only, non-0 for active set and sleep set
644 *
645 * Returns 0 on success or errno.
646 *
647 * This function is used to vote for the voltage of a regulator without
648 * using the regulator framework. It is needed by consumers which hold spin
649 * locks or have interrupts disabled because the regulator framework can sleep.
650 * It is also needed by consumers which wish to only vote for active set
651 * regulator voltage.
652 *
653 * If sleep_also == 0, then a sleep-set value of 0V will be voted for.
654 *
655 * This function may only be called for regulators which have the sleep flag
656 * specified in their private data.
657 */
658int rpm_vreg_set_voltage(enum rpm_vreg_id vreg_id, enum rpm_vreg_voter voter,
659 int min_uV, int max_uV, int sleep_also)
660{
661 unsigned int mask[2] = {0}, val[2] = {0};
662 struct vreg_range *range;
663 struct vreg *vreg;
664 int uV = min_uV;
665 int lim_min_uV, lim_max_uV, i, rc;
666
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700667 if (vreg_id < 0 || vreg_id > RPM_VREG_ID_PM8921_MAX_REAL) {
668 pr_err("invalid regulator id=%d\n", vreg_id);
669 return -EINVAL;
670 }
David Collins6ea0dcb2011-08-16 16:44:43 -0700671
672 /*
673 * TODO: make this function a no-op for 8064 so that it can be called by
674 * consumers on 8064 before RPM capabilities are present. (needed for
675 * acpuclock driver)
676 */
677 if (cpu_is_apq8064())
678 return 0;
679
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700680 vreg = &vregs[vreg_id];
681 range = &vreg->set_points->range[0];
682
683 if (!vreg->pdata.sleep_selectable) {
684 vreg_err(vreg, "regulator is not marked sleep selectable\n");
685 return -EINVAL;
686 }
687
688 /*
689 * Check if request voltage is outside of allowed range. The regulator
690 * core has already checked that constraint range is inside of the
691 * physically allowed range.
692 */
693 lim_min_uV = vreg->pdata.init_data.constraints.min_uV;
694 lim_max_uV = vreg->pdata.init_data.constraints.max_uV;
695
696 if (uV < lim_min_uV && max_uV >= lim_min_uV)
697 uV = lim_min_uV;
698
699 if (uV < lim_min_uV || uV > lim_max_uV) {
700 vreg_err(vreg,
701 "request v=[%d, %d] is outside allowed v=[%d, %d]\n",
702 min_uV, max_uV, lim_min_uV, lim_max_uV);
703 return -EINVAL;
704 }
705
706 /* Find the range which uV is inside of. */
David Collins935c41a2011-09-08 10:54:18 -0700707 for (i = vreg->set_points->count - 1; i > 0; i--) {
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700708 if (uV > vreg->set_points->range[i - 1].max_uV) {
709 range = &vreg->set_points->range[i];
710 break;
711 }
712 }
713
714 /*
715 * Force uV to be an allowed set point and apply a ceiling function
716 * to non-set point values.
717 */
718 uV = (uV - range->min_uV + range->step_uV - 1) / range->step_uV;
719 uV = uV * range->step_uV + range->min_uV;
720
721 if (vreg->part->uV.mask) {
722 val[vreg->part->uV.word] = uV << vreg->part->uV.shift;
723 mask[vreg->part->uV.word] = vreg->part->uV.mask;
724 } else {
725 val[vreg->part->mV.word]
726 = MICRO_TO_MILLI(uV) << vreg->part->mV.shift;
727 mask[vreg->part->mV.word] = vreg->part->mV.mask;
728 }
729
730 rc = vreg_set_noirq(vreg, voter, sleep_also, mask[0], val[0], mask[1],
731 val[1], vreg->part->request_len, 1);
732 if (rc)
733 vreg_err(vreg, "vreg_set_noirq failed, rc=%d\n", rc);
734
735 return rc;
736}
737EXPORT_SYMBOL_GPL(rpm_vreg_set_voltage);
738
739/**
740 * rpm_vreg_set_frequency - sets the frequency of a switching regulator
741 * @vreg: ID for regulator
742 * @freq: enum corresponding to desired frequency
743 *
744 * Returns 0 on success or errno.
745 */
746int rpm_vreg_set_frequency(enum rpm_vreg_id vreg_id, enum rpm_vreg_freq freq)
747{
748 unsigned int mask[2] = {0}, val[2] = {0};
749 struct vreg *vreg;
750 int rc;
751
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700752 if (vreg_id < 0 || vreg_id > RPM_VREG_ID_PM8921_MAX_REAL) {
753 pr_err("invalid regulator id=%d\n", vreg_id);
754 return -EINVAL;
755 }
David Collins6ea0dcb2011-08-16 16:44:43 -0700756
757 /*
758 * TODO: make this function a no-op for 8064 so that it can be called by
759 * consumers on 8064 before RPM capabilities are present.
760 */
761 if (cpu_is_apq8064())
762 return 0;
763
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700764 vreg = &vregs[vreg_id];
765
766 if (freq < 0 || freq > RPM_VREG_FREQ_1p20) {
767 vreg_err(vreg, "invalid frequency=%d\n", freq);
768 return -EINVAL;
769 }
770 if (!vreg->pdata.sleep_selectable) {
771 vreg_err(vreg, "regulator is not marked sleep selectable\n");
772 return -EINVAL;
773 }
774 if (!vreg->part->freq.mask) {
775 vreg_err(vreg, "frequency not supported\n");
776 return -EINVAL;
777 }
778
779 val[vreg->part->freq.word] = freq << vreg->part->freq.shift;
780 mask[vreg->part->freq.word] = vreg->part->freq.mask;
781
782 rc = vreg_set_noirq(vreg, RPM_VREG_VOTER_REG_FRAMEWORK, 1, mask[0],
783 val[0], mask[1], val[1], vreg->part->request_len, 0);
784 if (rc)
785 vreg_err(vreg, "vreg_set failed, rc=%d\n", rc);
786
787 return rc;
788}
789EXPORT_SYMBOL_GPL(rpm_vreg_set_frequency);
790
791static inline int vreg_hpm_min_uA(struct vreg *vreg)
792{
793 return vreg->hpm_min_load;
794}
795
796static inline int vreg_lpm_max_uA(struct vreg *vreg)
797{
798 return vreg->hpm_min_load - LOAD_THRESHOLD_STEP;
799}
800
801static inline unsigned saturate_peak_load(struct vreg *vreg, unsigned load_uA)
802{
803 unsigned load_max
804 = MILLI_TO_MICRO(vreg->part->ip.mask >> vreg->part->ip.shift);
805
806 return (load_uA > load_max ? load_max : load_uA);
807}
808
809static inline unsigned saturate_avg_load(struct vreg *vreg, unsigned load_uA)
810{
811 unsigned load_max
812 = MILLI_TO_MICRO(vreg->part->ia.mask >> vreg->part->ia.shift);
813 return (load_uA > load_max ? load_max : load_uA);
814}
815
816/* Change vreg->req, but do not send it to the RPM. */
817static int vreg_store(struct vreg *vreg, unsigned mask0, unsigned val0,
818 unsigned mask1, unsigned val1)
819{
820 unsigned long flags = 0;
821
822 if (vreg->pdata.sleep_selectable)
823 spin_lock_irqsave(&pm8921_noirq_lock, flags);
824
825 vreg->req[0].value &= ~mask0;
826 vreg->req[0].value |= val0 & mask0;
827
828 vreg->req[1].value &= ~mask1;
829 vreg->req[1].value |= val1 & mask1;
830
831 if (vreg->pdata.sleep_selectable)
832 spin_unlock_irqrestore(&pm8921_noirq_lock, flags);
833
834 return 0;
835}
836
837static int vreg_set(struct vreg *vreg, unsigned mask0, unsigned val0,
838 unsigned mask1, unsigned val1, unsigned cnt)
839{
840 unsigned prev0 = 0, prev1 = 0;
841 int rc;
842
843 /*
844 * Bypass the normal route for regulators that can be called to change
845 * just the active set values.
846 */
847 if (vreg->pdata.sleep_selectable)
848 return vreg_set_noirq(vreg, RPM_VREG_VOTER_REG_FRAMEWORK, 1,
849 mask0, val0, mask1, val1, cnt, 1);
850
851 prev0 = vreg->req[0].value;
852 vreg->req[0].value &= ~mask0;
853 vreg->req[0].value |= val0 & mask0;
854
855 prev1 = vreg->req[1].value;
856 vreg->req[1].value &= ~mask1;
857 vreg->req[1].value |= val1 & mask1;
858
859 /* Ignore duplicate requests */
860 if (vreg->req[0].value == vreg->prev_active_req[0].value &&
861 vreg->req[1].value == vreg->prev_active_req[1].value) {
862 if (msm_rpm_vreg_debug_mask & MSM_RPM_VREG_DEBUG_DUPLICATE)
863 rpm_regulator_duplicate(vreg, MSM_RPM_CTX_SET_0, cnt);
864 return 0;
865 }
866
867 rc = msm_rpm_set(MSM_RPM_CTX_SET_0, vreg->req, cnt);
868 if (rc) {
869 vreg->req[0].value = prev0;
870 vreg->req[1].value = prev1;
871
872 vreg_err(vreg, "msm_rpm_set failed, set=active, id=%d, rc=%d\n",
873 vreg->req[0].id, rc);
874 } else {
875 if (msm_rpm_vreg_debug_mask & MSM_RPM_VREG_DEBUG_REQUEST)
876 rpm_regulator_req(vreg, MSM_RPM_CTX_SET_0);
877 vreg->prev_active_req[0].value = vreg->req[0].value;
878 vreg->prev_active_req[1].value = vreg->req[1].value;
879 }
880
881 return rc;
882}
883
884static int vreg_is_enabled(struct regulator_dev *rdev)
885{
886 struct vreg *vreg = rdev_get_drvdata(rdev);
887 int enabled;
888
889 mutex_lock(&vreg->pc_lock);
890 enabled = vreg->is_enabled;
891 mutex_unlock(&vreg->pc_lock);
892
893 return enabled;
894}
895
896static void set_enable(struct vreg *vreg, unsigned int *mask, unsigned int *val)
897{
898 switch (vreg->type) {
899 case REGULATOR_TYPE_LDO:
900 case REGULATOR_TYPE_SMPS:
901 /* Enable by setting a voltage. */
902 if (vreg->part->uV.mask) {
903 val[vreg->part->uV.word]
904 |= vreg->save_uV << vreg->part->uV.shift;
905 mask[vreg->part->uV.word] |= vreg->part->uV.mask;
906 } else {
907 val[vreg->part->mV.word]
908 |= MICRO_TO_MILLI(vreg->save_uV)
909 << vreg->part->mV.shift;
910 mask[vreg->part->mV.word] |= vreg->part->mV.mask;
911 }
912 break;
913 case REGULATOR_TYPE_VS:
914 case REGULATOR_TYPE_NCP:
915 /* Enable by setting enable_state. */
916 val[vreg->part->enable_state.word]
917 |= RPM_VREG_STATE_ON << vreg->part->enable_state.shift;
918 mask[vreg->part->enable_state.word]
919 |= vreg->part->enable_state.mask;
920 }
921}
922
923static int vreg_enable(struct regulator_dev *rdev)
924{
925 struct vreg *vreg = rdev_get_drvdata(rdev);
926 unsigned int mask[2] = {0}, val[2] = {0};
927 int rc = 0;
928
929 set_enable(vreg, mask, val);
930
931 mutex_lock(&vreg->pc_lock);
932
933 rc = vreg_set(vreg, mask[0], val[0], mask[1], val[1],
934 vreg->part->request_len);
935 if (!rc)
936 vreg->is_enabled = true;
937
938 mutex_unlock(&vreg->pc_lock);
939
940 if (rc)
941 vreg_err(vreg, "vreg_set failed, rc=%d\n", rc);
942
943 return rc;
944}
945
946static void set_disable(struct vreg *vreg, unsigned int *mask,
947 unsigned int *val)
948{
949 switch (vreg->type) {
950 case REGULATOR_TYPE_LDO:
951 case REGULATOR_TYPE_SMPS:
952 /* Disable by setting a voltage of 0 uV. */
953 if (vreg->part->uV.mask) {
954 val[vreg->part->uV.word] |= 0 << vreg->part->uV.shift;
955 mask[vreg->part->uV.word] |= vreg->part->uV.mask;
956 } else {
957 val[vreg->part->mV.word] |= 0 << vreg->part->mV.shift;
958 mask[vreg->part->mV.word] |= vreg->part->mV.mask;
959 }
960 break;
961 case REGULATOR_TYPE_VS:
962 case REGULATOR_TYPE_NCP:
963 /* Disable by setting enable_state. */
964 val[vreg->part->enable_state.word]
965 |= RPM_VREG_STATE_OFF << vreg->part->enable_state.shift;
966 mask[vreg->part->enable_state.word]
967 |= vreg->part->enable_state.mask;
968 }
969}
970
971static int vreg_disable(struct regulator_dev *rdev)
972{
973 struct vreg *vreg = rdev_get_drvdata(rdev);
974 unsigned int mask[2] = {0}, val[2] = {0};
975 int rc = 0;
976
977 set_disable(vreg, mask, val);
978
979 mutex_lock(&vreg->pc_lock);
980
981 /* Only disable if pin control is not in use. */
982 if (!vreg->is_enabled_pc)
983 rc = vreg_set(vreg, mask[0], val[0], mask[1], val[1],
984 vreg->part->request_len);
985
986 if (!rc)
987 vreg->is_enabled = false;
988
989 mutex_unlock(&vreg->pc_lock);
990
991 if (rc)
992 vreg_err(vreg, "vreg_set failed, rc=%d\n", rc);
993
994 return rc;
995}
996
997static int vreg_set_voltage(struct regulator_dev *rdev, int min_uV, int max_uV,
998 unsigned *selector)
999{
1000 struct vreg *vreg = rdev_get_drvdata(rdev);
1001 struct vreg_range *range = &vreg->set_points->range[0];
1002 unsigned int mask[2] = {0}, val[2] = {0};
1003 int rc = 0, uV = min_uV;
1004 int lim_min_uV, lim_max_uV, i;
1005
1006 /* Check if request voltage is outside of physically settable range. */
1007 lim_min_uV = vreg->set_points->range[0].min_uV;
1008 lim_max_uV =
1009 vreg->set_points->range[vreg->set_points->count - 1].max_uV;
1010
1011 if (uV < lim_min_uV && max_uV >= lim_min_uV)
1012 uV = lim_min_uV;
1013
1014 if (uV < lim_min_uV || uV > lim_max_uV) {
1015 vreg_err(vreg,
1016 "request v=[%d, %d] is outside possible v=[%d, %d]\n",
1017 min_uV, max_uV, lim_min_uV, lim_max_uV);
1018 return -EINVAL;
1019 }
1020
1021 /* Find the range which uV is inside of. */
David Collins935c41a2011-09-08 10:54:18 -07001022 for (i = vreg->set_points->count - 1; i > 0; i--) {
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -07001023 if (uV > vreg->set_points->range[i - 1].max_uV) {
1024 range = &vreg->set_points->range[i];
1025 break;
1026 }
1027 }
1028
1029 /*
1030 * Force uV to be an allowed set point and apply a ceiling function
1031 * to non-set point values.
1032 */
1033 uV = (uV - range->min_uV + range->step_uV - 1) / range->step_uV;
1034 uV = uV * range->step_uV + range->min_uV;
1035
1036 if (vreg->part->uV.mask) {
1037 val[vreg->part->uV.word] = uV << vreg->part->uV.shift;
1038 mask[vreg->part->uV.word] = vreg->part->uV.mask;
1039 } else {
1040 val[vreg->part->mV.word]
1041 = MICRO_TO_MILLI(uV) << vreg->part->mV.shift;
1042 mask[vreg->part->mV.word] = vreg->part->mV.mask;
1043 }
1044
1045 mutex_lock(&vreg->pc_lock);
1046
1047 /*
1048 * Only send a request for a new voltage if the regulator is currently
1049 * enabled. This will ensure that LDO and SMPS regulators are not
1050 * inadvertently turned on because voltage > 0 is equivalent to
1051 * enabling. For NCP, this just removes unnecessary RPM requests.
1052 */
1053 if (vreg->is_enabled) {
1054 rc = vreg_set(vreg, mask[0], val[0], mask[1], val[1],
1055 vreg->part->request_len);
1056 if (rc)
1057 vreg_err(vreg, "vreg_set failed, rc=%d\n", rc);
1058 } else if (vreg->type == REGULATOR_TYPE_NCP) {
1059 /* Regulator is disabled; store but don't send new request. */
1060 rc = vreg_store(vreg, mask[0], val[0], mask[1], val[1]);
1061 }
1062
1063 if (!rc && (!vreg->pdata.sleep_selectable || !vreg->is_enabled))
1064 vreg->save_uV = uV;
1065
1066 mutex_unlock(&vreg->pc_lock);
1067
1068 return rc;
1069}
1070
1071static int vreg_get_voltage(struct regulator_dev *rdev)
1072{
1073 struct vreg *vreg = rdev_get_drvdata(rdev);
1074
1075 return vreg->save_uV;
1076}
1077
1078static int vreg_list_voltage(struct regulator_dev *rdev, unsigned selector)
1079{
1080 struct vreg *vreg = rdev_get_drvdata(rdev);
1081 int uV = 0;
1082 int i;
1083
1084 if (!vreg->set_points) {
1085 vreg_err(vreg, "no voltages available\n");
1086 return -EINVAL;
1087 }
1088
1089 if (selector >= vreg->set_points->n_voltages)
1090 return 0;
1091
1092 for (i = 0; i < vreg->set_points->count; i++) {
1093 if (selector < vreg->set_points->range[i].n_voltages) {
1094 uV = selector * vreg->set_points->range[i].step_uV
1095 + vreg->set_points->range[i].min_uV;
1096 break;
1097 } else {
1098 selector -= vreg->set_points->range[i].n_voltages;
1099 }
1100 }
1101
1102 return uV;
1103}
1104
1105static int vreg_set_mode(struct regulator_dev *rdev, unsigned int mode)
1106{
1107 struct vreg *vreg = rdev_get_drvdata(rdev);
1108 unsigned int mask[2] = {0}, val[2] = {0};
1109 int rc = 0;
1110 int peak_uA;
1111
1112 mutex_lock(&vreg->pc_lock);
1113
1114 peak_uA = MILLI_TO_MICRO((vreg->req[vreg->part->ip.word].value
1115 & vreg->part->ip.mask) >> vreg->part->ip.shift);
1116
1117 switch (mode) {
1118 case REGULATOR_MODE_NORMAL:
1119 /* Make sure that request currents are in HPM range. */
1120 if (peak_uA < vreg_hpm_min_uA(vreg)) {
1121 val[vreg->part->ip.word]
1122 = MICRO_TO_MILLI(vreg_hpm_min_uA(vreg))
1123 << vreg->part->ip.shift;
1124 mask[vreg->part->ip.word] = vreg->part->ip.mask;
1125 }
1126 break;
1127 case REGULATOR_MODE_IDLE:
1128 /* Make sure that request currents are in LPM range. */
1129 if (peak_uA > vreg_lpm_max_uA(vreg)) {
1130 val[vreg->part->ip.word]
1131 = MICRO_TO_MILLI(vreg_lpm_max_uA(vreg))
1132 << vreg->part->ip.shift;
1133 mask[vreg->part->ip.word] = vreg->part->ip.mask;
1134 }
1135 break;
1136 default:
1137 vreg_err(vreg, "invalid mode: %u\n", mode);
1138 mutex_unlock(&vreg->pc_lock);
1139 return -EINVAL;
1140 }
1141
1142 if (vreg->is_enabled) {
1143 rc = vreg_set(vreg, mask[0], val[0], mask[1], val[1],
1144 vreg->part->request_len);
1145 } else {
1146 /* Regulator is disabled; store but don't send new request. */
1147 rc = vreg_store(vreg, mask[0], val[0], mask[1], val[1]);
1148 }
1149
1150 if (rc)
1151 vreg_err(vreg, "vreg_set failed, rc=%d\n", rc);
1152 else
1153 vreg->mode = mode;
1154
1155 mutex_unlock(&vreg->pc_lock);
1156
1157 return rc;
1158}
1159
1160static unsigned int vreg_get_mode(struct regulator_dev *rdev)
1161{
1162 struct vreg *vreg = rdev_get_drvdata(rdev);
1163
1164 return vreg->mode;
1165}
1166
1167static unsigned int vreg_get_optimum_mode(struct regulator_dev *rdev,
1168 int input_uV, int output_uV, int load_uA)
1169{
1170 struct vreg *vreg = rdev_get_drvdata(rdev);
1171 unsigned int mode;
1172
1173 load_uA += vreg->pdata.system_uA;
1174
1175 mutex_lock(&vreg->pc_lock);
1176 SET_PART(vreg, ip, MICRO_TO_MILLI(saturate_peak_load(vreg, load_uA)));
1177 mutex_unlock(&vreg->pc_lock);
1178
1179 if (load_uA >= vreg->hpm_min_load)
1180 mode = REGULATOR_MODE_NORMAL;
1181 else
1182 mode = REGULATOR_MODE_IDLE;
1183
1184 return mode;
1185}
1186
1187/*
1188 * Returns the logical pin control enable state because the pin control options
1189 * present in the hardware out of restart could be different from those desired
1190 * by the consumer.
1191 */
1192static int vreg_pin_control_is_enabled(struct regulator_dev *rdev)
1193{
1194 struct vreg *vreg = rdev_get_drvdata(rdev);
1195
1196 return vreg->is_enabled_pc;
1197}
1198
1199static int vreg_pin_control_enable(struct regulator_dev *rdev)
1200{
1201 struct vreg *vreg = rdev_get_drvdata(rdev);
1202 unsigned int mask[2] = {0}, val[2] = {0};
1203 int rc;
1204
1205 mutex_lock(&vreg->pc_lock);
1206
1207 val[vreg->part->pc.word]
1208 |= vreg->pdata.pin_ctrl << vreg->part->pc.shift;
1209 mask[vreg->part->pc.word] |= vreg->part->pc.mask;
1210
1211 val[vreg->part->pf.word] |= vreg->pdata.pin_fn << vreg->part->pf.shift;
1212 mask[vreg->part->pf.word] |= vreg->part->pf.mask;
1213
1214 if (!vreg->is_enabled)
1215 set_enable(vreg, mask, val);
1216
1217 rc = vreg_set(vreg, mask[0], val[0], mask[1], val[1],
1218 vreg->part->request_len);
1219
1220 if (!rc)
1221 vreg->is_enabled_pc = true;
1222
1223 mutex_unlock(&vreg->pc_lock);
1224
1225 if (rc)
1226 vreg_err(vreg, "vreg_set failed, rc=%d\n", rc);
1227
1228 return rc;
1229}
1230
1231static int vreg_pin_control_disable(struct regulator_dev *rdev)
1232{
1233 struct vreg *vreg = rdev_get_drvdata(rdev);
1234 unsigned int mask[2] = {0}, val[2] = {0};
1235 enum rpm_vreg_pin_fn pin_fn;
1236 int rc;
1237
1238 mutex_lock(&vreg->pc_lock);
1239
1240 val[vreg->part->pc.word]
1241 |= RPM_VREG_PIN_CTRL_NONE << vreg->part->pc.shift;
1242 mask[vreg->part->pc.word] |= vreg->part->pc.mask;
1243
1244 pin_fn = RPM_VREG_PIN_FN_NONE;
1245 if (vreg->pdata.pin_fn == RPM_VREG_PIN_FN_SLEEP_B)
1246 pin_fn = RPM_VREG_PIN_FN_SLEEP_B;
1247 val[vreg->part->pf.word] |= pin_fn << vreg->part->pf.shift;
1248 mask[vreg->part->pf.word] |= vreg->part->pf.mask;
1249
1250 if (!vreg->is_enabled)
1251 set_disable(vreg, mask, val);
1252
1253 rc = vreg_set(vreg, mask[0], val[0], mask[1], val[1],
1254 vreg->part->request_len);
1255
1256 if (!rc)
1257 vreg->is_enabled_pc = false;
1258
1259 mutex_unlock(&vreg->pc_lock);
1260
1261 if (rc)
1262 vreg_err(vreg, "vreg_set failed, rc=%d\n", rc);
1263
1264 return rc;
1265}
1266
1267/* Real regulator operations. */
1268static struct regulator_ops ldo_ops = {
1269 .enable = vreg_enable,
1270 .disable = vreg_disable,
1271 .is_enabled = vreg_is_enabled,
1272 .set_voltage = vreg_set_voltage,
1273 .get_voltage = vreg_get_voltage,
1274 .list_voltage = vreg_list_voltage,
1275 .set_mode = vreg_set_mode,
1276 .get_mode = vreg_get_mode,
1277 .get_optimum_mode = vreg_get_optimum_mode,
1278};
1279
1280static struct regulator_ops smps_ops = {
1281 .enable = vreg_enable,
1282 .disable = vreg_disable,
1283 .is_enabled = vreg_is_enabled,
1284 .set_voltage = vreg_set_voltage,
1285 .get_voltage = vreg_get_voltage,
1286 .list_voltage = vreg_list_voltage,
1287 .set_mode = vreg_set_mode,
1288 .get_mode = vreg_get_mode,
1289 .get_optimum_mode = vreg_get_optimum_mode,
1290};
1291
1292static struct regulator_ops switch_ops = {
1293 .enable = vreg_enable,
1294 .disable = vreg_disable,
1295 .is_enabled = vreg_is_enabled,
1296};
1297
1298static struct regulator_ops ncp_ops = {
1299 .enable = vreg_enable,
1300 .disable = vreg_disable,
1301 .is_enabled = vreg_is_enabled,
1302 .set_voltage = vreg_set_voltage,
1303 .get_voltage = vreg_get_voltage,
1304 .list_voltage = vreg_list_voltage,
1305};
1306
1307/* Pin control regulator operations. */
1308static struct regulator_ops pin_control_ops = {
1309 .enable = vreg_pin_control_enable,
1310 .disable = vreg_pin_control_disable,
1311 .is_enabled = vreg_pin_control_is_enabled,
1312};
1313
1314#define VREG_DESC(_id, _name, _ops) \
1315 [RPM_VREG_ID_PM8921_##_id] = { \
1316 .id = RPM_VREG_ID_PM8921_##_id, \
1317 .name = _name, \
1318 .ops = _ops, \
1319 .type = REGULATOR_VOLTAGE, \
1320 .owner = THIS_MODULE, \
1321 }
1322
1323static struct regulator_desc vreg_description[] = {
1324 VREG_DESC(L1, "8921_l1", &ldo_ops),
1325 VREG_DESC(L2, "8921_l2", &ldo_ops),
1326 VREG_DESC(L3, "8921_l3", &ldo_ops),
1327 VREG_DESC(L4, "8921_l4", &ldo_ops),
1328 VREG_DESC(L5, "8921_l5", &ldo_ops),
1329 VREG_DESC(L6, "8921_l6", &ldo_ops),
1330 VREG_DESC(L7, "8921_l7", &ldo_ops),
1331 VREG_DESC(L8, "8921_l8", &ldo_ops),
1332 VREG_DESC(L9, "8921_l9", &ldo_ops),
1333 VREG_DESC(L10, "8921_l10", &ldo_ops),
1334 VREG_DESC(L11, "8921_l11", &ldo_ops),
1335 VREG_DESC(L12, "8921_l12", &ldo_ops),
1336 VREG_DESC(L14, "8921_l14", &ldo_ops),
1337 VREG_DESC(L15, "8921_l15", &ldo_ops),
1338 VREG_DESC(L16, "8921_l16", &ldo_ops),
1339 VREG_DESC(L17, "8921_l17", &ldo_ops),
1340 VREG_DESC(L18, "8921_l18", &ldo_ops),
1341 VREG_DESC(L21, "8921_l21", &ldo_ops),
1342 VREG_DESC(L22, "8921_l22", &ldo_ops),
1343 VREG_DESC(L23, "8921_l23", &ldo_ops),
1344 VREG_DESC(L24, "8921_l24", &ldo_ops),
1345 VREG_DESC(L25, "8921_l25", &ldo_ops),
1346 VREG_DESC(L26, "8921_l26", &ldo_ops),
1347 VREG_DESC(L27, "8921_l27", &ldo_ops),
1348 VREG_DESC(L28, "8921_l28", &ldo_ops),
1349 VREG_DESC(L29, "8921_l29", &ldo_ops),
1350
1351 VREG_DESC(S1, "8921_s1", &smps_ops),
1352 VREG_DESC(S2, "8921_s2", &smps_ops),
1353 VREG_DESC(S3, "8921_s3", &smps_ops),
1354 VREG_DESC(S4, "8921_s4", &smps_ops),
1355 VREG_DESC(S5, "8921_s5", &smps_ops),
1356 VREG_DESC(S6, "8921_s6", &smps_ops),
1357 VREG_DESC(S7, "8921_s7", &smps_ops),
1358 VREG_DESC(S8, "8921_s8", &smps_ops),
1359
1360 VREG_DESC(LVS1, "8921_lvs1", &switch_ops),
1361 VREG_DESC(LVS2, "8921_lvs2", &switch_ops),
1362 VREG_DESC(LVS3, "8921_lvs3", &switch_ops),
1363 VREG_DESC(LVS4, "8921_lvs4", &switch_ops),
1364 VREG_DESC(LVS5, "8921_lvs5", &switch_ops),
1365 VREG_DESC(LVS6, "8921_lvs6", &switch_ops),
1366 VREG_DESC(LVS7, "8921_lvs7", &switch_ops),
1367
1368 VREG_DESC(USB_OTG, "8921_usb_otg", &switch_ops),
1369 VREG_DESC(HDMI_MVS, "8921_hdmi_mvs", &switch_ops),
1370 VREG_DESC(NCP, "8921_ncp", &ncp_ops),
1371
1372 VREG_DESC(L1_PC, "8921_l1_pc", &pin_control_ops),
1373 VREG_DESC(L2_PC, "8921_l2_pc", &pin_control_ops),
1374 VREG_DESC(L3_PC, "8921_l3_pc", &pin_control_ops),
1375 VREG_DESC(L4_PC, "8921_l4_pc", &pin_control_ops),
1376 VREG_DESC(L5_PC, "8921_l5_pc", &pin_control_ops),
1377 VREG_DESC(L6_PC, "8921_l6_pc", &pin_control_ops),
1378 VREG_DESC(L7_PC, "8921_l7_pc", &pin_control_ops),
1379 VREG_DESC(L8_PC, "8921_l8_pc", &pin_control_ops),
1380 VREG_DESC(L9_PC, "8921_l9_pc", &pin_control_ops),
1381 VREG_DESC(L10_PC, "8921_l10_pc", &pin_control_ops),
1382 VREG_DESC(L11_PC, "8921_l11_pc", &pin_control_ops),
1383 VREG_DESC(L12_PC, "8921_l12_pc", &pin_control_ops),
1384 VREG_DESC(L14_PC, "8921_l14_pc", &pin_control_ops),
1385 VREG_DESC(L15_PC, "8921_l15_pc", &pin_control_ops),
1386 VREG_DESC(L16_PC, "8921_l16_pc", &pin_control_ops),
1387 VREG_DESC(L17_PC, "8921_l17_pc", &pin_control_ops),
1388 VREG_DESC(L18_PC, "8921_l18_pc", &pin_control_ops),
1389 VREG_DESC(L21_PC, "8921_l21_pc", &pin_control_ops),
1390 VREG_DESC(L22_PC, "8921_l22_pc", &pin_control_ops),
1391 VREG_DESC(L23_PC, "8921_l23_pc", &pin_control_ops),
1392 VREG_DESC(L29_PC, "8921_l29_pc", &pin_control_ops),
1393
1394 VREG_DESC(S1_PC, "8921_s1_pc", &pin_control_ops),
1395 VREG_DESC(S2_PC, "8921_s2_pc", &pin_control_ops),
1396 VREG_DESC(S3_PC, "8921_s3_pc", &pin_control_ops),
1397 VREG_DESC(S4_PC, "8921_s4_pc", &pin_control_ops),
1398 VREG_DESC(S7_PC, "8921_s7_pc", &pin_control_ops),
1399 VREG_DESC(S8_PC, "8921_s8_pc", &pin_control_ops),
1400
1401 VREG_DESC(LVS1_PC, "8921_lvs1_pc", &pin_control_ops),
1402 VREG_DESC(LVS3_PC, "8921_lvs3_pc", &pin_control_ops),
1403 VREG_DESC(LVS4_PC, "8921_lvs4_pc", &pin_control_ops),
1404 VREG_DESC(LVS5_PC, "8921_lvs5_pc", &pin_control_ops),
1405 VREG_DESC(LVS6_PC, "8921_lvs6_pc", &pin_control_ops),
1406 VREG_DESC(LVS7_PC, "8921_lvs7_pc", &pin_control_ops),
1407};
1408
1409static inline int is_real_regulator(int id)
1410{
1411 return (id >= 0) && (id <= RPM_VREG_ID_PM8921_MAX_REAL);
1412}
1413
1414static int pc_id_to_real_id(int id)
1415{
1416 int real_id;
1417
1418 if (id >= RPM_VREG_ID_PM8921_L1_PC && id <= RPM_VREG_ID_PM8921_L23_PC)
1419 real_id = id - RPM_VREG_ID_PM8921_L1_PC;
1420 else if (id >= RPM_VREG_ID_PM8921_L29_PC
1421 && id <= RPM_VREG_ID_PM8921_S4_PC)
1422 real_id = id - RPM_VREG_ID_PM8921_L29_PC
1423 + RPM_VREG_ID_PM8921_L29;
1424 else if (id >= RPM_VREG_ID_PM8921_S7_PC
1425 && id <= RPM_VREG_ID_PM8921_LVS1_PC)
1426 real_id = id - RPM_VREG_ID_PM8921_S7_PC + RPM_VREG_ID_PM8921_S7;
1427 else
1428 real_id = id - RPM_VREG_ID_PM8921_LVS3_PC
1429 + RPM_VREG_ID_PM8921_LVS3;
1430
1431 return real_id;
1432}
1433
1434static int __devinit
1435rpm_vreg_init_regulator(const struct rpm_regulator_init_data *pdata,
1436 struct device *dev)
1437{
1438 enum rpm_vreg_pin_fn pin_fn;
1439 struct regulator_desc *rdesc;
1440 struct regulator_dev *rdev;
1441 struct vreg *vreg;
1442 const char *reg_name = "";
1443 unsigned pin_ctrl;
1444 int rc = 0, id = pdata->id;
1445
1446 if (id < 0 || id > RPM_VREG_ID_PM8921_MAX) {
1447 pr_err("invalid regulator id: %d\n", id);
1448 return -ENODEV;
1449 }
1450
1451 rdesc = &vreg_description[pdata->id];
1452 if (!is_real_regulator(pdata->id))
1453 id = pc_id_to_real_id(pdata->id);
1454 vreg = &vregs[id];
1455 reg_name = vreg_description[pdata->id].name;
1456 if (!pdata) {
1457 pr_err("%s: requires platform data\n", reg_name);
1458 return -EINVAL;
1459 }
1460 if (vreg->set_points)
1461 rdesc->n_voltages = vreg->set_points->n_voltages;
1462 else
1463 rdesc->n_voltages = 0;
1464
1465 mutex_lock(&vreg->pc_lock);
1466
1467 if (is_real_regulator(pdata->id)) {
1468 /* Do not modify pin control and pin function values. */
1469 pin_ctrl = vreg->pdata.pin_ctrl;
1470 pin_fn = vreg->pdata.pin_fn;
1471 memcpy(&(vreg->pdata), pdata,
1472 sizeof(struct rpm_regulator_init_data));
1473 vreg->pdata.pin_ctrl = pin_ctrl;
1474 vreg->pdata.pin_fn = pin_fn;
1475 vreg->name = reg_name;
1476
1477 vreg->save_uV = vreg->pdata.default_uV;
1478 if (vreg->pdata.peak_uA >= vreg->hpm_min_load)
1479 vreg->mode = REGULATOR_MODE_NORMAL;
1480 else
1481 vreg->mode = REGULATOR_MODE_IDLE;
1482
1483 /* Initialize the RPM request. */
1484 SET_PART(vreg, ip,
1485 MICRO_TO_MILLI(saturate_peak_load(vreg, vreg->pdata.peak_uA)));
1486 SET_PART(vreg, fm, vreg->pdata.force_mode);
1487 SET_PART(vreg, pm, vreg->pdata.power_mode);
1488 SET_PART(vreg, pd, vreg->pdata.pull_down_enable);
1489 SET_PART(vreg, ia,
1490 MICRO_TO_MILLI(saturate_avg_load(vreg, vreg->pdata.avg_uA)));
1491 SET_PART(vreg, freq, vreg->pdata.freq);
1492 SET_PART(vreg, freq_clk_src, 0);
1493 SET_PART(vreg, comp_mode, 0);
1494 SET_PART(vreg, hpm, 0);
1495 if (!vreg->is_enabled_pc) {
1496 SET_PART(vreg, pf, RPM_VREG_PIN_FN_NONE);
1497 SET_PART(vreg, pc, RPM_VREG_PIN_CTRL_NONE);
1498 }
1499 } else {
1500 /* Pin control regulator */
1501 if ((pdata->pin_ctrl & RPM_VREG_PIN_CTRL_ALL)
1502 == RPM_VREG_PIN_CTRL_NONE
1503 && pdata->pin_fn != RPM_VREG_PIN_FN_SLEEP_B) {
1504 pr_err("%s: no pin control input specified\n",
1505 reg_name);
1506 mutex_unlock(&vreg->pc_lock);
1507 return -EINVAL;
1508 }
1509 vreg->pdata.pin_ctrl = pdata->pin_ctrl;
1510 vreg->pdata.pin_fn = pdata->pin_fn;
1511 if (!vreg->name)
1512 vreg->name = reg_name;
1513
1514 /* Initialize the RPM request. */
1515 pin_fn = RPM_VREG_PIN_FN_NONE;
1516 /* Allow pf=sleep_b to be specified by platform data. */
1517 if (vreg->pdata.pin_fn == RPM_VREG_PIN_FN_SLEEP_B)
1518 pin_fn = RPM_VREG_PIN_FN_SLEEP_B;
1519 SET_PART(vreg, pf, pin_fn);
1520 SET_PART(vreg, pc, RPM_VREG_PIN_CTRL_NONE);
1521 }
1522
1523 mutex_unlock(&vreg->pc_lock);
1524
1525 if (rc)
1526 goto bail;
1527
1528 rdev = regulator_register(rdesc, dev, &(pdata->init_data), vreg);
1529 if (IS_ERR(rdev)) {
1530 rc = PTR_ERR(rdev);
1531 pr_err("regulator_register failed: %s, rc=%d\n", reg_name, rc);
1532 return rc;
1533 } else {
1534 if (is_real_regulator(pdata->id))
1535 vreg->rdev = rdev;
1536 else
1537 vreg->rdev_pc = rdev;
1538 }
1539
1540bail:
1541 if (rc)
1542 pr_err("error for %s, rc=%d\n", reg_name, rc);
1543
1544 return rc;
1545}
1546
1547static int __devinit rpm_vreg_probe(struct platform_device *pdev)
1548{
1549 struct rpm_regulator_platform_data *platform_data;
1550 int rc = 0;
1551 int i;
1552
1553 platform_data = pdev->dev.platform_data;
1554 if (!platform_data) {
1555 pr_err("rpm-regulator requires platform data\n");
1556 return -EINVAL;
1557 }
1558
1559 /* Initialize all of the regulators listed in the platform data. */
1560 for (i = 0; i < platform_data->num_regulators; i++) {
1561 rc = rpm_vreg_init_regulator(&platform_data->init_data[i],
1562 &pdev->dev);
1563 if (rc) {
1564 pr_err("rpm_vreg_init_regulator failed, rc=%d\n", rc);
1565 goto remove_regulators;
1566 }
1567 }
1568
1569 platform_set_drvdata(pdev, platform_data);
1570
1571 return rc;
1572
1573remove_regulators:
1574 /* Unregister all regulators added before the erroring one. */
1575 for (; i >= 0; i--) {
1576 if (is_real_regulator(platform_data->init_data[i].id))
1577 regulator_unregister(vregs[i].rdev);
1578 else
1579 regulator_unregister(
1580 vregs[pc_id_to_real_id(i)].rdev_pc);
1581 }
1582
1583 return rc;
1584}
1585
1586static int __devexit rpm_vreg_remove(struct platform_device *pdev)
1587{
1588 struct rpm_regulator_platform_data *platform_data;
1589 int i, id;
1590
1591 platform_data = platform_get_drvdata(pdev);
1592 platform_set_drvdata(pdev, NULL);
1593
1594 if (platform_data) {
1595 for (i = 0; i < platform_data->num_regulators; i++) {
1596 id = platform_data->init_data[i].id;
1597 if (is_real_regulator(id)) {
1598 regulator_unregister(vregs[id].rdev);
1599 vregs[id].rdev = NULL;
1600 } else {
1601 regulator_unregister(
1602 vregs[pc_id_to_real_id(id)].rdev_pc);
1603 vregs[id].rdev_pc = NULL;
1604 }
1605 }
1606 }
1607
1608 return 0;
1609}
1610
1611static struct platform_driver rpm_vreg_driver = {
1612 .probe = rpm_vreg_probe,
1613 .remove = __devexit_p(rpm_vreg_remove),
1614 .driver = {
1615 .name = RPM_REGULATOR_DEV_NAME,
1616 .owner = THIS_MODULE,
1617 },
1618};
1619
1620static int __init rpm_vreg_init(void)
1621{
1622 struct vreg_set_points *set_points[] = {
1623 &pldo_set_points,
1624 &nldo_set_points,
1625 &nldo1200_set_points,
1626 &smps_set_points,
1627 &ftsmps_set_points,
1628 &ncp_set_points,
1629 };
1630 int i, j;
1631
1632 /* Calculate the number of set points available for each regualtor. */
1633 for (i = 0; i < ARRAY_SIZE(set_points); i++) {
1634 for (j = 0; j < set_points[i]->count; j++) {
1635 set_points[i]->range[j].n_voltages
1636 = (set_points[i]->range[j].max_uV
1637 - set_points[i]->range[j].min_uV)
1638 / set_points[i]->range[j].step_uV + 1;
1639 set_points[i]->n_voltages
1640 += set_points[i]->range[j].n_voltages;
1641 }
1642 }
1643
1644 /* Initialize pin control mutexes */
1645 for (i = 0; i < ARRAY_SIZE(vregs); i++)
1646 mutex_init(&vregs[i].pc_lock);
1647
1648 return platform_driver_register(&rpm_vreg_driver);
1649}
1650
1651static void __exit rpm_vreg_exit(void)
1652{
1653 int i;
1654
1655 platform_driver_unregister(&rpm_vreg_driver);
1656
1657 for (i = 0; i < ARRAY_SIZE(vregs); i++)
1658 mutex_destroy(&vregs[i].pc_lock);
1659}
1660
1661postcore_initcall(rpm_vreg_init);
1662module_exit(rpm_vreg_exit);
1663
1664MODULE_LICENSE("GPL v2");
1665MODULE_DESCRIPTION("MSM8960 rpm regulator driver");
1666MODULE_VERSION("1.0");
1667MODULE_ALIAS("platform:" RPM_REGULATOR_DEV_NAME);