Linux Audio

Check our new training course

Loading...
v6.13.7
   1/*
   2 * Generic device tree based pinctrl driver for one register per pin
   3 * type pinmux controllers
   4 *
   5 * Copyright (C) 2012 Texas Instruments, Inc.
   6 *
   7 * This file is licensed under the terms of the GNU General Public
   8 * License version 2. This program is licensed "as is" without any
   9 * warranty of any kind, whether express or implied.
  10 */
  11
  12#include <linux/init.h>
  13#include <linux/module.h>
  14#include <linux/io.h>
  15#include <linux/platform_device.h>
  16#include <linux/slab.h>
  17#include <linux/err.h>
  18#include <linux/list.h>
  19#include <linux/interrupt.h>
 
  20#include <linux/irqchip/chained_irq.h>
 
  21#include <linux/of.h>
 
 
  22#include <linux/of_irq.h>
  23#include <linux/seq_file.h>
  24
  25#include <linux/pinctrl/pinconf-generic.h>
  26#include <linux/pinctrl/pinconf.h>
  27#include <linux/pinctrl/pinctrl.h>
  28#include <linux/pinctrl/pinmux.h>
 
  29
  30#include <linux/platform_data/pinctrl-single.h>
  31
  32#include "core.h"
  33#include "devicetree.h"
  34#include "pinconf.h"
  35#include "pinmux.h"
  36
  37#define DRIVER_NAME			"pinctrl-single"
  38#define PCS_OFF_DISABLED		~0U
  39
  40/**
  41 * struct pcs_func_vals - mux function register offset and value pair
  42 * @reg:	register virtual address
  43 * @val:	register value
  44 * @mask:	mask
  45 */
  46struct pcs_func_vals {
  47	void __iomem *reg;
  48	unsigned val;
  49	unsigned mask;
  50};
  51
  52/**
  53 * struct pcs_conf_vals - pinconf parameter, pinconf register offset
  54 * and value, enable, disable, mask
  55 * @param:	config parameter
  56 * @val:	user input bits in the pinconf register
  57 * @enable:	enable bits in the pinconf register
  58 * @disable:	disable bits in the pinconf register
  59 * @mask:	mask bits in the register value
  60 */
  61struct pcs_conf_vals {
  62	enum pin_config_param param;
  63	unsigned val;
  64	unsigned enable;
  65	unsigned disable;
  66	unsigned mask;
  67};
  68
  69/**
  70 * struct pcs_conf_type - pinconf property name, pinconf param pair
  71 * @name:	property name in DTS file
  72 * @param:	config parameter
  73 */
  74struct pcs_conf_type {
  75	const char *name;
  76	enum pin_config_param param;
  77};
  78
  79/**
  80 * struct pcs_function - pinctrl function
  81 * @name:	pinctrl function name
  82 * @vals:	register and vals array
  83 * @nvals:	number of entries in vals array
  84 * @conf:	array of pin configurations
  85 * @nconfs:	number of pin configurations available
  86 * @node:	list node
  87 */
  88struct pcs_function {
  89	const char *name;
  90	struct pcs_func_vals *vals;
  91	unsigned nvals;
 
 
  92	struct pcs_conf_vals *conf;
  93	int nconfs;
  94	struct list_head node;
  95};
  96
  97/**
  98 * struct pcs_gpiofunc_range - pin ranges with same mux value of gpio function
  99 * @offset:	offset base of pins
 100 * @npins:	number pins with the same mux value of gpio function
 101 * @gpiofunc:	mux value of gpio function
 102 * @node:	list node
 103 */
 104struct pcs_gpiofunc_range {
 105	unsigned offset;
 106	unsigned npins;
 107	unsigned gpiofunc;
 108	struct list_head node;
 109};
 110
 111/**
 112 * struct pcs_data - wrapper for data needed by pinctrl framework
 113 * @pa:		pindesc array
 114 * @cur:	index to current element
 115 *
 116 * REVISIT: We should be able to drop this eventually by adding
 117 * support for registering pins individually in the pinctrl
 118 * framework for those drivers that don't need a static array.
 119 */
 120struct pcs_data {
 121	struct pinctrl_pin_desc *pa;
 122	int cur;
 123};
 124
 125/**
 126 * struct pcs_soc_data - SoC specific settings
 127 * @flags:	initial SoC specific PCS_FEAT_xxx values
 128 * @irq:	optional interrupt for the controller
 129 * @irq_enable_mask:	optional SoC specific interrupt enable mask
 130 * @irq_status_mask:	optional SoC specific interrupt status mask
 131 * @rearm:	optional SoC specific wake-up rearm function
 132 */
 133struct pcs_soc_data {
 134	unsigned flags;
 135	int irq;
 136	unsigned irq_enable_mask;
 137	unsigned irq_status_mask;
 138	void (*rearm)(void);
 139};
 140
 141/**
 142 * struct pcs_device - pinctrl device instance
 143 * @res:	resources
 144 * @base:	virtual address of the controller
 145 * @saved_vals: saved values for the controller
 146 * @size:	size of the ioremapped area
 147 * @dev:	device entry
 148 * @np:		device tree node
 149 * @pctl:	pin controller device
 150 * @flags:	mask of PCS_FEAT_xxx values
 151 * @missing_nr_pinctrl_cells: for legacy binding, may go away
 152 * @socdata:	soc specific data
 153 * @lock:	spinlock for register access
 154 * @mutex:	mutex protecting the lists
 155 * @width:	bits per mux register
 156 * @fmask:	function register mask
 157 * @fshift:	function register shift
 158 * @foff:	value to turn mux off
 159 * @fmax:	max number of functions in fmask
 160 * @bits_per_mux: number of bits per mux
 161 * @bits_per_pin: number of bits per pin
 162 * @pins:	physical pins on the SoC
 163 * @gpiofuncs:	list of gpio functions
 164 * @irqs:	list of interrupt registers
 165 * @chip:	chip container for this instance
 166 * @domain:	IRQ domain for this instance
 167 * @desc:	pin controller descriptor
 168 * @read:	register read function to use
 169 * @write:	register write function to use
 170 */
 171struct pcs_device {
 172	struct resource *res;
 173	void __iomem *base;
 174	void *saved_vals;
 175	unsigned size;
 176	struct device *dev;
 177	struct device_node *np;
 178	struct pinctrl_dev *pctl;
 179	unsigned flags;
 180#define PCS_CONTEXT_LOSS_OFF	(1 << 3)
 181#define PCS_QUIRK_SHARED_IRQ	(1 << 2)
 182#define PCS_FEAT_IRQ		(1 << 1)
 183#define PCS_FEAT_PINCONF	(1 << 0)
 184	struct property *missing_nr_pinctrl_cells;
 185	struct pcs_soc_data socdata;
 186	raw_spinlock_t lock;
 187	struct mutex mutex;
 188	unsigned width;
 189	unsigned fmask;
 190	unsigned fshift;
 191	unsigned foff;
 192	unsigned fmax;
 193	bool bits_per_mux;
 194	unsigned bits_per_pin;
 195	struct pcs_data pins;
 196	struct list_head gpiofuncs;
 197	struct list_head irqs;
 198	struct irq_chip chip;
 199	struct irq_domain *domain;
 200	struct pinctrl_desc desc;
 201	unsigned (*read)(void __iomem *reg);
 202	void (*write)(unsigned val, void __iomem *reg);
 203};
 204
 205#define PCS_QUIRK_HAS_SHARED_IRQ	(pcs->flags & PCS_QUIRK_SHARED_IRQ)
 206#define PCS_HAS_IRQ		(pcs->flags & PCS_FEAT_IRQ)
 207#define PCS_HAS_PINCONF		(pcs->flags & PCS_FEAT_PINCONF)
 208
 209static int pcs_pinconf_get(struct pinctrl_dev *pctldev, unsigned pin,
 210			   unsigned long *config);
 211static int pcs_pinconf_set(struct pinctrl_dev *pctldev, unsigned pin,
 212			   unsigned long *configs, unsigned num_configs);
 213
 214static enum pin_config_param pcs_bias[] = {
 215	PIN_CONFIG_BIAS_PULL_DOWN,
 216	PIN_CONFIG_BIAS_PULL_UP,
 217};
 218
 219/*
 220 * This lock class tells lockdep that irqchip core that this single
 221 * pinctrl can be in a different category than its parents, so it won't
 222 * report false recursion.
 223 */
 224static struct lock_class_key pcs_lock_class;
 225
 226/* Class for the IRQ request mutex */
 227static struct lock_class_key pcs_request_class;
 228
 229/*
 230 * REVISIT: Reads and writes could eventually use regmap or something
 231 * generic. But at least on omaps, some mux registers are performance
 232 * critical as they may need to be remuxed every time before and after
 233 * idle. Adding tests for register access width for every read and
 234 * write like regmap is doing is not desired, and caching the registers
 235 * does not help in this case.
 236 */
 237
 238static unsigned int pcs_readb(void __iomem *reg)
 239{
 240	return readb(reg);
 241}
 242
 243static unsigned int pcs_readw(void __iomem *reg)
 244{
 245	return readw(reg);
 246}
 247
 248static unsigned int pcs_readl(void __iomem *reg)
 249{
 250	return readl(reg);
 251}
 252
 253static void pcs_writeb(unsigned int val, void __iomem *reg)
 254{
 255	writeb(val, reg);
 256}
 257
 258static void pcs_writew(unsigned int val, void __iomem *reg)
 259{
 260	writew(val, reg);
 261}
 262
 263static void pcs_writel(unsigned int val, void __iomem *reg)
 264{
 265	writel(val, reg);
 266}
 267
 268static unsigned int pcs_pin_reg_offset_get(struct pcs_device *pcs,
 269					   unsigned int pin)
 270{
 271	unsigned int mux_bytes = pcs->width / BITS_PER_BYTE;
 272
 273	if (pcs->bits_per_mux) {
 274		unsigned int pin_offset_bytes;
 275
 276		pin_offset_bytes = (pcs->bits_per_pin * pin) / BITS_PER_BYTE;
 277		return (pin_offset_bytes / mux_bytes) * mux_bytes;
 278	}
 279
 280	return pin * mux_bytes;
 281}
 282
 283static unsigned int pcs_pin_shift_reg_get(struct pcs_device *pcs,
 284					  unsigned int pin)
 285{
 286	return (pin % (pcs->width / pcs->bits_per_pin)) * pcs->bits_per_pin;
 287}
 288
 289static void pcs_pin_dbg_show(struct pinctrl_dev *pctldev,
 290					struct seq_file *s,
 291					unsigned pin)
 292{
 293	struct pcs_device *pcs;
 294	unsigned int val;
 295	unsigned long offset;
 296	size_t pa;
 297
 298	pcs = pinctrl_dev_get_drvdata(pctldev);
 299
 300	offset = pcs_pin_reg_offset_get(pcs, pin);
 
 301	val = pcs->read(pcs->base + offset);
 302
 303	if (pcs->bits_per_mux)
 304		val &= pcs->fmask << pcs_pin_shift_reg_get(pcs, pin);
 305
 306	pa = pcs->res->start + offset;
 307
 308	seq_printf(s, "%zx %08x %s ", pa, val, DRIVER_NAME);
 309}
 310
 311static void pcs_dt_free_map(struct pinctrl_dev *pctldev,
 312				struct pinctrl_map *map, unsigned num_maps)
 313{
 314	struct pcs_device *pcs;
 315
 316	pcs = pinctrl_dev_get_drvdata(pctldev);
 317	devm_kfree(pcs->dev, map);
 318}
 319
 320static int pcs_dt_node_to_map(struct pinctrl_dev *pctldev,
 321				struct device_node *np_config,
 322				struct pinctrl_map **map, unsigned *num_maps);
 323
 324static const struct pinctrl_ops pcs_pinctrl_ops = {
 325	.get_groups_count = pinctrl_generic_get_group_count,
 326	.get_group_name = pinctrl_generic_get_group_name,
 327	.get_group_pins = pinctrl_generic_get_group_pins,
 328	.pin_dbg_show = pcs_pin_dbg_show,
 329	.dt_node_to_map = pcs_dt_node_to_map,
 330	.dt_free_map = pcs_dt_free_map,
 331};
 332
 333static int pcs_get_function(struct pinctrl_dev *pctldev, unsigned pin,
 334			    struct pcs_function **func)
 335{
 336	struct pcs_device *pcs = pinctrl_dev_get_drvdata(pctldev);
 337	struct pin_desc *pdesc = pin_desc_get(pctldev, pin);
 338	const struct pinctrl_setting_mux *setting;
 339	struct function_desc *function;
 340	unsigned fselector;
 341
 342	/* If pin is not described in DTS & enabled, mux_setting is NULL. */
 343	setting = pdesc->mux_setting;
 344	if (!setting)
 345		return -ENOTSUPP;
 346	fselector = setting->func;
 347	function = pinmux_generic_get_function(pctldev, fselector);
 348	if (!function)
 349		return -EINVAL;
 350	*func = function->data;
 351	if (!(*func)) {
 352		dev_err(pcs->dev, "%s could not find function%i\n",
 353			__func__, fselector);
 354		return -ENOTSUPP;
 355	}
 356	return 0;
 357}
 358
 359static int pcs_set_mux(struct pinctrl_dev *pctldev, unsigned fselector,
 360	unsigned group)
 361{
 362	struct pcs_device *pcs;
 363	struct function_desc *function;
 364	struct pcs_function *func;
 365	int i;
 366
 367	pcs = pinctrl_dev_get_drvdata(pctldev);
 368	/* If function mask is null, needn't enable it. */
 369	if (!pcs->fmask)
 370		return 0;
 371	function = pinmux_generic_get_function(pctldev, fselector);
 372	if (!function)
 373		return -EINVAL;
 374	func = function->data;
 375	if (!func)
 376		return -EINVAL;
 377
 378	dev_dbg(pcs->dev, "enabling %s function%i\n",
 379		func->name, fselector);
 380
 381	for (i = 0; i < func->nvals; i++) {
 382		struct pcs_func_vals *vals;
 383		unsigned long flags;
 384		unsigned val, mask;
 385
 386		vals = &func->vals[i];
 387		raw_spin_lock_irqsave(&pcs->lock, flags);
 388		val = pcs->read(vals->reg);
 389
 390		if (pcs->bits_per_mux)
 391			mask = vals->mask;
 392		else
 393			mask = pcs->fmask;
 394
 395		val &= ~mask;
 396		val |= (vals->val & mask);
 397		pcs->write(val, vals->reg);
 398		raw_spin_unlock_irqrestore(&pcs->lock, flags);
 399	}
 400
 401	return 0;
 402}
 403
 404static int pcs_request_gpio(struct pinctrl_dev *pctldev,
 405			    struct pinctrl_gpio_range *range, unsigned pin)
 406{
 407	struct pcs_device *pcs = pinctrl_dev_get_drvdata(pctldev);
 408	struct pcs_gpiofunc_range *frange = NULL;
 409	struct list_head *pos, *tmp;
 
 410	unsigned data;
 411
 412	/* If function mask is null, return directly. */
 413	if (!pcs->fmask)
 414		return -ENOTSUPP;
 415
 416	list_for_each_safe(pos, tmp, &pcs->gpiofuncs) {
 417		u32 offset;
 418
 419		frange = list_entry(pos, struct pcs_gpiofunc_range, node);
 420		if (pin >= frange->offset + frange->npins
 421			|| pin < frange->offset)
 422			continue;
 423
 424		offset = pcs_pin_reg_offset_get(pcs, pin);
 425
 426		if (pcs->bits_per_mux) {
 427			int pin_shift = pcs_pin_shift_reg_get(pcs, pin);
 
 
 
 
 
 428
 429			data = pcs->read(pcs->base + offset);
 430			data &= ~(pcs->fmask << pin_shift);
 431			data |= frange->gpiofunc << pin_shift;
 432			pcs->write(data, pcs->base + offset);
 433		} else {
 434			data = pcs->read(pcs->base + offset);
 435			data &= ~pcs->fmask;
 436			data |= frange->gpiofunc;
 437			pcs->write(data, pcs->base + offset);
 438		}
 439		break;
 440	}
 441	return 0;
 442}
 443
 444static const struct pinmux_ops pcs_pinmux_ops = {
 445	.get_functions_count = pinmux_generic_get_function_count,
 446	.get_function_name = pinmux_generic_get_function_name,
 447	.get_function_groups = pinmux_generic_get_function_groups,
 448	.set_mux = pcs_set_mux,
 449	.gpio_request_enable = pcs_request_gpio,
 450};
 451
 452/* Clear BIAS value */
 453static void pcs_pinconf_clear_bias(struct pinctrl_dev *pctldev, unsigned pin)
 454{
 455	unsigned long config;
 456	int i;
 457	for (i = 0; i < ARRAY_SIZE(pcs_bias); i++) {
 458		config = pinconf_to_config_packed(pcs_bias[i], 0);
 459		pcs_pinconf_set(pctldev, pin, &config, 1);
 460	}
 461}
 462
 463/*
 464 * Check whether PIN_CONFIG_BIAS_DISABLE is valid.
 465 * It's depend on that PULL_DOWN & PULL_UP configs are all invalid.
 466 */
 467static bool pcs_pinconf_bias_disable(struct pinctrl_dev *pctldev, unsigned pin)
 468{
 469	unsigned long config;
 470	int i;
 471
 472	for (i = 0; i < ARRAY_SIZE(pcs_bias); i++) {
 473		config = pinconf_to_config_packed(pcs_bias[i], 0);
 474		if (!pcs_pinconf_get(pctldev, pin, &config))
 475			goto out;
 476	}
 477	return true;
 478out:
 479	return false;
 480}
 481
 482static int pcs_pinconf_get(struct pinctrl_dev *pctldev,
 483				unsigned pin, unsigned long *config)
 484{
 485	struct pcs_device *pcs = pinctrl_dev_get_drvdata(pctldev);
 486	struct pcs_function *func;
 487	enum pin_config_param param;
 488	unsigned offset = 0, data = 0, i, j, ret;
 489
 490	ret = pcs_get_function(pctldev, pin, &func);
 491	if (ret)
 492		return ret;
 493
 494	for (i = 0; i < func->nconfs; i++) {
 495		param = pinconf_to_config_param(*config);
 496		if (param == PIN_CONFIG_BIAS_DISABLE) {
 497			if (pcs_pinconf_bias_disable(pctldev, pin)) {
 498				*config = 0;
 499				return 0;
 500			} else {
 501				return -ENOTSUPP;
 502			}
 503		} else if (param != func->conf[i].param) {
 504			continue;
 505		}
 506
 507		offset = pin * (pcs->width / BITS_PER_BYTE);
 508		data = pcs->read(pcs->base + offset) & func->conf[i].mask;
 509		switch (func->conf[i].param) {
 510		/* 4 parameters */
 511		case PIN_CONFIG_BIAS_PULL_DOWN:
 512		case PIN_CONFIG_BIAS_PULL_UP:
 513		case PIN_CONFIG_INPUT_SCHMITT_ENABLE:
 514			if ((data != func->conf[i].enable) ||
 515			    (data == func->conf[i].disable))
 516				return -ENOTSUPP;
 517			*config = 0;
 518			break;
 519		/* 2 parameters */
 520		case PIN_CONFIG_INPUT_SCHMITT:
 521			for (j = 0; j < func->nconfs; j++) {
 522				switch (func->conf[j].param) {
 523				case PIN_CONFIG_INPUT_SCHMITT_ENABLE:
 524					if (data != func->conf[j].enable)
 525						return -ENOTSUPP;
 526					break;
 527				default:
 528					break;
 529				}
 530			}
 531			*config = data;
 532			break;
 533		case PIN_CONFIG_DRIVE_STRENGTH:
 534		case PIN_CONFIG_SLEW_RATE:
 535		case PIN_CONFIG_MODE_LOW_POWER:
 536		case PIN_CONFIG_INPUT_ENABLE:
 537		default:
 538			*config = data;
 539			break;
 540		}
 541		return 0;
 542	}
 543	return -ENOTSUPP;
 544}
 545
 546static int pcs_pinconf_set(struct pinctrl_dev *pctldev,
 547				unsigned pin, unsigned long *configs,
 548				unsigned num_configs)
 549{
 550	struct pcs_device *pcs = pinctrl_dev_get_drvdata(pctldev);
 551	struct pcs_function *func;
 552	unsigned offset = 0, shift = 0, i, data, ret;
 553	u32 arg;
 554	int j;
 555	enum pin_config_param param;
 556
 557	ret = pcs_get_function(pctldev, pin, &func);
 558	if (ret)
 559		return ret;
 560
 561	for (j = 0; j < num_configs; j++) {
 562		param = pinconf_to_config_param(configs[j]);
 563
 564		/* BIAS_DISABLE has no entry in the func->conf table */
 565		if (param == PIN_CONFIG_BIAS_DISABLE) {
 566			/* This just disables all bias entries */
 567			pcs_pinconf_clear_bias(pctldev, pin);
 568			continue;
 569		}
 570
 571		for (i = 0; i < func->nconfs; i++) {
 572			if (param != func->conf[i].param)
 
 573				continue;
 574
 575			offset = pin * (pcs->width / BITS_PER_BYTE);
 576			data = pcs->read(pcs->base + offset);
 577			arg = pinconf_to_config_argument(configs[j]);
 578			switch (param) {
 579			/* 2 parameters */
 580			case PIN_CONFIG_INPUT_SCHMITT:
 581			case PIN_CONFIG_DRIVE_STRENGTH:
 582			case PIN_CONFIG_SLEW_RATE:
 583			case PIN_CONFIG_MODE_LOW_POWER:
 584			case PIN_CONFIG_INPUT_ENABLE:
 585				shift = ffs(func->conf[i].mask) - 1;
 586				data &= ~func->conf[i].mask;
 587				data |= (arg << shift) & func->conf[i].mask;
 588				break;
 589			/* 4 parameters */
 
 
 
 590			case PIN_CONFIG_BIAS_PULL_DOWN:
 591			case PIN_CONFIG_BIAS_PULL_UP:
 592				if (arg)
 593					pcs_pinconf_clear_bias(pctldev, pin);
 594				fallthrough;
 595			case PIN_CONFIG_INPUT_SCHMITT_ENABLE:
 596				data &= ~func->conf[i].mask;
 597				if (arg)
 598					data |= func->conf[i].enable;
 599				else
 600					data |= func->conf[i].disable;
 601				break;
 602			default:
 603				return -ENOTSUPP;
 604			}
 605			pcs->write(data, pcs->base + offset);
 606
 607			break;
 608		}
 609		if (i >= func->nconfs)
 610			return -ENOTSUPP;
 611	} /* for each config */
 612
 613	return 0;
 614}
 615
 616static int pcs_pinconf_group_get(struct pinctrl_dev *pctldev,
 617				unsigned group, unsigned long *config)
 618{
 619	const unsigned *pins;
 620	unsigned npins, old = 0;
 621	int i, ret;
 622
 623	ret = pinctrl_generic_get_group_pins(pctldev, group, &pins, &npins);
 624	if (ret)
 625		return ret;
 626	for (i = 0; i < npins; i++) {
 627		if (pcs_pinconf_get(pctldev, pins[i], config))
 628			return -ENOTSUPP;
 629		/* configs do not match between two pins */
 630		if (i && (old != *config))
 631			return -ENOTSUPP;
 632		old = *config;
 633	}
 634	return 0;
 635}
 636
 637static int pcs_pinconf_group_set(struct pinctrl_dev *pctldev,
 638				unsigned group, unsigned long *configs,
 639				unsigned num_configs)
 640{
 641	const unsigned *pins;
 642	unsigned npins;
 643	int i, ret;
 644
 645	ret = pinctrl_generic_get_group_pins(pctldev, group, &pins, &npins);
 646	if (ret)
 647		return ret;
 648	for (i = 0; i < npins; i++) {
 649		if (pcs_pinconf_set(pctldev, pins[i], configs, num_configs))
 650			return -ENOTSUPP;
 651	}
 652	return 0;
 653}
 654
 655static void pcs_pinconf_dbg_show(struct pinctrl_dev *pctldev,
 656				struct seq_file *s, unsigned pin)
 657{
 658}
 659
 660static void pcs_pinconf_group_dbg_show(struct pinctrl_dev *pctldev,
 661				struct seq_file *s, unsigned selector)
 662{
 663}
 664
 665static void pcs_pinconf_config_dbg_show(struct pinctrl_dev *pctldev,
 666					struct seq_file *s,
 667					unsigned long config)
 668{
 669	pinconf_generic_dump_config(pctldev, s, config);
 670}
 671
 672static const struct pinconf_ops pcs_pinconf_ops = {
 673	.pin_config_get = pcs_pinconf_get,
 674	.pin_config_set = pcs_pinconf_set,
 675	.pin_config_group_get = pcs_pinconf_group_get,
 676	.pin_config_group_set = pcs_pinconf_group_set,
 677	.pin_config_dbg_show = pcs_pinconf_dbg_show,
 678	.pin_config_group_dbg_show = pcs_pinconf_group_dbg_show,
 679	.pin_config_config_dbg_show = pcs_pinconf_config_dbg_show,
 680	.is_generic = true,
 681};
 682
 683/**
 684 * pcs_add_pin() - add a pin to the static per controller pin array
 685 * @pcs: pcs driver instance
 686 * @offset: register offset from base
 687 */
 688static int pcs_add_pin(struct pcs_device *pcs, unsigned int offset)
 
 689{
 690	struct pcs_soc_data *pcs_soc = &pcs->socdata;
 691	struct pinctrl_pin_desc *pin;
 692	int i;
 693
 694	i = pcs->pins.cur;
 695	if (i >= pcs->desc.npins) {
 696		dev_err(pcs->dev, "too many pins, max %i\n",
 697			pcs->desc.npins);
 698		return -ENOMEM;
 699	}
 700
 701	if (pcs_soc->irq_enable_mask) {
 702		unsigned val;
 703
 704		val = pcs->read(pcs->base + offset);
 705		if (val & pcs_soc->irq_enable_mask) {
 706			dev_dbg(pcs->dev, "irq enabled at boot for pin at %lx (%x), clearing\n",
 707				(unsigned long)pcs->res->start + offset, val);
 708			val &= ~pcs_soc->irq_enable_mask;
 709			pcs->write(val, pcs->base + offset);
 710		}
 711	}
 712
 713	pin = &pcs->pins.pa[i];
 714	pin->number = i;
 715	pcs->pins.cur++;
 716
 717	return i;
 718}
 719
 720/**
 721 * pcs_allocate_pin_table() - adds all the pins for the pinctrl driver
 722 * @pcs: pcs driver instance
 723 *
 724 * In case of errors, resources are freed in pcs_free_resources.
 725 *
 726 * If your hardware needs holes in the address space, then just set
 727 * up multiple driver instances.
 728 */
 729static int pcs_allocate_pin_table(struct pcs_device *pcs)
 730{
 731	int mux_bytes, nr_pins, i;
 
 732
 733	mux_bytes = pcs->width / BITS_PER_BYTE;
 734
 735	if (pcs->bits_per_mux && pcs->fmask) {
 736		pcs->bits_per_pin = fls(pcs->fmask);
 737		nr_pins = (pcs->size * BITS_PER_BYTE) / pcs->bits_per_pin;
 
 738	} else {
 739		nr_pins = pcs->size / mux_bytes;
 740	}
 741
 742	dev_dbg(pcs->dev, "allocating %i pins\n", nr_pins);
 743	pcs->pins.pa = devm_kcalloc(pcs->dev,
 744				nr_pins, sizeof(*pcs->pins.pa),
 745				GFP_KERNEL);
 746	if (!pcs->pins.pa)
 747		return -ENOMEM;
 748
 749	pcs->desc.pins = pcs->pins.pa;
 750	pcs->desc.npins = nr_pins;
 751
 752	for (i = 0; i < pcs->desc.npins; i++) {
 753		unsigned offset;
 754		int res;
 
 
 755
 756		offset = pcs_pin_reg_offset_get(pcs, i);
 757		res = pcs_add_pin(pcs, offset);
 
 
 
 
 
 
 758		if (res < 0) {
 759			dev_err(pcs->dev, "error adding pins: %i\n", res);
 760			return res;
 761		}
 762	}
 763
 764	return 0;
 765}
 766
 767/**
 768 * pcs_add_function() - adds a new function to the function list
 769 * @pcs: pcs driver instance
 770 * @fcn: new function allocated
 771 * @name: name of the function
 772 * @vals: array of mux register value pairs used by the function
 773 * @nvals: number of mux register value pairs
 774 * @pgnames: array of pingroup names for the function
 775 * @npgnames: number of pingroup names
 776 *
 777 * Caller must take care of locking.
 778 */
 779static int pcs_add_function(struct pcs_device *pcs,
 780			    struct pcs_function **fcn,
 781			    const char *name,
 782			    struct pcs_func_vals *vals,
 783			    unsigned int nvals,
 784			    const char **pgnames,
 785			    unsigned int npgnames)
 786{
 787	struct pcs_function *function;
 788	int selector;
 789
 790	function = devm_kzalloc(pcs->dev, sizeof(*function), GFP_KERNEL);
 791	if (!function)
 792		return -ENOMEM;
 793
 794	function->vals = vals;
 795	function->nvals = nvals;
 796	function->name = name;
 797
 798	selector = pinmux_generic_add_function(pcs->pctl, name,
 799					       pgnames, npgnames,
 800					       function);
 801	if (selector < 0) {
 802		devm_kfree(pcs->dev, function);
 803		*fcn = NULL;
 804	} else {
 805		*fcn = function;
 806	}
 807
 808	return selector;
 809}
 810
 811/**
 812 * pcs_get_pin_by_offset() - get a pin index based on the register offset
 813 * @pcs: pcs driver instance
 814 * @offset: register offset from the base
 815 *
 816 * Note that this is OK as long as the pins are in a static array.
 817 */
 818static int pcs_get_pin_by_offset(struct pcs_device *pcs, unsigned offset)
 819{
 820	unsigned index;
 821
 822	if (offset >= pcs->size) {
 823		dev_err(pcs->dev, "mux offset out of range: 0x%x (0x%x)\n",
 824			offset, pcs->size);
 825		return -EINVAL;
 826	}
 827
 828	if (pcs->bits_per_mux)
 829		index = (offset * BITS_PER_BYTE) / pcs->bits_per_pin;
 830	else
 831		index = offset / (pcs->width / BITS_PER_BYTE);
 832
 833	return index;
 834}
 835
 836/*
 837 * check whether data matches enable bits or disable bits
 838 * Return value: 1 for matching enable bits, 0 for matching disable bits,
 839 *               and negative value for matching failure.
 840 */
 841static int pcs_config_match(unsigned data, unsigned enable, unsigned disable)
 842{
 843	int ret = -EINVAL;
 844
 845	if (data == enable)
 846		ret = 1;
 847	else if (data == disable)
 848		ret = 0;
 849	return ret;
 850}
 851
 852static void add_config(struct pcs_conf_vals **conf, enum pin_config_param param,
 853		       unsigned value, unsigned enable, unsigned disable,
 854		       unsigned mask)
 855{
 856	(*conf)->param = param;
 857	(*conf)->val = value;
 858	(*conf)->enable = enable;
 859	(*conf)->disable = disable;
 860	(*conf)->mask = mask;
 861	(*conf)++;
 862}
 863
 864static void add_setting(unsigned long **setting, enum pin_config_param param,
 865			unsigned arg)
 866{
 867	**setting = pinconf_to_config_packed(param, arg);
 868	(*setting)++;
 869}
 870
 871/* add pinconf setting with 2 parameters */
 872static void pcs_add_conf2(struct pcs_device *pcs, struct device_node *np,
 873			  const char *name, enum pin_config_param param,
 874			  struct pcs_conf_vals **conf, unsigned long **settings)
 875{
 876	unsigned value[2], shift;
 877	int ret;
 878
 879	ret = of_property_read_u32_array(np, name, value, 2);
 880	if (ret)
 881		return;
 882	/* set value & mask */
 883	value[0] &= value[1];
 884	shift = ffs(value[1]) - 1;
 885	/* skip enable & disable */
 886	add_config(conf, param, value[0], 0, 0, value[1]);
 887	add_setting(settings, param, value[0] >> shift);
 888}
 889
 890/* add pinconf setting with 4 parameters */
 891static void pcs_add_conf4(struct pcs_device *pcs, struct device_node *np,
 892			  const char *name, enum pin_config_param param,
 893			  struct pcs_conf_vals **conf, unsigned long **settings)
 894{
 895	unsigned value[4];
 896	int ret;
 897
 898	/* value to set, enable, disable, mask */
 899	ret = of_property_read_u32_array(np, name, value, 4);
 900	if (ret)
 901		return;
 902	if (!value[3]) {
 903		dev_err(pcs->dev, "mask field of the property can't be 0\n");
 904		return;
 905	}
 906	value[0] &= value[3];
 907	value[1] &= value[3];
 908	value[2] &= value[3];
 909	ret = pcs_config_match(value[0], value[1], value[2]);
 910	if (ret < 0)
 911		dev_dbg(pcs->dev, "failed to match enable or disable bits\n");
 912	add_config(conf, param, value[0], value[1], value[2], value[3]);
 913	add_setting(settings, param, ret);
 914}
 915
 916static int pcs_parse_pinconf(struct pcs_device *pcs, struct device_node *np,
 917			     struct pcs_function *func,
 918			     struct pinctrl_map **map)
 919
 920{
 921	struct pinctrl_map *m = *map;
 922	int i = 0, nconfs = 0;
 923	unsigned long *settings = NULL, *s = NULL;
 924	struct pcs_conf_vals *conf = NULL;
 925	static const struct pcs_conf_type prop2[] = {
 926		{ "pinctrl-single,drive-strength", PIN_CONFIG_DRIVE_STRENGTH, },
 927		{ "pinctrl-single,slew-rate", PIN_CONFIG_SLEW_RATE, },
 928		{ "pinctrl-single,input-enable", PIN_CONFIG_INPUT_ENABLE, },
 929		{ "pinctrl-single,input-schmitt", PIN_CONFIG_INPUT_SCHMITT, },
 930		{ "pinctrl-single,low-power-mode", PIN_CONFIG_MODE_LOW_POWER, },
 931	};
 932	static const struct pcs_conf_type prop4[] = {
 933		{ "pinctrl-single,bias-pullup", PIN_CONFIG_BIAS_PULL_UP, },
 934		{ "pinctrl-single,bias-pulldown", PIN_CONFIG_BIAS_PULL_DOWN, },
 935		{ "pinctrl-single,input-schmitt-enable",
 936			PIN_CONFIG_INPUT_SCHMITT_ENABLE, },
 937	};
 938
 939	/* If pinconf isn't supported, don't parse properties in below. */
 940	if (!PCS_HAS_PINCONF)
 941		return -ENOTSUPP;
 942
 943	/* cacluate how much properties are supported in current node */
 944	for (i = 0; i < ARRAY_SIZE(prop2); i++) {
 945		if (of_property_present(np, prop2[i].name))
 946			nconfs++;
 947	}
 948	for (i = 0; i < ARRAY_SIZE(prop4); i++) {
 949		if (of_property_present(np, prop4[i].name))
 950			nconfs++;
 951	}
 952	if (!nconfs)
 953		return -ENOTSUPP;
 954
 955	func->conf = devm_kcalloc(pcs->dev,
 956				  nconfs, sizeof(struct pcs_conf_vals),
 957				  GFP_KERNEL);
 958	if (!func->conf)
 959		return -ENOMEM;
 960	func->nconfs = nconfs;
 961	conf = &(func->conf[0]);
 962	m++;
 963	settings = devm_kcalloc(pcs->dev, nconfs, sizeof(unsigned long),
 964				GFP_KERNEL);
 965	if (!settings)
 966		return -ENOMEM;
 967	s = &settings[0];
 968
 969	for (i = 0; i < ARRAY_SIZE(prop2); i++)
 970		pcs_add_conf2(pcs, np, prop2[i].name, prop2[i].param,
 971			      &conf, &s);
 972	for (i = 0; i < ARRAY_SIZE(prop4); i++)
 973		pcs_add_conf4(pcs, np, prop4[i].name, prop4[i].param,
 974			      &conf, &s);
 975	m->type = PIN_MAP_TYPE_CONFIGS_GROUP;
 976	m->data.configs.group_or_pin = np->name;
 977	m->data.configs.configs = settings;
 978	m->data.configs.num_configs = nconfs;
 979	return 0;
 980}
 981
 982/**
 983 * pcs_parse_one_pinctrl_entry() - parses a device tree mux entry
 
 984 * @pcs: pinctrl driver instance
 985 * @np: device node of the mux entry
 986 * @map: map entry
 987 * @num_maps: number of map
 988 * @pgnames: pingroup names
 989 *
 990 * Note that this binding currently supports only sets of one register + value.
 991 *
 992 * Also note that this driver tries to avoid understanding pin and function
 993 * names because of the extra bloat they would cause especially in the case of
 994 * a large number of pins. This driver just sets what is specified for the board
 995 * in the .dts file. Further user space debugging tools can be developed to
 996 * decipher the pin and function names using debugfs.
 997 *
 998 * If you are concerned about the boot time, set up the static pins in
 999 * the bootloader, and only set up selected pins as device tree entries.
1000 */
1001static int pcs_parse_one_pinctrl_entry(struct pcs_device *pcs,
1002						struct device_node *np,
1003						struct pinctrl_map **map,
1004						unsigned *num_maps,
1005						const char **pgnames)
1006{
1007	const char *name = "pinctrl-single,pins";
1008	struct pcs_func_vals *vals;
1009	int rows, *pins, found = 0, res = -ENOMEM, i, fsel, gsel;
1010	struct pcs_function *function = NULL;
1011
1012	rows = pinctrl_count_index_with_args(np, name);
1013	if (rows <= 0) {
1014		dev_err(pcs->dev, "Invalid number of rows: %d\n", rows);
1015		return -EINVAL;
1016	}
1017
1018	vals = devm_kcalloc(pcs->dev, rows, sizeof(*vals), GFP_KERNEL);
1019	if (!vals)
1020		return -ENOMEM;
1021
1022	pins = devm_kcalloc(pcs->dev, rows, sizeof(*pins), GFP_KERNEL);
1023	if (!pins)
1024		goto free_vals;
1025
1026	for (i = 0; i < rows; i++) {
1027		struct of_phandle_args pinctrl_spec;
1028		unsigned int offset;
1029		int pin;
1030
1031		res = pinctrl_parse_index_with_args(np, name, i, &pinctrl_spec);
1032		if (res)
1033			return res;
1034
1035		if (pinctrl_spec.args_count < 2 || pinctrl_spec.args_count > 3) {
1036			dev_err(pcs->dev, "invalid args_count for spec: %i\n",
1037				pinctrl_spec.args_count);
1038			break;
1039		}
1040
 
1041		offset = pinctrl_spec.args[0];
1042		vals[found].reg = pcs->base + offset;
 
1043
1044		switch (pinctrl_spec.args_count) {
1045		case 2:
1046			vals[found].val = pinctrl_spec.args[1];
1047			break;
1048		case 3:
1049			vals[found].val = (pinctrl_spec.args[1] | pinctrl_spec.args[2]);
1050			break;
1051		}
1052
1053		dev_dbg(pcs->dev, "%pOFn index: 0x%x value: 0x%x\n",
1054			pinctrl_spec.np, offset, vals[found].val);
1055
1056		pin = pcs_get_pin_by_offset(pcs, offset);
1057		if (pin < 0) {
1058			dev_err(pcs->dev,
1059				"could not add functions for %pOFn %ux\n",
1060				np, offset);
1061			break;
1062		}
1063		pins[found++] = pin;
1064	}
1065
1066	pgnames[0] = np->name;
1067	mutex_lock(&pcs->mutex);
1068	fsel = pcs_add_function(pcs, &function, np->name, vals, found,
1069				pgnames, 1);
1070	if (fsel < 0) {
1071		res = fsel;
1072		goto free_pins;
1073	}
1074
1075	gsel = pinctrl_generic_add_group(pcs->pctl, np->name, pins, found, pcs);
1076	if (gsel < 0) {
1077		res = gsel;
1078		goto free_function;
1079	}
1080
1081	(*map)->type = PIN_MAP_TYPE_MUX_GROUP;
1082	(*map)->data.mux.group = np->name;
1083	(*map)->data.mux.function = np->name;
1084
1085	if (PCS_HAS_PINCONF && function) {
1086		res = pcs_parse_pinconf(pcs, np, function, map);
1087		if (res == 0)
1088			*num_maps = 2;
1089		else if (res == -ENOTSUPP)
1090			*num_maps = 1;
1091		else
1092			goto free_pingroups;
 
1093	} else {
1094		*num_maps = 1;
1095	}
1096	mutex_unlock(&pcs->mutex);
1097
1098	return 0;
1099
1100free_pingroups:
1101	pinctrl_generic_remove_group(pcs->pctl, gsel);
1102	*num_maps = 1;
1103free_function:
1104	pinmux_generic_remove_function(pcs->pctl, fsel);
 
1105free_pins:
1106	mutex_unlock(&pcs->mutex);
1107	devm_kfree(pcs->dev, pins);
1108
1109free_vals:
1110	devm_kfree(pcs->dev, vals);
1111
1112	return res;
1113}
1114
1115static int pcs_parse_bits_in_pinctrl_entry(struct pcs_device *pcs,
1116						struct device_node *np,
1117						struct pinctrl_map **map,
1118						unsigned *num_maps,
1119						const char **pgnames)
1120{
1121	const char *name = "pinctrl-single,bits";
1122	struct pcs_func_vals *vals;
1123	int rows, *pins, found = 0, res = -ENOMEM, i, fsel;
1124	int npins_in_row;
1125	struct pcs_function *function = NULL;
1126
1127	rows = pinctrl_count_index_with_args(np, name);
1128	if (rows <= 0) {
1129		dev_err(pcs->dev, "Invalid number of rows: %d\n", rows);
1130		return -EINVAL;
1131	}
1132
1133	if (PCS_HAS_PINCONF) {
1134		dev_err(pcs->dev, "pinconf not supported\n");
1135		return -ENOTSUPP;
1136	}
1137
1138	npins_in_row = pcs->width / pcs->bits_per_pin;
1139
1140	vals = devm_kzalloc(pcs->dev,
1141			    array3_size(rows, npins_in_row, sizeof(*vals)),
1142			    GFP_KERNEL);
1143	if (!vals)
1144		return -ENOMEM;
1145
1146	pins = devm_kzalloc(pcs->dev,
1147			    array3_size(rows, npins_in_row, sizeof(*pins)),
1148			    GFP_KERNEL);
1149	if (!pins)
1150		goto free_vals;
1151
1152	for (i = 0; i < rows; i++) {
1153		struct of_phandle_args pinctrl_spec;
1154		unsigned offset, val;
1155		unsigned mask, bit_pos, val_pos, mask_pos, submask;
1156		unsigned pin_num_from_lsb;
1157		int pin;
1158
1159		res = pinctrl_parse_index_with_args(np, name, i, &pinctrl_spec);
1160		if (res)
1161			return res;
1162
1163		if (pinctrl_spec.args_count < 3) {
1164			dev_err(pcs->dev, "invalid args_count for spec: %i\n",
1165				pinctrl_spec.args_count);
1166			break;
1167		}
1168
1169		/* Index plus two value cells */
1170		offset = pinctrl_spec.args[0];
1171		val = pinctrl_spec.args[1];
1172		mask = pinctrl_spec.args[2];
1173
1174		dev_dbg(pcs->dev, "%pOFn index: 0x%x value: 0x%x mask: 0x%x\n",
1175			pinctrl_spec.np, offset, val, mask);
1176
1177		/* Parse pins in each row from LSB */
1178		while (mask) {
1179			bit_pos = __ffs(mask);
1180			pin_num_from_lsb = bit_pos / pcs->bits_per_pin;
1181			mask_pos = ((pcs->fmask) << bit_pos);
1182			val_pos = val & mask_pos;
1183			submask = mask & mask_pos;
1184
1185			if ((mask & mask_pos) == 0) {
1186				dev_err(pcs->dev,
1187					"Invalid mask for %pOFn at 0x%x\n",
1188					np, offset);
1189				break;
1190			}
1191
1192			mask &= ~mask_pos;
1193
1194			if (submask != mask_pos) {
1195				dev_warn(pcs->dev,
1196						"Invalid submask 0x%x for %pOFn at 0x%x\n",
1197						submask, np, offset);
1198				continue;
1199			}
1200
1201			vals[found].mask = submask;
1202			vals[found].reg = pcs->base + offset;
1203			vals[found].val = val_pos;
1204
1205			pin = pcs_get_pin_by_offset(pcs, offset);
1206			if (pin < 0) {
1207				dev_err(pcs->dev,
1208					"could not add functions for %pOFn %ux\n",
1209					np, offset);
1210				break;
1211			}
1212			pins[found++] = pin + pin_num_from_lsb;
1213		}
1214	}
1215
1216	pgnames[0] = np->name;
1217	mutex_lock(&pcs->mutex);
1218	fsel = pcs_add_function(pcs, &function, np->name, vals, found,
1219				pgnames, 1);
1220	if (fsel < 0) {
1221		res = fsel;
1222		goto free_pins;
1223	}
1224
1225	res = pinctrl_generic_add_group(pcs->pctl, np->name, pins, found, pcs);
1226	if (res < 0)
1227		goto free_function;
1228
1229	(*map)->type = PIN_MAP_TYPE_MUX_GROUP;
1230	(*map)->data.mux.group = np->name;
1231	(*map)->data.mux.function = np->name;
1232
1233	*num_maps = 1;
1234	mutex_unlock(&pcs->mutex);
 
 
1235
 
1236	return 0;
1237
 
 
 
1238free_function:
1239	pinmux_generic_remove_function(pcs->pctl, fsel);
1240free_pins:
1241	mutex_unlock(&pcs->mutex);
1242	devm_kfree(pcs->dev, pins);
1243
1244free_vals:
1245	devm_kfree(pcs->dev, vals);
1246
1247	return res;
1248}
1249/**
1250 * pcs_dt_node_to_map() - allocates and parses pinctrl maps
1251 * @pctldev: pinctrl instance
1252 * @np_config: device tree pinmux entry
1253 * @map: array of map entries
1254 * @num_maps: number of maps
1255 */
1256static int pcs_dt_node_to_map(struct pinctrl_dev *pctldev,
1257				struct device_node *np_config,
1258				struct pinctrl_map **map, unsigned *num_maps)
1259{
1260	struct pcs_device *pcs;
1261	const char **pgnames;
1262	int ret;
1263
1264	pcs = pinctrl_dev_get_drvdata(pctldev);
1265
1266	/* create 2 maps. One is for pinmux, and the other is for pinconf. */
1267	*map = devm_kcalloc(pcs->dev, 2, sizeof(**map), GFP_KERNEL);
1268	if (!*map)
1269		return -ENOMEM;
1270
1271	*num_maps = 0;
1272
1273	pgnames = devm_kzalloc(pcs->dev, sizeof(*pgnames), GFP_KERNEL);
1274	if (!pgnames) {
1275		ret = -ENOMEM;
1276		goto free_map;
1277	}
1278
1279	if (pcs->bits_per_mux) {
1280		ret = pcs_parse_bits_in_pinctrl_entry(pcs, np_config, map,
1281				num_maps, pgnames);
1282		if (ret < 0) {
1283			dev_err(pcs->dev, "no pins entries for %pOFn\n",
1284				np_config);
1285			goto free_pgnames;
1286		}
1287	} else {
1288		ret = pcs_parse_one_pinctrl_entry(pcs, np_config, map,
1289				num_maps, pgnames);
1290		if (ret < 0) {
1291			dev_err(pcs->dev, "no pins entries for %pOFn\n",
1292				np_config);
1293			goto free_pgnames;
1294		}
1295	}
1296
1297	return 0;
1298
1299free_pgnames:
1300	devm_kfree(pcs->dev, pgnames);
1301free_map:
1302	devm_kfree(pcs->dev, *map);
1303
1304	return ret;
1305}
1306
1307/**
1308 * pcs_irq_free() - free interrupt
1309 * @pcs: pcs driver instance
1310 */
1311static void pcs_irq_free(struct pcs_device *pcs)
1312{
1313	struct pcs_soc_data *pcs_soc = &pcs->socdata;
1314
1315	if (pcs_soc->irq < 0)
1316		return;
1317
1318	if (pcs->domain)
1319		irq_domain_remove(pcs->domain);
1320
1321	if (PCS_QUIRK_HAS_SHARED_IRQ)
1322		free_irq(pcs_soc->irq, pcs_soc);
1323	else
1324		irq_set_chained_handler(pcs_soc->irq, NULL);
1325}
1326
1327/**
1328 * pcs_free_resources() - free memory used by this driver
1329 * @pcs: pcs driver instance
1330 */
1331static void pcs_free_resources(struct pcs_device *pcs)
1332{
1333	pcs_irq_free(pcs);
 
1334
1335#if IS_BUILTIN(CONFIG_PINCTRL_SINGLE)
1336	if (pcs->missing_nr_pinctrl_cells)
1337		of_remove_property(pcs->np, pcs->missing_nr_pinctrl_cells);
1338#endif
1339}
1340
1341static int pcs_add_gpio_func(struct device_node *node, struct pcs_device *pcs)
1342{
1343	const char *propname = "pinctrl-single,gpio-range";
1344	const char *cellname = "#pinctrl-single,gpio-range-cells";
1345	struct of_phandle_args gpiospec;
1346	struct pcs_gpiofunc_range *range;
1347	int ret, i;
1348
1349	for (i = 0; ; i++) {
1350		ret = of_parse_phandle_with_args(node, propname, cellname,
1351						 i, &gpiospec);
1352		/* Do not treat it as error. Only treat it as end condition. */
1353		if (ret) {
1354			ret = 0;
1355			break;
1356		}
1357		range = devm_kzalloc(pcs->dev, sizeof(*range), GFP_KERNEL);
1358		if (!range) {
1359			ret = -ENOMEM;
1360			break;
1361		}
1362		range->offset = gpiospec.args[0];
1363		range->npins = gpiospec.args[1];
1364		range->gpiofunc = gpiospec.args[2];
1365		mutex_lock(&pcs->mutex);
1366		list_add_tail(&range->node, &pcs->gpiofuncs);
1367		mutex_unlock(&pcs->mutex);
1368	}
1369	return ret;
1370}
1371
1372/**
1373 * struct pcs_interrupt
1374 * @reg:	virtual address of interrupt register
1375 * @hwirq:	hardware irq number
1376 * @irq:	virtual irq number
1377 * @node:	list node
1378 */
1379struct pcs_interrupt {
1380	void __iomem *reg;
1381	irq_hw_number_t hwirq;
1382	unsigned int irq;
1383	struct list_head node;
1384};
1385
1386/**
1387 * pcs_irq_set() - enables or disables an interrupt
1388 * @pcs_soc: SoC specific settings
1389 * @irq: interrupt
1390 * @enable: enable or disable the interrupt
1391 *
1392 * Note that this currently assumes one interrupt per pinctrl
1393 * register that is typically used for wake-up events.
1394 */
1395static inline void pcs_irq_set(struct pcs_soc_data *pcs_soc,
1396			       int irq, const bool enable)
1397{
1398	struct pcs_device *pcs;
1399	struct list_head *pos;
1400	unsigned mask;
1401
1402	pcs = container_of(pcs_soc, struct pcs_device, socdata);
1403	list_for_each(pos, &pcs->irqs) {
1404		struct pcs_interrupt *pcswi;
1405		unsigned soc_mask;
1406
1407		pcswi = list_entry(pos, struct pcs_interrupt, node);
1408		if (irq != pcswi->irq)
1409			continue;
1410
1411		soc_mask = pcs_soc->irq_enable_mask;
1412		raw_spin_lock(&pcs->lock);
1413		mask = pcs->read(pcswi->reg);
1414		if (enable)
1415			mask |= soc_mask;
1416		else
1417			mask &= ~soc_mask;
1418		pcs->write(mask, pcswi->reg);
1419
1420		/* flush posted write */
1421		mask = pcs->read(pcswi->reg);
1422		raw_spin_unlock(&pcs->lock);
1423	}
1424
1425	if (pcs_soc->rearm)
1426		pcs_soc->rearm();
1427}
1428
1429/**
1430 * pcs_irq_mask() - mask pinctrl interrupt
1431 * @d: interrupt data
1432 */
1433static void pcs_irq_mask(struct irq_data *d)
1434{
1435	struct pcs_soc_data *pcs_soc = irq_data_get_irq_chip_data(d);
1436
1437	pcs_irq_set(pcs_soc, d->irq, false);
1438}
1439
1440/**
1441 * pcs_irq_unmask() - unmask pinctrl interrupt
1442 * @d: interrupt data
1443 */
1444static void pcs_irq_unmask(struct irq_data *d)
1445{
1446	struct pcs_soc_data *pcs_soc = irq_data_get_irq_chip_data(d);
1447
1448	pcs_irq_set(pcs_soc, d->irq, true);
1449}
1450
1451/**
1452 * pcs_irq_set_wake() - toggle the suspend and resume wake up
1453 * @d: interrupt data
1454 * @state: wake-up state
1455 *
1456 * Note that this should be called only for suspend and resume.
1457 * For runtime PM, the wake-up events should be enabled by default.
1458 */
1459static int pcs_irq_set_wake(struct irq_data *d, unsigned int state)
1460{
1461	if (state)
1462		pcs_irq_unmask(d);
1463	else
1464		pcs_irq_mask(d);
1465
1466	return 0;
1467}
1468
1469/**
1470 * pcs_irq_handle() - common interrupt handler
1471 * @pcs_soc: SoC specific settings
1472 *
1473 * Note that this currently assumes we have one interrupt bit per
1474 * mux register. This interrupt is typically used for wake-up events.
1475 * For more complex interrupts different handlers can be specified.
1476 */
1477static int pcs_irq_handle(struct pcs_soc_data *pcs_soc)
1478{
1479	struct pcs_device *pcs;
1480	struct list_head *pos;
1481	int count = 0;
1482
1483	pcs = container_of(pcs_soc, struct pcs_device, socdata);
1484	list_for_each(pos, &pcs->irqs) {
1485		struct pcs_interrupt *pcswi;
1486		unsigned mask;
1487
1488		pcswi = list_entry(pos, struct pcs_interrupt, node);
1489		raw_spin_lock(&pcs->lock);
1490		mask = pcs->read(pcswi->reg);
1491		raw_spin_unlock(&pcs->lock);
1492		if (mask & pcs_soc->irq_status_mask) {
1493			generic_handle_domain_irq(pcs->domain,
1494						  pcswi->hwirq);
1495			count++;
1496		}
1497	}
1498
1499	return count;
1500}
1501
1502/**
1503 * pcs_irq_handler() - handler for the shared interrupt case
1504 * @irq: interrupt
1505 * @d: data
1506 *
1507 * Use this for cases where multiple instances of
1508 * pinctrl-single share a single interrupt like on omaps.
1509 */
1510static irqreturn_t pcs_irq_handler(int irq, void *d)
1511{
1512	struct pcs_soc_data *pcs_soc = d;
1513
1514	return pcs_irq_handle(pcs_soc) ? IRQ_HANDLED : IRQ_NONE;
1515}
1516
1517/**
1518 * pcs_irq_chain_handler() - handler for the dedicated chained interrupt case
 
1519 * @desc: interrupt descriptor
1520 *
1521 * Use this if you have a separate interrupt for each
1522 * pinctrl-single instance.
1523 */
1524static void pcs_irq_chain_handler(struct irq_desc *desc)
1525{
1526	struct pcs_soc_data *pcs_soc = irq_desc_get_handler_data(desc);
1527	struct irq_chip *chip;
1528
1529	chip = irq_desc_get_chip(desc);
1530	chained_irq_enter(chip, desc);
1531	pcs_irq_handle(pcs_soc);
1532	/* REVISIT: export and add handle_bad_irq(irq, desc)? */
1533	chained_irq_exit(chip, desc);
1534}
1535
1536static int pcs_irqdomain_map(struct irq_domain *d, unsigned int irq,
1537			     irq_hw_number_t hwirq)
1538{
1539	struct pcs_soc_data *pcs_soc = d->host_data;
1540	struct pcs_device *pcs;
1541	struct pcs_interrupt *pcswi;
1542
1543	pcs = container_of(pcs_soc, struct pcs_device, socdata);
1544	pcswi = devm_kzalloc(pcs->dev, sizeof(*pcswi), GFP_KERNEL);
1545	if (!pcswi)
1546		return -ENOMEM;
1547
1548	pcswi->reg = pcs->base + hwirq;
1549	pcswi->hwirq = hwirq;
1550	pcswi->irq = irq;
1551
1552	mutex_lock(&pcs->mutex);
1553	list_add_tail(&pcswi->node, &pcs->irqs);
1554	mutex_unlock(&pcs->mutex);
1555
1556	irq_set_chip_data(irq, pcs_soc);
1557	irq_set_chip_and_handler(irq, &pcs->chip,
1558				 handle_level_irq);
1559	irq_set_lockdep_class(irq, &pcs_lock_class, &pcs_request_class);
1560	irq_set_noprobe(irq);
1561
1562	return 0;
1563}
1564
1565static const struct irq_domain_ops pcs_irqdomain_ops = {
1566	.map = pcs_irqdomain_map,
1567	.xlate = irq_domain_xlate_onecell,
1568};
1569
1570/**
1571 * pcs_irq_init_chained_handler() - set up a chained interrupt handler
1572 * @pcs: pcs driver instance
1573 * @np: device node pointer
1574 */
1575static int pcs_irq_init_chained_handler(struct pcs_device *pcs,
1576					struct device_node *np)
1577{
1578	struct pcs_soc_data *pcs_soc = &pcs->socdata;
1579	const char *name = "pinctrl";
1580	int num_irqs;
1581
1582	if (!pcs_soc->irq_enable_mask ||
1583	    !pcs_soc->irq_status_mask) {
1584		pcs_soc->irq = -1;
1585		return -EINVAL;
1586	}
1587
1588	INIT_LIST_HEAD(&pcs->irqs);
1589	pcs->chip.name = name;
1590	pcs->chip.irq_ack = pcs_irq_mask;
1591	pcs->chip.irq_mask = pcs_irq_mask;
1592	pcs->chip.irq_unmask = pcs_irq_unmask;
1593	pcs->chip.irq_set_wake = pcs_irq_set_wake;
1594
1595	if (PCS_QUIRK_HAS_SHARED_IRQ) {
1596		int res;
1597
1598		res = request_irq(pcs_soc->irq, pcs_irq_handler,
1599				  IRQF_SHARED | IRQF_NO_SUSPEND |
1600				  IRQF_NO_THREAD,
1601				  name, pcs_soc);
1602		if (res) {
1603			pcs_soc->irq = -1;
1604			return res;
1605		}
1606	} else {
1607		irq_set_chained_handler_and_data(pcs_soc->irq,
1608						 pcs_irq_chain_handler,
1609						 pcs_soc);
1610	}
1611
1612	/*
1613	 * We can use the register offset as the hardirq
1614	 * number as irq_domain_add_simple maps them lazily.
1615	 * This way we can easily support more than one
1616	 * interrupt per function if needed.
1617	 */
1618	num_irqs = pcs->size;
1619
1620	pcs->domain = irq_domain_add_simple(np, num_irqs, 0,
1621					    &pcs_irqdomain_ops,
1622					    pcs_soc);
1623	if (!pcs->domain) {
1624		irq_set_chained_handler(pcs_soc->irq, NULL);
1625		return -EINVAL;
1626	}
1627
1628	return 0;
1629}
1630
1631static int pcs_save_context(struct pcs_device *pcs)
1632{
1633	int i, mux_bytes;
1634	u64 *regsl;
1635	u32 *regsw;
1636	u16 *regshw;
1637
1638	mux_bytes = pcs->width / BITS_PER_BYTE;
1639
1640	if (!pcs->saved_vals) {
1641		pcs->saved_vals = devm_kzalloc(pcs->dev, pcs->size, GFP_ATOMIC);
1642		if (!pcs->saved_vals)
1643			return -ENOMEM;
1644	}
1645
1646	switch (pcs->width) {
1647	case 64:
1648		regsl = pcs->saved_vals;
1649		for (i = 0; i < pcs->size; i += mux_bytes)
1650			*regsl++ = pcs->read(pcs->base + i);
1651		break;
1652	case 32:
1653		regsw = pcs->saved_vals;
1654		for (i = 0; i < pcs->size; i += mux_bytes)
1655			*regsw++ = pcs->read(pcs->base + i);
1656		break;
1657	case 16:
1658		regshw = pcs->saved_vals;
1659		for (i = 0; i < pcs->size; i += mux_bytes)
1660			*regshw++ = pcs->read(pcs->base + i);
1661		break;
1662	}
1663
1664	return 0;
1665}
1666
1667static void pcs_restore_context(struct pcs_device *pcs)
1668{
1669	int i, mux_bytes;
1670	u64 *regsl;
1671	u32 *regsw;
1672	u16 *regshw;
1673
1674	mux_bytes = pcs->width / BITS_PER_BYTE;
1675
1676	switch (pcs->width) {
1677	case 64:
1678		regsl = pcs->saved_vals;
1679		for (i = 0; i < pcs->size; i += mux_bytes)
1680			pcs->write(*regsl++, pcs->base + i);
1681		break;
1682	case 32:
1683		regsw = pcs->saved_vals;
1684		for (i = 0; i < pcs->size; i += mux_bytes)
1685			pcs->write(*regsw++, pcs->base + i);
1686		break;
1687	case 16:
1688		regshw = pcs->saved_vals;
1689		for (i = 0; i < pcs->size; i += mux_bytes)
1690			pcs->write(*regshw++, pcs->base + i);
1691		break;
1692	}
1693}
1694
1695static int pinctrl_single_suspend_noirq(struct device *dev)
1696{
1697	struct pcs_device *pcs = dev_get_drvdata(dev);
1698
1699	if (pcs->flags & PCS_CONTEXT_LOSS_OFF) {
1700		int ret;
1701
1702		ret = pcs_save_context(pcs);
1703		if (ret < 0)
1704			return ret;
1705	}
1706
1707	return pinctrl_force_sleep(pcs->pctl);
1708}
1709
1710static int pinctrl_single_resume_noirq(struct device *dev)
1711{
1712	struct pcs_device *pcs = dev_get_drvdata(dev);
1713
1714	if (pcs->flags & PCS_CONTEXT_LOSS_OFF)
1715		pcs_restore_context(pcs);
 
1716
1717	return pinctrl_force_default(pcs->pctl);
1718}
1719
1720static DEFINE_NOIRQ_DEV_PM_OPS(pinctrl_single_pm_ops,
1721			       pinctrl_single_suspend_noirq,
1722			       pinctrl_single_resume_noirq);
1723
1724/**
1725 * pcs_quirk_missing_pinctrl_cells - handle legacy binding
1726 * @pcs: pinctrl driver instance
1727 * @np: device tree node
1728 * @cells: number of cells
1729 *
1730 * Handle legacy binding with no #pinctrl-cells. This should be
1731 * always two pinctrl-single,bit-per-mux and one for others.
1732 * At some point we may want to consider removing this.
1733 */
1734static int pcs_quirk_missing_pinctrl_cells(struct pcs_device *pcs,
1735					   struct device_node *np,
1736					   int cells)
1737{
1738	struct property *p;
1739	const char *name = "#pinctrl-cells";
1740	int error;
1741	u32 val;
1742
1743	error = of_property_read_u32(np, name, &val);
1744	if (!error)
1745		return 0;
1746
1747	dev_warn(pcs->dev, "please update dts to use %s = <%i>\n",
1748		 name, cells);
1749
1750	p = devm_kzalloc(pcs->dev, sizeof(*p), GFP_KERNEL);
1751	if (!p)
1752		return -ENOMEM;
1753
1754	p->length = sizeof(__be32);
1755	p->value = devm_kzalloc(pcs->dev, sizeof(__be32), GFP_KERNEL);
1756	if (!p->value)
1757		return -ENOMEM;
1758	*(__be32 *)p->value = cpu_to_be32(cells);
1759
1760	p->name = devm_kstrdup(pcs->dev, name, GFP_KERNEL);
1761	if (!p->name)
1762		return -ENOMEM;
1763
1764	pcs->missing_nr_pinctrl_cells = p;
1765
1766#if IS_BUILTIN(CONFIG_PINCTRL_SINGLE)
1767	error = of_add_property(np, pcs->missing_nr_pinctrl_cells);
1768#endif
1769
1770	return error;
1771}
1772
1773static int pcs_probe(struct platform_device *pdev)
1774{
1775	struct device_node *np = pdev->dev.of_node;
1776	struct pcs_pdata *pdata;
1777	struct resource *res;
1778	struct pcs_device *pcs;
1779	const struct pcs_soc_data *soc;
1780	int ret;
1781
1782	soc = of_device_get_match_data(&pdev->dev);
1783	if (WARN_ON(!soc))
1784		return -EINVAL;
1785
1786	pcs = devm_kzalloc(&pdev->dev, sizeof(*pcs), GFP_KERNEL);
1787	if (!pcs)
1788		return -ENOMEM;
1789
1790	pcs->dev = &pdev->dev;
1791	pcs->np = np;
1792	raw_spin_lock_init(&pcs->lock);
1793	mutex_init(&pcs->mutex);
1794	INIT_LIST_HEAD(&pcs->gpiofuncs);
1795	pcs->flags = soc->flags;
1796	memcpy(&pcs->socdata, soc, sizeof(*soc));
1797
1798	ret = of_property_read_u32(np, "pinctrl-single,register-width",
1799				   &pcs->width);
1800	if (ret) {
1801		dev_err(pcs->dev, "register width not specified\n");
1802
1803		return ret;
1804	}
1805
1806	ret = of_property_read_u32(np, "pinctrl-single,function-mask",
1807				   &pcs->fmask);
1808	if (!ret) {
1809		pcs->fshift = __ffs(pcs->fmask);
1810		pcs->fmax = pcs->fmask >> pcs->fshift;
1811	} else {
1812		/* If mask property doesn't exist, function mux is invalid. */
1813		pcs->fmask = 0;
1814		pcs->fshift = 0;
1815		pcs->fmax = 0;
1816	}
1817
1818	ret = of_property_read_u32(np, "pinctrl-single,function-off",
1819					&pcs->foff);
1820	if (ret)
1821		pcs->foff = PCS_OFF_DISABLED;
1822
1823	pcs->bits_per_mux = of_property_read_bool(np,
1824						  "pinctrl-single,bit-per-mux");
1825	ret = pcs_quirk_missing_pinctrl_cells(pcs, np,
1826					      pcs->bits_per_mux ? 2 : 1);
1827	if (ret) {
1828		dev_err(&pdev->dev, "unable to patch #pinctrl-cells\n");
1829
1830		return ret;
1831	}
1832
1833	res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
1834	if (!res) {
1835		dev_err(pcs->dev, "could not get resource\n");
1836		return -ENODEV;
1837	}
1838
1839	pcs->res = devm_request_mem_region(pcs->dev, res->start,
1840			resource_size(res), DRIVER_NAME);
1841	if (!pcs->res) {
1842		dev_err(pcs->dev, "could not get mem_region\n");
1843		return -EBUSY;
1844	}
1845
1846	pcs->size = resource_size(pcs->res);
1847	pcs->base = devm_ioremap(pcs->dev, pcs->res->start, pcs->size);
1848	if (!pcs->base) {
1849		dev_err(pcs->dev, "could not ioremap\n");
1850		return -ENODEV;
1851	}
1852
1853	platform_set_drvdata(pdev, pcs);
1854
1855	switch (pcs->width) {
1856	case 8:
1857		pcs->read = pcs_readb;
1858		pcs->write = pcs_writeb;
1859		break;
1860	case 16:
1861		pcs->read = pcs_readw;
1862		pcs->write = pcs_writew;
1863		break;
1864	case 32:
1865		pcs->read = pcs_readl;
1866		pcs->write = pcs_writel;
1867		break;
1868	default:
1869		break;
1870	}
1871
1872	pcs->desc.name = DRIVER_NAME;
1873	pcs->desc.pctlops = &pcs_pinctrl_ops;
1874	pcs->desc.pmxops = &pcs_pinmux_ops;
1875	if (PCS_HAS_PINCONF)
1876		pcs->desc.confops = &pcs_pinconf_ops;
1877	pcs->desc.owner = THIS_MODULE;
1878
1879	ret = pcs_allocate_pin_table(pcs);
1880	if (ret < 0)
1881		goto free;
1882
1883	ret = devm_pinctrl_register_and_init(pcs->dev, &pcs->desc, pcs, &pcs->pctl);
1884	if (ret) {
1885		dev_err(pcs->dev, "could not register single pinctrl driver\n");
1886		goto free;
1887	}
1888
1889	ret = pcs_add_gpio_func(np, pcs);
1890	if (ret < 0)
1891		goto free;
1892
1893	pcs->socdata.irq = irq_of_parse_and_map(np, 0);
1894	if (pcs->socdata.irq)
1895		pcs->flags |= PCS_FEAT_IRQ;
1896
1897	/* We still need auxdata for some omaps for PRM interrupts */
1898	pdata = dev_get_platdata(&pdev->dev);
1899	if (pdata) {
1900		if (pdata->rearm)
1901			pcs->socdata.rearm = pdata->rearm;
1902		if (pdata->irq) {
1903			pcs->socdata.irq = pdata->irq;
1904			pcs->flags |= PCS_FEAT_IRQ;
1905		}
1906	}
1907
1908	if (PCS_HAS_IRQ) {
1909		ret = pcs_irq_init_chained_handler(pcs, np);
1910		if (ret < 0)
1911			dev_warn(pcs->dev, "initialized with no interrupts\n");
1912	}
1913
1914	dev_info(pcs->dev, "%i pins, size %u\n", pcs->desc.npins, pcs->size);
1915
1916	ret = pinctrl_enable(pcs->pctl);
1917	if (ret)
1918		goto free;
1919
1920	return 0;
1921free:
1922	pcs_free_resources(pcs);
1923
1924	return ret;
1925}
1926
1927static void pcs_remove(struct platform_device *pdev)
1928{
1929	struct pcs_device *pcs = platform_get_drvdata(pdev);
1930
 
 
 
1931	pcs_free_resources(pcs);
 
 
1932}
1933
1934static const struct pcs_soc_data pinctrl_single_omap_wkup = {
1935	.flags = PCS_QUIRK_SHARED_IRQ,
1936	.irq_enable_mask = (1 << 14),	/* OMAP_WAKEUP_EN */
1937	.irq_status_mask = (1 << 15),	/* OMAP_WAKEUP_EVENT */
1938};
1939
1940static const struct pcs_soc_data pinctrl_single_dra7 = {
1941	.irq_enable_mask = (1 << 24),	/* WAKEUPENABLE */
1942	.irq_status_mask = (1 << 25),	/* WAKEUPEVENT */
1943};
1944
1945static const struct pcs_soc_data pinctrl_single_am437x = {
1946	.flags = PCS_QUIRK_SHARED_IRQ | PCS_CONTEXT_LOSS_OFF,
1947	.irq_enable_mask = (1 << 29),   /* OMAP_WAKEUP_EN */
1948	.irq_status_mask = (1 << 30),   /* OMAP_WAKEUP_EVENT */
1949};
1950
1951static const struct pcs_soc_data pinctrl_single_am654 = {
1952	.flags = PCS_QUIRK_SHARED_IRQ | PCS_CONTEXT_LOSS_OFF,
1953	.irq_enable_mask = (1 << 29),   /* WKUP_EN */
1954	.irq_status_mask = (1 << 30),   /* WKUP_EVT */
1955};
1956
1957static const struct pcs_soc_data pinctrl_single_j7200 = {
1958	.flags = PCS_CONTEXT_LOSS_OFF,
1959};
1960
1961static const struct pcs_soc_data pinctrl_single = {
1962};
1963
1964static const struct pcs_soc_data pinconf_single = {
1965	.flags = PCS_FEAT_PINCONF,
1966};
1967
1968static const struct of_device_id pcs_of_match[] = {
1969	{ .compatible = "marvell,pxa1908-padconf", .data = &pinconf_single },
1970	{ .compatible = "ti,am437-padconf", .data = &pinctrl_single_am437x },
1971	{ .compatible = "ti,am654-padconf", .data = &pinctrl_single_am654 },
1972	{ .compatible = "ti,dra7-padconf", .data = &pinctrl_single_dra7 },
1973	{ .compatible = "ti,omap3-padconf", .data = &pinctrl_single_omap_wkup },
1974	{ .compatible = "ti,omap4-padconf", .data = &pinctrl_single_omap_wkup },
1975	{ .compatible = "ti,omap5-padconf", .data = &pinctrl_single_omap_wkup },
1976	{ .compatible = "ti,j7200-padconf", .data = &pinctrl_single_j7200 },
 
1977	{ .compatible = "pinctrl-single", .data = &pinctrl_single },
1978	{ .compatible = "pinconf-single", .data = &pinconf_single },
1979	{ },
1980};
1981MODULE_DEVICE_TABLE(of, pcs_of_match);
1982
1983static struct platform_driver pcs_driver = {
1984	.probe		= pcs_probe,
1985	.remove		= pcs_remove,
1986	.driver = {
1987		.name		= DRIVER_NAME,
1988		.of_match_table	= pcs_of_match,
1989		.pm = pm_sleep_ptr(&pinctrl_single_pm_ops),
1990	},
 
 
 
 
1991};
1992
1993module_platform_driver(pcs_driver);
1994
1995MODULE_AUTHOR("Tony Lindgren <tony@atomide.com>");
1996MODULE_DESCRIPTION("One-register-per-pin type device tree based pinctrl driver");
1997MODULE_LICENSE("GPL v2");
v4.17
   1/*
   2 * Generic device tree based pinctrl driver for one register per pin
   3 * type pinmux controllers
   4 *
   5 * Copyright (C) 2012 Texas Instruments, Inc.
   6 *
   7 * This file is licensed under the terms of the GNU General Public
   8 * License version 2. This program is licensed "as is" without any
   9 * warranty of any kind, whether express or implied.
  10 */
  11
  12#include <linux/init.h>
  13#include <linux/module.h>
  14#include <linux/io.h>
 
  15#include <linux/slab.h>
  16#include <linux/err.h>
  17#include <linux/list.h>
  18#include <linux/interrupt.h>
  19
  20#include <linux/irqchip/chained_irq.h>
  21
  22#include <linux/of.h>
  23#include <linux/of_device.h>
  24#include <linux/of_address.h>
  25#include <linux/of_irq.h>
 
  26
 
 
  27#include <linux/pinctrl/pinctrl.h>
  28#include <linux/pinctrl/pinmux.h>
  29#include <linux/pinctrl/pinconf-generic.h>
  30
  31#include <linux/platform_data/pinctrl-single.h>
  32
  33#include "core.h"
  34#include "devicetree.h"
  35#include "pinconf.h"
  36#include "pinmux.h"
  37
  38#define DRIVER_NAME			"pinctrl-single"
  39#define PCS_OFF_DISABLED		~0U
  40
  41/**
  42 * struct pcs_func_vals - mux function register offset and value pair
  43 * @reg:	register virtual address
  44 * @val:	register value
 
  45 */
  46struct pcs_func_vals {
  47	void __iomem *reg;
  48	unsigned val;
  49	unsigned mask;
  50};
  51
  52/**
  53 * struct pcs_conf_vals - pinconf parameter, pinconf register offset
  54 * and value, enable, disable, mask
  55 * @param:	config parameter
  56 * @val:	user input bits in the pinconf register
  57 * @enable:	enable bits in the pinconf register
  58 * @disable:	disable bits in the pinconf register
  59 * @mask:	mask bits in the register value
  60 */
  61struct pcs_conf_vals {
  62	enum pin_config_param param;
  63	unsigned val;
  64	unsigned enable;
  65	unsigned disable;
  66	unsigned mask;
  67};
  68
  69/**
  70 * struct pcs_conf_type - pinconf property name, pinconf param pair
  71 * @name:	property name in DTS file
  72 * @param:	config parameter
  73 */
  74struct pcs_conf_type {
  75	const char *name;
  76	enum pin_config_param param;
  77};
  78
  79/**
  80 * struct pcs_function - pinctrl function
  81 * @name:	pinctrl function name
  82 * @vals:	register and vals array
  83 * @nvals:	number of entries in vals array
  84 * @pgnames:	array of pingroup names the function uses
  85 * @npgnames:	number of pingroup names the function uses
  86 * @node:	list node
  87 */
  88struct pcs_function {
  89	const char *name;
  90	struct pcs_func_vals *vals;
  91	unsigned nvals;
  92	const char **pgnames;
  93	int npgnames;
  94	struct pcs_conf_vals *conf;
  95	int nconfs;
  96	struct list_head node;
  97};
  98
  99/**
 100 * struct pcs_gpiofunc_range - pin ranges with same mux value of gpio function
 101 * @offset:	offset base of pins
 102 * @npins:	number pins with the same mux value of gpio function
 103 * @gpiofunc:	mux value of gpio function
 104 * @node:	list node
 105 */
 106struct pcs_gpiofunc_range {
 107	unsigned offset;
 108	unsigned npins;
 109	unsigned gpiofunc;
 110	struct list_head node;
 111};
 112
 113/**
 114 * struct pcs_data - wrapper for data needed by pinctrl framework
 115 * @pa:		pindesc array
 116 * @cur:	index to current element
 117 *
 118 * REVISIT: We should be able to drop this eventually by adding
 119 * support for registering pins individually in the pinctrl
 120 * framework for those drivers that don't need a static array.
 121 */
 122struct pcs_data {
 123	struct pinctrl_pin_desc *pa;
 124	int cur;
 125};
 126
 127/**
 128 * struct pcs_soc_data - SoC specific settings
 129 * @flags:	initial SoC specific PCS_FEAT_xxx values
 130 * @irq:	optional interrupt for the controller
 131 * @irq_enable_mask:	optional SoC specific interrupt enable mask
 132 * @irq_status_mask:	optional SoC specific interrupt status mask
 133 * @rearm:	optional SoC specific wake-up rearm function
 134 */
 135struct pcs_soc_data {
 136	unsigned flags;
 137	int irq;
 138	unsigned irq_enable_mask;
 139	unsigned irq_status_mask;
 140	void (*rearm)(void);
 141};
 142
 143/**
 144 * struct pcs_device - pinctrl device instance
 145 * @res:	resources
 146 * @base:	virtual address of the controller
 
 147 * @size:	size of the ioremapped area
 148 * @dev:	device entry
 149 * @np:		device tree node
 150 * @pctl:	pin controller device
 151 * @flags:	mask of PCS_FEAT_xxx values
 152 * @missing_nr_pinctrl_cells: for legacy binding, may go away
 153 * @socdata:	soc specific data
 154 * @lock:	spinlock for register access
 155 * @mutex:	mutex protecting the lists
 156 * @width:	bits per mux register
 157 * @fmask:	function register mask
 158 * @fshift:	function register shift
 159 * @foff:	value to turn mux off
 160 * @fmax:	max number of functions in fmask
 161 * @bits_per_mux: number of bits per mux
 162 * @bits_per_pin: number of bits per pin
 163 * @pins:	physical pins on the SoC
 164 * @gpiofuncs:	list of gpio functions
 165 * @irqs:	list of interrupt registers
 166 * @chip:	chip container for this instance
 167 * @domain:	IRQ domain for this instance
 168 * @desc:	pin controller descriptor
 169 * @read:	register read function to use
 170 * @write:	register write function to use
 171 */
 172struct pcs_device {
 173	struct resource *res;
 174	void __iomem *base;
 
 175	unsigned size;
 176	struct device *dev;
 177	struct device_node *np;
 178	struct pinctrl_dev *pctl;
 179	unsigned flags;
 
 180#define PCS_QUIRK_SHARED_IRQ	(1 << 2)
 181#define PCS_FEAT_IRQ		(1 << 1)
 182#define PCS_FEAT_PINCONF	(1 << 0)
 183	struct property *missing_nr_pinctrl_cells;
 184	struct pcs_soc_data socdata;
 185	raw_spinlock_t lock;
 186	struct mutex mutex;
 187	unsigned width;
 188	unsigned fmask;
 189	unsigned fshift;
 190	unsigned foff;
 191	unsigned fmax;
 192	bool bits_per_mux;
 193	unsigned bits_per_pin;
 194	struct pcs_data pins;
 195	struct list_head gpiofuncs;
 196	struct list_head irqs;
 197	struct irq_chip chip;
 198	struct irq_domain *domain;
 199	struct pinctrl_desc desc;
 200	unsigned (*read)(void __iomem *reg);
 201	void (*write)(unsigned val, void __iomem *reg);
 202};
 203
 204#define PCS_QUIRK_HAS_SHARED_IRQ	(pcs->flags & PCS_QUIRK_SHARED_IRQ)
 205#define PCS_HAS_IRQ		(pcs->flags & PCS_FEAT_IRQ)
 206#define PCS_HAS_PINCONF		(pcs->flags & PCS_FEAT_PINCONF)
 207
 208static int pcs_pinconf_get(struct pinctrl_dev *pctldev, unsigned pin,
 209			   unsigned long *config);
 210static int pcs_pinconf_set(struct pinctrl_dev *pctldev, unsigned pin,
 211			   unsigned long *configs, unsigned num_configs);
 212
 213static enum pin_config_param pcs_bias[] = {
 214	PIN_CONFIG_BIAS_PULL_DOWN,
 215	PIN_CONFIG_BIAS_PULL_UP,
 216};
 217
 218/*
 219 * This lock class tells lockdep that irqchip core that this single
 220 * pinctrl can be in a different category than its parents, so it won't
 221 * report false recursion.
 222 */
 223static struct lock_class_key pcs_lock_class;
 224
 225/* Class for the IRQ request mutex */
 226static struct lock_class_key pcs_request_class;
 227
 228/*
 229 * REVISIT: Reads and writes could eventually use regmap or something
 230 * generic. But at least on omaps, some mux registers are performance
 231 * critical as they may need to be remuxed every time before and after
 232 * idle. Adding tests for register access width for every read and
 233 * write like regmap is doing is not desired, and caching the registers
 234 * does not help in this case.
 235 */
 236
 237static unsigned __maybe_unused pcs_readb(void __iomem *reg)
 238{
 239	return readb(reg);
 240}
 241
 242static unsigned __maybe_unused pcs_readw(void __iomem *reg)
 243{
 244	return readw(reg);
 245}
 246
 247static unsigned __maybe_unused pcs_readl(void __iomem *reg)
 248{
 249	return readl(reg);
 250}
 251
 252static void __maybe_unused pcs_writeb(unsigned val, void __iomem *reg)
 253{
 254	writeb(val, reg);
 255}
 256
 257static void __maybe_unused pcs_writew(unsigned val, void __iomem *reg)
 258{
 259	writew(val, reg);
 260}
 261
 262static void __maybe_unused pcs_writel(unsigned val, void __iomem *reg)
 263{
 264	writel(val, reg);
 265}
 266
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 267static void pcs_pin_dbg_show(struct pinctrl_dev *pctldev,
 268					struct seq_file *s,
 269					unsigned pin)
 270{
 271	struct pcs_device *pcs;
 272	unsigned val, mux_bytes;
 273	unsigned long offset;
 274	size_t pa;
 275
 276	pcs = pinctrl_dev_get_drvdata(pctldev);
 277
 278	mux_bytes = pcs->width / BITS_PER_BYTE;
 279	offset = pin * mux_bytes;
 280	val = pcs->read(pcs->base + offset);
 
 
 
 
 281	pa = pcs->res->start + offset;
 282
 283	seq_printf(s, "%zx %08x %s ", pa, val, DRIVER_NAME);
 284}
 285
 286static void pcs_dt_free_map(struct pinctrl_dev *pctldev,
 287				struct pinctrl_map *map, unsigned num_maps)
 288{
 289	struct pcs_device *pcs;
 290
 291	pcs = pinctrl_dev_get_drvdata(pctldev);
 292	devm_kfree(pcs->dev, map);
 293}
 294
 295static int pcs_dt_node_to_map(struct pinctrl_dev *pctldev,
 296				struct device_node *np_config,
 297				struct pinctrl_map **map, unsigned *num_maps);
 298
 299static const struct pinctrl_ops pcs_pinctrl_ops = {
 300	.get_groups_count = pinctrl_generic_get_group_count,
 301	.get_group_name = pinctrl_generic_get_group_name,
 302	.get_group_pins = pinctrl_generic_get_group_pins,
 303	.pin_dbg_show = pcs_pin_dbg_show,
 304	.dt_node_to_map = pcs_dt_node_to_map,
 305	.dt_free_map = pcs_dt_free_map,
 306};
 307
 308static int pcs_get_function(struct pinctrl_dev *pctldev, unsigned pin,
 309			    struct pcs_function **func)
 310{
 311	struct pcs_device *pcs = pinctrl_dev_get_drvdata(pctldev);
 312	struct pin_desc *pdesc = pin_desc_get(pctldev, pin);
 313	const struct pinctrl_setting_mux *setting;
 314	struct function_desc *function;
 315	unsigned fselector;
 316
 317	/* If pin is not described in DTS & enabled, mux_setting is NULL. */
 318	setting = pdesc->mux_setting;
 319	if (!setting)
 320		return -ENOTSUPP;
 321	fselector = setting->func;
 322	function = pinmux_generic_get_function(pctldev, fselector);
 
 
 323	*func = function->data;
 324	if (!(*func)) {
 325		dev_err(pcs->dev, "%s could not find function%i\n",
 326			__func__, fselector);
 327		return -ENOTSUPP;
 328	}
 329	return 0;
 330}
 331
 332static int pcs_set_mux(struct pinctrl_dev *pctldev, unsigned fselector,
 333	unsigned group)
 334{
 335	struct pcs_device *pcs;
 336	struct function_desc *function;
 337	struct pcs_function *func;
 338	int i;
 339
 340	pcs = pinctrl_dev_get_drvdata(pctldev);
 341	/* If function mask is null, needn't enable it. */
 342	if (!pcs->fmask)
 343		return 0;
 344	function = pinmux_generic_get_function(pctldev, fselector);
 
 
 345	func = function->data;
 346	if (!func)
 347		return -EINVAL;
 348
 349	dev_dbg(pcs->dev, "enabling %s function%i\n",
 350		func->name, fselector);
 351
 352	for (i = 0; i < func->nvals; i++) {
 353		struct pcs_func_vals *vals;
 354		unsigned long flags;
 355		unsigned val, mask;
 356
 357		vals = &func->vals[i];
 358		raw_spin_lock_irqsave(&pcs->lock, flags);
 359		val = pcs->read(vals->reg);
 360
 361		if (pcs->bits_per_mux)
 362			mask = vals->mask;
 363		else
 364			mask = pcs->fmask;
 365
 366		val &= ~mask;
 367		val |= (vals->val & mask);
 368		pcs->write(val, vals->reg);
 369		raw_spin_unlock_irqrestore(&pcs->lock, flags);
 370	}
 371
 372	return 0;
 373}
 374
 375static int pcs_request_gpio(struct pinctrl_dev *pctldev,
 376			    struct pinctrl_gpio_range *range, unsigned pin)
 377{
 378	struct pcs_device *pcs = pinctrl_dev_get_drvdata(pctldev);
 379	struct pcs_gpiofunc_range *frange = NULL;
 380	struct list_head *pos, *tmp;
 381	int mux_bytes = 0;
 382	unsigned data;
 383
 384	/* If function mask is null, return directly. */
 385	if (!pcs->fmask)
 386		return -ENOTSUPP;
 387
 388	list_for_each_safe(pos, tmp, &pcs->gpiofuncs) {
 
 
 389		frange = list_entry(pos, struct pcs_gpiofunc_range, node);
 390		if (pin >= frange->offset + frange->npins
 391			|| pin < frange->offset)
 392			continue;
 393		mux_bytes = pcs->width / BITS_PER_BYTE;
 
 394
 395		if (pcs->bits_per_mux) {
 396			int byte_num, offset, pin_shift;
 397
 398			byte_num = (pcs->bits_per_pin * pin) / BITS_PER_BYTE;
 399			offset = (byte_num / mux_bytes) * mux_bytes;
 400			pin_shift = pin % (pcs->width / pcs->bits_per_pin) *
 401				    pcs->bits_per_pin;
 402
 403			data = pcs->read(pcs->base + offset);
 404			data &= ~(pcs->fmask << pin_shift);
 405			data |= frange->gpiofunc << pin_shift;
 406			pcs->write(data, pcs->base + offset);
 407		} else {
 408			data = pcs->read(pcs->base + pin * mux_bytes);
 409			data &= ~pcs->fmask;
 410			data |= frange->gpiofunc;
 411			pcs->write(data, pcs->base + pin * mux_bytes);
 412		}
 413		break;
 414	}
 415	return 0;
 416}
 417
 418static const struct pinmux_ops pcs_pinmux_ops = {
 419	.get_functions_count = pinmux_generic_get_function_count,
 420	.get_function_name = pinmux_generic_get_function_name,
 421	.get_function_groups = pinmux_generic_get_function_groups,
 422	.set_mux = pcs_set_mux,
 423	.gpio_request_enable = pcs_request_gpio,
 424};
 425
 426/* Clear BIAS value */
 427static void pcs_pinconf_clear_bias(struct pinctrl_dev *pctldev, unsigned pin)
 428{
 429	unsigned long config;
 430	int i;
 431	for (i = 0; i < ARRAY_SIZE(pcs_bias); i++) {
 432		config = pinconf_to_config_packed(pcs_bias[i], 0);
 433		pcs_pinconf_set(pctldev, pin, &config, 1);
 434	}
 435}
 436
 437/*
 438 * Check whether PIN_CONFIG_BIAS_DISABLE is valid.
 439 * It's depend on that PULL_DOWN & PULL_UP configs are all invalid.
 440 */
 441static bool pcs_pinconf_bias_disable(struct pinctrl_dev *pctldev, unsigned pin)
 442{
 443	unsigned long config;
 444	int i;
 445
 446	for (i = 0; i < ARRAY_SIZE(pcs_bias); i++) {
 447		config = pinconf_to_config_packed(pcs_bias[i], 0);
 448		if (!pcs_pinconf_get(pctldev, pin, &config))
 449			goto out;
 450	}
 451	return true;
 452out:
 453	return false;
 454}
 455
 456static int pcs_pinconf_get(struct pinctrl_dev *pctldev,
 457				unsigned pin, unsigned long *config)
 458{
 459	struct pcs_device *pcs = pinctrl_dev_get_drvdata(pctldev);
 460	struct pcs_function *func;
 461	enum pin_config_param param;
 462	unsigned offset = 0, data = 0, i, j, ret;
 463
 464	ret = pcs_get_function(pctldev, pin, &func);
 465	if (ret)
 466		return ret;
 467
 468	for (i = 0; i < func->nconfs; i++) {
 469		param = pinconf_to_config_param(*config);
 470		if (param == PIN_CONFIG_BIAS_DISABLE) {
 471			if (pcs_pinconf_bias_disable(pctldev, pin)) {
 472				*config = 0;
 473				return 0;
 474			} else {
 475				return -ENOTSUPP;
 476			}
 477		} else if (param != func->conf[i].param) {
 478			continue;
 479		}
 480
 481		offset = pin * (pcs->width / BITS_PER_BYTE);
 482		data = pcs->read(pcs->base + offset) & func->conf[i].mask;
 483		switch (func->conf[i].param) {
 484		/* 4 parameters */
 485		case PIN_CONFIG_BIAS_PULL_DOWN:
 486		case PIN_CONFIG_BIAS_PULL_UP:
 487		case PIN_CONFIG_INPUT_SCHMITT_ENABLE:
 488			if ((data != func->conf[i].enable) ||
 489			    (data == func->conf[i].disable))
 490				return -ENOTSUPP;
 491			*config = 0;
 492			break;
 493		/* 2 parameters */
 494		case PIN_CONFIG_INPUT_SCHMITT:
 495			for (j = 0; j < func->nconfs; j++) {
 496				switch (func->conf[j].param) {
 497				case PIN_CONFIG_INPUT_SCHMITT_ENABLE:
 498					if (data != func->conf[j].enable)
 499						return -ENOTSUPP;
 500					break;
 501				default:
 502					break;
 503				}
 504			}
 505			*config = data;
 506			break;
 507		case PIN_CONFIG_DRIVE_STRENGTH:
 508		case PIN_CONFIG_SLEW_RATE:
 509		case PIN_CONFIG_LOW_POWER_MODE:
 
 510		default:
 511			*config = data;
 512			break;
 513		}
 514		return 0;
 515	}
 516	return -ENOTSUPP;
 517}
 518
 519static int pcs_pinconf_set(struct pinctrl_dev *pctldev,
 520				unsigned pin, unsigned long *configs,
 521				unsigned num_configs)
 522{
 523	struct pcs_device *pcs = pinctrl_dev_get_drvdata(pctldev);
 524	struct pcs_function *func;
 525	unsigned offset = 0, shift = 0, i, data, ret;
 526	u32 arg;
 527	int j;
 
 528
 529	ret = pcs_get_function(pctldev, pin, &func);
 530	if (ret)
 531		return ret;
 532
 533	for (j = 0; j < num_configs; j++) {
 
 
 
 
 
 
 
 
 
 534		for (i = 0; i < func->nconfs; i++) {
 535			if (pinconf_to_config_param(configs[j])
 536				!= func->conf[i].param)
 537				continue;
 538
 539			offset = pin * (pcs->width / BITS_PER_BYTE);
 540			data = pcs->read(pcs->base + offset);
 541			arg = pinconf_to_config_argument(configs[j]);
 542			switch (func->conf[i].param) {
 543			/* 2 parameters */
 544			case PIN_CONFIG_INPUT_SCHMITT:
 545			case PIN_CONFIG_DRIVE_STRENGTH:
 546			case PIN_CONFIG_SLEW_RATE:
 547			case PIN_CONFIG_LOW_POWER_MODE:
 
 548				shift = ffs(func->conf[i].mask) - 1;
 549				data &= ~func->conf[i].mask;
 550				data |= (arg << shift) & func->conf[i].mask;
 551				break;
 552			/* 4 parameters */
 553			case PIN_CONFIG_BIAS_DISABLE:
 554				pcs_pinconf_clear_bias(pctldev, pin);
 555				break;
 556			case PIN_CONFIG_BIAS_PULL_DOWN:
 557			case PIN_CONFIG_BIAS_PULL_UP:
 558				if (arg)
 559					pcs_pinconf_clear_bias(pctldev, pin);
 560				/* fall through */
 561			case PIN_CONFIG_INPUT_SCHMITT_ENABLE:
 562				data &= ~func->conf[i].mask;
 563				if (arg)
 564					data |= func->conf[i].enable;
 565				else
 566					data |= func->conf[i].disable;
 567				break;
 568			default:
 569				return -ENOTSUPP;
 570			}
 571			pcs->write(data, pcs->base + offset);
 572
 573			break;
 574		}
 575		if (i >= func->nconfs)
 576			return -ENOTSUPP;
 577	} /* for each config */
 578
 579	return 0;
 580}
 581
 582static int pcs_pinconf_group_get(struct pinctrl_dev *pctldev,
 583				unsigned group, unsigned long *config)
 584{
 585	const unsigned *pins;
 586	unsigned npins, old = 0;
 587	int i, ret;
 588
 589	ret = pinctrl_generic_get_group_pins(pctldev, group, &pins, &npins);
 590	if (ret)
 591		return ret;
 592	for (i = 0; i < npins; i++) {
 593		if (pcs_pinconf_get(pctldev, pins[i], config))
 594			return -ENOTSUPP;
 595		/* configs do not match between two pins */
 596		if (i && (old != *config))
 597			return -ENOTSUPP;
 598		old = *config;
 599	}
 600	return 0;
 601}
 602
 603static int pcs_pinconf_group_set(struct pinctrl_dev *pctldev,
 604				unsigned group, unsigned long *configs,
 605				unsigned num_configs)
 606{
 607	const unsigned *pins;
 608	unsigned npins;
 609	int i, ret;
 610
 611	ret = pinctrl_generic_get_group_pins(pctldev, group, &pins, &npins);
 612	if (ret)
 613		return ret;
 614	for (i = 0; i < npins; i++) {
 615		if (pcs_pinconf_set(pctldev, pins[i], configs, num_configs))
 616			return -ENOTSUPP;
 617	}
 618	return 0;
 619}
 620
 621static void pcs_pinconf_dbg_show(struct pinctrl_dev *pctldev,
 622				struct seq_file *s, unsigned pin)
 623{
 624}
 625
 626static void pcs_pinconf_group_dbg_show(struct pinctrl_dev *pctldev,
 627				struct seq_file *s, unsigned selector)
 628{
 629}
 630
 631static void pcs_pinconf_config_dbg_show(struct pinctrl_dev *pctldev,
 632					struct seq_file *s,
 633					unsigned long config)
 634{
 635	pinconf_generic_dump_config(pctldev, s, config);
 636}
 637
 638static const struct pinconf_ops pcs_pinconf_ops = {
 639	.pin_config_get = pcs_pinconf_get,
 640	.pin_config_set = pcs_pinconf_set,
 641	.pin_config_group_get = pcs_pinconf_group_get,
 642	.pin_config_group_set = pcs_pinconf_group_set,
 643	.pin_config_dbg_show = pcs_pinconf_dbg_show,
 644	.pin_config_group_dbg_show = pcs_pinconf_group_dbg_show,
 645	.pin_config_config_dbg_show = pcs_pinconf_config_dbg_show,
 646	.is_generic = true,
 647};
 648
 649/**
 650 * pcs_add_pin() - add a pin to the static per controller pin array
 651 * @pcs: pcs driver instance
 652 * @offset: register offset from base
 653 */
 654static int pcs_add_pin(struct pcs_device *pcs, unsigned offset,
 655		unsigned pin_pos)
 656{
 657	struct pcs_soc_data *pcs_soc = &pcs->socdata;
 658	struct pinctrl_pin_desc *pin;
 659	int i;
 660
 661	i = pcs->pins.cur;
 662	if (i >= pcs->desc.npins) {
 663		dev_err(pcs->dev, "too many pins, max %i\n",
 664			pcs->desc.npins);
 665		return -ENOMEM;
 666	}
 667
 668	if (pcs_soc->irq_enable_mask) {
 669		unsigned val;
 670
 671		val = pcs->read(pcs->base + offset);
 672		if (val & pcs_soc->irq_enable_mask) {
 673			dev_dbg(pcs->dev, "irq enabled at boot for pin at %lx (%x), clearing\n",
 674				(unsigned long)pcs->res->start + offset, val);
 675			val &= ~pcs_soc->irq_enable_mask;
 676			pcs->write(val, pcs->base + offset);
 677		}
 678	}
 679
 680	pin = &pcs->pins.pa[i];
 681	pin->number = i;
 682	pcs->pins.cur++;
 683
 684	return i;
 685}
 686
 687/**
 688 * pcs_allocate_pin_table() - adds all the pins for the pinctrl driver
 689 * @pcs: pcs driver instance
 690 *
 691 * In case of errors, resources are freed in pcs_free_resources.
 692 *
 693 * If your hardware needs holes in the address space, then just set
 694 * up multiple driver instances.
 695 */
 696static int pcs_allocate_pin_table(struct pcs_device *pcs)
 697{
 698	int mux_bytes, nr_pins, i;
 699	int num_pins_in_register = 0;
 700
 701	mux_bytes = pcs->width / BITS_PER_BYTE;
 702
 703	if (pcs->bits_per_mux) {
 704		pcs->bits_per_pin = fls(pcs->fmask);
 705		nr_pins = (pcs->size * BITS_PER_BYTE) / pcs->bits_per_pin;
 706		num_pins_in_register = pcs->width / pcs->bits_per_pin;
 707	} else {
 708		nr_pins = pcs->size / mux_bytes;
 709	}
 710
 711	dev_dbg(pcs->dev, "allocating %i pins\n", nr_pins);
 712	pcs->pins.pa = devm_kzalloc(pcs->dev,
 713				sizeof(*pcs->pins.pa) * nr_pins,
 714				GFP_KERNEL);
 715	if (!pcs->pins.pa)
 716		return -ENOMEM;
 717
 718	pcs->desc.pins = pcs->pins.pa;
 719	pcs->desc.npins = nr_pins;
 720
 721	for (i = 0; i < pcs->desc.npins; i++) {
 722		unsigned offset;
 723		int res;
 724		int byte_num;
 725		int pin_pos = 0;
 726
 727		if (pcs->bits_per_mux) {
 728			byte_num = (pcs->bits_per_pin * i) / BITS_PER_BYTE;
 729			offset = (byte_num / mux_bytes) * mux_bytes;
 730			pin_pos = i % num_pins_in_register;
 731		} else {
 732			offset = i * mux_bytes;
 733		}
 734		res = pcs_add_pin(pcs, offset, pin_pos);
 735		if (res < 0) {
 736			dev_err(pcs->dev, "error adding pins: %i\n", res);
 737			return res;
 738		}
 739	}
 740
 741	return 0;
 742}
 743
 744/**
 745 * pcs_add_function() - adds a new function to the function list
 746 * @pcs: pcs driver instance
 747 * @np: device node of the mux entry
 748 * @name: name of the function
 749 * @vals: array of mux register value pairs used by the function
 750 * @nvals: number of mux register value pairs
 751 * @pgnames: array of pingroup names for the function
 752 * @npgnames: number of pingroup names
 
 
 753 */
 754static struct pcs_function *pcs_add_function(struct pcs_device *pcs,
 755					struct device_node *np,
 756					const char *name,
 757					struct pcs_func_vals *vals,
 758					unsigned nvals,
 759					const char **pgnames,
 760					unsigned npgnames)
 761{
 762	struct pcs_function *function;
 763	int res;
 764
 765	function = devm_kzalloc(pcs->dev, sizeof(*function), GFP_KERNEL);
 766	if (!function)
 767		return NULL;
 768
 769	function->vals = vals;
 770	function->nvals = nvals;
 
 771
 772	res = pinmux_generic_add_function(pcs->pctl, name,
 773					  pgnames, npgnames,
 774					  function);
 775	if (res)
 776		return NULL;
 
 
 
 
 777
 778	return function;
 779}
 780
 781/**
 782 * pcs_get_pin_by_offset() - get a pin index based on the register offset
 783 * @pcs: pcs driver instance
 784 * @offset: register offset from the base
 785 *
 786 * Note that this is OK as long as the pins are in a static array.
 787 */
 788static int pcs_get_pin_by_offset(struct pcs_device *pcs, unsigned offset)
 789{
 790	unsigned index;
 791
 792	if (offset >= pcs->size) {
 793		dev_err(pcs->dev, "mux offset out of range: 0x%x (0x%x)\n",
 794			offset, pcs->size);
 795		return -EINVAL;
 796	}
 797
 798	if (pcs->bits_per_mux)
 799		index = (offset * BITS_PER_BYTE) / pcs->bits_per_pin;
 800	else
 801		index = offset / (pcs->width / BITS_PER_BYTE);
 802
 803	return index;
 804}
 805
 806/*
 807 * check whether data matches enable bits or disable bits
 808 * Return value: 1 for matching enable bits, 0 for matching disable bits,
 809 *               and negative value for matching failure.
 810 */
 811static int pcs_config_match(unsigned data, unsigned enable, unsigned disable)
 812{
 813	int ret = -EINVAL;
 814
 815	if (data == enable)
 816		ret = 1;
 817	else if (data == disable)
 818		ret = 0;
 819	return ret;
 820}
 821
 822static void add_config(struct pcs_conf_vals **conf, enum pin_config_param param,
 823		       unsigned value, unsigned enable, unsigned disable,
 824		       unsigned mask)
 825{
 826	(*conf)->param = param;
 827	(*conf)->val = value;
 828	(*conf)->enable = enable;
 829	(*conf)->disable = disable;
 830	(*conf)->mask = mask;
 831	(*conf)++;
 832}
 833
 834static void add_setting(unsigned long **setting, enum pin_config_param param,
 835			unsigned arg)
 836{
 837	**setting = pinconf_to_config_packed(param, arg);
 838	(*setting)++;
 839}
 840
 841/* add pinconf setting with 2 parameters */
 842static void pcs_add_conf2(struct pcs_device *pcs, struct device_node *np,
 843			  const char *name, enum pin_config_param param,
 844			  struct pcs_conf_vals **conf, unsigned long **settings)
 845{
 846	unsigned value[2], shift;
 847	int ret;
 848
 849	ret = of_property_read_u32_array(np, name, value, 2);
 850	if (ret)
 851		return;
 852	/* set value & mask */
 853	value[0] &= value[1];
 854	shift = ffs(value[1]) - 1;
 855	/* skip enable & disable */
 856	add_config(conf, param, value[0], 0, 0, value[1]);
 857	add_setting(settings, param, value[0] >> shift);
 858}
 859
 860/* add pinconf setting with 4 parameters */
 861static void pcs_add_conf4(struct pcs_device *pcs, struct device_node *np,
 862			  const char *name, enum pin_config_param param,
 863			  struct pcs_conf_vals **conf, unsigned long **settings)
 864{
 865	unsigned value[4];
 866	int ret;
 867
 868	/* value to set, enable, disable, mask */
 869	ret = of_property_read_u32_array(np, name, value, 4);
 870	if (ret)
 871		return;
 872	if (!value[3]) {
 873		dev_err(pcs->dev, "mask field of the property can't be 0\n");
 874		return;
 875	}
 876	value[0] &= value[3];
 877	value[1] &= value[3];
 878	value[2] &= value[3];
 879	ret = pcs_config_match(value[0], value[1], value[2]);
 880	if (ret < 0)
 881		dev_dbg(pcs->dev, "failed to match enable or disable bits\n");
 882	add_config(conf, param, value[0], value[1], value[2], value[3]);
 883	add_setting(settings, param, ret);
 884}
 885
 886static int pcs_parse_pinconf(struct pcs_device *pcs, struct device_node *np,
 887			     struct pcs_function *func,
 888			     struct pinctrl_map **map)
 889
 890{
 891	struct pinctrl_map *m = *map;
 892	int i = 0, nconfs = 0;
 893	unsigned long *settings = NULL, *s = NULL;
 894	struct pcs_conf_vals *conf = NULL;
 895	static const struct pcs_conf_type prop2[] = {
 896		{ "pinctrl-single,drive-strength", PIN_CONFIG_DRIVE_STRENGTH, },
 897		{ "pinctrl-single,slew-rate", PIN_CONFIG_SLEW_RATE, },
 
 898		{ "pinctrl-single,input-schmitt", PIN_CONFIG_INPUT_SCHMITT, },
 899		{ "pinctrl-single,low-power-mode", PIN_CONFIG_LOW_POWER_MODE, },
 900	};
 901	static const struct pcs_conf_type prop4[] = {
 902		{ "pinctrl-single,bias-pullup", PIN_CONFIG_BIAS_PULL_UP, },
 903		{ "pinctrl-single,bias-pulldown", PIN_CONFIG_BIAS_PULL_DOWN, },
 904		{ "pinctrl-single,input-schmitt-enable",
 905			PIN_CONFIG_INPUT_SCHMITT_ENABLE, },
 906	};
 907
 908	/* If pinconf isn't supported, don't parse properties in below. */
 909	if (!PCS_HAS_PINCONF)
 910		return 0;
 911
 912	/* cacluate how much properties are supported in current node */
 913	for (i = 0; i < ARRAY_SIZE(prop2); i++) {
 914		if (of_find_property(np, prop2[i].name, NULL))
 915			nconfs++;
 916	}
 917	for (i = 0; i < ARRAY_SIZE(prop4); i++) {
 918		if (of_find_property(np, prop4[i].name, NULL))
 919			nconfs++;
 920	}
 921	if (!nconfs)
 922		return 0;
 923
 924	func->conf = devm_kzalloc(pcs->dev,
 925				  sizeof(struct pcs_conf_vals) * nconfs,
 926				  GFP_KERNEL);
 927	if (!func->conf)
 928		return -ENOMEM;
 929	func->nconfs = nconfs;
 930	conf = &(func->conf[0]);
 931	m++;
 932	settings = devm_kzalloc(pcs->dev, sizeof(unsigned long) * nconfs,
 933				GFP_KERNEL);
 934	if (!settings)
 935		return -ENOMEM;
 936	s = &settings[0];
 937
 938	for (i = 0; i < ARRAY_SIZE(prop2); i++)
 939		pcs_add_conf2(pcs, np, prop2[i].name, prop2[i].param,
 940			      &conf, &s);
 941	for (i = 0; i < ARRAY_SIZE(prop4); i++)
 942		pcs_add_conf4(pcs, np, prop4[i].name, prop4[i].param,
 943			      &conf, &s);
 944	m->type = PIN_MAP_TYPE_CONFIGS_GROUP;
 945	m->data.configs.group_or_pin = np->name;
 946	m->data.configs.configs = settings;
 947	m->data.configs.num_configs = nconfs;
 948	return 0;
 949}
 950
 951/**
 952 * smux_parse_one_pinctrl_entry() - parses a device tree mux entry
 953 * @pctldev: pin controller device
 954 * @pcs: pinctrl driver instance
 955 * @np: device node of the mux entry
 956 * @map: map entry
 957 * @num_maps: number of map
 958 * @pgnames: pingroup names
 959 *
 960 * Note that this binding currently supports only sets of one register + value.
 961 *
 962 * Also note that this driver tries to avoid understanding pin and function
 963 * names because of the extra bloat they would cause especially in the case of
 964 * a large number of pins. This driver just sets what is specified for the board
 965 * in the .dts file. Further user space debugging tools can be developed to
 966 * decipher the pin and function names using debugfs.
 967 *
 968 * If you are concerned about the boot time, set up the static pins in
 969 * the bootloader, and only set up selected pins as device tree entries.
 970 */
 971static int pcs_parse_one_pinctrl_entry(struct pcs_device *pcs,
 972						struct device_node *np,
 973						struct pinctrl_map **map,
 974						unsigned *num_maps,
 975						const char **pgnames)
 976{
 977	const char *name = "pinctrl-single,pins";
 978	struct pcs_func_vals *vals;
 979	int rows, *pins, found = 0, res = -ENOMEM, i;
 980	struct pcs_function *function;
 981
 982	rows = pinctrl_count_index_with_args(np, name);
 983	if (rows <= 0) {
 984		dev_err(pcs->dev, "Invalid number of rows: %d\n", rows);
 985		return -EINVAL;
 986	}
 987
 988	vals = devm_kzalloc(pcs->dev, sizeof(*vals) * rows, GFP_KERNEL);
 989	if (!vals)
 990		return -ENOMEM;
 991
 992	pins = devm_kzalloc(pcs->dev, sizeof(*pins) * rows, GFP_KERNEL);
 993	if (!pins)
 994		goto free_vals;
 995
 996	for (i = 0; i < rows; i++) {
 997		struct of_phandle_args pinctrl_spec;
 998		unsigned int offset;
 999		int pin;
1000
1001		res = pinctrl_parse_index_with_args(np, name, i, &pinctrl_spec);
1002		if (res)
1003			return res;
1004
1005		if (pinctrl_spec.args_count < 2) {
1006			dev_err(pcs->dev, "invalid args_count for spec: %i\n",
1007				pinctrl_spec.args_count);
1008			break;
1009		}
1010
1011		/* Index plus one value cell */
1012		offset = pinctrl_spec.args[0];
1013		vals[found].reg = pcs->base + offset;
1014		vals[found].val = pinctrl_spec.args[1];
1015
1016		dev_dbg(pcs->dev, "%s index: 0x%x value: 0x%x\n",
1017			pinctrl_spec.np->name, offset, pinctrl_spec.args[1]);
 
 
 
 
 
 
 
 
 
1018
1019		pin = pcs_get_pin_by_offset(pcs, offset);
1020		if (pin < 0) {
1021			dev_err(pcs->dev,
1022				"could not add functions for %s %ux\n",
1023				np->name, offset);
1024			break;
1025		}
1026		pins[found++] = pin;
1027	}
1028
1029	pgnames[0] = np->name;
1030	function = pcs_add_function(pcs, np, np->name, vals, found, pgnames, 1);
1031	if (!function) {
1032		res = -ENOMEM;
 
 
1033		goto free_pins;
1034	}
1035
1036	res = pinctrl_generic_add_group(pcs->pctl, np->name, pins, found, pcs);
1037	if (res < 0)
 
1038		goto free_function;
 
1039
1040	(*map)->type = PIN_MAP_TYPE_MUX_GROUP;
1041	(*map)->data.mux.group = np->name;
1042	(*map)->data.mux.function = np->name;
1043
1044	if (PCS_HAS_PINCONF) {
1045		res = pcs_parse_pinconf(pcs, np, function, map);
1046		if (res)
 
 
 
 
1047			goto free_pingroups;
1048		*num_maps = 2;
1049	} else {
1050		*num_maps = 1;
1051	}
 
 
1052	return 0;
1053
1054free_pingroups:
1055	pinctrl_generic_remove_last_group(pcs->pctl);
1056	*num_maps = 1;
1057free_function:
1058	pinmux_generic_remove_last_function(pcs->pctl);
1059
1060free_pins:
 
1061	devm_kfree(pcs->dev, pins);
1062
1063free_vals:
1064	devm_kfree(pcs->dev, vals);
1065
1066	return res;
1067}
1068
1069static int pcs_parse_bits_in_pinctrl_entry(struct pcs_device *pcs,
1070						struct device_node *np,
1071						struct pinctrl_map **map,
1072						unsigned *num_maps,
1073						const char **pgnames)
1074{
1075	const char *name = "pinctrl-single,bits";
1076	struct pcs_func_vals *vals;
1077	int rows, *pins, found = 0, res = -ENOMEM, i;
1078	int npins_in_row;
1079	struct pcs_function *function;
1080
1081	rows = pinctrl_count_index_with_args(np, name);
1082	if (rows <= 0) {
1083		dev_err(pcs->dev, "Invalid number of rows: %d\n", rows);
1084		return -EINVAL;
1085	}
1086
 
 
 
 
 
1087	npins_in_row = pcs->width / pcs->bits_per_pin;
1088
1089	vals = devm_kzalloc(pcs->dev, sizeof(*vals) * rows * npins_in_row,
1090			GFP_KERNEL);
 
1091	if (!vals)
1092		return -ENOMEM;
1093
1094	pins = devm_kzalloc(pcs->dev, sizeof(*pins) * rows * npins_in_row,
1095			GFP_KERNEL);
 
1096	if (!pins)
1097		goto free_vals;
1098
1099	for (i = 0; i < rows; i++) {
1100		struct of_phandle_args pinctrl_spec;
1101		unsigned offset, val;
1102		unsigned mask, bit_pos, val_pos, mask_pos, submask;
1103		unsigned pin_num_from_lsb;
1104		int pin;
1105
1106		res = pinctrl_parse_index_with_args(np, name, i, &pinctrl_spec);
1107		if (res)
1108			return res;
1109
1110		if (pinctrl_spec.args_count < 3) {
1111			dev_err(pcs->dev, "invalid args_count for spec: %i\n",
1112				pinctrl_spec.args_count);
1113			break;
1114		}
1115
1116		/* Index plus two value cells */
1117		offset = pinctrl_spec.args[0];
1118		val = pinctrl_spec.args[1];
1119		mask = pinctrl_spec.args[2];
1120
1121		dev_dbg(pcs->dev, "%s index: 0x%x value: 0x%x mask: 0x%x\n",
1122			pinctrl_spec.np->name, offset, val, mask);
1123
1124		/* Parse pins in each row from LSB */
1125		while (mask) {
1126			bit_pos = __ffs(mask);
1127			pin_num_from_lsb = bit_pos / pcs->bits_per_pin;
1128			mask_pos = ((pcs->fmask) << bit_pos);
1129			val_pos = val & mask_pos;
1130			submask = mask & mask_pos;
1131
1132			if ((mask & mask_pos) == 0) {
1133				dev_err(pcs->dev,
1134					"Invalid mask for %s at 0x%x\n",
1135					np->name, offset);
1136				break;
1137			}
1138
1139			mask &= ~mask_pos;
1140
1141			if (submask != mask_pos) {
1142				dev_warn(pcs->dev,
1143						"Invalid submask 0x%x for %s at 0x%x\n",
1144						submask, np->name, offset);
1145				continue;
1146			}
1147
1148			vals[found].mask = submask;
1149			vals[found].reg = pcs->base + offset;
1150			vals[found].val = val_pos;
1151
1152			pin = pcs_get_pin_by_offset(pcs, offset);
1153			if (pin < 0) {
1154				dev_err(pcs->dev,
1155					"could not add functions for %s %ux\n",
1156					np->name, offset);
1157				break;
1158			}
1159			pins[found++] = pin + pin_num_from_lsb;
1160		}
1161	}
1162
1163	pgnames[0] = np->name;
1164	function = pcs_add_function(pcs, np, np->name, vals, found, pgnames, 1);
1165	if (!function) {
1166		res = -ENOMEM;
 
 
1167		goto free_pins;
1168	}
1169
1170	res = pinctrl_generic_add_group(pcs->pctl, np->name, pins, found, pcs);
1171	if (res < 0)
1172		goto free_function;
1173
1174	(*map)->type = PIN_MAP_TYPE_MUX_GROUP;
1175	(*map)->data.mux.group = np->name;
1176	(*map)->data.mux.function = np->name;
1177
1178	if (PCS_HAS_PINCONF) {
1179		dev_err(pcs->dev, "pinconf not supported\n");
1180		goto free_pingroups;
1181	}
1182
1183	*num_maps = 1;
1184	return 0;
1185
1186free_pingroups:
1187	pinctrl_generic_remove_last_group(pcs->pctl);
1188	*num_maps = 1;
1189free_function:
1190	pinmux_generic_remove_last_function(pcs->pctl);
1191free_pins:
 
1192	devm_kfree(pcs->dev, pins);
1193
1194free_vals:
1195	devm_kfree(pcs->dev, vals);
1196
1197	return res;
1198}
1199/**
1200 * pcs_dt_node_to_map() - allocates and parses pinctrl maps
1201 * @pctldev: pinctrl instance
1202 * @np_config: device tree pinmux entry
1203 * @map: array of map entries
1204 * @num_maps: number of maps
1205 */
1206static int pcs_dt_node_to_map(struct pinctrl_dev *pctldev,
1207				struct device_node *np_config,
1208				struct pinctrl_map **map, unsigned *num_maps)
1209{
1210	struct pcs_device *pcs;
1211	const char **pgnames;
1212	int ret;
1213
1214	pcs = pinctrl_dev_get_drvdata(pctldev);
1215
1216	/* create 2 maps. One is for pinmux, and the other is for pinconf. */
1217	*map = devm_kzalloc(pcs->dev, sizeof(**map) * 2, GFP_KERNEL);
1218	if (!*map)
1219		return -ENOMEM;
1220
1221	*num_maps = 0;
1222
1223	pgnames = devm_kzalloc(pcs->dev, sizeof(*pgnames), GFP_KERNEL);
1224	if (!pgnames) {
1225		ret = -ENOMEM;
1226		goto free_map;
1227	}
1228
1229	if (pcs->bits_per_mux) {
1230		ret = pcs_parse_bits_in_pinctrl_entry(pcs, np_config, map,
1231				num_maps, pgnames);
1232		if (ret < 0) {
1233			dev_err(pcs->dev, "no pins entries for %s\n",
1234				np_config->name);
1235			goto free_pgnames;
1236		}
1237	} else {
1238		ret = pcs_parse_one_pinctrl_entry(pcs, np_config, map,
1239				num_maps, pgnames);
1240		if (ret < 0) {
1241			dev_err(pcs->dev, "no pins entries for %s\n",
1242				np_config->name);
1243			goto free_pgnames;
1244		}
1245	}
1246
1247	return 0;
1248
1249free_pgnames:
1250	devm_kfree(pcs->dev, pgnames);
1251free_map:
1252	devm_kfree(pcs->dev, *map);
1253
1254	return ret;
1255}
1256
1257/**
1258 * pcs_irq_free() - free interrupt
1259 * @pcs: pcs driver instance
1260 */
1261static void pcs_irq_free(struct pcs_device *pcs)
1262{
1263	struct pcs_soc_data *pcs_soc = &pcs->socdata;
1264
1265	if (pcs_soc->irq < 0)
1266		return;
1267
1268	if (pcs->domain)
1269		irq_domain_remove(pcs->domain);
1270
1271	if (PCS_QUIRK_HAS_SHARED_IRQ)
1272		free_irq(pcs_soc->irq, pcs_soc);
1273	else
1274		irq_set_chained_handler(pcs_soc->irq, NULL);
1275}
1276
1277/**
1278 * pcs_free_resources() - free memory used by this driver
1279 * @pcs: pcs driver instance
1280 */
1281static void pcs_free_resources(struct pcs_device *pcs)
1282{
1283	pcs_irq_free(pcs);
1284	pinctrl_unregister(pcs->pctl);
1285
1286#if IS_BUILTIN(CONFIG_PINCTRL_SINGLE)
1287	if (pcs->missing_nr_pinctrl_cells)
1288		of_remove_property(pcs->np, pcs->missing_nr_pinctrl_cells);
1289#endif
1290}
1291
1292static int pcs_add_gpio_func(struct device_node *node, struct pcs_device *pcs)
1293{
1294	const char *propname = "pinctrl-single,gpio-range";
1295	const char *cellname = "#pinctrl-single,gpio-range-cells";
1296	struct of_phandle_args gpiospec;
1297	struct pcs_gpiofunc_range *range;
1298	int ret, i;
1299
1300	for (i = 0; ; i++) {
1301		ret = of_parse_phandle_with_args(node, propname, cellname,
1302						 i, &gpiospec);
1303		/* Do not treat it as error. Only treat it as end condition. */
1304		if (ret) {
1305			ret = 0;
1306			break;
1307		}
1308		range = devm_kzalloc(pcs->dev, sizeof(*range), GFP_KERNEL);
1309		if (!range) {
1310			ret = -ENOMEM;
1311			break;
1312		}
1313		range->offset = gpiospec.args[0];
1314		range->npins = gpiospec.args[1];
1315		range->gpiofunc = gpiospec.args[2];
1316		mutex_lock(&pcs->mutex);
1317		list_add_tail(&range->node, &pcs->gpiofuncs);
1318		mutex_unlock(&pcs->mutex);
1319	}
1320	return ret;
1321}
 
