Linux Audio

Check our new training course

Loading...
Note: File does not exist in v3.1.
   1// SPDX-License-Identifier: GPL-2.0
   2/*
   3 * Pinctrl GPIO driver for Intel Baytrail
   4 *
   5 * Copyright (c) 2012-2013, Intel Corporation
   6 * Author: Mathias Nyman <mathias.nyman@linux.intel.com>
   7 */
   8
   9#include <linux/acpi.h>
  10#include <linux/bitops.h>
  11#include <linux/gpio/driver.h>
  12#include <linux/init.h>
  13#include <linux/interrupt.h>
  14#include <linux/io.h>
  15#include <linux/kernel.h>
  16#include <linux/types.h>
  17#include <linux/platform_device.h>
  18#include <linux/pm_runtime.h>
  19#include <linux/property.h>
  20#include <linux/seq_file.h>
  21
  22#include <linux/pinctrl/pinctrl.h>
  23#include <linux/pinctrl/pinmux.h>
  24#include <linux/pinctrl/pinconf.h>
  25#include <linux/pinctrl/pinconf-generic.h>
  26
  27#include "pinctrl-intel.h"
  28
  29/* memory mapped register offsets */
  30#define BYT_CONF0_REG		0x000
  31#define BYT_CONF1_REG		0x004
  32#define BYT_VAL_REG		0x008
  33#define BYT_DFT_REG		0x00c
  34#define BYT_INT_STAT_REG	0x800
  35#define BYT_DEBOUNCE_REG	0x9d0
  36
  37/* BYT_CONF0_REG register bits */
  38#define BYT_IODEN		BIT(31)
  39#define BYT_DIRECT_IRQ_EN	BIT(27)
  40#define BYT_TRIG_MASK		GENMASK(26, 24)
  41#define BYT_TRIG_NEG		BIT(26)
  42#define BYT_TRIG_POS		BIT(25)
  43#define BYT_TRIG_LVL		BIT(24)
  44#define BYT_DEBOUNCE_EN		BIT(20)
  45#define BYT_GLITCH_FILTER_EN	BIT(19)
  46#define BYT_GLITCH_F_SLOW_CLK	BIT(17)
  47#define BYT_GLITCH_F_FAST_CLK	BIT(16)
  48#define BYT_PULL_STR_SHIFT	9
  49#define BYT_PULL_STR_MASK	GENMASK(10, 9)
  50#define BYT_PULL_STR_2K		(0 << BYT_PULL_STR_SHIFT)
  51#define BYT_PULL_STR_10K	(1 << BYT_PULL_STR_SHIFT)
  52#define BYT_PULL_STR_20K	(2 << BYT_PULL_STR_SHIFT)
  53#define BYT_PULL_STR_40K	(3 << BYT_PULL_STR_SHIFT)
  54#define BYT_PULL_ASSIGN_SHIFT	7
  55#define BYT_PULL_ASSIGN_MASK	GENMASK(8, 7)
  56#define BYT_PULL_ASSIGN_UP	(1 << BYT_PULL_ASSIGN_SHIFT)
  57#define BYT_PULL_ASSIGN_DOWN	(2 << BYT_PULL_ASSIGN_SHIFT)
  58#define BYT_PIN_MUX		GENMASK(2, 0)
  59
  60/* BYT_VAL_REG register bits */
  61#define BYT_DIR_MASK		GENMASK(2, 1)
  62#define BYT_INPUT_EN		BIT(2)  /* 0: input enabled (active low)*/
  63#define BYT_OUTPUT_EN		BIT(1)  /* 0: output enabled (active low)*/
  64#define BYT_LEVEL		BIT(0)
  65
  66#define BYT_CONF0_RESTORE_MASK	(BYT_DIRECT_IRQ_EN | BYT_TRIG_MASK | BYT_PIN_MUX)
  67#define BYT_VAL_RESTORE_MASK	(BYT_DIR_MASK | BYT_LEVEL)
  68
  69/* BYT_DEBOUNCE_REG bits */
  70#define BYT_DEBOUNCE_PULSE_MASK		GENMASK(2, 0)
  71#define BYT_DEBOUNCE_PULSE_375US	1
  72#define BYT_DEBOUNCE_PULSE_750US	2
  73#define BYT_DEBOUNCE_PULSE_1500US	3
  74#define BYT_DEBOUNCE_PULSE_3MS		4
  75#define BYT_DEBOUNCE_PULSE_6MS		5
  76#define BYT_DEBOUNCE_PULSE_12MS		6
  77#define BYT_DEBOUNCE_PULSE_24MS		7
  78
  79#define BYT_NGPIO_SCORE		102
  80#define BYT_NGPIO_NCORE		28
  81#define BYT_NGPIO_SUS		44
  82
  83#define BYT_SCORE_ACPI_UID	"1"
  84#define BYT_NCORE_ACPI_UID	"2"
  85#define BYT_SUS_ACPI_UID	"3"
  86
  87/*
  88 * This is the function value most pins have for GPIO muxing. If the value
  89 * differs from the default one, it must be explicitly mentioned. Otherwise, the
  90 * pin control implementation will set the muxing value to default GPIO if it
  91 * does not find a match for the requested function.
  92 */
  93#define BYT_DEFAULT_GPIO_MUX	0
  94#define BYT_ALTER_GPIO_MUX	1
  95
  96struct intel_pad_context {
  97	u32 conf0;
  98	u32 val;
  99};
 100
 101#define COMMUNITY(p, n, map)		\
 102	{				\
 103		.pin_base	= (p),	\
 104		.npins		= (n),	\
 105		.pad_map	= (map),\
 106	}
 107
 108/* SCORE pins, aka GPIOC_<pin_no> or GPIO_S0_SC[<pin_no>] */
 109static const struct pinctrl_pin_desc byt_score_pins[] = {
 110	PINCTRL_PIN(0, "SATA_GP0"),
 111	PINCTRL_PIN(1, "SATA_GP1"),
 112	PINCTRL_PIN(2, "SATA_LED#"),
 113	PINCTRL_PIN(3, "PCIE_CLKREQ0"),
 114	PINCTRL_PIN(4, "PCIE_CLKREQ1"),
 115	PINCTRL_PIN(5, "PCIE_CLKREQ2"),
 116	PINCTRL_PIN(6, "PCIE_CLKREQ3"),
 117	PINCTRL_PIN(7, "SD3_WP"),
 118	PINCTRL_PIN(8, "HDA_RST"),
 119	PINCTRL_PIN(9, "HDA_SYNC"),
 120	PINCTRL_PIN(10, "HDA_CLK"),
 121	PINCTRL_PIN(11, "HDA_SDO"),
 122	PINCTRL_PIN(12, "HDA_SDI0"),
 123	PINCTRL_PIN(13, "HDA_SDI1"),
 124	PINCTRL_PIN(14, "GPIO_S0_SC14"),
 125	PINCTRL_PIN(15, "GPIO_S0_SC15"),
 126	PINCTRL_PIN(16, "MMC1_CLK"),
 127	PINCTRL_PIN(17, "MMC1_D0"),
 128	PINCTRL_PIN(18, "MMC1_D1"),
 129	PINCTRL_PIN(19, "MMC1_D2"),
 130	PINCTRL_PIN(20, "MMC1_D3"),
 131	PINCTRL_PIN(21, "MMC1_D4"),
 132	PINCTRL_PIN(22, "MMC1_D5"),
 133	PINCTRL_PIN(23, "MMC1_D6"),
 134	PINCTRL_PIN(24, "MMC1_D7"),
 135	PINCTRL_PIN(25, "MMC1_CMD"),
 136	PINCTRL_PIN(26, "MMC1_RST"),
 137	PINCTRL_PIN(27, "SD2_CLK"),
 138	PINCTRL_PIN(28, "SD2_D0"),
 139	PINCTRL_PIN(29, "SD2_D1"),
 140	PINCTRL_PIN(30, "SD2_D2"),
 141	PINCTRL_PIN(31, "SD2_D3_CD"),
 142	PINCTRL_PIN(32, "SD2_CMD"),
 143	PINCTRL_PIN(33, "SD3_CLK"),
 144	PINCTRL_PIN(34, "SD3_D0"),
 145	PINCTRL_PIN(35, "SD3_D1"),
 146	PINCTRL_PIN(36, "SD3_D2"),
 147	PINCTRL_PIN(37, "SD3_D3"),
 148	PINCTRL_PIN(38, "SD3_CD"),
 149	PINCTRL_PIN(39, "SD3_CMD"),
 150	PINCTRL_PIN(40, "SD3_1P8EN"),
 151	PINCTRL_PIN(41, "SD3_PWREN#"),
 152	PINCTRL_PIN(42, "ILB_LPC_AD0"),
 153	PINCTRL_PIN(43, "ILB_LPC_AD1"),
 154	PINCTRL_PIN(44, "ILB_LPC_AD2"),
 155	PINCTRL_PIN(45, "ILB_LPC_AD3"),
 156	PINCTRL_PIN(46, "ILB_LPC_FRAME"),
 157	PINCTRL_PIN(47, "ILB_LPC_CLK0"),
 158	PINCTRL_PIN(48, "ILB_LPC_CLK1"),
 159	PINCTRL_PIN(49, "ILB_LPC_CLKRUN"),
 160	PINCTRL_PIN(50, "ILB_LPC_SERIRQ"),
 161	PINCTRL_PIN(51, "PCU_SMB_DATA"),
 162	PINCTRL_PIN(52, "PCU_SMB_CLK"),
 163	PINCTRL_PIN(53, "PCU_SMB_ALERT"),
 164	PINCTRL_PIN(54, "ILB_8254_SPKR"),
 165	PINCTRL_PIN(55, "GPIO_S0_SC55"),
 166	PINCTRL_PIN(56, "GPIO_S0_SC56"),
 167	PINCTRL_PIN(57, "GPIO_S0_SC57"),
 168	PINCTRL_PIN(58, "GPIO_S0_SC58"),
 169	PINCTRL_PIN(59, "GPIO_S0_SC59"),
 170	PINCTRL_PIN(60, "GPIO_S0_SC60"),
 171	PINCTRL_PIN(61, "GPIO_S0_SC61"),
 172	PINCTRL_PIN(62, "LPE_I2S2_CLK"),
 173	PINCTRL_PIN(63, "LPE_I2S2_FRM"),
 174	PINCTRL_PIN(64, "LPE_I2S2_DATAIN"),
 175	PINCTRL_PIN(65, "LPE_I2S2_DATAOUT"),
 176	PINCTRL_PIN(66, "SIO_SPI_CS"),
 177	PINCTRL_PIN(67, "SIO_SPI_MISO"),
 178	PINCTRL_PIN(68, "SIO_SPI_MOSI"),
 179	PINCTRL_PIN(69, "SIO_SPI_CLK"),
 180	PINCTRL_PIN(70, "SIO_UART1_RXD"),
 181	PINCTRL_PIN(71, "SIO_UART1_TXD"),
 182	PINCTRL_PIN(72, "SIO_UART1_RTS"),
 183	PINCTRL_PIN(73, "SIO_UART1_CTS"),
 184	PINCTRL_PIN(74, "SIO_UART2_RXD"),
 185	PINCTRL_PIN(75, "SIO_UART2_TXD"),
 186	PINCTRL_PIN(76, "SIO_UART2_RTS"),
 187	PINCTRL_PIN(77, "SIO_UART2_CTS"),
 188	PINCTRL_PIN(78, "SIO_I2C0_DATA"),
 189	PINCTRL_PIN(79, "SIO_I2C0_CLK"),
 190	PINCTRL_PIN(80, "SIO_I2C1_DATA"),
 191	PINCTRL_PIN(81, "SIO_I2C1_CLK"),
 192	PINCTRL_PIN(82, "SIO_I2C2_DATA"),
 193	PINCTRL_PIN(83, "SIO_I2C2_CLK"),
 194	PINCTRL_PIN(84, "SIO_I2C3_DATA"),
 195	PINCTRL_PIN(85, "SIO_I2C3_CLK"),
 196	PINCTRL_PIN(86, "SIO_I2C4_DATA"),
 197	PINCTRL_PIN(87, "SIO_I2C4_CLK"),
 198	PINCTRL_PIN(88, "SIO_I2C5_DATA"),
 199	PINCTRL_PIN(89, "SIO_I2C5_CLK"),
 200	PINCTRL_PIN(90, "SIO_I2C6_DATA"),
 201	PINCTRL_PIN(91, "SIO_I2C6_CLK"),
 202	PINCTRL_PIN(92, "GPIO_S0_SC92"),
 203	PINCTRL_PIN(93, "GPIO_S0_SC93"),
 204	PINCTRL_PIN(94, "SIO_PWM0"),
 205	PINCTRL_PIN(95, "SIO_PWM1"),
 206	PINCTRL_PIN(96, "PMC_PLT_CLK0"),
 207	PINCTRL_PIN(97, "PMC_PLT_CLK1"),
 208	PINCTRL_PIN(98, "PMC_PLT_CLK2"),
 209	PINCTRL_PIN(99, "PMC_PLT_CLK3"),
 210	PINCTRL_PIN(100, "PMC_PLT_CLK4"),
 211	PINCTRL_PIN(101, "PMC_PLT_CLK5"),
 212};
 213
 214static const unsigned int byt_score_pins_map[BYT_NGPIO_SCORE] = {
 215	85, 89, 93, 96, 99, 102, 98, 101, 34, 37,
 216	36, 38, 39, 35, 40, 84, 62, 61, 64, 59,
 217	54, 56, 60, 55, 63, 57, 51, 50, 53, 47,
 218	52, 49, 48, 43, 46, 41, 45, 42, 58, 44,
 219	95, 105, 70, 68, 67, 66, 69, 71, 65, 72,
 220	86, 90, 88, 92, 103, 77, 79, 83, 78, 81,
 221	80, 82, 13, 12, 15, 14, 17, 18, 19, 16,
 222	2, 1, 0, 4, 6, 7, 9, 8, 33, 32,
 223	31, 30, 29, 27, 25, 28, 26, 23, 21, 20,
 224	24, 22, 5, 3, 10, 11, 106, 87, 91, 104,
 225	97, 100,
 226};
 227
 228/* SCORE groups */
 229static const unsigned int byt_score_uart1_pins[] = { 70, 71, 72, 73 };
 230static const unsigned int byt_score_uart2_pins[] = { 74, 75, 76, 77 };
 231
 232static const unsigned int byt_score_pwm0_pins[] = { 94 };
 233static const unsigned int byt_score_pwm1_pins[] = { 95 };
 234
 235static const unsigned int byt_score_sio_spi_pins[] = { 66, 67, 68, 69 };
 236
 237static const unsigned int byt_score_i2c5_pins[] = { 88, 89 };
 238static const unsigned int byt_score_i2c6_pins[] = { 90, 91 };
 239static const unsigned int byt_score_i2c4_pins[] = { 86, 87 };
 240static const unsigned int byt_score_i2c3_pins[] = { 84, 85 };
 241static const unsigned int byt_score_i2c2_pins[] = { 82, 83 };
 242static const unsigned int byt_score_i2c1_pins[] = { 80, 81 };
 243static const unsigned int byt_score_i2c0_pins[] = { 78, 79 };
 244
 245static const unsigned int byt_score_ssp0_pins[] = { 8, 9, 10, 11 };
 246static const unsigned int byt_score_ssp1_pins[] = { 12, 13, 14, 15 };
 247static const unsigned int byt_score_ssp2_pins[] = { 62, 63, 64, 65 };
 248
 249static const unsigned int byt_score_sdcard_pins[] = {
 250	7, 33, 34, 35, 36, 37, 38, 39, 40, 41,
 251};
 252static const unsigned int byt_score_sdcard_mux_values[] = {
 253	2, 1, 1, 1, 1, 1, 1, 1, 1, 1,
 254};
 255
 256static const unsigned int byt_score_sdio_pins[] = { 27, 28, 29, 30, 31, 32 };
 257
 258static const unsigned int byt_score_emmc_pins[] = {
 259	16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26,
 260};
 261
 262static const unsigned int byt_score_ilb_lpc_pins[] = {
 263	42, 43, 44, 45, 46, 47, 48, 49, 50,
 264};
 265
 266static const unsigned int byt_score_sata_pins[] = { 0, 1, 2 };
 267
 268static const unsigned int byt_score_plt_clk0_pins[] = { 96 };
 269static const unsigned int byt_score_plt_clk1_pins[] = { 97 };
 270static const unsigned int byt_score_plt_clk2_pins[] = { 98 };
 271static const unsigned int byt_score_plt_clk3_pins[] = { 99 };
 272static const unsigned int byt_score_plt_clk4_pins[] = { 100 };
 273static const unsigned int byt_score_plt_clk5_pins[] = { 101 };
 274
 275static const unsigned int byt_score_smbus_pins[] = { 51, 52, 53 };
 276
 277static const struct intel_pingroup byt_score_groups[] = {
 278	PIN_GROUP("uart1_grp", byt_score_uart1_pins, 1),
 279	PIN_GROUP("uart2_grp", byt_score_uart2_pins, 1),
 280	PIN_GROUP("pwm0_grp", byt_score_pwm0_pins, 1),
 281	PIN_GROUP("pwm1_grp", byt_score_pwm1_pins, 1),
 282	PIN_GROUP("ssp2_grp", byt_score_ssp2_pins, 1),
 283	PIN_GROUP("sio_spi_grp", byt_score_sio_spi_pins, 1),
 284	PIN_GROUP("i2c5_grp", byt_score_i2c5_pins, 1),
 285	PIN_GROUP("i2c6_grp", byt_score_i2c6_pins, 1),
 286	PIN_GROUP("i2c4_grp", byt_score_i2c4_pins, 1),
 287	PIN_GROUP("i2c3_grp", byt_score_i2c3_pins, 1),
 288	PIN_GROUP("i2c2_grp", byt_score_i2c2_pins, 1),
 289	PIN_GROUP("i2c1_grp", byt_score_i2c1_pins, 1),
 290	PIN_GROUP("i2c0_grp", byt_score_i2c0_pins, 1),
 291	PIN_GROUP("ssp0_grp", byt_score_ssp0_pins, 1),
 292	PIN_GROUP("ssp1_grp", byt_score_ssp1_pins, 1),
 293	PIN_GROUP("sdcard_grp", byt_score_sdcard_pins, byt_score_sdcard_mux_values),
 294	PIN_GROUP("sdio_grp", byt_score_sdio_pins, 1),
 295	PIN_GROUP("emmc_grp", byt_score_emmc_pins, 1),
 296	PIN_GROUP("lpc_grp", byt_score_ilb_lpc_pins, 1),
 297	PIN_GROUP("sata_grp", byt_score_sata_pins, 1),
 298	PIN_GROUP("plt_clk0_grp", byt_score_plt_clk0_pins, 1),
 299	PIN_GROUP("plt_clk1_grp", byt_score_plt_clk1_pins, 1),
 300	PIN_GROUP("plt_clk2_grp", byt_score_plt_clk2_pins, 1),
 301	PIN_GROUP("plt_clk3_grp", byt_score_plt_clk3_pins, 1),
 302	PIN_GROUP("plt_clk4_grp", byt_score_plt_clk4_pins, 1),
 303	PIN_GROUP("plt_clk5_grp", byt_score_plt_clk5_pins, 1),
 304	PIN_GROUP("smbus_grp", byt_score_smbus_pins, 1),
 305};
 306
 307static const char * const byt_score_uart_groups[] = {
 308	"uart1_grp", "uart2_grp",
 309};
 310static const char * const byt_score_pwm_groups[] = {
 311	"pwm0_grp", "pwm1_grp",
 312};
 313static const char * const byt_score_ssp_groups[] = {
 314	"ssp0_grp", "ssp1_grp", "ssp2_grp",
 315};
 316static const char * const byt_score_spi_groups[] = { "sio_spi_grp" };
 317static const char * const byt_score_i2c_groups[] = {
 318	"i2c0_grp", "i2c1_grp", "i2c2_grp", "i2c3_grp", "i2c4_grp", "i2c5_grp",
 319	"i2c6_grp",
 320};
 321static const char * const byt_score_sdcard_groups[] = { "sdcard_grp" };
 322static const char * const byt_score_sdio_groups[] = { "sdio_grp" };
 323static const char * const byt_score_emmc_groups[] = { "emmc_grp" };
 324static const char * const byt_score_lpc_groups[] = { "lpc_grp" };
 325static const char * const byt_score_sata_groups[] = { "sata_grp" };
 326static const char * const byt_score_plt_clk_groups[] = {
 327	"plt_clk0_grp", "plt_clk1_grp", "plt_clk2_grp", "plt_clk3_grp",
 328	"plt_clk4_grp", "plt_clk5_grp",
 329};
 330static const char * const byt_score_smbus_groups[] = { "smbus_grp" };
 331static const char * const byt_score_gpio_groups[] = {
 332	"uart1_grp", "uart2_grp", "pwm0_grp", "pwm1_grp", "ssp0_grp",
 333	"ssp1_grp", "ssp2_grp", "sio_spi_grp", "i2c0_grp", "i2c1_grp",
 334	"i2c2_grp", "i2c3_grp", "i2c4_grp", "i2c5_grp", "i2c6_grp",
 335	"sdcard_grp", "sdio_grp", "emmc_grp", "lpc_grp", "sata_grp",
 336	"plt_clk0_grp", "plt_clk1_grp", "plt_clk2_grp", "plt_clk3_grp",
 337	"plt_clk4_grp", "plt_clk5_grp", "smbus_grp",
 338};
 339
 340static const struct intel_function byt_score_functions[] = {
 341	FUNCTION("uart", byt_score_uart_groups),
 342	FUNCTION("pwm", byt_score_pwm_groups),
 343	FUNCTION("ssp", byt_score_ssp_groups),
 344	FUNCTION("spi", byt_score_spi_groups),
 345	FUNCTION("i2c", byt_score_i2c_groups),
 346	FUNCTION("sdcard", byt_score_sdcard_groups),
 347	FUNCTION("sdio", byt_score_sdio_groups),
 348	FUNCTION("emmc", byt_score_emmc_groups),
 349	FUNCTION("lpc", byt_score_lpc_groups),
 350	FUNCTION("sata", byt_score_sata_groups),
 351	FUNCTION("plt_clk", byt_score_plt_clk_groups),
 352	FUNCTION("smbus", byt_score_smbus_groups),
 353	FUNCTION("gpio", byt_score_gpio_groups),
 354};
 355
 356static const struct intel_community byt_score_communities[] = {
 357	COMMUNITY(0, BYT_NGPIO_SCORE, byt_score_pins_map),
 358};
 359
 360static const struct intel_pinctrl_soc_data byt_score_soc_data = {
 361	.uid		= BYT_SCORE_ACPI_UID,
 362	.pins		= byt_score_pins,
 363	.npins		= ARRAY_SIZE(byt_score_pins),
 364	.groups		= byt_score_groups,
 365	.ngroups	= ARRAY_SIZE(byt_score_groups),
 366	.functions	= byt_score_functions,
 367	.nfunctions	= ARRAY_SIZE(byt_score_functions),
 368	.communities	= byt_score_communities,
 369	.ncommunities	= ARRAY_SIZE(byt_score_communities),
 370};
 371
 372/* SUS pins, aka GPIOS_<pin_no> or GPIO_S5[<pin_no>]  */
 373static const struct pinctrl_pin_desc byt_sus_pins[] = {
 374	PINCTRL_PIN(0, "GPIO_S50"),
 375	PINCTRL_PIN(1, "GPIO_S51"),
 376	PINCTRL_PIN(2, "GPIO_S52"),
 377	PINCTRL_PIN(3, "GPIO_S53"),
 378	PINCTRL_PIN(4, "GPIO_S54"),
 379	PINCTRL_PIN(5, "GPIO_S55"),
 380	PINCTRL_PIN(6, "GPIO_S56"),
 381	PINCTRL_PIN(7, "GPIO_S57"),
 382	PINCTRL_PIN(8, "GPIO_S58"),
 383	PINCTRL_PIN(9, "GPIO_S59"),
 384	PINCTRL_PIN(10, "GPIO_S510"),
 385	PINCTRL_PIN(11, "PMC_SUSPWRDNACK"),
 386	PINCTRL_PIN(12, "PMC_SUSCLK0"),
 387	PINCTRL_PIN(13, "GPIO_S513"),
 388	PINCTRL_PIN(14, "USB_ULPI_RST"),
 389	PINCTRL_PIN(15, "PMC_WAKE_PCIE0#"),
 390	PINCTRL_PIN(16, "PMC_PWRBTN"),
 391	PINCTRL_PIN(17, "GPIO_S517"),
 392	PINCTRL_PIN(18, "PMC_SUS_STAT"),
 393	PINCTRL_PIN(19, "USB_OC0"),
 394	PINCTRL_PIN(20, "USB_OC1"),
 395	PINCTRL_PIN(21, "PCU_SPI_CS1"),
 396	PINCTRL_PIN(22, "GPIO_S522"),
 397	PINCTRL_PIN(23, "GPIO_S523"),
 398	PINCTRL_PIN(24, "GPIO_S524"),
 399	PINCTRL_PIN(25, "GPIO_S525"),
 400	PINCTRL_PIN(26, "GPIO_S526"),
 401	PINCTRL_PIN(27, "GPIO_S527"),
 402	PINCTRL_PIN(28, "GPIO_S528"),
 403	PINCTRL_PIN(29, "GPIO_S529"),
 404	PINCTRL_PIN(30, "GPIO_S530"),
 405	PINCTRL_PIN(31, "USB_ULPI_CLK"),
 406	PINCTRL_PIN(32, "USB_ULPI_DATA0"),
 407	PINCTRL_PIN(33, "USB_ULPI_DATA1"),
 408	PINCTRL_PIN(34, "USB_ULPI_DATA2"),
 409	PINCTRL_PIN(35, "USB_ULPI_DATA3"),
 410	PINCTRL_PIN(36, "USB_ULPI_DATA4"),
 411	PINCTRL_PIN(37, "USB_ULPI_DATA5"),
 412	PINCTRL_PIN(38, "USB_ULPI_DATA6"),
 413	PINCTRL_PIN(39, "USB_ULPI_DATA7"),
 414	PINCTRL_PIN(40, "USB_ULPI_DIR"),
 415	PINCTRL_PIN(41, "USB_ULPI_NXT"),
 416	PINCTRL_PIN(42, "USB_ULPI_STP"),
 417	PINCTRL_PIN(43, "USB_ULPI_REFCLK"),
 418};
 419
 420static const unsigned int byt_sus_pins_map[BYT_NGPIO_SUS] = {
 421	29, 33, 30, 31, 32, 34, 36, 35, 38, 37,
 422	18, 7, 11, 20, 17, 1, 8, 10, 19, 12,
 423	0, 2, 23, 39, 28, 27, 22, 21, 24, 25,
 424	26, 51, 56, 54, 49, 55, 48, 57, 50, 58,
 425	52, 53, 59, 40,
 426};
 427
 428static const unsigned int byt_sus_usb_over_current_pins[] = { 19, 20 };
 429static const unsigned int byt_sus_usb_over_current_mode_values[] = { 0, 0 };
 430static const unsigned int byt_sus_usb_over_current_gpio_mode_values[] = { 1, 1 };
 431
 432static const unsigned int byt_sus_usb_ulpi_pins[] = {
 433	14, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43,
 434};
 435static const unsigned int byt_sus_usb_ulpi_mode_values[] = {
 436	2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
 437};
 438static const unsigned int byt_sus_usb_ulpi_gpio_mode_values[] = {
 439	1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
 440};
 441
 442static const unsigned int byt_sus_pcu_spi_pins[] = { 21 };
 443static const unsigned int byt_sus_pcu_spi_mode_values[] = { 0 };
 444static const unsigned int byt_sus_pcu_spi_gpio_mode_values[] = { 1 };
 445
 446static const struct intel_pingroup byt_sus_groups[] = {
 447	PIN_GROUP("usb_oc_grp", byt_sus_usb_over_current_pins, byt_sus_usb_over_current_mode_values),
 448	PIN_GROUP("usb_ulpi_grp", byt_sus_usb_ulpi_pins, byt_sus_usb_ulpi_mode_values),
 449	PIN_GROUP("pcu_spi_grp", byt_sus_pcu_spi_pins, byt_sus_pcu_spi_mode_values),
 450	PIN_GROUP("usb_oc_grp_gpio", byt_sus_usb_over_current_pins, byt_sus_usb_over_current_gpio_mode_values),
 451	PIN_GROUP("usb_ulpi_grp_gpio", byt_sus_usb_ulpi_pins, byt_sus_usb_ulpi_gpio_mode_values),
 452	PIN_GROUP("pcu_spi_grp_gpio", byt_sus_pcu_spi_pins, byt_sus_pcu_spi_gpio_mode_values),
 453};
 454
 455static const char * const byt_sus_usb_groups[] = {
 456	"usb_oc_grp", "usb_ulpi_grp",
 457};
 458static const char * const byt_sus_spi_groups[] = { "pcu_spi_grp" };
 459static const char * const byt_sus_gpio_groups[] = {
 460	"usb_oc_grp_gpio", "usb_ulpi_grp_gpio", "pcu_spi_grp_gpio",
 461};
 462
 463static const struct intel_function byt_sus_functions[] = {
 464	FUNCTION("usb", byt_sus_usb_groups),
 465	FUNCTION("spi", byt_sus_spi_groups),
 466	FUNCTION("gpio", byt_sus_gpio_groups),
 467};
 468
 469static const struct intel_community byt_sus_communities[] = {
 470	COMMUNITY(0, BYT_NGPIO_SUS, byt_sus_pins_map),
 471};
 472
 473static const struct intel_pinctrl_soc_data byt_sus_soc_data = {
 474	.uid		= BYT_SUS_ACPI_UID,
 475	.pins		= byt_sus_pins,
 476	.npins		= ARRAY_SIZE(byt_sus_pins),
 477	.groups		= byt_sus_groups,
 478	.ngroups	= ARRAY_SIZE(byt_sus_groups),
 479	.functions	= byt_sus_functions,
 480	.nfunctions	= ARRAY_SIZE(byt_sus_functions),
 481	.communities	= byt_sus_communities,
 482	.ncommunities	= ARRAY_SIZE(byt_sus_communities),
 483};
 484
 485static const struct pinctrl_pin_desc byt_ncore_pins[] = {
 486	PINCTRL_PIN(0, "HV_DDI0_HPD"),
 487	PINCTRL_PIN(1, "HV_DDI0_DDC_SDA"),
 488	PINCTRL_PIN(2, "HV_DDI0_DDC_SCL"),
 489	PINCTRL_PIN(3, "PANEL0_VDDEN"),
 490	PINCTRL_PIN(4, "PANEL0_BKLTEN"),
 491	PINCTRL_PIN(5, "PANEL0_BKLTCTL"),
 492	PINCTRL_PIN(6, "HV_DDI1_HPD"),
 493	PINCTRL_PIN(7, "HV_DDI1_DDC_SDA"),
 494	PINCTRL_PIN(8, "HV_DDI1_DDC_SCL"),
 495	PINCTRL_PIN(9, "PANEL1_VDDEN"),
 496	PINCTRL_PIN(10, "PANEL1_BKLTEN"),
 497	PINCTRL_PIN(11, "PANEL1_BKLTCTL"),
 498	PINCTRL_PIN(12, "GP_INTD_DSI_TE1"),
 499	PINCTRL_PIN(13, "HV_DDI2_DDC_SDA"),
 500	PINCTRL_PIN(14, "HV_DDI2_DDC_SCL"),
 501	PINCTRL_PIN(15, "GP_CAMERASB00"),
 502	PINCTRL_PIN(16, "GP_CAMERASB01"),
 503	PINCTRL_PIN(17, "GP_CAMERASB02"),
 504	PINCTRL_PIN(18, "GP_CAMERASB03"),
 505	PINCTRL_PIN(19, "GP_CAMERASB04"),
 506	PINCTRL_PIN(20, "GP_CAMERASB05"),
 507	PINCTRL_PIN(21, "GP_CAMERASB06"),
 508	PINCTRL_PIN(22, "GP_CAMERASB07"),
 509	PINCTRL_PIN(23, "GP_CAMERASB08"),
 510	PINCTRL_PIN(24, "GP_CAMERASB09"),
 511	PINCTRL_PIN(25, "GP_CAMERASB10"),
 512	PINCTRL_PIN(26, "GP_CAMERASB11"),
 513	PINCTRL_PIN(27, "GP_INTD_DSI_TE2"),
 514};
 515
 516static const unsigned int byt_ncore_pins_map[BYT_NGPIO_NCORE] = {
 517	19, 18, 17, 20, 21, 22, 24, 25, 23, 16,
 518	14, 15, 12, 26, 27, 1, 4, 8, 11, 0,
 519	3, 6, 10, 13, 2, 5, 9, 7,
 520};
 521
 522static const struct intel_community byt_ncore_communities[] = {
 523	COMMUNITY(0, BYT_NGPIO_NCORE, byt_ncore_pins_map),
 524};
 525
 526static const struct intel_pinctrl_soc_data byt_ncore_soc_data = {
 527	.uid		= BYT_NCORE_ACPI_UID,
 528	.pins		= byt_ncore_pins,
 529	.npins		= ARRAY_SIZE(byt_ncore_pins),
 530	.communities	= byt_ncore_communities,
 531	.ncommunities	= ARRAY_SIZE(byt_ncore_communities),
 532};
 533
 534static const struct intel_pinctrl_soc_data *byt_soc_data[] = {
 535	&byt_score_soc_data,
 536	&byt_sus_soc_data,
 537	&byt_ncore_soc_data,
 538	NULL
 539};
 540
 541static DEFINE_RAW_SPINLOCK(byt_lock);
 542
 543static struct intel_community *byt_get_community(struct intel_pinctrl *vg,
 544						 unsigned int pin)
 545{
 546	struct intel_community *comm;
 547	int i;
 548
 549	for (i = 0; i < vg->ncommunities; i++) {
 550		comm = vg->communities + i;
 551		if (pin < comm->pin_base + comm->npins && pin >= comm->pin_base)
 552			return comm;
 553	}
 554
 555	return NULL;
 556}
 557
 558static void __iomem *byt_gpio_reg(struct intel_pinctrl *vg, unsigned int offset,
 559				  int reg)
 560{
 561	struct intel_community *comm = byt_get_community(vg, offset);
 562	u32 reg_offset;
 563
 564	if (!comm)
 565		return NULL;
 566
 567	offset -= comm->pin_base;
 568	switch (reg) {
 569	case BYT_INT_STAT_REG:
 570		reg_offset = (offset / 32) * 4;
 571		break;
 572	case BYT_DEBOUNCE_REG:
 573		reg_offset = 0;
 574		break;
 575	default:
 576		reg_offset = comm->pad_map[offset] * 16;
 577		break;
 578	}
 579
 580	return comm->pad_regs + reg_offset + reg;
 581}
 582
 583static int byt_get_groups_count(struct pinctrl_dev *pctldev)
 584{
 585	struct intel_pinctrl *vg = pinctrl_dev_get_drvdata(pctldev);
 586
 587	return vg->soc->ngroups;
 588}
 589
 590static const char *byt_get_group_name(struct pinctrl_dev *pctldev,
 591				      unsigned int selector)
 592{
 593	struct intel_pinctrl *vg = pinctrl_dev_get_drvdata(pctldev);
 594
 595	return vg->soc->groups[selector].name;
 596}
 597
 598static int byt_get_group_pins(struct pinctrl_dev *pctldev,
 599			      unsigned int selector,
 600			      const unsigned int **pins,
 601			      unsigned int *num_pins)
 602{
 603	struct intel_pinctrl *vg = pinctrl_dev_get_drvdata(pctldev);
 604
 605	*pins		= vg->soc->groups[selector].pins;
 606	*num_pins	= vg->soc->groups[selector].npins;
 607
 608	return 0;
 609}
 610
 611static const struct pinctrl_ops byt_pinctrl_ops = {
 612	.get_groups_count	= byt_get_groups_count,
 613	.get_group_name		= byt_get_group_name,
 614	.get_group_pins		= byt_get_group_pins,
 615};
 616
 617static int byt_get_functions_count(struct pinctrl_dev *pctldev)
 618{
 619	struct intel_pinctrl *vg = pinctrl_dev_get_drvdata(pctldev);
 620
 621	return vg->soc->nfunctions;
 622}
 623
 624static const char *byt_get_function_name(struct pinctrl_dev *pctldev,
 625					 unsigned int selector)
 626{
 627	struct intel_pinctrl *vg = pinctrl_dev_get_drvdata(pctldev);
 628
 629	return vg->soc->functions[selector].name;
 630}
 631
 632static int byt_get_function_groups(struct pinctrl_dev *pctldev,
 633				   unsigned int selector,
 634				   const char * const **groups,
 635				   unsigned int *num_groups)
 636{
 637	struct intel_pinctrl *vg = pinctrl_dev_get_drvdata(pctldev);
 638
 639	*groups		= vg->soc->functions[selector].groups;
 640	*num_groups	= vg->soc->functions[selector].ngroups;
 641
 642	return 0;
 643}
 644
 645static void byt_set_group_simple_mux(struct intel_pinctrl *vg,
 646				     const struct intel_pingroup group,
 647				     unsigned int func)
 648{
 649	unsigned long flags;
 650	int i;
 651
 652	raw_spin_lock_irqsave(&byt_lock, flags);
 653
 654	for (i = 0; i < group.npins; i++) {
 655		void __iomem *padcfg0;
 656		u32 value;
 657
 658		padcfg0 = byt_gpio_reg(vg, group.pins[i], BYT_CONF0_REG);
 659		if (!padcfg0) {
 660			dev_warn(vg->dev,
 661				 "Group %s, pin %i not muxed (no padcfg0)\n",
 662				 group.name, i);
 663			continue;
 664		}
 665
 666		value = readl(padcfg0);
 667		value &= ~BYT_PIN_MUX;
 668		value |= func;
 669		writel(value, padcfg0);
 670	}
 671
 672	raw_spin_unlock_irqrestore(&byt_lock, flags);
 673}
 674
 675static void byt_set_group_mixed_mux(struct intel_pinctrl *vg,
 676				    const struct intel_pingroup group,
 677				    const unsigned int *func)
 678{
 679	unsigned long flags;
 680	int i;
 681
 682	raw_spin_lock_irqsave(&byt_lock, flags);
 683
 684	for (i = 0; i < group.npins; i++) {
 685		void __iomem *padcfg0;
 686		u32 value;
 687
 688		padcfg0 = byt_gpio_reg(vg, group.pins[i], BYT_CONF0_REG);
 689		if (!padcfg0) {
 690			dev_warn(vg->dev,
 691				 "Group %s, pin %i not muxed (no padcfg0)\n",
 692				 group.name, i);
 693			continue;
 694		}
 695
 696		value = readl(padcfg0);
 697		value &= ~BYT_PIN_MUX;
 698		value |= func[i];
 699		writel(value, padcfg0);
 700	}
 701
 702	raw_spin_unlock_irqrestore(&byt_lock, flags);
 703}
 704
 705static int byt_set_mux(struct pinctrl_dev *pctldev, unsigned int func_selector,
 706		       unsigned int group_selector)
 707{
 708	struct intel_pinctrl *vg = pinctrl_dev_get_drvdata(pctldev);
 709	const struct intel_function func = vg->soc->functions[func_selector];
 710	const struct intel_pingroup group = vg->soc->groups[group_selector];
 711
 712	if (group.modes)
 713		byt_set_group_mixed_mux(vg, group, group.modes);
 714	else if (!strcmp(func.name, "gpio"))
 715		byt_set_group_simple_mux(vg, group, BYT_DEFAULT_GPIO_MUX);
 716	else
 717		byt_set_group_simple_mux(vg, group, group.mode);
 718
 719	return 0;
 720}
 721
 722static u32 byt_get_gpio_mux(struct intel_pinctrl *vg, unsigned int offset)
 723{
 724	/* SCORE pin 92-93 */
 725	if (!strcmp(vg->soc->uid, BYT_SCORE_ACPI_UID) &&
 726	    offset >= 92 && offset <= 93)
 727		return BYT_ALTER_GPIO_MUX;
 728
 729	/* SUS pin 11-21 */
 730	if (!strcmp(vg->soc->uid, BYT_SUS_ACPI_UID) &&
 731	    offset >= 11 && offset <= 21)
 732		return BYT_ALTER_GPIO_MUX;
 733
 734	return BYT_DEFAULT_GPIO_MUX;
 735}
 736
 737static void byt_gpio_clear_triggering(struct intel_pinctrl *vg, unsigned int offset)
 738{
 739	void __iomem *reg = byt_gpio_reg(vg, offset, BYT_CONF0_REG);
 740	unsigned long flags;
 741	u32 value;
 742
 743	raw_spin_lock_irqsave(&byt_lock, flags);
 744	value = readl(reg);
 745
 746	/* Do not clear direct-irq enabled IRQs (from gpio_disable_free) */
 747	if (value & BYT_DIRECT_IRQ_EN)
 748		/* nothing to do */ ;
 749	else
 750		value &= ~(BYT_TRIG_POS | BYT_TRIG_NEG | BYT_TRIG_LVL);
 751
 752	writel(value, reg);
 753	raw_spin_unlock_irqrestore(&byt_lock, flags);
 754}
 755
 756static int byt_gpio_request_enable(struct pinctrl_dev *pctl_dev,
 757				   struct pinctrl_gpio_range *range,
 758				   unsigned int offset)
 759{
 760	struct intel_pinctrl *vg = pinctrl_dev_get_drvdata(pctl_dev);
 761	void __iomem *reg = byt_gpio_reg(vg, offset, BYT_CONF0_REG);
 762	u32 value, gpio_mux;
 763	unsigned long flags;
 764
 765	raw_spin_lock_irqsave(&byt_lock, flags);
 766
 767	/*
 768	 * In most cases, func pin mux 000 means GPIO function.
 769	 * But, some pins may have func pin mux 001 represents
 770	 * GPIO function.
 771	 *
 772	 * Because there are devices out there where some pins were not
 773	 * configured correctly we allow changing the mux value from
 774	 * request (but print out warning about that).
 775	 */
 776	value = readl(reg) & BYT_PIN_MUX;
 777	gpio_mux = byt_get_gpio_mux(vg, offset);
 778	if (gpio_mux != value) {
 779		value = readl(reg) & ~BYT_PIN_MUX;
 780		value |= gpio_mux;
 781		writel(value, reg);
 782
 783		dev_warn(vg->dev, FW_BUG "pin %u forcibly re-configured as GPIO\n", offset);
 784	}
 785
 786	raw_spin_unlock_irqrestore(&byt_lock, flags);
 787
 788	pm_runtime_get(vg->dev);
 789
 790	return 0;
 791}
 792
 793static void byt_gpio_disable_free(struct pinctrl_dev *pctl_dev,
 794				  struct pinctrl_gpio_range *range,
 795				  unsigned int offset)
 796{
 797	struct intel_pinctrl *vg = pinctrl_dev_get_drvdata(pctl_dev);
 798
 799	byt_gpio_clear_triggering(vg, offset);
 800	pm_runtime_put(vg->dev);
 801}
 802
 803static void byt_gpio_direct_irq_check(struct intel_pinctrl *vg,
 804				      unsigned int offset)
 805{
 806	void __iomem *conf_reg = byt_gpio_reg(vg, offset, BYT_CONF0_REG);
 807
 808	/*
 809	 * Before making any direction modifications, do a check if gpio is set
 810	 * for direct IRQ. On Bay Trail, setting GPIO to output does not make
 811	 * sense, so let's at least inform the caller before they shoot
 812	 * themselves in the foot.
 813	 */
 814	if (readl(conf_reg) & BYT_DIRECT_IRQ_EN)
 815		dev_info_once(vg->dev, "Potential Error: Setting GPIO with direct_irq_en to output");
 816}
 817
 818static int byt_gpio_set_direction(struct pinctrl_dev *pctl_dev,
 819				  struct pinctrl_gpio_range *range,
 820				  unsigned int offset,
 821				  bool input)
 822{
 823	struct intel_pinctrl *vg = pinctrl_dev_get_drvdata(pctl_dev);
 824	void __iomem *val_reg = byt_gpio_reg(vg, offset, BYT_VAL_REG);
 825	unsigned long flags;
 826	u32 value;
 827
 828	raw_spin_lock_irqsave(&byt_lock, flags);
 829
 830	value = readl(val_reg);
 831	value &= ~BYT_DIR_MASK;
 832	if (input)
 833		value |= BYT_OUTPUT_EN;
 834	else
 835		byt_gpio_direct_irq_check(vg, offset);
 836
 837	writel(value, val_reg);
 838
 839	raw_spin_unlock_irqrestore(&byt_lock, flags);
 840
 841	return 0;
 842}
 843
 844static const struct pinmux_ops byt_pinmux_ops = {
 845	.get_functions_count	= byt_get_functions_count,
 846	.get_function_name	= byt_get_function_name,
 847	.get_function_groups	= byt_get_function_groups,
 848	.set_mux		= byt_set_mux,
 849	.gpio_request_enable	= byt_gpio_request_enable,
 850	.gpio_disable_free	= byt_gpio_disable_free,
 851	.gpio_set_direction	= byt_gpio_set_direction,
 852};
 853
 854static void byt_get_pull_strength(u32 reg, u16 *strength)
 855{
 856	switch (reg & BYT_PULL_STR_MASK) {
 857	case BYT_PULL_STR_2K:
 858		*strength = 2000;
 859		break;
 860	case BYT_PULL_STR_10K:
 861		*strength = 10000;
 862		break;
 863	case BYT_PULL_STR_20K:
 864		*strength = 20000;
 865		break;
 866	case BYT_PULL_STR_40K:
 867		*strength = 40000;
 868		break;
 869	}
 870}
 871
 872static int byt_set_pull_strength(u32 *reg, u16 strength)
 873{
 874	*reg &= ~BYT_PULL_STR_MASK;
 875
 876	switch (strength) {
 877	case 2000:
 878		*reg |= BYT_PULL_STR_2K;
 879		break;
 880	case 10000:
 881		*reg |= BYT_PULL_STR_10K;
 882		break;
 883	case 20000:
 884		*reg |= BYT_PULL_STR_20K;
 885		break;
 886	case 40000:
 887		*reg |= BYT_PULL_STR_40K;
 888		break;
 889	default:
 890		return -EINVAL;
 891	}
 892
 893	return 0;
 894}
 895
 896static int byt_pin_config_get(struct pinctrl_dev *pctl_dev, unsigned int offset,
 897			      unsigned long *config)
 898{
 899	struct intel_pinctrl *vg = pinctrl_dev_get_drvdata(pctl_dev);
 900	enum pin_config_param param = pinconf_to_config_param(*config);
 901	void __iomem *conf_reg = byt_gpio_reg(vg, offset, BYT_CONF0_REG);
 902	void __iomem *val_reg = byt_gpio_reg(vg, offset, BYT_VAL_REG);
 903	void __iomem *db_reg = byt_gpio_reg(vg, offset, BYT_DEBOUNCE_REG);
 904	unsigned long flags;
 905	u32 conf, pull, val, debounce;
 906	u16 arg = 0;
 907
 908	raw_spin_lock_irqsave(&byt_lock, flags);
 909	conf = readl(conf_reg);
 910	pull = conf & BYT_PULL_ASSIGN_MASK;
 911	val = readl(val_reg);
 912	raw_spin_unlock_irqrestore(&byt_lock, flags);
 913
 914	switch (param) {
 915	case PIN_CONFIG_BIAS_DISABLE:
 916		if (pull)
 917			return -EINVAL;
 918		break;
 919	case PIN_CONFIG_BIAS_PULL_DOWN:
 920		/* Pull assignment is only applicable in input mode */
 921		if ((val & BYT_INPUT_EN) || pull != BYT_PULL_ASSIGN_DOWN)
 922			return -EINVAL;
 923
 924		byt_get_pull_strength(conf, &arg);
 925
 926		break;
 927	case PIN_CONFIG_BIAS_PULL_UP:
 928		/* Pull assignment is only applicable in input mode */
 929		if ((val & BYT_INPUT_EN) || pull != BYT_PULL_ASSIGN_UP)
 930			return -EINVAL;
 931
 932		byt_get_pull_strength(conf, &arg);
 933
 934		break;
 935	case PIN_CONFIG_INPUT_DEBOUNCE:
 936		if (!(conf & BYT_DEBOUNCE_EN))
 937			return -EINVAL;
 938
 939		raw_spin_lock_irqsave(&byt_lock, flags);
 940		debounce = readl(db_reg);
 941		raw_spin_unlock_irqrestore(&byt_lock, flags);
 942
 943		switch (debounce & BYT_DEBOUNCE_PULSE_MASK) {
 944		case BYT_DEBOUNCE_PULSE_375US:
 945			arg = 375;
 946			break;
 947		case BYT_DEBOUNCE_PULSE_750US:
 948			arg = 750;
 949			break;
 950		case BYT_DEBOUNCE_PULSE_1500US:
 951			arg = 1500;
 952			break;
 953		case BYT_DEBOUNCE_PULSE_3MS:
 954			arg = 3000;
 955			break;
 956		case BYT_DEBOUNCE_PULSE_6MS:
 957			arg = 6000;
 958			break;
 959		case BYT_DEBOUNCE_PULSE_12MS:
 960			arg = 12000;
 961			break;
 962		case BYT_DEBOUNCE_PULSE_24MS:
 963			arg = 24000;
 964			break;
 965		default:
 966			return -EINVAL;
 967		}
 968
 969		break;
 970	default:
 971		return -ENOTSUPP;
 972	}
 973
 974	*config = pinconf_to_config_packed(param, arg);
 975
 976	return 0;
 977}
 978
 979static int byt_pin_config_set(struct pinctrl_dev *pctl_dev,
 980			      unsigned int offset,
 981			      unsigned long *configs,
 982			      unsigned int num_configs)
 983{
 984	struct intel_pinctrl *vg = pinctrl_dev_get_drvdata(pctl_dev);
 985	unsigned int param, arg;
 986	void __iomem *conf_reg = byt_gpio_reg(vg, offset, BYT_CONF0_REG);
 987	void __iomem *val_reg = byt_gpio_reg(vg, offset, BYT_VAL_REG);
 988	void __iomem *db_reg = byt_gpio_reg(vg, offset, BYT_DEBOUNCE_REG);
 989	unsigned long flags;
 990	u32 conf, val, debounce;
 991	int i, ret = 0;
 992
 993	raw_spin_lock_irqsave(&byt_lock, flags);
 994
 995	conf = readl(conf_reg);
 996	val = readl(val_reg);
 997
 998	for (i = 0; i < num_configs; i++) {
 999		param = pinconf_to_config_param(configs[i]);
1000		arg = pinconf_to_config_argument(configs[i]);
1001
1002		switch (param) {
1003		case PIN_CONFIG_BIAS_DISABLE:
1004			conf &= ~BYT_PULL_ASSIGN_MASK;
1005			break;
1006		case PIN_CONFIG_BIAS_PULL_DOWN:
1007			/* Set default strength value in case none is given */
1008			if (arg == 1)
1009				arg = 2000;
1010
1011			/*
1012			 * Pull assignment is only applicable in input mode. If
1013			 * chip is not in input mode, set it and warn about it.
1014			 */
1015			if (val & BYT_INPUT_EN) {
1016				val &= ~BYT_INPUT_EN;
1017				writel(val, val_reg);
1018				dev_warn(vg->dev,
1019					 "pin %u forcibly set to input mode\n",
1020					 offset);
1021			}
1022
1023			conf &= ~BYT_PULL_ASSIGN_MASK;
1024			conf |= BYT_PULL_ASSIGN_DOWN;
1025			ret = byt_set_pull_strength(&conf, arg);
1026
1027			break;
1028		case PIN_CONFIG_BIAS_PULL_UP:
1029			/* Set default strength value in case none is given */
1030			if (arg == 1)
1031				arg = 2000;
1032
1033			/*
1034			 * Pull assignment is only applicable in input mode. If
1035			 * chip is not in input mode, set it and warn about it.
1036			 */
1037			if (val & BYT_INPUT_EN) {
1038				val &= ~BYT_INPUT_EN;
1039				writel(val, val_reg);
1040				dev_warn(vg->dev,
1041					 "pin %u forcibly set to input mode\n",
1042					 offset);
1043			}
1044
1045			conf &= ~BYT_PULL_ASSIGN_MASK;
1046			conf |= BYT_PULL_ASSIGN_UP;
1047			ret = byt_set_pull_strength(&conf, arg);
1048
1049			break;
1050		case PIN_CONFIG_INPUT_DEBOUNCE:
1051			debounce = readl(db_reg);
1052			debounce &= ~BYT_DEBOUNCE_PULSE_MASK;
1053
1054			if (arg)
1055				conf |= BYT_DEBOUNCE_EN;
1056			else
1057				conf &= ~BYT_DEBOUNCE_EN;
1058
1059			switch (arg) {
1060			case 375:
1061				debounce |= BYT_DEBOUNCE_PULSE_375US;
1062				break;
1063			case 750:
1064				debounce |= BYT_DEBOUNCE_PULSE_750US;
1065				break;
1066			case 1500:
1067				debounce |= BYT_DEBOUNCE_PULSE_1500US;
1068				break;
1069			case 3000:
1070				debounce |= BYT_DEBOUNCE_PULSE_3MS;
1071				break;
1072			case 6000:
1073				debounce |= BYT_DEBOUNCE_PULSE_6MS;
1074				break;
1075			case 12000:
1076				debounce |= BYT_DEBOUNCE_PULSE_12MS;
1077				break;
1078			case 24000:
1079				debounce |= BYT_DEBOUNCE_PULSE_24MS;
1080				break;
1081			default:
1082				if (arg)
1083					ret = -EINVAL;
1084				break;
1085			}
1086
1087			if (!ret)
1088				writel(debounce, db_reg);
1089			break;
1090		default:
1091			ret = -ENOTSUPP;
1092		}
1093
1094		if (ret)
1095			break;
1096	}
1097
1098	if (!ret)
1099		writel(conf, conf_reg);
1100
1101	raw_spin_unlock_irqrestore(&byt_lock, flags);
1102
1103	return ret;
1104}
1105
1106static const struct pinconf_ops byt_pinconf_ops = {
1107	.is_generic	= true,
1108	.pin_config_get	= byt_pin_config_get,
1109	.pin_config_set	= byt_pin_config_set,
1110};
1111
1112static const struct pinctrl_desc byt_pinctrl_desc = {
1113	.pctlops	= &byt_pinctrl_ops,
1114	.pmxops		= &byt_pinmux_ops,
1115	.confops	= &byt_pinconf_ops,
1116	.owner		= THIS_MODULE,
1117};
1118
1119static int byt_gpio_get(struct gpio_chip *chip, unsigned int offset)
1120{
1121	struct intel_pinctrl *vg = gpiochip_get_data(chip);
1122	void __iomem *reg = byt_gpio_reg(vg, offset, BYT_VAL_REG);
1123	unsigned long flags;
1124	u32 val;
1125
1126	raw_spin_lock_irqsave(&byt_lock, flags);
1127	val = readl(reg);
1128	raw_spin_unlock_irqrestore(&byt_lock, flags);
1129
1130	return !!(val & BYT_LEVEL);
1131}
1132
1133static void byt_gpio_set(struct gpio_chip *chip, unsigned int offset, int value)
1134{
1135	struct intel_pinctrl *vg = gpiochip_get_data(chip);
1136	void __iomem *reg = byt_gpio_reg(vg, offset, BYT_VAL_REG);
1137	unsigned long flags;
1138	u32 old_val;
1139
1140	if (!reg)
1141		return;
1142
1143	raw_spin_lock_irqsave(&byt_lock, flags);
1144	old_val = readl(reg);
1145	if (value)
1146		writel(old_val | BYT_LEVEL, reg);
1147	else
1148		writel(old_val & ~BYT_LEVEL, reg);
1149	raw_spin_unlock_irqrestore(&byt_lock, flags);
1150}
1151
1152static int byt_gpio_get_direction(struct gpio_chip *chip, unsigned int offset)
1153{
1154	struct intel_pinctrl *vg = gpiochip_get_data(chip);
1155	void __iomem *reg = byt_gpio_reg(vg, offset, BYT_VAL_REG);
1156	unsigned long flags;
1157	u32 value;
1158
1159	if (!reg)
1160		return -EINVAL;
1161
1162	raw_spin_lock_irqsave(&byt_lock, flags);
1163	value = readl(reg);
1164	raw_spin_unlock_irqrestore(&byt_lock, flags);
1165
1166	if (!(value & BYT_OUTPUT_EN))
1167		return GPIO_LINE_DIRECTION_OUT;
1168	if (!(value & BYT_INPUT_EN))
1169		return GPIO_LINE_DIRECTION_IN;
1170
1171	return -EINVAL;
1172}
1173
1174static int byt_gpio_direction_input(struct gpio_chip *chip, unsigned int offset)
1175{
1176	struct intel_pinctrl *vg = gpiochip_get_data(chip);
1177	void __iomem *val_reg = byt_gpio_reg(vg, offset, BYT_VAL_REG);
1178	unsigned long flags;
1179	u32 reg;
1180
1181	raw_spin_lock_irqsave(&byt_lock, flags);
1182
1183	reg = readl(val_reg);
1184	reg &= ~BYT_DIR_MASK;
1185	reg |= BYT_OUTPUT_EN;
1186	writel(reg, val_reg);
1187
1188	raw_spin_unlock_irqrestore(&byt_lock, flags);
1189	return 0;
1190}
1191
1192/*
1193 * Note despite the temptation this MUST NOT be converted into a call to
1194 * pinctrl_gpio_direction_output() + byt_gpio_set() that does not work this
1195 * MUST be done as a single BYT_VAL_REG register write.
1196 * See the commit message of the commit adding this comment for details.
1197 */
1198static int byt_gpio_direction_output(struct gpio_chip *chip,
1199				     unsigned int offset, int value)
1200{
1201	struct intel_pinctrl *vg = gpiochip_get_data(chip);
1202	void __iomem *val_reg = byt_gpio_reg(vg, offset, BYT_VAL_REG);
1203	unsigned long flags;
1204	u32 reg;
1205
1206	raw_spin_lock_irqsave(&byt_lock, flags);
1207
1208	byt_gpio_direct_irq_check(vg, offset);
1209
1210	reg = readl(val_reg);
1211	reg &= ~BYT_DIR_MASK;
1212	if (value)
1213		reg |= BYT_LEVEL;
1214	else
1215		reg &= ~BYT_LEVEL;
1216
1217	writel(reg, val_reg);
1218
1219	raw_spin_unlock_irqrestore(&byt_lock, flags);
1220	return 0;
1221}
1222
1223static void byt_gpio_dbg_show(struct seq_file *s, struct gpio_chip *chip)
1224{
1225	struct intel_pinctrl *vg = gpiochip_get_data(chip);
1226	int i;
1227	u32 conf0, val;
1228
1229	for (i = 0; i < vg->soc->npins; i++) {
1230		const struct intel_community *comm;
1231		const char *pull_str = NULL;
1232		const char *pull = NULL;
1233		void __iomem *reg;
1234		unsigned long flags;
1235		const char *label;
1236		unsigned int pin;
1237
1238		raw_spin_lock_irqsave(&byt_lock, flags);
1239		pin = vg->soc->pins[i].number;
1240		reg = byt_gpio_reg(vg, pin, BYT_CONF0_REG);
1241		if (!reg) {
1242			seq_printf(s,
1243				   "Could not retrieve pin %i conf0 reg\n",
1244				   pin);
1245			raw_spin_unlock_irqrestore(&byt_lock, flags);
1246			continue;
1247		}
1248		conf0 = readl(reg);
1249
1250		reg = byt_gpio_reg(vg, pin, BYT_VAL_REG);
1251		if (!reg) {
1252			seq_printf(s,
1253				   "Could not retrieve pin %i val reg\n", pin);
1254			raw_spin_unlock_irqrestore(&byt_lock, flags);
1255			continue;
1256		}
1257		val = readl(reg);
1258		raw_spin_unlock_irqrestore(&byt_lock, flags);
1259
1260		comm = byt_get_community(vg, pin);
1261		if (!comm) {
1262			seq_printf(s,
1263				   "Could not get community for pin %i\n", pin);
1264			continue;
1265		}
1266		label = gpiochip_is_requested(chip, i);
1267		if (!label)
1268			label = "Unrequested";
1269
1270		switch (conf0 & BYT_PULL_ASSIGN_MASK) {
1271		case BYT_PULL_ASSIGN_UP:
1272			pull = "up";
1273			break;
1274		case BYT_PULL_ASSIGN_DOWN:
1275			pull = "down";
1276			break;
1277		}
1278
1279		switch (conf0 & BYT_PULL_STR_MASK) {
1280		case BYT_PULL_STR_2K:
1281			pull_str = "2k";
1282			break;
1283		case BYT_PULL_STR_10K:
1284			pull_str = "10k";
1285			break;
1286		case BYT_PULL_STR_20K:
1287			pull_str = "20k";
1288			break;
1289		case BYT_PULL_STR_40K:
1290			pull_str = "40k";
1291			break;
1292		}
1293
1294		seq_printf(s,
1295			   " gpio-%-3d (%-20.20s) %s %s %s pad-%-3d offset:0x%03x mux:%d %s%s%s",
1296			   pin,
1297			   label,
1298			   val & BYT_INPUT_EN ? "  " : "in",
1299			   val & BYT_OUTPUT_EN ? "   " : "out",
1300			   val & BYT_LEVEL ? "hi" : "lo",
1301			   comm->pad_map[i], comm->pad_map[i] * 16,
1302			   conf0 & 0x7,
1303			   conf0 & BYT_TRIG_NEG ? " fall" : "     ",
1304			   conf0 & BYT_TRIG_POS ? " rise" : "     ",
1305			   conf0 & BYT_TRIG_LVL ? " level" : "      ");
1306
1307		if (pull && pull_str)
1308			seq_printf(s, " %-4s %-3s", pull, pull_str);
1309		else
1310			seq_puts(s, "          ");
1311
1312		if (conf0 & BYT_IODEN)
1313			seq_puts(s, " open-drain");
1314
1315		seq_puts(s, "\n");
1316	}
1317}
1318
1319static const struct gpio_chip byt_gpio_chip = {
1320	.owner			= THIS_MODULE,
1321	.request		= gpiochip_generic_request,
1322	.free			= gpiochip_generic_free,
1323	.get_direction		= byt_gpio_get_direction,
1324	.direction_input	= byt_gpio_direction_input,
1325	.direction_output	= byt_gpio_direction_output,
1326	.get			= byt_gpio_get,
1327	.set			= byt_gpio_set,
1328	.set_config		= gpiochip_generic_config,
1329	.dbg_show		= byt_gpio_dbg_show,
1330};
1331
1332static void byt_irq_ack(struct irq_data *d)
1333{
1334	struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
1335	struct intel_pinctrl *vg = gpiochip_get_data(gc);
1336	unsigned int offset = irqd_to_hwirq(d);
1337	void __iomem *reg;
1338
1339	reg = byt_gpio_reg(vg, offset, BYT_INT_STAT_REG);
1340	if (!reg)
1341		return;
1342
1343	raw_spin_lock(&byt_lock);
1344	writel(BIT(offset % 32), reg);
1345	raw_spin_unlock(&byt_lock);
1346}
1347
1348static void byt_irq_mask(struct irq_data *d)
1349{
1350	struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
1351	struct intel_pinctrl *vg = gpiochip_get_data(gc);
1352
1353	byt_gpio_clear_triggering(vg, irqd_to_hwirq(d));
1354}
1355
1356static void byt_irq_unmask(struct irq_data *d)
1357{
1358	struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
1359	struct intel_pinctrl *vg = gpiochip_get_data(gc);
1360	unsigned int offset = irqd_to_hwirq(d);
1361	unsigned long flags;
1362	void __iomem *reg;
1363	u32 value;
1364
1365	reg = byt_gpio_reg(vg, offset, BYT_CONF0_REG);
1366	if (!reg)
1367		return;
1368
1369	raw_spin_lock_irqsave(&byt_lock, flags);
1370	value = readl(reg);
1371
1372	switch (irqd_get_trigger_type(d)) {
1373	case IRQ_TYPE_LEVEL_HIGH:
1374		value |= BYT_TRIG_LVL;
1375		fallthrough;
1376	case IRQ_TYPE_EDGE_RISING:
1377		value |= BYT_TRIG_POS;
1378		break;
1379	case IRQ_TYPE_LEVEL_LOW:
1380		value |= BYT_TRIG_LVL;
1381		fallthrough;
1382	case IRQ_TYPE_EDGE_FALLING:
1383		value |= BYT_TRIG_NEG;
1384		break;
1385	case IRQ_TYPE_EDGE_BOTH:
1386		value |= (BYT_TRIG_NEG | BYT_TRIG_POS);
1387		break;
1388	}
1389
1390	writel(value, reg);
1391
1392	raw_spin_unlock_irqrestore(&byt_lock, flags);
1393}
1394
1395static int byt_irq_type(struct irq_data *d, unsigned int type)
1396{
1397	struct intel_pinctrl *vg = gpiochip_get_data(irq_data_get_irq_chip_data(d));
1398	u32 offset = irqd_to_hwirq(d);
1399	u32 value;
1400	unsigned long flags;
1401	void __iomem *reg = byt_gpio_reg(vg, offset, BYT_CONF0_REG);
1402
1403	if (!reg || offset >= vg->chip.ngpio)
1404		return -EINVAL;
1405
1406	raw_spin_lock_irqsave(&byt_lock, flags);
1407	value = readl(reg);
1408
1409	WARN(value & BYT_DIRECT_IRQ_EN,
1410	     "Bad pad config for io mode, force direct_irq_en bit clearing");
1411
1412	/* For level trigges the BYT_TRIG_POS and BYT_TRIG_NEG bits
1413	 * are used to indicate high and low level triggering
1414	 */
1415	value &= ~(BYT_DIRECT_IRQ_EN | BYT_TRIG_POS | BYT_TRIG_NEG |
1416		   BYT_TRIG_LVL);
1417	/* Enable glitch filtering */
1418	value |= BYT_GLITCH_FILTER_EN | BYT_GLITCH_F_SLOW_CLK |
1419		 BYT_GLITCH_F_FAST_CLK;
1420
1421	writel(value, reg);
1422
1423	if (type & IRQ_TYPE_EDGE_BOTH)
1424		irq_set_handler_locked(d, handle_edge_irq);
1425	else if (type & IRQ_TYPE_LEVEL_MASK)
1426		irq_set_handler_locked(d, handle_level_irq);
1427
1428	raw_spin_unlock_irqrestore(&byt_lock, flags);
1429
1430	return 0;
1431}
1432
1433static void byt_gpio_irq_handler(struct irq_desc *desc)
1434{
1435	struct irq_data *data = irq_desc_get_irq_data(desc);
1436	struct intel_pinctrl *vg = gpiochip_get_data(irq_desc_get_handler_data(desc));
1437	struct irq_chip *chip = irq_data_get_irq_chip(data);
1438	u32 base, pin;
1439	void __iomem *reg;
1440	unsigned long pending;
1441	unsigned int virq;
1442
1443	/* check from GPIO controller which pin triggered the interrupt */
1444	for (base = 0; base < vg->chip.ngpio; base += 32) {
1445		reg = byt_gpio_reg(vg, base, BYT_INT_STAT_REG);
1446
1447		if (!reg) {
1448			dev_warn(vg->dev,
1449				 "Pin %i: could not retrieve interrupt status register\n",
1450				 base);
1451			continue;
1452		}
1453
1454		raw_spin_lock(&byt_lock);
1455		pending = readl(reg);
1456		raw_spin_unlock(&byt_lock);
1457		for_each_set_bit(pin, &pending, 32) {
1458			virq = irq_find_mapping(vg->chip.irq.domain, base + pin);
1459			generic_handle_irq(virq);
1460		}
1461	}
1462	chip->irq_eoi(data);
1463}
1464
1465static void byt_init_irq_valid_mask(struct gpio_chip *chip,
1466				    unsigned long *valid_mask,
1467				    unsigned int ngpios)
1468{
1469	struct intel_pinctrl *vg = gpiochip_get_data(chip);
1470	void __iomem *reg;
1471	u32 value;
1472	int i;
1473
1474	/*
1475	 * Clear interrupt triggers for all pins that are GPIOs and
1476	 * do not use direct IRQ mode. This will prevent spurious
1477	 * interrupts from misconfigured pins.
1478	 */
1479	for (i = 0; i < vg->soc->npins; i++) {
1480		unsigned int pin = vg->soc->pins[i].number;
1481
1482		reg = byt_gpio_reg(vg, pin, BYT_CONF0_REG);
1483		if (!reg) {
1484			dev_warn(vg->dev,
1485				 "Pin %i: could not retrieve conf0 register\n",
1486				 i);
1487			continue;
1488		}
1489
1490		value = readl(reg);
1491		if (value & BYT_DIRECT_IRQ_EN) {
1492			clear_bit(i, valid_mask);
1493			dev_dbg(vg->dev, "excluding GPIO %d from IRQ domain\n", i);
1494		} else if ((value & BYT_PIN_MUX) == byt_get_gpio_mux(vg, i)) {
1495			byt_gpio_clear_triggering(vg, i);
1496			dev_dbg(vg->dev, "disabling GPIO %d\n", i);
1497		}
1498	}
1499}
1500
1501static int byt_gpio_irq_init_hw(struct gpio_chip *chip)
1502{
1503	struct intel_pinctrl *vg = gpiochip_get_data(chip);
1504	void __iomem *reg;
1505	u32 base, value;
1506
1507	/* clear interrupt status trigger registers */
1508	for (base = 0; base < vg->soc->npins; base += 32) {
1509		reg = byt_gpio_reg(vg, base, BYT_INT_STAT_REG);
1510
1511		if (!reg) {
1512			dev_warn(vg->dev,
1513				 "Pin %i: could not retrieve irq status reg\n",
1514				 base);
1515			continue;
1516		}
1517
1518		writel(0xffffffff, reg);
1519		/* make sure trigger bits are cleared, if not then a pin
1520		   might be misconfigured in bios */
1521		value = readl(reg);
1522		if (value)
1523			dev_err(vg->dev,
1524				"GPIO interrupt error, pins misconfigured. INT_STAT%u: 0x%08x\n",
1525				base / 32, value);
1526	}
1527
1528	return 0;
1529}
1530
1531static int byt_gpio_add_pin_ranges(struct gpio_chip *chip)
1532{
1533	struct intel_pinctrl *vg = gpiochip_get_data(chip);
1534	struct device *dev = vg->dev;
1535	int ret;
1536
1537	ret = gpiochip_add_pin_range(chip, dev_name(dev), 0, 0, vg->soc->npins);
1538	if (ret)
1539		dev_err(dev, "failed to add GPIO pin range\n");
1540
1541	return ret;
1542}
1543
1544static int byt_gpio_probe(struct intel_pinctrl *vg)
1545{
1546	struct platform_device *pdev = to_platform_device(vg->dev);
1547	struct gpio_chip *gc;
1548	int irq, ret;
1549
1550	/* Set up gpio chip */
1551	vg->chip	= byt_gpio_chip;
1552	gc		= &vg->chip;
1553	gc->label	= dev_name(vg->dev);
1554	gc->base	= -1;
1555	gc->can_sleep	= false;
1556	gc->add_pin_ranges = byt_gpio_add_pin_ranges;
1557	gc->parent	= vg->dev;
1558	gc->ngpio	= vg->soc->npins;
1559
1560#ifdef CONFIG_PM_SLEEP
1561	vg->context.pads = devm_kcalloc(vg->dev, gc->ngpio, sizeof(*vg->context.pads),
1562					GFP_KERNEL);
1563	if (!vg->context.pads)
1564		return -ENOMEM;
1565#endif
1566
1567	/* set up interrupts  */
1568	irq = platform_get_irq_optional(pdev, 0);
1569	if (irq > 0) {
1570		struct gpio_irq_chip *girq;
1571
1572		vg->irqchip.name = "BYT-GPIO",
1573		vg->irqchip.irq_ack = byt_irq_ack,
1574		vg->irqchip.irq_mask = byt_irq_mask,
1575		vg->irqchip.irq_unmask = byt_irq_unmask,
1576		vg->irqchip.irq_set_type = byt_irq_type,
1577		vg->irqchip.flags = IRQCHIP_SKIP_SET_WAKE,
1578
1579		girq = &gc->irq;
1580		girq->chip = &vg->irqchip;
1581		girq->init_hw = byt_gpio_irq_init_hw;
1582		girq->init_valid_mask = byt_init_irq_valid_mask;
1583		girq->parent_handler = byt_gpio_irq_handler;
1584		girq->num_parents = 1;
1585		girq->parents = devm_kcalloc(vg->dev, girq->num_parents,
1586					     sizeof(*girq->parents), GFP_KERNEL);
1587		if (!girq->parents)
1588			return -ENOMEM;
1589		girq->parents[0] = irq;
1590		girq->default_type = IRQ_TYPE_NONE;
1591		girq->handler = handle_bad_irq;
1592	}
1593
1594	ret = devm_gpiochip_add_data(vg->dev, gc, vg);
1595	if (ret) {
1596		dev_err(vg->dev, "failed adding byt-gpio chip\n");
1597		return ret;
1598	}
1599
1600	return ret;
1601}
1602
1603static int byt_set_soc_data(struct intel_pinctrl *vg,
1604			    const struct intel_pinctrl_soc_data *soc)
1605{
1606	struct platform_device *pdev = to_platform_device(vg->dev);
1607	int i;
1608
1609	vg->soc = soc;
1610
1611	vg->ncommunities = vg->soc->ncommunities;
1612	vg->communities = devm_kcalloc(vg->dev, vg->ncommunities,
1613				       sizeof(*vg->communities), GFP_KERNEL);
1614	if (!vg->communities)
1615		return -ENOMEM;
1616
1617	for (i = 0; i < vg->soc->ncommunities; i++) {
1618		struct intel_community *comm = vg->communities + i;
1619
1620		*comm = vg->soc->communities[i];
1621
1622		comm->pad_regs = devm_platform_ioremap_resource(pdev, 0);
1623		if (IS_ERR(comm->pad_regs))
1624			return PTR_ERR(comm->pad_regs);
1625	}
1626
1627	return 0;
1628}
1629
1630static const struct acpi_device_id byt_gpio_acpi_match[] = {
1631	{ "INT33B2", (kernel_ulong_t)byt_soc_data },
1632	{ "INT33FC", (kernel_ulong_t)byt_soc_data },
1633	{ }
1634};
1635
1636static int byt_pinctrl_probe(struct platform_device *pdev)
1637{
1638	const struct intel_pinctrl_soc_data *soc_data = NULL;
1639	const struct intel_pinctrl_soc_data **soc_table;
1640	struct device *dev = &pdev->dev;
1641	struct acpi_device *acpi_dev;
1642	struct intel_pinctrl *vg;
1643	int i, ret;
1644
1645	acpi_dev = ACPI_COMPANION(dev);
1646	if (!acpi_dev)
1647		return -ENODEV;
1648
1649	soc_table = (const struct intel_pinctrl_soc_data **)device_get_match_data(dev);
1650
1651	for (i = 0; soc_table[i]; i++) {
1652		if (!strcmp(acpi_dev->pnp.unique_id, soc_table[i]->uid)) {
1653			soc_data = soc_table[i];
1654			break;
1655		}
1656	}
1657
1658	if (!soc_data)
1659		return -ENODEV;
1660
1661	vg = devm_kzalloc(dev, sizeof(*vg), GFP_KERNEL);
1662	if (!vg)
1663		return -ENOMEM;
1664
1665	vg->dev = dev;
1666	ret = byt_set_soc_data(vg, soc_data);
1667	if (ret) {
1668		dev_err(dev, "failed to set soc data\n");
1669		return ret;
1670	}
1671
1672	vg->pctldesc		= byt_pinctrl_desc;
1673	vg->pctldesc.name	= dev_name(dev);
1674	vg->pctldesc.pins	= vg->soc->pins;
1675	vg->pctldesc.npins	= vg->soc->npins;
1676
1677	vg->pctldev = devm_pinctrl_register(dev, &vg->pctldesc, vg);
1678	if (IS_ERR(vg->pctldev)) {
1679		dev_err(dev, "failed to register pinctrl driver\n");
1680		return PTR_ERR(vg->pctldev);
1681	}
1682
1683	ret = byt_gpio_probe(vg);
1684	if (ret)
1685		return ret;
1686
1687	platform_set_drvdata(pdev, vg);
1688	pm_runtime_enable(dev);
1689
1690	return 0;
1691}
1692
1693#ifdef CONFIG_PM_SLEEP
1694static int byt_gpio_suspend(struct device *dev)
1695{
1696	struct intel_pinctrl *vg = dev_get_drvdata(dev);
1697	unsigned long flags;
1698	int i;
1699
1700	raw_spin_lock_irqsave(&byt_lock, flags);
1701
1702	for (i = 0; i < vg->soc->npins; i++) {
1703		void __iomem *reg;
1704		u32 value;
1705		unsigned int pin = vg->soc->pins[i].number;
1706
1707		reg = byt_gpio_reg(vg, pin, BYT_CONF0_REG);
1708		if (!reg) {
1709			dev_warn(vg->dev,
1710				 "Pin %i: could not retrieve conf0 register\n",
1711				 i);
1712			continue;
1713		}
1714		value = readl(reg) & BYT_CONF0_RESTORE_MASK;
1715		vg->context.pads[i].conf0 = value;
1716
1717		reg = byt_gpio_reg(vg, pin, BYT_VAL_REG);
1718		value = readl(reg) & BYT_VAL_RESTORE_MASK;
1719		vg->context.pads[i].val = value;
1720	}
1721
1722	raw_spin_unlock_irqrestore(&byt_lock, flags);
1723	return 0;
1724}
1725
1726static int byt_gpio_resume(struct device *dev)
1727{
1728	struct intel_pinctrl *vg = dev_get_drvdata(dev);
1729	unsigned long flags;
1730	int i;
1731
1732	raw_spin_lock_irqsave(&byt_lock, flags);
1733
1734	for (i = 0; i < vg->soc->npins; i++) {
1735		void __iomem *reg;
1736		u32 value;
1737		unsigned int pin = vg->soc->pins[i].number;
1738
1739		reg = byt_gpio_reg(vg, pin, BYT_CONF0_REG);
1740		if (!reg) {
1741			dev_warn(vg->dev,
1742				 "Pin %i: could not retrieve conf0 register\n",
1743				 i);
1744			continue;
1745		}
1746		value = readl(reg);
1747		if ((value & BYT_CONF0_RESTORE_MASK) !=
1748		     vg->context.pads[i].conf0) {
1749			value &= ~BYT_CONF0_RESTORE_MASK;
1750			value |= vg->context.pads[i].conf0;
1751			writel(value, reg);
1752			dev_info(dev, "restored pin %d conf0 %#08x", i, value);
1753		}
1754
1755		reg = byt_gpio_reg(vg, pin, BYT_VAL_REG);
1756		value = readl(reg);
1757		if ((value & BYT_VAL_RESTORE_MASK) !=
1758		     vg->context.pads[i].val) {
1759			u32 v;
1760
1761			v = value & ~BYT_VAL_RESTORE_MASK;
1762			v |= vg->context.pads[i].val;
1763			if (v != value) {
1764				writel(v, reg);
1765				dev_dbg(dev, "restored pin %d val %#08x\n",
1766					i, v);
1767			}
1768		}
1769	}
1770
1771	raw_spin_unlock_irqrestore(&byt_lock, flags);
1772	return 0;
1773}
1774#endif
1775
1776#ifdef CONFIG_PM
1777static int byt_gpio_runtime_suspend(struct device *dev)
1778{
1779	return 0;
1780}
1781
1782static int byt_gpio_runtime_resume(struct device *dev)
1783{
1784	return 0;
1785}
1786#endif
1787
1788static const struct dev_pm_ops byt_gpio_pm_ops = {
1789	SET_LATE_SYSTEM_SLEEP_PM_OPS(byt_gpio_suspend, byt_gpio_resume)
1790	SET_RUNTIME_PM_OPS(byt_gpio_runtime_suspend, byt_gpio_runtime_resume,
1791			   NULL)
1792};
1793
1794static struct platform_driver byt_gpio_driver = {
1795	.probe          = byt_pinctrl_probe,
1796	.driver         = {
1797		.name			= "byt_gpio",
1798		.pm			= &byt_gpio_pm_ops,
1799		.acpi_match_table	= byt_gpio_acpi_match,
1800		.suppress_bind_attrs	= true,
1801	},
1802};
1803
1804static int __init byt_gpio_init(void)
1805{
1806	return platform_driver_register(&byt_gpio_driver);
1807}
1808subsys_initcall(byt_gpio_init);