linux/drivers/pinctrl/meson/pinctrl-meson-a1.c
<<
>>
Prefs
   1// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
   2/*
   3 * Pin controller and GPIO driver for Amlogic Meson A1 SoC.
   4 *
   5 * Copyright (c) 2019 Amlogic, Inc. All rights reserved.
   6 * Author: Qianggui Song <qianggui.song@amlogic.com>
   7 */
   8
   9#include <dt-bindings/gpio/meson-a1-gpio.h>
  10#include "pinctrl-meson.h"
  11#include "pinctrl-meson-axg-pmx.h"
  12
  13static const struct pinctrl_pin_desc meson_a1_periphs_pins[] = {
  14        MESON_PIN(GPIOP_0),
  15        MESON_PIN(GPIOP_1),
  16        MESON_PIN(GPIOP_2),
  17        MESON_PIN(GPIOP_3),
  18        MESON_PIN(GPIOP_4),
  19        MESON_PIN(GPIOP_5),
  20        MESON_PIN(GPIOP_6),
  21        MESON_PIN(GPIOP_7),
  22        MESON_PIN(GPIOP_8),
  23        MESON_PIN(GPIOP_9),
  24        MESON_PIN(GPIOP_10),
  25        MESON_PIN(GPIOP_11),
  26        MESON_PIN(GPIOP_12),
  27        MESON_PIN(GPIOB_0),
  28        MESON_PIN(GPIOB_1),
  29        MESON_PIN(GPIOB_2),
  30        MESON_PIN(GPIOB_3),
  31        MESON_PIN(GPIOB_4),
  32        MESON_PIN(GPIOB_5),
  33        MESON_PIN(GPIOB_6),
  34        MESON_PIN(GPIOX_0),
  35        MESON_PIN(GPIOX_1),
  36        MESON_PIN(GPIOX_2),
  37        MESON_PIN(GPIOX_3),
  38        MESON_PIN(GPIOX_4),
  39        MESON_PIN(GPIOX_5),
  40        MESON_PIN(GPIOX_6),
  41        MESON_PIN(GPIOX_7),
  42        MESON_PIN(GPIOX_8),
  43        MESON_PIN(GPIOX_9),
  44        MESON_PIN(GPIOX_10),
  45        MESON_PIN(GPIOX_11),
  46        MESON_PIN(GPIOX_12),
  47        MESON_PIN(GPIOX_13),
  48        MESON_PIN(GPIOX_14),
  49        MESON_PIN(GPIOX_15),
  50        MESON_PIN(GPIOX_16),
  51        MESON_PIN(GPIOF_0),
  52        MESON_PIN(GPIOF_1),
  53        MESON_PIN(GPIOF_2),
  54        MESON_PIN(GPIOF_3),
  55        MESON_PIN(GPIOF_4),
  56        MESON_PIN(GPIOF_5),
  57        MESON_PIN(GPIOF_6),
  58        MESON_PIN(GPIOF_7),
  59        MESON_PIN(GPIOF_8),
  60        MESON_PIN(GPIOF_9),
  61        MESON_PIN(GPIOF_10),
  62        MESON_PIN(GPIOF_11),
  63        MESON_PIN(GPIOF_12),
  64        MESON_PIN(GPIOA_0),
  65        MESON_PIN(GPIOA_1),
  66        MESON_PIN(GPIOA_2),
  67        MESON_PIN(GPIOA_3),
  68        MESON_PIN(GPIOA_4),
  69        MESON_PIN(GPIOA_5),
  70        MESON_PIN(GPIOA_6),
  71        MESON_PIN(GPIOA_7),
  72        MESON_PIN(GPIOA_8),
  73        MESON_PIN(GPIOA_9),
  74        MESON_PIN(GPIOA_10),
  75        MESON_PIN(GPIOA_11),
  76};
  77
  78/* psram */
  79static const unsigned int psram_clkn_pins[]             = { GPIOP_0 };
  80static const unsigned int psram_clkp_pins[]             = { GPIOP_1 };
  81static const unsigned int psram_ce_n_pins[]             = { GPIOP_2 };
  82static const unsigned int psram_rst_n_pins[]            = { GPIOP_3 };
  83static const unsigned int psram_adq0_pins[]             = { GPIOP_4 };
  84static const unsigned int psram_adq1_pins[]             = { GPIOP_5 };
  85static const unsigned int psram_adq2_pins[]             = { GPIOP_6 };
  86static const unsigned int psram_adq3_pins[]             = { GPIOP_7 };
  87static const unsigned int psram_adq4_pins[]             = { GPIOP_8 };
  88static const unsigned int psram_adq5_pins[]             = { GPIOP_9 };
  89static const unsigned int psram_adq6_pins[]             = { GPIOP_10 };
  90static const unsigned int psram_adq7_pins[]             = { GPIOP_11 };
  91static const unsigned int psram_dqs_dm_pins[]           = { GPIOP_12 };
  92
  93/* sdcard */
  94static const unsigned int sdcard_d0_b_pins[]            = { GPIOB_0 };
  95static const unsigned int sdcard_d1_b_pins[]            = { GPIOB_1 };
  96static const unsigned int sdcard_d2_b_pins[]            = { GPIOB_2 };
  97static const unsigned int sdcard_d3_b_pins[]            = { GPIOB_3 };
  98static const unsigned int sdcard_clk_b_pins[]           = { GPIOB_4 };
  99static const unsigned int sdcard_cmd_b_pins[]           = { GPIOB_5 };
 100
 101static const unsigned int sdcard_d0_x_pins[]            = { GPIOX_0 };
 102static const unsigned int sdcard_d1_x_pins[]            = { GPIOX_1 };
 103static const unsigned int sdcard_d2_x_pins[]            = { GPIOX_2 };
 104static const unsigned int sdcard_d3_x_pins[]            = { GPIOX_3 };
 105static const unsigned int sdcard_clk_x_pins[]           = { GPIOX_4 };
 106static const unsigned int sdcard_cmd_x_pins[]           = { GPIOX_5 };
 107
 108/* spif */
 109static const unsigned int spif_mo_pins[]                = { GPIOB_0 };
 110static const unsigned int spif_mi_pins[]                = { GPIOB_1 };
 111static const unsigned int spif_wp_n_pins[]              = { GPIOB_2 };
 112static const unsigned int spif_hold_n_pins[]            = { GPIOB_3 };
 113static const unsigned int spif_clk_pins[]               = { GPIOB_4 };
 114static const unsigned int spif_cs_pins[]                = { GPIOB_5 };
 115
 116/* i2c0 */
 117static const unsigned int i2c0_sck_f9_pins[]            = { GPIOF_9 };
 118static const unsigned int i2c0_sda_f10_pins[]           = { GPIOF_10 };
 119static const unsigned int i2c0_sck_f11_pins[]           = { GPIOF_11 };
 120static const unsigned int i2c0_sda_f12_pins[]           = { GPIOF_12 };
 121
 122/* i2c1 */
 123static const unsigned int i2c1_sda_x_pins[]             = { GPIOX_9 };
 124static const unsigned int i2c1_sck_x_pins[]             = { GPIOX_10 };
 125static const unsigned int i2c1_sda_a_pins[]             = { GPIOA_10 };
 126static const unsigned int i2c1_sck_a_pins[]             = { GPIOA_11 };
 127
 128/* i2c2 */
 129static const unsigned int i2c2_sck_x0_pins[]            = { GPIOX_0 };
 130static const unsigned int i2c2_sda_x1_pins[]            = { GPIOX_1 };
 131static const unsigned int i2c2_sck_x15_pins[]           = { GPIOX_15 };
 132static const unsigned int i2c2_sda_x16_pins[]           = { GPIOX_16 };
 133static const unsigned int i2c2_sck_a4_pins[]            = { GPIOA_4 };
 134static const unsigned int i2c2_sda_a5_pins[]            = { GPIOA_5 };
 135static const unsigned int i2c2_sck_a8_pins[]            = { GPIOA_8 };
 136static const unsigned int i2c2_sda_a9_pins[]            = { GPIOA_9 };
 137
 138/* i2c3 */
 139static const unsigned int i2c3_sck_f_pins[]             = { GPIOF_4 };
 140static const unsigned int i2c3_sda_f_pins[]             = { GPIOF_5 };
 141static const unsigned int i2c3_sck_x_pins[]             = { GPIOX_11 };
 142static const unsigned int i2c3_sda_x_pins[]             = { GPIOX_12 };
 143
 144/* i2c slave */
 145static const unsigned int i2c_slave_sck_a_pins[]        = { GPIOA_10 };
 146static const unsigned int i2c_slave_sda_a_pins[]        = { GPIOA_11 };
 147static const unsigned int i2c_slave_sck_f_pins[]        = { GPIOF_11 };
 148static const unsigned int i2c_slave_sda_f_pins[]        = { GPIOF_12 };
 149
 150/* uart_a */
 151static const unsigned int uart_a_tx_pins[]              = { GPIOX_11 };
 152static const unsigned int uart_a_rx_pins[]              = { GPIOX_12 };
 153static const unsigned int uart_a_cts_pins[]             = { GPIOX_13 };
 154static const unsigned int uart_a_rts_pins[]             = { GPIOX_14 };
 155
 156/* uart_b */
 157static const unsigned int uart_b_tx_x_pins[]            = { GPIOX_7 };
 158static const unsigned int uart_b_rx_x_pins[]            = { GPIOX_8 };
 159static const unsigned int uart_b_tx_f_pins[]            = { GPIOF_0 };
 160static const unsigned int uart_b_rx_f_pins[]            = { GPIOF_1 };
 161
 162/* uart_c */
 163static const unsigned int uart_c_tx_x0_pins[]           = { GPIOX_0 };
 164static const unsigned int uart_c_rx_x1_pins[]           = { GPIOX_1 };
 165static const unsigned int uart_c_cts_pins[]             = { GPIOX_2 };
 166static const unsigned int uart_c_rts_pins[]             = { GPIOX_3 };
 167static const unsigned int uart_c_tx_x15_pins[]          = { GPIOX_15 };
 168static const unsigned int uart_c_rx_x16_pins[]          = { GPIOX_16 };
 169
 170/* pmw_a */
 171static const unsigned int pwm_a_x6_pins[]               = { GPIOX_6 };
 172static const unsigned int pwm_a_x7_pins[]               = { GPIOX_7 };
 173static const unsigned int pwm_a_f6_pins[]               = { GPIOF_6 };
 174static const unsigned int pwm_a_f10_pins[]              = { GPIOF_10 };
 175static const unsigned int pwm_a_a_pins[]                = { GPIOA_5 };
 176
 177/* pmw_b */
 178static const unsigned int pwm_b_x_pins[]                = { GPIOX_8 };
 179static const unsigned int pwm_b_f_pins[]                = { GPIOF_7 };
 180static const unsigned int pwm_b_a_pins[]                = { GPIOA_11 };
 181
 182/* pmw_c */
 183static const unsigned int pwm_c_x_pins[]                = { GPIOX_9 };
 184static const unsigned int pwm_c_f3_pins[]               = { GPIOF_3 };
 185static const unsigned int pwm_c_f8_pins[]               = { GPIOF_8 };
 186static const unsigned int pwm_c_a_pins[]                = { GPIOA_10 };
 187
 188/* pwm_d */
 189static const unsigned int pwm_d_x10_pins[]              = { GPIOX_10 };
 190static const unsigned int pwm_d_x13_pins[]              = { GPIOX_13 };
 191static const unsigned int pwm_d_x15_pins[]              = { GPIOX_15 };
 192static const unsigned int pwm_d_f_pins[]                = { GPIOF_11 };
 193
 194/* pwm_e */
 195static const unsigned int pwm_e_p_pins[]                = { GPIOP_3 };
 196static const unsigned int pwm_e_x2_pins[]               = { GPIOX_2 };
 197static const unsigned int pwm_e_x14_pins[]              = { GPIOX_14 };
 198static const unsigned int pwm_e_x16_pins[]              = { GPIOX_16 };
 199static const unsigned int pwm_e_f_pins[]                = { GPIOF_3 };
 200static const unsigned int pwm_e_a_pins[]                = { GPIOA_0 };
 201
 202/* pwm_f */
 203static const unsigned int pwm_f_b_pins[]                = { GPIOB_6 };
 204static const unsigned int pwm_f_x_pins[]                = { GPIOX_3 };
 205static const unsigned int pwm_f_f4_pins[]               = { GPIOF_4 };
 206static const unsigned int pwm_f_f12_pins[]              = { GPIOF_12 };
 207
 208/* pwm_a_hiz */
 209static const unsigned int pwm_a_hiz_f8_pins[]           = { GPIOF_8 };
 210static const unsigned int pwm_a_hiz_f10_pins[]          = { GPIOF_10 };
 211static const unsigned int pmw_a_hiz_f6_pins[]           = { GPIOF_6 };
 212
 213/* pwm_b_hiz */
 214static const unsigned int pwm_b_hiz_pins[]              = { GPIOF_7 };
 215
 216/* pmw_c_hiz */
 217static const unsigned int pwm_c_hiz_pins[]              = { GPIOF_8 };
 218
 219/* tdm_a */
 220static const unsigned int tdm_a_dout1_pins[]            = { GPIOX_7 };
 221static const unsigned int tdm_a_dout0_pins[]            = { GPIOX_8 };
 222static const unsigned int tdm_a_fs_pins[]               = { GPIOX_9 };
 223static const unsigned int tdm_a_sclk_pins[]             = { GPIOX_10 };
 224static const unsigned int tdm_a_din1_pins[]             = { GPIOX_7 };
 225static const unsigned int tdm_a_din0_pins[]             = { GPIOX_8 };
 226static const unsigned int tdm_a_slv_fs_pins[]           = { GPIOX_9 };
 227static const unsigned int tdm_a_slv_sclk_pins[]         = { GPIOX_10 };
 228
 229/* spi_a */
 230static const unsigned int spi_a_mosi_x2_pins[]          = { GPIOX_2 };
 231static const unsigned int spi_a_ss0_x3_pins[]           = { GPIOX_3 };
 232static const unsigned int spi_a_sclk_x4_pins[]          = { GPIOX_4 };
 233static const unsigned int spi_a_miso_x5_pins[]          = { GPIOX_5 };
 234static const unsigned int spi_a_mosi_x7_pins[]          = { GPIOX_7 };
 235static const unsigned int spi_a_miso_x8_pins[]          = { GPIOX_8 };
 236static const unsigned int spi_a_ss0_x9_pins[]           = { GPIOX_9 };
 237static const unsigned int spi_a_sclk_x10_pins[]         = { GPIOX_10 };
 238
 239static const unsigned int spi_a_mosi_a_pins[]           = { GPIOA_6 };
 240static const unsigned int spi_a_miso_a_pins[]           = { GPIOA_7 };
 241static const unsigned int spi_a_ss0_a_pins[]            = { GPIOA_8 };
 242static const unsigned int spi_a_sclk_a_pins[]           = { GPIOA_9 };
 243
 244/* pdm */
 245static const unsigned int pdm_din0_x_pins[]             = { GPIOX_7 };
 246static const unsigned int pdm_din1_x_pins[]             = { GPIOX_8 };
 247static const unsigned int pdm_din2_x_pins[]             = { GPIOX_9 };
 248static const unsigned int pdm_dclk_x_pins[]             = { GPIOX_10 };
 249
 250static const unsigned int pdm_din2_a_pins[]             = { GPIOA_6 };
 251static const unsigned int pdm_din1_a_pins[]             = { GPIOA_7 };
 252static const unsigned int pdm_din0_a_pins[]             = { GPIOA_8 };
 253static const unsigned int pdm_dclk_pins[]               = { GPIOA_9 };
 254
 255/* gen_clk */
 256static const unsigned int gen_clk_x_pins[]              = { GPIOX_7 };
 257static const unsigned int gen_clk_f8_pins[]             = { GPIOF_8 };
 258static const unsigned int gen_clk_f10_pins[]            = { GPIOF_10 };
 259static const unsigned int gen_clk_a_pins[]              = { GPIOA_11 };
 260
 261/* jtag_a */
 262static const unsigned int jtag_a_clk_pins[]             = { GPIOF_4 };
 263static const unsigned int jtag_a_tms_pins[]             = { GPIOF_5 };
 264static const unsigned int jtag_a_tdi_pins[]             = { GPIOF_6 };
 265static const unsigned int jtag_a_tdo_pins[]             = { GPIOF_7 };
 266
 267/* clk_32_in */
 268static const unsigned int clk_32k_in_pins[]             = { GPIOF_2 };
 269
 270/* ir in */
 271static const unsigned int remote_input_f_pins[]         = { GPIOF_3 };
 272static const unsigned int remote_input_a_pins[]         = { GPIOA_11 };
 273
 274/* ir out */
 275static const unsigned int remote_out_pins[]             = { GPIOF_5 };
 276
 277/* spdif */
 278static const unsigned int spdif_in_f6_pins[]            = { GPIOF_6 };
 279static const unsigned int spdif_in_f7_pins[]            = { GPIOF_7 };
 280
 281/* sw */
 282static const unsigned int swclk_pins[]                  = { GPIOF_4 };
 283static const unsigned int swdio_pins[]                  = { GPIOF_5 };
 284
 285/* clk_25 */
 286static const unsigned int clk25_pins[]                  = { GPIOF_10 };
 287
 288/* cec_a */
 289static const unsigned int cec_a_pins[]                  = { GPIOF_2 };
 290
 291/* cec_b */
 292static const unsigned int cec_b_pins[]                  = { GPIOF_2 };
 293
 294/* clk12_24 */
 295static const unsigned int clk12_24_pins[]               = { GPIOF_10 };
 296
 297/* mclk_0 */
 298static const unsigned int mclk_0_pins[]                 = { GPIOA_0 };
 299
 300/* tdm_b */
 301static const unsigned int tdm_b_sclk_pins[]             = { GPIOA_1 };
 302static const unsigned int tdm_b_fs_pins[]               = { GPIOA_2 };
 303static const unsigned int tdm_b_dout0_pins[]            = { GPIOA_3 };
 304static const unsigned int tdm_b_dout1_pins[]            = { GPIOA_4 };
 305static const unsigned int tdm_b_dout2_pins[]            = { GPIOA_5 };
 306static const unsigned int tdm_b_dout3_pins[]            = { GPIOA_6 };
 307static const unsigned int tdm_b_dout4_pins[]            = { GPIOA_7 };
 308static const unsigned int tdm_b_dout5_pins[]            = { GPIOA_8 };
 309static const unsigned int tdm_b_slv_sclk_pins[]         = { GPIOA_5 };
 310static const unsigned int tdm_b_slv_fs_pins[]           = { GPIOA_6 };
 311static const unsigned int tdm_b_din0_pins[]             = { GPIOA_7 };
 312static const unsigned int tdm_b_din1_pins[]             = { GPIOA_8 };
 313static const unsigned int tdm_b_din2_pins[]             = { GPIOA_9 };
 314
 315/* mclk_vad */
 316static const unsigned int mclk_vad_pins[]               = { GPIOA_0 };
 317
 318/* tdm_vad */
 319static const unsigned int tdm_vad_sclk_a1_pins[]        = { GPIOA_1 };
 320static const unsigned int tdm_vad_fs_a2_pins[]          = { GPIOA_2 };
 321static const unsigned int tdm_vad_sclk_a5_pins[]        = { GPIOA_5 };
 322static const unsigned int tdm_vad_fs_a6_pins[]          = { GPIOA_6 };
 323
 324/* tst_out */
 325static const unsigned int tst_out0_pins[]               = { GPIOA_0 };
 326static const unsigned int tst_out1_pins[]               = { GPIOA_1 };
 327static const unsigned int tst_out2_pins[]               = { GPIOA_2 };
 328static const unsigned int tst_out3_pins[]               = { GPIOA_3 };
 329static const unsigned int tst_out4_pins[]               = { GPIOA_4 };
 330static const unsigned int tst_out5_pins[]               = { GPIOA_5 };
 331static const unsigned int tst_out6_pins[]               = { GPIOA_6 };
 332static const unsigned int tst_out7_pins[]               = { GPIOA_7 };
 333static const unsigned int tst_out8_pins[]               = { GPIOA_8 };
 334static const unsigned int tst_out9_pins[]               = { GPIOA_9 };
 335static const unsigned int tst_out10_pins[]              = { GPIOA_10 };
 336static const unsigned int tst_out11_pins[]              = { GPIOA_11 };
 337
 338/* mute */
 339static const unsigned int mute_key_pins[]               = { GPIOA_4 };
 340static const unsigned int mute_en_pins[]                = { GPIOA_5 };
 341
 342static struct meson_pmx_group meson_a1_periphs_groups[] = {
 343        GPIO_GROUP(GPIOP_0),
 344        GPIO_GROUP(GPIOP_1),
 345        GPIO_GROUP(GPIOP_2),
 346        GPIO_GROUP(GPIOP_3),
 347        GPIO_GROUP(GPIOP_4),
 348        GPIO_GROUP(GPIOP_5),
 349        GPIO_GROUP(GPIOP_6),
 350        GPIO_GROUP(GPIOP_7),
 351        GPIO_GROUP(GPIOP_8),
 352        GPIO_GROUP(GPIOP_9),
 353        GPIO_GROUP(GPIOP_10),
 354        GPIO_GROUP(GPIOP_11),
 355        GPIO_GROUP(GPIOP_12),
 356        GPIO_GROUP(GPIOB_0),
 357        GPIO_GROUP(GPIOB_1),
 358        GPIO_GROUP(GPIOB_2),
 359        GPIO_GROUP(GPIOB_3),
 360        GPIO_GROUP(GPIOB_4),
 361        GPIO_GROUP(GPIOB_5),
 362        GPIO_GROUP(GPIOB_6),
 363        GPIO_GROUP(GPIOX_0),
 364        GPIO_GROUP(GPIOX_1),
 365        GPIO_GROUP(GPIOX_2),
 366        GPIO_GROUP(GPIOX_3),
 367        GPIO_GROUP(GPIOX_4),
 368        GPIO_GROUP(GPIOX_5),
 369        GPIO_GROUP(GPIOX_6),
 370        GPIO_GROUP(GPIOX_7),
 371        GPIO_GROUP(GPIOX_8),
 372        GPIO_GROUP(GPIOX_9),
 373        GPIO_GROUP(GPIOX_10),
 374        GPIO_GROUP(GPIOX_11),
 375        GPIO_GROUP(GPIOX_12),
 376        GPIO_GROUP(GPIOX_13),
 377        GPIO_GROUP(GPIOX_14),
 378        GPIO_GROUP(GPIOX_15),
 379        GPIO_GROUP(GPIOX_16),
 380        GPIO_GROUP(GPIOF_0),
 381        GPIO_GROUP(GPIOF_1),
 382        GPIO_GROUP(GPIOF_2),
 383        GPIO_GROUP(GPIOF_3),
 384        GPIO_GROUP(GPIOF_4),
 385        GPIO_GROUP(GPIOF_5),
 386        GPIO_GROUP(GPIOF_6),
 387        GPIO_GROUP(GPIOF_7),
 388        GPIO_GROUP(GPIOF_8),
 389        GPIO_GROUP(GPIOF_9),
 390        GPIO_GROUP(GPIOF_10),
 391        GPIO_GROUP(GPIOF_11),
 392        GPIO_GROUP(GPIOF_12),
 393        GPIO_GROUP(GPIOA_0),
 394        GPIO_GROUP(GPIOA_1),
 395        GPIO_GROUP(GPIOA_2),
 396        GPIO_GROUP(GPIOA_3),
 397        GPIO_GROUP(GPIOA_4),
 398        GPIO_GROUP(GPIOA_5),
 399        GPIO_GROUP(GPIOA_6),
 400        GPIO_GROUP(GPIOA_7),
 401        GPIO_GROUP(GPIOA_8),
 402        GPIO_GROUP(GPIOA_9),
 403        GPIO_GROUP(GPIOA_10),
 404        GPIO_GROUP(GPIOA_11),
 405
 406        /* bank P func1 */
 407        GROUP(psram_clkn,               1),
 408        GROUP(psram_clkp,               1),
 409        GROUP(psram_ce_n,               1),
 410        GROUP(psram_rst_n,              1),
 411        GROUP(psram_adq0,               1),
 412        GROUP(psram_adq1,               1),
 413        GROUP(psram_adq2,               1),
 414        GROUP(psram_adq3,               1),
 415        GROUP(psram_adq4,               1),
 416        GROUP(psram_adq5,               1),
 417        GROUP(psram_adq6,               1),
 418        GROUP(psram_adq7,               1),
 419        GROUP(psram_dqs_dm,             1),
 420
 421        /*bank P func2 */
 422        GROUP(pwm_e_p,                  2),
 423
 424        /*bank B func1 */
 425        GROUP(spif_mo,                  1),
 426        GROUP(spif_mi,                  1),
 427        GROUP(spif_wp_n,                1),
 428        GROUP(spif_hold_n,              1),
 429        GROUP(spif_clk,                 1),
 430        GROUP(spif_cs,                  1),
 431        GROUP(pwm_f_b,                  1),
 432
 433        /*bank B func2 */
 434        GROUP(sdcard_d0_b,              2),
 435        GROUP(sdcard_d1_b,              2),
 436        GROUP(sdcard_d2_b,              2),
 437        GROUP(sdcard_d3_b,              2),
 438        GROUP(sdcard_clk_b,             2),
 439        GROUP(sdcard_cmd_b,             2),
 440
 441        /*bank X func1 */
 442        GROUP(sdcard_d0_x,              1),
 443        GROUP(sdcard_d1_x,              1),
 444        GROUP(sdcard_d2_x,              1),
 445        GROUP(sdcard_d3_x,              1),
 446        GROUP(sdcard_clk_x,             1),
 447        GROUP(sdcard_cmd_x,             1),
 448        GROUP(pwm_a_x6,                 1),
 449        GROUP(tdm_a_dout1,              1),
 450        GROUP(tdm_a_dout0,              1),
 451        GROUP(tdm_a_fs,                 1),
 452        GROUP(tdm_a_sclk,               1),
 453        GROUP(uart_a_tx,                1),
 454        GROUP(uart_a_rx,                1),
 455        GROUP(uart_a_cts,               1),
 456        GROUP(uart_a_rts,               1),
 457        GROUP(pwm_d_x15,                1),
 458        GROUP(pwm_e_x16,                1),
 459
 460        /*bank X func2 */
 461        GROUP(i2c2_sck_x0,              2),
 462        GROUP(i2c2_sda_x1,              2),
 463        GROUP(spi_a_mosi_x2,            2),
 464        GROUP(spi_a_ss0_x3,             2),
 465        GROUP(spi_a_sclk_x4,            2),
 466        GROUP(spi_a_miso_x5,            2),
 467        GROUP(tdm_a_din1,               2),
 468        GROUP(tdm_a_din0,               2),
 469        GROUP(tdm_a_slv_fs,             2),
 470        GROUP(tdm_a_slv_sclk,           2),
 471        GROUP(i2c3_sck_x,               2),
 472        GROUP(i2c3_sda_x,               2),
 473        GROUP(pwm_d_x13,                2),
 474        GROUP(pwm_e_x14,                2),
 475        GROUP(i2c2_sck_x15,             2),
 476        GROUP(i2c2_sda_x16,             2),
 477
 478        /*bank X func3 */
 479        GROUP(uart_c_tx_x0,             3),
 480        GROUP(uart_c_rx_x1,             3),
 481        GROUP(uart_c_cts,               3),
 482        GROUP(uart_c_rts,               3),
 483        GROUP(pdm_din0_x,               3),
 484        GROUP(pdm_din1_x,               3),
 485        GROUP(pdm_din2_x,               3),
 486        GROUP(pdm_dclk_x,               3),
 487        GROUP(uart_c_tx_x15,            3),
 488        GROUP(uart_c_rx_x16,            3),
 489
 490        /*bank X func4 */
 491        GROUP(pwm_e_x2,                 4),
 492        GROUP(pwm_f_x,                  4),
 493        GROUP(spi_a_mosi_x7,            4),
 494        GROUP(spi_a_miso_x8,            4),
 495        GROUP(spi_a_ss0_x9,             4),
 496        GROUP(spi_a_sclk_x10,           4),
 497
 498        /*bank X func5 */
 499        GROUP(uart_b_tx_x,              5),
 500        GROUP(uart_b_rx_x,              5),
 501        GROUP(i2c1_sda_x,               5),
 502        GROUP(i2c1_sck_x,               5),
 503
 504        /*bank X func6 */
 505        GROUP(pwm_a_x7,                 6),
 506        GROUP(pwm_b_x,                  6),
 507        GROUP(pwm_c_x,                  6),
 508        GROUP(pwm_d_x10,                6),
 509
 510        /*bank X func7 */
 511        GROUP(gen_clk_x,                7),
 512
 513        /*bank F func1 */
 514        GROUP(uart_b_tx_f,              1),
 515        GROUP(uart_b_rx_f,              1),
 516        GROUP(remote_input_f,           1),
 517        GROUP(jtag_a_clk,               1),
 518        GROUP(jtag_a_tms,               1),
 519        GROUP(jtag_a_tdi,               1),
 520        GROUP(jtag_a_tdo,               1),
 521        GROUP(gen_clk_f8,               1),
 522        GROUP(pwm_a_f10,                1),
 523        GROUP(i2c0_sck_f11,             1),
 524        GROUP(i2c0_sda_f12,             1),
 525
 526        /*bank F func2 */
 527        GROUP(clk_32k_in,               2),
 528        GROUP(pwm_e_f,                  2),
 529        GROUP(pwm_f_f4,                 2),
 530        GROUP(remote_out,               2),
 531        GROUP(spdif_in_f6,              2),
 532        GROUP(spdif_in_f7,              2),
 533        GROUP(pwm_a_hiz_f8,             2),
 534        GROUP(pwm_a_hiz_f10,            2),
 535        GROUP(pwm_d_f,                  2),
 536        GROUP(pwm_f_f12,                2),
 537
 538        /*bank F func3 */
 539        GROUP(pwm_c_f3,                 3),
 540        GROUP(swclk,                    3),
 541        GROUP(swdio,                    3),
 542        GROUP(pwm_a_f6,                 3),
 543        GROUP(pwm_b_f,                  3),
 544        GROUP(pwm_c_f8,                 3),
 545        GROUP(clk25,                    3),
 546        GROUP(i2c_slave_sck_f,          3),
 547        GROUP(i2c_slave_sda_f,          3),
 548
 549        /*bank F func4 */
 550        GROUP(cec_a,                    4),
 551        GROUP(i2c3_sck_f,               4),
 552        GROUP(i2c3_sda_f,               4),
 553        GROUP(pmw_a_hiz_f6,             4),
 554        GROUP(pwm_b_hiz,                4),
 555        GROUP(pwm_c_hiz,                4),
 556        GROUP(i2c0_sck_f9,              4),
 557        GROUP(i2c0_sda_f10,             4),
 558
 559        /*bank F func5 */
 560        GROUP(cec_b,                    5),
 561        GROUP(clk12_24,                 5),
 562
 563        /*bank F func7 */
 564        GROUP(gen_clk_f10,              7),
 565
 566        /*bank A func1 */
 567        GROUP(mclk_0,                   1),
 568        GROUP(tdm_b_sclk,               1),
 569        GROUP(tdm_b_fs,                 1),
 570        GROUP(tdm_b_dout0,              1),
 571        GROUP(tdm_b_dout1,              1),
 572        GROUP(tdm_b_dout2,              1),
 573        GROUP(tdm_b_dout3,              1),
 574        GROUP(tdm_b_dout4,              1),
 575        GROUP(tdm_b_dout5,              1),
 576        GROUP(remote_input_a,           1),
 577
 578        /*bank A func2 */
 579        GROUP(pwm_e_a,                  2),
 580        GROUP(tdm_b_slv_sclk,           2),
 581        GROUP(tdm_b_slv_fs,             2),
 582        GROUP(tdm_b_din0,               2),
 583        GROUP(tdm_b_din1,               2),
 584        GROUP(tdm_b_din2,               2),
 585        GROUP(i2c1_sda_a,               2),
 586        GROUP(i2c1_sck_a,               2),
 587
 588        /*bank A func3 */
 589        GROUP(i2c2_sck_a4,              3),
 590        GROUP(i2c2_sda_a5,              3),
 591        GROUP(pdm_din2_a,               3),
 592        GROUP(pdm_din1_a,               3),
 593        GROUP(pdm_din0_a,               3),
 594        GROUP(pdm_dclk,                 3),
 595        GROUP(pwm_c_a,                  3),
 596        GROUP(pwm_b_a,                  3),
 597
 598        /*bank A func4 */
 599        GROUP(pwm_a_a,                  4),
 600        GROUP(spi_a_mosi_a,             4),
 601        GROUP(spi_a_miso_a,             4),
 602        GROUP(spi_a_ss0_a,              4),
 603        GROUP(spi_a_sclk_a,             4),
 604        GROUP(i2c_slave_sck_a,          4),
 605        GROUP(i2c_slave_sda_a,          4),
 606
 607        /*bank A func5 */
 608        GROUP(mclk_vad,                 5),
 609        GROUP(tdm_vad_sclk_a1,          5),
 610        GROUP(tdm_vad_fs_a2,            5),
 611        GROUP(tdm_vad_sclk_a5,          5),
 612        GROUP(tdm_vad_fs_a6,            5),
 613        GROUP(i2c2_sck_a8,              5),
 614        GROUP(i2c2_sda_a9,              5),
 615
 616        /*bank A func6 */
 617        GROUP(tst_out0,                 6),
 618        GROUP(tst_out1,                 6),
 619        GROUP(tst_out2,                 6),
 620        GROUP(tst_out3,                 6),
 621        GROUP(tst_out4,                 6),
 622        GROUP(tst_out5,                 6),
 623        GROUP(tst_out6,                 6),
 624        GROUP(tst_out7,                 6),
 625        GROUP(tst_out8,                 6),
 626        GROUP(tst_out9,                 6),
 627        GROUP(tst_out10,                6),
 628        GROUP(tst_out11,                6),
 629
 630        /*bank A func7 */
 631        GROUP(mute_key,                 7),
 632        GROUP(mute_en,                  7),
 633        GROUP(gen_clk_a,                7),
 634};
 635
 636static const char * const gpio_periphs_groups[] = {
 637        "GPIOP_0", "GPIOP_1", "GPIOP_2", "GPIOP_3", "GPIOP_4",
 638        "GPIOP_5", "GPIOP_6", "GPIOP_7", "GPIOP_8", "GPIOP_9",
 639        "GPIOP_10", "GPIOP_11", "GPIOP_12",
 640
 641        "GPIOB_0", "GPIOB_1", "GPIOB_2", "GPIOB_3", "GPIOB_4",
 642        "GPIOB_5", "GPIOB_6",
 643
 644        "GPIOX_0", "GPIOX_1", "GPIOX_2", "GPIOX_3", "GPIOX_4",
 645        "GPIOX_5", "GPIOX_6", "GPIOX_7", "GPIOX_8", "GPIOX_9",
 646        "GPIOX_10", "GPIOX_11", "GPIOX_12", "GPIOX_13", "GPIOX_14",
 647        "GPIOX_15", "GPIOX_16",
 648
 649        "GPIOF_0", "GPIOF_1", "GPIOF_2", "GPIOF_3", "GPIOF_4",
 650        "GPIOF_5", "GPIOF_6", "GPIOF_7", "GPIOF_8", "GPIOF_9",
 651        "GPIOF_10", "GPIOF_11", "GPIOF_12",
 652
 653        "GPIOA_0", "GPIOA_1", "GPIOA_2", "GPIOA_3", "GPIOA_4",
 654        "GPIOA_5", "GPIOA_6", "GPIOA_7", "GPIOA_8", "GPIOA_9",
 655        "GPIOA_10", "GPIOA_11",
 656};
 657
 658static const char * const psram_groups[] = {
 659        "psram_clkn", "psram_clkp", "psram_ce_n", "psram_rst_n", "psram_adq0",
 660        "psram_adq1", "psram_adq2", "psram_adq3", "psram_adq4", "psram_adq5",
 661        "psram_adq6", "psram_adq7", "psram_dqs_dm",
 662};
 663
 664static const char * const pwm_a_groups[] = {
 665        "pwm_a_x6", "pwm_a_x7", "pwm_a_f10", "pwm_a_f6", "pwm_a_a",
 666};
 667
 668static const char * const pwm_b_groups[] = {
 669        "pwm_b_x", "pwm_b_f", "pwm_b_a",
 670};
 671
 672static const char * const pwm_c_groups[] = {
 673        "pwm_c_x", "pwm_c_f3", "pwm_c_f8", "pwm_c_a",
 674};
 675
 676static const char * const pwm_d_groups[] = {
 677        "pwm_d_x15", "pwm_d_x13", "pwm_d_x10", "pwm_d_f",
 678};
 679
 680static const char * const pwm_e_groups[] = {
 681        "pwm_e_p", "pwm_e_x16", "pwm_e_x14", "pwm_e_x2", "pwm_e_f",
 682        "pwm_e_a",
 683};
 684
 685static const char * const pwm_f_groups[] = {
 686        "pwm_f_b", "pwm_f_x", "pwm_f_f4", "pwm_f_f12",
 687};
 688
 689static const char * const pwm_a_hiz_groups[] = {
 690        "pwm_a_hiz_f8", "pwm_a_hiz_f10", "pwm_a_hiz_f6",
 691};
 692
 693static const char * const pwm_b_hiz_groups[] = {
 694        "pwm_b_hiz",
 695};
 696
 697static const char * const pwm_c_hiz_groups[] = {
 698        "pwm_c_hiz",
 699};
 700
 701static const char * const spif_groups[] = {
 702        "spif_mo", "spif_mi", "spif_wp_n", "spif_hold_n", "spif_clk",
 703        "spif_cs",
 704};
 705
 706static const char * const sdcard_groups[] = {
 707        "sdcard_d0_b", "sdcard_d1_b", "sdcard_d2_b", "sdcard_d3_b",
 708        "sdcard_clk_b", "sdcard_cmd_b",
 709
 710        "sdcard_d0_x", "sdcard_d1_x", "sdcard_d2_x", "sdcard_d3_x",
 711        "sdcard_clk_x", "sdcard_cmd_x",
 712};
 713
 714static const char * const tdm_a_groups[] = {
 715        "tdm_a_din0", "tdm_a_din1",  "tdm_a_fs", "tdm_a_sclk",
 716        "tdm_a_slv_fs", "tdm_a_slv_sclk", "tdm_a_dout0", "tdm_a_dout1",
 717};
 718
 719static const char * const uart_a_groups[] = {
 720        "uart_a_tx", "uart_a_rx", "uart_a_cts", "uart_a_rts",
 721};
 722
 723static const char * const uart_b_groups[] = {
 724        "uart_b_tx_x", "uart_b_rx_x", "uart_b_tx_f", "uart_b_rx_f",
 725};
 726
 727static const char * const uart_c_groups[] = {
 728        "uart_c_tx_x0", "uart_c_rx_x1", "uart_c_cts", "uart_c_rts",
 729        "uart_c_tx_x15", "uart_c_rx_x16",
 730};
 731
 732static const char * const i2c0_groups[] = {
 733        "i2c0_sck_f11", "i2c0_sda_f12", "i2c0_sck_f9", "i2c0_sda_f10",
 734};
 735
 736static const char * const i2c1_groups[] = {
 737        "i2c1_sda_x", "i2c1_sck_x", "i2c1_sda_a", "i2c1_sck_a",
 738};
 739
 740static const char * const i2c2_groups[] = {
 741        "i2c2_sck_x0", "i2c2_sda_x1", "i2c2_sck_x15", "i2c2_sda_x16",
 742        "i2c2_sck_a4", "i2c2_sda_a5", "i2c2_sck_a8", "i2c2_sda_a9",
 743};
 744
 745static const char * const i2c3_groups[] = {
 746        "i2c3_sck_x", "i2c3_sda_x", "i2c3_sck_f", "i2c3_sda_f",
 747};
 748
 749static const char * const i2c_slave_groups[] = {
 750        "i2c_slave_sda_a", "i2c_slave_sck_a",
 751        "i2c_slave_sda_f", "i2c_slave_sck_f",
 752};
 753
 754static const char * const spi_a_groups[] = {
 755        "spi_a_mosi_x2", "spi_a_ss0_x3", "spi_a_sclk_x4", "spi_a_miso_x5",
 756        "spi_a_mosi_x7", "spi_a_miso_x8", "spi_a_ss0_x9", "spi_a_sclk_x10",
 757
 758        "spi_a_mosi_a", "spi_a_miso_a", "spi_a_ss0_a", "spi_a_sclk_a",
 759};
 760
 761static const char * const pdm_groups[] = {
 762        "pdm_din0_x", "pdm_din1_x", "pdm_din2_x", "pdm_dclk_x", "pdm_din2_a",
 763        "pdm_din1_a", "pdm_din0_a", "pdm_dclk",
 764};
 765
 766static const char * const gen_clk_groups[] = {
 767        "gen_clk_x", "gen_clk_f8", "gen_clk_f10", "gen_clk_a",
 768};
 769
 770static const char * const remote_input_groups[] = {
 771        "remote_input_f",
 772        "remote_input_a",
 773};
 774
 775static const char * const jtag_a_groups[] = {
 776        "jtag_a_clk", "jtag_a_tms", "jtag_a_tdi", "jtag_a_tdo",
 777};
 778
 779static const char * const clk_32k_in_groups[] = {
 780        "clk_32k_in",
 781};
 782
 783static const char * const remote_out_groups[] = {
 784        "remote_out",
 785};
 786
 787static const char * const spdif_in_groups[] = {
 788        "spdif_in_f6", "spdif_in_f7",
 789};
 790
 791static const char * const sw_groups[] = {
 792        "swclk", "swdio",
 793};
 794
 795static const char * const clk25_groups[] = {
 796        "clk_25",
 797};
 798
 799static const char * const cec_a_groups[] = {
 800        "cec_a",
 801};
 802
 803static const char * const cec_b_groups[] = {
 804        "cec_b",
 805};
 806
 807static const char * const clk12_24_groups[] = {
 808        "clk12_24",
 809};
 810
 811static const char * const mclk_0_groups[] = {
 812        "mclk_0",
 813};
 814
 815static const char * const tdm_b_groups[] = {
 816        "tdm_b_din0", "tdm_b_din1", "tdm_b_din2",
 817        "tdm_b_sclk", "tdm_b_fs", "tdm_b_dout0", "tdm_b_dout1",
 818        "tdm_b_dout2", "tdm_b_dout3", "tdm_b_dout4", "tdm_b_dout5",
 819        "tdm_b_slv_sclk", "tdm_b_slv_fs",
 820};
 821
 822static const char * const mclk_vad_groups[] = {
 823        "mclk_vad",
 824};
 825
 826static const char * const tdm_vad_groups[] = {
 827        "tdm_vad_sclk_a1", "tdm_vad_fs_a2", "tdm_vad_sclk_a5", "tdm_vad_fs_a6",
 828};
 829
 830static const char * const tst_out_groups[] = {
 831        "tst_out0", "tst_out1", "tst_out2", "tst_out3",
 832        "tst_out4", "tst_out5", "tst_out6", "tst_out7",
 833        "tst_out8", "tst_out9", "tst_out10", "tst_out11",
 834};
 835
 836static const char * const mute_groups[] = {
 837        "mute_key", "mute_en",
 838};
 839
 840static struct meson_pmx_func meson_a1_periphs_functions[] = {
 841        FUNCTION(gpio_periphs),
 842        FUNCTION(psram),
 843        FUNCTION(pwm_a),
 844        FUNCTION(pwm_b),
 845        FUNCTION(pwm_c),
 846        FUNCTION(pwm_d),
 847        FUNCTION(pwm_e),
 848        FUNCTION(pwm_f),
 849        FUNCTION(pwm_a_hiz),
 850        FUNCTION(pwm_b_hiz),
 851        FUNCTION(pwm_c_hiz),
 852        FUNCTION(spif),
 853        FUNCTION(sdcard),
 854        FUNCTION(tdm_a),
 855        FUNCTION(uart_a),
 856        FUNCTION(uart_b),
 857        FUNCTION(uart_c),
 858        FUNCTION(i2c0),
 859        FUNCTION(i2c1),
 860        FUNCTION(i2c2),
 861        FUNCTION(i2c3),
 862        FUNCTION(spi_a),
 863        FUNCTION(pdm),
 864        FUNCTION(gen_clk),
 865        FUNCTION(remote_input),
 866        FUNCTION(jtag_a),
 867        FUNCTION(clk_32k_in),
 868        FUNCTION(remote_out),
 869        FUNCTION(spdif_in),
 870        FUNCTION(sw),
 871        FUNCTION(clk25),
 872        FUNCTION(cec_a),
 873        FUNCTION(cec_b),
 874        FUNCTION(clk12_24),
 875        FUNCTION(mclk_0),
 876        FUNCTION(tdm_b),
 877        FUNCTION(mclk_vad),
 878        FUNCTION(tdm_vad),
 879        FUNCTION(tst_out),
 880        FUNCTION(mute),
 881};
 882
 883static struct meson_bank meson_a1_periphs_banks[] = {
 884        /* name  first  last  irq  pullen  pull  dir  out  in  ds*/
 885        BANK_DS("P",  GPIOP_0,  GPIOP_12,  0,  12, 0x3,  0,  0x4,  0,
 886                0x2,  0,  0x1,  0,  0x0,  0,  0x5,  0),
 887        BANK_DS("B",  GPIOB_0,    GPIOB_6,   13,  19,  0x13,  0,  0x14,  0,
 888                0x12,  0,  0x11,  0,  0x10,  0,  0x15,  0),
 889        BANK_DS("X",  GPIOX_0,    GPIOX_16,  20,  36,  0x23,  0,  0x24,  0,
 890                0x22,  0,  0x21,  0,  0x20,  0,  0x25,  0),
 891        BANK_DS("F",  GPIOF_0,    GPIOF_12,  37,  49,  0x33,  0,  0x34,  0,
 892                0x32,  0,  0x31,  0,  0x30,  0,  0x35,  0),
 893        BANK_DS("A",  GPIOA_0,    GPIOA_11,  50,  61,  0x43,  0,  0x44,  0,
 894                0x42,  0,  0x41,  0,  0x40,  0,  0x45,  0),
 895};
 896
 897static struct meson_pmx_bank meson_a1_periphs_pmx_banks[] = {
 898        /*  name         first      lask    reg offset  */
 899        BANK_PMX("P",    GPIOP_0, GPIOP_12, 0x0, 0),
 900        BANK_PMX("B",    GPIOB_0, GPIOB_6,  0x2, 0),
 901        BANK_PMX("X",    GPIOX_0, GPIOX_16, 0x3, 0),
 902        BANK_PMX("F",    GPIOF_0, GPIOF_12, 0x6, 0),
 903        BANK_PMX("A",    GPIOA_0, GPIOA_11, 0x8, 0),
 904};
 905
 906static struct meson_axg_pmx_data meson_a1_periphs_pmx_banks_data = {
 907        .pmx_banks      = meson_a1_periphs_pmx_banks,
 908        .num_pmx_banks  = ARRAY_SIZE(meson_a1_periphs_pmx_banks),
 909};
 910
 911static struct meson_pinctrl_data meson_a1_periphs_pinctrl_data = {
 912        .name           = "periphs-banks",
 913        .pins           = meson_a1_periphs_pins,
 914        .groups         = meson_a1_periphs_groups,
 915        .funcs          = meson_a1_periphs_functions,
 916        .banks          = meson_a1_periphs_banks,
 917        .num_pins       = ARRAY_SIZE(meson_a1_periphs_pins),
 918        .num_groups     = ARRAY_SIZE(meson_a1_periphs_groups),
 919        .num_funcs      = ARRAY_SIZE(meson_a1_periphs_functions),
 920        .num_banks      = ARRAY_SIZE(meson_a1_periphs_banks),
 921        .pmx_ops        = &meson_axg_pmx_ops,
 922        .pmx_data       = &meson_a1_periphs_pmx_banks_data,
 923        .parse_dt       = &meson_a1_parse_dt_extra,
 924};
 925
 926static const struct of_device_id meson_a1_pinctrl_dt_match[] = {
 927        {
 928                .compatible = "amlogic,meson-a1-periphs-pinctrl",
 929                .data = &meson_a1_periphs_pinctrl_data,
 930        },
 931        { },
 932};
 933
 934static struct platform_driver meson_a1_pinctrl_driver = {
 935        .probe  = meson_pinctrl_probe,
 936        .driver = {
 937                .name   = "meson-a1-pinctrl",
 938                .of_match_table = meson_a1_pinctrl_dt_match,
 939        },
 940};
 941
 942builtin_platform_driver(meson_a1_pinctrl_driver);
 943