1322/**
 
1323 * @reg:	virtual address of interrupt register
1324 * @hwirq:	hardware irq number
1325 * @irq:	virtual irq number
1326 * @node:	list node
1327 */
1328struct pcs_interrupt {
1329	void __iomem *reg;
1330	irq_hw_number_t hwirq;
1331	unsigned int irq;
1332	struct list_head node;
1333};
1334
1335/**
1336 * pcs_irq_set() - enables or disables an interrupt
 
 
 
1337 *
1338 * Note that this currently assumes one interrupt per pinctrl
1339 * register that is typically used for wake-up events.
1340 */
1341static inline void pcs_irq_set(struct pcs_soc_data *pcs_soc,
1342			       int irq, const bool enable)
1343{
1344	struct pcs_device *pcs;
1345	struct list_head *pos;
1346	unsigned mask;
1347
1348	pcs = container_of(pcs_soc, struct pcs_device, socdata);
1349	list_for_each(pos, &pcs->irqs) {
1350		struct pcs_interrupt *pcswi;
1351		unsigned soc_mask;
1352
1353		pcswi = list_entry(pos, struct pcs_interrupt, node);
1354		if (irq != pcswi->irq)
1355			continue;
1356
1357		soc_mask = pcs_soc->irq_enable_mask;
1358		raw_spin_lock(&pcs->lock);
1359		mask = pcs->read(pcswi->reg);
1360		if (enable)
1361			mask |= soc_mask;
1362		else
1363			mask &= ~soc_mask;
1364		pcs->write(mask, pcswi->reg);
1365
1366		/* flush posted write */
1367		mask = pcs->read(pcswi->reg);
1368		raw_spin_unlock(&pcs->lock);
1369	}
1370
1371	if (pcs_soc->rearm)
1372		pcs_soc->rearm();
1373}
1374
1375/**
1376 * pcs_irq_mask() - mask pinctrl interrupt
1377 * @d: interrupt data
1378 */
1379static void pcs_irq_mask(struct irq_data *d)
1380{
1381	struct pcs_soc_data *pcs_soc = irq_data_get_irq_chip_data(d);
1382
1383	pcs_irq_set(pcs_soc, d->irq, false);
1384}
1385
1386/**
1387 * pcs_irq_unmask() - unmask pinctrl interrupt
1388 * @d: interrupt data
1389 */
1390static void pcs_irq_unmask(struct irq_data *d)
1391{
1392	struct pcs_soc_data *pcs_soc = irq_data_get_irq_chip_data(d);
1393
1394	pcs_irq_set(pcs_soc, d->irq, true);
1395}
1396
1397/**
1398 * pcs_irq_set_wake() - toggle the suspend and resume wake up
1399 * @d: interrupt data
1400 * @state: wake-up state
1401 *
1402 * Note that this should be called only for suspend and resume.
1403 * For runtime PM, the wake-up events should be enabled by default.
1404 */
1405static int pcs_irq_set_wake(struct irq_data *d, unsigned int state)
1406{
1407	if (state)
1408		pcs_irq_unmask(d);
1409	else
1410		pcs_irq_mask(d);
1411
1412	return 0;
1413}
1414
1415/**
1416 * pcs_irq_handle() - common interrupt handler
1417 * @pcs_irq: interrupt data
1418 *
1419 * Note that this currently assumes we have one interrupt bit per
1420 * mux register. This interrupt is typically used for wake-up events.
1421 * For more complex interrupts different handlers can be specified.
1422 */
1423static int pcs_irq_handle(struct pcs_soc_data *pcs_soc)
1424{
1425	struct pcs_device *pcs;
1426	struct list_head *pos;
1427	int count = 0;
1428
1429	pcs = container_of(pcs_soc, struct pcs_device, socdata);
1430	list_for_each(pos, &pcs->irqs) {
1431		struct pcs_interrupt *pcswi;
1432		unsigned mask;
1433
1434		pcswi = list_entry(pos, struct pcs_interrupt, node);
1435		raw_spin_lock(&pcs->lock);
1436		mask = pcs->read(pcswi->reg);
1437		raw_spin_unlock(&pcs->lock);
1438		if (mask & pcs_soc->irq_status_mask) {
1439			generic_handle_irq(irq_find_mapping(pcs->domain,
1440							    pcswi->hwirq));
1441			count++;
1442		}
1443	}
1444
1445	return count;
1446}
1447
1448/**
1449 * pcs_irq_handler() - handler for the shared interrupt case
1450 * @irq: interrupt
1451 * @d: data
1452 *
1453 * Use this for cases where multiple instances of
1454 * pinctrl-single share a single interrupt like on omaps.
1455 */
1456static irqreturn_t pcs_irq_handler(int irq, void *d)
1457{
1458	struct pcs_soc_data *pcs_soc = d;
1459
1460	return pcs_irq_handle(pcs_soc) ? IRQ_HANDLED : IRQ_NONE;
1461}
1462
1463/**
1464 * pcs_irq_handle() - handler for the dedicated chained interrupt case
1465 * @irq: interrupt
1466 * @desc: interrupt descriptor
1467 *
1468 * Use this if you have a separate interrupt for each
1469 * pinctrl-single instance.
1470 */
1471static void pcs_irq_chain_handler(struct irq_desc *desc)
1472{
1473	struct pcs_soc_data *pcs_soc = irq_desc_get_handler_data(desc);
1474	struct irq_chip *chip;
1475
1476	chip = irq_desc_get_chip(desc);
1477	chained_irq_enter(chip, desc);
1478	pcs_irq_handle(pcs_soc);
1479	/* REVISIT: export and add handle_bad_irq(irq, desc)? */
1480	chained_irq_exit(chip, desc);
1481}
1482
1483static int pcs_irqdomain_map(struct irq_domain *d, unsigned int irq,
1484			     irq_hw_number_t hwirq)
1485{
1486	struct pcs_soc_data *pcs_soc = d->host_data;
1487	struct pcs_device *pcs;
1488	struct pcs_interrupt *pcswi;
1489
1490	pcs = container_of(pcs_soc, struct pcs_device, socdata);
1491	pcswi = devm_kzalloc(pcs->dev, sizeof(*pcswi), GFP_KERNEL);
1492	if (!pcswi)
1493		return -ENOMEM;
1494
1495	pcswi->reg = pcs->base + hwirq;
1496	pcswi->hwirq = hwirq;
1497	pcswi->irq = irq;
1498
1499	mutex_lock(&pcs->mutex);
1500	list_add_tail(&pcswi->node, &pcs->irqs);
1501	mutex_unlock(&pcs->mutex);
1502
1503	irq_set_chip_data(irq, pcs_soc);
1504	irq_set_chip_and_handler(irq, &pcs->chip,
1505				 handle_level_irq);
1506	irq_set_lockdep_class(irq, &pcs_lock_class, &pcs_request_class);
1507	irq_set_noprobe(irq);
1508
1509	return 0;
1510}
1511
1512static const struct irq_domain_ops pcs_irqdomain_ops = {
1513	.map = pcs_irqdomain_map,
1514	.xlate = irq_domain_xlate_onecell,
1515};
1516
1517/**
1518 * pcs_irq_init_chained_handler() - set up a chained interrupt handler
1519 * @pcs: pcs driver instance
1520 * @np: device node pointer
1521 */
1522static int pcs_irq_init_chained_handler(struct pcs_device *pcs,
1523					struct device_node *np)
1524{
1525	struct pcs_soc_data *pcs_soc = &pcs->socdata;
1526	const char *name = "pinctrl";
1527	int num_irqs;
1528
1529	if (!pcs_soc->irq_enable_mask ||
1530	    !pcs_soc->irq_status_mask) {
1531		pcs_soc->irq = -1;
1532		return -EINVAL;
1533	}
1534
1535	INIT_LIST_HEAD(&pcs->irqs);
1536	pcs->chip.name = name;
1537	pcs->chip.irq_ack = pcs_irq_mask;
1538	pcs->chip.irq_mask = pcs_irq_mask;
1539	pcs->chip.irq_unmask = pcs_irq_unmask;
1540	pcs->chip.irq_set_wake = pcs_irq_set_wake;
1541
1542	if (PCS_QUIRK_HAS_SHARED_IRQ) {
1543		int res;
1544
1545		res = request_irq(pcs_soc->irq, pcs_irq_handler,
1546				  IRQF_SHARED | IRQF_NO_SUSPEND |
1547				  IRQF_NO_THREAD,
1548				  name, pcs_soc);
1549		if (res) {
1550			pcs_soc->irq = -1;
1551			return res;
1552		}
1553	} else {
1554		irq_set_chained_handler_and_data(pcs_soc->irq,
1555						 pcs_irq_chain_handler,
1556						 pcs_soc);
1557	}
1558
1559	/*
1560	 * We can use the register offset as the hardirq
1561	 * number as irq_domain_add_simple maps them lazily.
1562	 * This way we can easily support more than one
1563	 * interrupt per function if needed.
1564	 */
1565	num_irqs = pcs->size;
1566
1567	pcs->domain = irq_domain_add_simple(np, num_irqs, 0,
1568					    &pcs_irqdomain_ops,
1569					    pcs_soc);
1570	if (!pcs->domain) {
1571		irq_set_chained_handler(pcs_soc->irq, NULL);
1572		return -EINVAL;
1573	}
1574
1575	return 0;
1576}
1577
1578#ifdef CONFIG_PM
1579static int pinctrl_single_suspend(struct platform_device *pdev,
1580					pm_message_t state)
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1581{
1582	struct pcs_device *pcs;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1583
1584	pcs = platform_get_drvdata(pdev);
1585	if (!pcs)
1586		return -EINVAL;
 
1587
1588	return pinctrl_force_sleep(pcs->pctl);
1589}
1590
1591static int pinctrl_single_resume(struct platform_device *pdev)
1592{
1593	struct pcs_device *pcs;
1594
1595	pcs = platform_get_drvdata(pdev);
1596	if (!pcs)
1597		return -EINVAL;
1598
1599	return pinctrl_force_default(pcs->pctl);
1600}
1601#endif
 
 
 
