xref: /openbmc/linux/drivers/pinctrl/sunplus/sppctl.c (revision c900529f3d9161bfde5cca0754f83b4d3c3e0220)
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/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 
30 struct 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 
sppctl_first_readl(struct sppctl_gpio_chip * spp_gchip,u32 off)38 static 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 
sppctl_first_writel(struct sppctl_gpio_chip * spp_gchip,u32 val,u32 off)43 static 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 
sppctl_gpio_master_readl(struct sppctl_gpio_chip * spp_gchip,u32 off)48 static 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 
sppctl_gpio_master_writel(struct sppctl_gpio_chip * spp_gchip,u32 val,u32 off)53 static 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 
sppctl_gpio_oe_readl(struct sppctl_gpio_chip * spp_gchip,u32 off)59 static 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 
sppctl_gpio_oe_writel(struct sppctl_gpio_chip * spp_gchip,u32 val,u32 off)64 static 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 
sppctl_gpio_out_writel(struct sppctl_gpio_chip * spp_gchip,u32 val,u32 off)69 static 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 
sppctl_gpio_in_readl(struct sppctl_gpio_chip * spp_gchip,u32 off)74 static 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 
sppctl_gpio_iinv_readl(struct sppctl_gpio_chip * spp_gchip,u32 off)79 static 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 
sppctl_gpio_iinv_writel(struct sppctl_gpio_chip * spp_gchip,u32 val,u32 off)84 static 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 
sppctl_gpio_oinv_readl(struct sppctl_gpio_chip * spp_gchip,u32 off)90 static 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 
sppctl_gpio_oinv_writel(struct sppctl_gpio_chip * spp_gchip,u32 val,u32 off)95 static 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 
sppctl_gpio_od_readl(struct sppctl_gpio_chip * spp_gchip,u32 off)101 static 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 
sppctl_gpio_od_writel(struct sppctl_gpio_chip * spp_gchip,u32 val,u32 off)106 static 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 
sppctl_get_reg_and_bit_offset(unsigned int offset,u32 * reg_off)111 static 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 
sppctl_get_moon_reg_and_bit_offset(unsigned int offset,u32 * reg_off)122 static 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 
sppctl_prep_moon_reg_and_offset(unsigned int offset,u32 * reg_off,int val)138 static 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  */
sppctl_func_set(struct sppctl_pdata * pctl,u8 func,u8 val)174 static 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  */
sppctl_gmx_set(struct sppctl_pdata * pctl,u8 reg_off,u8 bit_off,u8 bit_sz,u8 val)226 static 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  */
sppctl_first_get(struct gpio_chip * chip,unsigned int offset)260 static 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  */
sppctl_master_get(struct gpio_chip * chip,unsigned int offset)295 static 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 
sppctl_first_master_set(struct gpio_chip * chip,unsigned int offset,enum mux_first_reg first,enum mux_master_reg master)305 static 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 
sppctl_gpio_input_inv_set(struct gpio_chip * chip,unsigned int offset)342 static 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 
sppctl_gpio_output_inv_set(struct gpio_chip * chip,unsigned int offset)351 static 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 
sppctl_gpio_output_od_get(struct gpio_chip * chip,unsigned int offset)360 static 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 
sppctl_gpio_output_od_set(struct gpio_chip * chip,unsigned int offset,unsigned int val)371 static 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 
sppctl_gpio_get_direction(struct gpio_chip * chip,unsigned int offset)381 static 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 
sppctl_gpio_inv_get(struct gpio_chip * chip,unsigned int offset)392 static 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 
sppctl_gpio_direction_input(struct gpio_chip * chip,unsigned int offset)412 static 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 
sppctl_gpio_direction_output(struct gpio_chip * chip,unsigned int offset,int val)428 static 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 
sppctl_gpio_get(struct gpio_chip * chip,unsigned int offset)452 static 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 
sppctl_gpio_set(struct gpio_chip * chip,unsigned int offset,int val)463 static 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 
sppctl_gpio_set_config(struct gpio_chip * chip,unsigned int offset,unsigned long config)472 static 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 
sppctl_gpio_dbg_show(struct seq_file * s,struct gpio_chip * chip)501 static 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 }
522 
sppctl_gpio_new(struct platform_device * pdev,struct sppctl_pdata * pctl)523 static 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;
550 	gchip->dbg_show         = IS_ENABLED(CONFIG_DEBUG_FS) ?
551 				  sppctl_gpio_dbg_show : NULL;
552 	gchip->base             = -1;
553 	gchip->ngpio            = sppctl_gpio_list_sz;
554 	gchip->names            = sppctl_gpio_list_s;
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 
sppctl_pin_config_get(struct pinctrl_dev * pctldev,unsigned int pin,unsigned long * config)567 static 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 
sppctl_pin_config_set(struct pinctrl_dev * pctldev,unsigned int pin,unsigned long * configs,unsigned int num_configs)599 static 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 
627 static 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 
sppctl_get_functions_count(struct pinctrl_dev * pctldev)633 static int sppctl_get_functions_count(struct pinctrl_dev *pctldev)
634 {
635 	return sppctl_list_funcs_sz;
636 }
637 
sppctl_get_function_name(struct pinctrl_dev * pctldev,unsigned int selector)638 static const char *sppctl_get_function_name(struct pinctrl_dev *pctldev,
639 					    unsigned int selector)
640 {
641 	return sppctl_list_funcs[selector].name;
642 }
643 
sppctl_get_function_groups(struct pinctrl_dev * pctldev,unsigned int selector,const char * const ** groups,unsigned int * num_groups)644 static 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  */
sppctl_fully_pinmux_conv(unsigned int offset)693 static inline int sppctl_fully_pinmux_conv(unsigned int offset)
694 {
695 	return (offset < 8) ? 0 : offset - 7;
696 }
697 
sppctl_set_mux(struct pinctrl_dev * pctldev,unsigned int func_selector,unsigned int group_selector)698 static 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 
sppctl_gpio_request_enable(struct pinctrl_dev * pctldev,struct pinctrl_gpio_range * range,unsigned int offset)730 static 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 
745 static 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 
sppctl_get_groups_count(struct pinctrl_dev * pctldev)754 static 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 
sppctl_get_group_name(struct pinctrl_dev * pctldev,unsigned int selector)761 static 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 
sppctl_get_group_pins(struct pinctrl_dev * pctldev,unsigned int selector,const unsigned int ** pins,unsigned int * num_pins)768 static 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
sppctl_pin_dbg_show(struct pinctrl_dev * pctldev,struct seq_file * s,unsigned int offset)799 static 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 
sppctl_dt_node_to_map(struct pinctrl_dev * pctldev,struct device_node * np_config,struct pinctrl_map ** map,unsigned int * num_maps)819 static 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);
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 
863 	if (nmG <= 0)
864 		nmG = 0;
865 
866 	*map = kcalloc(*num_maps + nmG, sizeof(**map), GFP_KERNEL);
867 	if (!(*map))
868 		return -ENOMEM;
869 
870 	parent = of_get_parent(np_config);
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);
884 			if (!configs)
885 				goto sppctl_map_err;
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);
899 			if (!configs)
900 				goto sppctl_map_err;
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;
970 
971 sppctl_map_err:
972 	for (i = 0; i < (*num_maps); i++)
973 		if ((*map)[i].type == PIN_MAP_TYPE_CONFIGS_PIN)
974 			kfree((*map)[i].data.configs.configs);
975 	kfree(*map);
976 	of_node_put(parent);
977 	return -ENOMEM;
978 }
979 
980 static 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 
sppctl_group_groups(struct platform_device * pdev)991 static 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 
sppctl_pinctrl_init(struct platform_device * pdev)1036 static 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 
sppctl_resource_map(struct platform_device * pdev,struct sppctl_pdata * sppctl)1062 static 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 
sppctl_probe(struct platform_device * pdev)1083 static 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 
1110 static const struct of_device_id sppctl_match_table[] = {
1111 	{ .compatible = "sunplus,sp7021-pctl" },
1112 	{ /* sentinel */ }
1113 };
1114 
1115 static 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 };
1122 builtin_platform_driver(sppctl_pinctrl_driver)
1123 
1124 MODULE_AUTHOR("Dvorkin Dmitry <dvorkin@tibbo.com>");
1125 MODULE_AUTHOR("Wells Lu <wellslutw@gmail.com>");
1126 MODULE_DESCRIPTION("Sunplus SP7021 Pin Control and GPIO driver");
1127 MODULE_LICENSE("GPL v2");
1128