xref: /linux/drivers/pinctrl/pinctrl-tps6594.c (revision bf977a9ad33d204c8ca646cef83184eb364820ff)
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * Pinmux and GPIO driver for tps6594 PMIC
4  *
5  * Copyright (C) 2023 BayLibre Incorporated - https://www.baylibre.com/
6  */
7 
8 #include <linux/gpio/driver.h>
9 #include <linux/gpio/regmap.h>
10 #include <linux/module.h>
11 #include <linux/pinctrl/pinmux.h>
12 #include <linux/platform_device.h>
13 #include <linux/mod_devicetable.h>
14 
15 #include <linux/mfd/tps6594.h>
16 
17 #define TPS6594_PINCTRL_GPIO_FUNCTION 0
18 #define TPS6594_PINCTRL_SCL_I2C2_CS_SPI_FUNCTION 1
19 #define TPS6594_PINCTRL_TRIG_WDOG_FUNCTION 1
20 #define TPS6594_PINCTRL_CLK32KOUT_FUNCTION 1
21 #define TPS6594_PINCTRL_SCLK_SPMI_FUNCTION 1
22 #define TPS6594_PINCTRL_SDATA_SPMI_FUNCTION 1
23 #define TPS6594_PINCTRL_NERR_MCU_FUNCTION 1
24 #define TPS6594_PINCTRL_PDOG_FUNCTION 1
25 #define TPS6594_PINCTRL_SYNCCLKIN_FUNCTION 1
26 #define TPS6594_PINCTRL_NRSTOUT_SOC_FUNCTION 2
27 #define TPS6594_PINCTRL_SYNCCLKOUT_FUNCTION 2
28 #define TPS6594_PINCTRL_SDA_I2C2_SDO_SPI_FUNCTION 2
29 #define TPS6594_PINCTRL_NERR_SOC_FUNCTION 2
30 #define TPS6594_PINCTRL_DISABLE_WDOG_FUNCTION 3
31 #define TPS6594_PINCTRL_NSLEEP1_FUNCTION 4
32 #define TPS6594_PINCTRL_NSLEEP2_FUNCTION 5
33 #define TPS6594_PINCTRL_WKUP1_FUNCTION 6
34 #define TPS6594_PINCTRL_WKUP2_FUNCTION 7
35 
36 /* Special muxval for recalcitrant pins */
37 #define TPS6594_PINCTRL_DISABLE_WDOG_FUNCTION_GPIO8 2
38 #define TPS6594_PINCTRL_SYNCCLKOUT_FUNCTION_GPIO8 3
39 #define TPS6594_PINCTRL_CLK32KOUT_FUNCTION_GPIO9 3
40 
41 /* TPS65224 pin muxval */
42 #define TPS65224_PINCTRL_SDA_I2C2_SDO_SPI_FUNCTION 1
43 #define TPS65224_PINCTRL_SCL_I2C2_CS_SPI_FUNCTION 1
44 #define TPS65224_PINCTRL_VMON1_FUNCTION 1
45 #define TPS65224_PINCTRL_VMON2_FUNCTION 1
46 #define TPS65224_PINCTRL_WKUP_FUNCTION 1
47 #define TPS65224_PINCTRL_NSLEEP2_FUNCTION 2
48 #define TPS65224_PINCTRL_NSLEEP1_FUNCTION 2
49 #define TPS65224_PINCTRL_SYNCCLKIN_FUNCTION 2
50 #define TPS65224_PINCTRL_NERR_MCU_FUNCTION 2
51 #define TPS65224_PINCTRL_NINT_FUNCTION 3
52 #define TPS65224_PINCTRL_TRIG_WDOG_FUNCTION 3
53 #define TPS65224_PINCTRL_PB_FUNCTION 3
54 #define TPS65224_PINCTRL_ADC_IN_FUNCTION 3
55 
56 /* TPS65224 Special muxval for recalcitrant pins */
57 #define TPS65224_PINCTRL_NSLEEP2_FUNCTION_GPIO5 1
58 #define TPS65224_PINCTRL_WKUP_FUNCTION_GPIO5 4
59 #define TPS65224_PINCTRL_SYNCCLKIN_FUNCTION_GPIO5 3
60 
61 #define TPS6594_OFFSET_GPIO_SEL 5
62 
63 #define TPS65224_NGPIO_PER_REG 6
64 #define TPS6594_NGPIO_PER_REG  8
65 
66 #define FUNCTION(dev_name, fname, v)							\
67 {											\
68 	.pinfunction = PINCTRL_PINFUNCTION(#fname,					\
69 					dev_name##_##fname##_func_group_names,		\
70 					ARRAY_SIZE(dev_name##_##fname##_func_group_names)),\
71 	.muxval = v,									\
72 }
73 
74 static const struct pinctrl_pin_desc tps6594_pins[] = {
75 	PINCTRL_PIN(0, "GPIO0"),   PINCTRL_PIN(1, "GPIO1"),
76 	PINCTRL_PIN(2, "GPIO2"),   PINCTRL_PIN(3, "GPIO3"),
77 	PINCTRL_PIN(4, "GPIO4"),   PINCTRL_PIN(5, "GPIO5"),
78 	PINCTRL_PIN(6, "GPIO6"),   PINCTRL_PIN(7, "GPIO7"),
79 	PINCTRL_PIN(8, "GPIO8"),   PINCTRL_PIN(9, "GPIO9"),
80 	PINCTRL_PIN(10, "GPIO10"),
81 };
82 
83 static const char *const tps6594_gpio_func_group_names[] = {
84 	"GPIO0", "GPIO1", "GPIO2", "GPIO3", "GPIO4", "GPIO5",
85 	"GPIO6", "GPIO7", "GPIO8", "GPIO9", "GPIO10",
86 };
87 
88 static const char *const tps6594_nsleep1_func_group_names[] = {
89 	"GPIO0", "GPIO1", "GPIO2", "GPIO3", "GPIO4", "GPIO5",
90 	"GPIO6", "GPIO7", "GPIO8", "GPIO9", "GPIO10",
91 };
92 
93 static const char *const tps6594_nsleep2_func_group_names[] = {
94 	"GPIO0", "GPIO1", "GPIO2", "GPIO3", "GPIO4", "GPIO5",
95 	"GPIO6", "GPIO7", "GPIO8", "GPIO9", "GPIO10",
96 };
97 
98 static const char *const tps6594_wkup1_func_group_names[] = {
99 	"GPIO0", "GPIO1", "GPIO2", "GPIO3", "GPIO4", "GPIO5",
100 	"GPIO6", "GPIO7", "GPIO8", "GPIO9", "GPIO10",
101 };
102 
103 static const char *const tps6594_wkup2_func_group_names[] = {
104 	"GPIO0", "GPIO1", "GPIO2", "GPIO3", "GPIO4", "GPIO5",
105 	"GPIO6", "GPIO7", "GPIO8", "GPIO9", "GPIO10",
106 };
107 
108 static const char *const tps6594_scl_i2c2_cs_spi_func_group_names[] = {
109 	"GPIO0",
110 	"GPIO1",
111 };
112 
113 static const char *const tps6594_nrstout_soc_func_group_names[] = {
114 	"GPIO0",
115 	"GPIO10",
116 };
117 
118 static const char *const tps6594_trig_wdog_func_group_names[] = {
119 	"GPIO1",
120 	"GPIO10",
121 };
122 
123 static const char *const tps6594_sda_i2c2_sdo_spi_func_group_names[] = {
124 	"GPIO1",
125 };
126 
127 static const char *const tps6594_clk32kout_func_group_names[] = {
128 	"GPIO2",
129 	"GPIO3",
130 	"GPIO7",
131 };
132 
133 static const char *const tps6594_nerr_soc_func_group_names[] = {
134 	"GPIO2",
135 };
136 
137 static const char *const tps6594_sclk_spmi_func_group_names[] = {
138 	"GPIO4",
139 };
140 
141 static const char *const tps6594_sdata_spmi_func_group_names[] = {
142 	"GPIO5",
143 };
144 
145 static const char *const tps6594_nerr_mcu_func_group_names[] = {
146 	"GPIO6",
147 };
148 
149 static const char *const tps6594_syncclkout_func_group_names[] = {
150 	"GPIO7",
151 	"GPIO9",
152 };
153 
154 static const char *const tps6594_disable_wdog_func_group_names[] = {
155 	"GPIO7",
156 	"GPIO8",
157 };
158 
159 static const char *const tps6594_pdog_func_group_names[] = {
160 	"GPIO8",
161 };
162 
163 static const char *const tps6594_syncclkin_func_group_names[] = {
164 	"GPIO9",
165 };
166 
167 static const struct pinctrl_pin_desc tps65224_pins[] = {
168 	PINCTRL_PIN(0, "GPIO0"),   PINCTRL_PIN(1, "GPIO1"),
169 	PINCTRL_PIN(2, "GPIO2"),   PINCTRL_PIN(3, "GPIO3"),
170 	PINCTRL_PIN(4, "GPIO4"),   PINCTRL_PIN(5, "GPIO5"),
171 };
172 
173 static const char *const tps65224_gpio_func_group_names[] = {
174 	"GPIO0", "GPIO1", "GPIO2", "GPIO3", "GPIO4", "GPIO5",
175 };
176 
177 static const char *const tps65224_sda_i2c2_sdo_spi_func_group_names[] = {
178 	"GPIO0",
179 };
180 
181 static const char *const tps65224_nsleep2_func_group_names[] = {
182 	"GPIO0", "GPIO5",
183 };
184 
185 static const char *const tps65224_nint_func_group_names[] = {
186 	"GPIO0",
187 };
188 
189 static const char *const tps65224_scl_i2c2_cs_spi_func_group_names[] = {
190 	"GPIO1",
191 };
192 
193 static const char *const tps65224_nsleep1_func_group_names[] = {
194 	"GPIO1", "GPIO2", "GPIO3",
195 };
196 
197 static const char *const tps65224_trig_wdog_func_group_names[] = {
198 	"GPIO1",
199 };
200 
201 static const char *const tps65224_vmon1_func_group_names[] = {
202 	"GPIO2",
203 };
204 
205 static const char *const tps65224_pb_func_group_names[] = {
206 	"GPIO2",
207 };
208 
209 static const char *const tps65224_vmon2_func_group_names[] = {
210 	"GPIO3",
211 };
212 
213 static const char *const tps65224_adc_in_func_group_names[] = {
214 	"GPIO3", "GPIO4",
215 };
216 
217 static const char *const tps65224_wkup_func_group_names[] = {
218 	"GPIO4", "GPIO5",
219 };
220 
221 static const char *const tps65224_syncclkin_func_group_names[] = {
222 	"GPIO4", "GPIO5",
223 };
224 
225 static const char *const tps65224_nerr_mcu_func_group_names[] = {
226 	"GPIO5",
227 };
228 
229 static const char *const tps652g1_cs_spi_func_group_names[] = {
230 	"GPIO1",
231 };
232 
233 struct tps6594_pinctrl_function {
234 	struct pinfunction pinfunction;
235 	u8 muxval;
236 };
237 
238 struct muxval_remap {
239 	unsigned int group;
240 	u8 muxval;
241 	u8 remap;
242 };
243 
244 static struct muxval_remap tps65224_muxval_remap[] = {
245 	{5, TPS6594_PINCTRL_DISABLE_WDOG_FUNCTION, TPS65224_PINCTRL_WKUP_FUNCTION_GPIO5},
246 	{5, TPS65224_PINCTRL_SYNCCLKIN_FUNCTION, TPS65224_PINCTRL_SYNCCLKIN_FUNCTION_GPIO5},
247 	{5, TPS65224_PINCTRL_NSLEEP2_FUNCTION, TPS65224_PINCTRL_NSLEEP2_FUNCTION_GPIO5},
248 };
249 
250 static struct muxval_remap tps6594_muxval_remap[] = {
251 	{8, TPS6594_PINCTRL_DISABLE_WDOG_FUNCTION, TPS6594_PINCTRL_DISABLE_WDOG_FUNCTION_GPIO8},
252 	{8, TPS6594_PINCTRL_SYNCCLKOUT_FUNCTION, TPS6594_PINCTRL_SYNCCLKOUT_FUNCTION_GPIO8},
253 	{9, TPS6594_PINCTRL_CLK32KOUT_FUNCTION, TPS6594_PINCTRL_CLK32KOUT_FUNCTION_GPIO9},
254 };
255 
256 static const struct tps6594_pinctrl_function pinctrl_functions[] = {
257 	FUNCTION(tps6594, gpio, TPS6594_PINCTRL_GPIO_FUNCTION),
258 	FUNCTION(tps6594, nsleep1, TPS6594_PINCTRL_NSLEEP1_FUNCTION),
259 	FUNCTION(tps6594, nsleep2, TPS6594_PINCTRL_NSLEEP2_FUNCTION),
260 	FUNCTION(tps6594, wkup1, TPS6594_PINCTRL_WKUP1_FUNCTION),
261 	FUNCTION(tps6594, wkup2, TPS6594_PINCTRL_WKUP2_FUNCTION),
262 	FUNCTION(tps6594, scl_i2c2_cs_spi, TPS6594_PINCTRL_SCL_I2C2_CS_SPI_FUNCTION),
263 	FUNCTION(tps6594, nrstout_soc, TPS6594_PINCTRL_NRSTOUT_SOC_FUNCTION),
264 	FUNCTION(tps6594, trig_wdog, TPS6594_PINCTRL_TRIG_WDOG_FUNCTION),
265 	FUNCTION(tps6594, sda_i2c2_sdo_spi, TPS6594_PINCTRL_SDA_I2C2_SDO_SPI_FUNCTION),
266 	FUNCTION(tps6594, clk32kout, TPS6594_PINCTRL_CLK32KOUT_FUNCTION),
267 	FUNCTION(tps6594, nerr_soc, TPS6594_PINCTRL_NERR_SOC_FUNCTION),
268 	FUNCTION(tps6594, sclk_spmi, TPS6594_PINCTRL_SCLK_SPMI_FUNCTION),
269 	FUNCTION(tps6594, sdata_spmi, TPS6594_PINCTRL_SDATA_SPMI_FUNCTION),
270 	FUNCTION(tps6594, nerr_mcu, TPS6594_PINCTRL_NERR_MCU_FUNCTION),
271 	FUNCTION(tps6594, syncclkout, TPS6594_PINCTRL_SYNCCLKOUT_FUNCTION),
272 	FUNCTION(tps6594, disable_wdog, TPS6594_PINCTRL_DISABLE_WDOG_FUNCTION),
273 	FUNCTION(tps6594, pdog, TPS6594_PINCTRL_PDOG_FUNCTION),
274 	FUNCTION(tps6594, syncclkin, TPS6594_PINCTRL_SYNCCLKIN_FUNCTION),
275 };
276 
277 static const struct tps6594_pinctrl_function tps65224_pinctrl_functions[] = {
278 	FUNCTION(tps65224, gpio, TPS6594_PINCTRL_GPIO_FUNCTION),
279 	FUNCTION(tps65224, sda_i2c2_sdo_spi, TPS65224_PINCTRL_SDA_I2C2_SDO_SPI_FUNCTION),
280 	FUNCTION(tps65224, nsleep2, TPS65224_PINCTRL_NSLEEP2_FUNCTION),
281 	FUNCTION(tps65224, nint, TPS65224_PINCTRL_NINT_FUNCTION),
282 	FUNCTION(tps65224, scl_i2c2_cs_spi, TPS65224_PINCTRL_SCL_I2C2_CS_SPI_FUNCTION),
283 	FUNCTION(tps65224, nsleep1, TPS65224_PINCTRL_NSLEEP1_FUNCTION),
284 	FUNCTION(tps65224, trig_wdog, TPS65224_PINCTRL_TRIG_WDOG_FUNCTION),
285 	FUNCTION(tps65224, vmon1, TPS65224_PINCTRL_VMON1_FUNCTION),
286 	FUNCTION(tps65224, pb, TPS65224_PINCTRL_PB_FUNCTION),
287 	FUNCTION(tps65224, vmon2, TPS65224_PINCTRL_VMON2_FUNCTION),
288 	FUNCTION(tps65224, adc_in, TPS65224_PINCTRL_ADC_IN_FUNCTION),
289 	FUNCTION(tps65224, wkup, TPS65224_PINCTRL_WKUP_FUNCTION),
290 	FUNCTION(tps65224, syncclkin, TPS65224_PINCTRL_SYNCCLKIN_FUNCTION),
291 	FUNCTION(tps65224, nerr_mcu, TPS65224_PINCTRL_NERR_MCU_FUNCTION),
292 };
293 
294 static const struct tps6594_pinctrl_function tps652g1_pinctrl_functions[] = {
295 	FUNCTION(tps65224, gpio, TPS6594_PINCTRL_GPIO_FUNCTION),
296 	FUNCTION(tps65224, sda_i2c2_sdo_spi, TPS65224_PINCTRL_SDA_I2C2_SDO_SPI_FUNCTION),
297 	FUNCTION(tps65224, nsleep2, TPS65224_PINCTRL_NSLEEP2_FUNCTION),
298 	FUNCTION(tps65224, nint, TPS65224_PINCTRL_NINT_FUNCTION),
299 	FUNCTION(tps652g1, cs_spi, TPS65224_PINCTRL_SCL_I2C2_CS_SPI_FUNCTION),
300 	FUNCTION(tps65224, nsleep1, TPS65224_PINCTRL_NSLEEP1_FUNCTION),
301 	FUNCTION(tps65224, pb, TPS65224_PINCTRL_PB_FUNCTION),
302 	FUNCTION(tps65224, wkup, TPS65224_PINCTRL_WKUP_FUNCTION),
303 	FUNCTION(tps65224, syncclkin, TPS65224_PINCTRL_SYNCCLKIN_FUNCTION),
304 };
305 
306 struct tps6594_pinctrl {
307 	struct tps6594 *tps;
308 	struct gpio_regmap *gpio_regmap;
309 	struct pinctrl_dev *pctl_dev;
310 	const struct tps6594_pinctrl_function *funcs;
311 	const struct pinctrl_pin_desc *pins;
312 	int func_cnt;
313 	int num_pins;
314 	u8 mux_sel_mask;
315 	unsigned int remap_cnt;
316 	struct muxval_remap *remap;
317 };
318 
319 static struct tps6594_pinctrl tps652g1_template_pinctrl = {
320 	.funcs = tps652g1_pinctrl_functions,
321 	.func_cnt = ARRAY_SIZE(tps652g1_pinctrl_functions),
322 	.pins = tps65224_pins,
323 	.num_pins = ARRAY_SIZE(tps65224_pins),
324 	.mux_sel_mask = TPS65224_MASK_GPIO_SEL,
325 	.remap = tps65224_muxval_remap,
326 	.remap_cnt = ARRAY_SIZE(tps65224_muxval_remap),
327 };
328 
329 static struct tps6594_pinctrl tps65224_template_pinctrl = {
330 	.funcs = tps65224_pinctrl_functions,
331 	.func_cnt = ARRAY_SIZE(tps65224_pinctrl_functions),
332 	.pins = tps65224_pins,
333 	.num_pins = ARRAY_SIZE(tps65224_pins),
334 	.mux_sel_mask = TPS65224_MASK_GPIO_SEL,
335 	.remap = tps65224_muxval_remap,
336 	.remap_cnt = ARRAY_SIZE(tps65224_muxval_remap),
337 };
338 
339 static struct tps6594_pinctrl tps6594_template_pinctrl = {
340 	.funcs = pinctrl_functions,
341 	.func_cnt = ARRAY_SIZE(pinctrl_functions),
342 	.pins = tps6594_pins,
343 	.num_pins = ARRAY_SIZE(tps6594_pins),
344 	.mux_sel_mask = TPS6594_MASK_GPIO_SEL,
345 	.remap = tps6594_muxval_remap,
346 	.remap_cnt = ARRAY_SIZE(tps6594_muxval_remap),
347 };
348 
tps6594_gpio_regmap_xlate(struct gpio_regmap * gpio,unsigned int base,unsigned int offset,unsigned int * reg,unsigned int * mask)349 static int tps6594_gpio_regmap_xlate(struct gpio_regmap *gpio,
350 				     unsigned int base, unsigned int offset,
351 				     unsigned int *reg, unsigned int *mask)
352 {
353 	unsigned int line = offset % 8;
354 	unsigned int stride = offset / 8;
355 
356 	switch (base) {
357 	case TPS6594_REG_GPIOX_CONF(0):
358 		*reg = TPS6594_REG_GPIOX_CONF(offset);
359 		*mask = TPS6594_BIT_GPIO_DIR;
360 		return 0;
361 	case TPS6594_REG_GPIO_IN_1:
362 	case TPS6594_REG_GPIO_OUT_1:
363 		*reg = base + stride;
364 		*mask = BIT(line);
365 		return 0;
366 	default:
367 		return -EINVAL;
368 	}
369 }
370 
tps6594_pmx_func_cnt(struct pinctrl_dev * pctldev)371 static int tps6594_pmx_func_cnt(struct pinctrl_dev *pctldev)
372 {
373 	struct tps6594_pinctrl *pinctrl = pinctrl_dev_get_drvdata(pctldev);
374 
375 	return pinctrl->func_cnt;
376 }
377 
tps6594_pmx_func_name(struct pinctrl_dev * pctldev,unsigned int selector)378 static const char *tps6594_pmx_func_name(struct pinctrl_dev *pctldev,
379 					 unsigned int selector)
380 {
381 	struct tps6594_pinctrl *pinctrl = pinctrl_dev_get_drvdata(pctldev);
382 
383 	return pinctrl->funcs[selector].pinfunction.name;
384 }
385 
tps6594_pmx_func_groups(struct pinctrl_dev * pctldev,unsigned int selector,const char * const ** groups,unsigned int * num_groups)386 static int tps6594_pmx_func_groups(struct pinctrl_dev *pctldev,
387 				   unsigned int selector,
388 				   const char *const **groups,
389 				   unsigned int *num_groups)
390 {
391 	struct tps6594_pinctrl *pinctrl = pinctrl_dev_get_drvdata(pctldev);
392 
393 	*groups = pinctrl->funcs[selector].pinfunction.groups;
394 	*num_groups = pinctrl->funcs[selector].pinfunction.ngroups;
395 
396 	return 0;
397 }
398 
tps6594_pmx_set(struct tps6594_pinctrl * pinctrl,unsigned int pin,u8 muxval)399 static int tps6594_pmx_set(struct tps6594_pinctrl *pinctrl, unsigned int pin,
400 			   u8 muxval)
401 {
402 	u8 mux_sel_val = muxval << TPS6594_OFFSET_GPIO_SEL;
403 	u8 mux_sel_mask = pinctrl->mux_sel_mask;
404 
405 	if (pinctrl->tps->chip_id == TPS65224 && pin == 5) {
406 		/* GPIO6 has a different mask in TPS65224*/
407 		mux_sel_mask = TPS65224_MASK_GPIO_SEL_GPIO6;
408 	}
409 
410 	return regmap_update_bits(pinctrl->tps->regmap,
411 				  TPS6594_REG_GPIOX_CONF(pin),
412 				  mux_sel_mask, mux_sel_val);
413 }
414 
tps6594_pmx_set_mux(struct pinctrl_dev * pctldev,unsigned int function,unsigned int group)415 static int tps6594_pmx_set_mux(struct pinctrl_dev *pctldev,
416 			       unsigned int function, unsigned int group)
417 {
418 	struct tps6594_pinctrl *pinctrl = pinctrl_dev_get_drvdata(pctldev);
419 	u8 muxval = pinctrl->funcs[function].muxval;
420 	unsigned int remap_cnt = pinctrl->remap_cnt;
421 	struct muxval_remap *remap = pinctrl->remap;
422 
423 	for (unsigned int i = 0; i < remap_cnt; i++) {
424 		if (group == remap[i].group && muxval == remap[i].muxval) {
425 			muxval = remap[i].remap;
426 			break;
427 		}
428 	}
429 
430 	return tps6594_pmx_set(pinctrl, group, muxval);
431 }
432 
tps6594_pmx_gpio_set_direction(struct pinctrl_dev * pctldev,struct pinctrl_gpio_range * range,unsigned int offset,bool input)433 static int tps6594_pmx_gpio_set_direction(struct pinctrl_dev *pctldev,
434 					  struct pinctrl_gpio_range *range,
435 					  unsigned int offset, bool input)
436 {
437 	struct tps6594_pinctrl *pinctrl = pinctrl_dev_get_drvdata(pctldev);
438 	u8 muxval = pinctrl->funcs[TPS6594_PINCTRL_GPIO_FUNCTION].muxval;
439 
440 	return tps6594_pmx_set(pinctrl, offset, muxval);
441 }
442 
443 static const struct pinmux_ops tps6594_pmx_ops = {
444 	.get_functions_count = tps6594_pmx_func_cnt,
445 	.get_function_name = tps6594_pmx_func_name,
446 	.get_function_groups = tps6594_pmx_func_groups,
447 	.set_mux = tps6594_pmx_set_mux,
448 	.gpio_set_direction = tps6594_pmx_gpio_set_direction,
449 	.strict = true,
450 };
451 
tps6594_groups_cnt(struct pinctrl_dev * pctldev)452 static int tps6594_groups_cnt(struct pinctrl_dev *pctldev)
453 {
454 	struct tps6594_pinctrl *pinctrl = pinctrl_dev_get_drvdata(pctldev);
455 
456 	return pinctrl->num_pins;
457 }
458 
tps6594_group_pins(struct pinctrl_dev * pctldev,unsigned int selector,const unsigned int ** pins,unsigned int * num_pins)459 static int tps6594_group_pins(struct pinctrl_dev *pctldev,
460 			      unsigned int selector, const unsigned int **pins,
461 			      unsigned int *num_pins)
462 {
463 	struct tps6594_pinctrl *pinctrl = pinctrl_dev_get_drvdata(pctldev);
464 
465 	*pins = &pinctrl->pins[selector].number;
466 	*num_pins = 1;
467 
468 	return 0;
469 }
470 
tps6594_group_name(struct pinctrl_dev * pctldev,unsigned int selector)471 static const char *tps6594_group_name(struct pinctrl_dev *pctldev,
472 				      unsigned int selector)
473 {
474 	struct tps6594_pinctrl *pinctrl = pinctrl_dev_get_drvdata(pctldev);
475 
476 	return pinctrl->pins[selector].name;
477 }
478 
479 static const struct pinctrl_ops tps6594_pctrl_ops = {
480 	.dt_node_to_map = pinconf_generic_dt_node_to_map_group,
481 	.dt_free_map = pinconf_generic_dt_free_map,
482 	.get_groups_count = tps6594_groups_cnt,
483 	.get_group_name = tps6594_group_name,
484 	.get_group_pins = tps6594_group_pins,
485 };
486 
tps6594_pinctrl_probe(struct platform_device * pdev)487 static int tps6594_pinctrl_probe(struct platform_device *pdev)
488 {
489 	struct tps6594 *tps = dev_get_drvdata(pdev->dev.parent);
490 	struct device *dev = &pdev->dev;
491 	struct tps6594_pinctrl *pinctrl;
492 	struct pinctrl_desc *pctrl_desc;
493 	struct gpio_regmap_config config = {};
494 
495 	pctrl_desc = devm_kzalloc(dev, sizeof(*pctrl_desc), GFP_KERNEL);
496 	if (!pctrl_desc)
497 		return -ENOMEM;
498 
499 	pinctrl = devm_kzalloc(dev, sizeof(*pinctrl), GFP_KERNEL);
500 	if (!pinctrl)
501 		return -ENOMEM;
502 
503 	switch (tps->chip_id) {
504 	case TPS652G1:
505 		pctrl_desc->pins = tps65224_pins;
506 		pctrl_desc->npins = ARRAY_SIZE(tps65224_pins);
507 
508 		*pinctrl = tps652g1_template_pinctrl;
509 
510 		config.ngpio = ARRAY_SIZE(tps65224_gpio_func_group_names);
511 		config.ngpio_per_reg = TPS65224_NGPIO_PER_REG;
512 		break;
513 	case TPS65224:
514 		pctrl_desc->pins = tps65224_pins;
515 		pctrl_desc->npins = ARRAY_SIZE(tps65224_pins);
516 
517 		*pinctrl = tps65224_template_pinctrl;
518 
519 		config.ngpio = ARRAY_SIZE(tps65224_gpio_func_group_names);
520 		config.ngpio_per_reg = TPS65224_NGPIO_PER_REG;
521 		break;
522 	case TPS6593:
523 	case TPS6594:
524 	case LP8764:
525 		pctrl_desc->pins = tps6594_pins;
526 		pctrl_desc->npins = ARRAY_SIZE(tps6594_pins);
527 
528 		*pinctrl = tps6594_template_pinctrl;
529 
530 		config.ngpio = ARRAY_SIZE(tps6594_gpio_func_group_names);
531 		config.ngpio_per_reg = TPS6594_NGPIO_PER_REG;
532 		break;
533 	default:
534 		break;
535 	}
536 
537 	pinctrl->tps = tps;
538 
539 	pctrl_desc->name = dev_name(dev);
540 	pctrl_desc->owner = THIS_MODULE;
541 	pctrl_desc->pctlops = &tps6594_pctrl_ops;
542 	pctrl_desc->pmxops = &tps6594_pmx_ops;
543 
544 	config.parent = tps->dev;
545 	config.regmap = tps->regmap;
546 	config.reg_dat_base = TPS6594_REG_GPIO_IN_1;
547 	config.reg_set_base = TPS6594_REG_GPIO_OUT_1;
548 	config.reg_dir_out_base = TPS6594_REG_GPIOX_CONF(0);
549 	config.reg_mask_xlate = tps6594_gpio_regmap_xlate;
550 
551 	pinctrl->pctl_dev = devm_pinctrl_register(dev, pctrl_desc, pinctrl);
552 	if (IS_ERR(pinctrl->pctl_dev))
553 		return dev_err_probe(dev, PTR_ERR(pinctrl->pctl_dev),
554 				     "Couldn't register pinctrl driver\n");
555 
556 	pinctrl->gpio_regmap = devm_gpio_regmap_register(dev, &config);
557 	if (IS_ERR(pinctrl->gpio_regmap))
558 		return dev_err_probe(dev, PTR_ERR(pinctrl->gpio_regmap),
559 				     "Couldn't register gpio_regmap driver\n");
560 
561 	return 0;
562 }
563 
564 static const struct platform_device_id tps6594_pinctrl_id_table[] = {
565 	{ "tps6594-pinctrl", },
566 	{}
567 };
568 MODULE_DEVICE_TABLE(platform, tps6594_pinctrl_id_table);
569 
570 static struct platform_driver tps6594_pinctrl_driver = {
571 	.probe = tps6594_pinctrl_probe,
572 	.driver = {
573 		.name = "tps6594-pinctrl",
574 	},
575 	.id_table = tps6594_pinctrl_id_table,
576 };
577 module_platform_driver(tps6594_pinctrl_driver);
578 
579 MODULE_AUTHOR("Esteban Blanc <eblanc@baylibre.com>");
580 MODULE_AUTHOR("Nirmala Devi Mal Nadar <m.nirmaladevi@ltts.com>");
581 MODULE_DESCRIPTION("TPS6594 pinctrl and GPIO driver");
582 MODULE_LICENSE("GPL");
583