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