xref: /OK3568_Linux_fs/kernel/drivers/pinctrl/mediatek/pinctrl-mt7623.c (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun // SPDX-License-Identifier: GPL-2.0
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun  * The MT7623 driver based on Linux generic pinctrl binding.
4*4882a593Smuzhiyun  *
5*4882a593Smuzhiyun  * Copyright (C) 2015 - 2018 MediaTek Inc.
6*4882a593Smuzhiyun  * Author: Biao Huang <biao.huang@mediatek.com>
7*4882a593Smuzhiyun  *	   Ryder Lee <ryder.lee@mediatek.com>
8*4882a593Smuzhiyun  *	   Sean Wang <sean.wang@mediatek.com>
9*4882a593Smuzhiyun  */
10*4882a593Smuzhiyun 
11*4882a593Smuzhiyun #include "pinctrl-moore.h"
12*4882a593Smuzhiyun 
13*4882a593Smuzhiyun #define PIN_BOND_REG0		0xb10
14*4882a593Smuzhiyun #define PIN_BOND_REG1		0xf20
15*4882a593Smuzhiyun #define PIN_BOND_REG2		0xef0
16*4882a593Smuzhiyun #define BOND_PCIE_CLR		(0x77 << 3)
17*4882a593Smuzhiyun #define BOND_I2S_CLR		0x3
18*4882a593Smuzhiyun #define BOND_MSDC0E_CLR		0x1
19*4882a593Smuzhiyun 
20*4882a593Smuzhiyun #define PIN_FIELD15(_s_pin, _e_pin, _s_addr, _x_addrs, _s_bit, _x_bits)	\
21*4882a593Smuzhiyun 	PIN_FIELD_CALC(_s_pin, _e_pin, 0, _s_addr, _x_addrs, _s_bit,	\
22*4882a593Smuzhiyun 		       _x_bits, 15, false)
23*4882a593Smuzhiyun 
24*4882a593Smuzhiyun #define PIN_FIELD16(_s_pin, _e_pin, _s_addr, _x_addrs, _s_bit, _x_bits)	\
25*4882a593Smuzhiyun 	PIN_FIELD_CALC(_s_pin, _e_pin, 0, _s_addr, _x_addrs, _s_bit,	\
26*4882a593Smuzhiyun 		       _x_bits, 16, 0)
27*4882a593Smuzhiyun 
28*4882a593Smuzhiyun #define PINS_FIELD16(_s_pin, _e_pin, _s_addr, _x_addrs, _s_bit, _x_bits)	\
29*4882a593Smuzhiyun 	PIN_FIELD_CALC(_s_pin, _e_pin, 0, _s_addr, _x_addrs, _s_bit,	\
30*4882a593Smuzhiyun 		       _x_bits, 16, 1)
31*4882a593Smuzhiyun 
32*4882a593Smuzhiyun #define MT7623_PIN(_number, _name, _eint_n, _drv_grp)			\
33*4882a593Smuzhiyun 	MTK_PIN(_number, _name, 0, _eint_n, _drv_grp)
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun static const struct mtk_pin_field_calc mt7623_pin_mode_range[] = {
36*4882a593Smuzhiyun 	PIN_FIELD15(0, 278, 0x760, 0x10, 0, 3),
37*4882a593Smuzhiyun };
38*4882a593Smuzhiyun 
39*4882a593Smuzhiyun static const struct mtk_pin_field_calc mt7623_pin_dir_range[] = {
40*4882a593Smuzhiyun 	PIN_FIELD16(0, 175, 0x0, 0x10, 0, 1),
41*4882a593Smuzhiyun 	PIN_FIELD16(176, 278, 0xc0, 0x10, 0, 1),
42*4882a593Smuzhiyun };
43*4882a593Smuzhiyun 
44*4882a593Smuzhiyun static const struct mtk_pin_field_calc mt7623_pin_di_range[] = {
45*4882a593Smuzhiyun 	PIN_FIELD16(0, 278, 0x630, 0x10, 0, 1),
46*4882a593Smuzhiyun };
47*4882a593Smuzhiyun 
48*4882a593Smuzhiyun static const struct mtk_pin_field_calc mt7623_pin_do_range[] = {
49*4882a593Smuzhiyun 	PIN_FIELD16(0, 278, 0x500, 0x10, 0, 1),
50*4882a593Smuzhiyun };
51*4882a593Smuzhiyun 
52*4882a593Smuzhiyun static const struct mtk_pin_field_calc mt7623_pin_ies_range[] = {
53*4882a593Smuzhiyun 	PINS_FIELD16(0, 6, 0xb20, 0x10, 0, 1),
54*4882a593Smuzhiyun 	PINS_FIELD16(7, 9, 0xb20, 0x10, 1, 1),
55*4882a593Smuzhiyun 	PINS_FIELD16(10, 13, 0xb30, 0x10, 3, 1),
56*4882a593Smuzhiyun 	PINS_FIELD16(14, 15, 0xb30, 0x10, 13, 1),
57*4882a593Smuzhiyun 	PINS_FIELD16(16, 17, 0xb40, 0x10, 7, 1),
58*4882a593Smuzhiyun 	PINS_FIELD16(18, 29, 0xb40, 0x10, 13, 1),
59*4882a593Smuzhiyun 	PINS_FIELD16(30, 32, 0xb40, 0x10, 7, 1),
60*4882a593Smuzhiyun 	PINS_FIELD16(33, 37, 0xb40, 0x10, 13, 1),
61*4882a593Smuzhiyun 	PIN_FIELD16(38, 38, 0xb20, 0x10, 13, 1),
62*4882a593Smuzhiyun 	PINS_FIELD16(39, 42, 0xb40, 0x10, 13, 1),
63*4882a593Smuzhiyun 	PINS_FIELD16(43, 45, 0xb20, 0x10, 10, 1),
64*4882a593Smuzhiyun 	PINS_FIELD16(47, 48, 0xb20, 0x10, 11, 1),
65*4882a593Smuzhiyun 	PIN_FIELD16(49, 49, 0xb20, 0x10, 12, 1),
66*4882a593Smuzhiyun 	PINS_FIELD16(50, 52, 0xb20, 0x10, 13, 1),
67*4882a593Smuzhiyun 	PINS_FIELD16(53, 56, 0xb20, 0x10, 14, 1),
68*4882a593Smuzhiyun 	PINS_FIELD16(57, 58, 0xb20, 0x10, 15, 1),
69*4882a593Smuzhiyun 	PIN_FIELD16(59, 59, 0xb30, 0x10, 10, 1),
70*4882a593Smuzhiyun 	PINS_FIELD16(60, 62, 0xb30, 0x10, 0, 1),
71*4882a593Smuzhiyun 	PINS_FIELD16(63, 65, 0xb30, 0x10, 1, 1),
72*4882a593Smuzhiyun 	PINS_FIELD16(66, 71, 0xb30, 0x10, 2, 1),
73*4882a593Smuzhiyun 	PINS_FIELD16(72, 74, 0xb20, 0x10, 12, 1),
74*4882a593Smuzhiyun 	PINS_FIELD16(75, 76, 0xb30, 0x10, 3, 1),
75*4882a593Smuzhiyun 	PINS_FIELD16(77, 78, 0xb30, 0x10, 4, 1),
76*4882a593Smuzhiyun 	PINS_FIELD16(79, 82, 0xb30, 0x10, 5, 1),
77*4882a593Smuzhiyun 	PINS_FIELD16(83, 84, 0xb30, 0x10, 2, 1),
78*4882a593Smuzhiyun 	PIN_FIELD16(85, 85, 0xda0, 0x10, 4, 1),
79*4882a593Smuzhiyun 	PIN_FIELD16(86, 86, 0xd90, 0x10, 4, 1),
80*4882a593Smuzhiyun 	PINS_FIELD16(87, 90, 0xdb0, 0x10, 4, 1),
81*4882a593Smuzhiyun 	PINS_FIELD16(101, 104, 0xb30, 0x10, 6, 1),
82*4882a593Smuzhiyun 	PIN_FIELD16(105, 105, 0xd40, 0x10, 4, 1),
83*4882a593Smuzhiyun 	PIN_FIELD16(106, 106, 0xd30, 0x10, 4, 1),
84*4882a593Smuzhiyun 	PINS_FIELD16(107, 110, 0xd50, 0x10, 4, 1),
85*4882a593Smuzhiyun 	PINS_FIELD16(111, 115, 0xce0, 0x10, 4, 1),
86*4882a593Smuzhiyun 	PIN_FIELD16(116, 116, 0xcd0, 0x10, 4, 1),
87*4882a593Smuzhiyun 	PIN_FIELD16(117, 117, 0xcc0, 0x10, 4, 1),
88*4882a593Smuzhiyun 	PINS_FIELD16(118, 121, 0xce0, 0x10, 4, 1),
89*4882a593Smuzhiyun 	PINS_FIELD16(122, 125, 0xb30, 0x10, 7, 1),
90*4882a593Smuzhiyun 	PIN_FIELD16(126, 126, 0xb20, 0x10, 12, 1),
91*4882a593Smuzhiyun 	PINS_FIELD16(127, 142, 0xb30, 0x10, 9, 1),
92*4882a593Smuzhiyun 	PINS_FIELD16(143, 160, 0xb30, 0x10, 10, 1),
93*4882a593Smuzhiyun 	PINS_FIELD16(161, 168, 0xb30, 0x10, 12, 1),
94*4882a593Smuzhiyun 	PINS_FIELD16(169, 183, 0xb30, 0x10, 10, 1),
95*4882a593Smuzhiyun 	PINS_FIELD16(184, 186, 0xb30, 0x10, 9, 1),
96*4882a593Smuzhiyun 	PIN_FIELD16(187, 187, 0xb30, 0x10, 14, 1),
97*4882a593Smuzhiyun 	PIN_FIELD16(188, 188, 0xb20, 0x10, 13, 1),
98*4882a593Smuzhiyun 	PINS_FIELD16(189, 193, 0xb30, 0x10, 15, 1),
99*4882a593Smuzhiyun 	PINS_FIELD16(194, 198, 0xb40, 0x10, 0, 1),
100*4882a593Smuzhiyun 	PIN_FIELD16(199, 199, 0xb20, 0x10, 1, 1),
101*4882a593Smuzhiyun 	PINS_FIELD16(200, 202, 0xb40, 0x10, 1, 1),
102*4882a593Smuzhiyun 	PINS_FIELD16(203, 207, 0xb40, 0x10, 2, 1),
103*4882a593Smuzhiyun 	PINS_FIELD16(208, 209, 0xb40, 0x10, 3, 1),
104*4882a593Smuzhiyun 	PIN_FIELD16(210, 210, 0xb40, 0x10, 4, 1),
105*4882a593Smuzhiyun 	PINS_FIELD16(211, 235, 0xb40, 0x10, 5, 1),
106*4882a593Smuzhiyun 	PINS_FIELD16(236, 241, 0xb40, 0x10, 6, 1),
107*4882a593Smuzhiyun 	PINS_FIELD16(242, 243, 0xb40, 0x10, 7, 1),
108*4882a593Smuzhiyun 	PINS_FIELD16(244, 247, 0xb40, 0x10, 8, 1),
109*4882a593Smuzhiyun 	PIN_FIELD16(248, 248, 0xb40, 0x10, 9, 1),
110*4882a593Smuzhiyun 	PINS_FIELD16(249, 257, 0xfc0, 0x10, 4, 1),
111*4882a593Smuzhiyun 	PIN_FIELD16(258, 258, 0xcb0, 0x10, 4, 1),
112*4882a593Smuzhiyun 	PIN_FIELD16(259, 259, 0xc90, 0x10, 4, 1),
113*4882a593Smuzhiyun 	PIN_FIELD16(260, 260, 0x3a0, 0x10, 4, 1),
114*4882a593Smuzhiyun 	PIN_FIELD16(261, 261, 0xd50, 0x10, 4, 1),
115*4882a593Smuzhiyun 	PINS_FIELD16(262, 277, 0xb40, 0x10, 12, 1),
116*4882a593Smuzhiyun 	PIN_FIELD16(278, 278, 0xb40, 0x10, 13, 1),
117*4882a593Smuzhiyun };
118*4882a593Smuzhiyun 
119*4882a593Smuzhiyun static const struct mtk_pin_field_calc mt7623_pin_smt_range[] = {
120*4882a593Smuzhiyun 	PINS_FIELD16(0, 6, 0xb50, 0x10, 0, 1),
121*4882a593Smuzhiyun 	PINS_FIELD16(7, 9, 0xb50, 0x10, 1, 1),
122*4882a593Smuzhiyun 	PINS_FIELD16(10, 13, 0xb60, 0x10, 3, 1),
123*4882a593Smuzhiyun 	PINS_FIELD16(14, 15, 0xb60, 0x10, 13, 1),
124*4882a593Smuzhiyun 	PINS_FIELD16(16, 17, 0xb70, 0x10, 7, 1),
125*4882a593Smuzhiyun 	PINS_FIELD16(18, 29, 0xb70, 0x10, 13, 1),
126*4882a593Smuzhiyun 	PINS_FIELD16(30, 32, 0xb70, 0x10, 7, 1),
127*4882a593Smuzhiyun 	PINS_FIELD16(33, 37, 0xb70, 0x10, 13, 1),
128*4882a593Smuzhiyun 	PIN_FIELD16(38, 38, 0xb50, 0x10, 13, 1),
129*4882a593Smuzhiyun 	PINS_FIELD16(39, 42, 0xb70, 0x10, 13, 1),
130*4882a593Smuzhiyun 	PINS_FIELD16(43, 45, 0xb50, 0x10, 10, 1),
131*4882a593Smuzhiyun 	PINS_FIELD16(47, 48, 0xb50, 0x10, 11, 1),
132*4882a593Smuzhiyun 	PIN_FIELD16(49, 49, 0xb50, 0x10, 12, 1),
133*4882a593Smuzhiyun 	PINS_FIELD16(50, 52, 0xb50, 0x10, 13, 1),
134*4882a593Smuzhiyun 	PINS_FIELD16(53, 56, 0xb50, 0x10, 14, 1),
135*4882a593Smuzhiyun 	PINS_FIELD16(57, 58, 0xb50, 0x10, 15, 1),
136*4882a593Smuzhiyun 	PIN_FIELD16(59, 59, 0xb60, 0x10, 10, 1),
137*4882a593Smuzhiyun 	PINS_FIELD16(60, 62, 0xb60, 0x10, 0, 1),
138*4882a593Smuzhiyun 	PINS_FIELD16(63, 65, 0xb60, 0x10, 1, 1),
139*4882a593Smuzhiyun 	PINS_FIELD16(66, 71, 0xb60, 0x10, 2, 1),
140*4882a593Smuzhiyun 	PINS_FIELD16(72, 74, 0xb50, 0x10, 12, 1),
141*4882a593Smuzhiyun 	PINS_FIELD16(75, 76, 0xb60, 0x10, 3, 1),
142*4882a593Smuzhiyun 	PINS_FIELD16(77, 78, 0xb60, 0x10, 4, 1),
143*4882a593Smuzhiyun 	PINS_FIELD16(79, 82, 0xb60, 0x10, 5, 1),
144*4882a593Smuzhiyun 	PINS_FIELD16(83, 84, 0xb60, 0x10, 2, 1),
145*4882a593Smuzhiyun 	PIN_FIELD16(85, 85, 0xda0, 0x10, 11, 1),
146*4882a593Smuzhiyun 	PIN_FIELD16(86, 86, 0xd90, 0x10, 11, 1),
147*4882a593Smuzhiyun 	PIN_FIELD16(87, 87, 0xdc0, 0x10, 3, 1),
148*4882a593Smuzhiyun 	PIN_FIELD16(88, 88, 0xdc0, 0x10, 7, 1),
149*4882a593Smuzhiyun 	PIN_FIELD16(89, 89, 0xdc0, 0x10, 11, 1),
150*4882a593Smuzhiyun 	PIN_FIELD16(90, 90, 0xdc0, 0x10, 15, 1),
151*4882a593Smuzhiyun 	PINS_FIELD16(101, 104, 0xb60, 0x10, 6, 1),
152*4882a593Smuzhiyun 	PIN_FIELD16(105, 105, 0xd40, 0x10, 11, 1),
153*4882a593Smuzhiyun 	PIN_FIELD16(106, 106, 0xd30, 0x10, 11, 1),
154*4882a593Smuzhiyun 	PIN_FIELD16(107, 107, 0xd60, 0x10, 3, 1),
155*4882a593Smuzhiyun 	PIN_FIELD16(108, 108, 0xd60, 0x10, 7, 1),
156*4882a593Smuzhiyun 	PIN_FIELD16(109, 109, 0xd60, 0x10, 11, 1),
157*4882a593Smuzhiyun 	PIN_FIELD16(110, 110, 0xd60, 0x10, 15, 1),
158*4882a593Smuzhiyun 	PIN_FIELD16(111, 111, 0xd00, 0x10, 15, 1),
159*4882a593Smuzhiyun 	PIN_FIELD16(112, 112, 0xd00, 0x10, 11, 1),
160*4882a593Smuzhiyun 	PIN_FIELD16(113, 113, 0xd00, 0x10, 7, 1),
161*4882a593Smuzhiyun 	PIN_FIELD16(114, 114, 0xd00, 0x10, 3, 1),
162*4882a593Smuzhiyun 	PIN_FIELD16(115, 115, 0xd10, 0x10, 3, 1),
163*4882a593Smuzhiyun 	PIN_FIELD16(116, 116, 0xcd0, 0x10, 11, 1),
164*4882a593Smuzhiyun 	PIN_FIELD16(117, 117, 0xcc0, 0x10, 11, 1),
165*4882a593Smuzhiyun 	PIN_FIELD16(118, 118, 0xcf0, 0x10, 15, 1),
166*4882a593Smuzhiyun 	PIN_FIELD16(119, 119, 0xcf0, 0x10, 7, 1),
167*4882a593Smuzhiyun 	PIN_FIELD16(120, 120, 0xcf0, 0x10, 3, 1),
168*4882a593Smuzhiyun 	PIN_FIELD16(121, 121, 0xcf0, 0x10, 7, 1),
169*4882a593Smuzhiyun 	PINS_FIELD16(122, 125, 0xb60, 0x10, 7, 1),
170*4882a593Smuzhiyun 	PIN_FIELD16(126, 126, 0xb50, 0x10, 12, 1),
171*4882a593Smuzhiyun 	PINS_FIELD16(127, 142, 0xb60, 0x10, 9, 1),
172*4882a593Smuzhiyun 	PINS_FIELD16(143, 160, 0xb60, 0x10, 10, 1),
173*4882a593Smuzhiyun 	PINS_FIELD16(161, 168, 0xb60, 0x10, 12, 1),
174*4882a593Smuzhiyun 	PINS_FIELD16(169, 183, 0xb60, 0x10, 10, 1),
175*4882a593Smuzhiyun 	PINS_FIELD16(184, 186, 0xb60, 0x10, 9, 1),
176*4882a593Smuzhiyun 	PIN_FIELD16(187, 187, 0xb60, 0x10, 14, 1),
177*4882a593Smuzhiyun 	PIN_FIELD16(188, 188, 0xb50, 0x10, 13, 1),
178*4882a593Smuzhiyun 	PINS_FIELD16(189, 193, 0xb60, 0x10, 15, 1),
179*4882a593Smuzhiyun 	PINS_FIELD16(194, 198, 0xb70, 0x10, 0, 1),
180*4882a593Smuzhiyun 	PIN_FIELD16(199, 199, 0xb50, 0x10, 1, 1),
181*4882a593Smuzhiyun 	PINS_FIELD16(200, 202, 0xb70, 0x10, 1, 1),
182*4882a593Smuzhiyun 	PINS_FIELD16(203, 207, 0xb70, 0x10, 2, 1),
183*4882a593Smuzhiyun 	PINS_FIELD16(208, 209, 0xb70, 0x10, 3, 1),
184*4882a593Smuzhiyun 	PIN_FIELD16(210, 210, 0xb70, 0x10, 4, 1),
185*4882a593Smuzhiyun 	PINS_FIELD16(211, 235, 0xb70, 0x10, 5, 1),
186*4882a593Smuzhiyun 	PINS_FIELD16(236, 241, 0xb70, 0x10, 6, 1),
187*4882a593Smuzhiyun 	PINS_FIELD16(242, 243, 0xb70, 0x10, 7, 1),
188*4882a593Smuzhiyun 	PINS_FIELD16(244, 247, 0xb70, 0x10, 8, 1),
189*4882a593Smuzhiyun 	PIN_FIELD16(248, 248, 0xb70, 0x10, 9, 10),
190*4882a593Smuzhiyun 	PIN_FIELD16(249, 249, 0x140, 0x10, 3, 1),
191*4882a593Smuzhiyun 	PIN_FIELD16(250, 250, 0x130, 0x10, 15, 1),
192*4882a593Smuzhiyun 	PIN_FIELD16(251, 251, 0x130, 0x10, 11, 1),
193*4882a593Smuzhiyun 	PIN_FIELD16(252, 252, 0x130, 0x10, 7, 1),
194*4882a593Smuzhiyun 	PIN_FIELD16(253, 253, 0x130, 0x10, 3, 1),
195*4882a593Smuzhiyun 	PIN_FIELD16(254, 254, 0xf40, 0x10, 15, 1),
196*4882a593Smuzhiyun 	PIN_FIELD16(255, 255, 0xf40, 0x10, 11, 1),
197*4882a593Smuzhiyun 	PIN_FIELD16(256, 256, 0xf40, 0x10, 7, 1),
198*4882a593Smuzhiyun 	PIN_FIELD16(257, 257, 0xf40, 0x10, 3, 1),
199*4882a593Smuzhiyun 	PIN_FIELD16(258, 258, 0xcb0, 0x10, 11, 1),
200*4882a593Smuzhiyun 	PIN_FIELD16(259, 259, 0xc90, 0x10, 11, 1),
201*4882a593Smuzhiyun 	PIN_FIELD16(260, 260, 0x3a0, 0x10, 11, 1),
202*4882a593Smuzhiyun 	PIN_FIELD16(261, 261, 0x0b0, 0x10, 3, 1),
203*4882a593Smuzhiyun 	PINS_FIELD16(262, 277, 0xb70, 0x10, 12, 1),
204*4882a593Smuzhiyun 	PIN_FIELD16(278, 278, 0xb70, 0x10, 13, 1),
205*4882a593Smuzhiyun };
206*4882a593Smuzhiyun 
207*4882a593Smuzhiyun static const struct mtk_pin_field_calc mt7623_pin_pullen_range[] = {
208*4882a593Smuzhiyun 	PIN_FIELD16(0, 278, 0x150, 0x10, 0, 1),
209*4882a593Smuzhiyun };
210*4882a593Smuzhiyun 
211*4882a593Smuzhiyun static const struct mtk_pin_field_calc mt7623_pin_pullsel_range[] = {
212*4882a593Smuzhiyun 	PIN_FIELD16(0, 278, 0x280, 0x10, 0, 1),
213*4882a593Smuzhiyun };
214*4882a593Smuzhiyun 
215*4882a593Smuzhiyun static const struct mtk_pin_field_calc mt7623_pin_drv_range[] = {
216*4882a593Smuzhiyun 	PINS_FIELD16(0, 6, 0xf50, 0x10, 0, 4),
217*4882a593Smuzhiyun 	PINS_FIELD16(7, 9, 0xf50, 0x10, 4, 4),
218*4882a593Smuzhiyun 	PINS_FIELD16(10, 13, 0xf50, 0x10, 4, 4),
219*4882a593Smuzhiyun 	PINS_FIELD16(14, 15, 0xf50, 0x10, 12, 4),
220*4882a593Smuzhiyun 	PINS_FIELD16(16, 17, 0xf60, 0x10, 0, 4),
221*4882a593Smuzhiyun 	PINS_FIELD16(18, 21, 0xf60, 0x10, 0, 4),
222*4882a593Smuzhiyun 	PINS_FIELD16(22, 26, 0xf60, 0x10, 8, 4),
223*4882a593Smuzhiyun 	PINS_FIELD16(27, 29, 0xf60, 0x10, 12, 4),
224*4882a593Smuzhiyun 	PINS_FIELD16(30, 32, 0xf60, 0x10, 0, 4),
225*4882a593Smuzhiyun 	PINS_FIELD16(33, 37, 0xf70, 0x10, 0, 4),
226*4882a593Smuzhiyun 	PIN_FIELD16(38, 38, 0xf70, 0x10, 4, 4),
227*4882a593Smuzhiyun 	PINS_FIELD16(39, 42, 0xf70, 0x10, 8, 4),
228*4882a593Smuzhiyun 	PINS_FIELD16(43, 45, 0xf70, 0x10, 12, 4),
229*4882a593Smuzhiyun 	PINS_FIELD16(47, 48, 0xf80, 0x10, 0, 4),
230*4882a593Smuzhiyun 	PIN_FIELD16(49, 49, 0xf80, 0x10, 4, 4),
231*4882a593Smuzhiyun 	PINS_FIELD16(50, 52, 0xf70, 0x10, 4, 4),
232*4882a593Smuzhiyun 	PINS_FIELD16(53, 56, 0xf80, 0x10, 12, 4),
233*4882a593Smuzhiyun 	PINS_FIELD16(60, 62, 0xf90, 0x10, 8, 4),
234*4882a593Smuzhiyun 	PINS_FIELD16(63, 65, 0xf90, 0x10, 12, 4),
235*4882a593Smuzhiyun 	PINS_FIELD16(66, 71, 0xfa0, 0x10, 0, 4),
236*4882a593Smuzhiyun 	PINS_FIELD16(72, 74, 0xf80, 0x10, 4, 4),
237*4882a593Smuzhiyun 	PIN_FIELD16(85, 85, 0xda0, 0x10, 0, 4),
238*4882a593Smuzhiyun 	PIN_FIELD16(86, 86, 0xd90, 0x10, 0, 4),
239*4882a593Smuzhiyun 	PINS_FIELD16(87, 90, 0xdb0, 0x10, 0, 4),
240*4882a593Smuzhiyun 	PIN_FIELD16(105, 105, 0xd40, 0x10, 0, 4),
241*4882a593Smuzhiyun 	PIN_FIELD16(106, 106, 0xd30, 0x10, 0, 4),
242*4882a593Smuzhiyun 	PINS_FIELD16(107, 110, 0xd50, 0x10, 0, 4),
243*4882a593Smuzhiyun 	PINS_FIELD16(111, 115, 0xce0, 0x10, 0, 4),
244*4882a593Smuzhiyun 	PIN_FIELD16(116, 116, 0xcd0, 0x10, 0, 4),
245*4882a593Smuzhiyun 	PIN_FIELD16(117, 117, 0xcc0, 0x10, 0, 4),
246*4882a593Smuzhiyun 	PINS_FIELD16(118, 121, 0xce0, 0x10, 0, 4),
247*4882a593Smuzhiyun 	PIN_FIELD16(126, 126, 0xf80, 0x10, 4, 4),
248*4882a593Smuzhiyun 	PIN_FIELD16(188, 188, 0xf70, 0x10, 4, 4),
249*4882a593Smuzhiyun 	PINS_FIELD16(189, 193, 0xfe0, 0x10, 8, 4),
250*4882a593Smuzhiyun 	PINS_FIELD16(194, 198, 0xfe0, 0x10, 12, 4),
251*4882a593Smuzhiyun 	PIN_FIELD16(199, 199, 0xf50, 0x10, 4, 4),
252*4882a593Smuzhiyun 	PINS_FIELD16(200, 202, 0xfd0, 0x10, 0, 4),
253*4882a593Smuzhiyun 	PINS_FIELD16(203, 207, 0xfd0, 0x10, 4, 4),
254*4882a593Smuzhiyun 	PINS_FIELD16(208, 209, 0xfd0, 0x10, 8, 4),
255*4882a593Smuzhiyun 	PIN_FIELD16(210, 210, 0xfd0, 0x10, 12, 4),
256*4882a593Smuzhiyun 	PINS_FIELD16(211, 235, 0xff0, 0x10, 0, 4),
257*4882a593Smuzhiyun 	PINS_FIELD16(236, 241, 0xff0, 0x10, 4, 4),
258*4882a593Smuzhiyun 	PINS_FIELD16(242, 243, 0xff0, 0x10, 8, 4),
259*4882a593Smuzhiyun 	PIN_FIELD16(248, 248, 0xf00, 0x10, 0, 4),
260*4882a593Smuzhiyun 	PINS_FIELD16(249, 256, 0xfc0, 0x10, 0, 4),
261*4882a593Smuzhiyun 	PIN_FIELD16(257, 257, 0xce0, 0x10, 0, 4),
262*4882a593Smuzhiyun 	PIN_FIELD16(258, 258, 0xcb0, 0x10, 0, 4),
263*4882a593Smuzhiyun 	PIN_FIELD16(259, 259, 0xc90, 0x10, 0, 4),
264*4882a593Smuzhiyun 	PIN_FIELD16(260, 260, 0x3a0, 0x10, 0, 4),
265*4882a593Smuzhiyun 	PIN_FIELD16(261, 261, 0xd50, 0x10, 0, 4),
266*4882a593Smuzhiyun 	PINS_FIELD16(262, 277, 0xf00, 0x10, 8, 4),
267*4882a593Smuzhiyun 	PIN_FIELD16(278, 278, 0xf70, 0x10, 8, 4),
268*4882a593Smuzhiyun };
269*4882a593Smuzhiyun 
270*4882a593Smuzhiyun static const struct mtk_pin_field_calc mt7623_pin_tdsel_range[] = {
271*4882a593Smuzhiyun 	PINS_FIELD16(262, 276, 0x4c0, 0x10, 0, 4),
272*4882a593Smuzhiyun };
273*4882a593Smuzhiyun 
274*4882a593Smuzhiyun static const struct mtk_pin_field_calc mt7623_pin_pupd_range[] = {
275*4882a593Smuzhiyun 	/* MSDC0 */
276*4882a593Smuzhiyun 	PIN_FIELD16(111, 111, 0xd00, 0x10, 12, 1),
277*4882a593Smuzhiyun 	PIN_FIELD16(112, 112, 0xd00, 0x10, 8, 1),
278*4882a593Smuzhiyun 	PIN_FIELD16(113, 113, 0xd00, 0x10, 4, 1),
279*4882a593Smuzhiyun 	PIN_FIELD16(114, 114, 0xd00, 0x10, 0, 1),
280*4882a593Smuzhiyun 	PIN_FIELD16(115, 115, 0xd10, 0x10, 0, 1),
281*4882a593Smuzhiyun 	PIN_FIELD16(116, 116, 0xcd0, 0x10, 8, 1),
282*4882a593Smuzhiyun 	PIN_FIELD16(117, 117, 0xcc0, 0x10, 8, 1),
283*4882a593Smuzhiyun 	PIN_FIELD16(118, 118, 0xcf0, 0x10, 12, 1),
284*4882a593Smuzhiyun 	PIN_FIELD16(119, 119, 0xcf0, 0x10, 8, 1),
285*4882a593Smuzhiyun 	PIN_FIELD16(120, 120, 0xcf0, 0x10, 4, 1),
286*4882a593Smuzhiyun 	PIN_FIELD16(121, 121, 0xcf0, 0x10, 0, 1),
287*4882a593Smuzhiyun 	/* MSDC1 */
288*4882a593Smuzhiyun 	PIN_FIELD16(105, 105, 0xd40, 0x10, 8, 1),
289*4882a593Smuzhiyun 	PIN_FIELD16(106, 106, 0xd30, 0x10, 8, 1),
290*4882a593Smuzhiyun 	PIN_FIELD16(107, 107, 0xd60, 0x10, 0, 1),
291*4882a593Smuzhiyun 	PIN_FIELD16(108, 108, 0xd60, 0x10, 10, 1),
292*4882a593Smuzhiyun 	PIN_FIELD16(109, 109, 0xd60, 0x10, 4, 1),
293*4882a593Smuzhiyun 	PIN_FIELD16(110, 110, 0xc60, 0x10, 12, 1),
294*4882a593Smuzhiyun 	/* MSDC1 */
295*4882a593Smuzhiyun 	PIN_FIELD16(85, 85, 0xda0, 0x10, 8, 1),
296*4882a593Smuzhiyun 	PIN_FIELD16(86, 86, 0xd90, 0x10, 8, 1),
297*4882a593Smuzhiyun 	PIN_FIELD16(87, 87, 0xdc0, 0x10, 0, 1),
298*4882a593Smuzhiyun 	PIN_FIELD16(88, 88, 0xdc0, 0x10, 10, 1),
299*4882a593Smuzhiyun 	PIN_FIELD16(89, 89, 0xdc0, 0x10, 4, 1),
300*4882a593Smuzhiyun 	PIN_FIELD16(90, 90, 0xdc0, 0x10, 12, 1),
301*4882a593Smuzhiyun 	/* MSDC0E */
302*4882a593Smuzhiyun 	PIN_FIELD16(249, 249, 0x140, 0x10, 0, 1),
303*4882a593Smuzhiyun 	PIN_FIELD16(250, 250, 0x130, 0x10, 12, 1),
304*4882a593Smuzhiyun 	PIN_FIELD16(251, 251, 0x130, 0x10, 8, 1),
305*4882a593Smuzhiyun 	PIN_FIELD16(252, 252, 0x130, 0x10, 4, 1),
306*4882a593Smuzhiyun 	PIN_FIELD16(253, 253, 0x130, 0x10, 0, 1),
307*4882a593Smuzhiyun 	PIN_FIELD16(254, 254, 0xf40, 0x10, 12, 1),
308*4882a593Smuzhiyun 	PIN_FIELD16(255, 255, 0xf40, 0x10, 8, 1),
309*4882a593Smuzhiyun 	PIN_FIELD16(256, 256, 0xf40, 0x10, 4, 1),
310*4882a593Smuzhiyun 	PIN_FIELD16(257, 257, 0xf40, 0x10, 0, 1),
311*4882a593Smuzhiyun 	PIN_FIELD16(258, 258, 0xcb0, 0x10, 8, 1),
312*4882a593Smuzhiyun 	PIN_FIELD16(259, 259, 0xc90, 0x10, 8, 1),
313*4882a593Smuzhiyun 	PIN_FIELD16(261, 261, 0x140, 0x10, 8, 1),
314*4882a593Smuzhiyun };
315*4882a593Smuzhiyun 
316*4882a593Smuzhiyun static const struct mtk_pin_field_calc mt7623_pin_r1_range[] = {
317*4882a593Smuzhiyun 	/* MSDC0 */
318*4882a593Smuzhiyun 	PIN_FIELD16(111, 111, 0xd00, 0x10, 13, 1),
319*4882a593Smuzhiyun 	PIN_FIELD16(112, 112, 0xd00, 0x10, 9, 1),
320*4882a593Smuzhiyun 	PIN_FIELD16(113, 113, 0xd00, 0x10, 5, 1),
321*4882a593Smuzhiyun 	PIN_FIELD16(114, 114, 0xd00, 0x10, 1, 1),
322*4882a593Smuzhiyun 	PIN_FIELD16(115, 115, 0xd10, 0x10, 1, 1),
323*4882a593Smuzhiyun 	PIN_FIELD16(116, 116, 0xcd0, 0x10, 9, 1),
324*4882a593Smuzhiyun 	PIN_FIELD16(117, 117, 0xcc0, 0x10, 9, 1),
325*4882a593Smuzhiyun 	PIN_FIELD16(118, 118, 0xcf0, 0x10, 13, 1),
326*4882a593Smuzhiyun 	PIN_FIELD16(119, 119, 0xcf0, 0x10, 9, 1),
327*4882a593Smuzhiyun 	PIN_FIELD16(120, 120, 0xcf0, 0x10, 5, 1),
328*4882a593Smuzhiyun 	PIN_FIELD16(121, 121, 0xcf0, 0x10, 1, 1),
329*4882a593Smuzhiyun 	/* MSDC1 */
330*4882a593Smuzhiyun 	PIN_FIELD16(105, 105, 0xd40, 0x10, 9, 1),
331*4882a593Smuzhiyun 	PIN_FIELD16(106, 106, 0xd30, 0x10, 9, 1),
332*4882a593Smuzhiyun 	PIN_FIELD16(107, 107, 0xd60, 0x10, 1, 1),
333*4882a593Smuzhiyun 	PIN_FIELD16(108, 108, 0xd60, 0x10, 9, 1),
334*4882a593Smuzhiyun 	PIN_FIELD16(109, 109, 0xd60, 0x10, 5, 1),
335*4882a593Smuzhiyun 	PIN_FIELD16(110, 110, 0xc60, 0x10, 13, 1),
336*4882a593Smuzhiyun 	/* MSDC2 */
337*4882a593Smuzhiyun 	PIN_FIELD16(85, 85, 0xda0, 0x10, 9, 1),
338*4882a593Smuzhiyun 	PIN_FIELD16(86, 86, 0xd90, 0x10, 9, 1),
339*4882a593Smuzhiyun 	PIN_FIELD16(87, 87, 0xdc0, 0x10, 1, 1),
340*4882a593Smuzhiyun 	PIN_FIELD16(88, 88, 0xdc0, 0x10, 9, 1),
341*4882a593Smuzhiyun 	PIN_FIELD16(89, 89, 0xdc0, 0x10, 5, 1),
342*4882a593Smuzhiyun 	PIN_FIELD16(90, 90, 0xdc0, 0x10, 13, 1),
343*4882a593Smuzhiyun 	/* MSDC0E */
344*4882a593Smuzhiyun 	PIN_FIELD16(249, 249, 0x140, 0x10, 1, 1),
345*4882a593Smuzhiyun 	PIN_FIELD16(250, 250, 0x130, 0x10, 13, 1),
346*4882a593Smuzhiyun 	PIN_FIELD16(251, 251, 0x130, 0x10, 9, 1),
347*4882a593Smuzhiyun 	PIN_FIELD16(252, 252, 0x130, 0x10, 5, 1),
348*4882a593Smuzhiyun 	PIN_FIELD16(253, 253, 0x130, 0x10, 1, 1),
349*4882a593Smuzhiyun 	PIN_FIELD16(254, 254, 0xf40, 0x10, 13, 1),
350*4882a593Smuzhiyun 	PIN_FIELD16(255, 255, 0xf40, 0x10, 9, 1),
351*4882a593Smuzhiyun 	PIN_FIELD16(256, 256, 0xf40, 0x10, 5, 1),
352*4882a593Smuzhiyun 	PIN_FIELD16(257, 257, 0xf40, 0x10, 1, 1),
353*4882a593Smuzhiyun 	PIN_FIELD16(258, 258, 0xcb0, 0x10, 9, 1),
354*4882a593Smuzhiyun 	PIN_FIELD16(259, 259, 0xc90, 0x10, 9, 1),
355*4882a593Smuzhiyun 	PIN_FIELD16(261, 261, 0x140, 0x10, 9, 1),
356*4882a593Smuzhiyun };
357*4882a593Smuzhiyun 
358*4882a593Smuzhiyun static const struct mtk_pin_field_calc mt7623_pin_r0_range[] = {
359*4882a593Smuzhiyun 	/* MSDC0 */
360*4882a593Smuzhiyun 	PIN_FIELD16(111, 111, 0xd00, 0x10, 14, 1),
361*4882a593Smuzhiyun 	PIN_FIELD16(112, 112, 0xd00, 0x10, 10, 1),
362*4882a593Smuzhiyun 	PIN_FIELD16(113, 113, 0xd00, 0x10, 6, 1),
363*4882a593Smuzhiyun 	PIN_FIELD16(114, 114, 0xd00, 0x10, 2, 1),
364*4882a593Smuzhiyun 	PIN_FIELD16(115, 115, 0xd10, 0x10, 2, 1),
365*4882a593Smuzhiyun 	PIN_FIELD16(116, 116, 0xcd0, 0x10, 10, 1),
366*4882a593Smuzhiyun 	PIN_FIELD16(117, 117, 0xcc0, 0x10, 10, 1),
367*4882a593Smuzhiyun 	PIN_FIELD16(118, 118, 0xcf0, 0x10, 14, 1),
368*4882a593Smuzhiyun 	PIN_FIELD16(119, 119, 0xcf0, 0x10, 10, 1),
369*4882a593Smuzhiyun 	PIN_FIELD16(120, 120, 0xcf0, 0x10, 6, 1),
370*4882a593Smuzhiyun 	PIN_FIELD16(121, 121, 0xcf0, 0x10, 2, 1),
371*4882a593Smuzhiyun 	/* MSDC1 */
372*4882a593Smuzhiyun 	PIN_FIELD16(105, 105, 0xd40, 0x10, 10, 1),
373*4882a593Smuzhiyun 	PIN_FIELD16(106, 106, 0xd30, 0x10, 10, 1),
374*4882a593Smuzhiyun 	PIN_FIELD16(107, 107, 0xd60, 0x10, 2, 1),
375*4882a593Smuzhiyun 	PIN_FIELD16(108, 108, 0xd60, 0x10, 8, 1),
376*4882a593Smuzhiyun 	PIN_FIELD16(109, 109, 0xd60, 0x10, 6, 1),
377*4882a593Smuzhiyun 	PIN_FIELD16(110, 110, 0xc60, 0x10, 14, 1),
378*4882a593Smuzhiyun 	/* MSDC2 */
379*4882a593Smuzhiyun 	PIN_FIELD16(85, 85, 0xda0, 0x10, 10, 1),
380*4882a593Smuzhiyun 	PIN_FIELD16(86, 86, 0xd90, 0x10, 10, 1),
381*4882a593Smuzhiyun 	PIN_FIELD16(87, 87, 0xdc0, 0x10, 2, 1),
382*4882a593Smuzhiyun 	PIN_FIELD16(88, 88, 0xdc0, 0x10, 8, 1),
383*4882a593Smuzhiyun 	PIN_FIELD16(89, 89, 0xdc0, 0x10, 6, 1),
384*4882a593Smuzhiyun 	PIN_FIELD16(90, 90, 0xdc0, 0x10, 14, 1),
385*4882a593Smuzhiyun 	/* MSDC0E */
386*4882a593Smuzhiyun 	PIN_FIELD16(249, 249, 0x140, 0x10, 2, 1),
387*4882a593Smuzhiyun 	PIN_FIELD16(250, 250, 0x130, 0x10, 14, 1),
388*4882a593Smuzhiyun 	PIN_FIELD16(251, 251, 0x130, 0x10, 10, 1),
389*4882a593Smuzhiyun 	PIN_FIELD16(252, 252, 0x130, 0x10, 6, 1),
390*4882a593Smuzhiyun 	PIN_FIELD16(253, 253, 0x130, 0x10, 2, 1),
391*4882a593Smuzhiyun 	PIN_FIELD16(254, 254, 0xf40, 0x10, 14, 1),
392*4882a593Smuzhiyun 	PIN_FIELD16(255, 255, 0xf40, 0x10, 10, 1),
393*4882a593Smuzhiyun 	PIN_FIELD16(256, 256, 0xf40, 0x10, 6, 1),
394*4882a593Smuzhiyun 	PIN_FIELD16(257, 257, 0xf40, 0x10, 5, 1),
395*4882a593Smuzhiyun 	PIN_FIELD16(258, 258, 0xcb0, 0x10, 10, 1),
396*4882a593Smuzhiyun 	PIN_FIELD16(259, 259, 0xc90, 0x10, 10, 1),
397*4882a593Smuzhiyun 	PIN_FIELD16(261, 261, 0x140, 0x10, 10, 1),
398*4882a593Smuzhiyun };
399*4882a593Smuzhiyun 
400*4882a593Smuzhiyun static const struct mtk_pin_reg_calc mt7623_reg_cals[] = {
401*4882a593Smuzhiyun 	[PINCTRL_PIN_REG_MODE] = MTK_RANGE(mt7623_pin_mode_range),
402*4882a593Smuzhiyun 	[PINCTRL_PIN_REG_DIR] = MTK_RANGE(mt7623_pin_dir_range),
403*4882a593Smuzhiyun 	[PINCTRL_PIN_REG_DI] = MTK_RANGE(mt7623_pin_di_range),
404*4882a593Smuzhiyun 	[PINCTRL_PIN_REG_DO] = MTK_RANGE(mt7623_pin_do_range),
405*4882a593Smuzhiyun 	[PINCTRL_PIN_REG_SMT] = MTK_RANGE(mt7623_pin_smt_range),
406*4882a593Smuzhiyun 	[PINCTRL_PIN_REG_PULLSEL] = MTK_RANGE(mt7623_pin_pullsel_range),
407*4882a593Smuzhiyun 	[PINCTRL_PIN_REG_PULLEN] = MTK_RANGE(mt7623_pin_pullen_range),
408*4882a593Smuzhiyun 	[PINCTRL_PIN_REG_DRV] = MTK_RANGE(mt7623_pin_drv_range),
409*4882a593Smuzhiyun 	[PINCTRL_PIN_REG_TDSEL] = MTK_RANGE(mt7623_pin_tdsel_range),
410*4882a593Smuzhiyun 	[PINCTRL_PIN_REG_IES] = MTK_RANGE(mt7623_pin_ies_range),
411*4882a593Smuzhiyun 	[PINCTRL_PIN_REG_PUPD] = MTK_RANGE(mt7623_pin_pupd_range),
412*4882a593Smuzhiyun 	[PINCTRL_PIN_REG_R0] = MTK_RANGE(mt7623_pin_r0_range),
413*4882a593Smuzhiyun 	[PINCTRL_PIN_REG_R1] = MTK_RANGE(mt7623_pin_r1_range),
414*4882a593Smuzhiyun };
415*4882a593Smuzhiyun 
416*4882a593Smuzhiyun static const struct mtk_pin_desc mt7623_pins[] = {
417*4882a593Smuzhiyun 	MT7623_PIN(0, "PWRAP_SPI0_MI", 148, DRV_GRP3),
418*4882a593Smuzhiyun 	MT7623_PIN(1, "PWRAP_SPI0_MO", 149, DRV_GRP3),
419*4882a593Smuzhiyun 	MT7623_PIN(2, "PWRAP_INT", 150, DRV_GRP3),
420*4882a593Smuzhiyun 	MT7623_PIN(3, "PWRAP_SPI0_CK", 151, DRV_GRP3),
421*4882a593Smuzhiyun 	MT7623_PIN(4, "PWRAP_SPI0_CSN", 152, DRV_GRP3),
422*4882a593Smuzhiyun 	MT7623_PIN(5, "PWRAP_SPI0_CK2", 153, DRV_GRP3),
423*4882a593Smuzhiyun 	MT7623_PIN(6, "PWRAP_SPI0_CSN2", 154, DRV_GRP3),
424*4882a593Smuzhiyun 	MT7623_PIN(7, "SPI1_CSN", 155, DRV_GRP3),
425*4882a593Smuzhiyun 	MT7623_PIN(8, "SPI1_MI", 156, DRV_GRP3),
426*4882a593Smuzhiyun 	MT7623_PIN(9, "SPI1_MO", 157, DRV_GRP3),
427*4882a593Smuzhiyun 	MT7623_PIN(10, "RTC32K_CK", 158, DRV_GRP3),
428*4882a593Smuzhiyun 	MT7623_PIN(11, "WATCHDOG", 159, DRV_GRP3),
429*4882a593Smuzhiyun 	MT7623_PIN(12, "SRCLKENA", 160, DRV_GRP3),
430*4882a593Smuzhiyun 	MT7623_PIN(13, "SRCLKENAI", 161, DRV_GRP3),
431*4882a593Smuzhiyun 	MT7623_PIN(14, "URXD2", 162, DRV_GRP1),
432*4882a593Smuzhiyun 	MT7623_PIN(15, "UTXD2", 163, DRV_GRP1),
433*4882a593Smuzhiyun 	MT7623_PIN(16, "I2S5_DATA_IN", 164, DRV_GRP1),
434*4882a593Smuzhiyun 	MT7623_PIN(17, "I2S5_BCK", 165, DRV_GRP1),
435*4882a593Smuzhiyun 	MT7623_PIN(18, "PCM_CLK", 166, DRV_GRP1),
436*4882a593Smuzhiyun 	MT7623_PIN(19, "PCM_SYNC", 167, DRV_GRP1),
437*4882a593Smuzhiyun 	MT7623_PIN(20, "PCM_RX", EINT_NA, DRV_GRP1),
438*4882a593Smuzhiyun 	MT7623_PIN(21, "PCM_TX", EINT_NA, DRV_GRP1),
439*4882a593Smuzhiyun 	MT7623_PIN(22, "EINT0", 0, DRV_GRP1),
440*4882a593Smuzhiyun 	MT7623_PIN(23, "EINT1", 1, DRV_GRP1),
441*4882a593Smuzhiyun 	MT7623_PIN(24, "EINT2", 2, DRV_GRP1),
442*4882a593Smuzhiyun 	MT7623_PIN(25, "EINT3", 3, DRV_GRP1),
443*4882a593Smuzhiyun 	MT7623_PIN(26, "EINT4", 4, DRV_GRP1),
444*4882a593Smuzhiyun 	MT7623_PIN(27, "EINT5", 5, DRV_GRP1),
445*4882a593Smuzhiyun 	MT7623_PIN(28, "EINT6", 6, DRV_GRP1),
446*4882a593Smuzhiyun 	MT7623_PIN(29, "EINT7", 7, DRV_GRP1),
447*4882a593Smuzhiyun 	MT7623_PIN(30, "I2S5_LRCK", 12, DRV_GRP1),
448*4882a593Smuzhiyun 	MT7623_PIN(31, "I2S5_MCLK", 13, DRV_GRP1),
449*4882a593Smuzhiyun 	MT7623_PIN(32, "I2S5_DATA", 14, DRV_GRP1),
450*4882a593Smuzhiyun 	MT7623_PIN(33, "I2S1_DATA", 15, DRV_GRP1),
451*4882a593Smuzhiyun 	MT7623_PIN(34, "I2S1_DATA_IN", 16, DRV_GRP1),
452*4882a593Smuzhiyun 	MT7623_PIN(35, "I2S1_BCK", 17, DRV_GRP1),
453*4882a593Smuzhiyun 	MT7623_PIN(36, "I2S1_LRCK", 18, DRV_GRP1),
454*4882a593Smuzhiyun 	MT7623_PIN(37, "I2S1_MCLK", 19, DRV_GRP1),
455*4882a593Smuzhiyun 	MT7623_PIN(38, "I2S2_DATA", 20, DRV_GRP1),
456*4882a593Smuzhiyun 	MT7623_PIN(39, "JTMS", 21, DRV_GRP3),
457*4882a593Smuzhiyun 	MT7623_PIN(40, "JTCK", 22, DRV_GRP3),
458*4882a593Smuzhiyun 	MT7623_PIN(41, "JTDI", 23, DRV_GRP3),
459*4882a593Smuzhiyun 	MT7623_PIN(42, "JTDO", 24, DRV_GRP3),
460*4882a593Smuzhiyun 	MT7623_PIN(43, "NCLE", 25, DRV_GRP1),
461*4882a593Smuzhiyun 	MT7623_PIN(44, "NCEB1", 26, DRV_GRP1),
462*4882a593Smuzhiyun 	MT7623_PIN(45, "NCEB0", 27, DRV_GRP1),
463*4882a593Smuzhiyun 	MT7623_PIN(46, "IR", 28, DRV_FIXED),
464*4882a593Smuzhiyun 	MT7623_PIN(47, "NREB", 29, DRV_GRP1),
465*4882a593Smuzhiyun 	MT7623_PIN(48, "NRNB", 30, DRV_GRP1),
466*4882a593Smuzhiyun 	MT7623_PIN(49, "I2S0_DATA", 31, DRV_GRP1),
467*4882a593Smuzhiyun 	MT7623_PIN(50, "I2S2_BCK", 32, DRV_GRP1),
468*4882a593Smuzhiyun 	MT7623_PIN(51, "I2S2_DATA_IN", 33, DRV_GRP1),
469*4882a593Smuzhiyun 	MT7623_PIN(52, "I2S2_LRCK", 34, DRV_GRP1),
470*4882a593Smuzhiyun 	MT7623_PIN(53, "SPI0_CSN", 35, DRV_GRP1),
471*4882a593Smuzhiyun 	MT7623_PIN(54, "SPI0_CK", 36, DRV_GRP1),
472*4882a593Smuzhiyun 	MT7623_PIN(55, "SPI0_MI", 37, DRV_GRP1),
473*4882a593Smuzhiyun 	MT7623_PIN(56, "SPI0_MO", 38, DRV_GRP1),
474*4882a593Smuzhiyun 	MT7623_PIN(57, "SDA1", 39, DRV_FIXED),
475*4882a593Smuzhiyun 	MT7623_PIN(58, "SCL1", 40, DRV_FIXED),
476*4882a593Smuzhiyun 	MT7623_PIN(59, "RAMBUF_I_CLK", EINT_NA, DRV_FIXED),
477*4882a593Smuzhiyun 	MT7623_PIN(60, "WB_RSTB", 41, DRV_GRP3),
478*4882a593Smuzhiyun 	MT7623_PIN(61, "F2W_DATA", 42, DRV_GRP3),
479*4882a593Smuzhiyun 	MT7623_PIN(62, "F2W_CLK", 43, DRV_GRP3),
480*4882a593Smuzhiyun 	MT7623_PIN(63, "WB_SCLK", 44, DRV_GRP3),
481*4882a593Smuzhiyun 	MT7623_PIN(64, "WB_SDATA", 45, DRV_GRP3),
482*4882a593Smuzhiyun 	MT7623_PIN(65, "WB_SEN", 46, DRV_GRP3),
483*4882a593Smuzhiyun 	MT7623_PIN(66, "WB_CRTL0", 47, DRV_GRP3),
484*4882a593Smuzhiyun 	MT7623_PIN(67, "WB_CRTL1", 48, DRV_GRP3),
485*4882a593Smuzhiyun 	MT7623_PIN(68, "WB_CRTL2", 49, DRV_GRP3),
486*4882a593Smuzhiyun 	MT7623_PIN(69, "WB_CRTL3", 50, DRV_GRP3),
487*4882a593Smuzhiyun 	MT7623_PIN(70, "WB_CRTL4", 51, DRV_GRP3),
488*4882a593Smuzhiyun 	MT7623_PIN(71, "WB_CRTL5", 52, DRV_GRP3),
489*4882a593Smuzhiyun 	MT7623_PIN(72, "I2S0_DATA_IN", 53, DRV_GRP1),
490*4882a593Smuzhiyun 	MT7623_PIN(73, "I2S0_LRCK", 54, DRV_GRP1),
491*4882a593Smuzhiyun 	MT7623_PIN(74, "I2S0_BCK", 55, DRV_GRP1),
492*4882a593Smuzhiyun 	MT7623_PIN(75, "SDA0", 56, DRV_FIXED),
493*4882a593Smuzhiyun 	MT7623_PIN(76, "SCL0", 57, DRV_FIXED),
494*4882a593Smuzhiyun 	MT7623_PIN(77, "SDA2", 58, DRV_FIXED),
495*4882a593Smuzhiyun 	MT7623_PIN(78, "SCL2", 59, DRV_FIXED),
496*4882a593Smuzhiyun 	MT7623_PIN(79, "URXD0", 60, DRV_FIXED),
497*4882a593Smuzhiyun 	MT7623_PIN(80, "UTXD0", 61, DRV_FIXED),
498*4882a593Smuzhiyun 	MT7623_PIN(81, "URXD1", 62, DRV_FIXED),
499*4882a593Smuzhiyun 	MT7623_PIN(82, "UTXD1", 63, DRV_FIXED),
500*4882a593Smuzhiyun 	MT7623_PIN(83, "LCM_RST", 64, DRV_FIXED),
501*4882a593Smuzhiyun 	MT7623_PIN(84, "DSI_TE", 65, DRV_FIXED),
502*4882a593Smuzhiyun 	MT7623_PIN(85, "MSDC2_CMD", 66, DRV_GRP4),
503*4882a593Smuzhiyun 	MT7623_PIN(86, "MSDC2_CLK", 67, DRV_GRP4),
504*4882a593Smuzhiyun 	MT7623_PIN(87, "MSDC2_DAT0", 68, DRV_GRP4),
505*4882a593Smuzhiyun 	MT7623_PIN(88, "MSDC2_DAT1", 69, DRV_GRP4),
506*4882a593Smuzhiyun 	MT7623_PIN(89, "MSDC2_DAT2", 70, DRV_GRP4),
507*4882a593Smuzhiyun 	MT7623_PIN(90, "MSDC2_DAT3", 71, DRV_GRP4),
508*4882a593Smuzhiyun 	MT7623_PIN(91, "TDN3", EINT_NA, DRV_FIXED),
509*4882a593Smuzhiyun 	MT7623_PIN(92, "TDP3", EINT_NA, DRV_FIXED),
510*4882a593Smuzhiyun 	MT7623_PIN(93, "TDN2", EINT_NA, DRV_FIXED),
511*4882a593Smuzhiyun 	MT7623_PIN(94, "TDP2", EINT_NA, DRV_FIXED),
512*4882a593Smuzhiyun 	MT7623_PIN(95, "TCN", EINT_NA, DRV_FIXED),
513*4882a593Smuzhiyun 	MT7623_PIN(96, "TCP", EINT_NA, DRV_FIXED),
514*4882a593Smuzhiyun 	MT7623_PIN(97, "TDN1", EINT_NA, DRV_FIXED),
515*4882a593Smuzhiyun 	MT7623_PIN(98, "TDP1", EINT_NA, DRV_FIXED),
516*4882a593Smuzhiyun 	MT7623_PIN(99, "TDN0", EINT_NA, DRV_FIXED),
517*4882a593Smuzhiyun 	MT7623_PIN(100, "TDP0", EINT_NA, DRV_FIXED),
518*4882a593Smuzhiyun 	MT7623_PIN(101, "SPI2_CSN", 74, DRV_FIXED),
519*4882a593Smuzhiyun 	MT7623_PIN(102, "SPI2_MI", 75, DRV_FIXED),
520*4882a593Smuzhiyun 	MT7623_PIN(103, "SPI2_MO", 76, DRV_FIXED),
521*4882a593Smuzhiyun 	MT7623_PIN(104, "SPI2_CLK", 77, DRV_FIXED),
522*4882a593Smuzhiyun 	MT7623_PIN(105, "MSDC1_CMD", 78, DRV_GRP4),
523*4882a593Smuzhiyun 	MT7623_PIN(106, "MSDC1_CLK", 79, DRV_GRP4),
524*4882a593Smuzhiyun 	MT7623_PIN(107, "MSDC1_DAT0", 80, DRV_GRP4),
525*4882a593Smuzhiyun 	MT7623_PIN(108, "MSDC1_DAT1", 81, DRV_GRP4),
526*4882a593Smuzhiyun 	MT7623_PIN(109, "MSDC1_DAT2", 82, DRV_GRP4),
527*4882a593Smuzhiyun 	MT7623_PIN(110, "MSDC1_DAT3", 83, DRV_GRP4),
528*4882a593Smuzhiyun 	MT7623_PIN(111, "MSDC0_DAT7", 84, DRV_GRP4),
529*4882a593Smuzhiyun 	MT7623_PIN(112, "MSDC0_DAT6", 85, DRV_GRP4),
530*4882a593Smuzhiyun 	MT7623_PIN(113, "MSDC0_DAT5", 86, DRV_GRP4),
531*4882a593Smuzhiyun 	MT7623_PIN(114, "MSDC0_DAT4", 87, DRV_GRP4),
532*4882a593Smuzhiyun 	MT7623_PIN(115, "MSDC0_RSTB", 88, DRV_GRP4),
533*4882a593Smuzhiyun 	MT7623_PIN(116, "MSDC0_CMD", 89, DRV_GRP4),
534*4882a593Smuzhiyun 	MT7623_PIN(117, "MSDC0_CLK", 90, DRV_GRP4),
535*4882a593Smuzhiyun 	MT7623_PIN(118, "MSDC0_DAT3", 91, DRV_GRP4),
536*4882a593Smuzhiyun 	MT7623_PIN(119, "MSDC0_DAT2", 92, DRV_GRP4),
537*4882a593Smuzhiyun 	MT7623_PIN(120, "MSDC0_DAT1", 93, DRV_GRP4),
538*4882a593Smuzhiyun 	MT7623_PIN(121, "MSDC0_DAT0", 94, DRV_GRP4),
539*4882a593Smuzhiyun 	MT7623_PIN(122, "CEC", 95, DRV_FIXED),
540*4882a593Smuzhiyun 	MT7623_PIN(123, "HTPLG", 96, DRV_FIXED),
541*4882a593Smuzhiyun 	MT7623_PIN(124, "HDMISCK", 97, DRV_FIXED),
542*4882a593Smuzhiyun 	MT7623_PIN(125, "HDMISD", 98, DRV_FIXED),
543*4882a593Smuzhiyun 	MT7623_PIN(126, "I2S0_MCLK", 99, DRV_GRP1),
544*4882a593Smuzhiyun 	MT7623_PIN(127, "RAMBUF_IDATA0", EINT_NA, DRV_FIXED),
545*4882a593Smuzhiyun 	MT7623_PIN(128, "RAMBUF_IDATA1", EINT_NA, DRV_FIXED),
546*4882a593Smuzhiyun 	MT7623_PIN(129, "RAMBUF_IDATA2", EINT_NA, DRV_FIXED),
547*4882a593Smuzhiyun 	MT7623_PIN(130, "RAMBUF_IDATA3", EINT_NA, DRV_FIXED),
548*4882a593Smuzhiyun 	MT7623_PIN(131, "RAMBUF_IDATA4", EINT_NA, DRV_FIXED),
549*4882a593Smuzhiyun 	MT7623_PIN(132, "RAMBUF_IDATA5", EINT_NA, DRV_FIXED),
550*4882a593Smuzhiyun 	MT7623_PIN(133, "RAMBUF_IDATA6", EINT_NA, DRV_FIXED),
551*4882a593Smuzhiyun 	MT7623_PIN(134, "RAMBUF_IDATA7", EINT_NA, DRV_FIXED),
552*4882a593Smuzhiyun 	MT7623_PIN(135, "RAMBUF_IDATA8", EINT_NA, DRV_FIXED),
553*4882a593Smuzhiyun 	MT7623_PIN(136, "RAMBUF_IDATA9", EINT_NA, DRV_FIXED),
554*4882a593Smuzhiyun 	MT7623_PIN(137, "RAMBUF_IDATA10", EINT_NA, DRV_FIXED),
555*4882a593Smuzhiyun 	MT7623_PIN(138, "RAMBUF_IDATA11", EINT_NA, DRV_FIXED),
556*4882a593Smuzhiyun 	MT7623_PIN(139, "RAMBUF_IDATA12", EINT_NA, DRV_FIXED),
557*4882a593Smuzhiyun 	MT7623_PIN(140, "RAMBUF_IDATA13", EINT_NA, DRV_FIXED),
558*4882a593Smuzhiyun 	MT7623_PIN(141, "RAMBUF_IDATA14", EINT_NA, DRV_FIXED),
559*4882a593Smuzhiyun 	MT7623_PIN(142, "RAMBUF_IDATA15", EINT_NA, DRV_FIXED),
560*4882a593Smuzhiyun 	MT7623_PIN(143, "RAMBUF_ODATA0", EINT_NA, DRV_FIXED),
561*4882a593Smuzhiyun 	MT7623_PIN(144, "RAMBUF_ODATA1", EINT_NA, DRV_FIXED),
562*4882a593Smuzhiyun 	MT7623_PIN(145, "RAMBUF_ODATA2", EINT_NA, DRV_FIXED),
563*4882a593Smuzhiyun 	MT7623_PIN(146, "RAMBUF_ODATA3", EINT_NA, DRV_FIXED),
564*4882a593Smuzhiyun 	MT7623_PIN(147, "RAMBUF_ODATA4", EINT_NA, DRV_FIXED),
565*4882a593Smuzhiyun 	MT7623_PIN(148, "RAMBUF_ODATA5", EINT_NA, DRV_FIXED),
566*4882a593Smuzhiyun 	MT7623_PIN(149, "RAMBUF_ODATA6", EINT_NA, DRV_FIXED),
567*4882a593Smuzhiyun 	MT7623_PIN(150, "RAMBUF_ODATA7", EINT_NA, DRV_FIXED),
568*4882a593Smuzhiyun 	MT7623_PIN(151, "RAMBUF_ODATA8", EINT_NA, DRV_FIXED),
569*4882a593Smuzhiyun 	MT7623_PIN(152, "RAMBUF_ODATA9", EINT_NA, DRV_FIXED),
570*4882a593Smuzhiyun 	MT7623_PIN(153, "RAMBUF_ODATA10", EINT_NA, DRV_FIXED),
571*4882a593Smuzhiyun 	MT7623_PIN(154, "RAMBUF_ODATA11", EINT_NA, DRV_FIXED),
572*4882a593Smuzhiyun 	MT7623_PIN(155, "RAMBUF_ODATA12", EINT_NA, DRV_FIXED),
573*4882a593Smuzhiyun 	MT7623_PIN(156, "RAMBUF_ODATA13", EINT_NA, DRV_FIXED),
574*4882a593Smuzhiyun 	MT7623_PIN(157, "RAMBUF_ODATA14", EINT_NA, DRV_FIXED),
575*4882a593Smuzhiyun 	MT7623_PIN(158, "RAMBUF_ODATA15", EINT_NA, DRV_FIXED),
576*4882a593Smuzhiyun 	MT7623_PIN(159, "RAMBUF_BE0", EINT_NA, DRV_FIXED),
577*4882a593Smuzhiyun 	MT7623_PIN(160, "RAMBUF_BE1", EINT_NA, DRV_FIXED),
578*4882a593Smuzhiyun 	MT7623_PIN(161, "AP2PT_INT", EINT_NA, DRV_FIXED),
579*4882a593Smuzhiyun 	MT7623_PIN(162, "AP2PT_INT_CLR", EINT_NA, DRV_FIXED),
580*4882a593Smuzhiyun 	MT7623_PIN(163, "PT2AP_INT", EINT_NA, DRV_FIXED),
581*4882a593Smuzhiyun 	MT7623_PIN(164, "PT2AP_INT_CLR", EINT_NA, DRV_FIXED),
582*4882a593Smuzhiyun 	MT7623_PIN(165, "AP2UP_INT", EINT_NA, DRV_FIXED),
583*4882a593Smuzhiyun 	MT7623_PIN(166, "AP2UP_INT_CLR", EINT_NA, DRV_FIXED),
584*4882a593Smuzhiyun 	MT7623_PIN(167, "UP2AP_INT", EINT_NA, DRV_FIXED),
585*4882a593Smuzhiyun 	MT7623_PIN(168, "UP2AP_INT_CLR", EINT_NA, DRV_FIXED),
586*4882a593Smuzhiyun 	MT7623_PIN(169, "RAMBUF_ADDR0", EINT_NA, DRV_FIXED),
587*4882a593Smuzhiyun 	MT7623_PIN(170, "RAMBUF_ADDR1", EINT_NA, DRV_FIXED),
588*4882a593Smuzhiyun 	MT7623_PIN(171, "RAMBUF_ADDR2", EINT_NA, DRV_FIXED),
589*4882a593Smuzhiyun 	MT7623_PIN(172, "RAMBUF_ADDR3", EINT_NA, DRV_FIXED),
590*4882a593Smuzhiyun 	MT7623_PIN(173, "RAMBUF_ADDR4", EINT_NA, DRV_FIXED),
591*4882a593Smuzhiyun 	MT7623_PIN(174, "RAMBUF_ADDR5", EINT_NA, DRV_FIXED),
592*4882a593Smuzhiyun 	MT7623_PIN(175, "RAMBUF_ADDR6", EINT_NA, DRV_FIXED),
593*4882a593Smuzhiyun 	MT7623_PIN(176, "RAMBUF_ADDR7", EINT_NA, DRV_FIXED),
594*4882a593Smuzhiyun 	MT7623_PIN(177, "RAMBUF_ADDR8", EINT_NA, DRV_FIXED),
595*4882a593Smuzhiyun 	MT7623_PIN(178, "RAMBUF_ADDR9", EINT_NA, DRV_FIXED),
596*4882a593Smuzhiyun 	MT7623_PIN(179, "RAMBUF_ADDR10", EINT_NA, DRV_FIXED),
597*4882a593Smuzhiyun 	MT7623_PIN(180, "RAMBUF_RW", EINT_NA, DRV_FIXED),
598*4882a593Smuzhiyun 	MT7623_PIN(181, "RAMBUF_LAST", EINT_NA, DRV_FIXED),
599*4882a593Smuzhiyun 	MT7623_PIN(182, "RAMBUF_HP", EINT_NA, DRV_FIXED),
600*4882a593Smuzhiyun 	MT7623_PIN(183, "RAMBUF_REQ", EINT_NA, DRV_FIXED),
601*4882a593Smuzhiyun 	MT7623_PIN(184, "RAMBUF_ALE", EINT_NA, DRV_FIXED),
602*4882a593Smuzhiyun 	MT7623_PIN(185, "RAMBUF_DLE", EINT_NA, DRV_FIXED),
603*4882a593Smuzhiyun 	MT7623_PIN(186, "RAMBUF_WDLE", EINT_NA, DRV_FIXED),
604*4882a593Smuzhiyun 	MT7623_PIN(187, "RAMBUF_O_CLK", EINT_NA, DRV_FIXED),
605*4882a593Smuzhiyun 	MT7623_PIN(188, "I2S2_MCLK", 100, DRV_GRP1),
606*4882a593Smuzhiyun 	MT7623_PIN(189, "I2S3_DATA", 101, DRV_GRP1),
607*4882a593Smuzhiyun 	MT7623_PIN(190, "I2S3_DATA_IN", 102, DRV_GRP1),
608*4882a593Smuzhiyun 	MT7623_PIN(191, "I2S3_BCK", 103, DRV_GRP1),
609*4882a593Smuzhiyun 	MT7623_PIN(192, "I2S3_LRCK", 104, DRV_GRP1),
610*4882a593Smuzhiyun 	MT7623_PIN(193, "I2S3_MCLK", 105, DRV_GRP1),
611*4882a593Smuzhiyun 	MT7623_PIN(194, "I2S4_DATA", 106, DRV_GRP1),
612*4882a593Smuzhiyun 	MT7623_PIN(195, "I2S4_DATA_IN", 107, DRV_GRP1),
613*4882a593Smuzhiyun 	MT7623_PIN(196, "I2S4_BCK", 108, DRV_GRP1),
614*4882a593Smuzhiyun 	MT7623_PIN(197, "I2S4_LRCK", 109, DRV_GRP1),
615*4882a593Smuzhiyun 	MT7623_PIN(198, "I2S4_MCLK", 110, DRV_GRP1),
616*4882a593Smuzhiyun 	MT7623_PIN(199, "SPI1_CLK", 111, DRV_GRP3),
617*4882a593Smuzhiyun 	MT7623_PIN(200, "SPDIF_OUT", 112, DRV_GRP1),
618*4882a593Smuzhiyun 	MT7623_PIN(201, "SPDIF_IN0", 113, DRV_GRP1),
619*4882a593Smuzhiyun 	MT7623_PIN(202, "SPDIF_IN1", 114, DRV_GRP1),
620*4882a593Smuzhiyun 	MT7623_PIN(203, "PWM0", 115, DRV_GRP1),
621*4882a593Smuzhiyun 	MT7623_PIN(204, "PWM1", 116, DRV_GRP1),
622*4882a593Smuzhiyun 	MT7623_PIN(205, "PWM2", 117, DRV_GRP1),
623*4882a593Smuzhiyun 	MT7623_PIN(206, "PWM3", 118, DRV_GRP1),
624*4882a593Smuzhiyun 	MT7623_PIN(207, "PWM4", 119, DRV_GRP1),
625*4882a593Smuzhiyun 	MT7623_PIN(208, "AUD_EXT_CK1", 120, DRV_GRP1),
626*4882a593Smuzhiyun 	MT7623_PIN(209, "AUD_EXT_CK2", 121, DRV_GRP1),
627*4882a593Smuzhiyun 	MT7623_PIN(210, "AUD_CLOCK", EINT_NA, DRV_GRP3),
628*4882a593Smuzhiyun 	MT7623_PIN(211, "DVP_RESET", EINT_NA, DRV_GRP3),
629*4882a593Smuzhiyun 	MT7623_PIN(212, "DVP_CLOCK", EINT_NA, DRV_GRP3),
630*4882a593Smuzhiyun 	MT7623_PIN(213, "DVP_CS", EINT_NA, DRV_GRP3),
631*4882a593Smuzhiyun 	MT7623_PIN(214, "DVP_CK", EINT_NA, DRV_GRP3),
632*4882a593Smuzhiyun 	MT7623_PIN(215, "DVP_DI", EINT_NA, DRV_GRP3),
633*4882a593Smuzhiyun 	MT7623_PIN(216, "DVP_DO", EINT_NA, DRV_GRP3),
634*4882a593Smuzhiyun 	MT7623_PIN(217, "AP_CS", EINT_NA, DRV_GRP3),
635*4882a593Smuzhiyun 	MT7623_PIN(218, "AP_CK", EINT_NA, DRV_GRP3),
636*4882a593Smuzhiyun 	MT7623_PIN(219, "AP_DI", EINT_NA, DRV_GRP3),
637*4882a593Smuzhiyun 	MT7623_PIN(220, "AP_DO", EINT_NA, DRV_GRP3),
638*4882a593Smuzhiyun 	MT7623_PIN(221, "DVD_BCLK", EINT_NA, DRV_GRP3),
639*4882a593Smuzhiyun 	MT7623_PIN(222, "T8032_CLK", EINT_NA, DRV_GRP3),
640*4882a593Smuzhiyun 	MT7623_PIN(223, "AP_BCLK", EINT_NA, DRV_GRP3),
641*4882a593Smuzhiyun 	MT7623_PIN(224, "HOST_CS", EINT_NA, DRV_GRP3),
642*4882a593Smuzhiyun 	MT7623_PIN(225, "HOST_CK", EINT_NA, DRV_GRP3),
643*4882a593Smuzhiyun 	MT7623_PIN(226, "HOST_DO0", EINT_NA, DRV_GRP3),
644*4882a593Smuzhiyun 	MT7623_PIN(227, "HOST_DO1", EINT_NA, DRV_GRP3),
645*4882a593Smuzhiyun 	MT7623_PIN(228, "SLV_CS", EINT_NA, DRV_GRP3),
646*4882a593Smuzhiyun 	MT7623_PIN(229, "SLV_CK", EINT_NA, DRV_GRP3),
647*4882a593Smuzhiyun 	MT7623_PIN(230, "SLV_DI0", EINT_NA, DRV_GRP3),
648*4882a593Smuzhiyun 	MT7623_PIN(231, "SLV_DI1", EINT_NA, DRV_GRP3),
649*4882a593Smuzhiyun 	MT7623_PIN(232, "AP2DSP_INT", EINT_NA, DRV_GRP3),
650*4882a593Smuzhiyun 	MT7623_PIN(233, "AP2DSP_INT_CLR", EINT_NA, DRV_GRP3),
651*4882a593Smuzhiyun 	MT7623_PIN(234, "DSP2AP_INT", EINT_NA, DRV_GRP3),
652*4882a593Smuzhiyun 	MT7623_PIN(235, "DSP2AP_INT_CLR", EINT_NA, DRV_GRP3),
653*4882a593Smuzhiyun 	MT7623_PIN(236, "EXT_SDIO3", 122, DRV_GRP1),
654*4882a593Smuzhiyun 	MT7623_PIN(237, "EXT_SDIO2", 123, DRV_GRP1),
655*4882a593Smuzhiyun 	MT7623_PIN(238, "EXT_SDIO1", 124, DRV_GRP1),
656*4882a593Smuzhiyun 	MT7623_PIN(239, "EXT_SDIO0", 125, DRV_GRP1),
657*4882a593Smuzhiyun 	MT7623_PIN(240, "EXT_XCS", 126, DRV_GRP1),
658*4882a593Smuzhiyun 	MT7623_PIN(241, "EXT_SCK", 127, DRV_GRP1),
659*4882a593Smuzhiyun 	MT7623_PIN(242, "URTS2", 128, DRV_GRP1),
660*4882a593Smuzhiyun 	MT7623_PIN(243, "UCTS2", 129, DRV_GRP1),
661*4882a593Smuzhiyun 	MT7623_PIN(244, "HDMI_SDA_RX", 130, DRV_FIXED),
662*4882a593Smuzhiyun 	MT7623_PIN(245, "HDMI_SCL_RX", 131, DRV_FIXED),
663*4882a593Smuzhiyun 	MT7623_PIN(246, "MHL_SENCE", 132, DRV_FIXED),
664*4882a593Smuzhiyun 	MT7623_PIN(247, "HDMI_HPD_CBUS_RX", 69, DRV_FIXED),
665*4882a593Smuzhiyun 	MT7623_PIN(248, "HDMI_TESTOUTP_RX", 133, DRV_GRP1),
666*4882a593Smuzhiyun 	MT7623_PIN(249, "MSDC0E_RSTB", 134, DRV_GRP4),
667*4882a593Smuzhiyun 	MT7623_PIN(250, "MSDC0E_DAT7", 135, DRV_GRP4),
668*4882a593Smuzhiyun 	MT7623_PIN(251, "MSDC0E_DAT6", 136, DRV_GRP4),
669*4882a593Smuzhiyun 	MT7623_PIN(252, "MSDC0E_DAT5", 137, DRV_GRP4),
670*4882a593Smuzhiyun 	MT7623_PIN(253, "MSDC0E_DAT4", 138, DRV_GRP4),
671*4882a593Smuzhiyun 	MT7623_PIN(254, "MSDC0E_DAT3", 139, DRV_GRP4),
672*4882a593Smuzhiyun 	MT7623_PIN(255, "MSDC0E_DAT2", 140, DRV_GRP4),
673*4882a593Smuzhiyun 	MT7623_PIN(256, "MSDC0E_DAT1", 141, DRV_GRP4),
674*4882a593Smuzhiyun 	MT7623_PIN(257, "MSDC0E_DAT0", 142, DRV_GRP4),
675*4882a593Smuzhiyun 	MT7623_PIN(258, "MSDC0E_CMD", 143, DRV_GRP4),
676*4882a593Smuzhiyun 	MT7623_PIN(259, "MSDC0E_CLK", 144, DRV_GRP4),
677*4882a593Smuzhiyun 	MT7623_PIN(260, "MSDC0E_DSL", 145, DRV_GRP4),
678*4882a593Smuzhiyun 	MT7623_PIN(261, "MSDC1_INS", 146, DRV_GRP4),
679*4882a593Smuzhiyun 	MT7623_PIN(262, "G2_TXEN", 8, DRV_GRP1),
680*4882a593Smuzhiyun 	MT7623_PIN(263, "G2_TXD3", 9, DRV_GRP1),
681*4882a593Smuzhiyun 	MT7623_PIN(264, "G2_TXD2", 10, DRV_GRP1),
682*4882a593Smuzhiyun 	MT7623_PIN(265, "G2_TXD1", 11, DRV_GRP1),
683*4882a593Smuzhiyun 	MT7623_PIN(266, "G2_TXD0", EINT_NA, DRV_GRP1),
684*4882a593Smuzhiyun 	MT7623_PIN(267, "G2_TXC", EINT_NA, DRV_GRP1),
685*4882a593Smuzhiyun 	MT7623_PIN(268, "G2_RXC", EINT_NA, DRV_GRP1),
686*4882a593Smuzhiyun 	MT7623_PIN(269, "G2_RXD0", EINT_NA, DRV_GRP1),
687*4882a593Smuzhiyun 	MT7623_PIN(270, "G2_RXD1", EINT_NA, DRV_GRP1),
688*4882a593Smuzhiyun 	MT7623_PIN(271, "G2_RXD2", EINT_NA, DRV_GRP1),
689*4882a593Smuzhiyun 	MT7623_PIN(272, "G2_RXD3", EINT_NA, DRV_GRP1),
690*4882a593Smuzhiyun 	MT7623_PIN(273, "ESW_INT", 168, DRV_GRP1),
691*4882a593Smuzhiyun 	MT7623_PIN(274, "G2_RXDV", EINT_NA, DRV_GRP1),
692*4882a593Smuzhiyun 	MT7623_PIN(275, "MDC", EINT_NA, DRV_GRP1),
693*4882a593Smuzhiyun 	MT7623_PIN(276, "MDIO", EINT_NA, DRV_GRP1),
694*4882a593Smuzhiyun 	MT7623_PIN(277, "ESW_RST", EINT_NA, DRV_GRP1),
695*4882a593Smuzhiyun 	MT7623_PIN(278, "JTAG_RESET", 147, DRV_GRP3),
696*4882a593Smuzhiyun 	MT7623_PIN(279, "USB3_RES_BOND", EINT_NA, DRV_GRP1),
697*4882a593Smuzhiyun };
698*4882a593Smuzhiyun 
699*4882a593Smuzhiyun /* List all groups consisting of these pins dedicated to the enablement of
700*4882a593Smuzhiyun  * certain hardware block and the corresponding mode for all of the pins.
701*4882a593Smuzhiyun  * The hardware probably has multiple combinations of these pinouts.
702*4882a593Smuzhiyun  */
703*4882a593Smuzhiyun 
704*4882a593Smuzhiyun /* AUDIO EXT CLK */
705*4882a593Smuzhiyun static int mt7623_aud_ext_clk0_pins[] = { 208, };
706*4882a593Smuzhiyun static int mt7623_aud_ext_clk0_funcs[] = { 1, };
707*4882a593Smuzhiyun static int mt7623_aud_ext_clk1_pins[] = { 209, };
708*4882a593Smuzhiyun static int mt7623_aud_ext_clk1_funcs[] = { 1, };
709*4882a593Smuzhiyun 
710*4882a593Smuzhiyun /* DISP PWM */
711*4882a593Smuzhiyun static int mt7623_disp_pwm_0_pins[] = { 72, };
712*4882a593Smuzhiyun static int mt7623_disp_pwm_0_funcs[] = { 5, };
713*4882a593Smuzhiyun static int mt7623_disp_pwm_1_pins[] = { 203, };
714*4882a593Smuzhiyun static int mt7623_disp_pwm_1_funcs[] = { 2, };
715*4882a593Smuzhiyun static int mt7623_disp_pwm_2_pins[] = { 208, };
716*4882a593Smuzhiyun static int mt7623_disp_pwm_2_funcs[] = { 5, };
717*4882a593Smuzhiyun 
718*4882a593Smuzhiyun /* ESW */
719*4882a593Smuzhiyun static int mt7623_esw_int_pins[] = { 273, };
720*4882a593Smuzhiyun static int mt7623_esw_int_funcs[] = { 1, };
721*4882a593Smuzhiyun static int mt7623_esw_rst_pins[] = { 277, };
722*4882a593Smuzhiyun static int mt7623_esw_rst_funcs[] = { 1, };
723*4882a593Smuzhiyun 
724*4882a593Smuzhiyun /* EPHY */
725*4882a593Smuzhiyun static int mt7623_ephy_pins[] = { 262, 263, 264, 265, 266, 267, 268,
726*4882a593Smuzhiyun 				  269, 270, 271, 272, 274, };
727*4882a593Smuzhiyun static int mt7623_ephy_funcs[] = { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, };
728*4882a593Smuzhiyun 
729*4882a593Smuzhiyun /* EXT_SDIO */
730*4882a593Smuzhiyun static int mt7623_ext_sdio_pins[] = { 236, 237, 238, 239, 240, 241, };
731*4882a593Smuzhiyun static int mt7623_ext_sdio_funcs[] = { 1, 1, 1, 1, 1, 1, };
732*4882a593Smuzhiyun 
733*4882a593Smuzhiyun /* HDMI RX */
734*4882a593Smuzhiyun static int mt7623_hdmi_rx_pins[] = { 247, 248, };
735*4882a593Smuzhiyun static int mt7623_hdmi_rx_funcs[] = { 1, 1 };
736*4882a593Smuzhiyun static int mt7623_hdmi_rx_i2c_pins[] = { 244, 245, };
737*4882a593Smuzhiyun static int mt7623_hdmi_rx_i2c_funcs[] = { 1, 1 };
738*4882a593Smuzhiyun 
739*4882a593Smuzhiyun /* HDMI TX */
740*4882a593Smuzhiyun static int mt7623_hdmi_cec_pins[] = { 122, };
741*4882a593Smuzhiyun static int mt7623_hdmi_cec_funcs[] = { 1, };
742*4882a593Smuzhiyun static int mt7623_hdmi_htplg_pins[] = { 123, };
743*4882a593Smuzhiyun static int mt7623_hdmi_htplg_funcs[] = { 1, };
744*4882a593Smuzhiyun static int mt7623_hdmi_i2c_pins[] = { 124, 125, };
745*4882a593Smuzhiyun static int mt7623_hdmi_i2c_funcs[] = { 1, 1 };
746*4882a593Smuzhiyun 
747*4882a593Smuzhiyun /* I2C */
748*4882a593Smuzhiyun static int mt7623_i2c0_pins[] = { 75, 76, };
749*4882a593Smuzhiyun static int mt7623_i2c0_funcs[] = { 1, 1, };
750*4882a593Smuzhiyun static int mt7623_i2c1_0_pins[] = { 57, 58, };
751*4882a593Smuzhiyun static int mt7623_i2c1_0_funcs[] = { 1, 1, };
752*4882a593Smuzhiyun static int mt7623_i2c1_1_pins[] = { 242, 243, };
753*4882a593Smuzhiyun static int mt7623_i2c1_1_funcs[] = { 4, 4, };
754*4882a593Smuzhiyun static int mt7623_i2c1_2_pins[] = { 85, 86, };
755*4882a593Smuzhiyun static int mt7623_i2c1_2_funcs[] = { 3, 3, };
756*4882a593Smuzhiyun static int mt7623_i2c1_3_pins[] = { 105, 106, };
757*4882a593Smuzhiyun static int mt7623_i2c1_3_funcs[] = { 3, 3, };
758*4882a593Smuzhiyun static int mt7623_i2c1_4_pins[] = { 124, 125, };
759*4882a593Smuzhiyun static int mt7623_i2c1_4_funcs[] = { 4, 4, };
760*4882a593Smuzhiyun static int mt7623_i2c2_0_pins[] = { 77, 78, };
761*4882a593Smuzhiyun static int mt7623_i2c2_0_funcs[] = { 1, 1, };
762*4882a593Smuzhiyun static int mt7623_i2c2_1_pins[] = { 89, 90, };
763*4882a593Smuzhiyun static int mt7623_i2c2_1_funcs[] = { 3, 3, };
764*4882a593Smuzhiyun static int mt7623_i2c2_2_pins[] = { 109, 110, };
765*4882a593Smuzhiyun static int mt7623_i2c2_2_funcs[] = { 3, 3, };
766*4882a593Smuzhiyun static int mt7623_i2c2_3_pins[] = { 122, 123, };
767*4882a593Smuzhiyun static int mt7623_i2c2_3_funcs[] = { 4, 4, };
768*4882a593Smuzhiyun 
769*4882a593Smuzhiyun /* I2S */
770*4882a593Smuzhiyun static int mt7623_i2s0_pins[] = { 49, 72, 73, 74, 126, };
771*4882a593Smuzhiyun static int mt7623_i2s0_funcs[] = { 1, 1, 1, 1, 1, };
772*4882a593Smuzhiyun static int mt7623_i2s1_pins[] = { 33, 34, 35, 36, 37, };
773*4882a593Smuzhiyun static int mt7623_i2s1_funcs[] = { 1, 1, 1, 1, 1, };
774*4882a593Smuzhiyun static int mt7623_i2s2_bclk_lrclk_mclk_pins[] = { 50, 52, 188, };
775*4882a593Smuzhiyun static int mt7623_i2s2_bclk_lrclk_mclk_funcs[] = { 1, 1, 1, };
776*4882a593Smuzhiyun static int mt7623_i2s2_data_in_pins[] = { 51, };
777*4882a593Smuzhiyun static int mt7623_i2s2_data_in_funcs[] = { 1, };
778*4882a593Smuzhiyun static int mt7623_i2s2_data_0_pins[] = { 203, };
779*4882a593Smuzhiyun static int mt7623_i2s2_data_0_funcs[] = { 9, };
780*4882a593Smuzhiyun static int mt7623_i2s2_data_1_pins[] = { 38,  };
781*4882a593Smuzhiyun static int mt7623_i2s2_data_1_funcs[] = { 4, };
782*4882a593Smuzhiyun static int mt7623_i2s3_bclk_lrclk_mclk_pins[] = { 191, 192, 193, };
783*4882a593Smuzhiyun static int mt7623_i2s3_bclk_lrclk_mclk_funcs[] = { 1, 1, 1, };
784*4882a593Smuzhiyun static int mt7623_i2s3_data_in_pins[] = { 190, };
785*4882a593Smuzhiyun static int mt7623_i2s3_data_in_funcs[] = { 1, };
786*4882a593Smuzhiyun static int mt7623_i2s3_data_0_pins[] = { 204, };
787*4882a593Smuzhiyun static int mt7623_i2s3_data_0_funcs[] = { 9, };
788*4882a593Smuzhiyun static int mt7623_i2s3_data_1_pins[] = { 2, };
789*4882a593Smuzhiyun static int mt7623_i2s3_data_1_funcs[] = { 0, };
790*4882a593Smuzhiyun static int mt7623_i2s4_pins[] = { 194, 195, 196, 197, 198, };
791*4882a593Smuzhiyun static int mt7623_i2s4_funcs[] = { 1, 1, 1, 1, 1, };
792*4882a593Smuzhiyun static int mt7623_i2s5_pins[] = { 16, 17, 30, 31, 32, };
793*4882a593Smuzhiyun static int mt7623_i2s5_funcs[] = { 1, 1, 1, 1, 1, };
794*4882a593Smuzhiyun 
795*4882a593Smuzhiyun /* IR */
796*4882a593Smuzhiyun static int mt7623_ir_pins[] = { 46, };
797*4882a593Smuzhiyun static int mt7623_ir_funcs[] = { 1, };
798*4882a593Smuzhiyun 
799*4882a593Smuzhiyun /* LCD */
800*4882a593Smuzhiyun static int mt7623_mipi_tx_pins[] = { 91, 92, 93, 94, 95, 96, 97, 98,
801*4882a593Smuzhiyun 				     99, 100, };
802*4882a593Smuzhiyun static int mt7623_mipi_tx_funcs[] = { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, };
803*4882a593Smuzhiyun static int mt7623_dsi_te_pins[] = { 84, };
804*4882a593Smuzhiyun static int mt7623_dsi_te_funcs[] = { 1, };
805*4882a593Smuzhiyun static int mt7623_lcm_rst_pins[] = { 83, };
806*4882a593Smuzhiyun static int mt7623_lcm_rst_funcs[] = { 1, };
807*4882a593Smuzhiyun 
808*4882a593Smuzhiyun /* MDC/MDIO */
809*4882a593Smuzhiyun static int mt7623_mdc_mdio_pins[] = { 275, 276, };
810*4882a593Smuzhiyun static int mt7623_mdc_mdio_funcs[] = { 1, 1, };
811*4882a593Smuzhiyun 
812*4882a593Smuzhiyun /* MSDC */
813*4882a593Smuzhiyun static int mt7623_msdc0_pins[] = { 111, 112, 113, 114, 115, 116, 117, 118,
814*4882a593Smuzhiyun 				   119, 120, 121, };
815*4882a593Smuzhiyun static int mt7623_msdc0_funcs[] = { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, };
816*4882a593Smuzhiyun static int mt7623_msdc1_pins[] = { 105, 106, 107, 108, 109, 110, };
817*4882a593Smuzhiyun static int mt7623_msdc1_funcs[] = { 1, 1, 1, 1, 1, 1, };
818*4882a593Smuzhiyun static int mt7623_msdc1_ins_pins[] = { 261, };
819*4882a593Smuzhiyun static int mt7623_msdc1_ins_funcs[] = { 1, };
820*4882a593Smuzhiyun static int mt7623_msdc1_wp_0_pins[] = { 29, };
821*4882a593Smuzhiyun static int mt7623_msdc1_wp_0_funcs[] = { 1, };
822*4882a593Smuzhiyun static int mt7623_msdc1_wp_1_pins[] = { 55, };
823*4882a593Smuzhiyun static int mt7623_msdc1_wp_1_funcs[] = { 3, };
824*4882a593Smuzhiyun static int mt7623_msdc1_wp_2_pins[] = { 209, };
825*4882a593Smuzhiyun static int mt7623_msdc1_wp_2_funcs[] = { 2, };
826*4882a593Smuzhiyun static int mt7623_msdc2_pins[] = { 85, 86, 87, 88, 89, 90, };
827*4882a593Smuzhiyun static int mt7623_msdc2_funcs[] = { 1, 1, 1, 1, 1, 1, };
828*4882a593Smuzhiyun static int mt7623_msdc3_pins[] = { 249, 250, 251, 252, 253, 254, 255, 256,
829*4882a593Smuzhiyun 				   257, 258, 259, 260, };
830*4882a593Smuzhiyun static int mt7623_msdc3_funcs[] = { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, };
831*4882a593Smuzhiyun 
832*4882a593Smuzhiyun /* NAND */
833*4882a593Smuzhiyun static int mt7623_nandc_pins[] = { 43, 47, 48, 111, 112, 113, 114, 115,
834*4882a593Smuzhiyun 				   116, 117, 118, 119, 120, 121, };
835*4882a593Smuzhiyun static int mt7623_nandc_funcs[] = { 1, 1, 1, 4, 4, 4, 4, 4, 4, 4, 4, 4,
836*4882a593Smuzhiyun 				   4, 4, };
837*4882a593Smuzhiyun static int mt7623_nandc_ceb0_pins[] = { 45, };
838*4882a593Smuzhiyun static int mt7623_nandc_ceb0_funcs[] = { 1, };
839*4882a593Smuzhiyun static int mt7623_nandc_ceb1_pins[] = { 44, };
840*4882a593Smuzhiyun static int mt7623_nandc_ceb1_funcs[] = { 1, };
841*4882a593Smuzhiyun 
842*4882a593Smuzhiyun /* RTC */
843*4882a593Smuzhiyun static int mt7623_rtc_pins[] = { 10, };
844*4882a593Smuzhiyun static int mt7623_rtc_funcs[] = { 1, };
845*4882a593Smuzhiyun 
846*4882a593Smuzhiyun /* OTG */
847*4882a593Smuzhiyun static int mt7623_otg_iddig0_0_pins[] = { 29, };
848*4882a593Smuzhiyun static int mt7623_otg_iddig0_0_funcs[] = { 1, };
849*4882a593Smuzhiyun static int mt7623_otg_iddig0_1_pins[] = { 44, };
850*4882a593Smuzhiyun static int mt7623_otg_iddig0_1_funcs[] = { 2, };
851*4882a593Smuzhiyun static int mt7623_otg_iddig0_2_pins[] = { 236, };
852*4882a593Smuzhiyun static int mt7623_otg_iddig0_2_funcs[] = { 2, };
853*4882a593Smuzhiyun static int mt7623_otg_iddig1_0_pins[] = { 27, };
854*4882a593Smuzhiyun static int mt7623_otg_iddig1_0_funcs[] = { 2, };
855*4882a593Smuzhiyun static int mt7623_otg_iddig1_1_pins[] = { 47, };
856*4882a593Smuzhiyun static int mt7623_otg_iddig1_1_funcs[] = { 2, };
857*4882a593Smuzhiyun static int mt7623_otg_iddig1_2_pins[] = { 238, };
858*4882a593Smuzhiyun static int mt7623_otg_iddig1_2_funcs[] = { 2, };
859*4882a593Smuzhiyun static int mt7623_otg_drv_vbus0_0_pins[] = { 28, };
860*4882a593Smuzhiyun static int mt7623_otg_drv_vbus0_0_funcs[] = { 1, };
861*4882a593Smuzhiyun static int mt7623_otg_drv_vbus0_1_pins[] = { 45, };
862*4882a593Smuzhiyun static int mt7623_otg_drv_vbus0_1_funcs[] = { 2, };
863*4882a593Smuzhiyun static int mt7623_otg_drv_vbus0_2_pins[] = { 237, };
864*4882a593Smuzhiyun static int mt7623_otg_drv_vbus0_2_funcs[] = { 2, };
865*4882a593Smuzhiyun static int mt7623_otg_drv_vbus1_0_pins[] = { 26, };
866*4882a593Smuzhiyun static int mt7623_otg_drv_vbus1_0_funcs[] = { 2, };
867*4882a593Smuzhiyun static int mt7623_otg_drv_vbus1_1_pins[] = { 48, };
868*4882a593Smuzhiyun static int mt7623_otg_drv_vbus1_1_funcs[] = { 2, };
869*4882a593Smuzhiyun static int mt7623_otg_drv_vbus1_2_pins[] = { 239, };
870*4882a593Smuzhiyun static int mt7623_otg_drv_vbus1_2_funcs[] = { 2, };
871*4882a593Smuzhiyun 
872*4882a593Smuzhiyun /* PCIE */
873*4882a593Smuzhiyun static int mt7623_pcie0_0_perst_pins[] = { 208, };
874*4882a593Smuzhiyun static int mt7623_pcie0_0_perst_funcs[] = { 3, };
875*4882a593Smuzhiyun static int mt7623_pcie0_1_perst_pins[] = { 22, };
876*4882a593Smuzhiyun static int mt7623_pcie0_1_perst_funcs[] = { 2, };
877*4882a593Smuzhiyun static int mt7623_pcie1_0_perst_pins[] = { 209, };
878*4882a593Smuzhiyun static int mt7623_pcie1_0_perst_funcs[] = { 3, };
879*4882a593Smuzhiyun static int mt7623_pcie1_1_perst_pins[] = { 23, };
880*4882a593Smuzhiyun static int mt7623_pcie1_1_perst_funcs[] = { 2, };
881*4882a593Smuzhiyun static int mt7623_pcie2_0_perst_pins[] = { 24, };
882*4882a593Smuzhiyun static int mt7623_pcie2_0_perst_funcs[] = { 2, };
883*4882a593Smuzhiyun static int mt7623_pcie2_1_perst_pins[] = { 29, };
884*4882a593Smuzhiyun static int mt7623_pcie2_1_perst_funcs[] = { 6, };
885*4882a593Smuzhiyun static int mt7623_pcie0_0_wake_pins[] = { 28, };
886*4882a593Smuzhiyun static int mt7623_pcie0_0_wake_funcs[] = { 6, };
887*4882a593Smuzhiyun static int mt7623_pcie0_1_wake_pins[] = { 251, };
888*4882a593Smuzhiyun static int mt7623_pcie0_1_wake_funcs[] = { 6, };
889*4882a593Smuzhiyun static int mt7623_pcie1_0_wake_pins[] = { 27, };
890*4882a593Smuzhiyun static int mt7623_pcie1_0_wake_funcs[] = { 6, };
891*4882a593Smuzhiyun static int mt7623_pcie1_1_wake_pins[] = { 253, };
892*4882a593Smuzhiyun static int mt7623_pcie1_1_wake_funcs[] = { 6, };
893*4882a593Smuzhiyun static int mt7623_pcie2_0_wake_pins[] = { 26, };
894*4882a593Smuzhiyun static int mt7623_pcie2_0_wake_funcs[] = { 6, };
895*4882a593Smuzhiyun static int mt7623_pcie2_1_wake_pins[] = { 255, };
896*4882a593Smuzhiyun static int mt7623_pcie2_1_wake_funcs[] = { 6, };
897*4882a593Smuzhiyun static int mt7623_pcie0_clkreq_pins[] = { 250, };
898*4882a593Smuzhiyun static int mt7623_pcie0_clkreq_funcs[] = { 6, };
899*4882a593Smuzhiyun static int mt7623_pcie1_clkreq_pins[] = { 252, };
900*4882a593Smuzhiyun static int mt7623_pcie1_clkreq_funcs[] = { 6, };
901*4882a593Smuzhiyun static int mt7623_pcie2_clkreq_pins[] = { 254, };
902*4882a593Smuzhiyun static int mt7623_pcie2_clkreq_funcs[] = { 6, };
903*4882a593Smuzhiyun 
904*4882a593Smuzhiyun /* the pcie_*_rev are only used for MT7623 */
905*4882a593Smuzhiyun static int mt7623_pcie0_0_rev_perst_pins[] = { 208, };
906*4882a593Smuzhiyun static int mt7623_pcie0_0_rev_perst_funcs[] = { 11, };
907*4882a593Smuzhiyun static int mt7623_pcie0_1_rev_perst_pins[] = { 22, };
908*4882a593Smuzhiyun static int mt7623_pcie0_1_rev_perst_funcs[] = { 10, };
909*4882a593Smuzhiyun static int mt7623_pcie1_0_rev_perst_pins[] = { 209, };
910*4882a593Smuzhiyun static int mt7623_pcie1_0_rev_perst_funcs[] = { 11, };
911*4882a593Smuzhiyun static int mt7623_pcie1_1_rev_perst_pins[] = { 23, };
912*4882a593Smuzhiyun static int mt7623_pcie1_1_rev_perst_funcs[] = { 10, };
913*4882a593Smuzhiyun static int mt7623_pcie2_0_rev_perst_pins[] = { 24, };
914*4882a593Smuzhiyun static int mt7623_pcie2_0_rev_perst_funcs[] = { 11, };
915*4882a593Smuzhiyun static int mt7623_pcie2_1_rev_perst_pins[] = { 29, };
916*4882a593Smuzhiyun static int mt7623_pcie2_1_rev_perst_funcs[] = { 14, };
917*4882a593Smuzhiyun 
918*4882a593Smuzhiyun /* PCM */
919*4882a593Smuzhiyun static int mt7623_pcm_clk_0_pins[] = { 18, };
920*4882a593Smuzhiyun static int mt7623_pcm_clk_0_funcs[] = { 1, };
921*4882a593Smuzhiyun static int mt7623_pcm_clk_1_pins[] = { 17, };
922*4882a593Smuzhiyun static int mt7623_pcm_clk_1_funcs[] = { 3, };
923*4882a593Smuzhiyun static int mt7623_pcm_clk_2_pins[] = { 35, };
924*4882a593Smuzhiyun static int mt7623_pcm_clk_2_funcs[] = { 3, };
925*4882a593Smuzhiyun static int mt7623_pcm_clk_3_pins[] = { 50, };
926*4882a593Smuzhiyun static int mt7623_pcm_clk_3_funcs[] = { 3, };
927*4882a593Smuzhiyun static int mt7623_pcm_clk_4_pins[] = { 74, };
928*4882a593Smuzhiyun static int mt7623_pcm_clk_4_funcs[] = { 3, };
929*4882a593Smuzhiyun static int mt7623_pcm_clk_5_pins[] = { 191, };
930*4882a593Smuzhiyun static int mt7623_pcm_clk_5_funcs[] = { 3, };
931*4882a593Smuzhiyun static int mt7623_pcm_clk_6_pins[] = { 196, };
932*4882a593Smuzhiyun static int mt7623_pcm_clk_6_funcs[] = { 3, };
933*4882a593Smuzhiyun static int mt7623_pcm_sync_0_pins[] = { 19, };
934*4882a593Smuzhiyun static int mt7623_pcm_sync_0_funcs[] = { 1, };
935*4882a593Smuzhiyun static int mt7623_pcm_sync_1_pins[] = { 30, };
936*4882a593Smuzhiyun static int mt7623_pcm_sync_1_funcs[] = { 3, };
937*4882a593Smuzhiyun static int mt7623_pcm_sync_2_pins[] = { 36, };
938*4882a593Smuzhiyun static int mt7623_pcm_sync_2_funcs[] = { 3, };
939*4882a593Smuzhiyun static int mt7623_pcm_sync_3_pins[] = { 52, };
940*4882a593Smuzhiyun static int mt7623_pcm_sync_3_funcs[] = { 31, };
941*4882a593Smuzhiyun static int mt7623_pcm_sync_4_pins[] = { 73, };
942*4882a593Smuzhiyun static int mt7623_pcm_sync_4_funcs[] = { 3, };
943*4882a593Smuzhiyun static int mt7623_pcm_sync_5_pins[] = { 192, };
944*4882a593Smuzhiyun static int mt7623_pcm_sync_5_funcs[] = { 3, };
945*4882a593Smuzhiyun static int mt7623_pcm_sync_6_pins[] = { 197, };
946*4882a593Smuzhiyun static int mt7623_pcm_sync_6_funcs[] = { 3, };
947*4882a593Smuzhiyun static int mt7623_pcm_rx_0_pins[] = { 20, };
948*4882a593Smuzhiyun static int mt7623_pcm_rx_0_funcs[] = { 1, };
949*4882a593Smuzhiyun static int mt7623_pcm_rx_1_pins[] = { 16, };
950*4882a593Smuzhiyun static int mt7623_pcm_rx_1_funcs[] = { 3, };
951*4882a593Smuzhiyun static int mt7623_pcm_rx_2_pins[] = { 34, };
952*4882a593Smuzhiyun static int mt7623_pcm_rx_2_funcs[] = { 3, };
953*4882a593Smuzhiyun static int mt7623_pcm_rx_3_pins[] = { 51, };
954*4882a593Smuzhiyun static int mt7623_pcm_rx_3_funcs[] = { 3, };
955*4882a593Smuzhiyun static int mt7623_pcm_rx_4_pins[] = { 72, };
956*4882a593Smuzhiyun static int mt7623_pcm_rx_4_funcs[] = { 3, };
957*4882a593Smuzhiyun static int mt7623_pcm_rx_5_pins[] = { 190, };
958*4882a593Smuzhiyun static int mt7623_pcm_rx_5_funcs[] = { 3, };
959*4882a593Smuzhiyun static int mt7623_pcm_rx_6_pins[] = { 195, };
960*4882a593Smuzhiyun static int mt7623_pcm_rx_6_funcs[] = { 3, };
961*4882a593Smuzhiyun static int mt7623_pcm_tx_0_pins[] = { 21, };
962*4882a593Smuzhiyun static int mt7623_pcm_tx_0_funcs[] = { 1, };
963*4882a593Smuzhiyun static int mt7623_pcm_tx_1_pins[] = { 32, };
964*4882a593Smuzhiyun static int mt7623_pcm_tx_1_funcs[] = { 3, };
965*4882a593Smuzhiyun static int mt7623_pcm_tx_2_pins[] = { 33, };
966*4882a593Smuzhiyun static int mt7623_pcm_tx_2_funcs[] = { 3, };
967*4882a593Smuzhiyun static int mt7623_pcm_tx_3_pins[] = { 38, };
968*4882a593Smuzhiyun static int mt7623_pcm_tx_3_funcs[] = { 3, };
969*4882a593Smuzhiyun static int mt7623_pcm_tx_4_pins[] = { 49, };
970*4882a593Smuzhiyun static int mt7623_pcm_tx_4_funcs[] = { 3, };
971*4882a593Smuzhiyun static int mt7623_pcm_tx_5_pins[] = { 189, };
972*4882a593Smuzhiyun static int mt7623_pcm_tx_5_funcs[] = { 3, };
973*4882a593Smuzhiyun static int mt7623_pcm_tx_6_pins[] = { 194, };
974*4882a593Smuzhiyun static int mt7623_pcm_tx_6_funcs[] = { 3, };
975*4882a593Smuzhiyun 
976*4882a593Smuzhiyun /* PWM */
977*4882a593Smuzhiyun static int mt7623_pwm_ch1_0_pins[] = { 203, };
978*4882a593Smuzhiyun static int mt7623_pwm_ch1_0_funcs[] = { 1, };
979*4882a593Smuzhiyun static int mt7623_pwm_ch1_1_pins[] = { 208, };
980*4882a593Smuzhiyun static int mt7623_pwm_ch1_1_funcs[] = { 2, };
981*4882a593Smuzhiyun static int mt7623_pwm_ch1_2_pins[] = { 72, };
982*4882a593Smuzhiyun static int mt7623_pwm_ch1_2_funcs[] = { 4, };
983*4882a593Smuzhiyun static int mt7623_pwm_ch1_3_pins[] = { 88, };
984*4882a593Smuzhiyun static int mt7623_pwm_ch1_3_funcs[] = { 3, };
985*4882a593Smuzhiyun static int mt7623_pwm_ch1_4_pins[] = { 108, };
986*4882a593Smuzhiyun static int mt7623_pwm_ch1_4_funcs[] = { 3, };
987*4882a593Smuzhiyun static int mt7623_pwm_ch2_0_pins[] = { 204, };
988*4882a593Smuzhiyun static int mt7623_pwm_ch2_0_funcs[] = { 1, };
989*4882a593Smuzhiyun static int mt7623_pwm_ch2_1_pins[] = { 53, };
990*4882a593Smuzhiyun static int mt7623_pwm_ch2_1_funcs[] = { 5, };
991*4882a593Smuzhiyun static int mt7623_pwm_ch2_2_pins[] = { 88, };
992*4882a593Smuzhiyun static int mt7623_pwm_ch2_2_funcs[] = { 6, };
993*4882a593Smuzhiyun static int mt7623_pwm_ch2_3_pins[] = { 108, };
994*4882a593Smuzhiyun static int mt7623_pwm_ch2_3_funcs[] = { 6, };
995*4882a593Smuzhiyun static int mt7623_pwm_ch2_4_pins[] = { 209, };
996*4882a593Smuzhiyun static int mt7623_pwm_ch2_4_funcs[] = { 5, };
997*4882a593Smuzhiyun static int mt7623_pwm_ch3_0_pins[] = { 205, };
998*4882a593Smuzhiyun static int mt7623_pwm_ch3_0_funcs[] = { 1, };
999*4882a593Smuzhiyun static int mt7623_pwm_ch3_1_pins[] = { 55, };
1000*4882a593Smuzhiyun static int mt7623_pwm_ch3_1_funcs[] = { 5, };
1001*4882a593Smuzhiyun static int mt7623_pwm_ch3_2_pins[] = { 89, };
1002*4882a593Smuzhiyun static int mt7623_pwm_ch3_2_funcs[] = { 6, };
1003*4882a593Smuzhiyun static int mt7623_pwm_ch3_3_pins[] = { 109, };
1004*4882a593Smuzhiyun static int mt7623_pwm_ch3_3_funcs[] = { 6, };
1005*4882a593Smuzhiyun static int mt7623_pwm_ch4_0_pins[] = { 206, };
1006*4882a593Smuzhiyun static int mt7623_pwm_ch4_0_funcs[] = { 1, };
1007*4882a593Smuzhiyun static int mt7623_pwm_ch4_1_pins[] = { 90, };
1008*4882a593Smuzhiyun static int mt7623_pwm_ch4_1_funcs[] = { 6, };
1009*4882a593Smuzhiyun static int mt7623_pwm_ch4_2_pins[] = { 110, };
1010*4882a593Smuzhiyun static int mt7623_pwm_ch4_2_funcs[] = { 6, };
1011*4882a593Smuzhiyun static int mt7623_pwm_ch4_3_pins[] = { 124, };
1012*4882a593Smuzhiyun static int mt7623_pwm_ch4_3_funcs[] = { 5, };
1013*4882a593Smuzhiyun static int mt7623_pwm_ch5_0_pins[] = { 207, };
1014*4882a593Smuzhiyun static int mt7623_pwm_ch5_0_funcs[] = { 1, };
1015*4882a593Smuzhiyun static int mt7623_pwm_ch5_1_pins[] = { 125, };
1016*4882a593Smuzhiyun static int mt7623_pwm_ch5_1_funcs[] = { 5, };
1017*4882a593Smuzhiyun 
1018*4882a593Smuzhiyun /* PWRAP */
1019*4882a593Smuzhiyun static int mt7623_pwrap_pins[] = { 0, 1, 2, 3, 4, 5, 6, };
1020*4882a593Smuzhiyun static int mt7623_pwrap_funcs[] = { 1, 1, 1, 1, 1, 1, 1, };
1021*4882a593Smuzhiyun 
1022*4882a593Smuzhiyun /* SPDIF */
1023*4882a593Smuzhiyun static int mt7623_spdif_in0_0_pins[] = { 56, };
1024*4882a593Smuzhiyun static int mt7623_spdif_in0_0_funcs[] = { 3, };
1025*4882a593Smuzhiyun static int mt7623_spdif_in0_1_pins[] = { 201, };
1026*4882a593Smuzhiyun static int mt7623_spdif_in0_1_funcs[] = { 1, };
1027*4882a593Smuzhiyun static int mt7623_spdif_in1_0_pins[] = { 54, };
1028*4882a593Smuzhiyun static int mt7623_spdif_in1_0_funcs[] = { 3, };
1029*4882a593Smuzhiyun static int mt7623_spdif_in1_1_pins[] = { 202, };
1030*4882a593Smuzhiyun static int mt7623_spdif_in1_1_funcs[] = { 1, };
1031*4882a593Smuzhiyun static int mt7623_spdif_out_pins[] = { 202, };
1032*4882a593Smuzhiyun static int mt7623_spdif_out_funcs[] = { 1, };
1033*4882a593Smuzhiyun 
1034*4882a593Smuzhiyun /* SPI */
1035*4882a593Smuzhiyun static int mt7623_spi0_pins[] = { 53, 54, 55, 56, };
1036*4882a593Smuzhiyun static int mt7623_spi0_funcs[] = { 1, 1, 1, 1, };
1037*4882a593Smuzhiyun static int mt7623_spi1_pins[] = { 7, 199, 8, 9, };
1038*4882a593Smuzhiyun static int mt7623_spi1_funcs[] = { 1, 1, 1, 1, };
1039*4882a593Smuzhiyun static int mt7623_spi2_pins[] = { 101, 104, 102, 103, };
1040*4882a593Smuzhiyun static int mt7623_spi2_funcs[] = { 1, 1, 1, 1, };
1041*4882a593Smuzhiyun 
1042*4882a593Smuzhiyun /* UART */
1043*4882a593Smuzhiyun static int mt7623_uart0_0_txd_rxd_pins[] = { 79, 80, };
1044*4882a593Smuzhiyun static int mt7623_uart0_0_txd_rxd_funcs[] = { 1, 1, };
1045*4882a593Smuzhiyun static int mt7623_uart0_1_txd_rxd_pins[] = { 87, 88, };
1046*4882a593Smuzhiyun static int mt7623_uart0_1_txd_rxd_funcs[] = { 5, 5, };
1047*4882a593Smuzhiyun static int mt7623_uart0_2_txd_rxd_pins[] = { 107, 108, };
1048*4882a593Smuzhiyun static int mt7623_uart0_2_txd_rxd_funcs[] = { 5, 5, };
1049*4882a593Smuzhiyun static int mt7623_uart0_3_txd_rxd_pins[] = { 123, 122, };
1050*4882a593Smuzhiyun static int mt7623_uart0_3_txd_rxd_funcs[] = { 5, 5, };
1051*4882a593Smuzhiyun static int mt7623_uart0_rts_cts_pins[] = { 22, 23, };
1052*4882a593Smuzhiyun static int mt7623_uart0_rts_cts_funcs[] = { 1, 1, };
1053*4882a593Smuzhiyun static int mt7623_uart1_0_txd_rxd_pins[] = { 81, 82, };
1054*4882a593Smuzhiyun static int mt7623_uart1_0_txd_rxd_funcs[] = { 1, 1, };
1055*4882a593Smuzhiyun static int mt7623_uart1_1_txd_rxd_pins[] = { 89, 90, };
1056*4882a593Smuzhiyun static int mt7623_uart1_1_txd_rxd_funcs[] = { 5, 5, };
1057*4882a593Smuzhiyun static int mt7623_uart1_2_txd_rxd_pins[] = { 109, 110, };
1058*4882a593Smuzhiyun static int mt7623_uart1_2_txd_rxd_funcs[] = { 5, 5, };
1059*4882a593Smuzhiyun static int mt7623_uart1_rts_cts_pins[] = { 24, 25, };
1060*4882a593Smuzhiyun static int mt7623_uart1_rts_cts_funcs[] = { 1, 1, };
1061*4882a593Smuzhiyun static int mt7623_uart2_0_txd_rxd_pins[] = { 14, 15, };
1062*4882a593Smuzhiyun static int mt7623_uart2_0_txd_rxd_funcs[] = { 1, 1, };
1063*4882a593Smuzhiyun static int mt7623_uart2_1_txd_rxd_pins[] = { 200, 201, };
1064*4882a593Smuzhiyun static int mt7623_uart2_1_txd_rxd_funcs[] = { 6, 6, };
1065*4882a593Smuzhiyun static int mt7623_uart2_rts_cts_pins[] = { 242, 243, };
1066*4882a593Smuzhiyun static int mt7623_uart2_rts_cts_funcs[] = { 1, 1, };
1067*4882a593Smuzhiyun static int mt7623_uart3_txd_rxd_pins[] = { 242, 243, };
1068*4882a593Smuzhiyun static int mt7623_uart3_txd_rxd_funcs[] = { 2, 2, };
1069*4882a593Smuzhiyun static int mt7623_uart3_rts_cts_pins[] = { 26, 27, };
1070*4882a593Smuzhiyun static int mt7623_uart3_rts_cts_funcs[] = { 1, 1, };
1071*4882a593Smuzhiyun 
1072*4882a593Smuzhiyun /* Watchdog */
1073*4882a593Smuzhiyun static int mt7623_watchdog_0_pins[] = { 11, };
1074*4882a593Smuzhiyun static int mt7623_watchdog_0_funcs[] = { 1, };
1075*4882a593Smuzhiyun static int mt7623_watchdog_1_pins[] = { 121, };
1076*4882a593Smuzhiyun static int mt7623_watchdog_1_funcs[] = { 5, };
1077*4882a593Smuzhiyun 
1078*4882a593Smuzhiyun static const struct group_desc mt7623_groups[] = {
1079*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("aud_ext_clk0", mt7623_aud_ext_clk0),
1080*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("aud_ext_clk1", mt7623_aud_ext_clk1),
1081*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("dsi_te", mt7623_dsi_te),
1082*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("disp_pwm_0", mt7623_disp_pwm_0),
1083*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("disp_pwm_1", mt7623_disp_pwm_1),
1084*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("disp_pwm_2", mt7623_disp_pwm_2),
1085*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("ephy", mt7623_ephy),
1086*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("esw_int", mt7623_esw_int),
1087*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("esw_rst", mt7623_esw_rst),
1088*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("ext_sdio", mt7623_ext_sdio),
1089*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("hdmi_cec", mt7623_hdmi_cec),
1090*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("hdmi_htplg", mt7623_hdmi_htplg),
1091*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("hdmi_i2c", mt7623_hdmi_i2c),
1092*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("hdmi_rx", mt7623_hdmi_rx),
1093*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("hdmi_rx_i2c", mt7623_hdmi_rx_i2c),
1094*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2c0", mt7623_i2c0),
1095*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2c1_0", mt7623_i2c1_0),
1096*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2c1_1", mt7623_i2c1_1),
1097*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2c1_2", mt7623_i2c1_2),
1098*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2c1_3", mt7623_i2c1_3),
1099*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2c1_4", mt7623_i2c1_4),
1100*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2c2_0", mt7623_i2c2_0),
1101*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2c2_1", mt7623_i2c2_1),
1102*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2c2_2", mt7623_i2c2_2),
1103*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2c2_3", mt7623_i2c2_3),
1104*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2s0", mt7623_i2s0),
1105*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2s1", mt7623_i2s1),
1106*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2s4", mt7623_i2s4),
1107*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2s5", mt7623_i2s5),
1108*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2s2_bclk_lrclk_mclk", mt7623_i2s2_bclk_lrclk_mclk),
1109*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2s3_bclk_lrclk_mclk", mt7623_i2s3_bclk_lrclk_mclk),
1110*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2s2_data_in", mt7623_i2s2_data_in),
1111*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2s3_data_in", mt7623_i2s3_data_in),
1112*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2s2_data_0", mt7623_i2s2_data_0),
1113*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2s2_data_1", mt7623_i2s2_data_1),
1114*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2s3_data_0", mt7623_i2s3_data_0),
1115*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("i2s3_data_1", mt7623_i2s3_data_1),
1116*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("ir", mt7623_ir),
1117*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("lcm_rst", mt7623_lcm_rst),
1118*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("mdc_mdio", mt7623_mdc_mdio),
1119*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("mipi_tx", mt7623_mipi_tx),
1120*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("msdc0", mt7623_msdc0),
1121*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("msdc1", mt7623_msdc1),
1122*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("msdc1_ins", mt7623_msdc1_ins),
1123*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("msdc1_wp_0", mt7623_msdc1_wp_0),
1124*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("msdc1_wp_1", mt7623_msdc1_wp_1),
1125*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("msdc1_wp_2", mt7623_msdc1_wp_2),
1126*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("msdc2", mt7623_msdc2),
1127*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("msdc3", mt7623_msdc3),
1128*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("nandc", mt7623_nandc),
1129*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("nandc_ceb0", mt7623_nandc_ceb0),
1130*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("nandc_ceb1", mt7623_nandc_ceb1),
1131*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("otg_iddig0_0", mt7623_otg_iddig0_0),
1132*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("otg_iddig0_1", mt7623_otg_iddig0_1),
1133*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("otg_iddig0_2", mt7623_otg_iddig0_2),
1134*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("otg_iddig1_0", mt7623_otg_iddig1_0),
1135*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("otg_iddig1_1", mt7623_otg_iddig1_1),
1136*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("otg_iddig1_2", mt7623_otg_iddig1_2),
1137*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("otg_drv_vbus0_0", mt7623_otg_drv_vbus0_0),
1138*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("otg_drv_vbus0_1", mt7623_otg_drv_vbus0_1),
1139*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("otg_drv_vbus0_2", mt7623_otg_drv_vbus0_2),
1140*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("otg_drv_vbus1_0", mt7623_otg_drv_vbus1_0),
1141*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("otg_drv_vbus1_1", mt7623_otg_drv_vbus1_1),
1142*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("otg_drv_vbus1_2", mt7623_otg_drv_vbus1_2),
1143*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie0_0_perst", mt7623_pcie0_0_perst),
1144*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie0_1_perst", mt7623_pcie0_1_perst),
1145*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie1_0_perst", mt7623_pcie1_0_perst),
1146*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie1_1_perst", mt7623_pcie1_1_perst),
1147*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie1_1_perst", mt7623_pcie1_1_perst),
1148*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie0_0_rev_perst", mt7623_pcie0_0_rev_perst),
1149*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie0_1_rev_perst", mt7623_pcie0_1_rev_perst),
1150*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie1_0_rev_perst", mt7623_pcie1_0_rev_perst),
1151*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie1_1_rev_perst", mt7623_pcie1_1_rev_perst),
1152*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie2_0_rev_perst", mt7623_pcie2_0_rev_perst),
1153*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie2_1_rev_perst", mt7623_pcie2_1_rev_perst),
1154*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie2_0_perst", mt7623_pcie2_0_perst),
1155*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie2_1_perst", mt7623_pcie2_1_perst),
1156*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie0_0_wake", mt7623_pcie0_0_wake),
1157*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie0_1_wake", mt7623_pcie0_1_wake),
1158*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie1_0_wake", mt7623_pcie1_0_wake),
1159*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie1_1_wake", mt7623_pcie1_1_wake),
1160*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie2_0_wake", mt7623_pcie2_0_wake),
1161*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie2_1_wake", mt7623_pcie2_1_wake),
1162*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie0_clkreq", mt7623_pcie0_clkreq),
1163*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie1_clkreq", mt7623_pcie1_clkreq),
1164*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcie2_clkreq", mt7623_pcie2_clkreq),
1165*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_clk_0", mt7623_pcm_clk_0),
1166*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_clk_1", mt7623_pcm_clk_1),
1167*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_clk_2", mt7623_pcm_clk_2),
1168*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_clk_3", mt7623_pcm_clk_3),
1169*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_clk_4", mt7623_pcm_clk_4),
1170*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_clk_5", mt7623_pcm_clk_5),
1171*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_clk_6", mt7623_pcm_clk_6),
1172*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_sync_0", mt7623_pcm_sync_0),
1173*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_sync_1", mt7623_pcm_sync_1),
1174*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_sync_2", mt7623_pcm_sync_2),
1175*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_sync_3", mt7623_pcm_sync_3),
1176*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_sync_4", mt7623_pcm_sync_4),
1177*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_sync_5", mt7623_pcm_sync_5),
1178*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_sync_6", mt7623_pcm_sync_6),
1179*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_rx_0", mt7623_pcm_rx_0),
1180*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_rx_1", mt7623_pcm_rx_1),
1181*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_rx_2", mt7623_pcm_rx_2),
1182*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_rx_3", mt7623_pcm_rx_3),
1183*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_rx_4", mt7623_pcm_rx_4),
1184*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_rx_5", mt7623_pcm_rx_5),
1185*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_rx_6", mt7623_pcm_rx_6),
1186*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_tx_0", mt7623_pcm_tx_0),
1187*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_tx_1", mt7623_pcm_tx_1),
1188*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_tx_2", mt7623_pcm_tx_2),
1189*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_tx_3", mt7623_pcm_tx_3),
1190*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_tx_4", mt7623_pcm_tx_4),
1191*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_tx_5", mt7623_pcm_tx_5),
1192*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pcm_tx_6", mt7623_pcm_tx_6),
1193*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch1_0", mt7623_pwm_ch1_0),
1194*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch1_1", mt7623_pwm_ch1_1),
1195*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch1_2", mt7623_pwm_ch1_2),
1196*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch1_3", mt7623_pwm_ch1_3),
1197*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch1_4", mt7623_pwm_ch1_4),
1198*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch2_0", mt7623_pwm_ch2_0),
1199*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch2_1", mt7623_pwm_ch2_1),
1200*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch2_2", mt7623_pwm_ch2_2),
1201*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch2_3", mt7623_pwm_ch2_3),
1202*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch2_4", mt7623_pwm_ch2_4),
1203*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch3_0", mt7623_pwm_ch3_0),
1204*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch3_1", mt7623_pwm_ch3_1),
1205*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch3_2", mt7623_pwm_ch3_2),
1206*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch3_3", mt7623_pwm_ch3_3),
1207*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch4_0", mt7623_pwm_ch4_0),
1208*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch4_1", mt7623_pwm_ch4_1),
1209*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch4_2", mt7623_pwm_ch4_2),
1210*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch4_3", mt7623_pwm_ch4_3),
1211*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch5_0", mt7623_pwm_ch5_0),
1212*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwm_ch5_1", mt7623_pwm_ch5_1),
1213*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("pwrap", mt7623_pwrap),
1214*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("rtc", mt7623_rtc),
1215*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("spdif_in0_0", mt7623_spdif_in0_0),
1216*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("spdif_in0_1", mt7623_spdif_in0_1),
1217*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("spdif_in1_0", mt7623_spdif_in1_0),
1218*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("spdif_in1_1", mt7623_spdif_in1_1),
1219*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("spdif_out", mt7623_spdif_out),
1220*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("spi0", mt7623_spi0),
1221*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("spi1", mt7623_spi1),
1222*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("spi2", mt7623_spi2),
1223*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("uart0_0_txd_rxd",  mt7623_uart0_0_txd_rxd),
1224*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("uart0_1_txd_rxd",  mt7623_uart0_1_txd_rxd),
1225*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("uart0_2_txd_rxd",  mt7623_uart0_2_txd_rxd),
1226*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("uart0_3_txd_rxd",  mt7623_uart0_3_txd_rxd),
1227*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("uart1_0_txd_rxd",  mt7623_uart1_0_txd_rxd),
1228*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("uart1_1_txd_rxd",  mt7623_uart1_1_txd_rxd),
1229*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("uart1_2_txd_rxd",  mt7623_uart1_2_txd_rxd),
1230*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("uart2_0_txd_rxd",  mt7623_uart2_0_txd_rxd),
1231*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("uart2_1_txd_rxd",  mt7623_uart2_1_txd_rxd),
1232*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("uart3_txd_rxd",  mt7623_uart3_txd_rxd),
1233*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("uart0_rts_cts",  mt7623_uart0_rts_cts),
1234*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("uart1_rts_cts",  mt7623_uart1_rts_cts),
1235*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("uart2_rts_cts",  mt7623_uart2_rts_cts),
1236*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("uart3_rts_cts",  mt7623_uart3_rts_cts),
1237*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("watchdog_0", mt7623_watchdog_0),
1238*4882a593Smuzhiyun 	PINCTRL_PIN_GROUP("watchdog_1", mt7623_watchdog_1),
1239*4882a593Smuzhiyun };
1240*4882a593Smuzhiyun 
1241*4882a593Smuzhiyun /* Joint those groups owning the same capability in user point of view which
1242*4882a593Smuzhiyun  * allows that people tend to use through the device tree.
1243*4882a593Smuzhiyun  */
1244*4882a593Smuzhiyun static const char *mt7623_aud_clk_groups[] = { "aud_ext_clk0",
1245*4882a593Smuzhiyun 					       "aud_ext_clk1", };
1246*4882a593Smuzhiyun static const char *mt7623_disp_pwm_groups[] = { "disp_pwm_0", "disp_pwm_1",
1247*4882a593Smuzhiyun 						"disp_pwm_2", };
1248*4882a593Smuzhiyun static const char *mt7623_ethernet_groups[] = { "esw_int", "esw_rst",
1249*4882a593Smuzhiyun 						"ephy", "mdc_mdio", };
1250*4882a593Smuzhiyun static const char *mt7623_ext_sdio_groups[] = { "ext_sdio", };
1251*4882a593Smuzhiyun static const char *mt7623_hdmi_groups[] = { "hdmi_cec", "hdmi_htplg",
1252*4882a593Smuzhiyun 					    "hdmi_i2c", "hdmi_rx",
1253*4882a593Smuzhiyun 					    "hdmi_rx_i2c", };
1254*4882a593Smuzhiyun static const char *mt7623_i2c_groups[] = { "i2c0", "i2c1_0", "i2c1_1",
1255*4882a593Smuzhiyun 					   "i2c1_2", "i2c1_3", "i2c1_4",
1256*4882a593Smuzhiyun 					   "i2c2_0", "i2c2_1", "i2c2_2",
1257*4882a593Smuzhiyun 					   "i2c2_3", };
1258*4882a593Smuzhiyun static const char *mt7623_i2s_groups[] = { "i2s0", "i2s1",
1259*4882a593Smuzhiyun 					   "i2s2_bclk_lrclk_mclk",
1260*4882a593Smuzhiyun 					   "i2s3_bclk_lrclk_mclk",
1261*4882a593Smuzhiyun 					   "i2s4", "i2s5",
1262*4882a593Smuzhiyun 					   "i2s2_data_in", "i2s3_data_in",
1263*4882a593Smuzhiyun 					   "i2s2_data_0", "i2s2_data_1",
1264*4882a593Smuzhiyun 					   "i2s3_data_0", "i2s3_data_1", };
1265*4882a593Smuzhiyun static const char *mt7623_ir_groups[] = { "ir", };
1266*4882a593Smuzhiyun static const char *mt7623_lcd_groups[] = { "dsi_te", "lcm_rst", "mipi_tx", };
1267*4882a593Smuzhiyun static const char *mt7623_msdc_groups[] = { "msdc0", "msdc1", "msdc1_ins",
1268*4882a593Smuzhiyun 					    "msdc1_wp_0", "msdc1_wp_1",
1269*4882a593Smuzhiyun 					    "msdc1_wp_2", "msdc2",
1270*4882a593Smuzhiyun 						"msdc3", };
1271*4882a593Smuzhiyun static const char *mt7623_nandc_groups[] = { "nandc", "nandc_ceb0",
1272*4882a593Smuzhiyun 					     "nandc_ceb1", };
1273*4882a593Smuzhiyun static const char *mt7623_otg_groups[] = { "otg_iddig0_0", "otg_iddig0_1",
1274*4882a593Smuzhiyun 					    "otg_iddig0_2", "otg_iddig1_0",
1275*4882a593Smuzhiyun 					    "otg_iddig1_1", "otg_iddig1_2",
1276*4882a593Smuzhiyun 					    "otg_drv_vbus0_0",
1277*4882a593Smuzhiyun 					    "otg_drv_vbus0_1",
1278*4882a593Smuzhiyun 					    "otg_drv_vbus0_2",
1279*4882a593Smuzhiyun 					    "otg_drv_vbus1_0",
1280*4882a593Smuzhiyun 					    "otg_drv_vbus1_1",
1281*4882a593Smuzhiyun 					    "otg_drv_vbus1_2", };
1282*4882a593Smuzhiyun static const char *mt7623_pcie_groups[] = { "pcie0_0_perst", "pcie0_1_perst",
1283*4882a593Smuzhiyun 					    "pcie1_0_perst", "pcie1_1_perst",
1284*4882a593Smuzhiyun 					    "pcie2_0_perst", "pcie2_1_perst",
1285*4882a593Smuzhiyun 					    "pcie0_0_rev_perst",
1286*4882a593Smuzhiyun 					    "pcie0_1_rev_perst",
1287*4882a593Smuzhiyun 					    "pcie1_0_rev_perst",
1288*4882a593Smuzhiyun 					    "pcie1_1_rev_perst",
1289*4882a593Smuzhiyun 					    "pcie2_0_rev_perst",
1290*4882a593Smuzhiyun 					    "pcie2_1_rev_perst",
1291*4882a593Smuzhiyun 					    "pcie0_0_wake", "pcie0_1_wake",
1292*4882a593Smuzhiyun 					    "pcie2_0_wake", "pcie2_1_wake",
1293*4882a593Smuzhiyun 					    "pcie0_clkreq", "pcie1_clkreq",
1294*4882a593Smuzhiyun 					    "pcie2_clkreq", };
1295*4882a593Smuzhiyun static const char *mt7623_pcm_groups[] = { "pcm_clk_0", "pcm_clk_1",
1296*4882a593Smuzhiyun 					   "pcm_clk_2", "pcm_clk_3",
1297*4882a593Smuzhiyun 					   "pcm_clk_4", "pcm_clk_5",
1298*4882a593Smuzhiyun 					   "pcm_clk_6", "pcm_sync_0",
1299*4882a593Smuzhiyun 					   "pcm_sync_1", "pcm_sync_2",
1300*4882a593Smuzhiyun 					   "pcm_sync_3", "pcm_sync_4",
1301*4882a593Smuzhiyun 					   "pcm_sync_5", "pcm_sync_6",
1302*4882a593Smuzhiyun 					   "pcm_rx_0", "pcm_rx_1",
1303*4882a593Smuzhiyun 					   "pcm_rx_2", "pcm_rx_3",
1304*4882a593Smuzhiyun 					   "pcm_rx_4", "pcm_rx_5",
1305*4882a593Smuzhiyun 					   "pcm_rx_6", "pcm_tx_0",
1306*4882a593Smuzhiyun 					   "pcm_tx_1", "pcm_tx_2",
1307*4882a593Smuzhiyun 					   "pcm_tx_3", "pcm_tx_4",
1308*4882a593Smuzhiyun 					   "pcm_tx_5", "pcm_tx_6", };
1309*4882a593Smuzhiyun static const char *mt7623_pwm_groups[] = { "pwm_ch1_0", "pwm_ch1_1",
1310*4882a593Smuzhiyun 					   "pwm_ch1_2", "pwm_ch2_0",
1311*4882a593Smuzhiyun 					   "pwm_ch2_1", "pwm_ch2_2",
1312*4882a593Smuzhiyun 					   "pwm_ch3_0", "pwm_ch3_1",
1313*4882a593Smuzhiyun 					   "pwm_ch3_2", "pwm_ch4_0",
1314*4882a593Smuzhiyun 					   "pwm_ch4_1", "pwm_ch4_2",
1315*4882a593Smuzhiyun 					   "pwm_ch4_3", "pwm_ch5_0",
1316*4882a593Smuzhiyun 					   "pwm_ch5_1", "pwm_ch5_2",
1317*4882a593Smuzhiyun 					   "pwm_ch6_0", "pwm_ch6_1",
1318*4882a593Smuzhiyun 					   "pwm_ch6_2", "pwm_ch6_3",
1319*4882a593Smuzhiyun 					   "pwm_ch7_0", "pwm_ch7_1",
1320*4882a593Smuzhiyun 					   "pwm_ch7_2", };
1321*4882a593Smuzhiyun static const char *mt7623_pwrap_groups[] = { "pwrap", };
1322*4882a593Smuzhiyun static const char *mt7623_rtc_groups[] = { "rtc", };
1323*4882a593Smuzhiyun static const char *mt7623_spi_groups[] = { "spi0", "spi2", "spi2", };
1324*4882a593Smuzhiyun static const char *mt7623_spdif_groups[] = { "spdif_in0_0", "spdif_in0_1",
1325*4882a593Smuzhiyun 					     "spdif_in1_0", "spdif_in1_1",
1326*4882a593Smuzhiyun 					     "spdif_out", };
1327*4882a593Smuzhiyun static const char *mt7623_uart_groups[] = { "uart0_0_txd_rxd",
1328*4882a593Smuzhiyun 					    "uart0_1_txd_rxd",
1329*4882a593Smuzhiyun 					    "uart0_2_txd_rxd",
1330*4882a593Smuzhiyun 					    "uart0_3_txd_rxd",
1331*4882a593Smuzhiyun 					    "uart1_0_txd_rxd",
1332*4882a593Smuzhiyun 					    "uart1_1_txd_rxd",
1333*4882a593Smuzhiyun 					    "uart1_2_txd_rxd",
1334*4882a593Smuzhiyun 					    "uart2_0_txd_rxd",
1335*4882a593Smuzhiyun 					    "uart2_1_txd_rxd",
1336*4882a593Smuzhiyun 					    "uart3_txd_rxd",
1337*4882a593Smuzhiyun 					    "uart0_rts_cts",
1338*4882a593Smuzhiyun 					    "uart1_rts_cts",
1339*4882a593Smuzhiyun 					    "uart2_rts_cts",
1340*4882a593Smuzhiyun 					    "uart3_rts_cts", };
1341*4882a593Smuzhiyun static const char *mt7623_wdt_groups[] = { "watchdog_0", "watchdog_1", };
1342*4882a593Smuzhiyun 
1343*4882a593Smuzhiyun static const struct function_desc mt7623_functions[] = {
1344*4882a593Smuzhiyun 	{"audck", mt7623_aud_clk_groups, ARRAY_SIZE(mt7623_aud_clk_groups)},
1345*4882a593Smuzhiyun 	{"disp", mt7623_disp_pwm_groups, ARRAY_SIZE(mt7623_disp_pwm_groups)},
1346*4882a593Smuzhiyun 	{"eth",	mt7623_ethernet_groups, ARRAY_SIZE(mt7623_ethernet_groups)},
1347*4882a593Smuzhiyun 	{"sdio", mt7623_ext_sdio_groups, ARRAY_SIZE(mt7623_ext_sdio_groups)},
1348*4882a593Smuzhiyun 	{"hdmi", mt7623_hdmi_groups, ARRAY_SIZE(mt7623_hdmi_groups)},
1349*4882a593Smuzhiyun 	{"i2c", mt7623_i2c_groups, ARRAY_SIZE(mt7623_i2c_groups)},
1350*4882a593Smuzhiyun 	{"i2s",	mt7623_i2s_groups, ARRAY_SIZE(mt7623_i2s_groups)},
1351*4882a593Smuzhiyun 	{"ir",	mt7623_ir_groups, ARRAY_SIZE(mt7623_ir_groups)},
1352*4882a593Smuzhiyun 	{"lcd", mt7623_lcd_groups, ARRAY_SIZE(mt7623_lcd_groups)},
1353*4882a593Smuzhiyun 	{"msdc", mt7623_msdc_groups, ARRAY_SIZE(mt7623_msdc_groups)},
1354*4882a593Smuzhiyun 	{"nand", mt7623_nandc_groups, ARRAY_SIZE(mt7623_nandc_groups)},
1355*4882a593Smuzhiyun 	{"otg", mt7623_otg_groups, ARRAY_SIZE(mt7623_otg_groups)},
1356*4882a593Smuzhiyun 	{"pcie", mt7623_pcie_groups, ARRAY_SIZE(mt7623_pcie_groups)},
1357*4882a593Smuzhiyun 	{"pcm",	mt7623_pcm_groups, ARRAY_SIZE(mt7623_pcm_groups)},
1358*4882a593Smuzhiyun 	{"pwm",	mt7623_pwm_groups, ARRAY_SIZE(mt7623_pwm_groups)},
1359*4882a593Smuzhiyun 	{"pwrap", mt7623_pwrap_groups, ARRAY_SIZE(mt7623_pwrap_groups)},
1360*4882a593Smuzhiyun 	{"rtc", mt7623_rtc_groups, ARRAY_SIZE(mt7623_rtc_groups)},
1361*4882a593Smuzhiyun 	{"spi",	mt7623_spi_groups, ARRAY_SIZE(mt7623_spi_groups)},
1362*4882a593Smuzhiyun 	{"spdif", mt7623_spdif_groups, ARRAY_SIZE(mt7623_spdif_groups)},
1363*4882a593Smuzhiyun 	{"uart", mt7623_uart_groups, ARRAY_SIZE(mt7623_uart_groups)},
1364*4882a593Smuzhiyun 	{"watchdog", mt7623_wdt_groups, ARRAY_SIZE(mt7623_wdt_groups)},
1365*4882a593Smuzhiyun };
1366*4882a593Smuzhiyun 
1367*4882a593Smuzhiyun static const struct mtk_eint_hw mt7623_eint_hw = {
1368*4882a593Smuzhiyun 	.port_mask = 6,
1369*4882a593Smuzhiyun 	.ports     = 6,
1370*4882a593Smuzhiyun 	.ap_num    = 169,
1371*4882a593Smuzhiyun 	.db_cnt    = 20,
1372*4882a593Smuzhiyun };
1373*4882a593Smuzhiyun 
1374*4882a593Smuzhiyun static struct mtk_pin_soc mt7623_data = {
1375*4882a593Smuzhiyun 	.reg_cal = mt7623_reg_cals,
1376*4882a593Smuzhiyun 	.pins = mt7623_pins,
1377*4882a593Smuzhiyun 	.npins = ARRAY_SIZE(mt7623_pins),
1378*4882a593Smuzhiyun 	.grps = mt7623_groups,
1379*4882a593Smuzhiyun 	.ngrps = ARRAY_SIZE(mt7623_groups),
1380*4882a593Smuzhiyun 	.funcs = mt7623_functions,
1381*4882a593Smuzhiyun 	.nfuncs = ARRAY_SIZE(mt7623_functions),
1382*4882a593Smuzhiyun 	.eint_hw = &mt7623_eint_hw,
1383*4882a593Smuzhiyun 	.gpio_m = 0,
1384*4882a593Smuzhiyun 	.ies_present = true,
1385*4882a593Smuzhiyun 	.base_names = mtk_default_register_base_names,
1386*4882a593Smuzhiyun 	.nbase_names = ARRAY_SIZE(mtk_default_register_base_names),
1387*4882a593Smuzhiyun 	.bias_disable_set = mtk_pinconf_bias_disable_set_rev1,
1388*4882a593Smuzhiyun 	.bias_disable_get = mtk_pinconf_bias_disable_get_rev1,
1389*4882a593Smuzhiyun 	.bias_set = mtk_pinconf_bias_set_rev1,
1390*4882a593Smuzhiyun 	.bias_get = mtk_pinconf_bias_get_rev1,
1391*4882a593Smuzhiyun 	.drive_set = mtk_pinconf_drive_set_rev1,
1392*4882a593Smuzhiyun 	.drive_get = mtk_pinconf_drive_get_rev1,
1393*4882a593Smuzhiyun 	.adv_pull_get = mtk_pinconf_adv_pull_get,
1394*4882a593Smuzhiyun 	.adv_pull_set = mtk_pinconf_adv_pull_set,
1395*4882a593Smuzhiyun };
1396*4882a593Smuzhiyun 
1397*4882a593Smuzhiyun /*
1398*4882a593Smuzhiyun  * There are some specific pins have mux functions greater than 8,
1399*4882a593Smuzhiyun  * and if we want to switch thees high modes we need to disable
1400*4882a593Smuzhiyun  * bonding constraints firstly.
1401*4882a593Smuzhiyun  */
mt7623_bonding_disable(struct platform_device * pdev)1402*4882a593Smuzhiyun static void mt7623_bonding_disable(struct platform_device *pdev)
1403*4882a593Smuzhiyun {
1404*4882a593Smuzhiyun 	struct mtk_pinctrl *hw = platform_get_drvdata(pdev);
1405*4882a593Smuzhiyun 
1406*4882a593Smuzhiyun 	mtk_rmw(hw, 0, PIN_BOND_REG0, BOND_PCIE_CLR, BOND_PCIE_CLR);
1407*4882a593Smuzhiyun 	mtk_rmw(hw, 0, PIN_BOND_REG1, BOND_I2S_CLR, BOND_I2S_CLR);
1408*4882a593Smuzhiyun 	mtk_rmw(hw, 0, PIN_BOND_REG2, BOND_MSDC0E_CLR, BOND_MSDC0E_CLR);
1409*4882a593Smuzhiyun }
1410*4882a593Smuzhiyun 
1411*4882a593Smuzhiyun static const struct of_device_id mt7623_pctrl_match[] = {
1412*4882a593Smuzhiyun 	{ .compatible = "mediatek,mt7623-moore-pinctrl", },
1413*4882a593Smuzhiyun 	{}
1414*4882a593Smuzhiyun };
1415*4882a593Smuzhiyun 
mt7623_pinctrl_probe(struct platform_device * pdev)1416*4882a593Smuzhiyun static int mt7623_pinctrl_probe(struct platform_device *pdev)
1417*4882a593Smuzhiyun {
1418*4882a593Smuzhiyun 	int err;
1419*4882a593Smuzhiyun 
1420*4882a593Smuzhiyun 	err = mtk_moore_pinctrl_probe(pdev, &mt7623_data);
1421*4882a593Smuzhiyun 	if (err)
1422*4882a593Smuzhiyun 		return err;
1423*4882a593Smuzhiyun 
1424*4882a593Smuzhiyun 	mt7623_bonding_disable(pdev);
1425*4882a593Smuzhiyun 
1426*4882a593Smuzhiyun 	return 0;
1427*4882a593Smuzhiyun }
1428*4882a593Smuzhiyun 
1429*4882a593Smuzhiyun static struct platform_driver mtk_pinctrl_driver = {
1430*4882a593Smuzhiyun 	.probe = mt7623_pinctrl_probe,
1431*4882a593Smuzhiyun 	.driver = {
1432*4882a593Smuzhiyun 		.name = "mt7623-moore-pinctrl",
1433*4882a593Smuzhiyun 		.of_match_table = mt7623_pctrl_match,
1434*4882a593Smuzhiyun 	},
1435*4882a593Smuzhiyun };
1436*4882a593Smuzhiyun 
mtk_pinctrl_init(void)1437*4882a593Smuzhiyun static int __init mtk_pinctrl_init(void)
1438*4882a593Smuzhiyun {
1439*4882a593Smuzhiyun 	return platform_driver_register(&mtk_pinctrl_driver);
1440*4882a593Smuzhiyun }
1441*4882a593Smuzhiyun arch_initcall(mtk_pinctrl_init);
1442