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