xref: /linux/drivers/regulator/rt5133-regulator.c (revision 714165e1c4b0d5b8c6d095fe07f65e6e7047aaeb)
1*714165e1SJeff Chang // SPDX-License-Identifier: GPL-2.0
2*714165e1SJeff Chang // Copyright (C) 2025 Richtek Technology Corp.
3*714165e1SJeff Chang // Author: ChiYuan Huang <cy_huang@richtek.com>
4*714165e1SJeff Chang // Author: ShihChia Chang <jeff_chang@richtek.com>
5*714165e1SJeff Chang 
6*714165e1SJeff Chang #include <linux/crc8.h>
7*714165e1SJeff Chang #include <linux/delay.h>
8*714165e1SJeff Chang #include <linux/gpio/consumer.h>
9*714165e1SJeff Chang #include <linux/gpio/driver.h>
10*714165e1SJeff Chang #include <linux/i2c.h>
11*714165e1SJeff Chang #include <linux/interrupt.h>
12*714165e1SJeff Chang #include <linux/kernel.h>
13*714165e1SJeff Chang #include <linux/module.h>
14*714165e1SJeff Chang #include <linux/of.h>
15*714165e1SJeff Chang #include <linux/regmap.h>
16*714165e1SJeff Chang #include <linux/regulator/driver.h>
17*714165e1SJeff Chang 
18*714165e1SJeff Chang #define RT5133_REG_CHIP_INFO		0x00
19*714165e1SJeff Chang #define RT5133_REG_RST_CTRL		0x06
20*714165e1SJeff Chang #define RT5133_REG_BASE_CTRL		0x09
21*714165e1SJeff Chang #define RT5133_REG_GPIO_CTRL		0x0B
22*714165e1SJeff Chang #define RT5133_REG_BASE_EVT		0x10
23*714165e1SJeff Chang #define RT5133_REG_LDO_PGB_STAT		0x15
24*714165e1SJeff Chang #define RT5133_REG_BASE_MASK		0x16
25*714165e1SJeff Chang #define RT5133_REG_LDO_SHDN		0x19
26*714165e1SJeff Chang #define RT5133_REG_LDO_ON		0x1A
27*714165e1SJeff Chang #define RT5133_REG_LDO_OFF		0x1B
28*714165e1SJeff Chang #define RT5133_REG_LDO1_CTRL1		0x20
29*714165e1SJeff Chang #define RT5133_REG_LDO1_CTRL2		0x21
30*714165e1SJeff Chang #define RT5133_REG_LDO1_CTRL3		0x22
31*714165e1SJeff Chang #define RT5133_REG_LDO2_CTRL1		0x24
32*714165e1SJeff Chang #define RT5133_REG_LDO2_CTRL2		0x25
33*714165e1SJeff Chang #define RT5133_REG_LDO2_CTRL3		0x26
34*714165e1SJeff Chang #define RT5133_REG_LDO3_CTRL1		0x28
35*714165e1SJeff Chang #define RT5133_REG_LDO3_CTRL2		0x29
36*714165e1SJeff Chang #define RT5133_REG_LDO3_CTRL3		0x2A
37*714165e1SJeff Chang #define RT5133_REG_LDO4_CTRL1		0x2C
38*714165e1SJeff Chang #define RT5133_REG_LDO4_CTRL2		0x2D
39*714165e1SJeff Chang #define RT5133_REG_LDO4_CTRL3		0x2E
40*714165e1SJeff Chang #define RT5133_REG_LDO5_CTRL1		0x30
41*714165e1SJeff Chang #define RT5133_REG_LDO5_CTRL2		0x31
42*714165e1SJeff Chang #define RT5133_REG_LDO5_CTRL3		0x32
43*714165e1SJeff Chang #define RT5133_REG_LDO6_CTRL1		0x34
44*714165e1SJeff Chang #define RT5133_REG_LDO6_CTRL2		0x35
45*714165e1SJeff Chang #define RT5133_REG_LDO6_CTRL3		0x36
46*714165e1SJeff Chang #define RT5133_REG_LDO7_CTRL1		0x38
47*714165e1SJeff Chang #define RT5133_REG_LDO7_CTRL2		0x39
48*714165e1SJeff Chang #define RT5133_REG_LDO7_CTRL3		0x3A
49*714165e1SJeff Chang #define RT5133_REG_LDO8_CTRL1		0x3C
50*714165e1SJeff Chang #define RT5133_REG_LDO8_CTRL2		0x3D
51*714165e1SJeff Chang #define RT5133_REG_LDO8_CTRL3		0x3E
52*714165e1SJeff Chang #define RT5133_REG_LDO8_CTRL4		0x3F
53*714165e1SJeff Chang 
54*714165e1SJeff Chang #define RT5133_LDO_REG_BASE(_id)	(0x20 + ((_id) - 1) * 4)
55*714165e1SJeff Chang 
56*714165e1SJeff Chang #define RT5133_VENDOR_ID_MASK		GENMASK(7, 4)
57*714165e1SJeff Chang #define RT5133_RESET_CODE		0xB1
58*714165e1SJeff Chang 
59*714165e1SJeff Chang #define RT5133_FOFF_BASE_MASK		BIT(1)
60*714165e1SJeff Chang #define RT5133_OCSHDN_ALL_MASK		BIT(7)
61*714165e1SJeff Chang #define RT5133_OCSHDN_ALL_SHIFT		(7)
62*714165e1SJeff Chang #define RT5133_PGBSHDN_ALL_MASK		BIT(6)
63*714165e1SJeff Chang #define RT5133_PGBSHDN_ALL_SHIFT	(6)
64*714165e1SJeff Chang 
65*714165e1SJeff Chang #define RT5133_OCPTSEL_MASK		BIT(5)
66*714165e1SJeff Chang #define RT5133_PGBPTSEL_MASK		BIT(4)
67*714165e1SJeff Chang #define RT5133_STBTDSEL_MASK		GENMASK(1, 0)
68*714165e1SJeff Chang 
69*714165e1SJeff Chang #define RT5133_LDO_ENABLE_MASK		BIT(7)
70*714165e1SJeff Chang #define RT5133_LDO_VSEL_MASK		GENMASK(7, 5)
71*714165e1SJeff Chang #define RT5133_LDO_AD_MASK		BIT(2)
72*714165e1SJeff Chang #define RT5133_LDO_SOFT_START_MASK	GENMASK(1, 0)
73*714165e1SJeff Chang 
74*714165e1SJeff Chang #define RT5133_GPIO_NR			3
75*714165e1SJeff Chang 
76*714165e1SJeff Chang #define RT5133_LDO_PGB_EVT_MASK		GENMASK(23, 16)
77*714165e1SJeff Chang #define RT5133_LDO_PGB_EVT_SHIFT	16
78*714165e1SJeff Chang #define RT5133_LDO_OC_EVT_MASK		GENMASK(15, 8)
79*714165e1SJeff Chang #define RT5133_LDO_OC_EVT_SHIFT		8
80*714165e1SJeff Chang #define RT5133_VREF_EVT_MASK		BIT(6)
81*714165e1SJeff Chang #define RT5133_BASE_EVT_MASK		GENMASK(7, 0)
82*714165e1SJeff Chang #define RT5133_INTR_CLR_MASK		GENMASK(23, 0)
83*714165e1SJeff Chang #define RT5133_INTR_BYTE_NR		3
84*714165e1SJeff Chang 
85*714165e1SJeff Chang #define RT5133_MAX_I2C_BLOCK_SIZE	1
86*714165e1SJeff Chang 
87*714165e1SJeff Chang #define RT5133_CRC8_POLYNOMIAL		0x7
88*714165e1SJeff Chang 
89*714165e1SJeff Chang #define RT5133_I2C_ADDR_LEN		1
90*714165e1SJeff Chang #define RT5133_PREDATA_LEN		2
91*714165e1SJeff Chang #define RT5133_I2C_CRC_LEN		1
92*714165e1SJeff Chang #define RT5133_REG_ADDR_LEN		1
93*714165e1SJeff Chang #define RT5133_I2C_DUMMY_LEN		1
94*714165e1SJeff Chang 
95*714165e1SJeff Chang #define I2C_ADDR_XLATE_8BIT(_addr, _rw)	((((_addr) & 0x7F) << 1) | (_rw))
96*714165e1SJeff Chang 
97*714165e1SJeff Chang enum {
98*714165e1SJeff Chang 	RT5133_REGULATOR_BASE = 0,
99*714165e1SJeff Chang 	RT5133_REGULATOR_LDO1,
100*714165e1SJeff Chang 	RT5133_REGULATOR_LDO2,
101*714165e1SJeff Chang 	RT5133_REGULATOR_LDO3,
102*714165e1SJeff Chang 	RT5133_REGULATOR_LDO4,
103*714165e1SJeff Chang 	RT5133_REGULATOR_LDO5,
104*714165e1SJeff Chang 	RT5133_REGULATOR_LDO6,
105*714165e1SJeff Chang 	RT5133_REGULATOR_LDO7,
106*714165e1SJeff Chang 	RT5133_REGULATOR_LDO8,
107*714165e1SJeff Chang 	RT5133_REGULATOR_MAX
108*714165e1SJeff Chang };
109*714165e1SJeff Chang 
110*714165e1SJeff Chang struct chip_data {
111*714165e1SJeff Chang 	const struct regulator_desc *regulators;
112*714165e1SJeff Chang 	const u8 vendor_id;
113*714165e1SJeff Chang };
114*714165e1SJeff Chang 
115*714165e1SJeff Chang struct rt5133_priv {
116*714165e1SJeff Chang 	struct device *dev;
117*714165e1SJeff Chang 	struct regmap *regmap;
118*714165e1SJeff Chang 	struct gpio_desc *enable_gpio;
119*714165e1SJeff Chang 	struct regulator_dev *rdev[RT5133_REGULATOR_MAX];
120*714165e1SJeff Chang 	struct gpio_chip gc;
121*714165e1SJeff Chang 	const struct chip_data *cdata;
122*714165e1SJeff Chang 	unsigned int gpio_output_flag;
123*714165e1SJeff Chang 	u8 crc8_tbls[CRC8_TABLE_SIZE];
124*714165e1SJeff Chang };
125*714165e1SJeff Chang 
126*714165e1SJeff Chang static const unsigned int vout_type1_tables[] = {
127*714165e1SJeff Chang 	1800000, 2500000, 2700000, 2800000, 2900000, 3000000, 3100000, 3200000
128*714165e1SJeff Chang };
129*714165e1SJeff Chang 
130*714165e1SJeff Chang static const unsigned int vout_type2_tables[] = {
131*714165e1SJeff Chang 	1700000, 1800000, 1900000, 2500000, 2700000, 2800000, 2900000, 3000000
132*714165e1SJeff Chang };
133*714165e1SJeff Chang 
134*714165e1SJeff Chang static const unsigned int vout_type3_tables[] = {
135*714165e1SJeff Chang 	900000, 950000, 1000000, 1050000, 1100000, 1150000, 1200000, 1800000
136*714165e1SJeff Chang };
137*714165e1SJeff Chang 
138*714165e1SJeff Chang static const unsigned int vout_type4_tables[] = {
139*714165e1SJeff Chang 	855000, 900000, 950000, 1000000, 1040000, 1090000, 1140000, 1710000
140*714165e1SJeff Chang };
141*714165e1SJeff Chang 
142*714165e1SJeff Chang static const struct regulator_ops rt5133_regulator_ops = {
143*714165e1SJeff Chang 	.list_voltage = regulator_list_voltage_table,
144*714165e1SJeff Chang 	.set_voltage_sel = regulator_set_voltage_sel_regmap,
145*714165e1SJeff Chang 	.get_voltage_sel = regulator_get_voltage_sel_regmap,
146*714165e1SJeff Chang 	.enable = regulator_enable_regmap,
147*714165e1SJeff Chang 	.disable = regulator_disable_regmap,
148*714165e1SJeff Chang 	.is_enabled = regulator_is_enabled_regmap,
149*714165e1SJeff Chang 	.set_active_discharge = regulator_set_active_discharge_regmap,
150*714165e1SJeff Chang };
151*714165e1SJeff Chang 
152*714165e1SJeff Chang static const struct regulator_ops rt5133_base_regulator_ops = {
153*714165e1SJeff Chang 	.enable = regulator_enable_regmap,
154*714165e1SJeff Chang 	.disable = regulator_disable_regmap,
155*714165e1SJeff Chang 	.is_enabled = regulator_is_enabled_regmap,
156*714165e1SJeff Chang };
157*714165e1SJeff Chang 
158*714165e1SJeff Chang #define RT5133_REGULATOR_DESC(_name, _node_name, vtables, _supply) \
159*714165e1SJeff Chang {\
160*714165e1SJeff Chang 	.name = #_name,\
161*714165e1SJeff Chang 	.id = RT5133_REGULATOR_##_name,\
162*714165e1SJeff Chang 	.of_match = of_match_ptr(#_node_name),\
163*714165e1SJeff Chang 	.regulators_node = of_match_ptr("regulators"),\
164*714165e1SJeff Chang 	.supply_name = _supply,\
165*714165e1SJeff Chang 	.type = REGULATOR_VOLTAGE,\
166*714165e1SJeff Chang 	.owner = THIS_MODULE,\
167*714165e1SJeff Chang 	.ops = &rt5133_regulator_ops,\
168*714165e1SJeff Chang 	.n_voltages = ARRAY_SIZE(vtables),\
169*714165e1SJeff Chang 	.volt_table = vtables,\
170*714165e1SJeff Chang 	.enable_reg = RT5133_REG_##_name##_CTRL1,\
171*714165e1SJeff Chang 	.enable_mask = RT5133_LDO_ENABLE_MASK,\
172*714165e1SJeff Chang 	.vsel_reg = RT5133_REG_##_name##_CTRL2,\
173*714165e1SJeff Chang 	.vsel_mask = RT5133_LDO_VSEL_MASK,\
174*714165e1SJeff Chang 	.active_discharge_reg = RT5133_REG_##_name##_CTRL3,\
175*714165e1SJeff Chang 	.active_discharge_mask = RT5133_LDO_AD_MASK,\
176*714165e1SJeff Chang }
177*714165e1SJeff Chang 
178*714165e1SJeff Chang static const struct regulator_desc rt5133_regulators[] = {
179*714165e1SJeff Chang 	/* For digital part, base current control */
180*714165e1SJeff Chang 	{
181*714165e1SJeff Chang 		.name = "base",
182*714165e1SJeff Chang 		.id = RT5133_REGULATOR_BASE,
183*714165e1SJeff Chang 		.of_match = of_match_ptr("base"),
184*714165e1SJeff Chang 		.regulators_node = of_match_ptr("regulators"),
185*714165e1SJeff Chang 		.type = REGULATOR_VOLTAGE,
186*714165e1SJeff Chang 		.owner = THIS_MODULE,
187*714165e1SJeff Chang 		.ops = &rt5133_base_regulator_ops,
188*714165e1SJeff Chang 		.enable_reg = RT5133_REG_BASE_CTRL,
189*714165e1SJeff Chang 		.enable_mask = RT5133_FOFF_BASE_MASK,
190*714165e1SJeff Chang 		.enable_is_inverted = true,
191*714165e1SJeff Chang 	},
192*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO1, ldo1, vout_type1_tables, "base"),
193*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO2, ldo2, vout_type1_tables, "base"),
194*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO3, ldo3, vout_type2_tables, "base"),
195*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO4, ldo4, vout_type2_tables, "base"),
196*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO5, ldo5, vout_type2_tables, "base"),
197*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO6, ldo6, vout_type2_tables, "base"),
198*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO7, ldo7, vout_type3_tables, "vin"),
199*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO8, ldo8, vout_type3_tables, "vin"),
200*714165e1SJeff Chang };
201*714165e1SJeff Chang 
202*714165e1SJeff Chang static const struct regulator_desc rt5133a_regulators[] = {
203*714165e1SJeff Chang 	/* For digital part, base current control */
204*714165e1SJeff Chang 	{
205*714165e1SJeff Chang 		.name = "base",
206*714165e1SJeff Chang 		.id = RT5133_REGULATOR_BASE,
207*714165e1SJeff Chang 		.of_match = of_match_ptr("base"),
208*714165e1SJeff Chang 		.regulators_node = of_match_ptr("regulators"),
209*714165e1SJeff Chang 		.type = REGULATOR_VOLTAGE,
210*714165e1SJeff Chang 		.owner = THIS_MODULE,
211*714165e1SJeff Chang 		.ops = &rt5133_base_regulator_ops,
212*714165e1SJeff Chang 		.enable_reg = RT5133_REG_BASE_CTRL,
213*714165e1SJeff Chang 		.enable_mask = RT5133_FOFF_BASE_MASK,
214*714165e1SJeff Chang 		.enable_is_inverted = true,
215*714165e1SJeff Chang 	},
216*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO1, ldo1, vout_type1_tables, "base"),
217*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO2, ldo2, vout_type1_tables, "base"),
218*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO3, ldo3, vout_type2_tables, "base"),
219*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO4, ldo4, vout_type2_tables, "base"),
220*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO5, ldo5, vout_type2_tables, "base"),
221*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO6, ldo6, vout_type2_tables, "base"),
222*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO7, ldo7, vout_type3_tables, "vin"),
223*714165e1SJeff Chang 	RT5133_REGULATOR_DESC(LDO8, ldo8, vout_type4_tables, "vin"),
224*714165e1SJeff Chang };
225*714165e1SJeff Chang 
226*714165e1SJeff Chang static const struct chip_data regulator_data[] = {
227*714165e1SJeff Chang 	{ rt5133_regulators, 0x70},
228*714165e1SJeff Chang 	{ rt5133a_regulators, 0x80},
229*714165e1SJeff Chang };
230*714165e1SJeff Chang 
231*714165e1SJeff Chang static int rt5133_gpio_direction_output(struct gpio_chip *gpio,
232*714165e1SJeff Chang 					unsigned int offset, int value)
233*714165e1SJeff Chang {
234*714165e1SJeff Chang 	struct rt5133_priv *priv = gpiochip_get_data(gpio);
235*714165e1SJeff Chang 
236*714165e1SJeff Chang 	if (offset >= RT5133_GPIO_NR)
237*714165e1SJeff Chang 		return -EINVAL;
238*714165e1SJeff Chang 
239*714165e1SJeff Chang 	return regmap_update_bits(priv->regmap, RT5133_REG_GPIO_CTRL,
240*714165e1SJeff Chang 				  BIT(7 - offset) | BIT(3 - offset),
241*714165e1SJeff Chang 				  value ? BIT(7 - offset) | BIT(3 - offset) : 0);
242*714165e1SJeff Chang }
243*714165e1SJeff Chang 
244*714165e1SJeff Chang static int rt5133_gpio_get(struct gpio_chip *chip, unsigned int offset)
245*714165e1SJeff Chang {
246*714165e1SJeff Chang 	struct rt5133_priv *priv = gpiochip_get_data(chip);
247*714165e1SJeff Chang 
248*714165e1SJeff Chang 	return !!(priv->gpio_output_flag & BIT(offset));
249*714165e1SJeff Chang }
250*714165e1SJeff Chang 
251*714165e1SJeff Chang static int rt5133_get_gpioen_mask(unsigned int offset, unsigned int *mask)
252*714165e1SJeff Chang {
253*714165e1SJeff Chang 	if (offset >= RT5133_GPIO_NR)
254*714165e1SJeff Chang 		return -EINVAL;
255*714165e1SJeff Chang 
256*714165e1SJeff Chang 	*mask = (BIT(7 - offset) | BIT(3 - offset));
257*714165e1SJeff Chang 
258*714165e1SJeff Chang 	return 0;
259*714165e1SJeff Chang }
260*714165e1SJeff Chang 
261*714165e1SJeff Chang static int rt5133_gpio_set(struct gpio_chip *chip, unsigned int offset, int set_val)
262*714165e1SJeff Chang {
263*714165e1SJeff Chang 	struct rt5133_priv *priv = gpiochip_get_data(chip);
264*714165e1SJeff Chang 	unsigned int mask = 0, val = 0, next_flag = priv->gpio_output_flag;
265*714165e1SJeff Chang 	int ret = 0;
266*714165e1SJeff Chang 
267*714165e1SJeff Chang 	ret = rt5133_get_gpioen_mask(offset, &mask);
268*714165e1SJeff Chang 	if (ret) {
269*714165e1SJeff Chang 		dev_err(priv->dev, "%s get gpion en mask failed, offset(%d)\n", __func__, offset);
270*714165e1SJeff Chang 		return ret;
271*714165e1SJeff Chang 	}
272*714165e1SJeff Chang 
273*714165e1SJeff Chang 	val = set_val ? mask : 0;
274*714165e1SJeff Chang 
275*714165e1SJeff Chang 	if (set_val)
276*714165e1SJeff Chang 		next_flag |= BIT(offset);
277*714165e1SJeff Chang 	else
278*714165e1SJeff Chang 		next_flag &= ~BIT(offset);
279*714165e1SJeff Chang 
280*714165e1SJeff Chang 	ret = regmap_update_bits(priv->regmap, RT5133_REG_GPIO_CTRL, mask, val);
281*714165e1SJeff Chang 	if (ret) {
282*714165e1SJeff Chang 		dev_err(priv->dev, "Failed to set gpio [%d] val %d\n", offset,
283*714165e1SJeff Chang 			set_val);
284*714165e1SJeff Chang 		return ret;
285*714165e1SJeff Chang 	}
286*714165e1SJeff Chang 
287*714165e1SJeff Chang 	priv->gpio_output_flag = next_flag;
288*714165e1SJeff Chang 	return 0;
289*714165e1SJeff Chang }
290*714165e1SJeff Chang 
291*714165e1SJeff Chang static irqreturn_t rt5133_intr_handler(int irq_number, void *data)
292*714165e1SJeff Chang {
293*714165e1SJeff Chang 	struct rt5133_priv *priv = data;
294*714165e1SJeff Chang 	u32 intr_evts = 0, handle_evts;
295*714165e1SJeff Chang 	int i, ret;
296*714165e1SJeff Chang 
297*714165e1SJeff Chang 	ret = regmap_bulk_read(priv->regmap, RT5133_REG_BASE_EVT, &intr_evts,
298*714165e1SJeff Chang 			       RT5133_INTR_BYTE_NR);
299*714165e1SJeff Chang 	if (ret) {
300*714165e1SJeff Chang 		dev_err(priv->dev, "%s, read event failed\n", __func__);
301*714165e1SJeff Chang 		return IRQ_NONE;
302*714165e1SJeff Chang 	}
303*714165e1SJeff Chang 
304*714165e1SJeff Chang 	handle_evts = intr_evts & RT5133_BASE_EVT_MASK;
305*714165e1SJeff Chang 	/*
306*714165e1SJeff Chang 	 * VREF_EVT is a special case, if base off
307*714165e1SJeff Chang 	 * this event will also be trigger. Skip it
308*714165e1SJeff Chang 	 */
309*714165e1SJeff Chang 	if (handle_evts & ~RT5133_VREF_EVT_MASK)
310*714165e1SJeff Chang 		dev_dbg(priv->dev, "base event occurred [0x%02x]\n",
311*714165e1SJeff Chang 			handle_evts);
312*714165e1SJeff Chang 
313*714165e1SJeff Chang 	handle_evts = (intr_evts & RT5133_LDO_OC_EVT_MASK) >>
314*714165e1SJeff Chang 		RT5133_LDO_OC_EVT_SHIFT;
315*714165e1SJeff Chang 
316*714165e1SJeff Chang 	for (i = RT5133_REGULATOR_LDO1; i < RT5133_REGULATOR_MAX && handle_evts; i++) {
317*714165e1SJeff Chang 		if (!(handle_evts & BIT(i - 1)))
318*714165e1SJeff Chang 			continue;
319*714165e1SJeff Chang 		regulator_notifier_call_chain(priv->rdev[i],
320*714165e1SJeff Chang 					      REGULATOR_EVENT_OVER_CURRENT,
321*714165e1SJeff Chang 					      &i);
322*714165e1SJeff Chang 	}
323*714165e1SJeff Chang 
324*714165e1SJeff Chang 	handle_evts = (intr_evts & RT5133_LDO_PGB_EVT_MASK) >>
325*714165e1SJeff Chang 		RT5133_LDO_PGB_EVT_SHIFT;
326*714165e1SJeff Chang 	for (i = RT5133_REGULATOR_LDO1; i < RT5133_REGULATOR_MAX && handle_evts; i++) {
327*714165e1SJeff Chang 		if (!(handle_evts & BIT(i - 1)))
328*714165e1SJeff Chang 			continue;
329*714165e1SJeff Chang 		regulator_notifier_call_chain(priv->rdev[i],
330*714165e1SJeff Chang 					      REGULATOR_EVENT_FAIL, &i);
331*714165e1SJeff Chang 	}
332*714165e1SJeff Chang 
333*714165e1SJeff Chang 	ret = regmap_bulk_write(priv->regmap, RT5133_REG_BASE_EVT, &intr_evts,
334*714165e1SJeff Chang 				RT5133_INTR_BYTE_NR);
335*714165e1SJeff Chang 	if (ret)
336*714165e1SJeff Chang 		dev_err(priv->dev, "%s, clear event failed\n", __func__);
337*714165e1SJeff Chang 
338*714165e1SJeff Chang 	return IRQ_HANDLED;
339*714165e1SJeff Chang }
340*714165e1SJeff Chang 
341*714165e1SJeff Chang static int rt5133_enable_interrupts(int irq_no, struct rt5133_priv *priv)
342*714165e1SJeff Chang {
343*714165e1SJeff Chang 	u32 mask = RT5133_INTR_CLR_MASK;
344*714165e1SJeff Chang 	int ret;
345*714165e1SJeff Chang 
346*714165e1SJeff Chang 	/* Force to write clear all events */
347*714165e1SJeff Chang 	ret = regmap_bulk_write(priv->regmap, RT5133_REG_BASE_EVT, &mask,
348*714165e1SJeff Chang 				RT5133_INTR_BYTE_NR);
349*714165e1SJeff Chang 	if (ret) {
350*714165e1SJeff Chang 		dev_err(priv->dev, "Failed to clear all interrupts\n");
351*714165e1SJeff Chang 		return ret;
352*714165e1SJeff Chang 	}
353*714165e1SJeff Chang 
354*714165e1SJeff Chang 	/* Unmask all interrupts */
355*714165e1SJeff Chang 	mask = 0;
356*714165e1SJeff Chang 	ret = regmap_bulk_write(priv->regmap, RT5133_REG_BASE_MASK, &mask,
357*714165e1SJeff Chang 				RT5133_INTR_BYTE_NR);
358*714165e1SJeff Chang 	if (ret) {
359*714165e1SJeff Chang 		dev_err(priv->dev, "Failed to unmask all interrupts\n");
360*714165e1SJeff Chang 		return ret;
361*714165e1SJeff Chang 	}
362*714165e1SJeff Chang 
363*714165e1SJeff Chang 	return devm_request_threaded_irq(priv->dev, irq_no, NULL,
364*714165e1SJeff Chang 					 rt5133_intr_handler, IRQF_ONESHOT,
365*714165e1SJeff Chang 					 dev_name(priv->dev), priv);
366*714165e1SJeff Chang }
367*714165e1SJeff Chang 
368*714165e1SJeff Chang static int rt5133_regmap_hw_read(void *context, const void *reg_buf,
369*714165e1SJeff Chang 				 size_t reg_size, void *val_buf,
370*714165e1SJeff Chang 				 size_t val_size)
371*714165e1SJeff Chang {
372*714165e1SJeff Chang 	struct rt5133_priv *priv = context;
373*714165e1SJeff Chang 	struct i2c_client *client = to_i2c_client(priv->dev);
374*714165e1SJeff Chang 	u8 reg = *(u8 *)reg_buf, crc;
375*714165e1SJeff Chang 	u8 *buf;
376*714165e1SJeff Chang 	int buf_len = RT5133_PREDATA_LEN + val_size + RT5133_I2C_CRC_LEN;
377*714165e1SJeff Chang 	int read_len, ret;
378*714165e1SJeff Chang 
379*714165e1SJeff Chang 	buf = kzalloc(buf_len, GFP_KERNEL);
380*714165e1SJeff Chang 	if (!buf)
381*714165e1SJeff Chang 		return -ENOMEM;
382*714165e1SJeff Chang 
383*714165e1SJeff Chang 	buf[0] = I2C_ADDR_XLATE_8BIT(client->addr, I2C_SMBUS_READ);
384*714165e1SJeff Chang 	buf[1] = reg;
385*714165e1SJeff Chang 
386*714165e1SJeff Chang 	read_len = val_size + RT5133_I2C_CRC_LEN;
387*714165e1SJeff Chang 	ret = i2c_smbus_read_i2c_block_data(client, reg, read_len,
388*714165e1SJeff Chang 					    buf + RT5133_PREDATA_LEN);
389*714165e1SJeff Chang 
390*714165e1SJeff Chang 	if (ret < 0)
391*714165e1SJeff Chang 		goto out_read_err;
392*714165e1SJeff Chang 
393*714165e1SJeff Chang 	if (ret != read_len) {
394*714165e1SJeff Chang 		ret = -EIO;
395*714165e1SJeff Chang 		goto out_read_err;
396*714165e1SJeff Chang 	}
397*714165e1SJeff Chang 
398*714165e1SJeff Chang 	crc = crc8(priv->crc8_tbls, buf, RT5133_PREDATA_LEN + val_size, 0);
399*714165e1SJeff Chang 	if (crc != buf[RT5133_PREDATA_LEN + val_size]) {
400*714165e1SJeff Chang 		ret = -EIO;
401*714165e1SJeff Chang 		goto out_read_err;
402*714165e1SJeff Chang 	}
403*714165e1SJeff Chang 
404*714165e1SJeff Chang 	memcpy(val_buf, buf + RT5133_PREDATA_LEN, val_size);
405*714165e1SJeff Chang 	dev_dbg(priv->dev, "%s, reg = 0x%02x, data = 0x%02x\n", __func__, reg, *(u8 *)val_buf);
406*714165e1SJeff Chang 
407*714165e1SJeff Chang out_read_err:
408*714165e1SJeff Chang 	kfree(buf);
409*714165e1SJeff Chang 	return (ret < 0) ? ret : 0;
410*714165e1SJeff Chang }
411*714165e1SJeff Chang 
412*714165e1SJeff Chang static int rt5133_regmap_hw_write(void *context, const void *data, size_t count)
413*714165e1SJeff Chang {
414*714165e1SJeff Chang 	struct rt5133_priv *priv = context;
415*714165e1SJeff Chang 	struct i2c_client *client = to_i2c_client(priv->dev);
416*714165e1SJeff Chang 	u8 reg = *(u8 *)data, crc;
417*714165e1SJeff Chang 	u8 *buf;
418*714165e1SJeff Chang 	int buf_len = RT5133_I2C_ADDR_LEN + count + RT5133_I2C_CRC_LEN +
419*714165e1SJeff Chang 		RT5133_I2C_DUMMY_LEN;
420*714165e1SJeff Chang 	int write_len, ret;
421*714165e1SJeff Chang 
422*714165e1SJeff Chang 	buf = kzalloc(buf_len, GFP_KERNEL);
423*714165e1SJeff Chang 	if (!buf)
424*714165e1SJeff Chang 		return -ENOMEM;
425*714165e1SJeff Chang 
426*714165e1SJeff Chang 	buf[0] = I2C_ADDR_XLATE_8BIT(client->addr, I2C_SMBUS_WRITE);
427*714165e1SJeff Chang 	buf[1] = reg;
428*714165e1SJeff Chang 	memcpy(buf + RT5133_PREDATA_LEN, data + RT5133_REG_ADDR_LEN,
429*714165e1SJeff Chang 	       count - RT5133_REG_ADDR_LEN);
430*714165e1SJeff Chang 
431*714165e1SJeff Chang 	crc = crc8(priv->crc8_tbls, buf, RT5133_I2C_ADDR_LEN + count, 0);
432*714165e1SJeff Chang 	buf[RT5133_I2C_ADDR_LEN + count] = crc;
433*714165e1SJeff Chang 
434*714165e1SJeff Chang 	write_len = count - RT5133_REG_ADDR_LEN + RT5133_I2C_CRC_LEN +
435*714165e1SJeff Chang 		RT5133_I2C_DUMMY_LEN;
436*714165e1SJeff Chang 	ret = i2c_smbus_write_i2c_block_data(client, reg, write_len,
437*714165e1SJeff Chang 					     buf + RT5133_PREDATA_LEN);
438*714165e1SJeff Chang 
439*714165e1SJeff Chang 	dev_dbg(priv->dev, "%s, reg = 0x%02x, data = 0x%02x\n", __func__, reg,
440*714165e1SJeff Chang 		*(u8 *)(buf + RT5133_PREDATA_LEN));
441*714165e1SJeff Chang 	kfree(buf);
442*714165e1SJeff Chang 	return ret;
443*714165e1SJeff Chang }
444*714165e1SJeff Chang 
445*714165e1SJeff Chang static const struct regmap_bus rt5133_regmap_bus = {
446*714165e1SJeff Chang 	.read = rt5133_regmap_hw_read,
447*714165e1SJeff Chang 	.write = rt5133_regmap_hw_write,
448*714165e1SJeff Chang 	/* Due to crc, the block read/write length has the limit */
449*714165e1SJeff Chang 	.max_raw_read = RT5133_MAX_I2C_BLOCK_SIZE,
450*714165e1SJeff Chang 	.max_raw_write = RT5133_MAX_I2C_BLOCK_SIZE,
451*714165e1SJeff Chang };
452*714165e1SJeff Chang 
453*714165e1SJeff Chang static bool rt5133_is_volatile_reg(struct device *dev, unsigned int reg)
454*714165e1SJeff Chang {
455*714165e1SJeff Chang 	switch (reg) {
456*714165e1SJeff Chang 	case RT5133_REG_CHIP_INFO:
457*714165e1SJeff Chang 	case RT5133_REG_BASE_EVT...RT5133_REG_LDO_PGB_STAT:
458*714165e1SJeff Chang 	case RT5133_REG_LDO_ON...RT5133_REG_LDO_OFF:
459*714165e1SJeff Chang 	case RT5133_REG_LDO1_CTRL1:
460*714165e1SJeff Chang 	case RT5133_REG_LDO2_CTRL1:
461*714165e1SJeff Chang 	case RT5133_REG_LDO3_CTRL1:
462*714165e1SJeff Chang 	case RT5133_REG_LDO4_CTRL1:
463*714165e1SJeff Chang 	case RT5133_REG_LDO5_CTRL1:
464*714165e1SJeff Chang 	case RT5133_REG_LDO6_CTRL1:
465*714165e1SJeff Chang 	case RT5133_REG_LDO7_CTRL1:
466*714165e1SJeff Chang 	case RT5133_REG_LDO8_CTRL1:
467*714165e1SJeff Chang 		return true;
468*714165e1SJeff Chang 	default:
469*714165e1SJeff Chang 		return false;
470*714165e1SJeff Chang 	};
471*714165e1SJeff Chang }
472*714165e1SJeff Chang 
473*714165e1SJeff Chang static const struct regmap_config rt5133_regmap_config = {
474*714165e1SJeff Chang 	.reg_bits = 8,
475*714165e1SJeff Chang 	.val_bits = 8,
476*714165e1SJeff Chang 	.max_register = RT5133_REG_LDO8_CTRL4,
477*714165e1SJeff Chang 	.cache_type = REGCACHE_FLAT,
478*714165e1SJeff Chang 	.num_reg_defaults_raw = RT5133_REG_LDO8_CTRL4 + 1,
479*714165e1SJeff Chang 	.volatile_reg = rt5133_is_volatile_reg,
480*714165e1SJeff Chang };
481*714165e1SJeff Chang 
482*714165e1SJeff Chang static int rt5133_chip_reset(struct rt5133_priv *priv)
483*714165e1SJeff Chang {
484*714165e1SJeff Chang 	int ret;
485*714165e1SJeff Chang 
486*714165e1SJeff Chang 	ret = regmap_write(priv->regmap, RT5133_REG_RST_CTRL,
487*714165e1SJeff Chang 			   RT5133_RESET_CODE);
488*714165e1SJeff Chang 	if (ret)
489*714165e1SJeff Chang 		return ret;
490*714165e1SJeff Chang 
491*714165e1SJeff Chang 	/* Wait for register reset to take effect */
492*714165e1SJeff Chang 	udelay(2);
493*714165e1SJeff Chang 
494*714165e1SJeff Chang 	return 0;
495*714165e1SJeff Chang }
496*714165e1SJeff Chang 
497*714165e1SJeff Chang static int rt5133_validate_vendor_info(struct rt5133_priv *priv)
498*714165e1SJeff Chang {
499*714165e1SJeff Chang 	unsigned int val = 0;
500*714165e1SJeff Chang 	int i, ret;
501*714165e1SJeff Chang 
502*714165e1SJeff Chang 	ret = regmap_read(priv->regmap, RT5133_REG_CHIP_INFO, &val);
503*714165e1SJeff Chang 	if (ret)
504*714165e1SJeff Chang 		return ret;
505*714165e1SJeff Chang 
506*714165e1SJeff Chang 	for (i = 0; i < ARRAY_SIZE(regulator_data); i++) {
507*714165e1SJeff Chang 		if ((val & RT5133_VENDOR_ID_MASK) ==
508*714165e1SJeff Chang 						regulator_data[i].vendor_id){
509*714165e1SJeff Chang 			priv->cdata = &regulator_data[i];
510*714165e1SJeff Chang 			break;
511*714165e1SJeff Chang 		}
512*714165e1SJeff Chang 	}
513*714165e1SJeff Chang 	if (IS_ERR(priv->cdata)) {
514*714165e1SJeff Chang 		dev_err(priv->dev, "Failed to find regualtor match version\n");
515*714165e1SJeff Chang 		return -ENODEV;
516*714165e1SJeff Chang 	}
517*714165e1SJeff Chang 
518*714165e1SJeff Chang 	return 0;
519*714165e1SJeff Chang }
520*714165e1SJeff Chang 
521*714165e1SJeff Chang static int rt5133_parse_dt(struct rt5133_priv *priv)
522*714165e1SJeff Chang {
523*714165e1SJeff Chang 	unsigned int val = 0;
524*714165e1SJeff Chang 	int ret = 0;
525*714165e1SJeff Chang 
526*714165e1SJeff Chang 	if (!device_property_read_bool(priv->dev, "richtek,oc-shutdown-all"))
527*714165e1SJeff Chang 		val = 0;
528*714165e1SJeff Chang 	else
529*714165e1SJeff Chang 		val = 1 << RT5133_OCSHDN_ALL_SHIFT;
530*714165e1SJeff Chang 	ret = regmap_update_bits(priv->regmap, RT5133_REG_LDO_SHDN,
531*714165e1SJeff Chang 				 RT5133_OCSHDN_ALL_MASK, val);
532*714165e1SJeff Chang 	if (ret)
533*714165e1SJeff Chang 		return ret;
534*714165e1SJeff Chang 
535*714165e1SJeff Chang 	if (!device_property_read_bool(priv->dev, "richtek,pgb-shutdown-all"))
536*714165e1SJeff Chang 		val = 0;
537*714165e1SJeff Chang 	else
538*714165e1SJeff Chang 		val = 1 << RT5133_PGBSHDN_ALL_SHIFT;
539*714165e1SJeff Chang 	return regmap_update_bits(priv->regmap, RT5133_REG_LDO_SHDN,
540*714165e1SJeff Chang 				  RT5133_PGBSHDN_ALL_MASK, val);
541*714165e1SJeff Chang }
542*714165e1SJeff Chang 
543*714165e1SJeff Chang static int rt5133_probe(struct i2c_client *i2c)
544*714165e1SJeff Chang {
545*714165e1SJeff Chang 	struct rt5133_priv *priv;
546*714165e1SJeff Chang 	struct regulator_config config = {0};
547*714165e1SJeff Chang 	int i, ret;
548*714165e1SJeff Chang 
549*714165e1SJeff Chang 	priv = devm_kzalloc(&i2c->dev, sizeof(*priv), GFP_KERNEL);
550*714165e1SJeff Chang 	if (!priv)
551*714165e1SJeff Chang 		return -ENOMEM;
552*714165e1SJeff Chang 
553*714165e1SJeff Chang 	priv->dev = &i2c->dev;
554*714165e1SJeff Chang 	crc8_populate_msb(priv->crc8_tbls, RT5133_CRC8_POLYNOMIAL);
555*714165e1SJeff Chang 
556*714165e1SJeff Chang 	priv->enable_gpio = devm_gpiod_get_optional(&i2c->dev, "enable",
557*714165e1SJeff Chang 						    GPIOD_OUT_HIGH);
558*714165e1SJeff Chang 	if (IS_ERR(priv->enable_gpio))
559*714165e1SJeff Chang 		dev_err(&i2c->dev, "Failed to request HWEN gpio, check if default en=high\n");
560*714165e1SJeff Chang 
561*714165e1SJeff Chang 	priv->regmap = devm_regmap_init(&i2c->dev, &rt5133_regmap_bus, priv,
562*714165e1SJeff Chang 					&rt5133_regmap_config);
563*714165e1SJeff Chang 	if (IS_ERR(priv->regmap)) {
564*714165e1SJeff Chang 		dev_err(&i2c->dev, "Failed to register regmap\n");
565*714165e1SJeff Chang 		return PTR_ERR(priv->regmap);
566*714165e1SJeff Chang 	}
567*714165e1SJeff Chang 
568*714165e1SJeff Chang 	ret = rt5133_validate_vendor_info(priv);
569*714165e1SJeff Chang 	if (ret) {
570*714165e1SJeff Chang 		dev_err(&i2c->dev, "Failed to check vendor info [%d]\n", ret);
571*714165e1SJeff Chang 		return ret;
572*714165e1SJeff Chang 	}
573*714165e1SJeff Chang 
574*714165e1SJeff Chang 	ret = rt5133_chip_reset(priv);
575*714165e1SJeff Chang 	if (ret) {
576*714165e1SJeff Chang 		dev_err(&i2c->dev, "Failed to execute sw reset\n");
577*714165e1SJeff Chang 		return ret;
578*714165e1SJeff Chang 	}
579*714165e1SJeff Chang 
580*714165e1SJeff Chang 	config.dev = &i2c->dev;
581*714165e1SJeff Chang 	config.driver_data = priv;
582*714165e1SJeff Chang 	config.regmap = priv->regmap;
583*714165e1SJeff Chang 
584*714165e1SJeff Chang 	for (i = 0; i < RT5133_REGULATOR_MAX; i++) {
585*714165e1SJeff Chang 		priv->rdev[i] = devm_regulator_register(&i2c->dev,
586*714165e1SJeff Chang 							priv->cdata->regulators + i,
587*714165e1SJeff Chang 							&config);
588*714165e1SJeff Chang 		if (IS_ERR(priv->rdev[i])) {
589*714165e1SJeff Chang 			dev_err(&i2c->dev,
590*714165e1SJeff Chang 				"Failed to register [%d] regulator\n", i);
591*714165e1SJeff Chang 			return PTR_ERR(priv->rdev[i]);
592*714165e1SJeff Chang 		}
593*714165e1SJeff Chang 	}
594*714165e1SJeff Chang 
595*714165e1SJeff Chang 	ret = rt5133_parse_dt(priv);
596*714165e1SJeff Chang 	if (ret) {
597*714165e1SJeff Chang 		dev_err(&i2c->dev, "%s, Failed to parse dt\n", __func__);
598*714165e1SJeff Chang 		return ret;
599*714165e1SJeff Chang 	}
600*714165e1SJeff Chang 
601*714165e1SJeff Chang 	priv->gc.label = dev_name(&i2c->dev);
602*714165e1SJeff Chang 	priv->gc.parent = &i2c->dev;
603*714165e1SJeff Chang 	priv->gc.base = -1;
604*714165e1SJeff Chang 	priv->gc.ngpio = RT5133_GPIO_NR;
605*714165e1SJeff Chang 	priv->gc.set = rt5133_gpio_set;
606*714165e1SJeff Chang 	priv->gc.get = rt5133_gpio_get;
607*714165e1SJeff Chang 	priv->gc.direction_output = rt5133_gpio_direction_output;
608*714165e1SJeff Chang 	priv->gc.can_sleep = true;
609*714165e1SJeff Chang 
610*714165e1SJeff Chang 	ret = devm_gpiochip_add_data(&i2c->dev, &priv->gc, priv);
611*714165e1SJeff Chang 	if (ret)
612*714165e1SJeff Chang 		return ret;
613*714165e1SJeff Chang 
614*714165e1SJeff Chang 	ret = rt5133_enable_interrupts(i2c->irq, priv);
615*714165e1SJeff Chang 	if (ret) {
616*714165e1SJeff Chang 		dev_err(&i2c->dev, "enable interrupt failed\n");
617*714165e1SJeff Chang 		return ret;
618*714165e1SJeff Chang 	}
619*714165e1SJeff Chang 
620*714165e1SJeff Chang 	i2c_set_clientdata(i2c, priv);
621*714165e1SJeff Chang 
622*714165e1SJeff Chang 	return ret;
623*714165e1SJeff Chang }
624*714165e1SJeff Chang 
625*714165e1SJeff Chang static const struct of_device_id __maybe_unused rt5133_of_match_table[] = {
626*714165e1SJeff Chang 	{ .compatible = "richtek,rt5133", },
627*714165e1SJeff Chang 	{ }
628*714165e1SJeff Chang };
629*714165e1SJeff Chang MODULE_DEVICE_TABLE(of, rt5133_of_match_table);
630*714165e1SJeff Chang 
631*714165e1SJeff Chang static struct i2c_driver rt5133_driver = {
632*714165e1SJeff Chang 	.driver = {
633*714165e1SJeff Chang 		.name = "rt5133",
634*714165e1SJeff Chang 		.probe_type = PROBE_PREFER_ASYNCHRONOUS,
635*714165e1SJeff Chang 		.of_match_table = rt5133_of_match_table,
636*714165e1SJeff Chang 	},
637*714165e1SJeff Chang 	.probe = rt5133_probe,
638*714165e1SJeff Chang };
639*714165e1SJeff Chang module_i2c_driver(rt5133_driver);
640*714165e1SJeff Chang 
641*714165e1SJeff Chang MODULE_DESCRIPTION("RT5133 Regulator Driver");
642*714165e1SJeff Chang MODULE_LICENSE("GPL v2");
643