xref: /openbmc/linux/drivers/pinctrl/qcom/pinctrl-spmi-gpio.c (revision 023e41632e065d49bcbe31b3c4b336217f96a271)
1 /*
2  * Copyright (c) 2012-2014, The Linux Foundation. All rights reserved.
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License version 2 and
6  * only version 2 as published by the Free Software Foundation.
7  *
8  * This program is distributed in the hope that it will be useful,
9  * but WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11  * GNU General Public License for more details.
12  */
13 
14 #include <linux/gpio/driver.h>
15 #include <linux/interrupt.h>
16 #include <linux/module.h>
17 #include <linux/of.h>
18 #include <linux/of_irq.h>
19 #include <linux/pinctrl/pinconf-generic.h>
20 #include <linux/pinctrl/pinconf.h>
21 #include <linux/pinctrl/pinmux.h>
22 #include <linux/platform_device.h>
23 #include <linux/regmap.h>
24 #include <linux/slab.h>
25 #include <linux/types.h>
26 
27 #include <dt-bindings/pinctrl/qcom,pmic-gpio.h>
28 
29 #include "../core.h"
30 #include "../pinctrl-utils.h"
31 
32 #define PMIC_GPIO_ADDRESS_RANGE			0x100
33 
34 /* type and subtype registers base address offsets */
35 #define PMIC_GPIO_REG_TYPE			0x4
36 #define PMIC_GPIO_REG_SUBTYPE			0x5
37 
38 /* GPIO peripheral type and subtype out_values */
39 #define PMIC_GPIO_TYPE				0x10
40 #define PMIC_GPIO_SUBTYPE_GPIO_4CH		0x1
41 #define PMIC_GPIO_SUBTYPE_GPIOC_4CH		0x5
42 #define PMIC_GPIO_SUBTYPE_GPIO_8CH		0x9
43 #define PMIC_GPIO_SUBTYPE_GPIOC_8CH		0xd
44 #define PMIC_GPIO_SUBTYPE_GPIO_LV		0x10
45 #define PMIC_GPIO_SUBTYPE_GPIO_MV		0x11
46 
47 #define PMIC_MPP_REG_RT_STS			0x10
48 #define PMIC_MPP_REG_RT_STS_VAL_MASK		0x1
49 
50 /* control register base address offsets */
51 #define PMIC_GPIO_REG_MODE_CTL			0x40
52 #define PMIC_GPIO_REG_DIG_VIN_CTL		0x41
53 #define PMIC_GPIO_REG_DIG_PULL_CTL		0x42
54 #define PMIC_GPIO_REG_LV_MV_DIG_OUT_SOURCE_CTL	0x44
55 #define PMIC_GPIO_REG_DIG_IN_CTL		0x43
56 #define PMIC_GPIO_REG_DIG_OUT_CTL		0x45
57 #define PMIC_GPIO_REG_EN_CTL			0x46
58 #define PMIC_GPIO_REG_LV_MV_ANA_PASS_THRU_SEL	0x4A
59 
60 /* PMIC_GPIO_REG_MODE_CTL */
61 #define PMIC_GPIO_REG_MODE_VALUE_SHIFT		0x1
62 #define PMIC_GPIO_REG_MODE_FUNCTION_SHIFT	1
63 #define PMIC_GPIO_REG_MODE_FUNCTION_MASK	0x7
64 #define PMIC_GPIO_REG_MODE_DIR_SHIFT		4
65 #define PMIC_GPIO_REG_MODE_DIR_MASK		0x7
66 
67 #define PMIC_GPIO_MODE_DIGITAL_INPUT		0
68 #define PMIC_GPIO_MODE_DIGITAL_OUTPUT		1
69 #define PMIC_GPIO_MODE_DIGITAL_INPUT_OUTPUT	2
70 #define PMIC_GPIO_MODE_ANALOG_PASS_THRU		3
71 #define PMIC_GPIO_REG_LV_MV_MODE_DIR_MASK	0x3
72 
73 /* PMIC_GPIO_REG_DIG_VIN_CTL */
74 #define PMIC_GPIO_REG_VIN_SHIFT			0
75 #define PMIC_GPIO_REG_VIN_MASK			0x7
76 
77 /* PMIC_GPIO_REG_DIG_PULL_CTL */
78 #define PMIC_GPIO_REG_PULL_SHIFT		0
79 #define PMIC_GPIO_REG_PULL_MASK			0x7
80 
81 #define PMIC_GPIO_PULL_DOWN			4
82 #define PMIC_GPIO_PULL_DISABLE			5
83 
84 /* PMIC_GPIO_REG_LV_MV_DIG_OUT_SOURCE_CTL for LV/MV */
85 #define PMIC_GPIO_LV_MV_OUTPUT_INVERT		0x80
86 #define PMIC_GPIO_LV_MV_OUTPUT_INVERT_SHIFT	7
87 #define PMIC_GPIO_LV_MV_OUTPUT_SOURCE_SEL_MASK	0xF
88 
89 /* PMIC_GPIO_REG_DIG_IN_CTL */
90 #define PMIC_GPIO_LV_MV_DIG_IN_DTEST_EN		0x80
91 #define PMIC_GPIO_LV_MV_DIG_IN_DTEST_SEL_MASK	0x7
92 #define PMIC_GPIO_DIG_IN_DTEST_SEL_MASK		0xf
93 
94 /* PMIC_GPIO_REG_DIG_OUT_CTL */
95 #define PMIC_GPIO_REG_OUT_STRENGTH_SHIFT	0
96 #define PMIC_GPIO_REG_OUT_STRENGTH_MASK		0x3
97 #define PMIC_GPIO_REG_OUT_TYPE_SHIFT		4
98 #define PMIC_GPIO_REG_OUT_TYPE_MASK		0x3
99 
100 /*
101  * Output type - indicates pin should be configured as push-pull,
102  * open drain or open source.
103  */
104 #define PMIC_GPIO_OUT_BUF_CMOS			0
105 #define PMIC_GPIO_OUT_BUF_OPEN_DRAIN_NMOS	1
106 #define PMIC_GPIO_OUT_BUF_OPEN_DRAIN_PMOS	2
107 
108 /* PMIC_GPIO_REG_EN_CTL */
109 #define PMIC_GPIO_REG_MASTER_EN_SHIFT		7
110 
111 #define PMIC_GPIO_PHYSICAL_OFFSET		1
112 
113 /* PMIC_GPIO_REG_LV_MV_ANA_PASS_THRU_SEL */
114 #define PMIC_GPIO_LV_MV_ANA_MUX_SEL_MASK		0x3
115 
116 /* Qualcomm specific pin configurations */
117 #define PMIC_GPIO_CONF_PULL_UP			(PIN_CONFIG_END + 1)
118 #define PMIC_GPIO_CONF_STRENGTH			(PIN_CONFIG_END + 2)
119 #define PMIC_GPIO_CONF_ATEST			(PIN_CONFIG_END + 3)
120 #define PMIC_GPIO_CONF_ANALOG_PASS		(PIN_CONFIG_END + 4)
121 #define PMIC_GPIO_CONF_DTEST_BUFFER		(PIN_CONFIG_END + 5)
122 
123 /* The index of each function in pmic_gpio_functions[] array */
124 enum pmic_gpio_func_index {
125 	PMIC_GPIO_FUNC_INDEX_NORMAL,
126 	PMIC_GPIO_FUNC_INDEX_PAIRED,
127 	PMIC_GPIO_FUNC_INDEX_FUNC1,
128 	PMIC_GPIO_FUNC_INDEX_FUNC2,
129 	PMIC_GPIO_FUNC_INDEX_FUNC3,
130 	PMIC_GPIO_FUNC_INDEX_FUNC4,
131 	PMIC_GPIO_FUNC_INDEX_DTEST1,
132 	PMIC_GPIO_FUNC_INDEX_DTEST2,
133 	PMIC_GPIO_FUNC_INDEX_DTEST3,
134 	PMIC_GPIO_FUNC_INDEX_DTEST4,
135 };
136 
137 /**
138  * struct pmic_gpio_pad - keep current GPIO settings
139  * @base: Address base in SPMI device.
140  * @is_enabled: Set to false when GPIO should be put in high Z state.
141  * @out_value: Cached pin output value
142  * @have_buffer: Set to true if GPIO output could be configured in push-pull,
143  *	open-drain or open-source mode.
144  * @output_enabled: Set to true if GPIO output logic is enabled.
145  * @input_enabled: Set to true if GPIO input buffer logic is enabled.
146  * @analog_pass: Set to true if GPIO is in analog-pass-through mode.
147  * @lv_mv_type: Set to true if GPIO subtype is GPIO_LV(0x10) or GPIO_MV(0x11).
148  * @num_sources: Number of power-sources supported by this GPIO.
149  * @power_source: Current power-source used.
150  * @buffer_type: Push-pull, open-drain or open-source.
151  * @pullup: Constant current which flow trough GPIO output buffer.
152  * @strength: No, Low, Medium, High
153  * @function: See pmic_gpio_functions[]
154  * @atest: the ATEST selection for GPIO analog-pass-through mode
155  * @dtest_buffer: the DTEST buffer selection for digital input mode.
156  */
157 struct pmic_gpio_pad {
158 	u16		base;
159 	bool		is_enabled;
160 	bool		out_value;
161 	bool		have_buffer;
162 	bool		output_enabled;
163 	bool		input_enabled;
164 	bool		analog_pass;
165 	bool		lv_mv_type;
166 	unsigned int	num_sources;
167 	unsigned int	power_source;
168 	unsigned int	buffer_type;
169 	unsigned int	pullup;
170 	unsigned int	strength;
171 	unsigned int	function;
172 	unsigned int	atest;
173 	unsigned int	dtest_buffer;
174 };
175 
176 struct pmic_gpio_state {
177 	struct device	*dev;
178 	struct regmap	*map;
179 	struct pinctrl_dev *ctrl;
180 	struct gpio_chip chip;
181 	struct fwnode_handle *fwnode;
182 	struct irq_domain *domain;
183 };
184 
185 static const struct pinconf_generic_params pmic_gpio_bindings[] = {
186 	{"qcom,pull-up-strength",	PMIC_GPIO_CONF_PULL_UP,		0},
187 	{"qcom,drive-strength",		PMIC_GPIO_CONF_STRENGTH,	0},
188 	{"qcom,atest",			PMIC_GPIO_CONF_ATEST,		0},
189 	{"qcom,analog-pass",		PMIC_GPIO_CONF_ANALOG_PASS,	0},
190 	{"qcom,dtest-buffer",           PMIC_GPIO_CONF_DTEST_BUFFER,    0},
191 };
192 
193 #ifdef CONFIG_DEBUG_FS
194 static const struct pin_config_item pmic_conf_items[ARRAY_SIZE(pmic_gpio_bindings)] = {
195 	PCONFDUMP(PMIC_GPIO_CONF_PULL_UP,  "pull up strength", NULL, true),
196 	PCONFDUMP(PMIC_GPIO_CONF_STRENGTH, "drive-strength", NULL, true),
197 	PCONFDUMP(PMIC_GPIO_CONF_ATEST, "atest", NULL, true),
198 	PCONFDUMP(PMIC_GPIO_CONF_ANALOG_PASS, "analog-pass", NULL, true),
199 	PCONFDUMP(PMIC_GPIO_CONF_DTEST_BUFFER, "dtest-buffer", NULL, true),
200 };
201 #endif
202 
203 static const char *const pmic_gpio_groups[] = {
204 	"gpio1", "gpio2", "gpio3", "gpio4", "gpio5", "gpio6", "gpio7", "gpio8",
205 	"gpio9", "gpio10", "gpio11", "gpio12", "gpio13", "gpio14", "gpio15",
206 	"gpio16", "gpio17", "gpio18", "gpio19", "gpio20", "gpio21", "gpio22",
207 	"gpio23", "gpio24", "gpio25", "gpio26", "gpio27", "gpio28", "gpio29",
208 	"gpio30", "gpio31", "gpio32", "gpio33", "gpio34", "gpio35", "gpio36",
209 };
210 
211 static const char *const pmic_gpio_functions[] = {
212 	[PMIC_GPIO_FUNC_INDEX_NORMAL]	= PMIC_GPIO_FUNC_NORMAL,
213 	[PMIC_GPIO_FUNC_INDEX_PAIRED]	= PMIC_GPIO_FUNC_PAIRED,
214 	[PMIC_GPIO_FUNC_INDEX_FUNC1]	= PMIC_GPIO_FUNC_FUNC1,
215 	[PMIC_GPIO_FUNC_INDEX_FUNC2]	= PMIC_GPIO_FUNC_FUNC2,
216 	[PMIC_GPIO_FUNC_INDEX_FUNC3]	= PMIC_GPIO_FUNC_FUNC3,
217 	[PMIC_GPIO_FUNC_INDEX_FUNC4]	= PMIC_GPIO_FUNC_FUNC4,
218 	[PMIC_GPIO_FUNC_INDEX_DTEST1]	= PMIC_GPIO_FUNC_DTEST1,
219 	[PMIC_GPIO_FUNC_INDEX_DTEST2]	= PMIC_GPIO_FUNC_DTEST2,
220 	[PMIC_GPIO_FUNC_INDEX_DTEST3]	= PMIC_GPIO_FUNC_DTEST3,
221 	[PMIC_GPIO_FUNC_INDEX_DTEST4]	= PMIC_GPIO_FUNC_DTEST4,
222 };
223 
224 static int pmic_gpio_read(struct pmic_gpio_state *state,
225 			  struct pmic_gpio_pad *pad, unsigned int addr)
226 {
227 	unsigned int val;
228 	int ret;
229 
230 	ret = regmap_read(state->map, pad->base + addr, &val);
231 	if (ret < 0)
232 		dev_err(state->dev, "read 0x%x failed\n", addr);
233 	else
234 		ret = val;
235 
236 	return ret;
237 }
238 
239 static int pmic_gpio_write(struct pmic_gpio_state *state,
240 			   struct pmic_gpio_pad *pad, unsigned int addr,
241 			   unsigned int val)
242 {
243 	int ret;
244 
245 	ret = regmap_write(state->map, pad->base + addr, val);
246 	if (ret < 0)
247 		dev_err(state->dev, "write 0x%x failed\n", addr);
248 
249 	return ret;
250 }
251 
252 static int pmic_gpio_get_groups_count(struct pinctrl_dev *pctldev)
253 {
254 	/* Every PIN is a group */
255 	return pctldev->desc->npins;
256 }
257 
258 static const char *pmic_gpio_get_group_name(struct pinctrl_dev *pctldev,
259 					    unsigned pin)
260 {
261 	return pctldev->desc->pins[pin].name;
262 }
263 
264 static int pmic_gpio_get_group_pins(struct pinctrl_dev *pctldev, unsigned pin,
265 				    const unsigned **pins, unsigned *num_pins)
266 {
267 	*pins = &pctldev->desc->pins[pin].number;
268 	*num_pins = 1;
269 	return 0;
270 }
271 
272 static const struct pinctrl_ops pmic_gpio_pinctrl_ops = {
273 	.get_groups_count	= pmic_gpio_get_groups_count,
274 	.get_group_name		= pmic_gpio_get_group_name,
275 	.get_group_pins		= pmic_gpio_get_group_pins,
276 	.dt_node_to_map		= pinconf_generic_dt_node_to_map_group,
277 	.dt_free_map		= pinctrl_utils_free_map,
278 };
279 
280 static int pmic_gpio_get_functions_count(struct pinctrl_dev *pctldev)
281 {
282 	return ARRAY_SIZE(pmic_gpio_functions);
283 }
284 
285 static const char *pmic_gpio_get_function_name(struct pinctrl_dev *pctldev,
286 					       unsigned function)
287 {
288 	return pmic_gpio_functions[function];
289 }
290 
291 static int pmic_gpio_get_function_groups(struct pinctrl_dev *pctldev,
292 					 unsigned function,
293 					 const char *const **groups,
294 					 unsigned *const num_qgroups)
295 {
296 	*groups = pmic_gpio_groups;
297 	*num_qgroups = pctldev->desc->npins;
298 	return 0;
299 }
300 
301 static int pmic_gpio_set_mux(struct pinctrl_dev *pctldev, unsigned function,
302 				unsigned pin)
303 {
304 	struct pmic_gpio_state *state = pinctrl_dev_get_drvdata(pctldev);
305 	struct pmic_gpio_pad *pad;
306 	unsigned int val;
307 	int ret;
308 
309 	if (function > PMIC_GPIO_FUNC_INDEX_DTEST4) {
310 		pr_err("function: %d is not defined\n", function);
311 		return -EINVAL;
312 	}
313 
314 	pad = pctldev->desc->pins[pin].drv_data;
315 	/*
316 	 * Non-LV/MV subtypes only support 2 special functions,
317 	 * offsetting the dtestx function values by 2
318 	 */
319 	if (!pad->lv_mv_type) {
320 		if (function == PMIC_GPIO_FUNC_INDEX_FUNC3 ||
321 				function == PMIC_GPIO_FUNC_INDEX_FUNC4) {
322 			pr_err("LV/MV subtype doesn't have func3/func4\n");
323 			return -EINVAL;
324 		}
325 		if (function >= PMIC_GPIO_FUNC_INDEX_DTEST1)
326 			function -= (PMIC_GPIO_FUNC_INDEX_DTEST1 -
327 					PMIC_GPIO_FUNC_INDEX_FUNC3);
328 	}
329 
330 	pad->function = function;
331 
332 	if (pad->analog_pass)
333 		val = PMIC_GPIO_MODE_ANALOG_PASS_THRU;
334 	else if (pad->output_enabled && pad->input_enabled)
335 		val = PMIC_GPIO_MODE_DIGITAL_INPUT_OUTPUT;
336 	else if (pad->output_enabled)
337 		val = PMIC_GPIO_MODE_DIGITAL_OUTPUT;
338 	else
339 		val = PMIC_GPIO_MODE_DIGITAL_INPUT;
340 
341 	if (pad->lv_mv_type) {
342 		ret = pmic_gpio_write(state, pad,
343 				PMIC_GPIO_REG_MODE_CTL, val);
344 		if (ret < 0)
345 			return ret;
346 
347 		val = pad->atest - 1;
348 		ret = pmic_gpio_write(state, pad,
349 				PMIC_GPIO_REG_LV_MV_ANA_PASS_THRU_SEL, val);
350 		if (ret < 0)
351 			return ret;
352 
353 		val = pad->out_value
354 			<< PMIC_GPIO_LV_MV_OUTPUT_INVERT_SHIFT;
355 		val |= pad->function
356 			& PMIC_GPIO_LV_MV_OUTPUT_SOURCE_SEL_MASK;
357 		ret = pmic_gpio_write(state, pad,
358 			PMIC_GPIO_REG_LV_MV_DIG_OUT_SOURCE_CTL, val);
359 		if (ret < 0)
360 			return ret;
361 	} else {
362 		val = val << PMIC_GPIO_REG_MODE_DIR_SHIFT;
363 		val |= pad->function << PMIC_GPIO_REG_MODE_FUNCTION_SHIFT;
364 		val |= pad->out_value & PMIC_GPIO_REG_MODE_VALUE_SHIFT;
365 
366 		ret = pmic_gpio_write(state, pad, PMIC_GPIO_REG_MODE_CTL, val);
367 		if (ret < 0)
368 			return ret;
369 	}
370 
371 	val = pad->is_enabled << PMIC_GPIO_REG_MASTER_EN_SHIFT;
372 
373 	return pmic_gpio_write(state, pad, PMIC_GPIO_REG_EN_CTL, val);
374 }
375 
376 static const struct pinmux_ops pmic_gpio_pinmux_ops = {
377 	.get_functions_count	= pmic_gpio_get_functions_count,
378 	.get_function_name	= pmic_gpio_get_function_name,
379 	.get_function_groups	= pmic_gpio_get_function_groups,
380 	.set_mux		= pmic_gpio_set_mux,
381 };
382 
383 static int pmic_gpio_config_get(struct pinctrl_dev *pctldev,
384 				unsigned int pin, unsigned long *config)
385 {
386 	unsigned param = pinconf_to_config_param(*config);
387 	struct pmic_gpio_pad *pad;
388 	unsigned arg;
389 
390 	pad = pctldev->desc->pins[pin].drv_data;
391 
392 	switch (param) {
393 	case PIN_CONFIG_DRIVE_PUSH_PULL:
394 		if (pad->buffer_type != PMIC_GPIO_OUT_BUF_CMOS)
395 			return -EINVAL;
396 		arg = 1;
397 		break;
398 	case PIN_CONFIG_DRIVE_OPEN_DRAIN:
399 		if (pad->buffer_type != PMIC_GPIO_OUT_BUF_OPEN_DRAIN_NMOS)
400 			return -EINVAL;
401 		arg = 1;
402 		break;
403 	case PIN_CONFIG_DRIVE_OPEN_SOURCE:
404 		if (pad->buffer_type != PMIC_GPIO_OUT_BUF_OPEN_DRAIN_PMOS)
405 			return -EINVAL;
406 		arg = 1;
407 		break;
408 	case PIN_CONFIG_BIAS_PULL_DOWN:
409 		if (pad->pullup != PMIC_GPIO_PULL_DOWN)
410 			return -EINVAL;
411 		arg = 1;
412 		break;
413 	case PIN_CONFIG_BIAS_DISABLE:
414 		if (pad->pullup != PMIC_GPIO_PULL_DISABLE)
415 			return -EINVAL;
416 		arg = 1;
417 		break;
418 	case PIN_CONFIG_BIAS_PULL_UP:
419 		if (pad->pullup != PMIC_GPIO_PULL_UP_30)
420 			return -EINVAL;
421 		arg = 1;
422 		break;
423 	case PIN_CONFIG_BIAS_HIGH_IMPEDANCE:
424 		if (pad->is_enabled)
425 			return -EINVAL;
426 		arg = 1;
427 		break;
428 	case PIN_CONFIG_POWER_SOURCE:
429 		arg = pad->power_source;
430 		break;
431 	case PIN_CONFIG_INPUT_ENABLE:
432 		if (!pad->input_enabled)
433 			return -EINVAL;
434 		arg = 1;
435 		break;
436 	case PIN_CONFIG_OUTPUT:
437 		arg = pad->out_value;
438 		break;
439 	case PMIC_GPIO_CONF_PULL_UP:
440 		arg = pad->pullup;
441 		break;
442 	case PMIC_GPIO_CONF_STRENGTH:
443 		arg = pad->strength;
444 		break;
445 	case PMIC_GPIO_CONF_ATEST:
446 		arg = pad->atest;
447 		break;
448 	case PMIC_GPIO_CONF_ANALOG_PASS:
449 		arg = pad->analog_pass;
450 		break;
451 	case PMIC_GPIO_CONF_DTEST_BUFFER:
452 		arg = pad->dtest_buffer;
453 		break;
454 	default:
455 		return -EINVAL;
456 	}
457 
458 	*config = pinconf_to_config_packed(param, arg);
459 	return 0;
460 }
461 
462 static int pmic_gpio_config_set(struct pinctrl_dev *pctldev, unsigned int pin,
463 				unsigned long *configs, unsigned nconfs)
464 {
465 	struct pmic_gpio_state *state = pinctrl_dev_get_drvdata(pctldev);
466 	struct pmic_gpio_pad *pad;
467 	unsigned param, arg;
468 	unsigned int val;
469 	int i, ret;
470 
471 	pad = pctldev->desc->pins[pin].drv_data;
472 
473 	pad->is_enabled = true;
474 	for (i = 0; i < nconfs; i++) {
475 		param = pinconf_to_config_param(configs[i]);
476 		arg = pinconf_to_config_argument(configs[i]);
477 
478 		switch (param) {
479 		case PIN_CONFIG_DRIVE_PUSH_PULL:
480 			pad->buffer_type = PMIC_GPIO_OUT_BUF_CMOS;
481 			break;
482 		case PIN_CONFIG_DRIVE_OPEN_DRAIN:
483 			if (!pad->have_buffer)
484 				return -EINVAL;
485 			pad->buffer_type = PMIC_GPIO_OUT_BUF_OPEN_DRAIN_NMOS;
486 			break;
487 		case PIN_CONFIG_DRIVE_OPEN_SOURCE:
488 			if (!pad->have_buffer)
489 				return -EINVAL;
490 			pad->buffer_type = PMIC_GPIO_OUT_BUF_OPEN_DRAIN_PMOS;
491 			break;
492 		case PIN_CONFIG_BIAS_DISABLE:
493 			pad->pullup = PMIC_GPIO_PULL_DISABLE;
494 			break;
495 		case PIN_CONFIG_BIAS_PULL_UP:
496 			pad->pullup = PMIC_GPIO_PULL_UP_30;
497 			break;
498 		case PIN_CONFIG_BIAS_PULL_DOWN:
499 			if (arg)
500 				pad->pullup = PMIC_GPIO_PULL_DOWN;
501 			else
502 				pad->pullup = PMIC_GPIO_PULL_DISABLE;
503 			break;
504 		case PIN_CONFIG_BIAS_HIGH_IMPEDANCE:
505 			pad->is_enabled = false;
506 			break;
507 		case PIN_CONFIG_POWER_SOURCE:
508 			if (arg >= pad->num_sources)
509 				return -EINVAL;
510 			pad->power_source = arg;
511 			break;
512 		case PIN_CONFIG_INPUT_ENABLE:
513 			pad->input_enabled = arg ? true : false;
514 			break;
515 		case PIN_CONFIG_OUTPUT:
516 			pad->output_enabled = true;
517 			pad->out_value = arg;
518 			break;
519 		case PMIC_GPIO_CONF_PULL_UP:
520 			if (arg > PMIC_GPIO_PULL_UP_1P5_30)
521 				return -EINVAL;
522 			pad->pullup = arg;
523 			break;
524 		case PMIC_GPIO_CONF_STRENGTH:
525 			if (arg > PMIC_GPIO_STRENGTH_LOW)
526 				return -EINVAL;
527 			pad->strength = arg;
528 			break;
529 		case PMIC_GPIO_CONF_ATEST:
530 			if (!pad->lv_mv_type || arg > 4)
531 				return -EINVAL;
532 			pad->atest = arg;
533 			break;
534 		case PMIC_GPIO_CONF_ANALOG_PASS:
535 			if (!pad->lv_mv_type)
536 				return -EINVAL;
537 			pad->analog_pass = true;
538 			break;
539 		case PMIC_GPIO_CONF_DTEST_BUFFER:
540 			if (arg > 4)
541 				return -EINVAL;
542 			pad->dtest_buffer = arg;
543 			break;
544 		default:
545 			return -EINVAL;
546 		}
547 	}
548 
549 	val = pad->power_source << PMIC_GPIO_REG_VIN_SHIFT;
550 
551 	ret = pmic_gpio_write(state, pad, PMIC_GPIO_REG_DIG_VIN_CTL, val);
552 	if (ret < 0)
553 		return ret;
554 
555 	val = pad->pullup << PMIC_GPIO_REG_PULL_SHIFT;
556 
557 	ret = pmic_gpio_write(state, pad, PMIC_GPIO_REG_DIG_PULL_CTL, val);
558 	if (ret < 0)
559 		return ret;
560 
561 	val = pad->buffer_type << PMIC_GPIO_REG_OUT_TYPE_SHIFT;
562 	val |= pad->strength << PMIC_GPIO_REG_OUT_STRENGTH_SHIFT;
563 
564 	ret = pmic_gpio_write(state, pad, PMIC_GPIO_REG_DIG_OUT_CTL, val);
565 	if (ret < 0)
566 		return ret;
567 
568 	if (pad->dtest_buffer == 0) {
569 		val = 0;
570 	} else {
571 		if (pad->lv_mv_type) {
572 			val = pad->dtest_buffer - 1;
573 			val |= PMIC_GPIO_LV_MV_DIG_IN_DTEST_EN;
574 		} else {
575 			val = BIT(pad->dtest_buffer - 1);
576 		}
577 	}
578 	ret = pmic_gpio_write(state, pad, PMIC_GPIO_REG_DIG_IN_CTL, val);
579 	if (ret < 0)
580 		return ret;
581 
582 	if (pad->analog_pass)
583 		val = PMIC_GPIO_MODE_ANALOG_PASS_THRU;
584 	else if (pad->output_enabled && pad->input_enabled)
585 		val = PMIC_GPIO_MODE_DIGITAL_INPUT_OUTPUT;
586 	else if (pad->output_enabled)
587 		val = PMIC_GPIO_MODE_DIGITAL_OUTPUT;
588 	else
589 		val = PMIC_GPIO_MODE_DIGITAL_INPUT;
590 
591 	if (pad->lv_mv_type) {
592 		ret = pmic_gpio_write(state, pad,
593 				PMIC_GPIO_REG_MODE_CTL, val);
594 		if (ret < 0)
595 			return ret;
596 
597 		val = pad->atest - 1;
598 		ret = pmic_gpio_write(state, pad,
599 				PMIC_GPIO_REG_LV_MV_ANA_PASS_THRU_SEL, val);
600 		if (ret < 0)
601 			return ret;
602 
603 		val = pad->out_value
604 			<< PMIC_GPIO_LV_MV_OUTPUT_INVERT_SHIFT;
605 		val |= pad->function
606 			& PMIC_GPIO_LV_MV_OUTPUT_SOURCE_SEL_MASK;
607 		ret = pmic_gpio_write(state, pad,
608 			PMIC_GPIO_REG_LV_MV_DIG_OUT_SOURCE_CTL, val);
609 		if (ret < 0)
610 			return ret;
611 	} else {
612 		val = val << PMIC_GPIO_REG_MODE_DIR_SHIFT;
613 		val |= pad->function << PMIC_GPIO_REG_MODE_FUNCTION_SHIFT;
614 		val |= pad->out_value & PMIC_GPIO_REG_MODE_VALUE_SHIFT;
615 
616 		ret = pmic_gpio_write(state, pad, PMIC_GPIO_REG_MODE_CTL, val);
617 		if (ret < 0)
618 			return ret;
619 	}
620 
621 	val = pad->is_enabled << PMIC_GPIO_REG_MASTER_EN_SHIFT;
622 
623 	ret = pmic_gpio_write(state, pad, PMIC_GPIO_REG_EN_CTL, val);
624 
625 	return ret;
626 }
627 
628 static void pmic_gpio_config_dbg_show(struct pinctrl_dev *pctldev,
629 				      struct seq_file *s, unsigned pin)
630 {
631 	struct pmic_gpio_state *state = pinctrl_dev_get_drvdata(pctldev);
632 	struct pmic_gpio_pad *pad;
633 	int ret, val, function;
634 
635 	static const char *const biases[] = {
636 		"pull-up 30uA", "pull-up 1.5uA", "pull-up 31.5uA",
637 		"pull-up 1.5uA + 30uA boost", "pull-down 10uA", "no pull"
638 	};
639 	static const char *const buffer_types[] = {
640 		"push-pull", "open-drain", "open-source"
641 	};
642 	static const char *const strengths[] = {
643 		"no", "high", "medium", "low"
644 	};
645 
646 	pad = pctldev->desc->pins[pin].drv_data;
647 
648 	seq_printf(s, " gpio%-2d:", pin + PMIC_GPIO_PHYSICAL_OFFSET);
649 
650 	val = pmic_gpio_read(state, pad, PMIC_GPIO_REG_EN_CTL);
651 
652 	if (val < 0 || !(val >> PMIC_GPIO_REG_MASTER_EN_SHIFT)) {
653 		seq_puts(s, " ---");
654 	} else {
655 		if (pad->input_enabled) {
656 			ret = pmic_gpio_read(state, pad, PMIC_MPP_REG_RT_STS);
657 			if (ret < 0)
658 				return;
659 
660 			ret &= PMIC_MPP_REG_RT_STS_VAL_MASK;
661 			pad->out_value = ret;
662 		}
663 		/*
664 		 * For the non-LV/MV subtypes only 2 special functions are
665 		 * available, offsetting the dtest function values by 2.
666 		 */
667 		function = pad->function;
668 		if (!pad->lv_mv_type &&
669 				pad->function >= PMIC_GPIO_FUNC_INDEX_FUNC3)
670 			function += PMIC_GPIO_FUNC_INDEX_DTEST1 -
671 				PMIC_GPIO_FUNC_INDEX_FUNC3;
672 
673 		if (pad->analog_pass)
674 			seq_puts(s, " analog-pass");
675 		else
676 			seq_printf(s, " %-4s",
677 					pad->output_enabled ? "out" : "in");
678 		seq_printf(s, " %-4s", pad->out_value ? "high" : "low");
679 		seq_printf(s, " %-7s", pmic_gpio_functions[function]);
680 		seq_printf(s, " vin-%d", pad->power_source);
681 		seq_printf(s, " %-27s", biases[pad->pullup]);
682 		seq_printf(s, " %-10s", buffer_types[pad->buffer_type]);
683 		seq_printf(s, " %-7s", strengths[pad->strength]);
684 		seq_printf(s, " atest-%d", pad->atest);
685 		seq_printf(s, " dtest-%d", pad->dtest_buffer);
686 	}
687 }
688 
689 static const struct pinconf_ops pmic_gpio_pinconf_ops = {
690 	.is_generic			= true,
691 	.pin_config_group_get		= pmic_gpio_config_get,
692 	.pin_config_group_set		= pmic_gpio_config_set,
693 	.pin_config_group_dbg_show	= pmic_gpio_config_dbg_show,
694 };
695 
696 static int pmic_gpio_direction_input(struct gpio_chip *chip, unsigned pin)
697 {
698 	struct pmic_gpio_state *state = gpiochip_get_data(chip);
699 	unsigned long config;
700 
701 	config = pinconf_to_config_packed(PIN_CONFIG_INPUT_ENABLE, 1);
702 
703 	return pmic_gpio_config_set(state->ctrl, pin, &config, 1);
704 }
705 
706 static int pmic_gpio_direction_output(struct gpio_chip *chip,
707 				      unsigned pin, int val)
708 {
709 	struct pmic_gpio_state *state = gpiochip_get_data(chip);
710 	unsigned long config;
711 
712 	config = pinconf_to_config_packed(PIN_CONFIG_OUTPUT, val);
713 
714 	return pmic_gpio_config_set(state->ctrl, pin, &config, 1);
715 }
716 
717 static int pmic_gpio_get(struct gpio_chip *chip, unsigned pin)
718 {
719 	struct pmic_gpio_state *state = gpiochip_get_data(chip);
720 	struct pmic_gpio_pad *pad;
721 	int ret;
722 
723 	pad = state->ctrl->desc->pins[pin].drv_data;
724 
725 	if (!pad->is_enabled)
726 		return -EINVAL;
727 
728 	if (pad->input_enabled) {
729 		ret = pmic_gpio_read(state, pad, PMIC_MPP_REG_RT_STS);
730 		if (ret < 0)
731 			return ret;
732 
733 		pad->out_value = ret & PMIC_MPP_REG_RT_STS_VAL_MASK;
734 	}
735 
736 	return !!pad->out_value;
737 }
738 
739 static void pmic_gpio_set(struct gpio_chip *chip, unsigned pin, int value)
740 {
741 	struct pmic_gpio_state *state = gpiochip_get_data(chip);
742 	unsigned long config;
743 
744 	config = pinconf_to_config_packed(PIN_CONFIG_OUTPUT, value);
745 
746 	pmic_gpio_config_set(state->ctrl, pin, &config, 1);
747 }
748 
749 static int pmic_gpio_of_xlate(struct gpio_chip *chip,
750 			      const struct of_phandle_args *gpio_desc,
751 			      u32 *flags)
752 {
753 	if (chip->of_gpio_n_cells < 2)
754 		return -EINVAL;
755 
756 	if (flags)
757 		*flags = gpio_desc->args[1];
758 
759 	return gpio_desc->args[0] - PMIC_GPIO_PHYSICAL_OFFSET;
760 }
761 
762 static int pmic_gpio_to_irq(struct gpio_chip *chip, unsigned pin)
763 {
764 	struct pmic_gpio_state *state = gpiochip_get_data(chip);
765 	struct irq_fwspec fwspec;
766 
767 	fwspec.fwnode = state->fwnode;
768 	fwspec.param_count = 2;
769 	fwspec.param[0] = pin + PMIC_GPIO_PHYSICAL_OFFSET;
770 	/*
771 	 * Set the type to a safe value temporarily. This will be overwritten
772 	 * later with the proper value by irq_set_type.
773 	 */
774 	fwspec.param[1] = IRQ_TYPE_EDGE_RISING;
775 
776 	return irq_create_fwspec_mapping(&fwspec);
777 }
778 
779 static void pmic_gpio_dbg_show(struct seq_file *s, struct gpio_chip *chip)
780 {
781 	struct pmic_gpio_state *state = gpiochip_get_data(chip);
782 	unsigned i;
783 
784 	for (i = 0; i < chip->ngpio; i++) {
785 		pmic_gpio_config_dbg_show(state->ctrl, s, i);
786 		seq_puts(s, "\n");
787 	}
788 }
789 
790 static const struct gpio_chip pmic_gpio_gpio_template = {
791 	.direction_input	= pmic_gpio_direction_input,
792 	.direction_output	= pmic_gpio_direction_output,
793 	.get			= pmic_gpio_get,
794 	.set			= pmic_gpio_set,
795 	.request		= gpiochip_generic_request,
796 	.free			= gpiochip_generic_free,
797 	.of_xlate		= pmic_gpio_of_xlate,
798 	.to_irq			= pmic_gpio_to_irq,
799 	.dbg_show		= pmic_gpio_dbg_show,
800 };
801 
802 static int pmic_gpio_populate(struct pmic_gpio_state *state,
803 			      struct pmic_gpio_pad *pad)
804 {
805 	int type, subtype, val, dir;
806 
807 	type = pmic_gpio_read(state, pad, PMIC_GPIO_REG_TYPE);
808 	if (type < 0)
809 		return type;
810 
811 	if (type != PMIC_GPIO_TYPE) {
812 		dev_err(state->dev, "incorrect block type 0x%x at 0x%x\n",
813 			type, pad->base);
814 		return -ENODEV;
815 	}
816 
817 	subtype = pmic_gpio_read(state, pad, PMIC_GPIO_REG_SUBTYPE);
818 	if (subtype < 0)
819 		return subtype;
820 
821 	switch (subtype) {
822 	case PMIC_GPIO_SUBTYPE_GPIO_4CH:
823 		pad->have_buffer = true;
824 	case PMIC_GPIO_SUBTYPE_GPIOC_4CH:
825 		pad->num_sources = 4;
826 		break;
827 	case PMIC_GPIO_SUBTYPE_GPIO_8CH:
828 		pad->have_buffer = true;
829 	case PMIC_GPIO_SUBTYPE_GPIOC_8CH:
830 		pad->num_sources = 8;
831 		break;
832 	case PMIC_GPIO_SUBTYPE_GPIO_LV:
833 		pad->num_sources = 1;
834 		pad->have_buffer = true;
835 		pad->lv_mv_type = true;
836 		break;
837 	case PMIC_GPIO_SUBTYPE_GPIO_MV:
838 		pad->num_sources = 2;
839 		pad->have_buffer = true;
840 		pad->lv_mv_type = true;
841 		break;
842 	default:
843 		dev_err(state->dev, "unknown GPIO type 0x%x\n", subtype);
844 		return -ENODEV;
845 	}
846 
847 	if (pad->lv_mv_type) {
848 		val = pmic_gpio_read(state, pad,
849 				PMIC_GPIO_REG_LV_MV_DIG_OUT_SOURCE_CTL);
850 		if (val < 0)
851 			return val;
852 
853 		pad->out_value = !!(val & PMIC_GPIO_LV_MV_OUTPUT_INVERT);
854 		pad->function = val & PMIC_GPIO_LV_MV_OUTPUT_SOURCE_SEL_MASK;
855 
856 		val = pmic_gpio_read(state, pad, PMIC_GPIO_REG_MODE_CTL);
857 		if (val < 0)
858 			return val;
859 
860 		dir = val & PMIC_GPIO_REG_LV_MV_MODE_DIR_MASK;
861 	} else {
862 		val = pmic_gpio_read(state, pad, PMIC_GPIO_REG_MODE_CTL);
863 		if (val < 0)
864 			return val;
865 
866 		pad->out_value = val & PMIC_GPIO_REG_MODE_VALUE_SHIFT;
867 
868 		dir = val >> PMIC_GPIO_REG_MODE_DIR_SHIFT;
869 		dir &= PMIC_GPIO_REG_MODE_DIR_MASK;
870 		pad->function = val >> PMIC_GPIO_REG_MODE_FUNCTION_SHIFT;
871 		pad->function &= PMIC_GPIO_REG_MODE_FUNCTION_MASK;
872 	}
873 
874 	switch (dir) {
875 	case PMIC_GPIO_MODE_DIGITAL_INPUT:
876 		pad->input_enabled = true;
877 		pad->output_enabled = false;
878 		break;
879 	case PMIC_GPIO_MODE_DIGITAL_OUTPUT:
880 		pad->input_enabled = false;
881 		pad->output_enabled = true;
882 		break;
883 	case PMIC_GPIO_MODE_DIGITAL_INPUT_OUTPUT:
884 		pad->input_enabled = true;
885 		pad->output_enabled = true;
886 		break;
887 	case PMIC_GPIO_MODE_ANALOG_PASS_THRU:
888 		if (!pad->lv_mv_type)
889 			return -ENODEV;
890 		pad->analog_pass = true;
891 		break;
892 	default:
893 		dev_err(state->dev, "unknown GPIO direction\n");
894 		return -ENODEV;
895 	}
896 
897 	val = pmic_gpio_read(state, pad, PMIC_GPIO_REG_DIG_VIN_CTL);
898 	if (val < 0)
899 		return val;
900 
901 	pad->power_source = val >> PMIC_GPIO_REG_VIN_SHIFT;
902 	pad->power_source &= PMIC_GPIO_REG_VIN_MASK;
903 
904 	val = pmic_gpio_read(state, pad, PMIC_GPIO_REG_DIG_PULL_CTL);
905 	if (val < 0)
906 		return val;
907 
908 	pad->pullup = val >> PMIC_GPIO_REG_PULL_SHIFT;
909 	pad->pullup &= PMIC_GPIO_REG_PULL_MASK;
910 
911 	val = pmic_gpio_read(state, pad, PMIC_GPIO_REG_DIG_IN_CTL);
912 	if (val < 0)
913 		return val;
914 
915 	if (pad->lv_mv_type && (val & PMIC_GPIO_LV_MV_DIG_IN_DTEST_EN))
916 		pad->dtest_buffer =
917 			(val & PMIC_GPIO_LV_MV_DIG_IN_DTEST_SEL_MASK) + 1;
918 	else if (!pad->lv_mv_type)
919 		pad->dtest_buffer = ffs(val);
920 	else
921 		pad->dtest_buffer = 0;
922 
923 	val = pmic_gpio_read(state, pad, PMIC_GPIO_REG_DIG_OUT_CTL);
924 	if (val < 0)
925 		return val;
926 
927 	pad->strength = val >> PMIC_GPIO_REG_OUT_STRENGTH_SHIFT;
928 	pad->strength &= PMIC_GPIO_REG_OUT_STRENGTH_MASK;
929 
930 	pad->buffer_type = val >> PMIC_GPIO_REG_OUT_TYPE_SHIFT;
931 	pad->buffer_type &= PMIC_GPIO_REG_OUT_TYPE_MASK;
932 
933 	if (pad->lv_mv_type) {
934 		val = pmic_gpio_read(state, pad,
935 				PMIC_GPIO_REG_LV_MV_ANA_PASS_THRU_SEL);
936 		if (val < 0)
937 			return val;
938 		pad->atest = (val & PMIC_GPIO_LV_MV_ANA_MUX_SEL_MASK) + 1;
939 	}
940 
941 	/* Pin could be disabled with PIN_CONFIG_BIAS_HIGH_IMPEDANCE */
942 	pad->is_enabled = true;
943 	return 0;
944 }
945 
946 static struct irq_chip pmic_gpio_irq_chip = {
947 	.name = "spmi-gpio",
948 	.irq_ack = irq_chip_ack_parent,
949 	.irq_mask = irq_chip_mask_parent,
950 	.irq_unmask = irq_chip_unmask_parent,
951 	.irq_set_type = irq_chip_set_type_parent,
952 	.irq_set_wake = irq_chip_set_wake_parent,
953 	.flags = IRQCHIP_MASK_ON_SUSPEND,
954 };
955 
956 static int pmic_gpio_domain_translate(struct irq_domain *domain,
957 				      struct irq_fwspec *fwspec,
958 				      unsigned long *hwirq,
959 				      unsigned int *type)
960 {
961 	struct pmic_gpio_state *state = container_of(domain->host_data,
962 						     struct pmic_gpio_state,
963 						     chip);
964 
965 	if (fwspec->param_count != 2 ||
966 	    fwspec->param[0] < 1 || fwspec->param[0] > state->chip.ngpio)
967 		return -EINVAL;
968 
969 	*hwirq = fwspec->param[0] - PMIC_GPIO_PHYSICAL_OFFSET;
970 	*type = fwspec->param[1];
971 
972 	return 0;
973 }
974 
975 static int pmic_gpio_domain_alloc(struct irq_domain *domain, unsigned int virq,
976 				  unsigned int nr_irqs, void *data)
977 {
978 	struct pmic_gpio_state *state = container_of(domain->host_data,
979 						     struct pmic_gpio_state,
980 						     chip);
981 	struct irq_fwspec *fwspec = data;
982 	struct irq_fwspec parent_fwspec;
983 	irq_hw_number_t hwirq;
984 	unsigned int type;
985 	int ret, i;
986 
987 	ret = pmic_gpio_domain_translate(domain, fwspec, &hwirq, &type);
988 	if (ret)
989 		return ret;
990 
991 	for (i = 0; i < nr_irqs; i++)
992 		irq_domain_set_info(domain, virq + i, hwirq + i,
993 				    &pmic_gpio_irq_chip, state,
994 				    handle_level_irq, NULL, NULL);
995 
996 	parent_fwspec.fwnode = domain->parent->fwnode;
997 	parent_fwspec.param_count = 4;
998 	parent_fwspec.param[0] = 0;
999 	parent_fwspec.param[1] = hwirq + 0xc0;
1000 	parent_fwspec.param[2] = 0;
1001 	parent_fwspec.param[3] = fwspec->param[1];
1002 
1003 	return irq_domain_alloc_irqs_parent(domain, virq, nr_irqs,
1004 					    &parent_fwspec);
1005 }
1006 
1007 static const struct irq_domain_ops pmic_gpio_domain_ops = {
1008 	.activate = gpiochip_irq_domain_activate,
1009 	.alloc = pmic_gpio_domain_alloc,
1010 	.deactivate = gpiochip_irq_domain_deactivate,
1011 	.free = irq_domain_free_irqs_common,
1012 	.translate = pmic_gpio_domain_translate,
1013 };
1014 
1015 static int pmic_gpio_probe(struct platform_device *pdev)
1016 {
1017 	struct irq_domain *parent_domain;
1018 	struct device_node *parent_node;
1019 	struct device *dev = &pdev->dev;
1020 	struct pinctrl_pin_desc *pindesc;
1021 	struct pinctrl_desc *pctrldesc;
1022 	struct pmic_gpio_pad *pad, *pads;
1023 	struct pmic_gpio_state *state;
1024 	int ret, npins, i;
1025 	u32 reg;
1026 
1027 	ret = of_property_read_u32(dev->of_node, "reg", &reg);
1028 	if (ret < 0) {
1029 		dev_err(dev, "missing base address");
1030 		return ret;
1031 	}
1032 
1033 	npins = (uintptr_t) device_get_match_data(&pdev->dev);
1034 
1035 	state = devm_kzalloc(dev, sizeof(*state), GFP_KERNEL);
1036 	if (!state)
1037 		return -ENOMEM;
1038 
1039 	platform_set_drvdata(pdev, state);
1040 
1041 	state->dev = &pdev->dev;
1042 	state->map = dev_get_regmap(dev->parent, NULL);
1043 
1044 	pindesc = devm_kcalloc(dev, npins, sizeof(*pindesc), GFP_KERNEL);
1045 	if (!pindesc)
1046 		return -ENOMEM;
1047 
1048 	pads = devm_kcalloc(dev, npins, sizeof(*pads), GFP_KERNEL);
1049 	if (!pads)
1050 		return -ENOMEM;
1051 
1052 	pctrldesc = devm_kzalloc(dev, sizeof(*pctrldesc), GFP_KERNEL);
1053 	if (!pctrldesc)
1054 		return -ENOMEM;
1055 
1056 	pctrldesc->pctlops = &pmic_gpio_pinctrl_ops;
1057 	pctrldesc->pmxops = &pmic_gpio_pinmux_ops;
1058 	pctrldesc->confops = &pmic_gpio_pinconf_ops;
1059 	pctrldesc->owner = THIS_MODULE;
1060 	pctrldesc->name = dev_name(dev);
1061 	pctrldesc->pins = pindesc;
1062 	pctrldesc->npins = npins;
1063 	pctrldesc->num_custom_params = ARRAY_SIZE(pmic_gpio_bindings);
1064 	pctrldesc->custom_params = pmic_gpio_bindings;
1065 #ifdef CONFIG_DEBUG_FS
1066 	pctrldesc->custom_conf_items = pmic_conf_items;
1067 #endif
1068 
1069 	for (i = 0; i < npins; i++, pindesc++) {
1070 		pad = &pads[i];
1071 		pindesc->drv_data = pad;
1072 		pindesc->number = i;
1073 		pindesc->name = pmic_gpio_groups[i];
1074 
1075 		pad->base = reg + i * PMIC_GPIO_ADDRESS_RANGE;
1076 
1077 		ret = pmic_gpio_populate(state, pad);
1078 		if (ret < 0)
1079 			return ret;
1080 	}
1081 
1082 	state->chip = pmic_gpio_gpio_template;
1083 	state->chip.parent = dev;
1084 	state->chip.base = -1;
1085 	state->chip.ngpio = npins;
1086 	state->chip.label = dev_name(dev);
1087 	state->chip.of_gpio_n_cells = 2;
1088 	state->chip.can_sleep = false;
1089 
1090 	state->ctrl = devm_pinctrl_register(dev, pctrldesc, state);
1091 	if (IS_ERR(state->ctrl))
1092 		return PTR_ERR(state->ctrl);
1093 
1094 	parent_node = of_irq_find_parent(state->dev->of_node);
1095 	if (!parent_node)
1096 		return -ENXIO;
1097 
1098 	parent_domain = irq_find_host(parent_node);
1099 	of_node_put(parent_node);
1100 	if (!parent_domain)
1101 		return -ENXIO;
1102 
1103 	state->fwnode = of_node_to_fwnode(state->dev->of_node);
1104 	state->domain = irq_domain_create_hierarchy(parent_domain, 0,
1105 						    state->chip.ngpio,
1106 						    state->fwnode,
1107 						    &pmic_gpio_domain_ops,
1108 						    &state->chip);
1109 	if (!state->domain)
1110 		return -ENODEV;
1111 
1112 	ret = gpiochip_add_data(&state->chip, state);
1113 	if (ret) {
1114 		dev_err(state->dev, "can't add gpio chip\n");
1115 		goto err_chip_add_data;
1116 	}
1117 
1118 	/*
1119 	 * For DeviceTree-supported systems, the gpio core checks the
1120 	 * pinctrl's device node for the "gpio-ranges" property.
1121 	 * If it is present, it takes care of adding the pin ranges
1122 	 * for the driver. In this case the driver can skip ahead.
1123 	 *
1124 	 * In order to remain compatible with older, existing DeviceTree
1125 	 * files which don't set the "gpio-ranges" property or systems that
1126 	 * utilize ACPI the driver has to call gpiochip_add_pin_range().
1127 	 */
1128 	if (!of_property_read_bool(dev->of_node, "gpio-ranges")) {
1129 		ret = gpiochip_add_pin_range(&state->chip, dev_name(dev), 0, 0,
1130 					     npins);
1131 		if (ret) {
1132 			dev_err(dev, "failed to add pin range\n");
1133 			goto err_range;
1134 		}
1135 	}
1136 
1137 	return 0;
1138 
1139 err_range:
1140 	gpiochip_remove(&state->chip);
1141 err_chip_add_data:
1142 	irq_domain_remove(state->domain);
1143 	return ret;
1144 }
1145 
1146 static int pmic_gpio_remove(struct platform_device *pdev)
1147 {
1148 	struct pmic_gpio_state *state = platform_get_drvdata(pdev);
1149 
1150 	gpiochip_remove(&state->chip);
1151 	irq_domain_remove(state->domain);
1152 	return 0;
1153 }
1154 
1155 static const struct of_device_id pmic_gpio_of_match[] = {
1156 	{ .compatible = "qcom,pm8005-gpio", .data = (void *) 4 },
1157 	{ .compatible = "qcom,pm8916-gpio", .data = (void *) 4 },
1158 	{ .compatible = "qcom,pm8941-gpio", .data = (void *) 36 },
1159 	{ .compatible = "qcom,pm8994-gpio", .data = (void *) 22 },
1160 	{ .compatible = "qcom,pmi8994-gpio", .data = (void *) 10 },
1161 	{ .compatible = "qcom,pm8998-gpio", .data = (void *) 26 },
1162 	{ .compatible = "qcom,pmi8998-gpio", .data = (void *) 14 },
1163 	{ .compatible = "qcom,pma8084-gpio", .data = (void *) 22 },
1164 	/* pms405 has 12 GPIOs with holes on 1, 9, and 10 */
1165 	{ .compatible = "qcom,pms405-gpio", .data = (void *) 12 },
1166 	{ },
1167 };
1168 
1169 MODULE_DEVICE_TABLE(of, pmic_gpio_of_match);
1170 
1171 static struct platform_driver pmic_gpio_driver = {
1172 	.driver = {
1173 		   .name = "qcom-spmi-gpio",
1174 		   .of_match_table = pmic_gpio_of_match,
1175 	},
1176 	.probe	= pmic_gpio_probe,
1177 	.remove = pmic_gpio_remove,
1178 };
1179 
1180 module_platform_driver(pmic_gpio_driver);
1181 
1182 MODULE_AUTHOR("Ivan T. Ivanov <iivanov@mm-sol.com>");
1183 MODULE_DESCRIPTION("Qualcomm SPMI PMIC GPIO pin control driver");
1184 MODULE_ALIAS("platform:qcom-spmi-gpio");
1185 MODULE_LICENSE("GPL v2");
1186