1/*
2 * Copyright (c) 2015, Sony Mobile Communications AB.
3 * Copyright (c) 2013, The Linux Foundation. All rights reserved.
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 and
7 * only version 2 as published by the Free Software Foundation.
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 * GNU General Public License for more details.
13 */
14
15#include <linux/module.h>
16#include <linux/platform_device.h>
17#include <linux/pinctrl/pinctrl.h>
18#include <linux/pinctrl/pinmux.h>
19#include <linux/pinctrl/pinconf.h>
20#include <linux/pinctrl/pinconf-generic.h>
21#include <linux/slab.h>
22#include <linux/regmap.h>
23#include <linux/gpio.h>
24#include <linux/interrupt.h>
25#include <linux/of_device.h>
26
27#include <dt-bindings/pinctrl/qcom,pmic-mpp.h>
28
29#include "../core.h"
30#include "../pinctrl-utils.h"
31
32/* MPP registers */
33#define SSBI_REG_ADDR_MPP_BASE		0x50
34#define SSBI_REG_ADDR_MPP(n)		(SSBI_REG_ADDR_MPP_BASE + n)
35
36/* MPP Type: type */
37#define PM8XXX_MPP_TYPE_D_INPUT         0
38#define PM8XXX_MPP_TYPE_D_OUTPUT        1
39#define PM8XXX_MPP_TYPE_D_BI_DIR        2
40#define PM8XXX_MPP_TYPE_A_INPUT         3
41#define PM8XXX_MPP_TYPE_A_OUTPUT        4
42#define PM8XXX_MPP_TYPE_SINK            5
43#define PM8XXX_MPP_TYPE_DTEST_SINK      6
44#define PM8XXX_MPP_TYPE_DTEST_OUTPUT    7
45
46/* Digital Input: control */
47#define PM8XXX_MPP_DIN_TO_INT           0
48#define PM8XXX_MPP_DIN_TO_DBUS1         1
49#define PM8XXX_MPP_DIN_TO_DBUS2         2
50#define PM8XXX_MPP_DIN_TO_DBUS3         3
51
52/* Digital Output: control */
53#define PM8XXX_MPP_DOUT_CTRL_LOW        0
54#define PM8XXX_MPP_DOUT_CTRL_HIGH       1
55#define PM8XXX_MPP_DOUT_CTRL_MPP        2
56#define PM8XXX_MPP_DOUT_CTRL_INV_MPP    3
57
58/* Bidirectional: control */
59#define PM8XXX_MPP_BI_PULLUP_1KOHM      0
60#define PM8XXX_MPP_BI_PULLUP_OPEN       1
61#define PM8XXX_MPP_BI_PULLUP_10KOHM     2
62#define PM8XXX_MPP_BI_PULLUP_30KOHM     3
63
64/* Analog Output: control */
65#define PM8XXX_MPP_AOUT_CTRL_DISABLE            0
66#define PM8XXX_MPP_AOUT_CTRL_ENABLE             1
67#define PM8XXX_MPP_AOUT_CTRL_MPP_HIGH_EN        2
68#define PM8XXX_MPP_AOUT_CTRL_MPP_LOW_EN         3
69
70/* Current Sink: control */
71#define PM8XXX_MPP_CS_CTRL_DISABLE      0
72#define PM8XXX_MPP_CS_CTRL_ENABLE       1
73#define PM8XXX_MPP_CS_CTRL_MPP_HIGH_EN  2
74#define PM8XXX_MPP_CS_CTRL_MPP_LOW_EN   3
75
76/* DTEST Current Sink: control */
77#define PM8XXX_MPP_DTEST_CS_CTRL_EN1    0
78#define PM8XXX_MPP_DTEST_CS_CTRL_EN2    1
79#define PM8XXX_MPP_DTEST_CS_CTRL_EN3    2
80#define PM8XXX_MPP_DTEST_CS_CTRL_EN4    3
81
82/* DTEST Digital Output: control */
83#define PM8XXX_MPP_DTEST_DBUS1          0
84#define PM8XXX_MPP_DTEST_DBUS2          1
85#define PM8XXX_MPP_DTEST_DBUS3          2
86#define PM8XXX_MPP_DTEST_DBUS4          3
87
88/* custom pinconf parameters */
89#define PM8XXX_CONFIG_AMUX		(PIN_CONFIG_END + 1)
90#define PM8XXX_CONFIG_DTEST_SELECTOR	(PIN_CONFIG_END + 2)
91#define PM8XXX_CONFIG_ALEVEL		(PIN_CONFIG_END + 3)
92#define PM8XXX_CONFIG_PAIRED		(PIN_CONFIG_END + 4)
93
94/**
95 * struct pm8xxx_pin_data - dynamic configuration for a pin
96 * @reg:		address of the control register
97 * @irq:		IRQ from the PMIC interrupt controller
98 * @mode:		operating mode for the pin (digital, analog or current sink)
99 * @input:		pin is input
100 * @output:		pin is output
101 * @high_z:		pin is floating
102 * @paired:		mpp operates in paired mode
103 * @output_value:	logical output value of the mpp
104 * @power_source:	selected power source
105 * @dtest:		DTEST route selector
106 * @amux:		input muxing in analog mode
107 * @aout_level:		selector of the output in analog mode
108 * @drive_strength:	drive strength of the current sink
109 * @pullup:		pull up value, when in digital bidirectional mode
110 */
111struct pm8xxx_pin_data {
112	unsigned reg;
113	int irq;
114
115	u8 mode;
116
117	bool input;
118	bool output;
119	bool high_z;
120	bool paired;
121	bool output_value;
122
123	u8 power_source;
124	u8 dtest;
125	u8 amux;
126	u8 aout_level;
127	u8 drive_strength;
128	unsigned pullup;
129};
130
131struct pm8xxx_mpp {
132	struct device *dev;
133	struct regmap *regmap;
134	struct pinctrl_dev *pctrl;
135	struct gpio_chip chip;
136
137	struct pinctrl_desc desc;
138	unsigned npins;
139};
140
141static const struct pinconf_generic_params pm8xxx_mpp_bindings[] = {
142	{"qcom,amux-route",	PM8XXX_CONFIG_AMUX,		0},
143	{"qcom,analog-level",	PM8XXX_CONFIG_ALEVEL,		0},
144	{"qcom,dtest",		PM8XXX_CONFIG_DTEST_SELECTOR,	0},
145	{"qcom,paired",		PM8XXX_CONFIG_PAIRED,		0},
146};
147
148#ifdef CONFIG_DEBUG_FS
149static const struct pin_config_item pm8xxx_conf_items[] = {
150	PCONFDUMP(PM8XXX_CONFIG_AMUX, "analog mux", NULL, true),
151	PCONFDUMP(PM8XXX_CONFIG_ALEVEL, "analog level", NULL, true),
152	PCONFDUMP(PM8XXX_CONFIG_DTEST_SELECTOR, "dtest", NULL, true),
153	PCONFDUMP(PM8XXX_CONFIG_PAIRED, "paired", NULL, false),
154};
155#endif
156
157#define PM8XXX_MAX_MPPS	12
158static const char * const pm8xxx_groups[PM8XXX_MAX_MPPS] = {
159	"mpp1", "mpp2", "mpp3", "mpp4", "mpp5", "mpp6", "mpp7", "mpp8",
160	"mpp9", "mpp10", "mpp11", "mpp12",
161};
162
163#define PM8XXX_MPP_DIGITAL	0
164#define PM8XXX_MPP_ANALOG	1
165#define PM8XXX_MPP_SINK		2
166
167static const char * const pm8xxx_mpp_functions[] = {
168	"digital", "analog", "sink",
169};
170
171static int pm8xxx_mpp_update(struct pm8xxx_mpp *pctrl,
172			     struct pm8xxx_pin_data *pin)
173{
174	unsigned level;
175	unsigned ctrl;
176	unsigned type;
177	int ret;
178	u8 val;
179
180	switch (pin->mode) {
181	case PM8XXX_MPP_DIGITAL:
182		if (pin->dtest) {
183			type = PM8XXX_MPP_TYPE_DTEST_OUTPUT;
184			ctrl = pin->dtest - 1;
185		} else if (pin->input && pin->output) {
186			type = PM8XXX_MPP_TYPE_D_BI_DIR;
187			if (pin->high_z)
188				ctrl = PM8XXX_MPP_BI_PULLUP_OPEN;
189			else if (pin->pullup == 600)
190				ctrl = PM8XXX_MPP_BI_PULLUP_1KOHM;
191			else if (pin->pullup == 10000)
192				ctrl = PM8XXX_MPP_BI_PULLUP_10KOHM;
193			else
194				ctrl = PM8XXX_MPP_BI_PULLUP_30KOHM;
195		} else if (pin->input) {
196			type = PM8XXX_MPP_TYPE_D_INPUT;
197			if (pin->dtest)
198				ctrl = pin->dtest;
199			else
200				ctrl = PM8XXX_MPP_DIN_TO_INT;
201		} else {
202			type = PM8XXX_MPP_TYPE_D_OUTPUT;
203			ctrl = !!pin->output_value;
204			if (pin->paired)
205				ctrl |= BIT(1);
206		}
207
208		level = pin->power_source;
209		break;
210	case PM8XXX_MPP_ANALOG:
211		if (pin->output) {
212			type = PM8XXX_MPP_TYPE_A_OUTPUT;
213			level = pin->aout_level;
214			ctrl = pin->output_value;
215			if (pin->paired)
216				ctrl |= BIT(1);
217		} else {
218			type = PM8XXX_MPP_TYPE_A_INPUT;
219			level = pin->amux;
220			ctrl = 0;
221		}
222		break;
223	case PM8XXX_MPP_SINK:
224		level = (pin->drive_strength / 5) - 1;
225		if (pin->dtest) {
226			type = PM8XXX_MPP_TYPE_DTEST_SINK;
227			ctrl = pin->dtest - 1;
228		} else {
229			type = PM8XXX_MPP_TYPE_SINK;
230			ctrl = pin->output_value;
231			if (pin->paired)
232				ctrl |= BIT(1);
233		}
234		break;
235	default:
236		return -EINVAL;
237	}
238
239	val = type << 5 | level << 2 | ctrl;
240	ret = regmap_write(pctrl->regmap, pin->reg, val);
241	if (ret)
242		dev_err(pctrl->dev, "failed to write register\n");
243
244	return ret;
245}
246
247static int pm8xxx_get_groups_count(struct pinctrl_dev *pctldev)
248{
249	struct pm8xxx_mpp *pctrl = pinctrl_dev_get_drvdata(pctldev);
250
251	return pctrl->npins;
252}
253
254static const char *pm8xxx_get_group_name(struct pinctrl_dev *pctldev,
255					 unsigned group)
256{
257	return pm8xxx_groups[group];
258}
259
260
261static int pm8xxx_get_group_pins(struct pinctrl_dev *pctldev,
262				 unsigned group,
263				 const unsigned **pins,
264				 unsigned *num_pins)
265{
266	struct pm8xxx_mpp *pctrl = pinctrl_dev_get_drvdata(pctldev);
267
268	*pins = &pctrl->desc.pins[group].number;
269	*num_pins = 1;
270
271	return 0;
272}
273
274static const struct pinctrl_ops pm8xxx_pinctrl_ops = {
275	.get_groups_count	= pm8xxx_get_groups_count,
276	.get_group_name		= pm8xxx_get_group_name,
277	.get_group_pins         = pm8xxx_get_group_pins,
278	.dt_node_to_map		= pinconf_generic_dt_node_to_map_group,
279	.dt_free_map		= pinctrl_utils_dt_free_map,
280};
281
282static int pm8xxx_get_functions_count(struct pinctrl_dev *pctldev)
283{
284	return ARRAY_SIZE(pm8xxx_mpp_functions);
285}
286
287static const char *pm8xxx_get_function_name(struct pinctrl_dev *pctldev,
288					    unsigned function)
289{
290	return pm8xxx_mpp_functions[function];
291}
292
293static int pm8xxx_get_function_groups(struct pinctrl_dev *pctldev,
294				      unsigned function,
295				      const char * const **groups,
296				      unsigned * const num_groups)
297{
298	struct pm8xxx_mpp *pctrl = pinctrl_dev_get_drvdata(pctldev);
299
300	*groups = pm8xxx_groups;
301	*num_groups = pctrl->npins;
302	return 0;
303}
304
305static int pm8xxx_pinmux_set_mux(struct pinctrl_dev *pctldev,
306				 unsigned function,
307				 unsigned group)
308{
309	struct pm8xxx_mpp *pctrl = pinctrl_dev_get_drvdata(pctldev);
310	struct pm8xxx_pin_data *pin = pctrl->desc.pins[group].drv_data;
311
312	pin->mode = function;
313	pm8xxx_mpp_update(pctrl, pin);
314
315	return 0;
316}
317
318static const struct pinmux_ops pm8xxx_pinmux_ops = {
319	.get_functions_count	= pm8xxx_get_functions_count,
320	.get_function_name	= pm8xxx_get_function_name,
321	.get_function_groups	= pm8xxx_get_function_groups,
322	.set_mux		= pm8xxx_pinmux_set_mux,
323};
324
325static int pm8xxx_pin_config_get(struct pinctrl_dev *pctldev,
326				 unsigned int offset,
327				 unsigned long *config)
328{
329	struct pm8xxx_mpp *pctrl = pinctrl_dev_get_drvdata(pctldev);
330	struct pm8xxx_pin_data *pin = pctrl->desc.pins[offset].drv_data;
331	unsigned param = pinconf_to_config_param(*config);
332	unsigned arg;
333
334	switch (param) {
335	case PIN_CONFIG_BIAS_PULL_UP:
336		arg = pin->pullup;
337		break;
338	case PIN_CONFIG_BIAS_HIGH_IMPEDANCE:
339		arg = pin->high_z;
340		break;
341	case PIN_CONFIG_INPUT_ENABLE:
342		arg = pin->input;
343		break;
344	case PIN_CONFIG_OUTPUT:
345		arg = pin->output_value;
346		break;
347	case PIN_CONFIG_POWER_SOURCE:
348		arg = pin->power_source;
349		break;
350	case PIN_CONFIG_DRIVE_STRENGTH:
351		arg = pin->drive_strength;
352		break;
353	case PM8XXX_CONFIG_DTEST_SELECTOR:
354		arg = pin->dtest;
355		break;
356	case PM8XXX_CONFIG_AMUX:
357		arg = pin->amux;
358		break;
359	case PM8XXX_CONFIG_ALEVEL:
360		arg = pin->aout_level;
361		break;
362	case PM8XXX_CONFIG_PAIRED:
363		arg = pin->paired;
364		break;
365	default:
366		return -EINVAL;
367	}
368
369	*config = pinconf_to_config_packed(param, arg);
370
371	return 0;
372}
373
374static int pm8xxx_pin_config_set(struct pinctrl_dev *pctldev,
375				 unsigned int offset,
376				 unsigned long *configs,
377				 unsigned num_configs)
378{
379	struct pm8xxx_mpp *pctrl = pinctrl_dev_get_drvdata(pctldev);
380	struct pm8xxx_pin_data *pin = pctrl->desc.pins[offset].drv_data;
381	unsigned param;
382	unsigned arg;
383	unsigned i;
384
385	for (i = 0; i < num_configs; i++) {
386		param = pinconf_to_config_param(configs[i]);
387		arg = pinconf_to_config_argument(configs[i]);
388
389		switch (param) {
390		case PIN_CONFIG_BIAS_PULL_UP:
391			pin->pullup = arg;
392			break;
393		case PIN_CONFIG_BIAS_HIGH_IMPEDANCE:
394			pin->high_z = true;
395			break;
396		case PIN_CONFIG_INPUT_ENABLE:
397			pin->input = true;
398			break;
399		case PIN_CONFIG_OUTPUT:
400			pin->output = true;
401			pin->output_value = !!arg;
402			break;
403		case PIN_CONFIG_POWER_SOURCE:
404			pin->power_source = arg;
405			break;
406		case PIN_CONFIG_DRIVE_STRENGTH:
407			pin->drive_strength = arg;
408			break;
409		case PM8XXX_CONFIG_DTEST_SELECTOR:
410			pin->dtest = arg;
411			break;
412		case PM8XXX_CONFIG_AMUX:
413			pin->amux = arg;
414			break;
415		case PM8XXX_CONFIG_ALEVEL:
416			pin->aout_level = arg;
417			break;
418		case PM8XXX_CONFIG_PAIRED:
419			pin->paired = !!arg;
420			break;
421		default:
422			dev_err(pctrl->dev,
423				"unsupported config parameter: %x\n",
424				param);
425			return -EINVAL;
426		}
427	}
428
429	pm8xxx_mpp_update(pctrl, pin);
430
431	return 0;
432}
433
434static const struct pinconf_ops pm8xxx_pinconf_ops = {
435	.is_generic = true,
436	.pin_config_group_get = pm8xxx_pin_config_get,
437	.pin_config_group_set = pm8xxx_pin_config_set,
438};
439
440static struct pinctrl_desc pm8xxx_pinctrl_desc = {
441	.name = "pm8xxx_mpp",
442	.pctlops = &pm8xxx_pinctrl_ops,
443	.pmxops = &pm8xxx_pinmux_ops,
444	.confops = &pm8xxx_pinconf_ops,
445	.owner = THIS_MODULE,
446};
447
448static int pm8xxx_mpp_direction_input(struct gpio_chip *chip,
449				       unsigned offset)
450{
451	struct pm8xxx_mpp *pctrl = container_of(chip, struct pm8xxx_mpp, chip);
452	struct pm8xxx_pin_data *pin = pctrl->desc.pins[offset].drv_data;
453
454	switch (pin->mode) {
455	case PM8XXX_MPP_DIGITAL:
456		pin->input = true;
457		break;
458	case PM8XXX_MPP_ANALOG:
459		pin->input = true;
460		pin->output = true;
461		break;
462	case PM8XXX_MPP_SINK:
463		return -EINVAL;
464	}
465
466	pm8xxx_mpp_update(pctrl, pin);
467
468	return 0;
469}
470
471static int pm8xxx_mpp_direction_output(struct gpio_chip *chip,
472					unsigned offset,
473					int value)
474{
475	struct pm8xxx_mpp *pctrl = container_of(chip, struct pm8xxx_mpp, chip);
476	struct pm8xxx_pin_data *pin = pctrl->desc.pins[offset].drv_data;
477
478	switch (pin->mode) {
479	case PM8XXX_MPP_DIGITAL:
480		pin->output = true;
481		break;
482	case PM8XXX_MPP_ANALOG:
483		pin->input = false;
484		pin->output = true;
485		break;
486	case PM8XXX_MPP_SINK:
487		pin->input = false;
488		pin->output = true;
489		break;
490	}
491
492	pm8xxx_mpp_update(pctrl, pin);
493
494	return 0;
495}
496
497static int pm8xxx_mpp_get(struct gpio_chip *chip, unsigned offset)
498{
499	struct pm8xxx_mpp *pctrl = container_of(chip, struct pm8xxx_mpp, chip);
500	struct pm8xxx_pin_data *pin = pctrl->desc.pins[offset].drv_data;
501	bool state;
502	int ret;
503
504	if (!pin->input)
505		return pin->output_value;
506
507	ret = irq_get_irqchip_state(pin->irq, IRQCHIP_STATE_LINE_LEVEL, &state);
508	if (!ret)
509		ret = !!state;
510
511	return ret;
512}
513
514static void pm8xxx_mpp_set(struct gpio_chip *chip, unsigned offset, int value)
515{
516	struct pm8xxx_mpp *pctrl = container_of(chip, struct pm8xxx_mpp, chip);
517	struct pm8xxx_pin_data *pin = pctrl->desc.pins[offset].drv_data;
518
519	pin->output_value = !!value;
520
521	pm8xxx_mpp_update(pctrl, pin);
522}
523
524static int pm8xxx_mpp_of_xlate(struct gpio_chip *chip,
525				const struct of_phandle_args *gpio_desc,
526				u32 *flags)
527{
528	if (chip->of_gpio_n_cells < 2)
529		return -EINVAL;
530
531	if (flags)
532		*flags = gpio_desc->args[1];
533
534	return gpio_desc->args[0] - 1;
535}
536
537
538static int pm8xxx_mpp_to_irq(struct gpio_chip *chip, unsigned offset)
539{
540	struct pm8xxx_mpp *pctrl = container_of(chip, struct pm8xxx_mpp, chip);
541	struct pm8xxx_pin_data *pin = pctrl->desc.pins[offset].drv_data;
542
543	return pin->irq;
544}
545
546#ifdef CONFIG_DEBUG_FS
547#include <linux/seq_file.h>
548
549static void pm8xxx_mpp_dbg_show_one(struct seq_file *s,
550				  struct pinctrl_dev *pctldev,
551				  struct gpio_chip *chip,
552				  unsigned offset,
553				  unsigned gpio)
554{
555	struct pm8xxx_mpp *pctrl = container_of(chip, struct pm8xxx_mpp, chip);
556	struct pm8xxx_pin_data *pin = pctrl->desc.pins[offset].drv_data;
557
558	static const char * const aout_lvls[] = {
559		"1v25", "1v25_2", "0v625", "0v3125", "mpp", "abus1", "abus2",
560		"abus3"
561	};
562
563	static const char * const amuxs[] = {
564		"amux5", "amux6", "amux7", "amux8", "amux9", "abus1", "abus2",
565		"abus3",
566	};
567
568	seq_printf(s, " mpp%-2d:", offset + 1);
569
570	switch (pin->mode) {
571	case PM8XXX_MPP_DIGITAL:
572		seq_puts(s, " digital ");
573		if (pin->dtest) {
574			seq_printf(s, "dtest%d\n", pin->dtest);
575		} else if (pin->input && pin->output) {
576			if (pin->high_z)
577				seq_puts(s, "bi-dir high-z");
578			else
579				seq_printf(s, "bi-dir %dOhm", pin->pullup);
580		} else if (pin->input) {
581			if (pin->dtest)
582				seq_printf(s, "in dtest%d", pin->dtest);
583			else
584				seq_puts(s, "in gpio");
585		} else if (pin->output) {
586			seq_puts(s, "out ");
587
588			if (!pin->paired) {
589				seq_puts(s, pin->output_value ?
590					 "high" : "low");
591			} else {
592				seq_puts(s, pin->output_value ?
593					 "inverted" : "follow");
594			}
595		}
596		break;
597	case PM8XXX_MPP_ANALOG:
598		seq_puts(s, " analog ");
599		if (pin->output) {
600			seq_printf(s, "out %s ", aout_lvls[pin->aout_level]);
601			if (!pin->paired) {
602				seq_puts(s, pin->output_value ?
603					 "high" : "low");
604			} else {
605				seq_puts(s, pin->output_value ?
606					 "inverted" : "follow");
607			}
608		} else {
609			seq_printf(s, "input mux %s", amuxs[pin->amux]);
610		}
611		break;
612	case PM8XXX_MPP_SINK:
613		seq_printf(s, " sink %dmA ", pin->drive_strength);
614		if (pin->dtest) {
615			seq_printf(s, "dtest%d", pin->dtest);
616		} else {
617			if (!pin->paired) {
618				seq_puts(s, pin->output_value ?
619					 "high" : "low");
620			} else {
621				seq_puts(s, pin->output_value ?
622					 "inverted" : "follow");
623			}
624		}
625		break;
626	}
627
628}
629
630static void pm8xxx_mpp_dbg_show(struct seq_file *s, struct gpio_chip *chip)
631{
632	unsigned gpio = chip->base;
633	unsigned i;
634
635	for (i = 0; i < chip->ngpio; i++, gpio++) {
636		pm8xxx_mpp_dbg_show_one(s, NULL, chip, i, gpio);
637		seq_puts(s, "\n");
638	}
639}
640
641#else
642#define pm8xxx_mpp_dbg_show NULL
643#endif
644
645static struct gpio_chip pm8xxx_mpp_template = {
646	.direction_input = pm8xxx_mpp_direction_input,
647	.direction_output = pm8xxx_mpp_direction_output,
648	.get = pm8xxx_mpp_get,
649	.set = pm8xxx_mpp_set,
650	.of_xlate = pm8xxx_mpp_of_xlate,
651	.to_irq = pm8xxx_mpp_to_irq,
652	.dbg_show = pm8xxx_mpp_dbg_show,
653	.owner = THIS_MODULE,
654};
655
656static int pm8xxx_pin_populate(struct pm8xxx_mpp *pctrl,
657			       struct pm8xxx_pin_data *pin)
658{
659	unsigned int val;
660	unsigned level;
661	unsigned ctrl;
662	unsigned type;
663	int ret;
664
665	ret = regmap_read(pctrl->regmap, pin->reg, &val);
666	if (ret) {
667		dev_err(pctrl->dev, "failed to read register\n");
668		return ret;
669	}
670
671	type = (val >> 5) & 7;
672	level = (val >> 2) & 7;
673	ctrl = (val) & 3;
674
675	switch (type) {
676	case PM8XXX_MPP_TYPE_D_INPUT:
677		pin->mode = PM8XXX_MPP_DIGITAL;
678		pin->input = true;
679		pin->power_source = level;
680		pin->dtest = ctrl;
681		break;
682	case PM8XXX_MPP_TYPE_D_OUTPUT:
683		pin->mode = PM8XXX_MPP_DIGITAL;
684		pin->output = true;
685		pin->power_source = level;
686		pin->output_value = !!(ctrl & BIT(0));
687		pin->paired = !!(ctrl & BIT(1));
688		break;
689	case PM8XXX_MPP_TYPE_D_BI_DIR:
690		pin->mode = PM8XXX_MPP_DIGITAL;
691		pin->input = true;
692		pin->output = true;
693		pin->power_source = level;
694		switch (ctrl) {
695		case PM8XXX_MPP_BI_PULLUP_1KOHM:
696			pin->pullup = 600;
697			break;
698		case PM8XXX_MPP_BI_PULLUP_OPEN:
699			pin->high_z = true;
700			break;
701		case PM8XXX_MPP_BI_PULLUP_10KOHM:
702			pin->pullup = 10000;
703			break;
704		case PM8XXX_MPP_BI_PULLUP_30KOHM:
705			pin->pullup = 30000;
706			break;
707		}
708		break;
709	case PM8XXX_MPP_TYPE_A_INPUT:
710		pin->mode = PM8XXX_MPP_ANALOG;
711		pin->input = true;
712		pin->amux = level;
713		break;
714	case PM8XXX_MPP_TYPE_A_OUTPUT:
715		pin->mode = PM8XXX_MPP_ANALOG;
716		pin->output = true;
717		pin->aout_level = level;
718		pin->output_value = !!(ctrl & BIT(0));
719		pin->paired = !!(ctrl & BIT(1));
720		break;
721	case PM8XXX_MPP_TYPE_SINK:
722		pin->mode = PM8XXX_MPP_SINK;
723		pin->drive_strength = 5 * (level + 1);
724		pin->output_value = !!(ctrl & BIT(0));
725		pin->paired = !!(ctrl & BIT(1));
726		break;
727	case PM8XXX_MPP_TYPE_DTEST_SINK:
728		pin->mode = PM8XXX_MPP_SINK;
729		pin->dtest = ctrl + 1;
730		pin->drive_strength = 5 * (level + 1);
731		break;
732	case PM8XXX_MPP_TYPE_DTEST_OUTPUT:
733		pin->mode = PM8XXX_MPP_DIGITAL;
734		pin->power_source = level;
735		if (ctrl >= 1)
736			pin->dtest = ctrl;
737		break;
738	}
739
740	return 0;
741}
742
743static const struct of_device_id pm8xxx_mpp_of_match[] = {
744	{ .compatible = "qcom,pm8018-mpp", .data = (void *)6 },
745	{ .compatible = "qcom,pm8038-mpp", .data = (void *)6 },
746	{ .compatible = "qcom,pm8917-mpp", .data = (void *)10 },
747	{ .compatible = "qcom,pm8821-mpp", .data = (void *)4 },
748	{ .compatible = "qcom,pm8921-mpp", .data = (void *)12 },
749	{ },
750};
751MODULE_DEVICE_TABLE(of, pm8xxx_mpp_of_match);
752
753static int pm8xxx_mpp_probe(struct platform_device *pdev)
754{
755	struct pm8xxx_pin_data *pin_data;
756	struct pinctrl_pin_desc *pins;
757	struct pm8xxx_mpp *pctrl;
758	int ret;
759	int i;
760
761	pctrl = devm_kzalloc(&pdev->dev, sizeof(*pctrl), GFP_KERNEL);
762	if (!pctrl)
763		return -ENOMEM;
764
765	pctrl->dev = &pdev->dev;
766	pctrl->npins = (unsigned long)of_device_get_match_data(&pdev->dev);
767
768	pctrl->regmap = dev_get_regmap(pdev->dev.parent, NULL);
769	if (!pctrl->regmap) {
770		dev_err(&pdev->dev, "parent regmap unavailable\n");
771		return -ENXIO;
772	}
773
774	pctrl->desc = pm8xxx_pinctrl_desc;
775	pctrl->desc.npins = pctrl->npins;
776
777	pins = devm_kcalloc(&pdev->dev,
778			    pctrl->desc.npins,
779			    sizeof(struct pinctrl_pin_desc),
780			    GFP_KERNEL);
781	if (!pins)
782		return -ENOMEM;
783
784	pin_data = devm_kcalloc(&pdev->dev,
785				pctrl->desc.npins,
786				sizeof(struct pm8xxx_pin_data),
787				GFP_KERNEL);
788	if (!pin_data)
789		return -ENOMEM;
790
791	for (i = 0; i < pctrl->desc.npins; i++) {
792		pin_data[i].reg = SSBI_REG_ADDR_MPP(i);
793		pin_data[i].irq = platform_get_irq(pdev, i);
794		if (pin_data[i].irq < 0) {
795			dev_err(&pdev->dev,
796				"missing interrupts for pin %d\n", i);
797			return pin_data[i].irq;
798		}
799
800		ret = pm8xxx_pin_populate(pctrl, &pin_data[i]);
801		if (ret)
802			return ret;
803
804		pins[i].number = i;
805		pins[i].name = pm8xxx_groups[i];
806		pins[i].drv_data = &pin_data[i];
807	}
808	pctrl->desc.pins = pins;
809
810	pctrl->desc.num_custom_params = ARRAY_SIZE(pm8xxx_mpp_bindings);
811	pctrl->desc.custom_params = pm8xxx_mpp_bindings;
812#ifdef CONFIG_DEBUG_FS
813	pctrl->desc.custom_conf_items = pm8xxx_conf_items;
814#endif
815
816	pctrl->pctrl = pinctrl_register(&pctrl->desc, &pdev->dev, pctrl);
817	if (IS_ERR(pctrl->pctrl)) {
818		dev_err(&pdev->dev, "couldn't register pm8xxx mpp driver\n");
819		return PTR_ERR(pctrl->pctrl);
820	}
821
822	pctrl->chip = pm8xxx_mpp_template;
823	pctrl->chip.base = -1;
824	pctrl->chip.dev = &pdev->dev;
825	pctrl->chip.of_node = pdev->dev.of_node;
826	pctrl->chip.of_gpio_n_cells = 2;
827	pctrl->chip.label = dev_name(pctrl->dev);
828	pctrl->chip.ngpio = pctrl->npins;
829	ret = gpiochip_add(&pctrl->chip);
830	if (ret) {
831		dev_err(&pdev->dev, "failed register gpiochip\n");
832		goto unregister_pinctrl;
833	}
834
835	ret = gpiochip_add_pin_range(&pctrl->chip,
836				     dev_name(pctrl->dev),
837				     0, 0, pctrl->chip.ngpio);
838	if (ret) {
839		dev_err(pctrl->dev, "failed to add pin range\n");
840		goto unregister_gpiochip;
841	}
842
843	platform_set_drvdata(pdev, pctrl);
844
845	dev_dbg(&pdev->dev, "Qualcomm pm8xxx mpp driver probed\n");
846
847	return 0;
848
849unregister_gpiochip:
850	gpiochip_remove(&pctrl->chip);
851
852unregister_pinctrl:
853	pinctrl_unregister(pctrl->pctrl);
854
855	return ret;
856}
857
858static int pm8xxx_mpp_remove(struct platform_device *pdev)
859{
860	struct pm8xxx_mpp *pctrl = platform_get_drvdata(pdev);
861
862	gpiochip_remove(&pctrl->chip);
863
864	pinctrl_unregister(pctrl->pctrl);
865
866	return 0;
867}
868
869static struct platform_driver pm8xxx_mpp_driver = {
870	.driver = {
871		.name = "qcom-ssbi-mpp",
872		.of_match_table = pm8xxx_mpp_of_match,
873	},
874	.probe = pm8xxx_mpp_probe,
875	.remove = pm8xxx_mpp_remove,
876};
877
878module_platform_driver(pm8xxx_mpp_driver);
879
880MODULE_AUTHOR("Bjorn Andersson <bjorn.andersson@sonymobile.com>");
881MODULE_DESCRIPTION("Qualcomm PM8xxx MPP driver");
882MODULE_LICENSE("GPL v2");
883