// SPDX-License-Identifier: GPL-2.0
//
// imx35 pinctrl driver.
//
// This driver was mostly copied from the imx51 pinctrl driver which has:
//
// Copyright (C) 2012 Freescale Semiconductor, Inc.
// Copyright (C) 2012 Linaro, Inc.
//
// Author: Dong Aisheng <dong.aisheng@linaro.org>
#include <linux/err.h>
#include <linux/init.h>
#include <linux/io.h>
#include <linux/mod_devicetable.h>
#include <linux/platform_device.h>
#include <linux/pinctrl/pinctrl.h>
#include "pinctrl-imx.h"
enum imx35_pads {
MX35_PAD_RESERVE0 = 0,
MX35_PAD_CAPTURE = 1,
MX35_PAD_COMPARE = 2,
MX35_PAD_WDOG_RST = 3,
MX35_PAD_GPIO1_0 = 4,
MX35_PAD_GPIO1_1 = 5,
MX35_PAD_GPIO2_0 = 6,
MX35_PAD_GPIO3_0 = 7,
MX35_PAD_CLKO = 8,
MX35_PAD_VSTBY = 9,
MX35_PAD_A0 = 10,
MX35_PAD_A1 = 11,
MX35_PAD_A2 = 12,
MX35_PAD_A3 = 13,
MX35_PAD_A4 = 14,
MX35_PAD_A5 = 15,
MX35_PAD_A6 = 16,
MX35_PAD_A7 = 17,
MX35_PAD_A8 = 18,
MX35_PAD_A9 = 19,
MX35_PAD_A10 = 20,
MX35_PAD_MA10 = 21,
MX35_PAD_A11 = 22,
MX35_PAD_A12 = 23,
MX35_PAD_A13 = 24,
MX35_PAD_A14 = 25,
MX35_PAD_A15 = 26,
MX35_PAD_A16 = 27,
MX35_PAD_A17 = 28,
MX35_PAD_A18 = 29,
MX35_PAD_A19 = 30,
MX35_PAD_A20 = 31,
MX35_PAD_A21 = 32,
MX35_PAD_A22 = 33,
MX35_PAD_A23 = 34,
MX35_PAD_A24 = 35,
MX35_PAD_A25 = 36,
MX35_PAD_EB0 = 37,
MX35_PAD_EB1 = 38,
MX35_PAD_OE = 39,
MX35_PAD_CS0 = 40,
MX35_PAD_CS1 = 41,
MX35_PAD_CS2 = 42,
MX35_PAD_CS3 = 43,
MX35_PAD_CS4 = 44,
MX35_PAD_CS5 = 45,
MX35_PAD_NF_CE0 = 46,
MX35_PAD_LBA = 47,
MX35_PAD_BCLK = 48,
MX35_PAD_RW = 49,
MX35_PAD_NFWE_B = 50,
MX35_PAD_NFRE_B = 51,
MX35_PAD_NFALE = 52,
MX35_PAD_NFCLE = 53,
MX35_PAD_NFWP_B = 54,
MX35_PAD_NFRB = 55,
MX35_PAD_CSI_D8 = 56,
MX35_PAD_CSI_D9 = 57,
MX35_PAD_CSI_D10 = 58,
MX35_PAD_CSI_D11 = 59,
MX35_PAD_CSI_D12 = 60,
MX35_PAD_CSI_D13 = 61,
MX35_PAD_CSI_D14 = 62,
MX35_PAD_CSI_D15 = 63,
MX35_PAD_CSI_MCLK = 64,
MX35_PAD_CSI_VSYNC = 65,
MX35_PAD_CSI_HSYNC = 66,
MX35_PAD_CSI_PIXCLK = 67,
MX35_PAD_I2C1_CLK = 68,
MX35_PAD_I2C1_DAT = 69,
MX35_PAD_I2C2_CLK = 70,
MX35_PAD_I2C2_DAT = 71,
MX35_PAD_STXD4 = 72,
MX35_PAD_SRXD4 = 73,
MX35_PAD_SCK4 = 74,
MX35_PAD_STXFS4 = 75,
MX35_PAD_STXD5 = 76,
MX35_PAD_SRXD5 = 77,
MX35_PAD_SCK5 = 78,
MX35_PAD_STXFS5 = 79,
MX35_PAD_SCKR = 80,
MX35_PAD_FSR = 81,
MX35_PAD_HCKR = 82,
MX35_PAD_SCKT = 83,
MX35_PAD_FST = 84,
MX35_PAD_HCKT = 85,
MX35_PAD_TX5_RX0 = 86,
MX35_PAD_TX4_RX1 = 87,
MX35_PAD_TX3_RX2 = 88,
MX35_PAD_TX2_RX3 = 89,
MX35_PAD_TX1 = 90,
MX35_PAD_TX0 = 91,
MX35_PAD_CSPI1_MOSI = 92,
MX35_PAD_CSPI1_MISO = 93,
MX35_PAD_CSPI1_SS0 = 94,
MX35_PAD_CSPI1_SS1 = 95,
MX35_PAD_CSPI1_SCLK = 96,
MX35_PAD_CSPI1_SPI_RDY = 97,
MX35_PAD_RXD1 = 98,
MX35_PAD_TXD1 = 99,
MX35_PAD_RTS1 = 100,
MX35_PAD_CTS1 = 101,
MX35_PAD_RXD2 = 102,
MX35_PAD_TXD2 = 103,
MX35_PAD_RTS2 = 104,
MX35_PAD_CTS2 = 105,
MX35_PAD_USBOTG_PWR = 106,
MX35_PAD_USBOTG_OC = 107,
MX35_PAD_LD0 = 108,
MX35_PAD_LD1 = 109,
MX35_PAD_LD2 = 110,
MX35_PAD_LD3 = 111,
MX35_PAD_LD4 = 112,
MX35_PAD_LD5 = 113,
MX35_PAD_LD6 = 114,
MX35_PAD_LD7 = 115,
MX35_PAD_LD8 = 116,
MX35_PAD_LD9 = 117,
MX35_PAD_LD10 = 118,
MX35_PAD_LD11 = 119,
MX35_PAD_LD12 = 120,
MX35_PAD_LD13 = 121,
MX35_PAD_LD14 = 122,
MX35_PAD_LD15 = 123,
MX35_PAD_LD16 = 124,
MX35_PAD_LD17 = 125,
MX35_PAD_LD18 = 126,
MX35_PAD_LD19 = 127,
MX35_PAD_LD20 = 128,
MX35_PAD_LD21 = 129,
MX35_PAD_LD22 = 130,
MX35_PAD_LD23 = 131,
MX35_PAD_D3_HSYNC = 132,
MX35_PAD_D3_FPSHIFT = 133,
MX35_PAD_D3_DRDY = 134,
MX35_PAD_CONTRAST = 135,
MX35_PAD_D3_VSYNC = 136,
MX35_PAD_D3_REV = 137,
MX35_PAD_D3_CLS = 138,
MX35_PAD_D3_SPL = 139,
MX35_PAD_SD1_CMD = 140,
MX35_PAD_SD1_CLK = 141,
MX35_PAD_SD1_DATA0 = 142,
MX35_PAD_SD1_DATA1 = 143,
MX35_PAD_SD1_DATA2 = 144,
MX35_PAD_SD1_DATA3 = 145,
MX35_PAD_SD2_CMD = 146,
MX35_PAD_SD2_CLK = 147,
MX35_PAD_SD2_DATA0 = 148,
MX35_PAD_SD2_DATA1 = 149,
MX35_PAD_SD2_DATA2 = 150,
MX35_PAD_SD2_DATA3 = 151,
MX35_PAD_ATA_CS0 = 152,
MX35_PAD_ATA_CS1 = 153,
MX35_PAD_ATA_DIOR = 154,
MX35_PAD_ATA_DIOW = 155,
MX35_PAD_ATA_DMACK = 156,
MX35_PAD_ATA_RESET_B = 157,
MX35_PAD_ATA_IORDY = 158,
MX35_PAD_ATA_DATA0 = 159,
MX35_PAD_ATA_DATA1 = 160,
MX35_PAD_ATA_DATA2 = 161,
MX35_PAD_ATA_DATA3 = 162,
MX35_PAD_ATA_DATA4 = 163,
MX35_PAD_ATA_DATA5 = 164,
MX35_PAD_ATA_DATA6 = 165,
MX35_PAD_ATA_DATA7 = 166,
MX35_PAD_ATA_DATA8 = 167,
MX35_PAD_ATA_DATA9 = 168,
MX35_PAD_ATA_DATA10 = 169,
MX35_PAD_ATA_DATA11 = 170,
MX35_PAD_ATA_DATA12 = 171,
MX35_PAD_ATA_DATA13 = 172,
MX35_PAD_ATA_DATA14 = 173,
MX35_PAD_ATA_DATA15 = 174,
MX35_PAD_ATA_INTRQ = 175,