1602
1603/**
1604 * pcs_quirk_missing_pinctrl_cells - handle legacy binding
1605 * @pcs: pinctrl driver instance
1606 * @np: device tree node
1607 * @cells: number of cells
1608 *
1609 * Handle legacy binding with no #pinctrl-cells. This should be
1610 * always two pinctrl-single,bit-per-mux and one for others.
1611 * At some point we may want to consider removing this.
1612 */
1613static int pcs_quirk_missing_pinctrl_cells(struct pcs_device *pcs,
1614					   struct device_node *np,
1615					   int cells)
1616{
1617	struct property *p;
1618	const char *name = "#pinctrl-cells";
1619	int error;
1620	u32 val;
1621
1622	error = of_property_read_u32(np, name, &val);
1623	if (!error)
1624		return 0;
1625
1626	dev_warn(pcs->dev, "please update dts to use %s = <%i>\n",
1627		 name, cells);
1628
1629	p = devm_kzalloc(pcs->dev, sizeof(*p), GFP_KERNEL);
1630	if (!p)
1631		return -ENOMEM;
1632
1633	p->length = sizeof(__be32);
1634	p->value = devm_kzalloc(pcs->dev, sizeof(__be32), GFP_KERNEL);
1635	if (!p->value)
1636		return -ENOMEM;
1637	*(__be32 *)p->value = cpu_to_be32(cells);
1638
1639	p->name = devm_kstrdup(pcs->dev, name, GFP_KERNEL);
1640	if (!p->name)
1641		return -ENOMEM;
1642
1643	pcs->missing_nr_pinctrl_cells = p;
1644
1645#if IS_BUILTIN(CONFIG_PINCTRL_SINGLE)
1646	error = of_add_property(np, pcs->missing_nr_pinctrl_cells);
1647#endif
1648
1649	return error;
1650}
1651
1652static int pcs_probe(struct platform_device *pdev)
1653{
1654	struct device_node *np = pdev->dev.of_node;
1655	struct pcs_pdata *pdata;
1656	struct resource *res;
1657	struct pcs_device *pcs;
1658	const struct pcs_soc_data *soc;
1659	int ret;
1660
1661	soc = of_device_get_match_data(&pdev->dev);
1662	if (WARN_ON(!soc))
1663		return -EINVAL;
1664
1665	pcs = devm_kzalloc(&pdev->dev, sizeof(*pcs), GFP_KERNEL);
1666	if (!pcs)
1667		return -ENOMEM;
1668
1669	pcs->dev = &pdev->dev;
1670	pcs->np = np;
1671	raw_spin_lock_init(&pcs->lock);
1672	mutex_init(&pcs->mutex);
1673	INIT_LIST_HEAD(&pcs->gpiofuncs);
1674	pcs->flags = soc->flags;
1675	memcpy(&pcs->socdata, soc, sizeof(*soc));
1676
1677	ret = of_property_read_u32(np, "pinctrl-single,register-width",
1678				   &pcs->width);
1679	if (ret) {
1680		dev_err(pcs->dev, "register width not specified\n");
1681
1682		return ret;
1683	}
1684
1685	ret = of_property_read_u32(np, "pinctrl-single,function-mask",
1686				   &pcs->fmask);
1687	if (!ret) {
1688		pcs->fshift = __ffs(pcs->fmask);
1689		pcs->fmax = pcs->fmask >> pcs->fshift;
1690	} else {
1691		/* If mask property doesn't exist, function mux is invalid. */
1692		pcs->fmask = 0;
1693		pcs->fshift = 0;
1694		pcs->fmax = 0;
1695	}
1696
1697	ret = of_property_read_u32(np, "pinctrl-single,function-off",
1698					&pcs->foff);
1699	if (ret)
1700		pcs->foff = PCS_OFF_DISABLED;
1701
1702	pcs->bits_per_mux = of_property_read_bool(np,
1703						  "pinctrl-single,bit-per-mux");
1704	ret = pcs_quirk_missing_pinctrl_cells(pcs, np,
1705					      pcs->bits_per_mux ? 2 : 1);
1706	if (ret) {
1707		dev_err(&pdev->dev, "unable to patch #pinctrl-cells\n");
1708
1709		return ret;
1710	}
1711
1712	res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
1713	if (!res) {
1714		dev_err(pcs->dev, "could not get resource\n");
1715		return -ENODEV;
1716	}
1717
1718	pcs->res = devm_request_mem_region(pcs->dev, res->start,
1719			resource_size(res), DRIVER_NAME);
1720	if (!pcs->res) {
1721		dev_err(pcs->dev, "could not get mem_region\n");
1722		return -EBUSY;
1723	}
1724
1725	pcs->size = resource_size(pcs->res);
1726	pcs->base = devm_ioremap(pcs->dev, pcs->res->start, pcs->size);
1727	if (!pcs->base) {
1728		dev_err(pcs->dev, "could not ioremap\n");
1729		return -ENODEV;
1730	}
1731
1732	platform_set_drvdata(pdev, pcs);
1733
1734	switch (pcs->width) {
1735	case 8:
1736		pcs->read = pcs_readb;
1737		pcs->write = pcs_writeb;
1738		break;
1739	case 16:
1740		pcs->read = pcs_readw;
1741		pcs->write = pcs_writew;
1742		break;
1743	case 32:
1744		pcs->read = pcs_readl;
1745		pcs->write = pcs_writel;
1746		break;
1747	default:
1748		break;
1749	}
1750
1751	pcs->desc.name = DRIVER_NAME;
1752	pcs->desc.pctlops = &pcs_pinctrl_ops;
1753	pcs->desc.pmxops = &pcs_pinmux_ops;
1754	if (PCS_HAS_PINCONF)
1755		pcs->desc.confops = &pcs_pinconf_ops;
1756	pcs->desc.owner = THIS_MODULE;
1757
1758	ret = pcs_allocate_pin_table(pcs);
1759	if (ret < 0)
1760		goto free;
1761
1762	ret = pinctrl_register_and_init(&pcs->desc, pcs->dev, pcs, &pcs->pctl);
1763	if (ret) {
1764		dev_err(pcs->dev, "could not register single pinctrl driver\n");
1765		goto free;
1766	}
1767
1768	ret = pcs_add_gpio_func(np, pcs);
1769	if (ret < 0)
1770		goto free;
1771
1772	pcs->socdata.irq = irq_of_parse_and_map(np, 0);
1773	if (pcs->socdata.irq)
1774		pcs->flags |= PCS_FEAT_IRQ;
1775
1776	/* We still need auxdata for some omaps for PRM interrupts */
1777	pdata = dev_get_platdata(&pdev->dev);
1778	if (pdata) {
1779		if (pdata->rearm)
1780			pcs->socdata.rearm = pdata->rearm;
1781		if (pdata->irq) {
1782			pcs->socdata.irq = pdata->irq;
1783			pcs->flags |= PCS_FEAT_IRQ;
1784		}
1785	}
1786
1787	if (PCS_HAS_IRQ) {
1788		ret = pcs_irq_init_chained_handler(pcs, np);
1789		if (ret < 0)
1790			dev_warn(pcs->dev, "initialized with no interrupts\n");
1791	}
1792
1793	dev_info(pcs->dev, "%i pins, size %u\n", pcs->desc.npins, pcs->size);
1794
1795	return pinctrl_enable(pcs->pctl);
 
 
1796
 
1797free:
1798	pcs_free_resources(pcs);
1799
1800	return ret;
1801}
1802
1803static int pcs_remove(struct platform_device *pdev)
1804{
1805	struct pcs_device *pcs = platform_get_drvdata(pdev);
1806
1807	if (!pcs)
1808		return 0;
1809
1810	pcs_free_resources(pcs);
1811
1812	return 0;
1813}
1814
1815static const struct pcs_soc_data pinctrl_single_omap_wkup = {
1816	.flags = PCS_QUIRK_SHARED_IRQ,
1817	.irq_enable_mask = (1 << 14),	/* OMAP_WAKEUP_EN */
1818	.irq_status_mask = (1 << 15),	/* OMAP_WAKEUP_EVENT */
1819};
1820
1821static const struct pcs_soc_data pinctrl_single_dra7 = {
1822	.irq_enable_mask = (1 << 24),	/* WAKEUPENABLE */
1823	.irq_status_mask = (1 << 25),	/* WAKEUPEVENT */
1824};
1825
1826static const struct pcs_soc_data pinctrl_single_am437x = {
1827	.flags = PCS_QUIRK_SHARED_IRQ,
1828	.irq_enable_mask = (1 << 29),   /* OMAP_WAKEUP_EN */
1829	.irq_status_mask = (1 << 30),   /* OMAP_WAKEUP_EVENT */
1830};
1831
 
 
 
 
 
 
 
 
 
 
1832static const struct pcs_soc_data pinctrl_single = {
1833};
1834
1835static const struct pcs_soc_data pinconf_single = {
1836	.flags = PCS_FEAT_PINCONF,
1837};
1838
1839static const struct of_device_id pcs_of_match[] = {
 
 
 
 
1840	{ .compatible = "ti,omap3-padconf", .data = &pinctrl_single_omap_wkup },
1841	{ .compatible = "ti,omap4-padconf", .data = &pinctrl_single_omap_wkup },
1842	{ .compatible = "ti,omap5-padconf", .data = &pinctrl_single_omap_wkup },
1843	{ .compatible = "ti,dra7-padconf", .data = &pinctrl_single_dra7 },
1844	{ .compatible = "ti,am437-padconf", .data = &pinctrl_single_am437x },
1845	{ .compatible = "pinctrl-single", .data = &pinctrl_single },
1846	{ .compatible = "pinconf-single", .data = &pinconf_single },
1847	{ },
1848};
1849MODULE_DEVICE_TABLE(of, pcs_of_match);
1850
1851static struct platform_driver pcs_driver = {
1852	.probe		= pcs_probe,
1853	.remove		= pcs_remove,
1854	.driver = {
1855		.name		= DRIVER_NAME,
1856		.of_match_table	= pcs_of_match,
 
1857	},
1858#ifdef CONFIG_PM
1859	.suspend = pinctrl_single_suspend,
1860	.resume = pinctrl_single_resume,
1861#endif
1862};
1863
1864module_platform_driver(pcs_driver);
1865
1866MODULE_AUTHOR("Tony Lindgren <tony@atomide.com>");
1867MODULE_DESCRIPTION("One-register-per-pin type device tree based pinctrl driver");
1868MODULE_LICENSE("GPL v2");