18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0+ 28c2ecf20Sopenharmony_ci// 38c2ecf20Sopenharmony_ci// Freescale i.MX28 pinctrl driver 48c2ecf20Sopenharmony_ci// 58c2ecf20Sopenharmony_ci// Author: Shawn Guo <shawn.guo@linaro.org> 68c2ecf20Sopenharmony_ci// Copyright 2012 Freescale Semiconductor, Inc. 78c2ecf20Sopenharmony_ci 88c2ecf20Sopenharmony_ci#include <linux/init.h> 98c2ecf20Sopenharmony_ci#include <linux/of_device.h> 108c2ecf20Sopenharmony_ci#include <linux/pinctrl/pinctrl.h> 118c2ecf20Sopenharmony_ci#include "pinctrl-mxs.h" 128c2ecf20Sopenharmony_ci 138c2ecf20Sopenharmony_cienum imx28_pin_enum { 148c2ecf20Sopenharmony_ci GPMI_D00 = PINID(0, 0), 158c2ecf20Sopenharmony_ci GPMI_D01 = PINID(0, 1), 168c2ecf20Sopenharmony_ci GPMI_D02 = PINID(0, 2), 178c2ecf20Sopenharmony_ci GPMI_D03 = PINID(0, 3), 188c2ecf20Sopenharmony_ci GPMI_D04 = PINID(0, 4), 198c2ecf20Sopenharmony_ci GPMI_D05 = PINID(0, 5), 208c2ecf20Sopenharmony_ci GPMI_D06 = PINID(0, 6), 218c2ecf20Sopenharmony_ci GPMI_D07 = PINID(0, 7), 228c2ecf20Sopenharmony_ci GPMI_CE0N = PINID(0, 16), 238c2ecf20Sopenharmony_ci GPMI_CE1N = PINID(0, 17), 248c2ecf20Sopenharmony_ci GPMI_CE2N = PINID(0, 18), 258c2ecf20Sopenharmony_ci GPMI_CE3N = PINID(0, 19), 268c2ecf20Sopenharmony_ci GPMI_RDY0 = PINID(0, 20), 278c2ecf20Sopenharmony_ci GPMI_RDY1 = PINID(0, 21), 288c2ecf20Sopenharmony_ci GPMI_RDY2 = PINID(0, 22), 298c2ecf20Sopenharmony_ci GPMI_RDY3 = PINID(0, 23), 308c2ecf20Sopenharmony_ci GPMI_RDN = PINID(0, 24), 318c2ecf20Sopenharmony_ci GPMI_WRN = PINID(0, 25), 328c2ecf20Sopenharmony_ci GPMI_ALE = PINID(0, 26), 338c2ecf20Sopenharmony_ci GPMI_CLE = PINID(0, 27), 348c2ecf20Sopenharmony_ci GPMI_RESETN = PINID(0, 28), 358c2ecf20Sopenharmony_ci LCD_D00 = PINID(1, 0), 368c2ecf20Sopenharmony_ci LCD_D01 = PINID(1, 1), 378c2ecf20Sopenharmony_ci LCD_D02 = PINID(1, 2), 388c2ecf20Sopenharmony_ci LCD_D03 = PINID(1, 3), 398c2ecf20Sopenharmony_ci LCD_D04 = PINID(1, 4), 408c2ecf20Sopenharmony_ci LCD_D05 = PINID(1, 5), 418c2ecf20Sopenharmony_ci LCD_D06 = PINID(1, 6), 428c2ecf20Sopenharmony_ci LCD_D07 = PINID(1, 7), 438c2ecf20Sopenharmony_ci LCD_D08 = PINID(1, 8), 448c2ecf20Sopenharmony_ci LCD_D09 = PINID(1, 9), 458c2ecf20Sopenharmony_ci LCD_D10 = PINID(1, 10), 468c2ecf20Sopenharmony_ci LCD_D11 = PINID(1, 11), 478c2ecf20Sopenharmony_ci LCD_D12 = PINID(1, 12), 488c2ecf20Sopenharmony_ci LCD_D13 = PINID(1, 13), 498c2ecf20Sopenharmony_ci LCD_D14 = PINID(1, 14), 508c2ecf20Sopenharmony_ci LCD_D15 = PINID(1, 15), 518c2ecf20Sopenharmony_ci LCD_D16 = PINID(1, 16), 528c2ecf20Sopenharmony_ci LCD_D17 = PINID(1, 17), 538c2ecf20Sopenharmony_ci LCD_D18 = PINID(1, 18), 548c2ecf20Sopenharmony_ci LCD_D19 = PINID(1, 19), 558c2ecf20Sopenharmony_ci LCD_D20 = PINID(1, 20), 568c2ecf20Sopenharmony_ci LCD_D21 = PINID(1, 21), 578c2ecf20Sopenharmony_ci LCD_D22 = PINID(1, 22), 588c2ecf20Sopenharmony_ci LCD_D23 = PINID(1, 23), 598c2ecf20Sopenharmony_ci LCD_RD_E = PINID(1, 24), 608c2ecf20Sopenharmony_ci LCD_WR_RWN = PINID(1, 25), 618c2ecf20Sopenharmony_ci LCD_RS = PINID(1, 26), 628c2ecf20Sopenharmony_ci LCD_CS = PINID(1, 27), 638c2ecf20Sopenharmony_ci LCD_VSYNC = PINID(1, 28), 648c2ecf20Sopenharmony_ci LCD_HSYNC = PINID(1, 29), 658c2ecf20Sopenharmony_ci LCD_DOTCLK = PINID(1, 30), 668c2ecf20Sopenharmony_ci LCD_ENABLE = PINID(1, 31), 678c2ecf20Sopenharmony_ci SSP0_DATA0 = PINID(2, 0), 688c2ecf20Sopenharmony_ci SSP0_DATA1 = PINID(2, 1), 698c2ecf20Sopenharmony_ci SSP0_DATA2 = PINID(2, 2), 708c2ecf20Sopenharmony_ci SSP0_DATA3 = PINID(2, 3), 718c2ecf20Sopenharmony_ci SSP0_DATA4 = PINID(2, 4), 728c2ecf20Sopenharmony_ci SSP0_DATA5 = PINID(2, 5), 738c2ecf20Sopenharmony_ci SSP0_DATA6 = PINID(2, 6), 748c2ecf20Sopenharmony_ci SSP0_DATA7 = PINID(2, 7), 758c2ecf20Sopenharmony_ci SSP0_CMD = PINID(2, 8), 768c2ecf20Sopenharmony_ci SSP0_DETECT = PINID(2, 9), 778c2ecf20Sopenharmony_ci SSP0_SCK = PINID(2, 10), 788c2ecf20Sopenharmony_ci SSP1_SCK = PINID(2, 12), 798c2ecf20Sopenharmony_ci SSP1_CMD = PINID(2, 13), 808c2ecf20Sopenharmony_ci SSP1_DATA0 = PINID(2, 14), 818c2ecf20Sopenharmony_ci SSP1_DATA3 = PINID(2, 15), 828c2ecf20Sopenharmony_ci SSP2_SCK = PINID(2, 16), 838c2ecf20Sopenharmony_ci SSP2_MOSI = PINID(2, 17), 848c2ecf20Sopenharmony_ci SSP2_MISO = PINID(2, 18), 858c2ecf20Sopenharmony_ci SSP2_SS0 = PINID(2, 19), 868c2ecf20Sopenharmony_ci SSP2_SS1 = PINID(2, 20), 878c2ecf20Sopenharmony_ci SSP2_SS2 = PINID(2, 21), 888c2ecf20Sopenharmony_ci SSP3_SCK = PINID(2, 24), 898c2ecf20Sopenharmony_ci SSP3_MOSI = PINID(2, 25), 908c2ecf20Sopenharmony_ci SSP3_MISO = PINID(2, 26), 918c2ecf20Sopenharmony_ci SSP3_SS0 = PINID(2, 27), 928c2ecf20Sopenharmony_ci AUART0_RX = PINID(3, 0), 938c2ecf20Sopenharmony_ci AUART0_TX = PINID(3, 1), 948c2ecf20Sopenharmony_ci AUART0_CTS = PINID(3, 2), 958c2ecf20Sopenharmony_ci AUART0_RTS = PINID(3, 3), 968c2ecf20Sopenharmony_ci AUART1_RX = PINID(3, 4), 978c2ecf20Sopenharmony_ci AUART1_TX = PINID(3, 5), 988c2ecf20Sopenharmony_ci AUART1_CTS = PINID(3, 6), 998c2ecf20Sopenharmony_ci AUART1_RTS = PINID(3, 7), 1008c2ecf20Sopenharmony_ci AUART2_RX = PINID(3, 8), 1018c2ecf20Sopenharmony_ci AUART2_TX = PINID(3, 9), 1028c2ecf20Sopenharmony_ci AUART2_CTS = PINID(3, 10), 1038c2ecf20Sopenharmony_ci AUART2_RTS = PINID(3, 11), 1048c2ecf20Sopenharmony_ci AUART3_RX = PINID(3, 12), 1058c2ecf20Sopenharmony_ci AUART3_TX = PINID(3, 13), 1068c2ecf20Sopenharmony_ci AUART3_CTS = PINID(3, 14), 1078c2ecf20Sopenharmony_ci AUART3_RTS = PINID(3, 15), 1088c2ecf20Sopenharmony_ci PWM0 = PINID(3, 16), 1098c2ecf20Sopenharmony_ci PWM1 = PINID(3, 17), 1108c2ecf20Sopenharmony_ci PWM2 = PINID(3, 18), 1118c2ecf20Sopenharmony_ci SAIF0_MCLK = PINID(3, 20), 1128c2ecf20Sopenharmony_ci SAIF0_LRCLK = PINID(3, 21), 1138c2ecf20Sopenharmony_ci SAIF0_BITCLK = PINID(3, 22), 1148c2ecf20Sopenharmony_ci SAIF0_SDATA0 = PINID(3, 23), 1158c2ecf20Sopenharmony_ci I2C0_SCL = PINID(3, 24), 1168c2ecf20Sopenharmony_ci I2C0_SDA = PINID(3, 25), 1178c2ecf20Sopenharmony_ci SAIF1_SDATA0 = PINID(3, 26), 1188c2ecf20Sopenharmony_ci SPDIF = PINID(3, 27), 1198c2ecf20Sopenharmony_ci PWM3 = PINID(3, 28), 1208c2ecf20Sopenharmony_ci PWM4 = PINID(3, 29), 1218c2ecf20Sopenharmony_ci LCD_RESET = PINID(3, 30), 1228c2ecf20Sopenharmony_ci ENET0_MDC = PINID(4, 0), 1238c2ecf20Sopenharmony_ci ENET0_MDIO = PINID(4, 1), 1248c2ecf20Sopenharmony_ci ENET0_RX_EN = PINID(4, 2), 1258c2ecf20Sopenharmony_ci ENET0_RXD0 = PINID(4, 3), 1268c2ecf20Sopenharmony_ci ENET0_RXD1 = PINID(4, 4), 1278c2ecf20Sopenharmony_ci ENET0_TX_CLK = PINID(4, 5), 1288c2ecf20Sopenharmony_ci ENET0_TX_EN = PINID(4, 6), 1298c2ecf20Sopenharmony_ci ENET0_TXD0 = PINID(4, 7), 1308c2ecf20Sopenharmony_ci ENET0_TXD1 = PINID(4, 8), 1318c2ecf20Sopenharmony_ci ENET0_RXD2 = PINID(4, 9), 1328c2ecf20Sopenharmony_ci ENET0_RXD3 = PINID(4, 10), 1338c2ecf20Sopenharmony_ci ENET0_TXD2 = PINID(4, 11), 1348c2ecf20Sopenharmony_ci ENET0_TXD3 = PINID(4, 12), 1358c2ecf20Sopenharmony_ci ENET0_RX_CLK = PINID(4, 13), 1368c2ecf20Sopenharmony_ci ENET0_COL = PINID(4, 14), 1378c2ecf20Sopenharmony_ci ENET0_CRS = PINID(4, 15), 1388c2ecf20Sopenharmony_ci ENET_CLK = PINID(4, 16), 1398c2ecf20Sopenharmony_ci JTAG_RTCK = PINID(4, 20), 1408c2ecf20Sopenharmony_ci EMI_D00 = PINID(5, 0), 1418c2ecf20Sopenharmony_ci EMI_D01 = PINID(5, 1), 1428c2ecf20Sopenharmony_ci EMI_D02 = PINID(5, 2), 1438c2ecf20Sopenharmony_ci EMI_D03 = PINID(5, 3), 1448c2ecf20Sopenharmony_ci EMI_D04 = PINID(5, 4), 1458c2ecf20Sopenharmony_ci EMI_D05 = PINID(5, 5), 1468c2ecf20Sopenharmony_ci EMI_D06 = PINID(5, 6), 1478c2ecf20Sopenharmony_ci EMI_D07 = PINID(5, 7), 1488c2ecf20Sopenharmony_ci EMI_D08 = PINID(5, 8), 1498c2ecf20Sopenharmony_ci EMI_D09 = PINID(5, 9), 1508c2ecf20Sopenharmony_ci EMI_D10 = PINID(5, 10), 1518c2ecf20Sopenharmony_ci EMI_D11 = PINID(5, 11), 1528c2ecf20Sopenharmony_ci EMI_D12 = PINID(5, 12), 1538c2ecf20Sopenharmony_ci EMI_D13 = PINID(5, 13), 1548c2ecf20Sopenharmony_ci EMI_D14 = PINID(5, 14), 1558c2ecf20Sopenharmony_ci EMI_D15 = PINID(5, 15), 1568c2ecf20Sopenharmony_ci EMI_ODT0 = PINID(5, 16), 1578c2ecf20Sopenharmony_ci EMI_DQM0 = PINID(5, 17), 1588c2ecf20Sopenharmony_ci EMI_ODT1 = PINID(5, 18), 1598c2ecf20Sopenharmony_ci EMI_DQM1 = PINID(5, 19), 1608c2ecf20Sopenharmony_ci EMI_DDR_OPEN_FB = PINID(5, 20), 1618c2ecf20Sopenharmony_ci EMI_CLK = PINID(5, 21), 1628c2ecf20Sopenharmony_ci EMI_DQS0 = PINID(5, 22), 1638c2ecf20Sopenharmony_ci EMI_DQS1 = PINID(5, 23), 1648c2ecf20Sopenharmony_ci EMI_DDR_OPEN = PINID(5, 26), 1658c2ecf20Sopenharmony_ci EMI_A00 = PINID(6, 0), 1668c2ecf20Sopenharmony_ci EMI_A01 = PINID(6, 1), 1678c2ecf20Sopenharmony_ci EMI_A02 = PINID(6, 2), 1688c2ecf20Sopenharmony_ci EMI_A03 = PINID(6, 3), 1698c2ecf20Sopenharmony_ci EMI_A04 = PINID(6, 4), 1708c2ecf20Sopenharmony_ci EMI_A05 = PINID(6, 5), 1718c2ecf20Sopenharmony_ci EMI_A06 = PINID(6, 6), 1728c2ecf20Sopenharmony_ci EMI_A07 = PINID(6, 7), 1738c2ecf20Sopenharmony_ci EMI_A08 = PINID(6, 8), 1748c2ecf20Sopenharmony_ci EMI_A09 = PINID(6, 9), 1758c2ecf20Sopenharmony_ci EMI_A10 = PINID(6, 10), 1768c2ecf20Sopenharmony_ci EMI_A11 = PINID(6, 11), 1778c2ecf20Sopenharmony_ci EMI_A12 = PINID(6, 12), 1788c2ecf20Sopenharmony_ci EMI_A13 = PINID(6, 13), 1798c2ecf20Sopenharmony_ci EMI_A14 = PINID(6, 14), 1808c2ecf20Sopenharmony_ci EMI_BA0 = PINID(6, 16), 1818c2ecf20Sopenharmony_ci EMI_BA1 = PINID(6, 17), 1828c2ecf20Sopenharmony_ci EMI_BA2 = PINID(6, 18), 1838c2ecf20Sopenharmony_ci EMI_CASN = PINID(6, 19), 1848c2ecf20Sopenharmony_ci EMI_RASN = PINID(6, 20), 1858c2ecf20Sopenharmony_ci EMI_WEN = PINID(6, 21), 1868c2ecf20Sopenharmony_ci EMI_CE0N = PINID(6, 22), 1878c2ecf20Sopenharmony_ci EMI_CE1N = PINID(6, 23), 1888c2ecf20Sopenharmony_ci EMI_CKE = PINID(6, 24), 1898c2ecf20Sopenharmony_ci}; 1908c2ecf20Sopenharmony_ci 1918c2ecf20Sopenharmony_cistatic const struct pinctrl_pin_desc imx28_pins[] = { 1928c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_D00), 1938c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_D01), 1948c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_D02), 1958c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_D03), 1968c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_D04), 1978c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_D05), 1988c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_D06), 1998c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_D07), 2008c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_CE0N), 2018c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_CE1N), 2028c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_CE2N), 2038c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_CE3N), 2048c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_RDY0), 2058c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_RDY1), 2068c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_RDY2), 2078c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_RDY3), 2088c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_RDN), 2098c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_WRN), 2108c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_ALE), 2118c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_CLE), 2128c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(GPMI_RESETN), 2138c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D00), 2148c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D01), 2158c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D02), 2168c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D03), 2178c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D04), 2188c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D05), 2198c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D06), 2208c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D07), 2218c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D08), 2228c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D09), 2238c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D10), 2248c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D11), 2258c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D12), 2268c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D13), 2278c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D14), 2288c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D15), 2298c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D16), 2308c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D17), 2318c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D18), 2328c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D19), 2338c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D20), 2348c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D21), 2358c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D22), 2368c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_D23), 2378c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_RD_E), 2388c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_WR_RWN), 2398c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_RS), 2408c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_CS), 2418c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_VSYNC), 2428c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_HSYNC), 2438c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_DOTCLK), 2448c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_ENABLE), 2458c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP0_DATA0), 2468c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP0_DATA1), 2478c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP0_DATA2), 2488c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP0_DATA3), 2498c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP0_DATA4), 2508c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP0_DATA5), 2518c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP0_DATA6), 2528c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP0_DATA7), 2538c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP0_CMD), 2548c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP0_DETECT), 2558c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP0_SCK), 2568c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP1_SCK), 2578c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP1_CMD), 2588c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP1_DATA0), 2598c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP1_DATA3), 2608c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP2_SCK), 2618c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP2_MOSI), 2628c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP2_MISO), 2638c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP2_SS0), 2648c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP2_SS1), 2658c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP2_SS2), 2668c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP3_SCK), 2678c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP3_MOSI), 2688c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP3_MISO), 2698c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SSP3_SS0), 2708c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART0_RX), 2718c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART0_TX), 2728c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART0_CTS), 2738c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART0_RTS), 2748c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART1_RX), 2758c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART1_TX), 2768c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART1_CTS), 2778c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART1_RTS), 2788c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART2_RX), 2798c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART2_TX), 2808c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART2_CTS), 2818c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART2_RTS), 2828c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART3_RX), 2838c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART3_TX), 2848c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART3_CTS), 2858c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(AUART3_RTS), 2868c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(PWM0), 2878c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(PWM1), 2888c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(PWM2), 2898c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SAIF0_MCLK), 2908c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SAIF0_LRCLK), 2918c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SAIF0_BITCLK), 2928c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SAIF0_SDATA0), 2938c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(I2C0_SCL), 2948c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(I2C0_SDA), 2958c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SAIF1_SDATA0), 2968c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(SPDIF), 2978c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(PWM3), 2988c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(PWM4), 2998c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(LCD_RESET), 3008c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_MDC), 3018c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_MDIO), 3028c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_RX_EN), 3038c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_RXD0), 3048c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_RXD1), 3058c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_TX_CLK), 3068c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_TX_EN), 3078c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_TXD0), 3088c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_TXD1), 3098c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_RXD2), 3108c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_RXD3), 3118c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_TXD2), 3128c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_TXD3), 3138c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_RX_CLK), 3148c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_COL), 3158c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET0_CRS), 3168c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(ENET_CLK), 3178c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(JTAG_RTCK), 3188c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D00), 3198c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D01), 3208c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D02), 3218c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D03), 3228c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D04), 3238c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D05), 3248c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D06), 3258c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D07), 3268c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D08), 3278c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D09), 3288c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D10), 3298c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D11), 3308c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D12), 3318c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D13), 3328c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D14), 3338c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_D15), 3348c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_ODT0), 3358c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_DQM0), 3368c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_ODT1), 3378c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_DQM1), 3388c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_DDR_OPEN_FB), 3398c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_CLK), 3408c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_DQS0), 3418c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_DQS1), 3428c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_DDR_OPEN), 3438c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_A00), 3448c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_A01), 3458c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_A02), 3468c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_A03), 3478c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_A04), 3488c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_A05), 3498c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_A06), 3508c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_A07), 3518c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_A08), 3528c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_A09), 3538c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_A10), 3548c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_A11), 3558c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_A12), 3568c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_A13), 3578c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_A14), 3588c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_BA0), 3598c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_BA1), 3608c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_BA2), 3618c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_CASN), 3628c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_RASN), 3638c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_WEN), 3648c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_CE0N), 3658c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_CE1N), 3668c2ecf20Sopenharmony_ci MXS_PINCTRL_PIN(EMI_CKE), 3678c2ecf20Sopenharmony_ci}; 3688c2ecf20Sopenharmony_ci 3698c2ecf20Sopenharmony_cistatic const struct mxs_regs imx28_regs = { 3708c2ecf20Sopenharmony_ci .muxsel = 0x100, 3718c2ecf20Sopenharmony_ci .drive = 0x300, 3728c2ecf20Sopenharmony_ci .pull = 0x600, 3738c2ecf20Sopenharmony_ci}; 3748c2ecf20Sopenharmony_ci 3758c2ecf20Sopenharmony_cistatic struct mxs_pinctrl_soc_data imx28_pinctrl_data = { 3768c2ecf20Sopenharmony_ci .regs = &imx28_regs, 3778c2ecf20Sopenharmony_ci .pins = imx28_pins, 3788c2ecf20Sopenharmony_ci .npins = ARRAY_SIZE(imx28_pins), 3798c2ecf20Sopenharmony_ci}; 3808c2ecf20Sopenharmony_ci 3818c2ecf20Sopenharmony_cistatic int imx28_pinctrl_probe(struct platform_device *pdev) 3828c2ecf20Sopenharmony_ci{ 3838c2ecf20Sopenharmony_ci return mxs_pinctrl_probe(pdev, &imx28_pinctrl_data); 3848c2ecf20Sopenharmony_ci} 3858c2ecf20Sopenharmony_ci 3868c2ecf20Sopenharmony_cistatic const struct of_device_id imx28_pinctrl_of_match[] = { 3878c2ecf20Sopenharmony_ci { .compatible = "fsl,imx28-pinctrl", }, 3888c2ecf20Sopenharmony_ci { /* sentinel */ } 3898c2ecf20Sopenharmony_ci}; 3908c2ecf20Sopenharmony_ci 3918c2ecf20Sopenharmony_cistatic struct platform_driver imx28_pinctrl_driver = { 3928c2ecf20Sopenharmony_ci .driver = { 3938c2ecf20Sopenharmony_ci .name = "imx28-pinctrl", 3948c2ecf20Sopenharmony_ci .suppress_bind_attrs = true, 3958c2ecf20Sopenharmony_ci .of_match_table = imx28_pinctrl_of_match, 3968c2ecf20Sopenharmony_ci }, 3978c2ecf20Sopenharmony_ci .probe = imx28_pinctrl_probe, 3988c2ecf20Sopenharmony_ci}; 3998c2ecf20Sopenharmony_ci 4008c2ecf20Sopenharmony_cistatic int __init imx28_pinctrl_init(void) 4018c2ecf20Sopenharmony_ci{ 4028c2ecf20Sopenharmony_ci return platform_driver_register(&imx28_pinctrl_driver); 4038c2ecf20Sopenharmony_ci} 4048c2ecf20Sopenharmony_cipostcore_initcall(imx28_pinctrl_init); 405