xref: /openbmc/linux/drivers/pinctrl/sunplus/sppctl.c (revision 2455f0e1)
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * SP7021 Pin Controller Driver.
4  * Copyright (C) Sunplus Tech / Tibbo Tech.
5  */
6 
7 #include <linux/bitfield.h>
8 #include <linux/device.h>
9 #include <linux/err.h>
10 #include <linux/gpio/driver.h>
11 #include <linux/init.h>
12 #include <linux/module.h>
13 #include <linux/of.h>
14 #include <linux/of_device.h>
15 #include <linux/overflow.h>
16 #include <linux/platform_device.h>
17 #include <linux/seq_file.h>
18 #include <linux/slab.h>
19 
20 #include <linux/pinctrl/pinconf.h>
21 #include <linux/pinctrl/pinconf-generic.h>
22 #include <linux/pinctrl/pinmux.h>
23 
24 #include <dt-bindings/pinctrl/sppctl-sp7021.h>
25 
26 #include "../core.h"
27 #include "../pinctrl-utils.h"
28 
29 #include "sppctl.h"
30 
31 struct sppctl_gpio_chip {
32 	void __iomem *gpioxt_base;	/* MASTER, OE, OUT, IN, I_INV, O_INV, OD */
33 	void __iomem *first_base;	/* GPIO_FIRST                            */
34 
35 	struct gpio_chip chip;
36 	spinlock_t lock;		/* lock for accessing OE register        */
37 };
38 
39 static inline u32 sppctl_first_readl(struct sppctl_gpio_chip *spp_gchip, u32 off)
40 {
41 	return readl(spp_gchip->first_base + SPPCTL_GPIO_OFF_FIRST + off);
42 }
43 
44 static inline void sppctl_first_writel(struct sppctl_gpio_chip *spp_gchip, u32 val, u32 off)
45 {
46 	writel(val, spp_gchip->first_base + SPPCTL_GPIO_OFF_FIRST + off);
47 }
48 
49 static inline u32 sppctl_gpio_master_readl(struct sppctl_gpio_chip *spp_gchip, u32 off)
50 {
51 	return readl(spp_gchip->gpioxt_base + SPPCTL_GPIO_OFF_MASTER + off);
52 }
53 
54 static inline void sppctl_gpio_master_writel(struct sppctl_gpio_chip *spp_gchip, u32 val,
55 					     u32 off)
56 {
57 	writel(val, spp_gchip->gpioxt_base + SPPCTL_GPIO_OFF_MASTER + off);
58 }
59 
60 static inline u32 sppctl_gpio_oe_readl(struct sppctl_gpio_chip *spp_gchip, u32 off)
61 {
62 	return readl(spp_gchip->gpioxt_base + SPPCTL_GPIO_OFF_OE + off);
63 }
64 
65 static inline void sppctl_gpio_oe_writel(struct sppctl_gpio_chip *spp_gchip, u32 val, u32 off)
66 {
67 	writel(val, spp_gchip->gpioxt_base + SPPCTL_GPIO_OFF_OE + off);
68 }
69 
70 static inline void sppctl_gpio_out_writel(struct sppctl_gpio_chip *spp_gchip, u32 val, u32 off)
71 {
72 	writel(val, spp_gchip->gpioxt_base + SPPCTL_GPIO_OFF_OUT + off);
73 }
74 
75 static inline u32 sppctl_gpio_in_readl(struct sppctl_gpio_chip *spp_gchip, u32 off)
76 {
77 	return readl(spp_gchip->gpioxt_base + SPPCTL_GPIO_OFF_IN + off);
78 }
79 
80 static inline u32 sppctl_gpio_iinv_readl(struct sppctl_gpio_chip *spp_gchip, u32 off)
81 {
82 	return readl(spp_gchip->gpioxt_base + SPPCTL_GPIO_OFF_IINV + off);
83 }
84 
85 static inline void sppctl_gpio_iinv_writel(struct sppctl_gpio_chip *spp_gchip, u32 val,
86 					   u32 off)
87 {
88 	writel(val, spp_gchip->gpioxt_base + SPPCTL_GPIO_OFF_IINV + off);
89 }
90 
91 static inline u32 sppctl_gpio_oinv_readl(struct sppctl_gpio_chip *spp_gchip, u32 off)
92 {
93 	return readl(spp_gchip->gpioxt_base + SPPCTL_GPIO_OFF_OINV + off);
94 }
95 
96 static inline void sppctl_gpio_oinv_writel(struct sppctl_gpio_chip *spp_gchip, u32 val,
97 					   u32 off)
98 {
99 	writel(val, spp_gchip->gpioxt_base + SPPCTL_GPIO_OFF_OINV + off);
100 }
101 
102 static inline u32 sppctl_gpio_od_readl(struct sppctl_gpio_chip *spp_gchip, u32 off)
103 {
104 	return readl(spp_gchip->gpioxt_base + SPPCTL_GPIO_OFF_OD + off);
105 }
106 
107 static inline void sppctl_gpio_od_writel(struct sppctl_gpio_chip *spp_gchip, u32 val, u32 off)
108 {
109 	writel(val, spp_gchip->gpioxt_base + SPPCTL_GPIO_OFF_OD + off);
110 }
111 
112 static inline u32 sppctl_get_reg_and_bit_offset(unsigned int offset, u32 *reg_off)
113 {
114 	u32 bit_off;
115 
116 	/* Each register has 32 bits. */
117 	*reg_off = (offset / 32) * 4;
118 	bit_off = offset % 32;
119 
120 	return bit_off;
121 }
122 
123 static inline u32 sppctl_get_moon_reg_and_bit_offset(unsigned int offset, u32 *reg_off)
124 {
125 	u32 bit_off;
126 
127 	/*
128 	 * Each MOON register has 32 bits. Upper 16-bit word are mask-fields.
129 	 * The lower 16-bit word are the control-fields. The corresponding
130 	 * bits in mask-field should be set then you can write something to
131 	 * control-field.
132 	 */
133 	*reg_off = (offset / 16) * 4;
134 	bit_off = offset % 16;
135 
136 	return bit_off;
137 }
138 
139 static inline u32 sppctl_prep_moon_reg_and_offset(unsigned int offset, u32 *reg_off, int val)
140 {
141 	u32 bit_off;
142 
143 	bit_off = sppctl_get_moon_reg_and_bit_offset(offset, reg_off);
144 	if (val)
145 		return SPPCTL_SET_MOON_REG_BIT(bit_off);
146 	else
147 		return SPPCTL_CLR_MOON_REG_BIT(bit_off);
148 }
149 
150 /**
151  * sppctl_func_set() - Set pin of fully-pinmux function.
152  *
153  * Mask-fields and control-fields of fully-pinmux function of SP7021 are
154  * arranged as shown below:
155  *
156  *  func# | register |  mask-field  | control-field
157  * -------+----------+--------------+---------------
158  *    0   | base[0]  |  (22 : 16)   |   ( 6 : 0)
159  *    1   | base[0]  |  (30 : 24)   |   (14 : 8)
160  *    2   | base[1]  |  (22 : 16)   |   ( 6 : 0)
161  *    3   | baeg[1]  |  (30 : 24)   |   (14 : 8)
162  *    :   |    :     |      :       |       :
163  *
164  * where mask-fields are used to protect control-fields from write-in
165  * accidentally. Set the corresponding bits in the mask-field before
166  * you write a value into a control-field.
167  *
168  * Control-fields are used to set where the function pin is going to
169  * be routed to.
170  *
171  * Note that mask-fields and control-fields of even number of 'func'
172  * are located at bits (22:16) and (6:0), while odd number of 'func's
173  * are located at bits (30:24) and (14:8).
174  */
175 static void sppctl_func_set(struct sppctl_pdata *pctl, u8 func, u8 val)
176 {
177 	u32 reg, offset;
178 
179 	/*
180 	 * Note that upper 16-bit word are mask-fields and lower 16-bit
181 	 * word are the control-fields. Set corresponding bits in mask-
182 	 * field before write to a control-field.
183 	 */
184 	reg = SPPCTL_FULLY_PINMUX_MASK_MASK | val;
185 
186 	/*
187 	 * MUXF_L2SW_CLK_OUT is the first fully-pinmux pin
188 	 * and its register offset is 0.
189 	 */
190 	func -= MUXF_L2SW_CLK_OUT;
191 
192 	/*
193 	 * Check if 'func' is an odd number or not. Mask and control-
194 	 * fields of odd number 'func' is located at upper portion of
195 	 * a register. Extra shift is needed.
196 	 */
197 	if (func & BIT(0))
198 		reg <<= SPPCTL_FULLY_PINMUX_UPPER_SHIFT;
199 
200 	/* Convert func# to register offset w.r.t. base register. */
201 	offset = func * 2;
202 	offset &= GENMASK(31, 2);
203 
204 	writel(reg, pctl->moon2_base + offset);
205 }
206 
207 /**
208  * sppctl_gmx_set() - Set pin of group-pinmux.
209  *
210  * Mask-fields and control-fields of group-pinmux function of SP7021 are
211  * arranged as shown below:
212  *
213  *  register |  mask-fields | control-fields
214  * ----------+--------------+----------------
215  *  base[0]  |  (31 : 16)   |   (15 : 0)
216  *  base[1]  |  (31 : 24)   |   (15 : 0)
217  *  base[2]  |  (31 : 24)   |   (15 : 0)
218  *     :     |      :       |       :
219  *
220  * where mask-fields are used to protect control-fields from write-in
221  * accidentally. Set the corresponding bits in the mask-field before
222  * you write a value into a control-field.
223  *
224  * Control-fields are used to set where the function pin is going to
225  * be routed to. A control-field consists of one or more bits.
226  */
227 static void sppctl_gmx_set(struct sppctl_pdata *pctl, u8 reg_off, u8 bit_off, u8 bit_sz,
228 			   u8 val)
229 {
230 	u32 mask, reg;
231 
232 	/*
233 	 * Note that upper 16-bit word are mask-fields and lower 16-bit
234 	 * word are the control-fields. Set corresponding bits in mask-
235 	 * field before write to a control-field.
236 	 */
237 	mask = GENMASK(bit_sz - 1, 0) << SPPCTL_MOON_REG_MASK_SHIFT;
238 	reg = (mask | val) << bit_off;
239 
240 	writel(reg, pctl->moon1_base + reg_off * 4);
241 }
242 
243 /**
244  * sppctl_first_get() - get bit of FIRST register.
245  *
246  * There are 4 FIRST registers. Each has 32 control-bits.
247  * Totally, there are 4 * 32 = 128 control-bits.
248  * Control-bits are arranged as shown below:
249  *
250  *  registers | control-bits
251  * -----------+--------------
252  *  first[0]  |  (31 :  0)
253  *  first[1]  |  (63 : 32)
254  *  first[2]  |  (95 : 64)
255  *  first[3]  | (127 : 96)
256  *
257  * Each control-bit sets type of a GPIO pin.
258  *   0: a fully-pinmux pin
259  *   1: a GPIO or IOP pin
260  */
261 static int sppctl_first_get(struct gpio_chip *chip, unsigned int offset)
262 {
263 	struct sppctl_gpio_chip *spp_gchip = gpiochip_get_data(chip);
264 	u32 reg_off, bit_off, reg;
265 
266 	bit_off = sppctl_get_reg_and_bit_offset(offset, &reg_off);
267 	reg = sppctl_first_readl(spp_gchip, reg_off);
268 
269 	return (reg & BIT(bit_off)) ? 1 : 0;
270 }
271 
272 /**
273  * sppctl_master_get() - get bit of MASTER register.
274  *
275  * There are 8 MASTER registers. Each has 16 mask-bits and 16 control-bits.
276  * Upper 16-bit of MASTER registers are mask-bits while lower 16-bit are
277  * control-bits. Totally, there are 128 mask-bits and 128 control-bits.
278  * They are arranged as shown below:
279  *
280  *  register  |  mask-bits  | control-bits
281  * -----------+-------------+--------------
282  *  master[0] |  (15 :   0) |  (15 :   0)
283  *  master[1] |  (31 :  16) |  (31 :  16)
284  *  master[2] |  (47 :  32) |  (47 :  32)
285  *     :      |      :      |      :
286  *  master[7] | (127 : 112) | (127 : 112)
287  *
288  * where mask-bits are used to protect control-bits from write-in
289  * accidentally. Set the corresponding mask-bit before you write
290  * a value into a control-bit.
291  *
292  * Each control-bit sets type of a GPIO pin when FIRST bit is 1.
293  *   0: a IOP pin
294  *   1: a GPIO pin
295  */
296 static int sppctl_master_get(struct gpio_chip *chip, unsigned int offset)
297 {
298 	struct sppctl_gpio_chip *spp_gchip = gpiochip_get_data(chip);
299 	u32 reg_off, bit_off, reg;
300 
301 	bit_off = sppctl_get_moon_reg_and_bit_offset(offset, &reg_off);
302 	reg = sppctl_gpio_master_readl(spp_gchip, reg_off);
303 	return (reg & BIT(bit_off)) ? 1 : 0;
304 }
305 
306 static void sppctl_first_master_set(struct gpio_chip *chip, unsigned int offset,
307 				    enum mux_first_reg first, enum mux_master_reg master)
308 {
309 	struct sppctl_gpio_chip *spp_gchip = gpiochip_get_data(chip);
310 	u32 reg_off, bit_off, reg;
311 	enum mux_first_reg val;
312 
313 	/* FIRST register */
314 	if (first != mux_f_keep) {
315 		bit_off = sppctl_get_reg_and_bit_offset(offset, &reg_off);
316 		reg = sppctl_first_readl(spp_gchip, reg_off);
317 		val = (reg & BIT(bit_off)) ? mux_f_gpio : mux_f_mux;
318 
319 		if (first != val)
320 			switch (first) {
321 			case mux_f_gpio:
322 				reg |= BIT(bit_off);
323 				sppctl_first_writel(spp_gchip, reg, reg_off);
324 				break;
325 
326 			case mux_f_mux:
327 				reg &= ~BIT(bit_off);
328 				sppctl_first_writel(spp_gchip, reg, reg_off);
329 				break;
330 
331 			case mux_f_keep:
332 				break;
333 			}
334 	}
335 
336 	/* MASTER register */
337 	if (master != mux_m_keep) {
338 		reg = sppctl_prep_moon_reg_and_offset(offset, &reg_off, (master == mux_m_gpio));
339 		sppctl_gpio_master_writel(spp_gchip, reg, reg_off);
340 	}
341 }
342 
343 static void sppctl_gpio_input_inv_set(struct gpio_chip *chip, unsigned int offset)
344 {
345 	struct sppctl_gpio_chip *spp_gchip = gpiochip_get_data(chip);
346 	u32 reg_off, reg;
347 
348 	reg = sppctl_prep_moon_reg_and_offset(offset, &reg_off, 1);
349 	sppctl_gpio_iinv_writel(spp_gchip, reg, reg_off);
350 }
351 
352 static void sppctl_gpio_output_inv_set(struct gpio_chip *chip, unsigned int offset)
353 {
354 	struct sppctl_gpio_chip *spp_gchip = gpiochip_get_data(chip);
355 	u32 reg_off, reg;
356 
357 	reg = sppctl_prep_moon_reg_and_offset(offset, &reg_off, 1);
358 	sppctl_gpio_oinv_writel(spp_gchip, reg, reg_off);
359 }
360 
361 static int sppctl_gpio_output_od_get(struct gpio_chip *chip, unsigned int offset)
362 {
363 	struct sppctl_gpio_chip *spp_gchip = gpiochip_get_data(chip);
364 	u32 reg_off, bit_off, reg;
365 
366 	bit_off = sppctl_get_moon_reg_and_bit_offset(offset, &reg_off);
367 	reg = sppctl_gpio_od_readl(spp_gchip, reg_off);
368 
369 	return (reg & BIT(bit_off)) ? 1 : 0;
370 }
371 
372 static void sppctl_gpio_output_od_set(struct gpio_chip *chip, unsigned int offset,
373 				      unsigned int val)
374 {
375 	struct sppctl_gpio_chip *spp_gchip = gpiochip_get_data(chip);
376 	u32 reg_off, reg;
377 
378 	reg = sppctl_prep_moon_reg_and_offset(offset, &reg_off, val);
379 	sppctl_gpio_od_writel(spp_gchip, reg, reg_off);
380 }
381 
382 static int sppctl_gpio_get_direction(struct gpio_chip *chip, unsigned int offset)
383 {
384 	struct sppctl_gpio_chip *spp_gchip = gpiochip_get_data(chip);
385 	u32 reg_off, bit_off, reg;
386 
387 	bit_off = sppctl_get_moon_reg_and_bit_offset(offset, &reg_off);
388 	reg = sppctl_gpio_oe_readl(spp_gchip, reg_off);
389 
390 	return (reg & BIT(bit_off)) ? 0 : 1;
391 }
392 
393 static int sppctl_gpio_inv_get(struct gpio_chip *chip, unsigned int offset)
394 {
395 	struct sppctl_gpio_chip *spp_gchip = gpiochip_get_data(chip);
396 	u32 reg_off, bit_off, reg;
397 	unsigned long flags;
398 
399 	bit_off = sppctl_get_moon_reg_and_bit_offset(offset, &reg_off);
400 
401 	spin_lock_irqsave(&spp_gchip->lock, flags);
402 
403 	if (sppctl_gpio_get_direction(chip, offset))
404 		reg = sppctl_gpio_iinv_readl(spp_gchip, reg_off);
405 	else
406 		reg = sppctl_gpio_oinv_readl(spp_gchip, reg_off);
407 
408 	spin_unlock_irqrestore(&spp_gchip->lock, flags);
409 
410 	return (reg & BIT(bit_off)) ? 1 : 0;
411 }
412 
413 static int sppctl_gpio_direction_input(struct gpio_chip *chip, unsigned int offset)
414 {
415 	struct sppctl_gpio_chip *spp_gchip = gpiochip_get_data(chip);
416 	unsigned long flags;
417 	u32 reg_off, reg;
418 
419 	reg = sppctl_prep_moon_reg_and_offset(offset, &reg_off, 0);
420 
421 	spin_lock_irqsave(&spp_gchip->lock, flags);
422 
423 	sppctl_gpio_oe_writel(spp_gchip, reg, reg_off);
424 
425 	spin_unlock_irqrestore(&spp_gchip->lock, flags);
426 	return 0;
427 }
428 
429 static int sppctl_gpio_direction_output(struct gpio_chip *chip, unsigned int offset, int val)
430 {
431 	struct sppctl_gpio_chip *spp_gchip = gpiochip_get_data(chip);
432 	unsigned long flags;
433 	u32 reg_off, reg;
434 
435 	reg = sppctl_prep_moon_reg_and_offset(offset, &reg_off, 1);
436 
437 	spin_lock_irqsave(&spp_gchip->lock, flags);
438 
439 	sppctl_gpio_oe_writel(spp_gchip, reg, reg_off);
440 
441 	if (val < 0) {
442 		spin_unlock_irqrestore(&spp_gchip->lock, flags);
443 		return 0;
444 	}
445 
446 	reg = sppctl_prep_moon_reg_and_offset(offset, &reg_off, val);
447 	sppctl_gpio_out_writel(spp_gchip, reg, reg_off);
448 
449 	spin_unlock_irqrestore(&spp_gchip->lock, flags);
450 	return 0;
451 }
452 
453 static int sppctl_gpio_get(struct gpio_chip *chip, unsigned int offset)
454 {
455 	struct sppctl_gpio_chip *spp_gchip = gpiochip_get_data(chip);
456 	u32 reg_off, bit_off, reg;
457 
458 	bit_off = sppctl_get_reg_and_bit_offset(offset, &reg_off);
459 	reg = sppctl_gpio_in_readl(spp_gchip, reg_off);
460 
461 	return (reg & BIT(bit_off)) ? 1 : 0;
462 }
463 
464 static void sppctl_gpio_set(struct gpio_chip *chip, unsigned int offset, int val)
465 {
466 	struct sppctl_gpio_chip *spp_gchip = gpiochip_get_data(chip);
467 	u32 reg_off, reg;
468 
469 	reg = sppctl_prep_moon_reg_and_offset(offset, &reg_off, val);
470 	sppctl_gpio_out_writel(spp_gchip, reg, reg_off);
471 }
472 
473 static int sppctl_gpio_set_config(struct gpio_chip *chip, unsigned int offset,
474 				  unsigned long config)
475 {
476 	enum pin_config_param param = pinconf_to_config_param(config);
477 	struct sppctl_gpio_chip *spp_gchip = gpiochip_get_data(chip);
478 	u32 reg_off, reg;
479 
480 	switch (param) {
481 	case PIN_CONFIG_DRIVE_OPEN_DRAIN:
482 		reg = sppctl_prep_moon_reg_and_offset(offset, &reg_off, 1);
483 		sppctl_gpio_od_writel(spp_gchip, reg, reg_off);
484 		break;
485 
486 	case PIN_CONFIG_INPUT_ENABLE:
487 		break;
488 
489 	case PIN_CONFIG_OUTPUT:
490 		return sppctl_gpio_direction_output(chip, offset, 0);
491 
492 	case PIN_CONFIG_PERSIST_STATE:
493 		return -ENOTSUPP;
494 
495 	default:
496 		return -EINVAL;
497 	}
498 
499 	return 0;
500 }
501 
502 static void sppctl_gpio_dbg_show(struct seq_file *s, struct gpio_chip *chip)
503 {
504 	const char *label;
505 	int i;
506 
507 	for (i = 0; i < chip->ngpio; i++) {
508 		label = gpiochip_is_requested(chip, i);
509 		if (!label)
510 			label = "";
511 
512 		seq_printf(s, " gpio-%03d (%-16.16s | %-16.16s)", i + chip->base,
513 			   chip->names[i], label);
514 		seq_printf(s, " %c", sppctl_gpio_get_direction(chip, i) ? 'I' : 'O');
515 		seq_printf(s, ":%d", sppctl_gpio_get(chip, i));
516 		seq_printf(s, " %s", sppctl_first_get(chip, i) ? "gpi" : "mux");
517 		seq_printf(s, " %s", sppctl_master_get(chip, i) ? "gpi" : "iop");
518 		seq_printf(s, " %s", sppctl_gpio_inv_get(chip, i) ? "inv" : "   ");
519 		seq_printf(s, " %s", sppctl_gpio_output_od_get(chip, i) ? "oDr" : "");
520 		seq_puts(s, "\n");
521 	}
522 }
523 
524 static int sppctl_gpio_new(struct platform_device *pdev, struct sppctl_pdata *pctl)
525 {
526 	struct sppctl_gpio_chip *spp_gchip;
527 	struct gpio_chip *gchip;
528 	int err;
529 
530 	spp_gchip = devm_kzalloc(&pdev->dev, sizeof(*spp_gchip), GFP_KERNEL);
531 	if (!spp_gchip)
532 		return -ENOMEM;
533 	pctl->spp_gchip = spp_gchip;
534 
535 	spp_gchip->gpioxt_base  = pctl->gpioxt_base;
536 	spp_gchip->first_base   = pctl->first_base;
537 	spin_lock_init(&spp_gchip->lock);
538 
539 	gchip                   = &spp_gchip->chip;
540 	gchip->label            = SPPCTL_MODULE_NAME;
541 	gchip->parent           = &pdev->dev;
542 	gchip->owner            = THIS_MODULE;
543 	gchip->request          = gpiochip_generic_request;
544 	gchip->free             = gpiochip_generic_free;
545 	gchip->get_direction    = sppctl_gpio_get_direction;
546 	gchip->direction_input  = sppctl_gpio_direction_input;
547 	gchip->direction_output = sppctl_gpio_direction_output;
548 	gchip->get              = sppctl_gpio_get;
549 	gchip->set              = sppctl_gpio_set;
550 	gchip->set_config       = sppctl_gpio_set_config;
551 	gchip->dbg_show         = IS_ENABLED(CONFIG_DEBUG_FS) ?
552 				  sppctl_gpio_dbg_show : NULL;
553 	gchip->base             = -1;
554 	gchip->ngpio            = sppctl_gpio_list_sz;
555 	gchip->names            = sppctl_gpio_list_s;
556 	gchip->of_gpio_n_cells  = 2;
557 
558 	pctl->pctl_grange.npins = gchip->ngpio;
559 	pctl->pctl_grange.name  = gchip->label;
560 	pctl->pctl_grange.gc    = gchip;
561 
562 	err = devm_gpiochip_add_data(&pdev->dev, gchip, spp_gchip);
563 	if (err)
564 		return dev_err_probe(&pdev->dev, err, "Failed to add gpiochip!\n");
565 
566 	return 0;
567 }
568 
569 static int sppctl_pin_config_get(struct pinctrl_dev *pctldev, unsigned int pin,
570 				 unsigned long *config)
571 {
572 	struct sppctl_pdata *pctl = pinctrl_dev_get_drvdata(pctldev);
573 	unsigned int param = pinconf_to_config_param(*config);
574 	unsigned int arg;
575 
576 	switch (param) {
577 	case PIN_CONFIG_DRIVE_OPEN_DRAIN:
578 		if (!sppctl_gpio_output_od_get(&pctl->spp_gchip->chip, pin))
579 			return -EINVAL;
580 		arg = 0;
581 		break;
582 
583 	case PIN_CONFIG_OUTPUT:
584 		if (!sppctl_first_get(&pctl->spp_gchip->chip, pin))
585 			return -EINVAL;
586 		if (!sppctl_master_get(&pctl->spp_gchip->chip, pin))
587 			return -EINVAL;
588 		if (sppctl_gpio_get_direction(&pctl->spp_gchip->chip, pin))
589 			return -EINVAL;
590 		arg = sppctl_gpio_get(&pctl->spp_gchip->chip, pin);
591 		break;
592 
593 	default:
594 		return -EOPNOTSUPP;
595 	}
596 	*config = pinconf_to_config_packed(param, arg);
597 
598 	return 0;
599 }
600 
601 static int sppctl_pin_config_set(struct pinctrl_dev *pctldev, unsigned int pin,
602 				 unsigned long *configs, unsigned int num_configs)
603 {
604 	struct sppctl_pdata *pctl = pinctrl_dev_get_drvdata(pctldev);
605 	int i;
606 
607 	/* Special handling for IOP pins */
608 	if (configs[0] == SPPCTL_IOP_CONFIGS) {
609 		sppctl_first_master_set(&pctl->spp_gchip->chip, pin, mux_f_gpio, mux_m_iop);
610 		return 0;
611 	}
612 
613 	for (i = 0; i < num_configs; i++) {
614 		if (configs[i] & SPPCTL_PCTL_L_OUT)
615 			sppctl_gpio_direction_output(&pctl->spp_gchip->chip, pin, 0);
616 		if (configs[i] & SPPCTL_PCTL_L_OU1)
617 			sppctl_gpio_direction_output(&pctl->spp_gchip->chip, pin, 1);
618 		if (configs[i] & SPPCTL_PCTL_L_INV)
619 			sppctl_gpio_input_inv_set(&pctl->spp_gchip->chip, pin);
620 		if (configs[i] & SPPCTL_PCTL_L_ONV)
621 			sppctl_gpio_output_inv_set(&pctl->spp_gchip->chip, pin);
622 		if (configs[i] & SPPCTL_PCTL_L_ODR)
623 			sppctl_gpio_output_od_set(&pctl->spp_gchip->chip, pin, 1);
624 	}
625 
626 	return 0;
627 }
628 
629 static const struct pinconf_ops sppctl_pconf_ops = {
630 	.is_generic     = true,
631 	.pin_config_get = sppctl_pin_config_get,
632 	.pin_config_set = sppctl_pin_config_set,
633 };
634 
635 static int sppctl_get_functions_count(struct pinctrl_dev *pctldev)
636 {
637 	return sppctl_list_funcs_sz;
638 }
639 
640 static const char *sppctl_get_function_name(struct pinctrl_dev *pctldev,
641 					    unsigned int selector)
642 {
643 	return sppctl_list_funcs[selector].name;
644 }
645 
646 static int sppctl_get_function_groups(struct pinctrl_dev *pctldev, unsigned int selector,
647 				      const char * const **groups, unsigned int *num_groups)
648 {
649 	struct sppctl_pdata *pctl = pinctrl_dev_get_drvdata(pctldev);
650 	const struct sppctl_func *f = &sppctl_list_funcs[selector];
651 	int i;
652 
653 	*num_groups = 0;
654 	switch (f->type) {
655 	case pinmux_type_fpmx:
656 		*num_groups = sppctl_pmux_list_sz;
657 		*groups = sppctl_pmux_list_s;
658 		break;
659 
660 	case pinmux_type_grp:
661 		if (!f->grps)
662 			break;
663 
664 		*num_groups = f->gnum;
665 		for (i = 0; i < pctl->unq_grps_sz; i++)
666 			if (pctl->g2fp_maps[i].f_idx == selector)
667 				break;
668 		*groups = &pctl->unq_grps[i];
669 		break;
670 
671 	default:
672 		dev_err(pctldev->dev, "Unknown pinmux (selector: %d, type: %d)\n",
673 			selector, f->type);
674 		break;
675 	}
676 
677 	return 0;
678 }
679 
680 /**
681  * sppctl_fully_pinmux_conv - Convert GPIO# to fully-pinmux control-field setting
682  *
683  * Each fully-pinmux function can be mapped to any of GPIO 8 ~ 71 by
684  * settings its control-field. Refer to following table:
685  *
686  * control-field |  GPIO
687  * --------------+--------
688  *        0      |  No map
689  *        1      |    8
690  *        2      |    9
691  *        3      |   10
692  *        :      |    :
693  *       65      |   71
694  */
695 static inline int sppctl_fully_pinmux_conv(unsigned int offset)
696 {
697 	return (offset < 8) ? 0 : offset - 7;
698 }
699 
700 static int sppctl_set_mux(struct pinctrl_dev *pctldev, unsigned int func_selector,
701 			  unsigned int group_selector)
702 {
703 	const struct sppctl_func *f = &sppctl_list_funcs[func_selector];
704 	struct sppctl_pdata *pctl = pinctrl_dev_get_drvdata(pctldev);
705 	struct grp2fp_map g2fpm = pctl->g2fp_maps[group_selector];
706 	int i;
707 
708 	switch (f->type) {
709 	case pinmux_type_fpmx:
710 		sppctl_first_master_set(&pctl->spp_gchip->chip, group_selector,
711 					mux_f_mux, mux_m_keep);
712 		sppctl_func_set(pctl, func_selector, sppctl_fully_pinmux_conv(group_selector));
713 		break;
714 
715 	case pinmux_type_grp:
716 		for (i = 0; i < f->grps[g2fpm.g_idx].pnum; i++)
717 			sppctl_first_master_set(&pctl->spp_gchip->chip,
718 						f->grps[g2fpm.g_idx].pins[i],
719 						mux_f_mux, mux_m_keep);
720 		sppctl_gmx_set(pctl, f->roff, f->boff, f->blen, f->grps[g2fpm.g_idx].gval);
721 		break;
722 
723 	default:
724 		dev_err(pctldev->dev, "Unknown pinmux type (func_selector: %d, type: %d)\n",
725 			func_selector, f->type);
726 		break;
727 	}
728 
729 	return 0;
730 }
731 
732 static int sppctl_gpio_request_enable(struct pinctrl_dev *pctldev,
733 				      struct pinctrl_gpio_range *range, unsigned int offset)
734 {
735 	struct sppctl_pdata *pctl = pinctrl_dev_get_drvdata(pctldev);
736 	int g_f, g_m;
737 
738 	g_f = sppctl_first_get(&pctl->spp_gchip->chip, offset);
739 	g_m = sppctl_master_get(&pctl->spp_gchip->chip, offset);
740 	if (g_f == mux_f_gpio && g_m == mux_m_gpio)
741 		return 0;
742 
743 	sppctl_first_master_set(&pctl->spp_gchip->chip, offset, mux_f_gpio, mux_m_gpio);
744 	return 0;
745 }
746 
747 static const struct pinmux_ops sppctl_pinmux_ops = {
748 	.get_functions_count = sppctl_get_functions_count,
749 	.get_function_name   = sppctl_get_function_name,
750 	.get_function_groups = sppctl_get_function_groups,
751 	.set_mux             = sppctl_set_mux,
752 	.gpio_request_enable = sppctl_gpio_request_enable,
753 	.strict              = true,
754 };
755 
756 static int sppctl_get_groups_count(struct pinctrl_dev *pctldev)
757 {
758 	struct sppctl_pdata *pctl = pinctrl_dev_get_drvdata(pctldev);
759 
760 	return pctl->unq_grps_sz;
761 }
762 
763 static const char *sppctl_get_group_name(struct pinctrl_dev *pctldev, unsigned int selector)
764 {
765 	struct sppctl_pdata *pctl = pinctrl_dev_get_drvdata(pctldev);
766 
767 	return pctl->unq_grps[selector];
768 }
769 
770 static int sppctl_get_group_pins(struct pinctrl_dev *pctldev, unsigned int selector,
771 				 const unsigned int **pins, unsigned int *num_pins)
772 {
773 	struct sppctl_pdata *pctl = pinctrl_dev_get_drvdata(pctldev);
774 	struct grp2fp_map g2fpm = pctl->g2fp_maps[selector];
775 	const struct sppctl_func *f;
776 
777 	f = &sppctl_list_funcs[g2fpm.f_idx];
778 	*num_pins = 0;
779 
780 	/* Except group-pinmux, each group has 1 pin. */
781 	if (f->type != pinmux_type_grp) {
782 		*num_pins = 1;
783 		*pins = &sppctl_pins_gpio[selector];
784 		return 0;
785 	}
786 
787 	/* Group-pinmux may have more than one pin. */
788 	if (!f->grps)
789 		return 0;
790 
791 	if (f->gnum < 1)
792 		return 0;
793 
794 	*num_pins = f->grps[g2fpm.g_idx].pnum;
795 	*pins = f->grps[g2fpm.g_idx].pins;
796 
797 	return 0;
798 }
799 
800 #ifdef CONFIG_DEBUG_FS
801 static void sppctl_pin_dbg_show(struct pinctrl_dev *pctldev, struct seq_file *s,
802 				unsigned int offset)
803 {
804 	struct sppctl_pdata *pctl = pinctrl_dev_get_drvdata(pctldev);
805 	const char *pin_type;
806 	u8 first, master;
807 
808 	first = sppctl_first_get(&pctl->spp_gchip->chip, offset);
809 	master = sppctl_master_get(&pctl->spp_gchip->chip, offset);
810 	if (first)
811 		if (master)
812 			pin_type = "GPIO";
813 		else
814 			pin_type = " IOP";
815 	else
816 		pin_type = " MUX";
817 	seq_printf(s, " %s", pin_type);
818 }
819 #endif
820 
821 static int sppctl_dt_node_to_map(struct pinctrl_dev *pctldev, struct device_node *np_config,
822 				 struct pinctrl_map **map, unsigned int *num_maps)
823 {
824 	struct sppctl_pdata *pctl = pinctrl_dev_get_drvdata(pctldev);
825 	int nmG = of_property_count_strings(np_config, "groups");
826 	const struct sppctl_func *f = NULL;
827 	u8 pin_num, pin_type, pin_func;
828 	struct device_node *parent;
829 	unsigned long *configs;
830 	struct property *prop;
831 	const char *s_f, *s_g;
832 
833 	const __be32 *list;
834 	u32 dt_pin, dt_fun;
835 	int i, size = 0;
836 
837 	list = of_get_property(np_config, "sunplus,pins", &size);
838 
839 	if (nmG <= 0)
840 		nmG = 0;
841 
842 	parent = of_get_parent(np_config);
843 	*num_maps = size / sizeof(*list);
844 
845 	/*
846 	 * Process property:
847 	 *     sunplus,pins = < u32 u32 u32 ... >;
848 	 *
849 	 * Each 32-bit integer defines a individual pin in which:
850 	 *
851 	 *   Bit 32~24: defines GPIO pin number. Its range is 0 ~ 98.
852 	 *   Bit 23~16: defines types: (1) fully-pinmux pins
853 	 *                             (2) IO processor pins
854 	 *                             (3) digital GPIO pins
855 	 *   Bit 15~8:  defines pins of peripherals (which are defined in
856 	 *              'include/dt-binging/pinctrl/sppctl.h').
857 	 *   Bit 7~0:   defines types or initial-state of digital GPIO pins.
858 	 */
859 	for (i = 0; i < (*num_maps); i++) {
860 		dt_pin = be32_to_cpu(list[i]);
861 		pin_num = FIELD_GET(GENMASK(31, 24), dt_pin);
862 
863 		if (pin_num >= sppctl_pins_all_sz) {
864 			dev_err(pctldev->dev, "Invalid pin property at index %d (0x%08x)\n",
865 				i, dt_pin);
866 			return -EINVAL;
867 		}
868 	}
869 
870 	*map = kcalloc(*num_maps + nmG, sizeof(**map), GFP_KERNEL);
871 	if (*map == NULL)
872 		return -ENOMEM;
873 
874 	for (i = 0; i < (*num_maps); i++) {
875 		dt_pin = be32_to_cpu(list[i]);
876 		pin_num = FIELD_GET(GENMASK(31, 24), dt_pin);
877 		pin_type = FIELD_GET(GENMASK(23, 16), dt_pin);
878 		pin_func = FIELD_GET(GENMASK(15, 8), dt_pin);
879 		(*map)[i].name = parent->name;
880 
881 		if (pin_type == SPPCTL_PCTL_G_GPIO) {
882 			/* A digital GPIO pin */
883 			(*map)[i].type = PIN_MAP_TYPE_CONFIGS_PIN;
884 			(*map)[i].data.configs.num_configs = 1;
885 			(*map)[i].data.configs.group_or_pin = pin_get_name(pctldev, pin_num);
886 			configs = kmalloc(sizeof(*configs), GFP_KERNEL);
887 			*configs = FIELD_GET(GENMASK(7, 0), dt_pin);
888 			(*map)[i].data.configs.configs = configs;
889 
890 			dev_dbg(pctldev->dev, "%s: GPIO (%s)\n",
891 				(*map)[i].data.configs.group_or_pin,
892 				(*configs & (SPPCTL_PCTL_L_OUT | SPPCTL_PCTL_L_OU1)) ?
893 				"OUT" : "IN");
894 		} else if (pin_type == SPPCTL_PCTL_G_IOPP) {
895 			/* A IO Processor (IOP) pin */
896 			(*map)[i].type = PIN_MAP_TYPE_CONFIGS_PIN;
897 			(*map)[i].data.configs.num_configs = 1;
898 			(*map)[i].data.configs.group_or_pin = pin_get_name(pctldev, pin_num);
899 			configs = kmalloc(sizeof(*configs), GFP_KERNEL);
900 			*configs = SPPCTL_IOP_CONFIGS;
901 			(*map)[i].data.configs.configs = configs;
902 
903 			dev_dbg(pctldev->dev, "%s: IOP\n",
904 				(*map)[i].data.configs.group_or_pin);
905 		} else {
906 			/* A fully-pinmux pin */
907 			(*map)[i].type = PIN_MAP_TYPE_MUX_GROUP;
908 			(*map)[i].data.mux.function = sppctl_list_funcs[pin_func].name;
909 			(*map)[i].data.mux.group = pin_get_name(pctldev, pin_num);
910 
911 			dev_dbg(pctldev->dev, "%s: %s\n", (*map)[i].data.mux.group,
912 				(*map)[i].data.mux.function);
913 		}
914 	}
915 
916 	/*
917 	 * Process properties:
918 	 *     function = "xxx";
919 	 *     groups = "yyy";
920 	 */
921 	if (nmG > 0 && of_property_read_string(np_config, "function", &s_f) == 0) {
922 		of_property_for_each_string(np_config, "groups", prop, s_g) {
923 			(*map)[*num_maps].type = PIN_MAP_TYPE_MUX_GROUP;
924 			(*map)[*num_maps].data.mux.function = s_f;
925 			(*map)[*num_maps].data.mux.group = s_g;
926 			(*num_maps)++;
927 
928 			dev_dbg(pctldev->dev, "%s: %s\n", s_f, s_g);
929 		}
930 	}
931 
932 	/*
933 	 * Process property:
934 	 *     sunplus,zerofunc = < u32 u32 u32 ...>
935 	 */
936 	list = of_get_property(np_config, "sunplus,zerofunc", &size);
937 	if (list) {
938 		for (i = 0; i < (size / sizeof(*list)); i++) {
939 			dt_fun = be32_to_cpu(list[i]);
940 			if (dt_fun >= sppctl_list_funcs_sz) {
941 				dev_err(pctldev->dev, "Zero-func %d out of range!\n",
942 					dt_fun);
943 				continue;
944 			}
945 
946 			f = &sppctl_list_funcs[dt_fun];
947 			switch (f->type) {
948 			case pinmux_type_fpmx:
949 				sppctl_func_set(pctl, dt_fun, 0);
950 				dev_dbg(pctldev->dev, "%s: No map\n", f->name);
951 				break;
952 
953 			case pinmux_type_grp:
954 				sppctl_gmx_set(pctl, f->roff, f->boff, f->blen, 0);
955 				dev_dbg(pctldev->dev, "%s: No map\n", f->name);
956 				break;
957 
958 			default:
959 				dev_err(pctldev->dev, "Wrong zero-group: %d (%s)\n",
960 					dt_fun, f->name);
961 				break;
962 			}
963 		}
964 	}
965 
966 	of_node_put(parent);
967 	dev_dbg(pctldev->dev, "%d pins mapped\n", *num_maps);
968 	return 0;
969 }
970 
971 static const struct pinctrl_ops sppctl_pctl_ops = {
972 	.get_groups_count = sppctl_get_groups_count,
973 	.get_group_name   = sppctl_get_group_name,
974 	.get_group_pins   = sppctl_get_group_pins,
975 #ifdef CONFIG_DEBUG_FS
976 	.pin_dbg_show     = sppctl_pin_dbg_show,
977 #endif
978 	.dt_node_to_map   = sppctl_dt_node_to_map,
979 	.dt_free_map      = pinctrl_utils_free_map,
980 };
981 
982 static int sppctl_group_groups(struct platform_device *pdev)
983 {
984 	struct sppctl_pdata *sppctl = platform_get_drvdata(pdev);
985 	int i, k, j;
986 
987 	/* Calculate number of total group (GPIO + group-pinmux group). */
988 	sppctl->unq_grps_sz = sppctl_gpio_list_sz;
989 	for (i = 0; i < sppctl_list_funcs_sz; i++)
990 		if (sppctl_list_funcs[i].type == pinmux_type_grp)
991 			sppctl->unq_grps_sz += sppctl_list_funcs[i].gnum;
992 
993 	sppctl->unq_grps = devm_kcalloc(&pdev->dev, sppctl->unq_grps_sz + 1,
994 					sizeof(*sppctl->unq_grps), GFP_KERNEL);
995 	if (!sppctl->unq_grps)
996 		return -ENOMEM;
997 
998 	sppctl->g2fp_maps = devm_kcalloc(&pdev->dev, sppctl->unq_grps_sz + 1,
999 					 sizeof(*sppctl->g2fp_maps), GFP_KERNEL);
1000 	if (!sppctl->g2fp_maps)
1001 		return -ENOMEM;
1002 
1003 	/* Add GPIO pins. */
1004 	for (i = 0; i < sppctl_gpio_list_sz; i++) {
1005 		sppctl->unq_grps[i] = sppctl_gpio_list_s[i];
1006 		sppctl->g2fp_maps[i].f_idx = 0;
1007 		sppctl->g2fp_maps[i].g_idx = i;
1008 	}
1009 
1010 	/* Add group-pinmux to end of GPIO pins. */
1011 	j = sppctl_gpio_list_sz;
1012 	for (i = 0; i < sppctl_list_funcs_sz; i++) {
1013 		if (sppctl_list_funcs[i].type != pinmux_type_grp)
1014 			continue;
1015 
1016 		for (k = 0; k < sppctl_list_funcs[i].gnum; k++) {
1017 			sppctl->unq_grps[j] = sppctl_list_funcs[i].grps[k].name;
1018 			sppctl->g2fp_maps[j].f_idx = i;
1019 			sppctl->g2fp_maps[j].g_idx = k;
1020 			j++;
1021 		}
1022 	}
1023 
1024 	return 0;
1025 }
1026 
1027 static int sppctl_pinctrl_init(struct platform_device *pdev)
1028 {
1029 	struct sppctl_pdata *sppctl = platform_get_drvdata(pdev);
1030 	int err;
1031 
1032 	sppctl->pctl_desc.owner   = THIS_MODULE;
1033 	sppctl->pctl_desc.name    = dev_name(&pdev->dev);
1034 	sppctl->pctl_desc.pins    = sppctl_pins_all;
1035 	sppctl->pctl_desc.npins   = sppctl_pins_all_sz;
1036 	sppctl->pctl_desc.pctlops = &sppctl_pctl_ops;
1037 	sppctl->pctl_desc.confops = &sppctl_pconf_ops;
1038 	sppctl->pctl_desc.pmxops  = &sppctl_pinmux_ops;
1039 
1040 	err = sppctl_group_groups(pdev);
1041 	if (err)
1042 		return err;
1043 
1044 	err = devm_pinctrl_register_and_init(&pdev->dev, &sppctl->pctl_desc,
1045 					     sppctl, &sppctl->pctl_dev);
1046 	if (err)
1047 		return dev_err_probe(&pdev->dev, err, "Failed to register pinctrl!\n");
1048 
1049 	pinctrl_enable(sppctl->pctl_dev);
1050 	return 0;
1051 }
1052 
1053 static int sppctl_resource_map(struct platform_device *pdev, struct sppctl_pdata *sppctl)
1054 {
1055 	sppctl->moon2_base = devm_platform_ioremap_resource_byname(pdev, "moon2");
1056 	if (IS_ERR(sppctl->moon2_base))
1057 		return PTR_ERR(sppctl->moon2_base);
1058 
1059 	sppctl->gpioxt_base = devm_platform_ioremap_resource_byname(pdev, "gpioxt");
1060 	if (IS_ERR(sppctl->gpioxt_base))
1061 		return PTR_ERR(sppctl->gpioxt_base);
1062 
1063 	sppctl->first_base = devm_platform_ioremap_resource_byname(pdev, "first");
1064 	if (IS_ERR(sppctl->first_base))
1065 		return PTR_ERR(sppctl->first_base);
1066 
1067 	sppctl->moon1_base = devm_platform_ioremap_resource_byname(pdev, "moon1");
1068 	if (IS_ERR(sppctl->moon1_base))
1069 		return PTR_ERR(sppctl->moon1_base);
1070 
1071 	return 0;
1072 }
1073 
1074 static int sppctl_probe(struct platform_device *pdev)
1075 {
1076 	struct sppctl_pdata *sppctl;
1077 	int ret;
1078 
1079 	sppctl = devm_kzalloc(&pdev->dev, sizeof(*sppctl), GFP_KERNEL);
1080 	if (!sppctl)
1081 		return -ENOMEM;
1082 	platform_set_drvdata(pdev, sppctl);
1083 
1084 	ret = sppctl_resource_map(pdev, sppctl);
1085 	if (ret)
1086 		return ret;
1087 
1088 	ret = sppctl_gpio_new(pdev, sppctl);
1089 	if (ret)
1090 		return ret;
1091 
1092 	ret = sppctl_pinctrl_init(pdev);
1093 	if (ret)
1094 		return ret;
1095 
1096 	pinctrl_add_gpio_range(sppctl->pctl_dev, &sppctl->pctl_grange);
1097 
1098 	return 0;
1099 }
1100 
1101 static const struct of_device_id sppctl_match_table[] = {
1102 	{ .compatible = "sunplus,sp7021-pctl" },
1103 	{ /* sentinel */ }
1104 };
1105 
1106 static struct platform_driver sppctl_pinctrl_driver = {
1107 	.driver = {
1108 		.name           = SPPCTL_MODULE_NAME,
1109 		.of_match_table = sppctl_match_table,
1110 	},
1111 	.probe  = sppctl_probe,
1112 };
1113 builtin_platform_driver(sppctl_pinctrl_driver)
1114 
1115 MODULE_AUTHOR("Dvorkin Dmitry <dvorkin@tibbo.com>");
1116 MODULE_AUTHOR("Wells Lu <wellslutw@gmail.com>");
1117 MODULE_DESCRIPTION("Sunplus SP7021 Pin Control and GPIO driver");
1118 MODULE_LICENSE("GPL v2");
1119