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