Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux
1
fork

Configure Feed

Select the types of activity you want to include in your feed.

pinctrl: Add driver support for Amlogic C3 SoCs

Add a new pinctrl driver for Amlogic C3 SoCs which share
the same register layout as the previous Amlogic S4.

Signed-off-by: Huqiang Qin <huqiang.qin@amlogic.com>
Link: https://lore.kernel.org/r/20230714122441.3098337-3-huqiang.qin@amlogic.com
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>

authored by

Huqiang Qin and committed by
Linus Walleij
ea90ca10 e55ef16b

+1115
+6
drivers/pinctrl/meson/Kconfig
··· 67 67 select PINCTRL_MESON_AXG_PMX 68 68 default y 69 69 70 + config PINCTRL_AMLOGIC_C3 71 + tristate "Amlogic C3 SoC pinctrl driver" 72 + depends on ARM64 73 + select PINCTRL_MESON_AXG_PMX 74 + default y 75 + 70 76 endif
+1
drivers/pinctrl/meson/Makefile
··· 10 10 obj-$(CONFIG_PINCTRL_MESON_G12A) += pinctrl-meson-g12a.o 11 11 obj-$(CONFIG_PINCTRL_MESON_A1) += pinctrl-meson-a1.o 12 12 obj-$(CONFIG_PINCTRL_MESON_S4) += pinctrl-meson-s4.o 13 + obj-$(CONFIG_PINCTRL_AMLOGIC_C3) += pinctrl-amlogic-c3.o
+1108
drivers/pinctrl/meson/pinctrl-amlogic-c3.c
··· 1 + // SPDX-License-Identifier: (GPL-2.0-only OR MIT) 2 + /* 3 + * Pin controller and GPIO driver for Amlogic C3 SoC. 4 + * 5 + * Copyright (c) 2021 Amlogic, Inc. All rights reserved. 6 + * Author: Huqiang Qin <huqiang.qin@amlogic.com> 7 + */ 8 + 9 + #include <dt-bindings/gpio/amlogic-c3-gpio.h> 10 + #include "pinctrl-meson.h" 11 + #include "pinctrl-meson-axg-pmx.h" 12 + 13 + static const struct pinctrl_pin_desc c3_periphs_pins[] = { 14 + MESON_PIN(GPIOE_0), 15 + MESON_PIN(GPIOE_1), 16 + MESON_PIN(GPIOE_2), 17 + MESON_PIN(GPIOE_3), 18 + MESON_PIN(GPIOE_4), 19 + MESON_PIN(GPIOB_0), 20 + MESON_PIN(GPIOB_1), 21 + MESON_PIN(GPIOB_2), 22 + MESON_PIN(GPIOB_3), 23 + MESON_PIN(GPIOB_4), 24 + MESON_PIN(GPIOB_5), 25 + MESON_PIN(GPIOB_6), 26 + MESON_PIN(GPIOB_7), 27 + MESON_PIN(GPIOB_8), 28 + MESON_PIN(GPIOB_9), 29 + MESON_PIN(GPIOB_10), 30 + MESON_PIN(GPIOB_11), 31 + MESON_PIN(GPIOB_12), 32 + MESON_PIN(GPIOB_13), 33 + MESON_PIN(GPIOB_14), 34 + MESON_PIN(GPIOC_0), 35 + MESON_PIN(GPIOC_1), 36 + MESON_PIN(GPIOC_2), 37 + MESON_PIN(GPIOC_3), 38 + MESON_PIN(GPIOC_4), 39 + MESON_PIN(GPIOC_5), 40 + MESON_PIN(GPIOC_6), 41 + MESON_PIN(GPIOX_0), 42 + MESON_PIN(GPIOX_1), 43 + MESON_PIN(GPIOX_2), 44 + MESON_PIN(GPIOX_3), 45 + MESON_PIN(GPIOX_4), 46 + MESON_PIN(GPIOX_5), 47 + MESON_PIN(GPIOX_6), 48 + MESON_PIN(GPIOX_7), 49 + MESON_PIN(GPIOX_8), 50 + MESON_PIN(GPIOX_9), 51 + MESON_PIN(GPIOX_10), 52 + MESON_PIN(GPIOX_11), 53 + MESON_PIN(GPIOX_12), 54 + MESON_PIN(GPIOX_13), 55 + MESON_PIN(GPIOD_0), 56 + MESON_PIN(GPIOD_1), 57 + MESON_PIN(GPIOD_2), 58 + MESON_PIN(GPIOD_3), 59 + MESON_PIN(GPIOD_4), 60 + MESON_PIN(GPIOD_5), 61 + MESON_PIN(GPIOD_6), 62 + MESON_PIN(GPIOA_0), 63 + MESON_PIN(GPIOA_1), 64 + MESON_PIN(GPIOA_2), 65 + MESON_PIN(GPIOA_3), 66 + MESON_PIN(GPIOA_4), 67 + MESON_PIN(GPIOA_5), 68 + MESON_PIN(GPIO_TEST_N), 69 + }; 70 + 71 + /* Bank E func1 */ 72 + static const unsigned int pwm_a_pins[] = { GPIOE_0 }; 73 + static const unsigned int pwm_b_pins[] = { GPIOE_1 }; 74 + static const unsigned int i2c2_sda_pins[] = { GPIOE_2 }; 75 + static const unsigned int i2c2_scl_pins[] = { GPIOE_3 }; 76 + static const unsigned int gen_clk_e_pins[] = { GPIOE_4 }; 77 + 78 + /* Bank E func2 */ 79 + static const unsigned int i2c0_sda_e_pins[] = { GPIOE_0 }; 80 + static const unsigned int i2c0_scl_e_pins[] = { GPIOE_1 }; 81 + static const unsigned int clk_32k_in_pins[] = { GPIOE_4 }; 82 + 83 + /* Bank E func3 */ 84 + static const unsigned int i2c_slave_scl_pins[] = { GPIOE_0 }; 85 + static const unsigned int i2c_slave_sda_pins[] = { GPIOE_1 }; 86 + static const unsigned int clk12_24_e_pins[] = { GPIOE_4 }; 87 + 88 + /* Bank B func1 */ 89 + static const unsigned int emmc_nand_d0_pins[] = { GPIOB_0 }; 90 + static const unsigned int emmc_nand_d1_pins[] = { GPIOB_1 }; 91 + static const unsigned int emmc_nand_d2_pins[] = { GPIOB_2 }; 92 + static const unsigned int emmc_nand_d3_pins[] = { GPIOB_3 }; 93 + static const unsigned int emmc_nand_d4_pins[] = { GPIOB_4 }; 94 + static const unsigned int emmc_nand_d5_pins[] = { GPIOB_5 }; 95 + static const unsigned int emmc_nand_d6_pins[] = { GPIOB_6 }; 96 + static const unsigned int emmc_nand_d7_pins[] = { GPIOB_7 }; 97 + static const unsigned int emmc_clk_pins[] = { GPIOB_8 }; 98 + static const unsigned int emmc_rst_pins[] = { GPIOB_9 }; 99 + static const unsigned int emmc_cmd_pins[] = { GPIOB_10 }; 100 + static const unsigned int emmc_nand_ds_pins[] = { GPIOB_11 }; 101 + 102 + /* Bank B func2 */ 103 + static const unsigned int nand_wen_clk_pins[] = { GPIOB_8 }; 104 + static const unsigned int nand_ale_pins[] = { GPIOB_9 }; 105 + static const unsigned int nand_ren_wr_pins[] = { GPIOB_10 }; 106 + static const unsigned int nand_cle_pins[] = { GPIOB_11 }; 107 + static const unsigned int nand_ce0_pins[] = { GPIOB_12 }; 108 + 109 + /* Bank B func3 */ 110 + static const unsigned int pwm_g_b_pins[] = { GPIOB_0 }; 111 + static const unsigned int pwm_h_b_pins[] = { GPIOB_1 }; 112 + static const unsigned int pwm_i_b_pins[] = { GPIOB_2 }; 113 + static const unsigned int spif_hold_pins[] = { GPIOB_3 }; 114 + static const unsigned int spif_mo_pins[] = { GPIOB_4 }; 115 + static const unsigned int spif_mi_pins[] = { GPIOB_5 }; 116 + static const unsigned int spif_clk_pins[] = { GPIOB_6 }; 117 + static const unsigned int spif_wp_pins[] = { GPIOB_7 }; 118 + static const unsigned int pwm_j_b_pins[] = { GPIOB_8 }; 119 + static const unsigned int pwm_k_b_pins[] = { GPIOB_9 }; 120 + static const unsigned int pwm_l_b_pins[] = { GPIOB_10 }; 121 + static const unsigned int pwm_m_b_pins[] = { GPIOB_11 }; 122 + static const unsigned int pwm_n_b_pins[] = { GPIOB_12 }; 123 + static const unsigned int spif_cs_pins[] = { GPIOB_13 }; 124 + static const unsigned int spif_clk_loop_pins[] = { GPIOB_14 }; 125 + 126 + /* Bank B func4 */ 127 + static const unsigned int lcd_d0_pins[] = { GPIOB_0 }; 128 + static const unsigned int lcd_d1_pins[] = { GPIOB_1 }; 129 + static const unsigned int lcd_d2_pins[] = { GPIOB_2 }; 130 + static const unsigned int lcd_d3_pins[] = { GPIOB_8 }; 131 + static const unsigned int lcd_d4_pins[] = { GPIOB_9 }; 132 + static const unsigned int lcd_d5_pins[] = { GPIOB_10 }; 133 + static const unsigned int lcd_d6_pins[] = { GPIOB_11 }; 134 + static const unsigned int lcd_d7_pins[] = { GPIOB_12 }; 135 + 136 + /* Bank B func5 */ 137 + static const unsigned int spi_a_mosi_b_pins[] = { GPIOB_0 }; 138 + static const unsigned int spi_a_miso_b_pins[] = { GPIOB_1 }; 139 + static const unsigned int spi_a_clk_b_pins[] = { GPIOB_2 }; 140 + static const unsigned int spi_a_ss0_b_pins[] = { GPIOB_8 }; 141 + static const unsigned int spi_a_ss1_b_pins[] = { GPIOB_9 }; 142 + static const unsigned int spi_a_ss2_b_pins[] = { GPIOB_10 }; 143 + static const unsigned int i2c1_sda_b_pins[] = { GPIOB_11 }; 144 + static const unsigned int i2c1_scl_b_pins[] = { GPIOB_12 }; 145 + 146 + /* Bank B func6 */ 147 + static const unsigned int uart_a_tx_b_pins[] = { GPIOB_0 }; 148 + static const unsigned int uart_a_rx_b_pins[] = { GPIOB_1 }; 149 + static const unsigned int uart_a_cts_b_pins[] = { GPIOB_2 }; 150 + static const unsigned int uart_a_rts_b_pins[] = { GPIOB_8 }; 151 + static const unsigned int uart_d_tx_b_pins[] = { GPIOB_9 }; 152 + static const unsigned int uart_d_rx_b_pins[] = { GPIOB_10 }; 153 + static const unsigned int pdm_dclk_b_pins[] = { GPIOB_11 }; 154 + static const unsigned int pdm_din0_b_pins[] = { GPIOB_12 }; 155 + 156 + /* Bank C func1 */ 157 + static const unsigned int sdcard_d0_pins[] = { GPIOC_0 }; 158 + static const unsigned int sdcard_d1_pins[] = { GPIOC_1 }; 159 + static const unsigned int sdcard_d2_pins[] = { GPIOC_2 }; 160 + static const unsigned int sdcard_d3_pins[] = { GPIOC_3 }; 161 + static const unsigned int sdcard_clk_pins[] = { GPIOC_4 }; 162 + static const unsigned int sdcard_cmd_pins[] = { GPIOC_5 }; 163 + static const unsigned int sdcard_cd_pins[] = { GPIOC_6 }; 164 + 165 + /* Bank C func2 */ 166 + static const unsigned int jtag_b_tdo_pins[] = { GPIOC_0 }; 167 + static const unsigned int jtag_b_tdi_pins[] = { GPIOC_1 }; 168 + static const unsigned int uart_b_rx_c_pins[] = { GPIOC_2 }; 169 + static const unsigned int uart_b_tx_c_pins[] = { GPIOC_3 }; 170 + static const unsigned int jtag_b_clk_pins[] = { GPIOC_4 }; 171 + static const unsigned int jtag_b_tms_pins[] = { GPIOC_5 }; 172 + static const unsigned int gen_clk_c_pins[] = { GPIOC_6 }; 173 + 174 + /* Bank C func3 */ 175 + static const unsigned int tdm_d3_pins[] = { GPIOC_0 }; 176 + static const unsigned int tdm_d2_pins[] = { GPIOC_1 }; 177 + static const unsigned int mclk_1_pins[] = { GPIOC_2 }; 178 + static const unsigned int tdm_sclk1_pins[] = { GPIOC_3 }; 179 + static const unsigned int tdm_fs1_pins[] = { GPIOC_4 }; 180 + static const unsigned int pdm_dclk_c_pins[] = { GPIOC_5 }; 181 + static const unsigned int pdm_din0_c_pins[] = { GPIOC_6 }; 182 + 183 + /* Bank C func4 */ 184 + static const unsigned int spi_a_mosi_c_pins[] = { GPIOC_0 }; 185 + static const unsigned int spi_a_miso_c_pins[] = { GPIOC_1 }; 186 + static const unsigned int spi_a_clk_c_pins[] = { GPIOC_2 }; 187 + static const unsigned int spi_a_ss0_c_pins[] = { GPIOC_3 }; 188 + static const unsigned int spi_a_ss1_c_pins[] = { GPIOC_4 }; 189 + 190 + /* Bank C func5 */ 191 + static const unsigned int pwm_g_c_pins[] = { GPIOC_0 }; 192 + static const unsigned int pwm_h_c_pins[] = { GPIOC_1 }; 193 + static const unsigned int pwm_i_c_pins[] = { GPIOC_2 }; 194 + static const unsigned int pwm_j_c_pins[] = { GPIOC_3 }; 195 + static const unsigned int pwm_k_c_pins[] = { GPIOC_4 }; 196 + static const unsigned int pwm_l_c_pins[] = { GPIOC_5 }; 197 + static const unsigned int pwm_m_c_pins[] = { GPIOC_6 }; 198 + 199 + /* Bank C func6 */ 200 + static const unsigned int uart_a_rx_c_pins[] = { GPIOC_0 }; 201 + static const unsigned int uart_a_tx_c_pins[] = { GPIOC_1 }; 202 + static const unsigned int uart_c_rx_c_pins[] = { GPIOC_2 }; 203 + static const unsigned int uart_c_tx_c_pins[] = { GPIOC_3 }; 204 + static const unsigned int i2c3_sda_c_pins[] = { GPIOC_4 }; 205 + static const unsigned int i2c3_scl_c_pins[] = { GPIOC_5 }; 206 + static const unsigned int clk12_24_c_pins[] = { GPIOC_6 }; 207 + 208 + /* Bank X func1 */ 209 + static const unsigned int sdio_d0_pins[] = { GPIOX_0 }; 210 + static const unsigned int sdio_d1_pins[] = { GPIOX_1 }; 211 + static const unsigned int sdio_d2_pins[] = { GPIOX_2 }; 212 + static const unsigned int sdio_d3_pins[] = { GPIOX_3 }; 213 + static const unsigned int sdio_clk_pins[] = { GPIOX_4 }; 214 + static const unsigned int sdio_cmd_pins[] = { GPIOX_5 }; 215 + static const unsigned int clk12_24_x_pins[] = { GPIOX_6 }; 216 + static const unsigned int uart_e_tx_x_pins[] = { GPIOX_7 }; 217 + static const unsigned int uart_e_rx_x_pins[] = { GPIOX_8 }; 218 + static const unsigned int uart_e_cts_pins[] = { GPIOX_9 }; 219 + static const unsigned int uart_e_rts_pins[] = { GPIOX_10 }; 220 + static const unsigned int pwm_e_pins[] = { GPIOX_11 }; 221 + static const unsigned int pwm_j_x12_pins[] = { GPIOX_12 }; 222 + static const unsigned int pwm_k_x13_pins[] = { GPIOX_13 }; 223 + 224 + /* Bank X func2 */ 225 + static const unsigned int spi_a_mosi_x_pins[] = { GPIOX_0 }; 226 + static const unsigned int spi_a_miso_x_pins[] = { GPIOX_1 }; 227 + static const unsigned int spi_a_clk_x_pins[] = { GPIOX_2 }; 228 + static const unsigned int spi_a_ss0_x_pins[] = { GPIOX_3 }; 229 + static const unsigned int spi_a_ss1_x_pins[] = { GPIOX_4 }; 230 + static const unsigned int spi_a_ss2_x_pins[] = { GPIOX_5 }; 231 + static const unsigned int spi_b_ss2_x6_pins[] = { GPIOX_6 }; 232 + static const unsigned int spi_b_miso_x_pins[] = { GPIOX_7 }; 233 + static const unsigned int spi_b_clk_x_pins[] = { GPIOX_8 }; 234 + static const unsigned int spi_b_mosi_x_pins[] = { GPIOX_9 }; 235 + static const unsigned int spi_b_ss0_x_pins[] = { GPIOX_10 }; 236 + static const unsigned int spi_b_ss1_x_pins[] = { GPIOX_11 }; 237 + static const unsigned int spi_b_ss2_x12_pins[] = { GPIOX_12 }; 238 + static const unsigned int gen_clk_x_pins[] = { GPIOX_13 }; 239 + 240 + /* Bank X func3 */ 241 + static const unsigned int tdm_d1_x_pins[] = { GPIOX_0 }; 242 + static const unsigned int tdm_d0_x_pins[] = { GPIOX_1 }; 243 + static const unsigned int mclk_0_x_pins[] = { GPIOX_2 }; 244 + static const unsigned int tdm_sclk0_x_pins[] = { GPIOX_3 }; 245 + static const unsigned int tdm_fs0_x_pins[] = { GPIOX_4 }; 246 + static const unsigned int pdm_dclk_x5_pins[] = { GPIOX_5 }; 247 + static const unsigned int pdm_din0_x6_pins[] = { GPIOX_6 }; 248 + static const unsigned int pdm_din0_x9_pins[] = { GPIOX_9 }; 249 + static const unsigned int pdm_dclk_x10_pins[] = { GPIOX_10 }; 250 + static const unsigned int clk12_24_x13_pins[] = { GPIOX_13 }; 251 + 252 + /* Bank X func4 */ 253 + static const unsigned int lcd_d8_pins[] = { GPIOX_0 }; 254 + static const unsigned int lcd_d9_pins[] = { GPIOX_1 }; 255 + static const unsigned int lcd_d10_pins[] = { GPIOX_2 }; 256 + static const unsigned int lcd_d11_pins[] = { GPIOX_3 }; 257 + static const unsigned int lcd_d12_pins[] = { GPIOX_4 }; 258 + static const unsigned int lcd_d13_pins[] = { GPIOX_5 }; 259 + static const unsigned int lcd_d14_pins[] = { GPIOX_6 }; 260 + static const unsigned int lcd_d15_pins[] = { GPIOX_7 }; 261 + static const unsigned int lcd_vs_pins[] = { GPIOX_8 }; 262 + static const unsigned int lcd_hs_pins[] = { GPIOX_9 }; 263 + static const unsigned int lcd_den_pins[] = { GPIOX_10 }; 264 + static const unsigned int lcd_d16_pins[] = { GPIOX_11 }; 265 + static const unsigned int lcd_clk_x_pins[] = { GPIOX_12 }; 266 + static const unsigned int lcd_d17_pins[] = { GPIOX_13 }; 267 + 268 + /* Bank X func5 */ 269 + static const unsigned int pwm_g_x0_pins[] = { GPIOX_0 }; 270 + static const unsigned int pwm_h_x1_pins[] = { GPIOX_1 }; 271 + static const unsigned int pwm_i_x2_pins[] = { GPIOX_2 }; 272 + static const unsigned int pwm_j_x3_pins[] = { GPIOX_3 }; 273 + static const unsigned int pwm_k_x4_pins[] = { GPIOX_4 }; 274 + static const unsigned int pwm_l_x_pins[] = { GPIOX_5 }; 275 + static const unsigned int pwm_m_x_pins[] = { GPIOX_6 }; 276 + static const unsigned int pwm_n_x_pins[] = { GPIOX_7 }; 277 + static const unsigned int pwm_g_x8_pins[] = { GPIOX_8 }; 278 + static const unsigned int pwm_h_x9_pins[] = { GPIOX_9 }; 279 + static const unsigned int pwm_i_x10_pins[] = { GPIOX_10 }; 280 + static const unsigned int clk12_24_x11_pins[] = { GPIOX_11 }; 281 + 282 + /* Bank X func6 */ 283 + static const unsigned int uart_a_rx_x_pins[] = { GPIOX_0 }; 284 + static const unsigned int uart_a_tx_x_pins[] = { GPIOX_1 }; 285 + static const unsigned int uart_c_rx_x_pins[] = { GPIOX_2 }; 286 + static const unsigned int uart_c_tx_x_pins[] = { GPIOX_3 }; 287 + static const unsigned int i2c3_sda_x_pins[] = { GPIOX_4 }; 288 + static const unsigned int i2c3_scl_x_pins[] = { GPIOX_5 }; 289 + static const unsigned int i2c1_sda_x_pins[] = { GPIOX_7 }; 290 + static const unsigned int i2c1_scl_x_pins[] = { GPIOX_8 }; 291 + static const unsigned int uart_d_tx_x_pins[] = { GPIOX_9 }; 292 + static const unsigned int uart_d_rx_x_pins[] = { GPIOX_10 }; 293 + 294 + /* Bank D func1 */ 295 + static const unsigned int pwm_g_d_pins[] = { GPIOD_0 }; 296 + static const unsigned int pwm_h_d_pins[] = { GPIOD_1 }; 297 + static const unsigned int eth_led_act_pins[] = { GPIOD_2 }; 298 + static const unsigned int eth_led_link_pins[] = { GPIOD_3 }; 299 + static const unsigned int pwm_d_pins[] = { GPIOD_4 }; 300 + static const unsigned int pwm_f_pins[] = { GPIOD_5 }; 301 + static const unsigned int pwm_k_d_pins[] = { GPIOD_6 }; 302 + 303 + /* Bank D func2 */ 304 + static const unsigned int uart_a_tx_d_pins[] = { GPIOD_0 }; 305 + static const unsigned int uart_a_rx_d_pins[] = { GPIOD_1 }; 306 + static const unsigned int spi_b_miso_d_pins[] = { GPIOD_2 }; 307 + static const unsigned int spi_b_clk_d_pins[] = { GPIOD_3 }; 308 + static const unsigned int spi_b_mosi_d_pins[] = { GPIOD_4 }; 309 + static const unsigned int spi_b_ss0_d_pins[] = { GPIOD_5 }; 310 + static const unsigned int spi_b_ss1_d_pins[] = { GPIOD_6 }; 311 + 312 + /* Bank D func3 */ 313 + static const unsigned int i2c0_sda_d_pins[] = { GPIOD_0 }; 314 + static const unsigned int i2c0_scl_d_pins[] = { GPIOD_1 }; 315 + static const unsigned int i2c1_sda_d_pins[] = { GPIOD_2 }; 316 + static const unsigned int i2c1_scl_d_pins[] = { GPIOD_3 }; 317 + static const unsigned int pdm_dclk_d_pins[] = { GPIOD_4 }; 318 + static const unsigned int pdm_din0_d_pins[] = { GPIOD_5 }; 319 + static const unsigned int ir_in_d6_pins[] = { GPIOD_6 }; 320 + 321 + /* Bank D func4 */ 322 + static const unsigned int ir_in_d0_pins[] = { GPIOD_0 }; 323 + static const unsigned int ir_out_pins[] = { GPIOD_1 }; 324 + static const unsigned int pwm_i_d_pins[] = { GPIOD_2 }; 325 + static const unsigned int pwm_j_d_pins[] = { GPIOD_3 }; 326 + static const unsigned int i2c3_sda_d_pins[] = { GPIOD_4 }; 327 + static const unsigned int i2c3_scl_d_pins[] = { GPIOD_5 }; 328 + 329 + /* Bank D func5 */ 330 + static const unsigned int tdm_fs0_d_pins[] = { GPIOD_2 }; 331 + static const unsigned int tdm_sclk0_d_pins[] = { GPIOD_3 }; 332 + static const unsigned int mclk_0_d_pins[] = { GPIOD_4 }; 333 + static const unsigned int tdm_d1_d_pins[] = { GPIOD_5 }; 334 + static const unsigned int tdm_d0_d_pins[] = { GPIOD_6 }; 335 + 336 + /* Bank D func6 */ 337 + static const unsigned int uart_d_tx_d_pins[] = { GPIOD_0 }; 338 + static const unsigned int uart_d_rx_d_pins[] = { GPIOD_1 }; 339 + static const unsigned int uart_c_tx_d_pins[] = { GPIOD_2 }; 340 + static const unsigned int uart_c_rx_d_pins[] = { GPIOD_3 }; 341 + 342 + /* Bank A func1 */ 343 + static const unsigned int uart_b_tx_a_pins[] = { GPIOA_0 }; 344 + static const unsigned int uart_b_rx_a_pins[] = { GPIOA_1 }; 345 + static const unsigned int pwm_c_pins[] = { GPIOA_2 }; 346 + static const unsigned int pwm_l_a_pins[] = { GPIOA_3 }; 347 + static const unsigned int i2c1_sda_a_pins[] = { GPIOA_4 }; 348 + static const unsigned int i2c1_scl_a_pins[] = { GPIOA_5 }; 349 + 350 + /* Bank A func2 */ 351 + static const unsigned int pwm_c_hiz_pins[] = { GPIOA_2 }; 352 + static const unsigned int gen_clk_a_pins[] = { GPIOA_3 }; 353 + static const unsigned int pdm_dclk_z_pins[] = { GPIOA_4 }; 354 + static const unsigned int pdm_din0_a_pins[] = { GPIOA_5 }; 355 + 356 + /* Bank A func3 */ 357 + static const unsigned int jtag_a_clk_pins[] = { GPIOA_2 }; 358 + static const unsigned int jtag_a_tms_pins[] = { GPIOA_3 }; 359 + static const unsigned int jtag_a_tdi_pins[] = { GPIOA_4 }; 360 + static const unsigned int jtag_a_tdo_pins[] = { GPIOA_5 }; 361 + 362 + /* Bank A func4 */ 363 + static const unsigned int lcd_clk_a_pins[] = { GPIOA_3 }; 364 + static const unsigned int uart_f_tx_a_pins[] = { GPIOA_4 }; 365 + static const unsigned int uart_f_rx_a_pins[] = { GPIOA_5 }; 366 + 367 + /* Bank A func5 */ 368 + static const unsigned int uart_e_tx_a_pins[] = { GPIOA_2 }; 369 + static const unsigned int uart_e_rx_a_pins[] = { GPIOA_3 }; 370 + static const unsigned int pwm_m_a_pins[] = { GPIOA_4 }; 371 + static const unsigned int pwm_n_a_pins[] = { GPIOA_5 }; 372 + 373 + /* Bank A func6 */ 374 + static const unsigned int spi_a_mosi_a_pins[] = { GPIOA_3 }; 375 + static const unsigned int gen_clk_a4_pins[] = { GPIOA_4 }; 376 + static const unsigned int clk12_24_a_pins[] = { GPIOA_5 }; 377 + 378 + static struct meson_pmx_group c3_periphs_groups[] = { 379 + GPIO_GROUP(GPIOE_0), 380 + GPIO_GROUP(GPIOE_1), 381 + GPIO_GROUP(GPIOE_2), 382 + GPIO_GROUP(GPIOE_3), 383 + GPIO_GROUP(GPIOE_4), 384 + GPIO_GROUP(GPIOB_0), 385 + GPIO_GROUP(GPIOB_1), 386 + GPIO_GROUP(GPIOB_2), 387 + GPIO_GROUP(GPIOB_3), 388 + GPIO_GROUP(GPIOB_4), 389 + GPIO_GROUP(GPIOB_5), 390 + GPIO_GROUP(GPIOB_6), 391 + GPIO_GROUP(GPIOB_7), 392 + GPIO_GROUP(GPIOB_8), 393 + GPIO_GROUP(GPIOB_9), 394 + GPIO_GROUP(GPIOB_10), 395 + GPIO_GROUP(GPIOB_11), 396 + GPIO_GROUP(GPIOB_12), 397 + GPIO_GROUP(GPIOB_13), 398 + GPIO_GROUP(GPIOB_14), 399 + GPIO_GROUP(GPIOC_0), 400 + GPIO_GROUP(GPIOC_1), 401 + GPIO_GROUP(GPIOC_2), 402 + GPIO_GROUP(GPIOC_3), 403 + GPIO_GROUP(GPIOC_4), 404 + GPIO_GROUP(GPIOC_5), 405 + GPIO_GROUP(GPIOC_6), 406 + GPIO_GROUP(GPIOX_0), 407 + GPIO_GROUP(GPIOX_1), 408 + GPIO_GROUP(GPIOX_2), 409 + GPIO_GROUP(GPIOX_3), 410 + GPIO_GROUP(GPIOX_4), 411 + GPIO_GROUP(GPIOX_5), 412 + GPIO_GROUP(GPIOX_6), 413 + GPIO_GROUP(GPIOX_7), 414 + GPIO_GROUP(GPIOX_8), 415 + GPIO_GROUP(GPIOX_9), 416 + GPIO_GROUP(GPIOX_10), 417 + GPIO_GROUP(GPIOX_11), 418 + GPIO_GROUP(GPIOX_12), 419 + GPIO_GROUP(GPIOX_13), 420 + GPIO_GROUP(GPIOD_0), 421 + GPIO_GROUP(GPIOD_1), 422 + GPIO_GROUP(GPIOD_2), 423 + GPIO_GROUP(GPIOD_3), 424 + GPIO_GROUP(GPIOD_4), 425 + GPIO_GROUP(GPIOD_5), 426 + GPIO_GROUP(GPIOD_6), 427 + GPIO_GROUP(GPIOA_0), 428 + GPIO_GROUP(GPIOA_1), 429 + GPIO_GROUP(GPIOA_2), 430 + GPIO_GROUP(GPIOA_3), 431 + GPIO_GROUP(GPIOA_4), 432 + GPIO_GROUP(GPIOA_5), 433 + GPIO_GROUP(GPIO_TEST_N), 434 + 435 + /* Bank E func1 */ 436 + GROUP(pwm_a, 1), 437 + GROUP(pwm_b, 1), 438 + GROUP(i2c2_sda, 1), 439 + GROUP(i2c2_scl, 1), 440 + GROUP(gen_clk_e, 1), 441 + 442 + /* Bank E func2 */ 443 + GROUP(i2c0_sda_e, 2), 444 + GROUP(i2c0_scl_e, 2), 445 + GROUP(clk_32k_in, 2), 446 + 447 + /* Bank E func3 */ 448 + GROUP(i2c_slave_scl, 3), 449 + GROUP(i2c_slave_sda, 3), 450 + GROUP(clk12_24_e, 3), 451 + 452 + /* Bank B func1 */ 453 + GROUP(emmc_nand_d0, 1), 454 + GROUP(emmc_nand_d1, 1), 455 + GROUP(emmc_nand_d2, 1), 456 + GROUP(emmc_nand_d3, 1), 457 + GROUP(emmc_nand_d4, 1), 458 + GROUP(emmc_nand_d5, 1), 459 + GROUP(emmc_nand_d6, 1), 460 + GROUP(emmc_nand_d7, 1), 461 + GROUP(emmc_clk, 1), 462 + GROUP(emmc_rst, 1), 463 + GROUP(emmc_cmd, 1), 464 + GROUP(emmc_nand_ds, 1), 465 + 466 + /* Bank B func2 */ 467 + GROUP(nand_wen_clk, 2), 468 + GROUP(nand_ale, 2), 469 + GROUP(nand_ren_wr, 2), 470 + GROUP(nand_cle, 2), 471 + GROUP(nand_ce0, 2), 472 + 473 + /* Bank B func3 */ 474 + GROUP(pwm_g_b, 3), 475 + GROUP(pwm_h_b, 3), 476 + GROUP(pwm_i_b, 3), 477 + GROUP(spif_hold, 3), 478 + GROUP(spif_mo, 3), 479 + GROUP(spif_mi, 3), 480 + GROUP(spif_clk, 3), 481 + GROUP(spif_wp, 3), 482 + GROUP(pwm_j_b, 3), 483 + GROUP(pwm_k_b, 3), 484 + GROUP(pwm_l_b, 3), 485 + GROUP(pwm_m_b, 3), 486 + GROUP(pwm_n_b, 3), 487 + GROUP(spif_cs, 3), 488 + GROUP(spif_clk_loop, 3), 489 + 490 + /* Bank B func4 */ 491 + GROUP(lcd_d0, 4), 492 + GROUP(lcd_d1, 4), 493 + GROUP(lcd_d2, 4), 494 + GROUP(lcd_d3, 4), 495 + GROUP(lcd_d4, 4), 496 + GROUP(lcd_d5, 4), 497 + GROUP(lcd_d6, 4), 498 + GROUP(lcd_d7, 4), 499 + 500 + /* Bank B func5 */ 501 + GROUP(spi_a_mosi_b, 5), 502 + GROUP(spi_a_miso_b, 5), 503 + GROUP(spi_a_clk_b, 5), 504 + GROUP(spi_a_ss0_b, 5), 505 + GROUP(spi_a_ss1_b, 5), 506 + GROUP(spi_a_ss2_b, 5), 507 + GROUP(i2c1_sda_b, 5), 508 + GROUP(i2c1_scl_b, 5), 509 + 510 + /* Bank B func6 */ 511 + GROUP(uart_a_tx_b, 6), 512 + GROUP(uart_a_rx_b, 6), 513 + GROUP(uart_a_cts_b, 6), 514 + GROUP(uart_a_rts_b, 6), 515 + GROUP(uart_d_tx_b, 6), 516 + GROUP(uart_d_rx_b, 6), 517 + GROUP(pdm_dclk_b, 6), 518 + GROUP(pdm_din0_b, 6), 519 + 520 + /* Bank C func1 */ 521 + GROUP(sdcard_d0, 1), 522 + GROUP(sdcard_d1, 1), 523 + GROUP(sdcard_d2, 1), 524 + GROUP(sdcard_d3, 1), 525 + GROUP(sdcard_clk, 1), 526 + GROUP(sdcard_cmd, 1), 527 + GROUP(sdcard_cd, 1), 528 + 529 + /* Bank C func2 */ 530 + GROUP(jtag_b_tdo, 2), 531 + GROUP(jtag_b_tdi, 2), 532 + GROUP(uart_b_rx_c, 2), 533 + GROUP(uart_b_tx_c, 2), 534 + GROUP(jtag_b_clk, 2), 535 + GROUP(jtag_b_tms, 2), 536 + GROUP(gen_clk_c, 2), 537 + 538 + /* Bank C func3 */ 539 + GROUP(tdm_d3, 3), 540 + GROUP(tdm_d2, 3), 541 + GROUP(mclk_1, 3), 542 + GROUP(tdm_sclk1, 3), 543 + GROUP(tdm_fs1, 3), 544 + GROUP(pdm_dclk_c, 3), 545 + GROUP(pdm_din0_c, 3), 546 + 547 + /* Bank C func4 */ 548 + GROUP(spi_a_mosi_c, 4), 549 + GROUP(spi_a_miso_c, 4), 550 + GROUP(spi_a_clk_c, 4), 551 + GROUP(spi_a_ss0_c, 4), 552 + GROUP(spi_a_ss1_c, 4), 553 + 554 + /* Bank C func5 */ 555 + GROUP(pwm_g_c, 5), 556 + GROUP(pwm_h_c, 5), 557 + GROUP(pwm_i_c, 5), 558 + GROUP(pwm_j_c, 5), 559 + GROUP(pwm_k_c, 5), 560 + GROUP(pwm_l_c, 5), 561 + GROUP(pwm_m_c, 5), 562 + 563 + /* Bank C func6 */ 564 + GROUP(uart_a_rx_c, 6), 565 + GROUP(uart_a_tx_c, 6), 566 + GROUP(uart_c_rx_c, 6), 567 + GROUP(uart_c_tx_c, 6), 568 + GROUP(i2c3_sda_c, 6), 569 + GROUP(i2c3_scl_c, 6), 570 + GROUP(clk12_24_c, 6), 571 + 572 + /* Bank X func1 */ 573 + GROUP(sdio_d0, 1), 574 + GROUP(sdio_d1, 1), 575 + GROUP(sdio_d2, 1), 576 + GROUP(sdio_d3, 1), 577 + GROUP(sdio_clk, 1), 578 + GROUP(sdio_cmd, 1), 579 + GROUP(clk12_24_x, 1), 580 + GROUP(uart_e_tx_x, 1), 581 + GROUP(uart_e_rx_x, 1), 582 + GROUP(uart_e_cts, 1), 583 + GROUP(uart_e_rts, 1), 584 + GROUP(pwm_e, 1), 585 + GROUP(pwm_j_x12, 1), 586 + GROUP(pwm_k_x13, 1), 587 + 588 + /* Bank X func2 */ 589 + GROUP(spi_a_mosi_x, 2), 590 + GROUP(spi_a_miso_x, 2), 591 + GROUP(spi_a_clk_x, 2), 592 + GROUP(spi_a_ss0_x, 2), 593 + GROUP(spi_a_ss1_x, 2), 594 + GROUP(spi_a_ss2_x, 2), 595 + GROUP(spi_b_ss2_x6, 2), 596 + GROUP(spi_b_miso_x, 2), 597 + GROUP(spi_b_clk_x, 2), 598 + GROUP(spi_b_mosi_x, 2), 599 + GROUP(spi_b_ss0_x, 2), 600 + GROUP(spi_b_ss1_x, 2), 601 + GROUP(spi_b_ss2_x12, 2), 602 + GROUP(gen_clk_x, 2), 603 + 604 + /* Bank X func3 */ 605 + GROUP(tdm_d1_x, 3), 606 + GROUP(tdm_d0_x, 3), 607 + GROUP(mclk_0_x, 3), 608 + GROUP(tdm_sclk0_x, 3), 609 + GROUP(tdm_fs0_x, 3), 610 + GROUP(pdm_dclk_x5, 3), 611 + GROUP(pdm_din0_x6, 3), 612 + GROUP(pdm_din0_x9, 3), 613 + GROUP(pdm_dclk_x10, 3), 614 + GROUP(clk12_24_x13, 3), 615 + 616 + /* Bank X func4 */ 617 + GROUP(lcd_d8, 4), 618 + GROUP(lcd_d9, 4), 619 + GROUP(lcd_d10, 4), 620 + GROUP(lcd_d11, 4), 621 + GROUP(lcd_d12, 4), 622 + GROUP(lcd_d13, 4), 623 + GROUP(lcd_d14, 4), 624 + GROUP(lcd_d15, 4), 625 + GROUP(lcd_vs, 4), 626 + GROUP(lcd_hs, 4), 627 + GROUP(lcd_den, 4), 628 + GROUP(lcd_d16, 4), 629 + GROUP(lcd_clk_x, 4), 630 + GROUP(lcd_d17, 4), 631 + 632 + /* Bank X func5 */ 633 + GROUP(pwm_g_x0, 5), 634 + GROUP(pwm_h_x1, 5), 635 + GROUP(pwm_i_x2, 5), 636 + GROUP(pwm_j_x3, 5), 637 + GROUP(pwm_k_x4, 5), 638 + GROUP(pwm_l_x, 5), 639 + GROUP(pwm_m_x, 5), 640 + GROUP(pwm_n_x, 5), 641 + GROUP(pwm_g_x8, 5), 642 + GROUP(pwm_h_x9, 5), 643 + GROUP(pwm_i_x10, 5), 644 + GROUP(clk12_24_x11, 5), 645 + 646 + /* Bank X func6 */ 647 + GROUP(uart_a_rx_x, 6), 648 + GROUP(uart_a_tx_x, 6), 649 + GROUP(uart_c_rx_x, 6), 650 + GROUP(uart_c_tx_x, 6), 651 + GROUP(i2c3_sda_x, 6), 652 + GROUP(i2c3_scl_x, 6), 653 + GROUP(i2c1_sda_x, 6), 654 + GROUP(i2c1_scl_x, 6), 655 + GROUP(uart_d_tx_x, 6), 656 + GROUP(uart_d_rx_x, 6), 657 + 658 + /* Bank D func1 */ 659 + GROUP(pwm_g_d, 1), 660 + GROUP(pwm_h_d, 1), 661 + GROUP(eth_led_act, 1), 662 + GROUP(eth_led_link, 1), 663 + GROUP(pwm_d, 1), 664 + GROUP(pwm_f, 1), 665 + GROUP(pwm_k_d, 1), 666 + 667 + /* Bank D func2 */ 668 + GROUP(uart_a_tx_d, 2), 669 + GROUP(uart_a_rx_d, 2), 670 + GROUP(spi_b_miso_d, 2), 671 + GROUP(spi_b_clk_d, 2), 672 + GROUP(spi_b_mosi_d, 2), 673 + GROUP(spi_b_ss0_d, 2), 674 + GROUP(spi_b_ss1_d, 2), 675 + 676 + /* Bank D func3 */ 677 + GROUP(i2c0_sda_d, 3), 678 + GROUP(i2c0_scl_d, 3), 679 + GROUP(i2c1_sda_d, 3), 680 + GROUP(i2c1_scl_d, 3), 681 + GROUP(pdm_dclk_d, 3), 682 + GROUP(pdm_din0_d, 3), 683 + GROUP(ir_in_d6, 3), 684 + 685 + /* Bank D func4 */ 686 + GROUP(ir_in_d0, 4), 687 + GROUP(ir_out, 4), 688 + GROUP(pwm_i_d, 4), 689 + GROUP(pwm_j_d, 4), 690 + GROUP(i2c3_sda_d, 4), 691 + GROUP(i2c3_scl_d, 4), 692 + 693 + /* Bank D func5 */ 694 + GROUP(tdm_fs0_d, 5), 695 + GROUP(tdm_sclk0_d, 5), 696 + GROUP(mclk_0_d, 5), 697 + GROUP(tdm_d1_d, 5), 698 + GROUP(tdm_d0_d, 5), 699 + 700 + /* Bank D func6 */ 701 + GROUP(uart_d_tx_d, 6), 702 + GROUP(uart_d_rx_d, 6), 703 + GROUP(uart_c_tx_d, 6), 704 + GROUP(uart_c_rx_d, 6), 705 + 706 + /* Bank A func1 */ 707 + GROUP(uart_b_tx_a, 1), 708 + GROUP(uart_b_rx_a, 1), 709 + GROUP(pwm_c, 1), 710 + GROUP(pwm_l_a, 1), 711 + GROUP(i2c1_sda_a, 1), 712 + GROUP(i2c1_scl_a, 1), 713 + 714 + /* Bank A func2 */ 715 + GROUP(pwm_c_hiz, 2), 716 + GROUP(gen_clk_a, 2), 717 + GROUP(pdm_dclk_z, 2), 718 + GROUP(pdm_din0_a, 2), 719 + 720 + /* Bank A func3 */ 721 + GROUP(jtag_a_clk, 3), 722 + GROUP(jtag_a_tms, 3), 723 + GROUP(jtag_a_tdi, 3), 724 + GROUP(jtag_a_tdo, 3), 725 + 726 + /* Bank A func4 */ 727 + GROUP(lcd_clk_a, 4), 728 + GROUP(uart_f_tx_a, 4), 729 + GROUP(uart_f_rx_a, 4), 730 + 731 + /* Bank A func5 */ 732 + GROUP(uart_e_tx_a, 5), 733 + GROUP(uart_e_rx_a, 5), 734 + GROUP(pwm_m_a, 5), 735 + GROUP(pwm_n_a, 5), 736 + 737 + /* Bank A func6 */ 738 + GROUP(spi_a_mosi_a, 6), 739 + GROUP(gen_clk_a4, 6), 740 + GROUP(clk12_24_a, 6), 741 + }; 742 + 743 + static const char * const gpio_periphs_groups[] = { 744 + "GPIO_TEST_N", 745 + 746 + "GPIOE_0", "GPIOE_1", "GPIOE_2", "GPIOE_3", "GPIOE_4", 747 + 748 + "GPIOB_0", "GPIOB_1", "GPIOB_2", "GPIOB_3", "GPIOB_4", 749 + "GPIOB_5", "GPIOB_6", "GPIOB_7", "GPIOB_8", "GPIOB_9", 750 + "GPIOB_10", "GPIOB_11", "GPIOB_12", "GPIOB_13", 751 + "GPIOB_14", 752 + 753 + "GPIOC_0", "GPIOC_1", "GPIOC_2", "GPIOC_3", "GPIOC_4", 754 + "GPIOC_5", "GPIOC_6", 755 + 756 + "GPIOX_0", "GPIOX_1", "GPIOX_2", "GPIOX_3", "GPIOX_4", 757 + "GPIOX_5", "GPIOX_6", "GPIOX_7", "GPIOX_8", "GPIOX_9", 758 + "GPIOX_10", "GPIOX_11", "GPIOX_12", "GPIOX_13", 759 + 760 + "GPIOD_0", "GPIOD_1", "GPIOD_2", "GPIOD_3", "GPIOD_4", 761 + "GPIOD_5", "GPIOD_6", 762 + 763 + "GPIOA_0", "GPIOA_1", "GPIOA_2", "GPIOA_3", "GPIOA_4", 764 + "GPIOA_5", 765 + }; 766 + 767 + static const char * const uart_a_groups[] = { 768 + "uart_a_tx_b", "uart_a_rx_b", "uart_a_cts_b", "uart_a_rts_b", 769 + "uart_a_rx_c", "uart_a_tx_c", "uart_a_rx_x", "uart_a_tx_x", 770 + "uart_a_tx_d", "uart_a_rx_d", 771 + }; 772 + 773 + static const char * const uart_b_groups[] = { 774 + "uart_b_rx_c", "uart_b_tx_c", "uart_b_tx_a", "uart_b_rx_a", 775 + }; 776 + 777 + static const char * const uart_c_groups[] = { 778 + "uart_c_rx_c", "uart_c_tx_c", 779 + "uart_c_rx_x", "uart_c_tx_x", 780 + "uart_c_tx_d", "uart_c_rx_d", 781 + }; 782 + 783 + static const char * const uart_d_groups[] = { 784 + "uart_d_tx_b", "uart_d_rx_b", "uart_d_tx_d", "uart_d_rx_d", 785 + "uart_d_rx_x", "uart_d_tx_x", 786 + }; 787 + 788 + static const char * const uart_e_groups[] = { 789 + "uart_e_cts", "uart_e_tx_x", "uart_e_rx_x", "uart_e_rts", 790 + "uart_e_tx_a", "uart_e_rx_a", 791 + }; 792 + 793 + static const char * const i2c0_groups[] = { 794 + "i2c0_sda_e", "i2c0_scl_e", 795 + "i2c0_sda_d", "i2c0_scl_d", 796 + }; 797 + 798 + static const char * const i2c1_groups[] = { 799 + "i2c1_sda_x", "i2c1_scl_x", 800 + "i2c1_sda_d", "i2c1_scl_d", 801 + "i2c1_sda_a", "i2c1_scl_a", 802 + "i2c1_sda_b", "i2c1_scl_b", 803 + }; 804 + 805 + static const char * const i2c2_groups[] = { 806 + "i2c2_sda", "i2c2_scl", 807 + }; 808 + 809 + static const char * const i2c3_groups[] = { 810 + "i2c3_sda_c", "i2c3_scl_c", 811 + "i2c3_sda_x", "i2c3_scl_x", 812 + "i2c3_sda_d", "i2c3_scl_d", 813 + }; 814 + 815 + static const char * const i2c_slave_groups[] = { 816 + "i2c_slave_scl", "i2c_slave_sda", 817 + }; 818 + 819 + static const char * const pwm_a_groups[] = { 820 + "pwm_a", 821 + }; 822 + 823 + static const char * const pwm_b_groups[] = { 824 + "pwm_b", 825 + }; 826 + 827 + static const char * const pwm_c_groups[] = { 828 + "pwm_c", 829 + }; 830 + 831 + static const char * const pwm_d_groups[] = { 832 + "pwm_d", 833 + }; 834 + 835 + static const char * const pwm_e_groups[] = { 836 + "pwm_e", 837 + }; 838 + 839 + static const char * const pwm_f_groups[] = { 840 + "pwm_f", 841 + }; 842 + 843 + static const char * const pwm_g_groups[] = { 844 + "pwm_g_b", "pwm_g_c", "pwm_g_d", "pwm_g_x0", "pwm_g_x8", 845 + }; 846 + 847 + static const char * const pwm_h_groups[] = { 848 + "pwm_h_b", "pwm_h_c", "pwm_h_d", "pwm_h_x1", "pwm_h_x9", 849 + }; 850 + 851 + static const char * const pwm_i_groups[] = { 852 + "pwm_i_b", "pwm_i_c", "pwm_i_d", "pwm_i_x2", "pwm_i_x10", 853 + }; 854 + 855 + static const char * const pwm_j_groups[] = { 856 + "pwm_j_c", "pwm_j_d", "pwm_j_b", "pwm_j_x3", "pwm_j_x12", 857 + }; 858 + 859 + static const char * const pwm_k_groups[] = { 860 + "pwm_k_c", "pwm_k_d", "pwm_k_b", "pwm_k_x4", "pwm_k_x13", 861 + }; 862 + 863 + static const char * const pwm_l_groups[] = { 864 + "pwm_l_c", "pwm_l_x", "pwm_l_b", "pwm_l_a", 865 + }; 866 + 867 + static const char * const pwm_m_groups[] = { 868 + "pwm_m_c", "pwm_m_x", "pwm_m_a", "pwm_m_b", 869 + }; 870 + 871 + static const char * const pwm_n_groups[] = { 872 + "pwm_n_x", "pwm_n_a", "pwm_n_b", 873 + }; 874 + 875 + static const char * const pwm_c_hiz_groups[] = { 876 + "pwm_c_hiz", 877 + }; 878 + 879 + static const char * const ir_out_groups[] = { 880 + "ir_out", 881 + }; 882 + 883 + static const char * const ir_in_groups[] = { 884 + "ir_in_d0", "ir_in_d6", 885 + }; 886 + 887 + static const char * const jtag_a_groups[] = { 888 + "jtag_a_clk", "jtag_a_tms", "jtag_a_tdi", "jtag_a_tdo", 889 + }; 890 + 891 + static const char * const jtag_b_groups[] = { 892 + "jtag_b_tdo", "jtag_b_tdi", "jtag_b_clk", "jtag_b_tms", 893 + }; 894 + 895 + static const char * const gen_clk_groups[] = { 896 + "gen_clk_e", "gen_clk_c", "gen_clk_a", "gen_clk_x", 897 + "gen_clk_a4", 898 + }; 899 + 900 + static const char * const clk12_24_groups[] = { 901 + "clk12_24_e", "clk12_24_c", "clk12_24_x", "clk12_24_a", 902 + "clk12_24_x13", "clk12_24_x11", 903 + }; 904 + 905 + static const char * const clk_32k_in_groups[] = { 906 + "clk_32k_in", 907 + }; 908 + 909 + static const char * const emmc_groups[] = { 910 + "emmc_nand_d0", "emmc_nand_d1", "emmc_nand_d2", "emmc_nand_d3", 911 + "emmc_nand_d4", "emmc_nand_d5", "emmc_nand_d6", "emmc_nand_d7", 912 + "emmc_clk", "emmc_rst", "emmc_cmd", "emmc_nand_ds", 913 + }; 914 + 915 + static const char * const nand_groups[] = { 916 + "emmc_nand_d0", "emmc_nand_d1", "emmc_nand_d2", "emmc_nand_d3", 917 + "emmc_nand_d4", "emmc_nand_d5", "emmc_nand_d6", "emmc_nand_d7", 918 + "emmc_clk", "emmc_rst", "emmc_cmd", "emmc_nand_ds", 919 + "nand_wen_clk", "nand_ale", "nand_ren_wr", "nand_cle", 920 + "nand_ce0", 921 + }; 922 + 923 + static const char * const spif_groups[] = { 924 + "spif_mo", "spif_mi", "spif_wp", "spif_cs", 925 + "spif_clk", "spif_hold", "spif_clk_loop", 926 + }; 927 + 928 + static const char * const spi_a_groups[] = { 929 + "spi_a_clk_b", "spi_a_ss0_b", "spi_a_ss1_b", "spi_a_ss2_b", 930 + "spi_a_mosi_b", "spi_a_miso_b", 931 + 932 + "spi_a_clk_c", "spi_a_ss0_c", "spi_a_ss1_c", 933 + "spi_a_mosi_c", "spi_a_miso_c", 934 + 935 + "spi_a_clk_x", "spi_a_ss0_x", "spi_a_ss1_x", "spi_a_ss2_x", 936 + "spi_a_mosi_x", "spi_a_miso_x", 937 + "spi_a_mosi_a", 938 + }; 939 + 940 + static const char * const spi_b_groups[] = { 941 + "spi_b_clk_x", "spi_b_ss0_x", "spi_b_ss1_x", "spi_b_ss2_x6", 942 + "spi_b_miso_x", "spi_b_mosi_x", "spi_b_ss2_x12", 943 + 944 + "spi_b_clk_d", "spi_b_ss0_d", "spi_b_ss1_d", "spi_b_miso_d", 945 + "spi_b_mosi_d", 946 + }; 947 + 948 + static const char * const sdcard_groups[] = { 949 + "sdcard_d0", "sdcard_d1", "sdcard_d2", "sdcard_d3", 950 + "sdcard_cd", "sdcard_clk", "sdcard_cmd", 951 + }; 952 + 953 + static const char * const sdio_groups[] = { 954 + "sdio_d0", "sdio_d1", "sdio_d2", "sdio_d3", 955 + "sdio_clk", "sdio_cmd", 956 + }; 957 + 958 + static const char * const pdm_groups[] = { 959 + "pdm_dclk_c", "pdm_din0_c", "pdm_dclk_d", "pdm_din0_d", 960 + "pdm_dclk_z", "pdm_din0_a", "pdm_dclk_b", "pdm_din0_b", 961 + "pdm_dclk_x5", "pdm_din0_x6", "pdm_din0_x9", "pdm_dclk_x10", 962 + }; 963 + 964 + static const char * const eth_groups[] = { 965 + "eth_led_act", "eth_led_link", 966 + }; 967 + 968 + static const char * const mclk_0_groups[] = { 969 + "mclk_0_x", "mclk_0_d", 970 + }; 971 + 972 + static const char * const mclk_1_groups[] = { 973 + "mclk_1", 974 + }; 975 + 976 + static const char * const tdm_groups[] = { 977 + "tdm_d3", "tdm_d2", "tdm_fs1", "tdm_d1_x", "tdm_d0_x", 978 + "tdm_d1_d", "tdm_d0_d", "tdm_sclk1", "tdm_fs0_x", "tdm_fs0_d", 979 + "tdm_sclk0_x", "tdm_sclk0_d", 980 + }; 981 + 982 + static const char * const lcd_groups[] = { 983 + "lcd_d0", "lcd_d1", "lcd_d2", "lcd_d3", "lcd_d4", 984 + "lcd_d5", "lcd_d6", "lcd_d7", "lcd_d8", "lcd_d9", 985 + "lcd_d10", "lcd_d11", "lcd_d12", "lcd_d13", "lcd_d14", 986 + "lcd_d15", "lcd_d16", "lcd_d17", "lcd_den", 987 + "lcd_clk_a", "lcd_clk_x", "lcd_hs", "lcd_vs", 988 + }; 989 + 990 + static struct meson_pmx_func c3_periphs_functions[] = { 991 + FUNCTION(gpio_periphs), 992 + FUNCTION(uart_a), 993 + FUNCTION(uart_b), 994 + FUNCTION(uart_c), 995 + FUNCTION(uart_d), 996 + FUNCTION(uart_e), 997 + FUNCTION(i2c0), 998 + FUNCTION(i2c1), 999 + FUNCTION(i2c2), 1000 + FUNCTION(i2c3), 1001 + FUNCTION(i2c_slave), 1002 + FUNCTION(pwm_a), 1003 + FUNCTION(pwm_b), 1004 + FUNCTION(pwm_c), 1005 + FUNCTION(pwm_d), 1006 + FUNCTION(pwm_e), 1007 + FUNCTION(pwm_f), 1008 + FUNCTION(pwm_g), 1009 + FUNCTION(pwm_h), 1010 + FUNCTION(pwm_i), 1011 + FUNCTION(pwm_j), 1012 + FUNCTION(pwm_k), 1013 + FUNCTION(pwm_l), 1014 + FUNCTION(pwm_m), 1015 + FUNCTION(pwm_n), 1016 + FUNCTION(pwm_c_hiz), 1017 + FUNCTION(ir_out), 1018 + FUNCTION(ir_in), 1019 + FUNCTION(jtag_a), 1020 + FUNCTION(jtag_b), 1021 + FUNCTION(gen_clk), 1022 + FUNCTION(clk12_24), 1023 + FUNCTION(clk_32k_in), 1024 + FUNCTION(emmc), 1025 + FUNCTION(nand), 1026 + FUNCTION(spif), 1027 + FUNCTION(spi_a), 1028 + FUNCTION(spi_b), 1029 + FUNCTION(sdcard), 1030 + FUNCTION(sdio), 1031 + FUNCTION(pdm), 1032 + FUNCTION(eth), 1033 + FUNCTION(mclk_0), 1034 + FUNCTION(mclk_1), 1035 + FUNCTION(tdm), 1036 + FUNCTION(lcd), 1037 + }; 1038 + 1039 + static struct meson_bank c3_periphs_banks[] = { 1040 + /* name first last irq pullen pull dir out in ds */ 1041 + BANK_DS("X", GPIOX_0, GPIOX_13, 40, 53, 1042 + 0x03, 0, 0x04, 0, 0x02, 0, 0x01, 0, 0x00, 0, 0x07, 0), 1043 + BANK_DS("D", GPIOD_0, GPIOD_6, 33, 39, 1044 + 0x23, 0, 0x24, 0, 0x22, 0, 0x21, 0, 0x20, 0, 0x27, 0), 1045 + BANK_DS("E", GPIOE_0, GPIOE_4, 22, 26, 1046 + 0x33, 0, 0x34, 0, 0x32, 0, 0x31, 0, 0x30, 0, 0x37, 0), 1047 + BANK_DS("C", GPIOC_0, GPIOC_6, 15, 21, 1048 + 0x43, 0, 0x44, 0, 0x42, 0, 0x41, 0, 0x40, 0, 0x47, 0), 1049 + BANK_DS("B", GPIOB_0, GPIOB_14, 0, 14, 1050 + 0x53, 0, 0x54, 0, 0x52, 0, 0x51, 0, 0x50, 0, 0x57, 0), 1051 + BANK_DS("A", GPIOA_0, GPIOA_5, 27, 32, 1052 + 0x63, 0, 0x64, 0, 0x62, 0, 0x61, 0, 0x60, 0, 0x67, 0), 1053 + BANK_DS("TEST_N", GPIO_TEST_N, GPIO_TEST_N, 54, 54, 1054 + 0x73, 0, 0x74, 0, 0x72, 0, 0x71, 0, 0x70, 0, 0x77, 0), 1055 + }; 1056 + 1057 + static struct meson_pmx_bank c3_periphs_pmx_banks[] = { 1058 + /* name first last reg offset */ 1059 + BANK_PMX("B", GPIOB_0, GPIOB_14, 0x00, 0), 1060 + BANK_PMX("X", GPIOX_0, GPIOX_13, 0x03, 0), 1061 + BANK_PMX("C", GPIOC_0, GPIOC_6, 0x09, 0), 1062 + BANK_PMX("A", GPIOA_0, GPIOA_5, 0x0b, 0), 1063 + BANK_PMX("D", GPIOD_0, GPIOD_6, 0x10, 0), 1064 + BANK_PMX("E", GPIOE_0, GPIOE_4, 0x12, 0), 1065 + BANK_PMX("TEST_N", GPIO_TEST_N, GPIO_TEST_N, 0x02, 0), 1066 + }; 1067 + 1068 + static struct meson_axg_pmx_data c3_periphs_pmx_banks_data = { 1069 + .pmx_banks = c3_periphs_pmx_banks, 1070 + .num_pmx_banks = ARRAY_SIZE(c3_periphs_pmx_banks), 1071 + }; 1072 + 1073 + static struct meson_pinctrl_data c3_periphs_pinctrl_data = { 1074 + .name = "periphs-banks", 1075 + .pins = c3_periphs_pins, 1076 + .groups = c3_periphs_groups, 1077 + .funcs = c3_periphs_functions, 1078 + .banks = c3_periphs_banks, 1079 + .num_pins = ARRAY_SIZE(c3_periphs_pins), 1080 + .num_groups = ARRAY_SIZE(c3_periphs_groups), 1081 + .num_funcs = ARRAY_SIZE(c3_periphs_functions), 1082 + .num_banks = ARRAY_SIZE(c3_periphs_banks), 1083 + .pmx_ops = &meson_axg_pmx_ops, 1084 + .pmx_data = &c3_periphs_pmx_banks_data, 1085 + .parse_dt = &meson_a1_parse_dt_extra, 1086 + }; 1087 + 1088 + static const struct of_device_id c3_pinctrl_dt_match[] = { 1089 + { 1090 + .compatible = "amlogic,c3-periphs-pinctrl", 1091 + .data = &c3_periphs_pinctrl_data, 1092 + }, 1093 + { } 1094 + }; 1095 + MODULE_DEVICE_TABLE(of, c3_pinctrl_dt_match); 1096 + 1097 + static struct platform_driver c3_pinctrl_driver = { 1098 + .probe = meson_pinctrl_probe, 1099 + .driver = { 1100 + .name = "amlogic-c3-pinctrl", 1101 + .of_match_table = c3_pinctrl_dt_match, 1102 + }, 1103 + }; 1104 + module_platform_driver(c3_pinctrl_driver); 1105 + 1106 + MODULE_AUTHOR("Huqiang Qin <huqiang.qin@amlogic.com>"); 1107 + MODULE_DESCRIPTION("Pin controller and GPIO driver for Amlogic C3 SoC"); 1108 + MODULE_LICENSE("Dual BSD/GPL");