xref: /linux/drivers/regulator/rtq2208-regulator.c (revision 90d32e92011eaae8e70a9169b4e7acf4ca8f9d3a)
1 // SPDX-License-Identifier: GPL-2.0+
2 
3 #include <linux/bitops.h>
4 #include <linux/bitfield.h>
5 #include <linux/util_macros.h>
6 #include <linux/module.h>
7 #include <linux/i2c.h>
8 #include <linux/regmap.h>
9 #include <linux/regulator/driver.h>
10 #include <linux/regulator/machine.h>
11 #include <linux/regulator/of_regulator.h>
12 #include <linux/mod_devicetable.h>
13 
14 /* Register */
15 #define RTQ2208_REG_GLOBAL_INT1			0x12
16 #define RTQ2208_REG_FLT_RECORDBUCK_CB		0x18
17 #define RTQ2208_REG_GLOBAL_INT1_MASK		0x1D
18 #define RTQ2208_REG_FLT_MASKBUCK_CB		0x1F
19 #define RTQ2208_REG_BUCK_C_CFG0			0x32
20 #define RTQ2208_REG_BUCK_B_CFG0			0x42
21 #define RTQ2208_REG_BUCK_A_CFG0			0x52
22 #define RTQ2208_REG_BUCK_D_CFG0			0x62
23 #define RTQ2208_REG_BUCK_G_CFG0			0x72
24 #define RTQ2208_REG_BUCK_F_CFG0			0x82
25 #define RTQ2208_REG_BUCK_E_CFG0			0x92
26 #define RTQ2208_REG_BUCK_H_CFG0			0xA2
27 #define RTQ2208_REG_LDO1_CFG			0xB1
28 #define RTQ2208_REG_LDO2_CFG			0xC1
29 #define RTQ2208_REG_LDO_DVS_CTRL		0xD0
30 
31 /* Mask */
32 #define RTQ2208_BUCK_NR_MTP_SEL_MASK		GENMASK(7, 0)
33 #define RTQ2208_BUCK_EN_NR_MTP_SEL0_MASK	BIT(0)
34 #define RTQ2208_BUCK_EN_NR_MTP_SEL1_MASK	BIT(1)
35 #define RTQ2208_BUCK_RSPUP_MASK			GENMASK(6, 4)
36 #define RTQ2208_BUCK_RSPDN_MASK			GENMASK(2, 0)
37 #define RTQ2208_BUCK_NRMODE_MASK		BIT(5)
38 #define RTQ2208_BUCK_STRMODE_MASK		BIT(5)
39 #define RTQ2208_BUCK_EN_STR_MASK		BIT(0)
40 #define RTQ2208_LDO_EN_STR_MASK			BIT(7)
41 #define RTQ2208_EN_DIS_MASK			BIT(0)
42 #define RTQ2208_BUCK_RAMP_SEL_MASK		GENMASK(2, 0)
43 #define RTQ2208_HD_INT_MASK			BIT(0)
44 #define RTQ2208_LDO1_DISCHG_EN_MASK		BIT(4)
45 #define RTQ2208_LDO1_VOSEL_SD_MASK		BIT(5)
46 #define RTQ2208_LDO2_DISCHG_EN_MASK		BIT(6)
47 #define RTQ2208_LDO2_VOSEL_SD_MASK		BIT(7)
48 
49 /* Size */
50 #define RTQ2208_VOUT_MAXNUM			256
51 #define RTQ2208_BUCK_NUM_IRQ_REGS		5
52 #define RTQ2208_STS_NUM_IRQ_REGS		2
53 
54 /* Value */
55 #define RTQ2208_RAMP_VALUE_MIN_uV		500
56 #define RTQ2208_RAMP_VALUE_MAX_uV		16000
57 
58 #define RTQ2208_BUCK_MASK(uv_irq, ov_irq)	(1 << ((uv_irq) % 8) | 1 << ((ov_irq) % 8))
59 
60 enum {
61 	RTQ2208_BUCK_B = 0,
62 	RTQ2208_BUCK_C,
63 	RTQ2208_BUCK_D,
64 	RTQ2208_BUCK_A,
65 	RTQ2208_BUCK_F,
66 	RTQ2208_BUCK_G,
67 	RTQ2208_BUCK_H,
68 	RTQ2208_BUCK_E,
69 	RTQ2208_LDO2,
70 	RTQ2208_LDO1,
71 	RTQ2208_LDO_MAX,
72 };
73 
74 enum {
75 	RTQ2208_AUTO_MODE = 0,
76 	RTQ2208_FCCM,
77 };
78 
79 struct rtq2208_regulator_desc {
80 	struct regulator_desc desc;
81 	unsigned int mtp_sel_reg;
82 	unsigned int mtp_sel_mask;
83 	unsigned int mode_reg;
84 	unsigned int mode_mask;
85 	unsigned int suspend_config_reg;
86 	unsigned int suspend_enable_mask;
87 	unsigned int suspend_mode_mask;
88 };
89 
90 struct rtq2208_rdev_map {
91 	struct regulator_dev *rdev[RTQ2208_LDO_MAX];
92 	struct regmap *regmap;
93 	struct device *dev;
94 };
95 
96 /* set Normal Auto/FCCM mode */
97 static int rtq2208_set_mode(struct regulator_dev *rdev, unsigned int mode)
98 {
99 	const struct rtq2208_regulator_desc *rdesc =
100 		(const struct rtq2208_regulator_desc *)rdev->desc;
101 	unsigned int val, shift;
102 
103 	switch (mode) {
104 	case REGULATOR_MODE_NORMAL:
105 		val = RTQ2208_AUTO_MODE;
106 		break;
107 	case REGULATOR_MODE_FAST:
108 		val = RTQ2208_FCCM;
109 		break;
110 	default:
111 		return -EINVAL;
112 	}
113 
114 	shift = ffs(rdesc->mode_mask) - 1;
115 	return regmap_update_bits(rdev->regmap, rdesc->mode_reg,
116 				  rdesc->mode_mask, val << shift);
117 }
118 
119 static unsigned int rtq2208_get_mode(struct regulator_dev *rdev)
120 {
121 	const struct rtq2208_regulator_desc *rdesc =
122 		(const struct rtq2208_regulator_desc *)rdev->desc;
123 	unsigned int mode_val;
124 	int ret;
125 
126 	ret = regmap_read(rdev->regmap, rdesc->mode_reg, &mode_val);
127 	if (ret)
128 		return REGULATOR_MODE_INVALID;
129 
130 	return (mode_val & rdesc->mode_mask) ? REGULATOR_MODE_FAST : REGULATOR_MODE_NORMAL;
131 }
132 
133 static int rtq2208_set_ramp_delay(struct regulator_dev *rdev, int ramp_delay)
134 {
135 	const struct regulator_desc *desc = rdev->desc;
136 	unsigned int sel = 0, val;
137 
138 	ramp_delay = max(ramp_delay, RTQ2208_RAMP_VALUE_MIN_uV);
139 	ramp_delay = min(ramp_delay, RTQ2208_RAMP_VALUE_MAX_uV);
140 
141 	ramp_delay /= RTQ2208_RAMP_VALUE_MIN_uV;
142 
143 	/*
144 	 * fls(ramp_delay) - 1: doing LSB shift, let it starts from 0
145 	 *
146 	 * RTQ2208_BUCK_RAMP_SEL_MASK - sel: doing descending order shifting.
147 	 * Because the relation of seleltion and value is like that
148 	 *
149 	 * seletion: value
150 	 * 010: 16mv
151 	 * ...
152 	 * 111: 0.5mv
153 	 *
154 	 * For example, if I would like to select 16mv, the fls(ramp_delay) - 1 will be 0b010,
155 	 * and I need to use 0b111 - sel to do the shifting
156 	 */
157 
158 	sel = fls(ramp_delay) - 1;
159 	sel = RTQ2208_BUCK_RAMP_SEL_MASK - sel;
160 
161 	val = FIELD_PREP(RTQ2208_BUCK_RSPUP_MASK, sel) | FIELD_PREP(RTQ2208_BUCK_RSPDN_MASK, sel);
162 
163 	return regmap_update_bits(rdev->regmap, desc->ramp_reg,
164 				  RTQ2208_BUCK_RSPUP_MASK | RTQ2208_BUCK_RSPDN_MASK, val);
165 }
166 
167 static int rtq2208_set_suspend_enable(struct regulator_dev *rdev)
168 {
169 	const struct rtq2208_regulator_desc *rdesc =
170 		(const struct rtq2208_regulator_desc *)rdev->desc;
171 
172 	return regmap_set_bits(rdev->regmap, rdesc->suspend_config_reg, rdesc->suspend_enable_mask);
173 }
174 
175 static int rtq2208_set_suspend_disable(struct regulator_dev *rdev)
176 {
177 	const struct rtq2208_regulator_desc *rdesc =
178 		(const struct rtq2208_regulator_desc *)rdev->desc;
179 
180 	return regmap_update_bits(rdev->regmap, rdesc->suspend_config_reg, rdesc->suspend_enable_mask, 0);
181 }
182 
183 static int rtq2208_set_suspend_mode(struct regulator_dev *rdev, unsigned int mode)
184 {
185 	const struct rtq2208_regulator_desc *rdesc =
186 		(const struct rtq2208_regulator_desc *)rdev->desc;
187 	unsigned int val, shift;
188 
189 	switch (mode) {
190 	case REGULATOR_MODE_NORMAL:
191 		val = RTQ2208_AUTO_MODE;
192 		break;
193 	case REGULATOR_MODE_FAST:
194 		val = RTQ2208_FCCM;
195 		break;
196 	default:
197 		return -EINVAL;
198 	}
199 
200 	shift = ffs(rdesc->suspend_mode_mask) - 1;
201 
202 	return regmap_update_bits(rdev->regmap, rdesc->suspend_config_reg,
203 			rdesc->suspend_mode_mask, val << shift);
204 }
205 
206 static const struct regulator_ops rtq2208_regulator_buck_ops = {
207 	.enable = regulator_enable_regmap,
208 	.disable = regulator_disable_regmap,
209 	.is_enabled = regulator_is_enabled_regmap,
210 	.list_voltage = regulator_list_voltage_linear_range,
211 	.set_voltage_sel = regulator_set_voltage_sel_regmap,
212 	.get_voltage_sel = regulator_get_voltage_sel_regmap,
213 	.set_mode = rtq2208_set_mode,
214 	.get_mode = rtq2208_get_mode,
215 	.set_ramp_delay = rtq2208_set_ramp_delay,
216 	.set_active_discharge = regulator_set_active_discharge_regmap,
217 	.set_suspend_enable = rtq2208_set_suspend_enable,
218 	.set_suspend_disable = rtq2208_set_suspend_disable,
219 	.set_suspend_mode = rtq2208_set_suspend_mode,
220 };
221 
222 static const struct regulator_ops rtq2208_regulator_ldo_ops = {
223 	.enable = regulator_enable_regmap,
224 	.disable = regulator_disable_regmap,
225 	.is_enabled = regulator_is_enabled_regmap,
226 	.set_active_discharge = regulator_set_active_discharge_regmap,
227 	.set_suspend_enable = rtq2208_set_suspend_enable,
228 	.set_suspend_disable = rtq2208_set_suspend_disable,
229 };
230 
231 static unsigned int rtq2208_of_map_mode(unsigned int mode)
232 {
233 	switch (mode) {
234 	case RTQ2208_AUTO_MODE:
235 		return REGULATOR_MODE_NORMAL;
236 	case RTQ2208_FCCM:
237 		return REGULATOR_MODE_FAST;
238 	default:
239 		return REGULATOR_MODE_INVALID;
240 	}
241 }
242 
243 static int rtq2208_init_irq_mask(struct rtq2208_rdev_map *rdev_map, unsigned int *buck_masks)
244 {
245 	unsigned char buck_clr_masks[5] = {0x33, 0x33, 0x33, 0x33, 0x33},
246 		      sts_clr_masks[2] = {0xE7, 0xF7}, sts_masks[2] = {0xE6, 0xF6};
247 	int ret;
248 
249 	/* write clear all buck irq once */
250 	ret = regmap_bulk_write(rdev_map->regmap, RTQ2208_REG_FLT_RECORDBUCK_CB, buck_clr_masks, 5);
251 	if (ret)
252 		return dev_err_probe(rdev_map->dev, ret, "Failed to clr buck irqs\n");
253 
254 	/* write clear general irq once */
255 	ret = regmap_bulk_write(rdev_map->regmap, RTQ2208_REG_GLOBAL_INT1, sts_clr_masks, 2);
256 	if (ret)
257 		return dev_err_probe(rdev_map->dev, ret, "Failed to clr general irqs\n");
258 
259 	/* unmask buck ov/uv irq */
260 	ret = regmap_bulk_write(rdev_map->regmap, RTQ2208_REG_FLT_MASKBUCK_CB, buck_masks, 5);
261 	if (ret)
262 		return dev_err_probe(rdev_map->dev, ret, "Failed to unmask buck irqs\n");
263 
264 	/* unmask needed general irq */
265 	return regmap_bulk_write(rdev_map->regmap, RTQ2208_REG_GLOBAL_INT1_MASK, sts_masks, 2);
266 }
267 
268 static irqreturn_t rtq2208_irq_handler(int irqno, void *devid)
269 {
270 	unsigned char buck_flags[RTQ2208_BUCK_NUM_IRQ_REGS], sts_flags[RTQ2208_STS_NUM_IRQ_REGS];
271 	int ret = 0, i, uv_bit, ov_bit;
272 	struct rtq2208_rdev_map *rdev_map = devid;
273 	struct regulator_dev *rdev;
274 
275 	if (!rdev_map)
276 		return IRQ_NONE;
277 
278 	/* read irq event */
279 	ret = regmap_bulk_read(rdev_map->regmap, RTQ2208_REG_FLT_RECORDBUCK_CB,
280 				buck_flags, ARRAY_SIZE(buck_flags));
281 	if (ret)
282 		return IRQ_NONE;
283 
284 	ret = regmap_bulk_read(rdev_map->regmap, RTQ2208_REG_GLOBAL_INT1,
285 				sts_flags, ARRAY_SIZE(sts_flags));
286 	if (ret)
287 		return IRQ_NONE;
288 
289 	/* clear irq event */
290 	ret = regmap_bulk_write(rdev_map->regmap, RTQ2208_REG_FLT_RECORDBUCK_CB,
291 				buck_flags, ARRAY_SIZE(buck_flags));
292 	if (ret)
293 		return IRQ_NONE;
294 
295 	ret = regmap_bulk_write(rdev_map->regmap, RTQ2208_REG_GLOBAL_INT1,
296 				sts_flags, ARRAY_SIZE(sts_flags));
297 	if (ret)
298 		return IRQ_NONE;
299 
300 	for (i = 0; i < RTQ2208_LDO_MAX; i++) {
301 		if (!rdev_map->rdev[i])
302 			continue;
303 
304 		rdev = rdev_map->rdev[i];
305 		/* uv irq */
306 		uv_bit = (i & 1) ? 4 : 0;
307 		if (buck_flags[i >> 1] & (1 << uv_bit))
308 			regulator_notifier_call_chain(rdev,
309 					REGULATOR_EVENT_UNDER_VOLTAGE, NULL);
310 		/* ov irq */
311 		ov_bit = uv_bit + 1;
312 		if (buck_flags[i >> 1] & (1 << ov_bit))
313 			regulator_notifier_call_chain(rdev,
314 					REGULATOR_EVENT_REGULATION_OUT, NULL);
315 
316 		/* hd irq */
317 		if (sts_flags[1] & RTQ2208_HD_INT_MASK)
318 			regulator_notifier_call_chain(rdev,
319 					REGULATOR_EVENT_OVER_TEMP, NULL);
320 	}
321 
322 	return IRQ_HANDLED;
323 }
324 
325 static int rtq2208_of_get_fixed_voltage(struct device *dev,
326 					struct of_regulator_match *rtq2208_ldo_match, int n_fixed)
327 {
328 	struct device_node *np;
329 	struct of_regulator_match *match;
330 	struct rtq2208_regulator_desc *rdesc;
331 	struct regulator_init_data *init_data;
332 	int ret, i;
333 
334 	if (!dev->of_node)
335 		return -ENODEV;
336 
337 	np = of_get_child_by_name(dev->of_node, "regulators");
338 	if (!np)
339 		np = dev->of_node;
340 
341 	ret = of_regulator_match(dev, np, rtq2208_ldo_match, n_fixed);
342 
343 	of_node_put(np);
344 
345 	if (ret < 0)
346 		return ret;
347 
348 	for (i = 0; i < n_fixed; i++) {
349 		match = rtq2208_ldo_match + i;
350 		init_data = match->init_data;
351 		rdesc = (struct rtq2208_regulator_desc *)match->driver_data;
352 
353 		if (!init_data || !rdesc)
354 			continue;
355 
356 		if (init_data->constraints.min_uV == init_data->constraints.max_uV)
357 			rdesc->desc.fixed_uV = init_data->constraints.min_uV;
358 	}
359 
360 	return 0;
361 }
362 
363 
364 #define BUCK_INFO(_name, _id)						\
365 {									\
366 	.name = _name,							\
367 	.base = RTQ2208_REG_BUCK_##_id##_CFG0,				\
368 	.enable_reg = BUCK_RG_SHIFT(RTQ2208_REG_BUCK_##_id##_CFG0, 2),	\
369 	.dis_reg = RTQ2208_REG_BUCK_##_id##_CFG0,			\
370 }
371 
372 #define LDO_INFO(_name, _id)						\
373 {									\
374 	.name = _name,							\
375 	.base = RTQ2208_REG_LDO##_id##_CFG,				\
376 	.enable_reg = RTQ2208_REG_LDO##_id##_CFG,			\
377 	.dis_mask = RTQ2208_LDO##_id##_DISCHG_EN_MASK,			\
378 	.dis_on = RTQ2208_LDO##_id##_DISCHG_EN_MASK,			\
379 	.vsel_mask = RTQ2208_LDO##_id##_VOSEL_SD_MASK,			\
380 }
381 
382 #define BUCK_RG_SHIFT(_base, _shift)	(_base + _shift)
383 #define	VSEL_SHIFT(_sel)	(_sel ? 3 : 1)
384 #define MTP_SEL_MASK(_sel)	RTQ2208_BUCK_EN_NR_MTP_SEL##_sel##_MASK
385 
386 static const struct linear_range rtq2208_vout_range[] = {
387 	REGULATOR_LINEAR_RANGE(400000, 0, 180, 5000),
388 	REGULATOR_LINEAR_RANGE(1310000, 181, 255, 10000),
389 };
390 
391 static void rtq2208_init_regulator_desc(struct rtq2208_regulator_desc *rdesc, int mtp_sel,
392 					int idx, struct of_regulator_match *rtq2208_ldo_match, int *ldo_idx)
393 {
394 	struct regulator_desc *desc;
395 	static const struct {
396 		char *name;
397 		int base;
398 		int enable_reg;
399 		int dis_reg;
400 		int dis_mask;
401 		int dis_on;
402 		int vsel_mask;
403 	} regulator_info[] = {
404 		BUCK_INFO("buck-b", B),
405 		BUCK_INFO("buck-c", C),
406 		BUCK_INFO("buck-d", D),
407 		BUCK_INFO("buck-a", A),
408 		BUCK_INFO("buck-f", F),
409 		BUCK_INFO("buck-g", G),
410 		BUCK_INFO("buck-h", H),
411 		BUCK_INFO("buck-e", E),
412 		LDO_INFO("ldo2", 2),
413 		LDO_INFO("ldo1", 1),
414 	}, *curr_info;
415 
416 	curr_info = regulator_info + idx;
417 	desc = &rdesc->desc;
418 	desc->name = curr_info->name;
419 	desc->of_match = of_match_ptr(curr_info->name);
420 	desc->regulators_node = of_match_ptr("regulators");
421 	desc->id = idx;
422 	desc->owner = THIS_MODULE;
423 	desc->type = REGULATOR_VOLTAGE;
424 	desc->enable_mask = mtp_sel ? MTP_SEL_MASK(1) : MTP_SEL_MASK(0);
425 	desc->enable_reg = curr_info->enable_reg;
426 	desc->active_discharge_off = 0;
427 
428 	rdesc->mode_mask = RTQ2208_BUCK_NRMODE_MASK;
429 
430 	if (idx >= RTQ2208_BUCK_B && idx <= RTQ2208_BUCK_E) {
431 		/* init buck desc */
432 		desc->ops = &rtq2208_regulator_buck_ops;
433 		desc->vsel_reg = curr_info->base + VSEL_SHIFT(mtp_sel);
434 		desc->vsel_mask = RTQ2208_BUCK_NR_MTP_SEL_MASK;
435 		desc->n_voltages = RTQ2208_VOUT_MAXNUM;
436 		desc->linear_ranges = rtq2208_vout_range;
437 		desc->n_linear_ranges = ARRAY_SIZE(rtq2208_vout_range);
438 		desc->ramp_reg = BUCK_RG_SHIFT(curr_info->base, 5);
439 		desc->of_map_mode = rtq2208_of_map_mode;
440 		desc->active_discharge_reg = curr_info->dis_reg;
441 		desc->active_discharge_on = RTQ2208_EN_DIS_MASK;
442 		desc->active_discharge_mask = RTQ2208_EN_DIS_MASK;
443 
444 		rdesc->mode_reg = BUCK_RG_SHIFT(curr_info->base, 2);
445 		rdesc->suspend_config_reg = BUCK_RG_SHIFT(curr_info->base, 4);
446 		rdesc->suspend_enable_mask = RTQ2208_BUCK_EN_STR_MASK;
447 		rdesc->suspend_mode_mask = RTQ2208_BUCK_STRMODE_MASK;
448 	} else {
449 		/* init ldo desc */
450 		desc->active_discharge_reg = RTQ2208_REG_LDO_DVS_CTRL;
451 		desc->active_discharge_on = curr_info->dis_on;
452 		desc->active_discharge_mask = curr_info->dis_mask;
453 		desc->vsel_reg = RTQ2208_REG_LDO_DVS_CTRL;
454 		desc->vsel_mask = curr_info->vsel_mask;
455 
456 		rdesc->suspend_config_reg = curr_info->base;
457 		rdesc->suspend_enable_mask = RTQ2208_LDO_EN_STR_MASK;
458 	}
459 }
460 
461 static int rtq2208_parse_regulator_dt_data(int n_regulator, const unsigned int *regulator_idx_table,
462 		struct rtq2208_regulator_desc *rdesc[RTQ2208_LDO_MAX], struct device *dev)
463 {
464 	struct of_regulator_match rtq2208_ldo_match[2];
465 	int mtp_sel, ret, i, idx, ldo_idx = 0;
466 
467 	/* get mtp_sel0 or mtp_sel1 */
468 	mtp_sel = device_property_read_bool(dev, "richtek,mtp-sel-high");
469 
470 	for (i = 0; i < n_regulator; i++) {
471 		idx = regulator_idx_table[i];
472 
473 		rdesc[i] = devm_kcalloc(dev, 1, sizeof(*rdesc[0]), GFP_KERNEL);
474 		if (!rdesc[i])
475 			return -ENOMEM;
476 
477 		rtq2208_init_regulator_desc(rdesc[i], mtp_sel, idx, rtq2208_ldo_match, &ldo_idx);
478 
479 		/* init ldo dvs ability */
480 		if (idx >= RTQ2208_LDO2)
481 			rtq2208_ldo_match[idx - RTQ2208_LDO2].desc = &rdesc[i]->desc;
482 	}
483 
484 	/* init ldo fixed_uV */
485 	ret = rtq2208_of_get_fixed_voltage(dev, rtq2208_ldo_match, ldo_idx);
486 	if (ret)
487 		return dev_err_probe(dev, ret, "Failed to get ldo fixed_uV\n");
488 
489 	return 0;
490 
491 }
492 
493 /** different slave address corresponds different used bucks
494  * slave address 0x10: BUCK[BCA FGE]
495  * slave address 0x20: BUCK[BC FGHE]
496  * slave address 0x40: BUCK[C G]
497  */
498 static int rtq2208_regulator_check(int slave_addr, int *num,
499 				int *regulator_idx_table, unsigned int *buck_masks)
500 {
501 	static bool rtq2208_used_table[3][RTQ2208_LDO_MAX] = {
502 		/* BUCK[BCA FGE], LDO[12] */
503 		{1, 1, 0, 1, 1, 1, 0, 1, 1, 1},
504 		/* BUCK[BC FGHE], LDO[12]*/
505 		{1, 1, 0, 0, 1, 1, 1, 1, 1, 1},
506 		/* BUCK[C G], LDO[12] */
507 		{0, 1, 0, 0, 0, 1, 0, 0, 1, 1},
508 	};
509 	int i, idx = ffs(slave_addr >> 4) - 1;
510 	u8 mask;
511 
512 	for (i = 0; i < RTQ2208_LDO_MAX; i++) {
513 		if (!rtq2208_used_table[idx][i])
514 			continue;
515 
516 		regulator_idx_table[(*num)++] = i;
517 
518 		mask = RTQ2208_BUCK_MASK(4 * i, 4 * i + 1);
519 		buck_masks[i >> 1] &= ~mask;
520 	}
521 
522 	return 0;
523 }
524 
525 static const struct regmap_config rtq2208_regmap_config = {
526 	.reg_bits = 8,
527 	.val_bits = 8,
528 	.max_register = 0xEF,
529 };
530 
531 static int rtq2208_probe(struct i2c_client *i2c)
532 {
533 	struct device *dev = &i2c->dev;
534 	struct regmap *regmap;
535 	struct rtq2208_regulator_desc *rdesc[RTQ2208_LDO_MAX];
536 	struct regulator_dev *rdev;
537 	struct regulator_config cfg;
538 	struct rtq2208_rdev_map *rdev_map;
539 	int i, ret = 0, idx, n_regulator = 0;
540 	unsigned int regulator_idx_table[RTQ2208_LDO_MAX],
541 		     buck_masks[RTQ2208_BUCK_NUM_IRQ_REGS] = {0x33, 0x33, 0x33, 0x33, 0x33};
542 
543 	rdev_map = devm_kzalloc(dev, sizeof(struct rtq2208_rdev_map), GFP_KERNEL);
544 	if (!rdev_map)
545 		return -ENOMEM;
546 
547 	regmap = devm_regmap_init_i2c(i2c, &rtq2208_regmap_config);
548 	if (IS_ERR(regmap))
549 		return dev_err_probe(dev, PTR_ERR(regmap), "Failed to allocate regmap\n");
550 
551 	/* get needed regulator */
552 	ret = rtq2208_regulator_check(i2c->addr, &n_regulator, regulator_idx_table, buck_masks);
553 	if (ret)
554 		return dev_err_probe(dev, ret, "Failed to check used regulators\n");
555 
556 	rdev_map->regmap = regmap;
557 	rdev_map->dev = dev;
558 
559 	cfg.dev = dev;
560 
561 	/* init regulator desc */
562 	ret = rtq2208_parse_regulator_dt_data(n_regulator, regulator_idx_table, rdesc, dev);
563 	if (ret)
564 		return ret;
565 
566 	for (i = 0; i < n_regulator; i++) {
567 		idx = regulator_idx_table[i];
568 
569 		/* register regulator */
570 		rdev = devm_regulator_register(dev, &rdesc[i]->desc, &cfg);
571 		if (IS_ERR(rdev))
572 			return PTR_ERR(rdev);
573 
574 		rdev_map->rdev[idx] = rdev;
575 	}
576 
577 	/* init interrupt mask */
578 	ret = rtq2208_init_irq_mask(rdev_map, buck_masks);
579 	if (ret)
580 		return ret;
581 
582 	/* register interrupt */
583 	return devm_request_threaded_irq(dev, i2c->irq, NULL, rtq2208_irq_handler,
584 					IRQF_ONESHOT, dev_name(dev), rdev_map);
585 }
586 
587 static const struct of_device_id rtq2208_device_tables[] = {
588 	{ .compatible = "richtek,rtq2208" },
589 	{}
590 };
591 MODULE_DEVICE_TABLE(of, rtq2208_device_tables);
592 
593 static struct i2c_driver rtq2208_driver = {
594 	.driver = {
595 		.name = "rtq2208",
596 		.of_match_table = rtq2208_device_tables,
597 	},
598 	.probe = rtq2208_probe,
599 };
600 module_i2c_driver(rtq2208_driver);
601 
602 MODULE_AUTHOR("Alina Yu <alina_yu@richtek.com>");
603 MODULE_DESCRIPTION("Richtek RTQ2208 Regulator Driver");
604 MODULE_LICENSE("GPL");
605