// SPDX-License-Identifier: GPL-2.0 // // Author: Jerry Zhu // Author: Gary Yang #include #include #include #include #include #include #include #include "linux/stddef.h" #include "../core.h" #include "pinctrl-sky1.h" /* Pad names for the s5 domain pinmux subsystem */ static const char * const gpio1_group[] = {"GPIO1"}; static const char * const gpio2_group[] = {"GPIO2"}; static const char * const gpio3_group[] = {"GPIO3"}; static const char * const gpio4_group[] = {"GPIO4"}; static const char * const gpio5_group[] = {"GPIO5"}; static const char * const gpio6_group[] = {"GPIO6"}; static const char * const gpio7_group[] = {"GPIO7"}; static const char * const gpio8_group[] = {"GPIO8"}; static const char * const gpio9_group[] = {"GPIO9"}; static const char * const gpio10_group[] = {"GPIO10"}; static const char * const gpio11_group[] = {"GPIO11"}; static const char * const gpio12_group[] = {"GPIO12"}; static const char * const gpio13_group[] = {"GPIO13"}; static const char * const gpio14_group[] = {"GPIO14"}; static const char * const rsmrst_group[] = { }; static const char * const srst_group[] = { }; static const char * const slp_s3_group[] = { }; static const char * const slp_s5_group[] = { }; static const char * const pwrgd_group[] = { }; static const char * const pwrok_group[] = { }; static const char * const pwrbtn_group[] = { }; static const char * const ddrio_gate_group[] = { }; static const char * const jtag_gpio_group[] = { }; static const char * const jtag_tck_group[] = { }; static const char * const jtag_tdi_group[] = { }; static const char * const jtag_tdo_group[] = { }; static const char * const tms_group[] = { }; static const char * const trsl_group[] = { }; static const char * const sfi_i2c0_scl_group[] = {"SFI_I2C0_SCL", "SFI_I3C0_SCL"}; static const char * const sfi_i2c0_sda_group[] = {"SFI_I2C0_SDA", "SFI_I3C0_SDA"}; static const char * const sfi_i2c1_scl_group[] = {"SFI_I2C1_SCL", "SFI_I3C1_SCL", "SFI_SPI_CS0"}; static const char * const sfi_i2c1_sda_group[] = {"SFI_I2C1_SDA", "SFI_I3C1_SDA", "SFI_SPI_CS1"}; static const char * const sfi_gpio0_group[] = {"GPIO15", "SFI_SPI_SCK", "SFI_GPIO0"}; static const char * const sfi_gpio1_group[] = {"GPIO16", "SFI_SPI_MOSI", "SFI_GPIO1"}; static const char * const sfi_gpio2_group[] = {"GPIO17", "SFI_SPI_MISO", "SFI_GPIO2"}; static const char * const gpio18_group[] = {"SFI_GPIO3", "GPIO18"}; static const char * const gpio19_group[] = {"SFI_GPIO4", "GPIO19"}; static const char * const gpio20_group[] = {"SFI_GPIO5", "GPIO20"}; static const char * const gpio21_group[] = {"SFI_GPIO6", "GPIO21"}; static const char * const gpio22_group[] = {"SFI_GPIO7", "GPIO22"}; static const char * const gpio23_group[] = {"SFI_GPIO8", "GPIO23", "SFI_I3C0_PUR_EN_L"}; static const char * const gpio24_group[] = {"SFI_GPIO9", "GPIO24", "SFI_I3C1_PUR_EN_L"}; static const char * const spi1_miso_group[] = {"SPI1_MISO", "GPIO25"}; static const char * const spi1_cs0_group[] = {"SPI1_CS0", "GPIO26"}; static const char * const spi1_cs1_group[] = {"SPI1_CS1", "GPIO27"}; static const char * const spi1_mosi_group[] = {"SPI1_MOSI", "GPIO28"}; static const char * const spi1_clk_group[] = {"SPI1_CLK", "GPIO29"}; static const char * const gpio30_group[] = {"GPIO30", "USB_0C0_L"}; static const char * const gpio31_group[] = {"GPIO31", "USB_0C1_L"}; static const char * const gpio32_group[] = {"GPIO32", "USB_0C2_L"}; static const char * const gpio33_group[] = {"GPIO33", "USB_0C3_L"}; static const char * const gpio34_group[] = {"GPIO34", "USB_0C4_L"}; static const char * const gpio35_group[] = {"GPIO35", "USB_0C5_L"}; static const char * const gpio36_group[] = {"GPIO36", "USB_0C6_L"}; static const char * const gpio37_group[] = {"GPIO37", "USB_0C7_L"}; static const char * const gpio38_group[] = {"GPIO38", "USB_0C8_L"}; static const char * const gpio39_group[] = {"GPIO39", "USB_0C9_L"}; static const char * const gpio40_group[] = {"GPIO40", "USB_DRIVE_VBUS0"}; static const char * const gpio41_group[] = {"GPIO41", "USB_DRIVE_VBUS4"}; static const char * const gpio42_group[] = {"GPIO42", "USB_DRIVE_VBUS5"}; static const char * const se_qspi_clk_group[] = {"SE_QSPI_CLK", "QSPI_CLK"}; static const char * const se_qspi_cs_group[] = {"SE_QSPI_CS_L", "QSPI_CS_L"}; static const char * const se_qspi_data0_group[] = {"SE_QSPI_DATA0", "QSPI_DATA0"}; static const char * const se_qspi_data1_group[] = {"SE_QSPI_DATA1", "QSPI_DATA1"}; static const char * const se_qspi_data2_group[] = {"SE_QSPI_DATA2", "QSPI_DATA2"}; static const char * const se_qspi_data3_group[] = {"SE_QSPI_DATA3", "QSPI_DATA3"}; static const struct sky1_pin_desc sky1_pinctrl_s5_pads[] = { SKY_PINFUNCTION(PINCTRL_PIN(0, "GPIO1"), gpio1), SKY_PINFUNCTION(PINCTRL_PIN(1, "GPIO2"), gpio2), SKY_PINFUNCTION(PINCTRL_PIN(2, "GPIO3"), gpio3), SKY_PINFUNCTION(PINCTRL_PIN(3, "GPIO4"), gpio4), SKY_PINFUNCTION(PINCTRL_PIN(4, "GPIO5"), gpio5), SKY_PINFUNCTION(PINCTRL_PIN(5, "GPIO6"), gpio6), SKY_PINFUNCTION(PINCTRL_PIN(6, "GPIO7"), gpio7), SKY_PINFUNCTION(PINCTRL_PIN(7, "GPIO8"), gpio8), SKY_PINFUNCTION(PINCTRL_PIN(8, "GPIO9"), gpio9), SKY_PINFUNCTION(PINCTRL_PIN(9, "GPIO10"), gpio10), SKY_PINFUNCTION(PINCTRL_PIN(10, "GPIO11"), gpio11), SKY_PINFUNCTION(PINCTRL_PIN(11, "GPIO12"), gpio12), SKY_PINFUNCTION(PINCTRL_PIN(12, "GPIO13"), gpio13), SKY_PINFUNCTION(PINCTRL_PIN(13, "GPIO14"), gpio14), SKY_PINFUNCTION(PINCTRL_PIN(14, "RSMRST_L"), rsmrst), SKY_PINFUNCTION(PINCTRL_PIN(15, "SRST_L"), srst), SKY_PINFUNCTION(PINCTRL_PIN(16, "SLP_S3_L"), slp_s3), SKY_PINFUNCTION(PINCTRL_PIN(17, "SLP_S5_L"), slp_s5), SKY_PINFUNCTION(PINCTRL_PIN(18, "PWRGD"), pwrgd), SKY_PINFUNCTION(PINCTRL_PIN(19, "PWROK"), pwrok), SKY_PINFUNCTION(PINCTRL_PIN(20, "PWRBTN_L"), pwrbtn), SKY_PINFUNCTION(PINCTRL_PIN(21, "VDD_DDRIO_GATE"), ddrio_gate), SKY_PINFUNCTION(PINCTRL_PIN(22, "JTAG_GPIO_L"), jtag_gpio), SKY_PINFUNCTION(PINCTRL_PIN(23, "JTAG_TCK"), jtag_tck), SKY_PINFUNCTION(PINCTRL_PIN(24, "JTAG_TDI"), jtag_tdi), SKY_PINFUNCTION(PINCTRL_PIN(25, "JTAG_TDO"), jtag_tdo), SKY_PINFUNCTION(PINCTRL_PIN(26, "TMS"), tms), SKY_PINFUNCTION(PINCTRL_PIN(27, "TRSL_L"), trsl), SKY_PINFUNCTION(PINCTRL_PIN(28, "SFI_I2C0_SCL"), sfi_i2c0_scl), SKY_PINFUNCTION(PINCTRL_PIN(29, "SFI_I2C0_SDA"), sfi_i2c0_sda), SKY_PINFUNCTION(PINCTRL_PIN(30, "SFI_I2C1_SCL"), sfi_i2c1_scl), SKY_PINFUNCTION(PINCTRL_PIN(31, "SFI_I2C1_SDA"), sfi_i2c1_sda), SKY_PINFUNCTION(PINCTRL_PIN(32, "SFI_GPIO0"), sfi_gpio0), SKY_PINFUNCTION(PINCTRL_PIN(33, "SFI_GPIO1"), sfi_gpio1), SKY_PINFUNCTION(PINCTRL_PIN(34, "SFI_GPIO2"), sfi_gpio2), SKY_PINFUNCTION(PINCTRL_PIN(35, "GPIO18"), gpio18), SKY_PINFUNCTION(PINCTRL_PIN(36, "GPIO19"), gpio19), SKY_PINFUNCTION(PINCTRL_PIN(37, "GPIO20"), gpio20), SKY_PINFUNCTION(PINCTRL_PIN(38, "GPIO21"), gpio21), SKY_PINFUNCTION(PINCTRL_PIN(39, "GPIO22"), gpio22), SKY_PINFUNCTION(PINCTRL_PIN(40, "GPIO23"), gpio23), SKY_PINFUNCTION(PINCTRL_PIN(41, "GPIO24"), gpio24), SKY_PINFUNCTION(PINCTRL_PIN(42, "SPI1_MISO"), spi1_miso), SKY_PINFUNCTION(PINCTRL_PIN(43, "SPI1_CS0"), spi1_cs0), SKY_PINFUNCTION(PINCTRL_PIN(44, "SPI1_CS1"), spi1_cs1), SKY_PINFUNCTION(PINCTRL_PIN(45, "SPI1_MOSI"), spi1_mosi), SKY_PINFUNCTION(PINCTRL_PIN(46, "SPI1_CLK"), spi1_clk), SKY_PINFUNCTION(PINCTRL_PIN(47, "GPIO30"), gpio30), SKY_PINFUNCTION(PINCTRL_PIN(48, "GPIO31"), gpio31), SKY_PINFUNCTION(PINCTRL_PIN(49, "GPIO32"), gpio32), SKY_PINFUNCTION(PINCTRL_PIN(50, "GPIO33"), gpio33), SKY_PINFUNCTION(PINCTRL_PIN(51, "GPIO34"), gpio34), SKY_PINFUNCTION(PINCTRL_PIN(52, "GPIO35"), gpio35), SKY_PINFUNCTION(PINCTRL_PIN(53, "GPIO36"), gpio36), SKY_PINFUNCTION(PINCTRL_PIN(54, "GPIO37"), gpio37), SKY_PINFUNCTION(PINCTRL_PIN(55, "GPIO38"), gpio38), SKY_PINFUNCTION(PINCTRL_PIN(56, "GPIO39"), gpio39), SKY_PINFUNCTION(PINCTRL_PIN(57, "GPIO40"), gpio40), SKY_PINFUNCTION(PINCTRL_PIN(58, "GPIO41"), gpio41), SKY_PINFUNCTION(PINCTRL_PIN(59, "GPIO42"), gpio42), SKY_PINFUNCTION(PINCTRL_PIN(60, "SE_QSPI_CLK"), se_qspi_clk), SKY_PINFUNCTION(PINCTRL_PIN(61, "SE_QSPI_CS_L"), se_qspi_cs), SKY_PINFUNCTION(PINCTRL_PIN(62, "SE_QSPI_DATA0"), se_qspi_data0), SKY_PINFUNCTION(PINCTRL_PIN(63, "SE_QSPI_DATA1"), se_qspi_data1), SKY_PINFUNCTION(PINCTRL_PIN(64, "SE_QSPI_DATA2"), se_qspi_data2), SKY_PINFUNCTION(PINCTRL_PIN(65, "SE_QSPI_DATA3"), se_qspi_data3), }; /* Pad names for the s0 domain pinmux subsystem */ static const char * const gpio43_group[] = {"GPIO43"}; static const char * const gpio44_group[] = {"GPIO44"}; static const char * const gpio45_group[] = {"GPIO45"}; static const char * const gpio46_group[] = {"GPIO46"}; static const char * const reset_in_group[] = { }; static const char * const plt_reset_group[] = { }; static const char * const thermtrip_group[] = { }; static const char * const prochot_group[] = { }; static const char * const pm_i2c0_clk_group[] = { }; static const char * const pm_i2c0_data_group[] = { }; static const char * const pm_i2c1_clk_group[] = { }; static const char * const pm_i2c1_data_group[] = { }; static const char * const pm_i2c2_clk_group[] = { }; static const char * const pm_i2c2_data_group[] = { }; static const char * const pm_i2c3_clk_group[] = { }; static const char * const pm_i2c3_data_group[] = { }; static const char * const strap0_group[] = { }; static const char * const strap1_group[] = { }; static const char * const dp2_digon_group[] = {"DP2_DIGON"}; static const char * const dp2_blon_group[] = {"DP2_BLON"}; static const char * const dp2_vary_bl_group[] = {"DP2_VARY_BL"}; static const char * const i2c7_scl_group[] = {"I2C7_SCL"}; static const char * const i2c7_sda_group[] = {"I2C7_SDA"}; static const char * const uart6_csu_se_txd_group[] = { }; static const char * const clk_req1_group[] = { }; static const char * const clk_req3_group[] = { }; static const char * const i2c5_scl_group[] = {"I2C5_SCL", "GPIO47"}; static const char * const i2c5_sda_group[] = {"I2C5_SDA", "GPIO48"}; static const char * const i2c6_scl_group[] = {"I2C6_SCL", "GPIO49"}; static const char * const i2c6_sda_group[] = {"I2C6_SDA", "GPIO50"}; static const char * const i2c0_scl_group[] = {"I2C0_SCL", "GPIO51"}; static const char * const i2c0_sda_group[] = {"I2C0_SDA", "GPIO52"}; static const char * const i2c1_scl_group[] = {"I2C1_SCL", "GPIO53"}; static const char * const i2c1_sda_group[] = {"I2C1_SDA", "GPIO54"}; static const char * const i2c2_scl_group[] = {"I2C2_SCL", "I3C0_SCL", "GPIO55"}; static const char * const i2c2_sda_group[] = {"I2C2_SDA", "I3C0_SDA", "GPIO56"}; static const char * const gpio57_group[] = {"GPIO57", "I3C0_PUR_EN_L"}; static const char * const i2c3_scl_group[] = {"I2C3_SCL", "I3C1_SCL", "GPIO58"}; static const char * const i2c3_sda_group[] = {"I2C3_SDA", "I3C1_SDA", "GPIO59"}; static const char * const gpio60_group[] = {"GPIO60", "I3C1_PUR_EN_L"}; static const char * const i2c4_scl_group[] = {"I2C4_SCL", "GPIO61"}; static const char * const i2c4_sda_group[] = {"I2C4_SDA", "GPIO62"}; static const char * const hda_bitclk_group[] = {"HDA_BITCLK", "I2S0_SCK", "I2S9_RSCK_DBG"}; static const char * const hda_rst_group[] = {"HDA_RST_L", "I2S0_DATA_IN", "I2S9_DATA_IN_DBG"}; static const char * const hda_sdin0_group[] = {"HDA_SDIN0", "I2S0_MCLK", "I2S9_TSCK_DBG"}; static const char * const hda_sdout0_group[] = {"HDA_SDOUT0", "I2S0_DATA_OUT", "I2S9_TWS_DBG"}; static const char * const hda_sync_group[] = {"HDA_SYNC", "I2S0_WS", "I2S9_RWS_DBG"}; static const char * const hda_sdin1_group[] = {"HDA_SDIN1", "GPIO63", "I2S9_DATA_IN1_DBG"}; static const char * const hda_sdout1_group[] = {"HDA_SDOUT1", "GPIO64", "I2S9_DATA_OUT0_DBG"}; static const char * const i2s1_mclk_group[] = {"I2S1_MCLK", "GPIO65"}; static const char * const i2s1_sck_group[] = {"I2S1_SCK", "GPIO66"}; static const char * const i2s1_ws_group[] = {"I2S1_WS", "GPIO67"}; static const char * const i2s1_data_in_group[] = {"I2S1_DATA_IN", "GPIO68"}; static const char * const i2s1_data_out_group[] = {"I2S1_DATA_OUT", "GPIO69"}; static const char * const i2s2_mck_group[] = {"I2S2_MCLK", "GPIO70"}; static const char * const i2s2_rsck_group[] = {"I2S2_RSCK", "GPIO71", "I2S5_RSCK_DBG", "I2S6_RSCK_DBG"}; static const char * const i2s2_rws_group[] = {"I2S2_RWS", "GPIO72", "I2S5_RWS_DBG", "I2S6_RWS_DBG"}; static const char * const i2s2_tsck_group[] = {"I2S2_TSCK", "GPIO73", "I2S5_TSCK_DBG", "I2S6_TSCK_DBG"}; static const char * const i2s2_tws_group[] = {"I2S2_TWS", "GPIO74", "I2S5_TWS_DBG", "I2S6_TWS_DBG"}; static const char * const i2s2_data_in0_group[] = {"I2S2_DATA_IN0", "GPIO75", "I2S5_DATA_IN0_DBG", "I2S6_DATA_IN0_DBG"}; static const char * const i2s2_data_in1_group[] = {"I2S2_DATA_IN1", "GPIO76", "I2S5_DATA_IN1_DBG", "I2S6_DATA_IN1_DBG"}; static const char * const i2s2_data_out0_group[] = {"I2S2_DATA_OUT0", "GPIO77", "I2S5_DATA_OUT0_DBG", "I2S6_DATA_OUT0_DBG"}; static const char * const i2s2_data_out1_group[] = {"I2S2_DATA_OUT1", "GPIO78", "I2S5_DATA_OUT1_DBG", "I2S6_DATA_OUT1_DBG"}; static const char * const i2s2_data_out2_group[] = {"I2S2_DATA_OUT2", "GPIO79"}; static const char * const i2s2_data_out3_group[] = {"I2S2_DATA_OUT3", "GPIO80", "I2S9_DATA_OUT1_DBG"}; static const char * const i2s3_mclk_group[] = {"I2S3_MCLK", "GPIO81"}; static const char * const i2s3_rsck_group[] = {"I2S3_RSCK", "GPIO82", "I2S7_RSCK_DBG", "I2S8_RSCK_DBG"}; static const char * const i2s3_rws_group[] = {"I2S3_RWS", "GPIO83", "I2S7_RWS_DBG", "I2S8_RWS_DBG"}; static const char * const i2s3_tsck_group[] = {"I2S3_TSCK", "GPIO84", "I2S7_TSCK_DBG", "I2S8_TSCK_DBG"}; static const char * const i2s3_tws_group[] = {"I2S3_TWS", "GPIO85", "I2S7_TWS_DBG", "I2S8_TWS_DBG"}; static const char * const i2s3_data_in0_group[] = {"I2S3_DATA_IN0", "GPIO86", "I2S7_DATA_IN0_DBG", "I2S8_DATA_IN0_DBG"}; static const char * const i2s3_data_in1_group[] = {"I2S3_DATA_IN1", "GPIO87", "I2S7_DATA_IN1_DBG", "I2S8_DATA_IN1_DBG"}; static const char * const i2s3_data_out0_group[] = {"I2S3_DATA_OUT0", "GPIO88", "I2S7_DATA_OUT0_DBG", "I2S8_DATA_OUT0_DBG"}; static const char * const i2s3_data_out1_group[] = {"I2S3_DATA_OUT1", "GPIO89", "I2S7_DATA_OUT1_DBG", "I2S8_DATA_OUT1_DBG"}; static const char * const gpio90_group[] = {"GPIO90", "I2S4_MCLK_LB"}; static const char * const gpio91_group[] = {"GPIO91", "I2S4_SCK_LB"}; static const char * const gpio92_group[] = {"GPIO92", "I2S4_WS_LB"}; static const char * const gpio93_group[] = {"GPIO93", "I2S4_DATA_IN_LB"}; static const char * const gpio94_group[] = {"GPIO94", "I2S4_DATA_OUT_LB"}; static const char * const uart0_txd_group[] = {"UART0_TXD", "PWM0", "GPIO95"}; static const char * const uart0_rxd_group[] = {"UART0_RXD", "PWM1", "GPIO96"}; static const char * const uart0_cts_group[] = {"UART0_CTS", "FAN_OUT2", "GPIO97"}; static const char * const uart0_rts_group[] = {"UART0_RTS", "FAN_TACH2", "GPIO98"}; static const char * const uart1_txd_group[] = {"UART1_TXD", "FAN_OUT0", "GPIO99"}; static const char * const uart1_rxd_group[] = {"UART1_RXD", "FAN_TACH0", "GPIO100"}; static const char * const uart1_cts_group[] = {"UART1_CTS", "FAN_OUT1", "GPIO101"}; static const char * const uart1_rts_group[] = {"UART1_RTS", "FAN_TACH1", "GPIO102"}; static const char * const uart2_txd_group[] = {"UART2_TXD", "GPIO103"}; static const char * const uart2_rxd_group[] = {"UART2_RXD", "GPIO104"}; static const char * const uart3_txd_group[] = {"UART3_TXD", "GPIO105"}; static const char * const uart3_rxd_group[] = {"UART3_RXD", "GPIO106"}; static const char * const uart3_cts_group[] = {"UART3_CTS", "GPIO107", "TRIGIN0"}; static const char * const uart3_rts_group[] = {"UART3_RTS", "GPIO108", "TRIGIN1"}; static const char * const uart4_csu_pm_txd_group[] = {"UART4_CSU_PM_TXD", "GPIO109"}; static const char * const uart4_csu_pm_rxd_group[] = {"UART4_CSU_PM_RXD", "GPIO110"}; static const char * const uart5_csu_se_txd_group[] = {"UART5_CSU_SE_TXD", "GPIO111"}; static const char * const uart5_csu_se_rxd_group[] = {"UART5_CSU_SE_RXD", "GPIO112"}; static const char * const uart6_csu_se_rxd_group[] = {"UART6_CSU_SE_RXD", "GPIO113"}; static const char * const clk_req0_group[] = {"CLK_REQ0_L", "GPIO114"}; static const char * const clk_req2_group[] = {"CLK_REQ2_L", "GPIO115"}; static const char * const clk_req4_group[] = {"CLK_REQ4_L", "GPIO116"}; static const char * const csi0_mclk0_group[] = {"CSI0_MCLK0", "GPIO117"}; static const char * const csi0_mclk1_group[] = {"CSI0_MCLK1", "GPIO118"}; static const char * const csi1_mclk0_group[] = {"CSI1_MCLK0", "GPIO119"}; static const char * const csi1_mclk1_group[] = {"CSI1_MCLK1", "GPIO120"}; static const char * const gpio121_group[] = {"GPIO121", "GMAC0_REFCLK_25M"}; static const char * const gpio122_group[] = {"GPIO122", "GMAC0_TX_CTL"}; static const char * const gpio123_group[] = {"GPIO123", "GMAC0_TXD0"}; static const char * const gpio124_group[] = {"GPIO124", "GMAC0_TXD1"}; static const char * const gpio125_group[] = {"GPIO125", "GMAC0_TXD2"}; static const char * const gpio126_group[] = {"GPIO126", "GMAC0_TXD3"}; static const char * const gpio127_group[] = {"GPIO127", "GMAC0_TX_CLK"}; static const char * const gpio128_group[] = {"GPIO128", "GMAC0_RX_CTL"}; static const char * const gpio129_group[] = {"GPIO129", "GMAC0_RXD0"}; static const char * const gpio130_group[] = {"GPIO130", "GMAC0_RXD1"}; static const char * const gpio131_group[] = {"GPIO131", "GMAC0_RXD2"}; static const char * const gpio132_group[] = {"GPIO132", "GMAC0_RXD3"}; static const char * const gpio133_group[] = {"GPIO133", "GMAC0_RX_CLK"}; static const char * const gpio134_group[] = {"GPIO134", "GMAC0_MDC"}; static const char * const gpio135_group[] = {"GPIO135", "GMAC0_MDIO"}; static const char * const gpio136_group[] = {"GPIO136", "GMAC1_REFCLK_25M"}; static const char * const gpio137_group[] = {"GPIO137", "GMAC1_TX_CTL"}; static const char * const gpio138_group[] = {"GPIO138", "GMAC1_TXD0", "SPI2_MISO"}; static const char * const gpio139_group[] = {"GPIO139", "GMAC1_TXD1", "SPI2_CS0"}; static const char * const gpio140_group[] = {"GPIO140", "GMAC1_TXD2", "SPI2_CS1"}; static const char * const gpio141_group[] = {"GPIO141", "GMAC1_TXD3", "SPI2_MOSI"}; static const char * const gpio142_group[] = {"GPIO142", "GMAC1_TX_CLK", "SPI2_CLK"}; static const char * const gpio143_group[] = {"GPIO143", "GMAC1_RX_CTL"}; static const char * const gpio144_group[] = {"GPIO144", "GMAC1_RXD0"}; static const char * const gpio145_group[] = {"GPIO145", "GMAC1_RXD1"}; static const char * const gpio146_group[] = {"GPIO146", "GMAC1_RXD2"}; static const char * const gpio147_group[] = {"GPIO147", "GMAC1_RXD3"}; static const char * const gpio148_group[] = {"GPIO148", "GMAC1_RX_CLK"}; static const char * const gpio149_group[] = {"GPIO149", "GMAC1_MDC"}; static const char * const gpio150_group[] = {"GPIO150", "GMAC1_MDIO"}; static const char * const gpio151_group[] = {"GPIO151", "PM_GPIO0"}; static const char * const gpio152_group[] = {"GPIO152", "PM_GPIO1"}; static const char * const gpio153_group[] = {"GPIO153", "PM_GPIO2"}; static const struct sky1_pin_desc sky1_pinctrl_pads[] = { SKY_PINFUNCTION(PINCTRL_PIN(0, "GPIO43"), gpio43), SKY_PINFUNCTION(PINCTRL_PIN(1, "GPIO44"), gpio44), SKY_PINFUNCTION(PINCTRL_PIN(2, "GPIO45"), gpio45), SKY_PINFUNCTION(PINCTRL_PIN(3, "GPIO46"), gpio46), SKY_PINFUNCTION(PINCTRL_PIN(4, "RESET_IN_L"), reset_in), SKY_PINFUNCTION(PINCTRL_PIN(5, "PLT_RESET_L"), plt_reset), SKY_PINFUNCTION(PINCTRL_PIN(6, "THERMTRIP_L"), thermtrip), SKY_PINFUNCTION(PINCTRL_PIN(7, "PROCHOT_L"), prochot), SKY_PINFUNCTION(PINCTRL_PIN(8, "PM_I2C0_CLK"), pm_i2c0_clk), SKY_PINFUNCTION(PINCTRL_PIN(9, "PM_I2C0_DATA"), pm_i2c0_data), SKY_PINFUNCTION(PINCTRL_PIN(10, "PM_I2C1_CLK"), pm_i2c1_clk), SKY_PINFUNCTION(PINCTRL_PIN(11, "PM_I2C1_DATA"), pm_i2c1_data), SKY_PINFUNCTION(PINCTRL_PIN(12, "PM_I2C2_CLK"), pm_i2c2_clk), SKY_PINFUNCTION(PINCTRL_PIN(13, "PM_I2C2_DATA"), pm_i2c2_data), SKY_PINFUNCTION(PINCTRL_PIN(14, "PM_I2C3_CLK"), pm_i2c3_clk), SKY_PINFUNCTION(PINCTRL_PIN(15, "PM_I2C3_DATA"), pm_i2c3_data), SKY_PINFUNCTION(PINCTRL_PIN(16, "STRAP0"), strap0), SKY_PINFUNCTION(PINCTRL_PIN(17, "STRAP1"), strap1), SKY_PINFUNCTION(PINCTRL_PIN(18, "DP2_DIGON"), dp2_digon), SKY_PINFUNCTION(PINCTRL_PIN(19, "DP2_BLON"), dp2_blon), SKY_PINFUNCTION(PINCTRL_PIN(20, "DP2_VARY_BL"), dp2_vary_bl), SKY_PINFUNCTION(PINCTRL_PIN(21, "I2C7_SCL"), i2c7_scl), SKY_PINFUNCTION(PINCTRL_PIN(22, "I2C7_SDA"), i2c7_sda), SKY_PINFUNCTION(PINCTRL_PIN(23, "UART6_CSU_SE_TXD"), uart6_csu_se_txd), SKY_PINFUNCTION(PINCTRL_PIN(24, "CLK_REQ1_L"), clk_req1), SKY_PINFUNCTION(PINCTRL_PIN(25, "CLK_REQ3_L"), clk_req3), SKY_PINFUNCTION(PINCTRL_PIN(26, "I2C5_SCL"), i2c5_scl), SKY_PINFUNCTION(PINCTRL_PIN(27, "I2C5_SDA"), i2c5_sda), SKY_PINFUNCTION(PINCTRL_PIN(28, "I2C6_SCL"), i2c6_scl), SKY_PINFUNCTION(PINCTRL_PIN(29, "I2C6_SDA"), i2c6_sda), SKY_PINFUNCTION(PINCTRL_PIN(30, "I2C0_CLK"), i2c0_scl), SKY_PINFUNCTION(PINCTRL_PIN(31, "I2C0_SDA"), i2c0_sda), SKY_PINFUNCTION(PINCTRL_PIN(32, "I2C1_CLK"), i2c1_scl), SKY_PINFUNCTION(PINCTRL_PIN(33, "I2C1_SDA"), i2c1_sda), SKY_PINFUNCTION(PINCTRL_PIN(34, "I2C2_SCL"), i2c2_scl), SKY_PINFUNCTION(PINCTRL_PIN(35, "I2C2_SDA"), i2c2_sda), SKY_PINFUNCTION(PINCTRL_PIN(36, "GPIO57"), gpio57), SKY_PINFUNCTION(PINCTRL_PIN(37, "I2C3_SCL"), i2c3_scl), SKY_PINFUNCTION(PINCTRL_PIN(38, "I2C3_SDA"), i2c3_sda), SKY_PINFUNCTION(PINCTRL_PIN(39, "GPIO60"), gpio60), SKY_PINFUNCTION(PINCTRL_PIN(40, "I2C4_SCL"), i2c4_scl), SKY_PINFUNCTION(PINCTRL_PIN(41, "I2C4_SDA"), i2c4_sda), SKY_PINFUNCTION(PINCTRL_PIN(42, "HDA_BITCLK"), hda_bitclk), SKY_PINFUNCTION(PINCTRL_PIN(43, "HDA_RST_L"), hda_rst), SKY_PINFUNCTION(PINCTRL_PIN(44, "HDA_SDIN0"), hda_sdin0), SKY_PINFUNCTION(PINCTRL_PIN(45, "HDA_SDOUT0"), hda_sdout0), SKY_PINFUNCTION(PINCTRL_PIN(46, "HDA_SYNC"), hda_sync), SKY_PINFUNCTION(PINCTRL_PIN(47, "HDA_SDIN1"), hda_sdin1), SKY_PINFUNCTION(PINCTRL_PIN(48, "HDA_SDOUT1"), hda_sdout1), SKY_PINFUNCTION(PINCTRL_PIN(49, "I2S1_MCLK"), i2s1_mclk), SKY_PINFUNCTION(PINCTRL_PIN(50, "I2S1_SCK"), i2s1_sck), SKY_PINFUNCTION(PINCTRL_PIN(51, "I2S1_WS"), i2s1_ws), SKY_PINFUNCTION(PINCTRL_PIN(52, "I2S1_DATA_IN"), i2s1_data_in), SKY_PINFUNCTION(PINCTRL_PIN(53, "I2S1_DATA_OUT"), i2s1_data_out), SKY_PINFUNCTION(PINCTRL_PIN(54, "I2S2_MCLK"), i2s2_mck), SKY_PINFUNCTION(PINCTRL_PIN(55, "I2S2_RSCK"), i2s2_rsck), SKY_PINFUNCTION(PINCTRL_PIN(56, "I2S2_RWS"), i2s2_rws), SKY_PINFUNCTION(PINCTRL_PIN(57, "I2S2_TSCK"), i2s2_tsck), SKY_PINFUNCTION(PINCTRL_PIN(58, "I2S2_TWS"), i2s2_tws), SKY_PINFUNCTION(PINCTRL_PIN(59, "I2S2_DATA_IN0"), i2s2_data_in0), SKY_PINFUNCTION(PINCTRL_PIN(60, "I2S2_DATA_IN1"), i2s2_data_in1), SKY_PINFUNCTION(PINCTRL_PIN(61, "I2S2_DATA_OUT0"), i2s2_data_out0), SKY_PINFUNCTION(PINCTRL_PIN(62, "I2S2_DATA_OUT1"), i2s2_data_out1), SKY_PINFUNCTION(PINCTRL_PIN(63, "I2S2_DATA_OUT2"), i2s2_data_out2), SKY_PINFUNCTION(PINCTRL_PIN(64, "I2S2_DATA_OUT3"), i2s2_data_out3), SKY_PINFUNCTION(PINCTRL_PIN(65, "I2S3_MCLK"), i2s3_mclk), SKY_PINFUNCTION(PINCTRL_PIN(66, "I2S3_RSCK"), i2s3_rsck), SKY_PINFUNCTION(PINCTRL_PIN(67, "I2S3_RWS"), i2s3_rws), SKY_PINFUNCTION(PINCTRL_PIN(68, "I2S3_TSCK"), i2s3_tsck), SKY_PINFUNCTION(PINCTRL_PIN(69, "I2S3_TWS"), i2s3_tws), SKY_PINFUNCTION(PINCTRL_PIN(70, "I2S3_DATA_IN0"), i2s3_data_in0), SKY_PINFUNCTION(PINCTRL_PIN(71, "I2S3_DATA_IN1"), i2s3_data_in1), SKY_PINFUNCTION(PINCTRL_PIN(72, "I2S3_DATA_OUT0"), i2s3_data_out0), SKY_PINFUNCTION(PINCTRL_PIN(73, "I2S3_DATA_OUT1"), i2s3_data_out1), SKY_PINFUNCTION(PINCTRL_PIN(74, "GPIO90"), gpio90), SKY_PINFUNCTION(PINCTRL_PIN(75, "GPIO91"), gpio91), SKY_PINFUNCTION(PINCTRL_PIN(76, "GPIO92"), gpio92), SKY_PINFUNCTION(PINCTRL_PIN(77, "GPIO93"), gpio93), SKY_PINFUNCTION(PINCTRL_PIN(78, "GPIO94"), gpio94), SKY_PINFUNCTION(PINCTRL_PIN(79, "UART0_TXD"), uart0_txd), SKY_PINFUNCTION(PINCTRL_PIN(80, "UART0_RXD"), uart0_rxd), SKY_PINFUNCTION(PINCTRL_PIN(81, "UART0_CTS"), uart0_cts), SKY_PINFUNCTION(PINCTRL_PIN(82, "UART0_RTS"), uart0_rts), SKY_PINFUNCTION(PINCTRL_PIN(83, "UART1_TXD"), uart1_txd), SKY_PINFUNCTION(PINCTRL_PIN(84, "UART1_RXD"), uart1_rxd), SKY_PINFUNCTION(PINCTRL_PIN(85, "UART1_CTS"), uart1_cts), SKY_PINFUNCTION(PINCTRL_PIN(86, "UART1_RTS"), uart1_rts), SKY_PINFUNCTION(PINCTRL_PIN(87, "UART2_TXD"), uart2_txd), SKY_PINFUNCTION(PINCTRL_PIN(88, "UART2_RXD"), uart2_rxd), SKY_PINFUNCTION(PINCTRL_PIN(89, "UART3_TXD"), uart3_txd), SKY_PINFUNCTION(PINCTRL_PIN(90, "UART3_RXD"), uart3_rxd), SKY_PINFUNCTION(PINCTRL_PIN(91, "UART3_CTS"), uart3_cts), SKY_PINFUNCTION(PINCTRL_PIN(92, "UART3_RTS"), uart3_rts), SKY_PINFUNCTION(PINCTRL_PIN(93, "UART4_CSU_PM_TXD"), uart4_csu_pm_txd), SKY_PINFUNCTION(PINCTRL_PIN(94, "UART4_CSU_PM_RXD"), uart4_csu_pm_rxd), SKY_PINFUNCTION(PINCTRL_PIN(95, "UART5_CSU_SE_TXD"), uart5_csu_se_txd), SKY_PINFUNCTION(PINCTRL_PIN(96, "UART5_CSU_SE_RXD"), uart5_csu_se_rxd), SKY_PINFUNCTION(PINCTRL_PIN(97, "UART6_CSU_SE_RXD"), uart6_csu_se_rxd), SKY_PINFUNCTION(PINCTRL_PIN(98, "CLK_REQ0_L"), clk_req0), SKY_PINFUNCTION(PINCTRL_PIN(99, "CLK_REQ2_L"), clk_req2), SKY_PINFUNCTION(PINCTRL_PIN(100, "CLK_REQ4_L"), clk_req4), SKY_PINFUNCTION(PINCTRL_PIN(101, "CSI0_MCLK0"), csi0_mclk0), SKY_PINFUNCTION(PINCTRL_PIN(102, "CSI0_MCLK1"), csi0_mclk1), SKY_PINFUNCTION(PINCTRL_PIN(103, "CSI1_MCLK0"), csi1_mclk0), SKY_PINFUNCTION(PINCTRL_PIN(104, "CSI1_MCLK1"), csi1_mclk1), SKY_PINFUNCTION(PINCTRL_PIN(105, "GPIO121"), gpio121), SKY_PINFUNCTION(PINCTRL_PIN(106, "GPIO122"), gpio122), SKY_PINFUNCTION(PINCTRL_PIN(107, "GPIO123"), gpio123), SKY_PINFUNCTION(PINCTRL_PIN(108, "GPIO124"), gpio124), SKY_PINFUNCTION(PINCTRL_PIN(109, "GPIO125"), gpio125), SKY_PINFUNCTION(PINCTRL_PIN(110, "GPIO126"), gpio126), SKY_PINFUNCTION(PINCTRL_PIN(111, "GPIO127"), gpio127), SKY_PINFUNCTION(PINCTRL_PIN(112, "GPIO128"), gpio128), SKY_PINFUNCTION(PINCTRL_PIN(113, "GPIO129"), gpio129), SKY_PINFUNCTION(PINCTRL_PIN(114, "GPIO130"), gpio130), SKY_PINFUNCTION(PINCTRL_PIN(115, "GPIO131"), gpio131), SKY_PINFUNCTION(PINCTRL_PIN(116, "GPIO132"), gpio132), SKY_PINFUNCTION(PINCTRL_PIN(117, "GPIO133"), gpio133), SKY_PINFUNCTION(PINCTRL_PIN(118, "GPIO134"), gpio134), SKY_PINFUNCTION(PINCTRL_PIN(119, "GPIO135"), gpio135), SKY_PINFUNCTION(PINCTRL_PIN(120, "GPIO136"), gpio136), SKY_PINFUNCTION(PINCTRL_PIN(121, "GPIO137"), gpio137), SKY_PINFUNCTION(PINCTRL_PIN(122, "GPIO138"), gpio138), SKY_PINFUNCTION(PINCTRL_PIN(123, "GPIO139"), gpio139), SKY_PINFUNCTION(PINCTRL_PIN(124, "GPIO140"), gpio140), SKY_PINFUNCTION(PINCTRL_PIN(125, "GPIO141"), gpio141), SKY_PINFUNCTION(PINCTRL_PIN(126, "GPIO142"), gpio142), SKY_PINFUNCTION(PINCTRL_PIN(127, "GPIO143"), gpio143), SKY_PINFUNCTION(PINCTRL_PIN(128, "GPIO144"), gpio144), SKY_PINFUNCTION(PINCTRL_PIN(129, "GPIO145"), gpio145), SKY_PINFUNCTION(PINCTRL_PIN(130, "GPIO146"), gpio146), SKY_PINFUNCTION(PINCTRL_PIN(131, "GPIO147"), gpio147), SKY_PINFUNCTION(PINCTRL_PIN(132, "GPIO148"), gpio148), SKY_PINFUNCTION(PINCTRL_PIN(133, "GPIO149"), gpio149), SKY_PINFUNCTION(PINCTRL_PIN(134, "GPIO150"), gpio150), SKY_PINFUNCTION(PINCTRL_PIN(135, "GPIO151"), gpio151), SKY_PINFUNCTION(PINCTRL_PIN(136, "GPIO152"), gpio152), SKY_PINFUNCTION(PINCTRL_PIN(137, "GPIO153"), gpio153), }; static const struct sky1_pinctrl_soc_info sky1_pinctrl_s5_info = { .pins = sky1_pinctrl_s5_pads, .npins = ARRAY_SIZE(sky1_pinctrl_s5_pads), }; static const struct sky1_pinctrl_soc_info sky1_pinctrl_info = { .pins = sky1_pinctrl_pads, .npins = ARRAY_SIZE(sky1_pinctrl_pads), }; static const struct of_device_id sky1_pinctrl_of_match[] = { { .compatible = "cix,sky1-pinctrl-s5", .data = &sky1_pinctrl_s5_info, }, { .compatible = "cix,sky1-pinctrl", .data = &sky1_pinctrl_info, }, { /* sentinel */ } }; MODULE_DEVICE_TABLE(of, sky1_pinctrl_of_match); static int __maybe_unused sky1_pinctrl_suspend(struct device *dev) { struct sky1_pinctrl *spctl = dev_get_drvdata(dev); return pinctrl_force_sleep(spctl->pctl); } static int __maybe_unused sky1_pinctrl_resume(struct device *dev) { struct sky1_pinctrl *spctl = dev_get_drvdata(dev); return pinctrl_force_default(spctl->pctl); } const struct dev_pm_ops sky1_pinctrl_pm_ops = { SET_LATE_SYSTEM_SLEEP_PM_OPS(sky1_pinctrl_suspend, sky1_pinctrl_resume) }; EXPORT_SYMBOL_GPL(sky1_pinctrl_pm_ops); static int sky1_pinctrl_probe(struct platform_device *pdev) { const struct sky1_pinctrl_soc_info *pinctrl_info; pinctrl_info = device_get_match_data(&pdev->dev); if (!pinctrl_info) return -ENODEV; return sky1_base_pinctrl_probe(pdev, pinctrl_info); } static struct platform_driver sky1_pinctrl_driver = { .driver = { .name = "sky1-pinctrl", .of_match_table = sky1_pinctrl_of_match, .pm = &sky1_pinctrl_pm_ops, }, .probe = sky1_pinctrl_probe, }; static int __init sky1_pinctrl_init(void) { return platform_driver_register(&sky1_pinctrl_driver); } arch_initcall(sky1_pinctrl_init); MODULE_AUTHOR("Jerry Zhu "); MODULE_DESCRIPTION("Cix Sky1 pinctrl driver"); MODULE_LICENSE("GPL");