xref: /linux/drivers/pinctrl/aspeed/pinctrl-aspeed-g5.c (revision 1fd1dc41724319406b0aff221a352a400b0ddfc5)
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3  * Copyright (C) 2016 IBM Corp.
4  */
5 #include <linux/bitops.h>
6 #include <linux/init.h>
7 #include <linux/io.h>
8 #include <linux/kernel.h>
9 #include <linux/mfd/syscon.h>
10 #include <linux/mod_devicetable.h>
11 #include <linux/of.h>
12 #include <linux/platform_device.h>
13 #include <linux/pinctrl/pinctrl.h>
14 #include <linux/pinctrl/pinmux.h>
15 #include <linux/pinctrl/pinconf.h>
16 #include <linux/pinctrl/pinconf-generic.h>
17 #include <linux/types.h>
18 
19 #include "../core.h"
20 #include "../pinctrl-utils.h"
21 #include "pinctrl-aspeed.h"
22 
23 /* Wrap some of the common macros for clarity */
24 #define SIG_EXPR_DECL_SINGLE(sig, func, ...) \
25 	SIG_EXPR_DECL(sig, func, func, __VA_ARGS__)
26 
27 #define SIG_EXPR_LIST_DECL_SINGLE SIG_EXPR_LIST_DECL_SESG
28 #define SIG_EXPR_LIST_DECL_DUAL SIG_EXPR_LIST_DECL_DESG
29 
30 /*
31  * The "Multi-function Pins Mapping and Control" table in the SoC datasheet
32  * references registers by the device/offset mnemonic. The register macros
33  * below are named the same way to ease transcription and verification (as
34  * opposed to naming them e.g. PINMUX_CTRL_[0-9]). Further, signal expressions
35  * reference registers beyond those dedicated to pinmux, such as the system
36  * reset control and MAC clock configuration registers. The AST2500 goes a step
37  * further and references registers in the graphics IP block.
38  */
39 #define SCU2C           0x2C /* Misc. Control Register */
40 #define SCU3C           0x3C /* System Reset Control/Status Register */
41 #define SCU48           0x48 /* MAC Interface Clock Delay Setting */
42 #define HW_STRAP1       0x70 /* AST2400 strapping is 33 bits, is split */
43 #define HW_REVISION_ID  0x7C /* Silicon revision ID register */
44 #define SCU80           0x80 /* Multi-function Pin Control #1 */
45 #define SCU84           0x84 /* Multi-function Pin Control #2 */
46 #define SCU88           0x88 /* Multi-function Pin Control #3 */
47 #define SCU8C           0x8C /* Multi-function Pin Control #4 */
48 #define SCU90           0x90 /* Multi-function Pin Control #5 */
49 #define SCU94           0x94 /* Multi-function Pin Control #6 */
50 #define SCUA0           0xA0 /* Multi-function Pin Control #7 */
51 #define SCUA4           0xA4 /* Multi-function Pin Control #8 */
52 #define SCUA8           0xA8 /* Multi-function Pin Control #9 */
53 #define SCUAC           0xAC /* Multi-function Pin Control #10 */
54 #define HW_STRAP2       0xD0 /* Strapping */
55 
56 #define ASPEED_G5_NR_PINS 236
57 
58 #define COND1		{ ASPEED_IP_SCU, SCU90, BIT(6), 0, 0 }
59 #define COND2		{ ASPEED_IP_SCU, SCU94, GENMASK(1, 0), 0, 0 }
60 
61 /* LHCR0 is offset from the end of the H8S/2168-compatible registers */
62 #define LHCR0		0xa0
63 #define GFX064		0x64
64 
65 #define B14 0
66 SSSF_PIN_DECL(B14, GPIOA0, MAC1LINK, SIG_DESC_SET(SCU80, 0));
67 
68 #define D14 1
69 SSSF_PIN_DECL(D14, GPIOA1, MAC2LINK, SIG_DESC_SET(SCU80, 1));
70 
71 #define D13 2
72 SIG_EXPR_LIST_DECL_SINGLE(D13, SPI1CS1, SPI1CS1, SIG_DESC_SET(SCU80, 15));
73 SIG_EXPR_LIST_DECL_SINGLE(D13, TIMER3, TIMER3, SIG_DESC_SET(SCU80, 2));
74 PIN_DECL_2(D13, GPIOA2, SPI1CS1, TIMER3);
75 FUNC_GROUP_DECL(SPI1CS1, D13);
76 FUNC_GROUP_DECL(TIMER3, D13);
77 
78 #define E13 3
79 SSSF_PIN_DECL(E13, GPIOA3, TIMER4, SIG_DESC_SET(SCU80, 3));
80 
81 #define I2C9_DESC	SIG_DESC_SET(SCU90, 22)
82 
83 #define C14 4
84 SIG_EXPR_LIST_DECL_SINGLE(C14, SCL9, I2C9, I2C9_DESC, COND1);
85 SIG_EXPR_LIST_DECL_SINGLE(C14, TIMER5, TIMER5, SIG_DESC_SET(SCU80, 4), COND1);
86 PIN_DECL_2(C14, GPIOA4, SCL9, TIMER5);
87 
88 FUNC_GROUP_DECL(TIMER5, C14);
89 
90 #define A13 5
91 SIG_EXPR_LIST_DECL_SINGLE(A13, SDA9, I2C9, I2C9_DESC, COND1);
92 SIG_EXPR_LIST_DECL_SINGLE(A13, TIMER6, TIMER6, SIG_DESC_SET(SCU80, 5), COND1);
93 PIN_DECL_2(A13, GPIOA5, SDA9, TIMER6);
94 
95 FUNC_GROUP_DECL(TIMER6, A13);
96 
97 FUNC_GROUP_DECL(I2C9, C14, A13);
98 
99 #define MDIO2_DESC	SIG_DESC_SET(SCU90, 2)
100 
101 #define C13 6
102 SIG_EXPR_LIST_DECL_SINGLE(C13, MDC2, MDIO2, MDIO2_DESC, COND1);
103 SIG_EXPR_LIST_DECL_SINGLE(C13, TIMER7, TIMER7, SIG_DESC_SET(SCU80, 6), COND1);
104 PIN_DECL_2(C13, GPIOA6, MDC2, TIMER7);
105 
106 FUNC_GROUP_DECL(TIMER7, C13);
107 
108 #define B13 7
109 SIG_EXPR_LIST_DECL_SINGLE(B13, MDIO2, MDIO2, MDIO2_DESC, COND1);
110 SIG_EXPR_LIST_DECL_SINGLE(B13, TIMER8, TIMER8, SIG_DESC_SET(SCU80, 7), COND1);
111 PIN_DECL_2(B13, GPIOA7, MDIO2, TIMER8);
112 
113 FUNC_GROUP_DECL(TIMER8, B13);
114 
115 FUNC_GROUP_DECL(MDIO2, C13, B13);
116 
117 #define K19 8
118 GPIO_PIN_DECL(K19, GPIOB0);
119 
120 #define L19 9
121 GPIO_PIN_DECL(L19, GPIOB1);
122 
123 #define L18 10
124 GPIO_PIN_DECL(L18, GPIOB2);
125 
126 #define K18 11
127 GPIO_PIN_DECL(K18, GPIOB3);
128 
129 #define J20 12
130 SSSF_PIN_DECL(J20, GPIOB4, USBCKI, SIG_DESC_SET(HW_STRAP1, 23));
131 
132 #define H21 13
133 #define H21_DESC	SIG_DESC_SET(SCU80, 13)
134 SIG_EXPR_LIST_DECL_SINGLE(H21, LPCPD, LPCPD, H21_DESC);
135 SIG_EXPR_LIST_DECL_SINGLE(H21, LPCSMI, LPCSMI, H21_DESC);
136 PIN_DECL_2(H21, GPIOB5, LPCPD, LPCSMI);
137 FUNC_GROUP_DECL(LPCPD, H21);
138 FUNC_GROUP_DECL(LPCSMI, H21);
139 
140 #define H22 14
141 SSSF_PIN_DECL(H22, GPIOB6, LPCPME, SIG_DESC_SET(SCU80, 14));
142 
143 #define H20 15
144 GPIO_PIN_DECL(H20, GPIOB7);
145 
146 #define SD1_DESC	SIG_DESC_SET(SCU90, 0)
147 
148 #define C12 16
149 #define I2C10_DESC	SIG_DESC_SET(SCU90, 23)
150 SIG_EXPR_LIST_DECL_SINGLE(C12, SD1CLK, SD1, SD1_DESC);
151 SIG_EXPR_LIST_DECL_SINGLE(C12, SCL10, I2C10, I2C10_DESC);
152 PIN_DECL_2(C12, GPIOC0, SD1CLK, SCL10);
153 
154 #define A12 17
155 SIG_EXPR_LIST_DECL_SINGLE(A12, SD1CMD, SD1, SD1_DESC);
156 SIG_EXPR_LIST_DECL_SINGLE(A12, SDA10, I2C10, I2C10_DESC);
157 PIN_DECL_2(A12, GPIOC1, SD1CMD, SDA10);
158 
159 FUNC_GROUP_DECL(I2C10, C12, A12);
160 
161 #define B12 18
162 #define I2C11_DESC	SIG_DESC_SET(SCU90, 24)
163 SIG_EXPR_LIST_DECL_SINGLE(B12, SD1DAT0, SD1, SD1_DESC);
164 SIG_EXPR_LIST_DECL_SINGLE(B12, SCL11, I2C11, I2C11_DESC);
165 PIN_DECL_2(B12, GPIOC2, SD1DAT0, SCL11);
166 
167 #define D9  19
168 SIG_EXPR_LIST_DECL_SINGLE(D9, SD1DAT1, SD1, SD1_DESC);
169 SIG_EXPR_LIST_DECL_SINGLE(D9, SDA11, I2C11, I2C11_DESC);
170 PIN_DECL_2(D9, GPIOC3, SD1DAT1, SDA11);
171 
172 FUNC_GROUP_DECL(I2C11, B12, D9);
173 
174 #define D10 20
175 #define I2C12_DESC	SIG_DESC_SET(SCU90, 25)
176 SIG_EXPR_LIST_DECL_SINGLE(D10, SD1DAT2, SD1, SD1_DESC);
177 SIG_EXPR_LIST_DECL_SINGLE(D10, SCL12, I2C12, I2C12_DESC);
178 PIN_DECL_2(D10, GPIOC4, SD1DAT2, SCL12);
179 
180 #define E12 21
181 SIG_EXPR_LIST_DECL_SINGLE(E12, SD1DAT3, SD1, SD1_DESC);
182 SIG_EXPR_LIST_DECL_SINGLE(E12, SDA12, I2C12, I2C12_DESC);
183 PIN_DECL_2(E12, GPIOC5, SD1DAT3, SDA12);
184 
185 FUNC_GROUP_DECL(I2C12, D10, E12);
186 
187 #define C11 22
188 #define I2C13_DESC	SIG_DESC_SET(SCU90, 26)
189 SIG_EXPR_LIST_DECL_SINGLE(C11, SD1CD, SD1, SD1_DESC);
190 SIG_EXPR_LIST_DECL_SINGLE(C11, SCL13, I2C13, I2C13_DESC);
191 PIN_DECL_2(C11, GPIOC6, SD1CD, SCL13);
192 
193 #define B11 23
194 SIG_EXPR_LIST_DECL_SINGLE(B11, SD1WP, SD1, SD1_DESC);
195 SIG_EXPR_LIST_DECL_SINGLE(B11, SDA13, I2C13, I2C13_DESC);
196 PIN_DECL_2(B11, GPIOC7, SD1WP, SDA13);
197 
198 FUNC_GROUP_DECL(I2C13, C11, B11);
199 FUNC_GROUP_DECL(SD1, C12, A12, B12, D9, D10, E12, C11, B11);
200 
201 #define SD2_DESC        SIG_DESC_SET(SCU90, 1)
202 #define GPID0_DESC      SIG_DESC_SET(SCU8C, 8)
203 #define GPID_DESC       SIG_DESC_SET(HW_STRAP1, 21)
204 
205 #define F19 24
206 SIG_EXPR_LIST_DECL_SINGLE(F19, SD2CLK, SD2, SD2_DESC);
207 SIG_EXPR_DECL_SINGLE(GPID0IN, GPID0, GPID0_DESC);
208 SIG_EXPR_DECL_SINGLE(GPID0IN, GPID, GPID_DESC);
209 SIG_EXPR_LIST_DECL_DUAL(F19, GPID0IN, GPID0, GPID);
210 PIN_DECL_2(F19, GPIOD0, SD2CLK, GPID0IN);
211 
212 #define E21 25
213 SIG_EXPR_LIST_DECL_SINGLE(E21, SD2CMD, SD2, SD2_DESC);
214 SIG_EXPR_DECL_SINGLE(GPID0OUT, GPID0, GPID0_DESC);
215 SIG_EXPR_DECL_SINGLE(GPID0OUT, GPID, GPID_DESC);
216 SIG_EXPR_LIST_DECL_DUAL(E21, GPID0OUT, GPID0, GPID);
217 PIN_DECL_2(E21, GPIOD1, SD2CMD, GPID0OUT);
218 
219 FUNC_GROUP_DECL(GPID0, F19, E21);
220 
221 #define GPID2_DESC      SIG_DESC_SET(SCU8C, 9)
222 
223 #define F20 26
224 SIG_EXPR_LIST_DECL_SINGLE(F20, SD2DAT0, SD2, SD2_DESC);
225 SIG_EXPR_DECL_SINGLE(GPID2IN, GPID2, GPID2_DESC);
226 SIG_EXPR_DECL_SINGLE(GPID2IN, GPID, GPID_DESC);
227 SIG_EXPR_LIST_DECL_DUAL(F20, GPID2IN, GPID2, GPID);
228 PIN_DECL_2(F20, GPIOD2, SD2DAT0, GPID2IN);
229 
230 #define D20 27
231 SIG_EXPR_LIST_DECL_SINGLE(D20, SD2DAT1, SD2, SD2_DESC);
232 SIG_EXPR_DECL_SINGLE(GPID2OUT, GPID2, GPID2_DESC);
233 SIG_EXPR_DECL_SINGLE(GPID2OUT, GPID, GPID_DESC);
234 SIG_EXPR_LIST_DECL_DUAL(D20, GPID2OUT, GPID2, GPID);
235 PIN_DECL_2(D20, GPIOD3, SD2DAT1, GPID2OUT);
236 
237 FUNC_GROUP_DECL(GPID2, F20, D20);
238 
239 #define GPID4_DESC      SIG_DESC_SET(SCU8C, 10)
240 
241 #define D21 28
242 SIG_EXPR_LIST_DECL_SINGLE(D21, SD2DAT2, SD2, SD2_DESC);
243 SIG_EXPR_DECL_SINGLE(GPID4IN, GPID4, GPID4_DESC);
244 SIG_EXPR_DECL_SINGLE(GPID4IN, GPID, GPID_DESC);
245 SIG_EXPR_LIST_DECL_DUAL(D21, GPID4IN, GPID4, GPID);
246 PIN_DECL_2(D21, GPIOD4, SD2DAT2, GPID4IN);
247 
248 #define E20 29
249 SIG_EXPR_LIST_DECL_SINGLE(E20, SD2DAT3, SD2, SD2_DESC);
250 SIG_EXPR_DECL_SINGLE(GPID4OUT, GPID4, GPID4_DESC);
251 SIG_EXPR_DECL_SINGLE(GPID4OUT, GPID, GPID_DESC);
252 SIG_EXPR_LIST_DECL_DUAL(E20, GPID4OUT, GPID4, GPID);
253 PIN_DECL_2(E20, GPIOD5, SD2DAT3, GPID4OUT);
254 
255 FUNC_GROUP_DECL(GPID4, D21, E20);
256 
257 #define GPID6_DESC      SIG_DESC_SET(SCU8C, 11)
258 
259 #define G18 30
260 SIG_EXPR_LIST_DECL_SINGLE(G18, SD2CD, SD2, SD2_DESC);
261 SIG_EXPR_DECL_SINGLE(GPID6IN, GPID6, GPID6_DESC);
262 SIG_EXPR_DECL_SINGLE(GPID6IN, GPID, GPID_DESC);
263 SIG_EXPR_LIST_DECL_DUAL(G18, GPID6IN, GPID6, GPID);
264 PIN_DECL_2(G18, GPIOD6, SD2CD, GPID6IN);
265 
266 #define C21 31
267 SIG_EXPR_LIST_DECL_SINGLE(C21, SD2WP, SD2, SD2_DESC);
268 SIG_EXPR_DECL_SINGLE(GPID6OUT, GPID6, GPID6_DESC);
269 SIG_EXPR_DECL_SINGLE(GPID6OUT, GPID, GPID_DESC);
270 SIG_EXPR_LIST_DECL_DUAL(C21, GPID6OUT, GPID6, GPID);
271 PIN_DECL_2(C21, GPIOD7, SD2WP, GPID6OUT);
272 
273 FUNC_GROUP_DECL(GPID6, G18, C21);
274 FUNC_GROUP_DECL(SD2, F19, E21, F20, D20, D21, E20, G18, C21);
275 
276 #define GPIE_DESC	SIG_DESC_SET(HW_STRAP1, 22)
277 #define GPIE0_DESC	SIG_DESC_SET(SCU8C, 12)
278 
279 #define B20 32
280 SIG_EXPR_LIST_DECL_SINGLE(B20, NCTS3, NCTS3, SIG_DESC_SET(SCU80, 16));
281 SIG_EXPR_DECL_SINGLE(GPIE0IN, GPIE0, GPIE0_DESC);
282 SIG_EXPR_DECL_SINGLE(GPIE0IN, GPIE, GPIE_DESC);
283 SIG_EXPR_LIST_DECL_DUAL(B20, GPIE0IN, GPIE0, GPIE);
284 PIN_DECL_2(B20, GPIOE0, NCTS3, GPIE0IN);
285 FUNC_GROUP_DECL(NCTS3, B20);
286 
287 #define C20 33
288 SIG_EXPR_LIST_DECL_SINGLE(C20, NDCD3, NDCD3, SIG_DESC_SET(SCU80, 17));
289 SIG_EXPR_DECL_SINGLE(GPIE0OUT, GPIE0, GPIE0_DESC);
290 SIG_EXPR_DECL_SINGLE(GPIE0OUT, GPIE, GPIE_DESC);
291 SIG_EXPR_LIST_DECL_DUAL(C20, GPIE0OUT, GPIE0, GPIE);
292 PIN_DECL_2(C20, GPIOE1, NDCD3, GPIE0OUT);
293 FUNC_GROUP_DECL(NDCD3, C20);
294 
295 FUNC_GROUP_DECL(GPIE0, B20, C20);
296 
297 #define GPIE2_DESC	SIG_DESC_SET(SCU8C, 13)
298 
299 #define F18 34
300 SIG_EXPR_LIST_DECL_SINGLE(F18, NDSR3, NDSR3, SIG_DESC_SET(SCU80, 18));
301 SIG_EXPR_DECL_SINGLE(GPIE2IN, GPIE2, GPIE2_DESC);
302 SIG_EXPR_DECL_SINGLE(GPIE2IN, GPIE, GPIE_DESC);
303 SIG_EXPR_LIST_DECL_DUAL(F18, GPIE2IN, GPIE2, GPIE);
304 PIN_DECL_2(F18, GPIOE2, NDSR3, GPIE2IN);
305 FUNC_GROUP_DECL(NDSR3, F18);
306 
307 
308 #define F17 35
309 SIG_EXPR_LIST_DECL_SINGLE(F17, NRI3, NRI3, SIG_DESC_SET(SCU80, 19));
310 SIG_EXPR_DECL_SINGLE(GPIE2OUT, GPIE2, GPIE2_DESC);
311 SIG_EXPR_DECL_SINGLE(GPIE2OUT, GPIE, GPIE_DESC);
312 SIG_EXPR_LIST_DECL_DUAL(F17, GPIE2OUT, GPIE2, GPIE);
313 PIN_DECL_2(F17, GPIOE3, NRI3, GPIE2OUT);
314 FUNC_GROUP_DECL(NRI3, F17);
315 
316 FUNC_GROUP_DECL(GPIE2, F18, F17);
317 
318 #define GPIE4_DESC	SIG_DESC_SET(SCU8C, 14)
319 
320 #define E18 36
321 SIG_EXPR_LIST_DECL_SINGLE(E18, NDTR3, NDTR3, SIG_DESC_SET(SCU80, 20));
322 SIG_EXPR_DECL_SINGLE(GPIE4IN, GPIE4, GPIE4_DESC);
323 SIG_EXPR_DECL_SINGLE(GPIE4IN, GPIE, GPIE_DESC);
324 SIG_EXPR_LIST_DECL_DUAL(E18, GPIE4IN, GPIE4, GPIE);
325 PIN_DECL_2(E18, GPIOE4, NDTR3, GPIE4IN);
326 FUNC_GROUP_DECL(NDTR3, E18);
327 
328 #define D19 37
329 SIG_EXPR_LIST_DECL_SINGLE(D19, NRTS3, NRTS3, SIG_DESC_SET(SCU80, 21));
330 SIG_EXPR_DECL_SINGLE(GPIE4OUT, GPIE4, GPIE4_DESC);
331 SIG_EXPR_DECL_SINGLE(GPIE4OUT, GPIE, GPIE_DESC);
332 SIG_EXPR_LIST_DECL_DUAL(D19, GPIE4OUT, GPIE4, GPIE);
333 PIN_DECL_2(D19, GPIOE5, NRTS3, GPIE4OUT);
334 FUNC_GROUP_DECL(NRTS3, D19);
335 
336 FUNC_GROUP_DECL(GPIE4, E18, D19);
337 
338 #define GPIE6_DESC	SIG_DESC_SET(SCU8C, 15)
339 
340 #define A20 38
341 SIG_EXPR_LIST_DECL_SINGLE(A20, TXD3, TXD3, SIG_DESC_SET(SCU80, 22));
342 SIG_EXPR_DECL_SINGLE(GPIE6IN, GPIE6, GPIE6_DESC);
343 SIG_EXPR_DECL_SINGLE(GPIE6IN, GPIE, GPIE_DESC);
344 SIG_EXPR_LIST_DECL_DUAL(A20, GPIE6IN, GPIE6, GPIE);
345 PIN_DECL_2(A20, GPIOE6, TXD3, GPIE6IN);
346 FUNC_GROUP_DECL(TXD3, A20);
347 
348 #define B19 39
349 SIG_EXPR_LIST_DECL_SINGLE(B19, RXD3, RXD3, SIG_DESC_SET(SCU80, 23));
350 SIG_EXPR_DECL_SINGLE(GPIE6OUT, GPIE6, GPIE6_DESC);
351 SIG_EXPR_DECL_SINGLE(GPIE6OUT, GPIE, GPIE_DESC);
352 SIG_EXPR_LIST_DECL_DUAL(B19, GPIE6OUT, GPIE6, GPIE);
353 PIN_DECL_2(B19, GPIOE7, RXD3, GPIE6OUT);
354 FUNC_GROUP_DECL(RXD3, B19);
355 
356 FUNC_GROUP_DECL(GPIE6, A20, B19);
357 
358 #define LPCHC_DESC	SIG_DESC_IP_SET(ASPEED_IP_LPC, LHCR0, 0)
359 #define LPCPLUS_DESC	SIG_DESC_SET(SCU90, 30)
360 
361 #define J19 40
362 SIG_EXPR_DECL_SINGLE(LHAD0, LPCHC, LPCHC_DESC);
363 SIG_EXPR_DECL_SINGLE(LHAD0, LPCPLUS, LPCPLUS_DESC);
364 SIG_EXPR_LIST_DECL_DUAL(J19, LHAD0, LPCHC, LPCPLUS);
365 SIG_EXPR_LIST_DECL_SINGLE(J19, NCTS4, NCTS4, SIG_DESC_SET(SCU80, 24));
366 PIN_DECL_2(J19, GPIOF0, LHAD0, NCTS4);
367 FUNC_GROUP_DECL(NCTS4, J19);
368 
369 #define J18 41
370 SIG_EXPR_DECL_SINGLE(LHAD1, LPCHC, LPCHC_DESC);
371 SIG_EXPR_DECL_SINGLE(LHAD1, LPCPLUS, LPCPLUS_DESC);
372 SIG_EXPR_LIST_DECL_DUAL(J18, LHAD1, LPCHC, LPCPLUS);
373 SIG_EXPR_LIST_DECL_SINGLE(J18, NDCD4, NDCD4, SIG_DESC_SET(SCU80, 25));
374 PIN_DECL_2(J18, GPIOF1, LHAD1, NDCD4);
375 FUNC_GROUP_DECL(NDCD4, J18);
376 
377 #define B22 42
378 SIG_EXPR_DECL_SINGLE(LHAD2, LPCHC, LPCHC_DESC);
379 SIG_EXPR_DECL_SINGLE(LHAD2, LPCPLUS, LPCPLUS_DESC);
380 SIG_EXPR_LIST_DECL_DUAL(B22, LHAD2, LPCHC, LPCPLUS);
381 SIG_EXPR_LIST_DECL_SINGLE(B22, NDSR4, NDSR4, SIG_DESC_SET(SCU80, 26));
382 PIN_DECL_2(B22, GPIOF2, LHAD2, NDSR4);
383 FUNC_GROUP_DECL(NDSR4, B22);
384 
385 #define B21 43
386 SIG_EXPR_DECL_SINGLE(LHAD3, LPCHC, LPCHC_DESC);
387 SIG_EXPR_DECL_SINGLE(LHAD3, LPCPLUS, LPCPLUS_DESC);
388 SIG_EXPR_LIST_DECL_DUAL(B21, LHAD3, LPCHC, LPCPLUS);
389 SIG_EXPR_LIST_DECL_SINGLE(B21, NRI4, NRI4, SIG_DESC_SET(SCU80, 27));
390 PIN_DECL_2(B21, GPIOF3, LHAD3, NRI4);
391 FUNC_GROUP_DECL(NRI4, B21);
392 
393 #define A21 44
394 SIG_EXPR_DECL_SINGLE(LHCLK, LPCHC, LPCHC_DESC);
395 SIG_EXPR_DECL_SINGLE(LHCLK, LPCPLUS, LPCPLUS_DESC);
396 SIG_EXPR_LIST_DECL_DUAL(A21, LHCLK, LPCHC, LPCPLUS);
397 SIG_EXPR_LIST_DECL_SINGLE(A21, NDTR4, NDTR4, SIG_DESC_SET(SCU80, 28));
398 PIN_DECL_2(A21, GPIOF4, LHCLK, NDTR4);
399 FUNC_GROUP_DECL(NDTR4, A21);
400 
401 #define H19 45
402 SIG_EXPR_DECL_SINGLE(LHFRAME, LPCHC, LPCHC_DESC);
403 SIG_EXPR_DECL_SINGLE(LHFRAME, LPCPLUS, LPCPLUS_DESC);
404 SIG_EXPR_LIST_DECL_DUAL(H19, LHFRAME, LPCHC, LPCPLUS);
405 SIG_EXPR_LIST_DECL_SINGLE(H19, NRTS4, NRTS4, SIG_DESC_SET(SCU80, 29));
406 PIN_DECL_2(H19, GPIOF5, LHFRAME, NRTS4);
407 FUNC_GROUP_DECL(NRTS4, H19);
408 
409 #define G17 46
410 SIG_EXPR_LIST_DECL_SINGLE(G17, LHSIRQ, LPCHC, LPCHC_DESC);
411 SIG_EXPR_LIST_DECL_SINGLE(G17, TXD4, TXD4, SIG_DESC_SET(SCU80, 30));
412 PIN_DECL_2(G17, GPIOF6, LHSIRQ, TXD4);
413 FUNC_GROUP_DECL(TXD4, G17);
414 
415 #define H18 47
416 SIG_EXPR_DECL_SINGLE(LHRST, LPCHC, LPCHC_DESC);
417 SIG_EXPR_DECL_SINGLE(LHRST, LPCPLUS, LPCPLUS_DESC);
418 SIG_EXPR_LIST_DECL_DUAL(H18, LHRST, LPCHC, LPCPLUS);
419 SIG_EXPR_LIST_DECL_SINGLE(H18, RXD4, RXD4, SIG_DESC_SET(SCU80, 31));
420 PIN_DECL_2(H18, GPIOF7, LHRST, RXD4);
421 FUNC_GROUP_DECL(RXD4, H18);
422 
423 FUNC_GROUP_DECL(LPCHC, J19, J18, B22, B21, A21, H19, G17, H18);
424 FUNC_GROUP_DECL(LPCPLUS, J19, J18, B22, B21, A21, H19, H18);
425 
426 #define A19 48
427 SIG_EXPR_LIST_DECL_SINGLE(A19, SGPS1CK, SGPS1, COND1, SIG_DESC_SET(SCU84, 0));
428 PIN_DECL_1(A19, GPIOG0, SGPS1CK);
429 
430 #define E19 49
431 SIG_EXPR_LIST_DECL_SINGLE(E19, SGPS1LD, SGPS1, COND1, SIG_DESC_SET(SCU84, 1));
432 PIN_DECL_1(E19, GPIOG1, SGPS1LD);
433 
434 #define C19 50
435 SIG_EXPR_LIST_DECL_SINGLE(C19, SGPS1I0, SGPS1, COND1, SIG_DESC_SET(SCU84, 2));
436 PIN_DECL_1(C19, GPIOG2, SGPS1I0);
437 
438 #define E16 51
439 SIG_EXPR_LIST_DECL_SINGLE(E16, SGPS1I1, SGPS1, COND1, SIG_DESC_SET(SCU84, 3));
440 PIN_DECL_1(E16, GPIOG3, SGPS1I1);
441 
442 FUNC_GROUP_DECL(SGPS1, A19, E19, C19, E16);
443 
444 #define SGPS2_DESC	SIG_DESC_SET(SCU94, 12)
445 
446 #define E17 52
447 SIG_EXPR_LIST_DECL_SINGLE(E17, SGPS2CK, SGPS2, COND1, SGPS2_DESC);
448 SIG_EXPR_LIST_DECL_SINGLE(E17, SALT1, SALT1, COND1, SIG_DESC_SET(SCU84, 4));
449 PIN_DECL_2(E17, GPIOG4, SGPS2CK, SALT1);
450 FUNC_GROUP_DECL(SALT1, E17);
451 
452 #define D16 53
453 SIG_EXPR_LIST_DECL_SINGLE(D16, SGPS2LD, SGPS2, COND1, SGPS2_DESC);
454 SIG_EXPR_LIST_DECL_SINGLE(D16, SALT2, SALT2, COND1, SIG_DESC_SET(SCU84, 5));
455 PIN_DECL_2(D16, GPIOG5, SGPS2LD, SALT2);
456 FUNC_GROUP_DECL(SALT2, D16);
457 
458 #define D15 54
459 SIG_EXPR_LIST_DECL_SINGLE(D15, SGPS2I0, SGPS2, COND1, SGPS2_DESC);
460 SIG_EXPR_LIST_DECL_SINGLE(D15, SALT3, SALT3, COND1, SIG_DESC_SET(SCU84, 6));
461 PIN_DECL_2(D15, GPIOG6, SGPS2I0, SALT3);
462 FUNC_GROUP_DECL(SALT3, D15);
463 
464 #define E14 55
465 SIG_EXPR_LIST_DECL_SINGLE(E14, SGPS2I1, SGPS2, COND1, SGPS2_DESC);
466 SIG_EXPR_LIST_DECL_SINGLE(E14, SALT4, SALT4, COND1, SIG_DESC_SET(SCU84, 7));
467 PIN_DECL_2(E14, GPIOG7, SGPS2I1, SALT4);
468 FUNC_GROUP_DECL(SALT4, E14);
469 
470 FUNC_GROUP_DECL(SGPS2, E17, D16, D15, E14);
471 
472 #define UART6_DESC	SIG_DESC_SET(SCU90, 7)
473 
474 #define A18 56
475 SIG_EXPR_LIST_DECL_SINGLE(A18, DASHA18, DASHA18, COND1, SIG_DESC_SET(SCU94, 5));
476 SIG_EXPR_LIST_DECL_SINGLE(A18, NCTS6, UART6, COND1, UART6_DESC);
477 PIN_DECL_2(A18, GPIOH0, DASHA18, NCTS6);
478 
479 #define B18 57
480 SIG_EXPR_LIST_DECL_SINGLE(B18, DASHB18, DASHB18, COND1, SIG_DESC_SET(SCU94, 5));
481 SIG_EXPR_LIST_DECL_SINGLE(B18, NDCD6, UART6, COND1, UART6_DESC);
482 PIN_DECL_2(B18, GPIOH1, DASHB18, NDCD6);
483 
484 #define D17 58
485 SIG_EXPR_LIST_DECL_SINGLE(D17, DASHD17, DASHD17, COND1, SIG_DESC_SET(SCU94, 6));
486 SIG_EXPR_LIST_DECL_SINGLE(D17, NDSR6, UART6, COND1, UART6_DESC);
487 PIN_DECL_2(D17, GPIOH2, DASHD17, NDSR6);
488 
489 #define C17 59
490 SIG_EXPR_LIST_DECL_SINGLE(C17, DASHC17, DASHC17, COND1, SIG_DESC_SET(SCU94, 6));
491 SIG_EXPR_LIST_DECL_SINGLE(C17, NRI6, UART6, COND1, UART6_DESC);
492 PIN_DECL_2(C17, GPIOH3, DASHC17, NRI6);
493 
494 #define A17 60
495 SIG_EXPR_LIST_DECL_SINGLE(A17, DASHA17, DASHA17, COND1, SIG_DESC_SET(SCU94, 7));
496 SIG_EXPR_LIST_DECL_SINGLE(A17, NDTR6, UART6, COND1, UART6_DESC);
497 PIN_DECL_2(A17, GPIOH4, DASHA17, NDTR6);
498 
499 #define B17 61
500 SIG_EXPR_LIST_DECL_SINGLE(B17, DASHB17, DASHB17, COND1, SIG_DESC_SET(SCU94, 7));
501 SIG_EXPR_LIST_DECL_SINGLE(B17, NRTS6, UART6, COND1, UART6_DESC);
502 PIN_DECL_2(B17, GPIOH5, DASHB17, NRTS6);
503 
504 #define A16 62
505 SIG_EXPR_LIST_DECL_SINGLE(A16, TXD6, UART6, COND1, UART6_DESC);
506 PIN_DECL_1(A16, GPIOH6, TXD6);
507 
508 #define D18 63
509 SIG_EXPR_LIST_DECL_SINGLE(D18, RXD6, UART6, COND1, UART6_DESC);
510 PIN_DECL_1(D18, GPIOH7, RXD6);
511 
512 FUNC_GROUP_DECL(UART6, A18, B18, D17, C17, A17, B17, A16, D18);
513 
514 #define SPI1_DESC \
515 	{ ASPEED_IP_SCU, HW_STRAP1, GENMASK(13, 12), 1, 0 }
516 #define SPI1DEBUG_DESC \
517 	{ ASPEED_IP_SCU, HW_STRAP1, GENMASK(13, 12), 2, 0 }
518 #define SPI1PASSTHRU_DESC \
519 	{ ASPEED_IP_SCU, HW_STRAP1, GENMASK(13, 12), 3, 0 }
520 
521 #define C18 64
522 SIG_EXPR_DECL_SINGLE(SYSCS, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
523 SIG_EXPR_DECL_SINGLE(SYSCS, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
524 SIG_EXPR_LIST_DECL_DUAL(C18, SYSCS, SPI1DEBUG, SPI1PASSTHRU);
525 PIN_DECL_1(C18, GPIOI0, SYSCS);
526 
527 #define E15 65
528 SIG_EXPR_DECL_SINGLE(SYSCK, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
529 SIG_EXPR_DECL_SINGLE(SYSCK, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
530 SIG_EXPR_LIST_DECL_DUAL(E15, SYSCK, SPI1DEBUG, SPI1PASSTHRU);
531 PIN_DECL_1(E15, GPIOI1, SYSCK);
532 
533 #define B16 66
534 SIG_EXPR_DECL_SINGLE(SYSMOSI, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
535 SIG_EXPR_DECL_SINGLE(SYSMOSI, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
536 SIG_EXPR_LIST_DECL_DUAL(B16, SYSMOSI, SPI1DEBUG, SPI1PASSTHRU);
537 PIN_DECL_1(B16, GPIOI2, SYSMOSI);
538 
539 #define C16 67
540 SIG_EXPR_DECL_SINGLE(SYSMISO, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
541 SIG_EXPR_DECL_SINGLE(SYSMISO, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
542 SIG_EXPR_LIST_DECL_DUAL(C16, SYSMISO, SPI1DEBUG, SPI1PASSTHRU);
543 PIN_DECL_1(C16, GPIOI3, SYSMISO);
544 
545 #define VB_DESC	SIG_DESC_SET(HW_STRAP1, 5)
546 
547 #define B15 68
548 SIG_EXPR_DECL_SINGLE(SPI1CS0, SPI1, COND1, SPI1_DESC);
549 SIG_EXPR_DECL_SINGLE(SPI1CS0, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
550 SIG_EXPR_DECL_SINGLE(SPI1CS0, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
551 SIG_EXPR_LIST_DECL(SPI1CS0, SPI1,
552 			    SIG_EXPR_PTR(SPI1CS0, SPI1),
553 			    SIG_EXPR_PTR(SPI1CS0, SPI1DEBUG),
554 			    SIG_EXPR_PTR(SPI1CS0, SPI1PASSTHRU));
555 SIG_EXPR_LIST_ALIAS(B15, SPI1CS0, SPI1);
556 SIG_EXPR_LIST_DECL_SINGLE(B15, VBCS, VGABIOSROM, COND1, VB_DESC);
557 PIN_DECL_2(B15, GPIOI4, SPI1CS0, VBCS);
558 
559 #define C15 69
560 SIG_EXPR_DECL_SINGLE(SPI1CK, SPI1, COND1, SPI1_DESC);
561 SIG_EXPR_DECL_SINGLE(SPI1CK, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
562 SIG_EXPR_DECL_SINGLE(SPI1CK, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
563 SIG_EXPR_LIST_DECL(SPI1CK, SPI1,
564 			    SIG_EXPR_PTR(SPI1CK, SPI1),
565 			    SIG_EXPR_PTR(SPI1CK, SPI1DEBUG),
566 			    SIG_EXPR_PTR(SPI1CK, SPI1PASSTHRU));
567 SIG_EXPR_LIST_ALIAS(C15, SPI1CK, SPI1);
568 SIG_EXPR_LIST_DECL_SINGLE(C15, VBCK, VGABIOSROM, COND1, VB_DESC);
569 PIN_DECL_2(C15, GPIOI5, SPI1CK, VBCK);
570 
571 #define A14 70
572 SIG_EXPR_DECL_SINGLE(SPI1MOSI, SPI1, COND1, SPI1_DESC);
573 SIG_EXPR_DECL_SINGLE(SPI1MOSI, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
574 SIG_EXPR_DECL_SINGLE(SPI1MOSI, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
575 SIG_EXPR_LIST_DECL(SPI1MOSI, SPI1,
576 			    SIG_EXPR_PTR(SPI1MOSI, SPI1),
577 			    SIG_EXPR_PTR(SPI1MOSI, SPI1DEBUG),
578 			    SIG_EXPR_PTR(SPI1MOSI, SPI1PASSTHRU));
579 SIG_EXPR_LIST_ALIAS(A14, SPI1MOSI, SPI1);
580 SIG_EXPR_LIST_DECL_SINGLE(A14, VBMOSI, VGABIOSROM, COND1, VB_DESC);
581 PIN_DECL_2(A14, GPIOI6, SPI1MOSI, VBMOSI);
582 
583 #define A15 71
584 SIG_EXPR_DECL_SINGLE(SPI1MISO, SPI1, COND1, SPI1_DESC);
585 SIG_EXPR_DECL_SINGLE(SPI1MISO, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
586 SIG_EXPR_DECL_SINGLE(SPI1MISO, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
587 SIG_EXPR_LIST_DECL(SPI1MISO, SPI1,
588 			    SIG_EXPR_PTR(SPI1MISO, SPI1),
589 			    SIG_EXPR_PTR(SPI1MISO, SPI1DEBUG),
590 			    SIG_EXPR_PTR(SPI1MISO, SPI1PASSTHRU));
591 SIG_EXPR_LIST_ALIAS(A15, SPI1MISO, SPI1);
592 SIG_EXPR_LIST_DECL_SINGLE(A15, VBMISO, VGABIOSROM, COND1, VB_DESC);
593 PIN_DECL_2(A15, GPIOI7, SPI1MISO, VBMISO);
594 
595 FUNC_GROUP_DECL(SPI1, B15, C15, A14, A15);
596 FUNC_GROUP_DECL(SPI1DEBUG, C18, E15, B16, C16, B15, C15, A14, A15);
597 FUNC_GROUP_DECL(SPI1PASSTHRU, C18, E15, B16, C16, B15, C15, A14, A15);
598 FUNC_GROUP_DECL(VGABIOSROM, B15, C15, A14, A15);
599 
600 #define R2 72
601 SIG_EXPR_LIST_DECL_SINGLE(R2, SGPMCK, SGPM, SIG_DESC_SET(SCU84, 8));
602 PIN_DECL_1(R2, GPIOJ0, SGPMCK);
603 
604 #define L2 73
605 SIG_EXPR_LIST_DECL_SINGLE(L2, SGPMLD, SGPM, SIG_DESC_SET(SCU84, 9));
606 PIN_DECL_1(L2, GPIOJ1, SGPMLD);
607 
608 #define N3 74
609 SIG_EXPR_LIST_DECL_SINGLE(N3, SGPMO, SGPM, SIG_DESC_SET(SCU84, 10));
610 PIN_DECL_1(N3, GPIOJ2, SGPMO);
611 
612 #define N4 75
613 SIG_EXPR_LIST_DECL_SINGLE(N4, SGPMI, SGPM, SIG_DESC_SET(SCU84, 11));
614 PIN_DECL_1(N4, GPIOJ3, SGPMI);
615 
616 FUNC_GROUP_DECL(SGPM, R2, L2, N3, N4);
617 
618 #define N5 76
619 SIG_EXPR_LIST_DECL_SINGLE(N5, VGAHS, VGAHS, SIG_DESC_SET(SCU84, 12));
620 SIG_EXPR_LIST_DECL_SINGLE(N5, DASHN5, DASHN5, SIG_DESC_SET(SCU94, 8));
621 PIN_DECL_2(N5, GPIOJ4, VGAHS, DASHN5);
622 FUNC_GROUP_DECL(VGAHS, N5);
623 
624 #define R4 77
625 SIG_EXPR_LIST_DECL_SINGLE(R4, VGAVS, VGAVS, SIG_DESC_SET(SCU84, 13));
626 SIG_EXPR_LIST_DECL_SINGLE(R4, DASHR4, DASHR4, SIG_DESC_SET(SCU94, 8));
627 PIN_DECL_2(R4, GPIOJ5, VGAVS, DASHR4);
628 FUNC_GROUP_DECL(VGAVS, R4);
629 
630 #define R3 78
631 SIG_EXPR_LIST_DECL_SINGLE(R3, DDCCLK, DDCCLK, SIG_DESC_SET(SCU84, 14));
632 SIG_EXPR_LIST_DECL_SINGLE(R3, DASHR3, DASHR3, SIG_DESC_SET(SCU94, 9));
633 PIN_DECL_2(R3, GPIOJ6, DDCCLK, DASHR3);
634 FUNC_GROUP_DECL(DDCCLK, R3);
635 
636 #define T3 79
637 SIG_EXPR_LIST_DECL_SINGLE(T3, DDCDAT, DDCDAT, SIG_DESC_SET(SCU84, 15));
638 SIG_EXPR_LIST_DECL_SINGLE(T3, DASHT3, DASHT3, SIG_DESC_SET(SCU94, 9));
639 PIN_DECL_2(T3, GPIOJ7, DDCDAT, DASHT3);
640 FUNC_GROUP_DECL(DDCDAT, T3);
641 
642 #define I2C5_DESC       SIG_DESC_SET(SCU90, 18)
643 
644 #define L3 80
645 SIG_EXPR_LIST_DECL_SINGLE(L3, SCL5, I2C5, I2C5_DESC);
646 PIN_DECL_1(L3, GPIOK0, SCL5);
647 
648 #define L4 81
649 SIG_EXPR_LIST_DECL_SINGLE(L4, SDA5, I2C5, I2C5_DESC);
650 PIN_DECL_1(L4, GPIOK1, SDA5);
651 
652 FUNC_GROUP_DECL(I2C5, L3, L4);
653 
654 #define I2C6_DESC       SIG_DESC_SET(SCU90, 19)
655 
656 #define L1 82
657 SIG_EXPR_LIST_DECL_SINGLE(L1, SCL6, I2C6, I2C6_DESC);
658 PIN_DECL_1(L1, GPIOK2, SCL6);
659 
660 #define N2 83
661 SIG_EXPR_LIST_DECL_SINGLE(N2, SDA6, I2C6, I2C6_DESC);
662 PIN_DECL_1(N2, GPIOK3, SDA6);
663 
664 FUNC_GROUP_DECL(I2C6, L1, N2);
665 
666 #define I2C7_DESC       SIG_DESC_SET(SCU90, 20)
667 
668 #define N1 84
669 SIG_EXPR_LIST_DECL_SINGLE(N1, SCL7, I2C7, I2C7_DESC);
670 PIN_DECL_1(N1, GPIOK4, SCL7);
671 
672 #define P1 85
673 SIG_EXPR_LIST_DECL_SINGLE(P1, SDA7, I2C7, I2C7_DESC);
674 PIN_DECL_1(P1, GPIOK5, SDA7);
675 
676 FUNC_GROUP_DECL(I2C7, N1, P1);
677 
678 #define I2C8_DESC       SIG_DESC_SET(SCU90, 21)
679 
680 #define P2 86
681 SIG_EXPR_LIST_DECL_SINGLE(P2, SCL8, I2C8, I2C8_DESC);
682 PIN_DECL_1(P2, GPIOK6, SCL8);
683 
684 #define R1 87
685 SIG_EXPR_LIST_DECL_SINGLE(R1, SDA8, I2C8, I2C8_DESC);
686 PIN_DECL_1(R1, GPIOK7, SDA8);
687 
688 FUNC_GROUP_DECL(I2C8, P2, R1);
689 
690 #define T2 88
691 SSSF_PIN_DECL(T2, GPIOL0, NCTS1, SIG_DESC_SET(SCU84, 16));
692 
693 #define VPIOFF0_DESC    { ASPEED_IP_SCU, SCU90, GENMASK(5, 4), 0, 0 }
694 #define VPIOFF1_DESC    { ASPEED_IP_SCU, SCU90, GENMASK(5, 4), 1, 0 }
695 #define VPI24_DESC      { ASPEED_IP_SCU, SCU90, GENMASK(5, 4), 2, 0 }
696 #define VPIRSVD_DESC    { ASPEED_IP_SCU, SCU90, GENMASK(5, 4), 3, 0 }
697 #define VPI_24_RSVD_DESC	SIG_DESC_SET(SCU90, 5)
698 
699 #define T1 89
700 #define T1_DESC		SIG_DESC_SET(SCU84, 17)
701 SIG_EXPR_LIST_DECL_SINGLE(T1, VPIDE, VPI24, VPI_24_RSVD_DESC, T1_DESC, COND2);
702 SIG_EXPR_LIST_DECL_SINGLE(T1, NDCD1, NDCD1, T1_DESC, COND2);
703 PIN_DECL_2(T1, GPIOL1, VPIDE, NDCD1);
704 FUNC_GROUP_DECL(NDCD1, T1);
705 
706 #define U1 90
707 #define U1_DESC		SIG_DESC_SET(SCU84, 18)
708 SIG_EXPR_LIST_DECL_SINGLE(U1, DASHU1, VPI24, VPI_24_RSVD_DESC, U1_DESC);
709 SIG_EXPR_LIST_DECL_SINGLE(U1, NDSR1, NDSR1, U1_DESC);
710 PIN_DECL_2(U1, GPIOL2, DASHU1, NDSR1);
711 FUNC_GROUP_DECL(NDSR1, U1);
712 
713 #define U2 91
714 #define U2_DESC		SIG_DESC_SET(SCU84, 19)
715 SIG_EXPR_LIST_DECL_SINGLE(U2, VPIHS, VPI24, VPI_24_RSVD_DESC, U2_DESC, COND2);
716 SIG_EXPR_LIST_DECL_SINGLE(U2, NRI1, NRI1, U2_DESC, COND2);
717 PIN_DECL_2(U2, GPIOL3, VPIHS, NRI1);
718 FUNC_GROUP_DECL(NRI1, U2);
719 
720 #define P4 92
721 #define P4_DESC		SIG_DESC_SET(SCU84, 20)
722 SIG_EXPR_LIST_DECL_SINGLE(P4, VPIVS, VPI24, VPI_24_RSVD_DESC, P4_DESC, COND2);
723 SIG_EXPR_LIST_DECL_SINGLE(P4, NDTR1, NDTR1, P4_DESC, COND2);
724 PIN_DECL_2(P4, GPIOL4, VPIVS, NDTR1);
725 FUNC_GROUP_DECL(NDTR1, P4);
726 
727 #define P3 93
728 #define P3_DESC		SIG_DESC_SET(SCU84, 21)
729 SIG_EXPR_LIST_DECL_SINGLE(P3, VPICLK, VPI24, VPI_24_RSVD_DESC, P3_DESC, COND2);
730 SIG_EXPR_LIST_DECL_SINGLE(P3, NRTS1, NRTS1, P3_DESC, COND2);
731 PIN_DECL_2(P3, GPIOL5, VPICLK, NRTS1);
732 FUNC_GROUP_DECL(NRTS1, P3);
733 
734 #define V1 94
735 #define V1_DESC		SIG_DESC_SET(SCU84, 22)
736 SIG_EXPR_LIST_DECL_SINGLE(V1, DASHV1, DASHV1, VPIRSVD_DESC, V1_DESC);
737 SIG_EXPR_LIST_DECL_SINGLE(V1, TXD1, TXD1, V1_DESC, COND2);
738 PIN_DECL_2(V1, GPIOL6, DASHV1, TXD1);
739 FUNC_GROUP_DECL(TXD1, V1);
740 
741 #define W1 95
742 #define W1_DESC		SIG_DESC_SET(SCU84, 23)
743 SIG_EXPR_LIST_DECL_SINGLE(W1, DASHW1, DASHW1, VPIRSVD_DESC, W1_DESC);
744 SIG_EXPR_LIST_DECL_SINGLE(W1, RXD1, RXD1, W1_DESC, COND2);
745 PIN_DECL_2(W1, GPIOL7, DASHW1, RXD1);
746 FUNC_GROUP_DECL(RXD1, W1);
747 
748 #define Y1 96
749 #define Y1_DESC		SIG_DESC_SET(SCU84, 24)
750 SIG_EXPR_LIST_DECL_SINGLE(Y1, VPIB2, VPI24, VPI_24_RSVD_DESC, Y1_DESC, COND2);
751 SIG_EXPR_LIST_DECL_SINGLE(Y1, NCTS2, NCTS2, Y1_DESC, COND2);
752 PIN_DECL_2(Y1, GPIOM0, VPIB2, NCTS2);
753 FUNC_GROUP_DECL(NCTS2, Y1);
754 
755 #define AB2 97
756 #define AB2_DESC	SIG_DESC_SET(SCU84, 25)
757 SIG_EXPR_LIST_DECL_SINGLE(AB2, VPIB3, VPI24, VPI_24_RSVD_DESC, AB2_DESC, COND2);
758 SIG_EXPR_LIST_DECL_SINGLE(AB2, NDCD2, NDCD2, AB2_DESC, COND2);
759 PIN_DECL_2(AB2, GPIOM1, VPIB3, NDCD2);
760 FUNC_GROUP_DECL(NDCD2, AB2);
761 
762 #define AA1 98
763 #define AA1_DESC	SIG_DESC_SET(SCU84, 26)
764 SIG_EXPR_LIST_DECL_SINGLE(AA1, VPIB4, VPI24, VPI_24_RSVD_DESC, AA1_DESC, COND2);
765 SIG_EXPR_LIST_DECL_SINGLE(AA1, NDSR2, NDSR2, AA1_DESC, COND2);
766 PIN_DECL_2(AA1, GPIOM2, VPIB4, NDSR2);
767 FUNC_GROUP_DECL(NDSR2, AA1);
768 
769 #define Y2 99
770 #define Y2_DESC		SIG_DESC_SET(SCU84, 27)
771 SIG_EXPR_LIST_DECL_SINGLE(Y2, VPIB5, VPI24, VPI_24_RSVD_DESC, Y2_DESC, COND2);
772 SIG_EXPR_LIST_DECL_SINGLE(Y2, NRI2, NRI2, Y2_DESC, COND2);
773 PIN_DECL_2(Y2, GPIOM3, VPIB5, NRI2);
774 FUNC_GROUP_DECL(NRI2, Y2);
775 
776 #define AA2 100
777 #define AA2_DESC	SIG_DESC_SET(SCU84, 28)
778 SIG_EXPR_LIST_DECL_SINGLE(AA2, VPIB6, VPI24, VPI_24_RSVD_DESC, AA2_DESC, COND2);
779 SIG_EXPR_LIST_DECL_SINGLE(AA2, NDTR2, NDTR2, AA2_DESC, COND2);
780 PIN_DECL_2(AA2, GPIOM4, VPIB6, NDTR2);
781 FUNC_GROUP_DECL(NDTR2, AA2);
782 
783 #define P5 101
784 #define P5_DESC	SIG_DESC_SET(SCU84, 29)
785 SIG_EXPR_LIST_DECL_SINGLE(P5, VPIB7, VPI24, VPI_24_RSVD_DESC, P5_DESC, COND2);
786 SIG_EXPR_LIST_DECL_SINGLE(P5, NRTS2, NRTS2, P5_DESC, COND2);
787 PIN_DECL_2(P5, GPIOM5, VPIB7, NRTS2);
788 FUNC_GROUP_DECL(NRTS2, P5);
789 
790 #define R5 102
791 #define R5_DESC	SIG_DESC_SET(SCU84, 30)
792 SIG_EXPR_LIST_DECL_SINGLE(R5, VPIB8, VPI24, VPI_24_RSVD_DESC, R5_DESC, COND2);
793 SIG_EXPR_LIST_DECL_SINGLE(R5, TXD2, TXD2, R5_DESC, COND2);
794 PIN_DECL_2(R5, GPIOM6, VPIB8, TXD2);
795 FUNC_GROUP_DECL(TXD2, R5);
796 
797 #define T5 103
798 #define T5_DESC	SIG_DESC_SET(SCU84, 31)
799 SIG_EXPR_LIST_DECL_SINGLE(T5, VPIB9, VPI24, VPI_24_RSVD_DESC, T5_DESC, COND2);
800 SIG_EXPR_LIST_DECL_SINGLE(T5, RXD2, RXD2, T5_DESC, COND2);
801 PIN_DECL_2(T5, GPIOM7, VPIB9, RXD2);
802 FUNC_GROUP_DECL(RXD2, T5);
803 
804 #define V2 104
805 #define V2_DESC         SIG_DESC_SET(SCU88, 0)
806 SIG_EXPR_LIST_DECL_SINGLE(V2, DASHN0, DASHN0, VPIRSVD_DESC, V2_DESC);
807 SIG_EXPR_LIST_DECL_SINGLE(V2, PWM0, PWM0, V2_DESC, COND2);
808 PIN_DECL_2(V2, GPION0, DASHN0, PWM0);
809 FUNC_GROUP_DECL(PWM0, V2);
810 
811 #define W2 105
812 #define W2_DESC         SIG_DESC_SET(SCU88, 1)
813 SIG_EXPR_LIST_DECL_SINGLE(W2, DASHN1, DASHN1, VPIRSVD_DESC, W2_DESC);
814 SIG_EXPR_LIST_DECL_SINGLE(W2, PWM1, PWM1, W2_DESC, COND2);
815 PIN_DECL_2(W2, GPION1, DASHN1, PWM1);
816 FUNC_GROUP_DECL(PWM1, W2);
817 
818 #define V3 106
819 #define V3_DESC         SIG_DESC_SET(SCU88, 2)
820 SIG_EXPR_DECL_SINGLE(VPIG2, VPI24, VPI24_DESC, V3_DESC, COND2);
821 SIG_EXPR_DECL_SINGLE(VPIG2, VPIRSVD, VPIRSVD_DESC, V3_DESC, COND2);
822 SIG_EXPR_LIST_DECL_DUAL(V3, VPIG2, VPI24, VPIRSVD);
823 SIG_EXPR_LIST_DECL_SINGLE(V3, PWM2, PWM2, V3_DESC, COND2);
824 PIN_DECL_2(V3, GPION2, VPIG2, PWM2);
825 FUNC_GROUP_DECL(PWM2, V3);
826 
827 #define U3 107
828 #define U3_DESC         SIG_DESC_SET(SCU88, 3)
829 SIG_EXPR_DECL_SINGLE(VPIG3, VPI24, VPI24_DESC, U3_DESC, COND2);
830 SIG_EXPR_DECL_SINGLE(VPIG3, VPIRSVD, VPIRSVD_DESC, U3_DESC, COND2);
831 SIG_EXPR_LIST_DECL_DUAL(U3, VPIG3, VPI24, VPIRSVD);
832 SIG_EXPR_LIST_DECL_SINGLE(U3, PWM3, PWM3, U3_DESC, COND2);
833 PIN_DECL_2(U3, GPION3, VPIG3, PWM3);
834 FUNC_GROUP_DECL(PWM3, U3);
835 
836 #define W3 108
837 #define W3_DESC         SIG_DESC_SET(SCU88, 4)
838 SIG_EXPR_DECL_SINGLE(VPIG4, VPI24, VPI24_DESC, W3_DESC, COND2);
839 SIG_EXPR_DECL_SINGLE(VPIG4, VPIRSVD, VPIRSVD_DESC, W3_DESC, COND2);
840 SIG_EXPR_LIST_DECL_DUAL(W3, VPIG4, VPI24, VPIRSVD);
841 SIG_EXPR_LIST_DECL_SINGLE(W3, PWM4, PWM4, W3_DESC, COND2);
842 PIN_DECL_2(W3, GPION4, VPIG4, PWM4);
843 FUNC_GROUP_DECL(PWM4, W3);
844 
845 #define AA3 109
846 #define AA3_DESC        SIG_DESC_SET(SCU88, 5)
847 SIG_EXPR_DECL_SINGLE(VPIG5, VPI24, VPI24_DESC, AA3_DESC, COND2);
848 SIG_EXPR_DECL_SINGLE(VPIG5, VPIRSVD, VPIRSVD_DESC, AA3_DESC, COND2);
849 SIG_EXPR_LIST_DECL_DUAL(AA3, VPIG5, VPI24, VPIRSVD);
850 SIG_EXPR_LIST_DECL_SINGLE(AA3, PWM5, PWM5, AA3_DESC, COND2);
851 PIN_DECL_2(AA3, GPION5, VPIG5, PWM5);
852 FUNC_GROUP_DECL(PWM5, AA3);
853 
854 #define Y3 110
855 #define Y3_DESC         SIG_DESC_SET(SCU88, 6)
856 SIG_EXPR_LIST_DECL_SINGLE(Y3, VPIG6, VPI24, VPI24_DESC, Y3_DESC);
857 SIG_EXPR_LIST_DECL_SINGLE(Y3, PWM6, PWM6, Y3_DESC, COND2);
858 PIN_DECL_2(Y3, GPION6, VPIG6, PWM6);
859 FUNC_GROUP_DECL(PWM6, Y3);
860 
861 #define T4 111
862 #define T4_DESC         SIG_DESC_SET(SCU88, 7)
863 SIG_EXPR_LIST_DECL_SINGLE(T4, VPIG7, VPI24, VPI24_DESC, T4_DESC);
864 SIG_EXPR_LIST_DECL_SINGLE(T4, PWM7, PWM7, T4_DESC, COND2);
865 PIN_DECL_2(T4, GPION7, VPIG7, PWM7);
866 FUNC_GROUP_DECL(PWM7, T4);
867 
868 #define U5 112
869 SIG_EXPR_LIST_DECL_SINGLE(U5, VPIG8, VPI24, VPI24_DESC, SIG_DESC_SET(SCU88, 8),
870 			  COND2);
871 PIN_DECL_1(U5, GPIOO0, VPIG8);
872 
873 #define U4 113
874 SIG_EXPR_LIST_DECL_SINGLE(U4, VPIG9, VPI24, VPI24_DESC, SIG_DESC_SET(SCU88, 9),
875 			  COND2);
876 PIN_DECL_1(U4, GPIOO1, VPIG9);
877 
878 #define V5 114
879 SIG_EXPR_LIST_DECL_SINGLE(V5, DASHV5, DASHV5, VPI_24_RSVD_DESC,
880 			  SIG_DESC_SET(SCU88, 10));
881 PIN_DECL_1(V5, GPIOO2, DASHV5);
882 
883 #define AB4 115
884 SIG_EXPR_LIST_DECL_SINGLE(AB4, DASHAB4, DASHAB4, VPI_24_RSVD_DESC,
885 			  SIG_DESC_SET(SCU88, 11));
886 PIN_DECL_1(AB4, GPIOO3, DASHAB4);
887 
888 #define AB3 116
889 SIG_EXPR_LIST_DECL_SINGLE(AB3, VPIR2, VPI24, VPI24_DESC,
890 			  SIG_DESC_SET(SCU88, 12), COND2);
891 PIN_DECL_1(AB3, GPIOO4, VPIR2);
892 
893 #define Y4 117
894 SIG_EXPR_LIST_DECL_SINGLE(Y4, VPIR3, VPI24, VPI24_DESC,
895 			  SIG_DESC_SET(SCU88, 13), COND2);
896 PIN_DECL_1(Y4, GPIOO5, VPIR3);
897 
898 #define AA4 118
899 SIG_EXPR_LIST_DECL_SINGLE(AA4, VPIR4, VPI24, VPI24_DESC,
900 			  SIG_DESC_SET(SCU88, 14), COND2);
901 PIN_DECL_1(AA4, GPIOO6, VPIR4);
902 
903 #define W4 119
904 SIG_EXPR_LIST_DECL_SINGLE(W4, VPIR5, VPI24, VPI24_DESC,
905 			  SIG_DESC_SET(SCU88, 15), COND2);
906 PIN_DECL_1(W4, GPIOO7, VPIR5);
907 
908 #define V4 120
909 SIG_EXPR_LIST_DECL_SINGLE(V4, VPIR6, VPI24, VPI24_DESC,
910 			  SIG_DESC_SET(SCU88, 16), COND2);
911 PIN_DECL_1(V4, GPIOP0, VPIR6);
912 
913 #define W5 121
914 SIG_EXPR_LIST_DECL_SINGLE(W5, VPIR7, VPI24, VPI24_DESC,
915 			  SIG_DESC_SET(SCU88, 17), COND2);
916 PIN_DECL_1(W5, GPIOP1, VPIR7);
917 
918 #define AA5 122
919 SIG_EXPR_LIST_DECL_SINGLE(AA5, VPIR8, VPI24, VPI24_DESC,
920 			  SIG_DESC_SET(SCU88, 18), COND2);
921 PIN_DECL_1(AA5, GPIOP2, VPIR8);
922 
923 #define AB5 123
924 SIG_EXPR_LIST_DECL_SINGLE(AB5, VPIR9, VPI24, VPI24_DESC,
925 			  SIG_DESC_SET(SCU88, 19), COND2);
926 PIN_DECL_1(AB5, GPIOP3, VPIR9);
927 
928 FUNC_GROUP_DECL(VPI24, T1, U2, P4, P3, Y1, AB2, AA1, Y2, AA2, P5, R5, T5, V3,
929 		U3, W3, AA3, Y3, T4, U5, U4, AB3, Y4, AA4, W4, V4, W5, AA5,
930 		AB5);
931 
932 #define Y6 124
933 SIG_EXPR_LIST_DECL_SINGLE(Y6, DASHY6, DASHY6, SIG_DESC_SET(SCU90, 28),
934 			  SIG_DESC_SET(SCU88, 20));
935 PIN_DECL_1(Y6, GPIOP4, DASHY6);
936 
937 #define Y5 125
938 SIG_EXPR_LIST_DECL_SINGLE(Y5, DASHY5, DASHY5, SIG_DESC_SET(SCU90, 28),
939 			  SIG_DESC_SET(SCU88, 21));
940 PIN_DECL_1(Y5, GPIOP5, DASHY5);
941 
942 #define W6 126
943 SIG_EXPR_LIST_DECL_SINGLE(W6, DASHW6, DASHW6, SIG_DESC_SET(SCU90, 28),
944 			  SIG_DESC_SET(SCU88, 22));
945 PIN_DECL_1(W6, GPIOP6, DASHW6);
946 
947 #define V6 127
948 SIG_EXPR_LIST_DECL_SINGLE(V6, DASHV6, DASHV6, SIG_DESC_SET(SCU90, 28),
949 			  SIG_DESC_SET(SCU88, 23));
950 PIN_DECL_1(V6, GPIOP7, DASHV6);
951 
952 #define I2C3_DESC	SIG_DESC_SET(SCU90, 16)
953 
954 #define A11 128
955 SIG_EXPR_LIST_DECL_SINGLE(A11, SCL3, I2C3, I2C3_DESC);
956 PIN_DECL_1(A11, GPIOQ0, SCL3);
957 
958 #define A10 129
959 SIG_EXPR_LIST_DECL_SINGLE(A10, SDA3, I2C3, I2C3_DESC);
960 PIN_DECL_1(A10, GPIOQ1, SDA3);
961 
962 FUNC_GROUP_DECL(I2C3, A11, A10);
963 
964 #define I2C4_DESC	SIG_DESC_SET(SCU90, 17)
965 
966 #define A9 130
967 SIG_EXPR_LIST_DECL_SINGLE(A9, SCL4, I2C4, I2C4_DESC);
968 PIN_DECL_1(A9, GPIOQ2, SCL4);
969 
970 #define B9 131
971 SIG_EXPR_LIST_DECL_SINGLE(B9, SDA4, I2C4, I2C4_DESC);
972 PIN_DECL_1(B9, GPIOQ3, SDA4);
973 
974 FUNC_GROUP_DECL(I2C4, A9, B9);
975 
976 #define I2C14_DESC	SIG_DESC_SET(SCU90, 27)
977 
978 #define N21 132
979 SIG_EXPR_LIST_DECL_SINGLE(N21, SCL14, I2C14, I2C14_DESC);
980 PIN_DECL_1(N21, GPIOQ4, SCL14);
981 
982 #define N22 133
983 SIG_EXPR_LIST_DECL_SINGLE(N22, SDA14, I2C14, I2C14_DESC);
984 PIN_DECL_1(N22, GPIOQ5, SDA14);
985 
986 FUNC_GROUP_DECL(I2C14, N21, N22);
987 
988 #define B10 134
989 SSSF_PIN_DECL(B10, GPIOQ6, OSCCLK, SIG_DESC_SET(SCU2C, 1));
990 
991 #define N20 135
992 SSSF_PIN_DECL(N20, GPIOQ7, PEWAKE, SIG_DESC_SET(SCU2C, 29));
993 
994 #define AA19 136
995 SSSF_PIN_DECL(AA19, GPIOR0, FWSPICS1, SIG_DESC_SET(SCU88, 24), COND2);
996 
997 #define T19 137
998 SSSF_PIN_DECL(T19, GPIOR1, FWSPICS2, SIG_DESC_SET(SCU88, 25), COND2);
999 
1000 #define T17 138
1001 SSSF_PIN_DECL(T17, GPIOR2, SPI2CS0, SIG_DESC_SET(SCU88, 26), COND2);
1002 
1003 #define Y19 139
1004 SSSF_PIN_DECL(Y19, GPIOR3, SPI2CK, SIG_DESC_SET(SCU88, 27), COND2);
1005 
1006 #define W19 140
1007 SSSF_PIN_DECL(W19, GPIOR4, SPI2MOSI, SIG_DESC_SET(SCU88, 28), COND2);
1008 
1009 #define V19 141
1010 SSSF_PIN_DECL(V19, GPIOR5, SPI2MISO, SIG_DESC_SET(SCU88, 29), COND2);
1011 
1012 #define D8 142
1013 SIG_EXPR_LIST_DECL_SINGLE(D8, MDC1, MDIO1, SIG_DESC_SET(SCU88, 30));
1014 PIN_DECL_1(D8, GPIOR6, MDC1);
1015 
1016 #define E10 143
1017 SIG_EXPR_LIST_DECL_SINGLE(E10, MDIO1, MDIO1, SIG_DESC_SET(SCU88, 31));
1018 PIN_DECL_1(E10, GPIOR7, MDIO1);
1019 
1020 FUNC_GROUP_DECL(MDIO1, D8, E10);
1021 
1022 #define VPOOFF0_DESC	{ ASPEED_IP_SCU, SCU94, GENMASK(1, 0), 0, 0 }
1023 #define VPO_DESC	{ ASPEED_IP_SCU, SCU94, GENMASK(1, 0), 1, 0 }
1024 #define VPOOFF1_DESC	{ ASPEED_IP_SCU, SCU94, GENMASK(1, 0), 2, 0 }
1025 #define VPOOFF2_DESC	{ ASPEED_IP_SCU, SCU94, GENMASK(1, 0), 3, 0 }
1026 
1027 #define CRT_DVO_EN_DESC	SIG_DESC_IP_SET(ASPEED_IP_GFX, GFX064, 7)
1028 
1029 #define V20 144
1030 #define V20_DESC	SIG_DESC_SET(SCU8C, 0)
1031 SIG_EXPR_DECL_SINGLE(VPOB2, VPO, V20_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1032 SIG_EXPR_DECL_SINGLE(VPOB2, VPOOFF1, V20_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1033 SIG_EXPR_DECL_SINGLE(VPOB2, VPOOFF2, V20_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1034 SIG_EXPR_LIST_DECL(VPOB2, VPO,
1035 		SIG_EXPR_PTR(VPOB2, VPO),
1036 		SIG_EXPR_PTR(VPOB2, VPOOFF1),
1037 		SIG_EXPR_PTR(VPOB2, VPOOFF2));
1038 SIG_EXPR_LIST_ALIAS(V20, VPOB2, VPO);
1039 SIG_EXPR_LIST_DECL_SINGLE(V20, SPI2CS1, SPI2CS1, V20_DESC);
1040 PIN_DECL_2(V20, GPIOS0, VPOB2, SPI2CS1);
1041 FUNC_GROUP_DECL(SPI2CS1, V20);
1042 
1043 #define U19 145
1044 #define U19_DESC	SIG_DESC_SET(SCU8C, 1)
1045 SIG_EXPR_DECL_SINGLE(VPOB3, VPO, U19_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1046 SIG_EXPR_DECL_SINGLE(VPOB3, VPOOFF1, U19_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1047 SIG_EXPR_DECL_SINGLE(VPOB3, VPOOFF2, U19_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1048 SIG_EXPR_LIST_DECL(VPOB3, VPO,
1049 		SIG_EXPR_PTR(VPOB3, VPO),
1050 		SIG_EXPR_PTR(VPOB3, VPOOFF1),
1051 		SIG_EXPR_PTR(VPOB3, VPOOFF2));
1052 SIG_EXPR_LIST_ALIAS(U19, VPOB3, VPO);
1053 SIG_EXPR_LIST_DECL_SINGLE(U19, BMCINT, BMCINT, U19_DESC);
1054 PIN_DECL_2(U19, GPIOS1, VPOB3, BMCINT);
1055 FUNC_GROUP_DECL(BMCINT, U19);
1056 
1057 #define R18 146
1058 #define R18_DESC	SIG_DESC_SET(SCU8C, 2)
1059 SIG_EXPR_DECL_SINGLE(VPOB4, VPO, R18_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1060 SIG_EXPR_DECL_SINGLE(VPOB4, VPOOFF1, R18_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1061 SIG_EXPR_DECL_SINGLE(VPOB4, VPOOFF2, R18_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1062 SIG_EXPR_LIST_DECL(VPOB4, VPO,
1063 		SIG_EXPR_PTR(VPOB4, VPO),
1064 		SIG_EXPR_PTR(VPOB4, VPOOFF1),
1065 		SIG_EXPR_PTR(VPOB4, VPOOFF2));
1066 SIG_EXPR_LIST_ALIAS(R18, VPOB4, VPO);
1067 SIG_EXPR_LIST_DECL_SINGLE(R18, SALT5, SALT5, R18_DESC);
1068 PIN_DECL_2(R18, GPIOS2, VPOB4, SALT5);
1069 FUNC_GROUP_DECL(SALT5, R18);
1070 
1071 #define P18 147
1072 #define P18_DESC	SIG_DESC_SET(SCU8C, 3)
1073 SIG_EXPR_DECL_SINGLE(VPOB5, VPO, P18_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1074 SIG_EXPR_DECL_SINGLE(VPOB5, VPOOFF1, P18_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1075 SIG_EXPR_DECL_SINGLE(VPOB5, VPOOFF2, P18_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1076 SIG_EXPR_LIST_DECL(VPOB5, VPO,
1077 		SIG_EXPR_PTR(VPOB5, VPO),
1078 		SIG_EXPR_PTR(VPOB5, VPOOFF1),
1079 		SIG_EXPR_PTR(VPOB5, VPOOFF2));
1080 SIG_EXPR_LIST_ALIAS(P18, VPOB5, VPO);
1081 SIG_EXPR_LIST_DECL_SINGLE(P18, SALT6, SALT6, P18_DESC);
1082 PIN_DECL_2(P18, GPIOS3, VPOB5, SALT6);
1083 FUNC_GROUP_DECL(SALT6, P18);
1084 
1085 #define R19 148
1086 #define R19_DESC	SIG_DESC_SET(SCU8C, 4)
1087 SIG_EXPR_DECL_SINGLE(VPOB6, VPO, R19_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1088 SIG_EXPR_DECL_SINGLE(VPOB6, VPOOFF1, R19_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1089 SIG_EXPR_DECL_SINGLE(VPOB6, VPOOFF2, R19_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1090 SIG_EXPR_LIST_DECL(VPOB6, VPO,
1091 		SIG_EXPR_PTR(VPOB6, VPO),
1092 		SIG_EXPR_PTR(VPOB6, VPOOFF1),
1093 		SIG_EXPR_PTR(VPOB6, VPOOFF2));
1094 SIG_EXPR_LIST_ALIAS(R19, VPOB6, VPO);
1095 PIN_DECL_1(R19, GPIOS4, VPOB6);
1096 
1097 #define W20 149
1098 #define W20_DESC	SIG_DESC_SET(SCU8C, 5)
1099 SIG_EXPR_DECL_SINGLE(VPOB7, VPO, W20_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1100 SIG_EXPR_DECL_SINGLE(VPOB7, VPOOFF1, W20_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1101 SIG_EXPR_DECL_SINGLE(VPOB7, VPOOFF2, W20_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1102 SIG_EXPR_LIST_DECL(VPOB7, VPO,
1103 		SIG_EXPR_PTR(VPOB7, VPO),
1104 		SIG_EXPR_PTR(VPOB7, VPOOFF1),
1105 		SIG_EXPR_PTR(VPOB7, VPOOFF2));
1106 SIG_EXPR_LIST_ALIAS(W20, VPOB7, VPO);
1107 PIN_DECL_1(W20, GPIOS5, VPOB7);
1108 
1109 #define U20 150
1110 #define U20_DESC	SIG_DESC_SET(SCU8C, 6)
1111 SIG_EXPR_DECL_SINGLE(VPOB8, VPO, U20_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1112 SIG_EXPR_DECL_SINGLE(VPOB8, VPOOFF1, U20_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1113 SIG_EXPR_DECL_SINGLE(VPOB8, VPOOFF2, U20_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1114 SIG_EXPR_LIST_DECL(VPOB8, VPO,
1115 		SIG_EXPR_PTR(VPOB8, VPO),
1116 		SIG_EXPR_PTR(VPOB8, VPOOFF1),
1117 		SIG_EXPR_PTR(VPOB8, VPOOFF2));
1118 SIG_EXPR_LIST_ALIAS(U20, VPOB8, VPO);
1119 PIN_DECL_1(U20, GPIOS6, VPOB8);
1120 
1121 #define AA20 151
1122 #define AA20_DESC	SIG_DESC_SET(SCU8C, 7)
1123 SIG_EXPR_DECL_SINGLE(VPOB9, VPO, AA20_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1124 SIG_EXPR_DECL_SINGLE(VPOB9, VPOOFF1, AA20_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1125 SIG_EXPR_DECL_SINGLE(VPOB9, VPOOFF2, AA20_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1126 SIG_EXPR_LIST_DECL(VPOB9, VPO,
1127 		SIG_EXPR_PTR(VPOB9, VPO),
1128 		SIG_EXPR_PTR(VPOB9, VPOOFF1),
1129 		SIG_EXPR_PTR(VPOB9, VPOOFF2));
1130 SIG_EXPR_LIST_ALIAS(AA20, VPOB9, VPO);
1131 PIN_DECL_1(AA20, GPIOS7, VPOB9);
1132 
1133 /* RGMII1/RMII1 */
1134 
1135 #define RMII1_DESC      SIG_DESC_BIT(HW_STRAP1, 6, 0)
1136 #define RMII2_DESC      SIG_DESC_BIT(HW_STRAP1, 7, 0)
1137 
1138 #define B5 152
1139 SIG_EXPR_LIST_DECL_SINGLE(B5, GPIOT0, GPIOT0, SIG_DESC_SET(SCUA0, 0));
1140 SIG_EXPR_LIST_DECL_SINGLE(B5, RMII1RCLKO, RMII1, RMII1_DESC,
1141 		SIG_DESC_SET(SCU48, 29));
1142 SIG_EXPR_LIST_DECL_SINGLE(B5, RGMII1TXCK, RGMII1);
1143 PIN_DECL_(B5, SIG_EXPR_LIST_PTR(B5, GPIOT0), SIG_EXPR_LIST_PTR(B5, RMII1RCLKO),
1144 		SIG_EXPR_LIST_PTR(B5, RGMII1TXCK));
1145 
1146 #define E9 153
1147 SIG_EXPR_LIST_DECL_SINGLE(E9, GPIOT1, GPIOT1, SIG_DESC_SET(SCUA0, 1));
1148 SIG_EXPR_LIST_DECL_SINGLE(E9, RMII1TXEN, RMII1, RMII1_DESC);
1149 SIG_EXPR_LIST_DECL_SINGLE(E9, RGMII1TXCTL, RGMII1);
1150 PIN_DECL_(E9, SIG_EXPR_LIST_PTR(E9, GPIOT1), SIG_EXPR_LIST_PTR(E9, RMII1TXEN),
1151 		SIG_EXPR_LIST_PTR(E9, RGMII1TXCTL));
1152 
1153 #define F9 154
1154 SIG_EXPR_LIST_DECL_SINGLE(F9, GPIOT2, GPIOT2, SIG_DESC_SET(SCUA0, 2));
1155 SIG_EXPR_LIST_DECL_SINGLE(F9, RMII1TXD0, RMII1, RMII1_DESC);
1156 SIG_EXPR_LIST_DECL_SINGLE(F9, RGMII1TXD0, RGMII1);
1157 PIN_DECL_(F9, SIG_EXPR_LIST_PTR(F9, GPIOT2), SIG_EXPR_LIST_PTR(F9, RMII1TXD0),
1158 		SIG_EXPR_LIST_PTR(F9, RGMII1TXD0));
1159 
1160 #define A5 155
1161 SIG_EXPR_LIST_DECL_SINGLE(A5, GPIOT3, GPIOT3, SIG_DESC_SET(SCUA0, 3));
1162 SIG_EXPR_LIST_DECL_SINGLE(A5, RMII1TXD1, RMII1, RMII1_DESC);
1163 SIG_EXPR_LIST_DECL_SINGLE(A5, RGMII1TXD1, RGMII1);
1164 PIN_DECL_(A5, SIG_EXPR_LIST_PTR(A5, GPIOT3), SIG_EXPR_LIST_PTR(A5, RMII1TXD1),
1165 		SIG_EXPR_LIST_PTR(A5, RGMII1TXD1));
1166 
1167 #define E7 156
1168 SIG_EXPR_LIST_DECL_SINGLE(E7, GPIOT4, GPIOT4, SIG_DESC_SET(SCUA0, 4));
1169 SIG_EXPR_LIST_DECL_SINGLE(E7, RMII1DASH0, RMII1, RMII1_DESC);
1170 SIG_EXPR_LIST_DECL_SINGLE(E7, RGMII1TXD2, RGMII1);
1171 PIN_DECL_(E7, SIG_EXPR_LIST_PTR(E7, GPIOT4), SIG_EXPR_LIST_PTR(E7, RMII1DASH0),
1172 		SIG_EXPR_LIST_PTR(E7, RGMII1TXD2));
1173 
1174 #define D7 157
1175 SIG_EXPR_LIST_DECL_SINGLE(D7, GPIOT5, GPIOT5, SIG_DESC_SET(SCUA0, 5));
1176 SIG_EXPR_LIST_DECL_SINGLE(D7, RMII1DASH1, RMII1, RMII1_DESC);
1177 SIG_EXPR_LIST_DECL_SINGLE(D7, RGMII1TXD3, RGMII1);
1178 PIN_DECL_(D7, SIG_EXPR_LIST_PTR(D7, GPIOT5), SIG_EXPR_LIST_PTR(D7, RMII1DASH1),
1179 		SIG_EXPR_LIST_PTR(D7, RGMII1TXD3));
1180 
1181 #define B2 158
1182 SIG_EXPR_LIST_DECL_SINGLE(B2, GPIOT6, GPIOT6, SIG_DESC_SET(SCUA0, 6));
1183 SIG_EXPR_LIST_DECL_SINGLE(B2, RMII2RCLKO, RMII2, RMII2_DESC,
1184 		SIG_DESC_SET(SCU48, 30));
1185 SIG_EXPR_LIST_DECL_SINGLE(B2, RGMII2TXCK, RGMII2);
1186 PIN_DECL_(B2, SIG_EXPR_LIST_PTR(B2, GPIOT6), SIG_EXPR_LIST_PTR(B2, RMII2RCLKO),
1187 		SIG_EXPR_LIST_PTR(B2, RGMII2TXCK));
1188 
1189 #define B1 159
1190 SIG_EXPR_LIST_DECL_SINGLE(B1, GPIOT7, GPIOT7, SIG_DESC_SET(SCUA0, 7));
1191 SIG_EXPR_LIST_DECL_SINGLE(B1, RMII2TXEN, RMII2, RMII2_DESC);
1192 SIG_EXPR_LIST_DECL_SINGLE(B1, RGMII2TXCTL, RGMII2);
1193 PIN_DECL_(B1, SIG_EXPR_LIST_PTR(B1, GPIOT7), SIG_EXPR_LIST_PTR(B1, RMII2TXEN),
1194 		SIG_EXPR_LIST_PTR(B1, RGMII2TXCTL));
1195 
1196 #define A2 160
1197 SIG_EXPR_LIST_DECL_SINGLE(A2, GPIOU0, GPIOU0, SIG_DESC_SET(SCUA0, 8));
1198 SIG_EXPR_LIST_DECL_SINGLE(A2, RMII2TXD0, RMII2, RMII2_DESC);
1199 SIG_EXPR_LIST_DECL_SINGLE(A2, RGMII2TXD0, RGMII2);
1200 PIN_DECL_(A2, SIG_EXPR_LIST_PTR(A2, GPIOU0), SIG_EXPR_LIST_PTR(A2, RMII2TXD0),
1201 		SIG_EXPR_LIST_PTR(A2, RGMII2TXD0));
1202 
1203 #define B3 161
1204 SIG_EXPR_LIST_DECL_SINGLE(B3, GPIOU1, GPIOU1, SIG_DESC_SET(SCUA0, 9));
1205 SIG_EXPR_LIST_DECL_SINGLE(B3, RMII2TXD1, RMII2, RMII2_DESC);
1206 SIG_EXPR_LIST_DECL_SINGLE(B3, RGMII2TXD1, RGMII2);
1207 PIN_DECL_(B3, SIG_EXPR_LIST_PTR(B3, GPIOU1), SIG_EXPR_LIST_PTR(B3, RMII2TXD1),
1208 		SIG_EXPR_LIST_PTR(B3, RGMII2TXD1));
1209 
1210 #define D5 162
1211 SIG_EXPR_LIST_DECL_SINGLE(D5, GPIOU2, GPIOU2, SIG_DESC_SET(SCUA0, 10));
1212 SIG_EXPR_LIST_DECL_SINGLE(D5, RMII2DASH0, RMII2, RMII2_DESC);
1213 SIG_EXPR_LIST_DECL_SINGLE(D5, RGMII2TXD2, RGMII2);
1214 PIN_DECL_(D5, SIG_EXPR_LIST_PTR(D5, GPIOU2), SIG_EXPR_LIST_PTR(D5, RMII2DASH0),
1215 		SIG_EXPR_LIST_PTR(D5, RGMII2TXD2));
1216 
1217 #define D4 163
1218 SIG_EXPR_LIST_DECL_SINGLE(D4, GPIOU3, GPIOU3, SIG_DESC_SET(SCUA0, 11));
1219 SIG_EXPR_LIST_DECL_SINGLE(D4, RMII2DASH1, RMII2, RMII2_DESC);
1220 SIG_EXPR_LIST_DECL_SINGLE(D4, RGMII2TXD3, RGMII2);
1221 PIN_DECL_(D4, SIG_EXPR_LIST_PTR(D4, GPIOU3), SIG_EXPR_LIST_PTR(D4, RMII2DASH1),
1222 		SIG_EXPR_LIST_PTR(D4, RGMII2TXD3));
1223 
1224 #define B4 164
1225 SIG_EXPR_LIST_DECL_SINGLE(B4, GPIOU4, GPIOU4, SIG_DESC_SET(SCUA0, 12));
1226 SIG_EXPR_LIST_DECL_SINGLE(B4, RMII1RCLKI, RMII1, RMII1_DESC);
1227 SIG_EXPR_LIST_DECL_SINGLE(B4, RGMII1RXCK, RGMII1);
1228 PIN_DECL_(B4, SIG_EXPR_LIST_PTR(B4, GPIOU4), SIG_EXPR_LIST_PTR(B4, RMII1RCLKI),
1229 		SIG_EXPR_LIST_PTR(B4, RGMII1RXCK));
1230 
1231 #define A4 165
1232 SIG_EXPR_LIST_DECL_SINGLE(A4, GPIOU5, GPIOU5, SIG_DESC_SET(SCUA0, 13));
1233 SIG_EXPR_LIST_DECL_SINGLE(A4, RMII1DASH2, RMII1, RMII1_DESC);
1234 SIG_EXPR_LIST_DECL_SINGLE(A4, RGMII1RXCTL, RGMII1);
1235 PIN_DECL_(A4, SIG_EXPR_LIST_PTR(A4, GPIOU5), SIG_EXPR_LIST_PTR(A4, RMII1DASH2),
1236 		SIG_EXPR_LIST_PTR(A4, RGMII1RXCTL));
1237 
1238 #define A3 166
1239 SIG_EXPR_LIST_DECL_SINGLE(A3, GPIOU6, GPIOU6, SIG_DESC_SET(SCUA0, 14));
1240 SIG_EXPR_LIST_DECL_SINGLE(A3, RMII1RXD0, RMII1, RMII1_DESC);
1241 SIG_EXPR_LIST_DECL_SINGLE(A3, RGMII1RXD0, RGMII1);
1242 PIN_DECL_(A3, SIG_EXPR_LIST_PTR(A3, GPIOU6), SIG_EXPR_LIST_PTR(A3, RMII1RXD0),
1243 		SIG_EXPR_LIST_PTR(A3, RGMII1RXD0));
1244 
1245 #define D6 167
1246 SIG_EXPR_LIST_DECL_SINGLE(D6, GPIOU7, GPIOU7, SIG_DESC_SET(SCUA0, 15));
1247 SIG_EXPR_LIST_DECL_SINGLE(D6, RMII1RXD1, RMII1, RMII1_DESC);
1248 SIG_EXPR_LIST_DECL_SINGLE(D6, RGMII1RXD1, RGMII1);
1249 PIN_DECL_(D6, SIG_EXPR_LIST_PTR(D6, GPIOU7), SIG_EXPR_LIST_PTR(D6, RMII1RXD1),
1250 		SIG_EXPR_LIST_PTR(D6, RGMII1RXD1));
1251 
1252 #define C5 168
1253 SIG_EXPR_LIST_DECL_SINGLE(C5, GPIOV0, GPIOV0, SIG_DESC_SET(SCUA0, 16));
1254 SIG_EXPR_LIST_DECL_SINGLE(C5, RMII1CRSDV, RMII1, RMII1_DESC);
1255 SIG_EXPR_LIST_DECL_SINGLE(C5, RGMII1RXD2, RGMII1);
1256 PIN_DECL_(C5, SIG_EXPR_LIST_PTR(C5, GPIOV0), SIG_EXPR_LIST_PTR(C5, RMII1CRSDV),
1257 		SIG_EXPR_LIST_PTR(C5, RGMII1RXD2));
1258 
1259 #define C4 169
1260 SIG_EXPR_LIST_DECL_SINGLE(C4, GPIOV1, GPIOV1, SIG_DESC_SET(SCUA0, 17));
1261 SIG_EXPR_LIST_DECL_SINGLE(C4, RMII1RXER, RMII1, RMII1_DESC);
1262 SIG_EXPR_LIST_DECL_SINGLE(C4, RGMII1RXD3, RGMII1);
1263 PIN_DECL_(C4, SIG_EXPR_LIST_PTR(C4, GPIOV1), SIG_EXPR_LIST_PTR(C4, RMII1RXER),
1264 		SIG_EXPR_LIST_PTR(C4, RGMII1RXD3));
1265 
1266 FUNC_GROUP_DECL(RGMII1, B4, A4, A3, D6, C5, C4, B5, E9, F9, A5, E7, D7);
1267 FUNC_GROUP_DECL(RMII1, B4, A3, D6, C5, C4, B5, E9, F9, A5);
1268 
1269 #define C2 170
1270 SIG_EXPR_LIST_DECL_SINGLE(C2, GPIOV2, GPIOV2, SIG_DESC_SET(SCUA0, 18));
1271 SIG_EXPR_LIST_DECL_SINGLE(C2, RMII2RCLKI, RMII2, RMII2_DESC);
1272 SIG_EXPR_LIST_DECL_SINGLE(C2, RGMII2RXCK, RGMII2);
1273 PIN_DECL_(C2, SIG_EXPR_LIST_PTR(C2, GPIOV2), SIG_EXPR_LIST_PTR(C2, RMII2RCLKI),
1274 		SIG_EXPR_LIST_PTR(C2, RGMII2RXCK));
1275 
1276 #define C1 171
1277 SIG_EXPR_LIST_DECL_SINGLE(C1, GPIOV3, GPIOV3, SIG_DESC_SET(SCUA0, 19));
1278 SIG_EXPR_LIST_DECL_SINGLE(C1, RMII2DASH2, RMII2, RMII2_DESC);
1279 SIG_EXPR_LIST_DECL_SINGLE(C1, RGMII2RXCTL, RGMII2);
1280 PIN_DECL_(C1, SIG_EXPR_LIST_PTR(C1, GPIOV3), SIG_EXPR_LIST_PTR(C1, RMII2DASH2),
1281 		SIG_EXPR_LIST_PTR(C1, RGMII2RXCTL));
1282 
1283 #define C3 172
1284 SIG_EXPR_LIST_DECL_SINGLE(C3, GPIOV4, GPIOV4, SIG_DESC_SET(SCUA0, 20));
1285 SIG_EXPR_LIST_DECL_SINGLE(C3, RMII2RXD0, RMII2, RMII2_DESC);
1286 SIG_EXPR_LIST_DECL_SINGLE(C3, RGMII2RXD0, RGMII2);
1287 PIN_DECL_(C3, SIG_EXPR_LIST_PTR(C3, GPIOV4), SIG_EXPR_LIST_PTR(C3, RMII2RXD0),
1288 		SIG_EXPR_LIST_PTR(C3, RGMII2RXD0));
1289 
1290 #define D1 173
1291 SIG_EXPR_LIST_DECL_SINGLE(D1, GPIOV5, GPIOV5, SIG_DESC_SET(SCUA0, 21));
1292 SIG_EXPR_LIST_DECL_SINGLE(D1, RMII2RXD1, RMII2, RMII2_DESC);
1293 SIG_EXPR_LIST_DECL_SINGLE(D1, RGMII2RXD1, RGMII2);
1294 PIN_DECL_(D1, SIG_EXPR_LIST_PTR(D1, GPIOV5), SIG_EXPR_LIST_PTR(D1, RMII2RXD1),
1295 		SIG_EXPR_LIST_PTR(D1, RGMII2RXD1));
1296 
1297 #define D2 174
1298 SIG_EXPR_LIST_DECL_SINGLE(D2, GPIOV6, GPIOV6, SIG_DESC_SET(SCUA0, 22));
1299 SIG_EXPR_LIST_DECL_SINGLE(D2, RMII2CRSDV, RMII2, RMII2_DESC);
1300 SIG_EXPR_LIST_DECL_SINGLE(D2, RGMII2RXD2, RGMII2);
1301 PIN_DECL_(D2, SIG_EXPR_LIST_PTR(D2, GPIOV6), SIG_EXPR_LIST_PTR(D2, RMII2CRSDV),
1302 		SIG_EXPR_LIST_PTR(D2, RGMII2RXD2));
1303 
1304 #define E6 175
1305 SIG_EXPR_LIST_DECL_SINGLE(E6, GPIOV7, GPIOV7, SIG_DESC_SET(SCUA0, 23));
1306 SIG_EXPR_LIST_DECL_SINGLE(E6, RMII2RXER, RMII2, RMII2_DESC);
1307 SIG_EXPR_LIST_DECL_SINGLE(E6, RGMII2RXD3, RGMII2);
1308 PIN_DECL_(E6, SIG_EXPR_LIST_PTR(E6, GPIOV7), SIG_EXPR_LIST_PTR(E6, RMII2RXER),
1309 		SIG_EXPR_LIST_PTR(E6, RGMII2RXD3));
1310 
1311 FUNC_GROUP_DECL(RGMII2, B2, B1, A2, B3, D5, D4, C2, C1, C3, D1, D2, E6);
1312 FUNC_GROUP_DECL(RMII2, B2, B1, A2, B3, C2, C3, D1, D2, E6);
1313 
1314 #define F4 176
1315 SIG_EXPR_LIST_DECL_SINGLE(F4, GPIOW0, GPIOW0, SIG_DESC_SET(SCUA0, 24));
1316 SIG_EXPR_LIST_DECL_SINGLE(F4, ADC0, ADC0);
1317 PIN_DECL_(F4, SIG_EXPR_LIST_PTR(F4, GPIOW0), SIG_EXPR_LIST_PTR(F4, ADC0));
1318 FUNC_GROUP_DECL(ADC0, F4);
1319 
1320 #define F5 177
1321 SIG_EXPR_LIST_DECL_SINGLE(F5, GPIOW1, GPIOW1, SIG_DESC_SET(SCUA0, 25));
1322 SIG_EXPR_LIST_DECL_SINGLE(F5, ADC1, ADC1);
1323 PIN_DECL_(F5, SIG_EXPR_LIST_PTR(F5, GPIOW1), SIG_EXPR_LIST_PTR(F5, ADC1));
1324 FUNC_GROUP_DECL(ADC1, F5);
1325 
1326 #define E2 178
1327 SIG_EXPR_LIST_DECL_SINGLE(E2, GPIOW2, GPIOW2, SIG_DESC_SET(SCUA0, 26));
1328 SIG_EXPR_LIST_DECL_SINGLE(E2, ADC2, ADC2);
1329 PIN_DECL_(E2, SIG_EXPR_LIST_PTR(E2, GPIOW2), SIG_EXPR_LIST_PTR(E2, ADC2));
1330 FUNC_GROUP_DECL(ADC2, E2);
1331 
1332 #define E1 179
1333 SIG_EXPR_LIST_DECL_SINGLE(E1, GPIOW3, GPIOW3, SIG_DESC_SET(SCUA0, 27));
1334 SIG_EXPR_LIST_DECL_SINGLE(E1, ADC3, ADC3);
1335 PIN_DECL_(E1, SIG_EXPR_LIST_PTR(E1, GPIOW3), SIG_EXPR_LIST_PTR(E1, ADC3));
1336 FUNC_GROUP_DECL(ADC3, E1);
1337 
1338 #define F3 180
1339 SIG_EXPR_LIST_DECL_SINGLE(F3, GPIOW4, GPIOW4, SIG_DESC_SET(SCUA0, 28));
1340 SIG_EXPR_LIST_DECL_SINGLE(F3, ADC4, ADC4);
1341 PIN_DECL_(F3, SIG_EXPR_LIST_PTR(F3, GPIOW4), SIG_EXPR_LIST_PTR(F3, ADC4));
1342 FUNC_GROUP_DECL(ADC4, F3);
1343 
1344 #define E3 181
1345 SIG_EXPR_LIST_DECL_SINGLE(E3, GPIOW5, GPIOW5, SIG_DESC_SET(SCUA0, 29));
1346 SIG_EXPR_LIST_DECL_SINGLE(E3, ADC5, ADC5);
1347 PIN_DECL_(E3, SIG_EXPR_LIST_PTR(E3, GPIOW5), SIG_EXPR_LIST_PTR(E3, ADC5));
1348 FUNC_GROUP_DECL(ADC5, E3);
1349 
1350 #define G5 182
1351 SIG_EXPR_LIST_DECL_SINGLE(G5, GPIOW6, GPIOW6, SIG_DESC_SET(SCUA0, 30));
1352 SIG_EXPR_LIST_DECL_SINGLE(G5, ADC6, ADC6);
1353 PIN_DECL_(G5, SIG_EXPR_LIST_PTR(G5, GPIOW6), SIG_EXPR_LIST_PTR(G5, ADC6));
1354 FUNC_GROUP_DECL(ADC6, G5);
1355 
1356 #define G4 183
1357 SIG_EXPR_LIST_DECL_SINGLE(G4, GPIOW7, GPIOW7, SIG_DESC_SET(SCUA0, 31));
1358 SIG_EXPR_LIST_DECL_SINGLE(G4, ADC7, ADC7);
1359 PIN_DECL_(G4, SIG_EXPR_LIST_PTR(G4, GPIOW7), SIG_EXPR_LIST_PTR(G4, ADC7));
1360 FUNC_GROUP_DECL(ADC7, G4);
1361 
1362 #define F2 184
1363 SIG_EXPR_LIST_DECL_SINGLE(F2, GPIOX0, GPIOX0, SIG_DESC_SET(SCUA4, 0));
1364 SIG_EXPR_LIST_DECL_SINGLE(F2, ADC8, ADC8);
1365 PIN_DECL_(F2, SIG_EXPR_LIST_PTR(F2, GPIOX0), SIG_EXPR_LIST_PTR(F2, ADC8));
1366 FUNC_GROUP_DECL(ADC8, F2);
1367 
1368 #define G3 185
1369 SIG_EXPR_LIST_DECL_SINGLE(G3, GPIOX1, GPIOX1, SIG_DESC_SET(SCUA4, 1));
1370 SIG_EXPR_LIST_DECL_SINGLE(G3, ADC9, ADC9);
1371 PIN_DECL_(G3, SIG_EXPR_LIST_PTR(G3, GPIOX1), SIG_EXPR_LIST_PTR(G3, ADC9));
1372 FUNC_GROUP_DECL(ADC9, G3);
1373 
1374 #define G2 186
1375 SIG_EXPR_LIST_DECL_SINGLE(G2, GPIOX2, GPIOX2, SIG_DESC_SET(SCUA4, 2));
1376 SIG_EXPR_LIST_DECL_SINGLE(G2, ADC10, ADC10);
1377 PIN_DECL_(G2, SIG_EXPR_LIST_PTR(G2, GPIOX2), SIG_EXPR_LIST_PTR(G2, ADC10));
1378 FUNC_GROUP_DECL(ADC10, G2);
1379 
1380 #define F1 187
1381 SIG_EXPR_LIST_DECL_SINGLE(F1, GPIOX3, GPIOX3, SIG_DESC_SET(SCUA4, 3));
1382 SIG_EXPR_LIST_DECL_SINGLE(F1, ADC11, ADC11);
1383 PIN_DECL_(F1, SIG_EXPR_LIST_PTR(F1, GPIOX3), SIG_EXPR_LIST_PTR(F1, ADC11));
1384 FUNC_GROUP_DECL(ADC11, F1);
1385 
1386 #define H5 188
1387 SIG_EXPR_LIST_DECL_SINGLE(H5, GPIOX4, GPIOX4, SIG_DESC_SET(SCUA4, 4));
1388 SIG_EXPR_LIST_DECL_SINGLE(H5, ADC12, ADC12);
1389 PIN_DECL_(H5, SIG_EXPR_LIST_PTR(H5, GPIOX4), SIG_EXPR_LIST_PTR(H5, ADC12));
1390 FUNC_GROUP_DECL(ADC12, H5);
1391 
1392 #define G1 189
1393 SIG_EXPR_LIST_DECL_SINGLE(G1, GPIOX5, GPIOX5, SIG_DESC_SET(SCUA4, 5));
1394 SIG_EXPR_LIST_DECL_SINGLE(G1, ADC13, ADC13);
1395 PIN_DECL_(G1, SIG_EXPR_LIST_PTR(G1, GPIOX5), SIG_EXPR_LIST_PTR(G1, ADC13));
1396 FUNC_GROUP_DECL(ADC13, G1);
1397 
1398 #define H3 190
1399 SIG_EXPR_LIST_DECL_SINGLE(H3, GPIOX6, GPIOX6, SIG_DESC_SET(SCUA4, 6));
1400 SIG_EXPR_LIST_DECL_SINGLE(H3, ADC14, ADC14);
1401 PIN_DECL_(H3, SIG_EXPR_LIST_PTR(H3, GPIOX6), SIG_EXPR_LIST_PTR(H3, ADC14));
1402 FUNC_GROUP_DECL(ADC14, H3);
1403 
1404 #define H4 191
1405 SIG_EXPR_LIST_DECL_SINGLE(H4, GPIOX7, GPIOX7, SIG_DESC_SET(SCUA4, 7));
1406 SIG_EXPR_LIST_DECL_SINGLE(H4, ADC15, ADC15);
1407 PIN_DECL_(H4, SIG_EXPR_LIST_PTR(H4, GPIOX7), SIG_EXPR_LIST_PTR(H4, ADC15));
1408 FUNC_GROUP_DECL(ADC15, H4);
1409 
1410 #define ACPI_DESC	SIG_DESC_SET(HW_STRAP1, 19)
1411 
1412 #define R22 192
1413 SIG_EXPR_DECL_SINGLE(SIOS3, SIOS3, SIG_DESC_SET(SCUA4, 8));
1414 SIG_EXPR_DECL_SINGLE(SIOS3, ACPI, ACPI_DESC);
1415 SIG_EXPR_LIST_DECL_DUAL(R22, SIOS3, SIOS3, ACPI);
1416 SIG_EXPR_LIST_DECL_SINGLE(R22, DASHR22, DASHR22, SIG_DESC_SET(SCU94, 10));
1417 PIN_DECL_2(R22, GPIOY0, SIOS3, DASHR22);
1418 FUNC_GROUP_DECL(SIOS3, R22);
1419 
1420 #define R21 193
1421 SIG_EXPR_DECL_SINGLE(SIOS5, SIOS5, SIG_DESC_SET(SCUA4, 9));
1422 SIG_EXPR_DECL_SINGLE(SIOS5, ACPI, ACPI_DESC);
1423 SIG_EXPR_LIST_DECL_DUAL(R21, SIOS5, SIOS5, ACPI);
1424 SIG_EXPR_LIST_DECL_SINGLE(R21, DASHR21, DASHR21, SIG_DESC_SET(SCU94, 10));
1425 PIN_DECL_2(R21, GPIOY1, SIOS5, DASHR21);
1426 FUNC_GROUP_DECL(SIOS5, R21);
1427 
1428 #define P22 194
1429 SIG_EXPR_DECL_SINGLE(SIOPWREQ, SIOPWREQ, SIG_DESC_SET(SCUA4, 10));
1430 SIG_EXPR_DECL_SINGLE(SIOPWREQ, ACPI, ACPI_DESC);
1431 SIG_EXPR_LIST_DECL_DUAL(P22, SIOPWREQ, SIOPWREQ, ACPI);
1432 SIG_EXPR_LIST_DECL_SINGLE(P22, DASHP22, DASHP22, SIG_DESC_SET(SCU94, 11));
1433 PIN_DECL_2(P22, GPIOY2, SIOPWREQ, DASHP22);
1434 FUNC_GROUP_DECL(SIOPWREQ, P22);
1435 
1436 #define P21 195
1437 SIG_EXPR_DECL_SINGLE(SIOONCTRL, SIOONCTRL, SIG_DESC_SET(SCUA4, 11));
1438 SIG_EXPR_DECL_SINGLE(SIOONCTRL, ACPI, ACPI_DESC);
1439 SIG_EXPR_LIST_DECL_DUAL(P21, SIOONCTRL, SIOONCTRL, ACPI);
1440 SIG_EXPR_LIST_DECL_SINGLE(P21, DASHP21, DASHP21, SIG_DESC_SET(SCU94, 11));
1441 PIN_DECL_2(P21, GPIOY3, SIOONCTRL, DASHP21);
1442 FUNC_GROUP_DECL(SIOONCTRL, P21);
1443 
1444 #define M18 196
1445 SSSF_PIN_DECL(M18, GPIOY4, SCL1, SIG_DESC_SET(SCUA4, 12));
1446 
1447 #define M19 197
1448 SSSF_PIN_DECL(M19, GPIOY5, SDA1, SIG_DESC_SET(SCUA4, 13));
1449 
1450 #define M20 198
1451 SSSF_PIN_DECL(M20, GPIOY6, SCL2, SIG_DESC_SET(SCUA4, 14));
1452 
1453 #define P20 199
1454 SSSF_PIN_DECL(P20, GPIOY7, SDA2, SIG_DESC_SET(SCUA4, 15));
1455 
1456 #define PNOR_DESC	SIG_DESC_SET(SCU90, 31)
1457 
1458 #define Y20 200
1459 #define Y20_DESC	SIG_DESC_SET(SCUA4, 16)
1460 SIG_EXPR_DECL_SINGLE(VPOG2, VPO, Y20_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1461 SIG_EXPR_DECL_SINGLE(VPOG2, VPOOFF1, Y20_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1462 SIG_EXPR_DECL_SINGLE(VPOG2, VPOOFF2, Y20_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1463 SIG_EXPR_LIST_DECL(VPOG2, VPO,
1464 		SIG_EXPR_PTR(VPOG2, VPO),
1465 		SIG_EXPR_PTR(VPOG2, VPOOFF1),
1466 		SIG_EXPR_PTR(VPOG2, VPOOFF2));
1467 SIG_EXPR_LIST_ALIAS(Y20, VPOG2, VPO);
1468 SIG_EXPR_DECL_SINGLE(SIOPBI, SIOPBI, Y20_DESC);
1469 SIG_EXPR_DECL_SINGLE(SIOPBI, ACPI, Y20_DESC);
1470 SIG_EXPR_LIST_DECL_DUAL(Y20, SIOPBI, SIOPBI, ACPI);
1471 SIG_EXPR_LIST_DECL_SINGLE(Y20, NORA0, PNOR, PNOR_DESC);
1472 SIG_EXPR_LIST_DECL_SINGLE(Y20, GPIOZ0, GPIOZ0);
1473 PIN_DECL_(Y20, SIG_EXPR_LIST_PTR(Y20, VPOG2), SIG_EXPR_LIST_PTR(Y20, SIOPBI),
1474 		SIG_EXPR_LIST_PTR(Y20, NORA0), SIG_EXPR_LIST_PTR(Y20, GPIOZ0));
1475 FUNC_GROUP_DECL(SIOPBI, Y20);
1476 
1477 #define AB20 201
1478 #define AB20_DESC	SIG_DESC_SET(SCUA4, 17)
1479 SIG_EXPR_DECL_SINGLE(VPOG3, VPO, AB20_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1480 SIG_EXPR_DECL_SINGLE(VPOG3, VPOOFF1, AB20_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1481 SIG_EXPR_DECL_SINGLE(VPOG3, VPOOFF2, AB20_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1482 SIG_EXPR_LIST_DECL(VPOG3, VPO,
1483 		SIG_EXPR_PTR(VPOG3, VPO),
1484 		SIG_EXPR_PTR(VPOG3, VPOOFF1),
1485 		SIG_EXPR_PTR(VPOG3, VPOOFF2));
1486 SIG_EXPR_LIST_ALIAS(AB20, VPOG3, VPO);
1487 SIG_EXPR_DECL_SINGLE(SIOPWRGD, SIOPWRGD, AB20_DESC);
1488 SIG_EXPR_DECL_SINGLE(SIOPWRGD, ACPI, AB20_DESC);
1489 SIG_EXPR_LIST_DECL_DUAL(AB20, SIOPWRGD, SIOPWRGD, ACPI);
1490 SIG_EXPR_LIST_DECL_SINGLE(AB20, NORA1, PNOR, PNOR_DESC);
1491 SIG_EXPR_LIST_DECL_SINGLE(AB20, GPIOZ1, GPIOZ1);
1492 PIN_DECL_(AB20, SIG_EXPR_LIST_PTR(AB20, VPOG3),
1493 	  SIG_EXPR_LIST_PTR(AB20, SIOPWRGD), SIG_EXPR_LIST_PTR(AB20, NORA1),
1494 	  SIG_EXPR_LIST_PTR(AB20, GPIOZ1));
1495 FUNC_GROUP_DECL(SIOPWRGD, AB20);
1496 
1497 #define AB21 202
1498 #define AB21_DESC	SIG_DESC_SET(SCUA4, 18)
1499 SIG_EXPR_DECL_SINGLE(VPOG4, VPO, AB21_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1500 SIG_EXPR_DECL_SINGLE(VPOG4, VPOOFF1, AB21_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1501 SIG_EXPR_DECL_SINGLE(VPOG4, VPOOFF2, AB21_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1502 SIG_EXPR_LIST_DECL(VPOG4, VPO,
1503 		SIG_EXPR_PTR(VPOG4, VPO),
1504 		SIG_EXPR_PTR(VPOG4, VPOOFF1),
1505 		SIG_EXPR_PTR(VPOG4, VPOOFF2));
1506 SIG_EXPR_LIST_ALIAS(AB21, VPOG4, VPO);
1507 SIG_EXPR_DECL_SINGLE(SIOPBO, SIOPBO, AB21_DESC);
1508 SIG_EXPR_DECL_SINGLE(SIOPBO, ACPI, AB21_DESC);
1509 SIG_EXPR_LIST_DECL_DUAL(AB21, SIOPBO, SIOPBO, ACPI);
1510 SIG_EXPR_LIST_DECL_SINGLE(AB21, NORA2, PNOR, PNOR_DESC);
1511 SIG_EXPR_LIST_DECL_SINGLE(AB21, GPIOZ2, GPIOZ2);
1512 PIN_DECL_(AB21, SIG_EXPR_LIST_PTR(AB21, VPOG4),
1513 	  SIG_EXPR_LIST_PTR(AB21, SIOPBO), SIG_EXPR_LIST_PTR(AB21, NORA2),
1514 	  SIG_EXPR_LIST_PTR(AB21, GPIOZ2));
1515 FUNC_GROUP_DECL(SIOPBO, AB21);
1516 
1517 #define AA21 203
1518 #define AA21_DESC	SIG_DESC_SET(SCUA4, 19)
1519 SIG_EXPR_DECL_SINGLE(VPOG5, VPO, AA21_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1520 SIG_EXPR_DECL_SINGLE(VPOG5, VPOOFF1, AA21_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1521 SIG_EXPR_DECL_SINGLE(VPOG5, VPOOFF2, AA21_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1522 SIG_EXPR_LIST_DECL(VPOG5, VPO,
1523 		SIG_EXPR_PTR(VPOG5, VPO),
1524 		SIG_EXPR_PTR(VPOG5, VPOOFF1),
1525 		SIG_EXPR_PTR(VPOG5, VPOOFF2));
1526 SIG_EXPR_LIST_ALIAS(AA21, VPOG5, VPO);
1527 SIG_EXPR_DECL_SINGLE(SIOSCI, SIOSCI, AA21_DESC);
1528 SIG_EXPR_DECL_SINGLE(SIOSCI, ACPI, AA21_DESC);
1529 SIG_EXPR_LIST_DECL_DUAL(AA21, SIOSCI, SIOSCI, ACPI);
1530 SIG_EXPR_LIST_DECL_SINGLE(AA21, NORA3, PNOR, PNOR_DESC);
1531 SIG_EXPR_LIST_DECL_SINGLE(AA21, GPIOZ3, GPIOZ3);
1532 PIN_DECL_(AA21, SIG_EXPR_LIST_PTR(AA21, VPOG5),
1533 	  SIG_EXPR_LIST_PTR(AA21, SIOSCI), SIG_EXPR_LIST_PTR(AA21, NORA3),
1534 	  SIG_EXPR_LIST_PTR(AA21, GPIOZ3));
1535 FUNC_GROUP_DECL(SIOSCI, AA21);
1536 
1537 FUNC_GROUP_DECL(ACPI, R22, R21, P22, P21, Y20, AB20, AB21, AA21);
1538 
1539 /* CRT DVO disabled, configured for single-edge mode */
1540 #define CRT_DVO_DS_DESC { ASPEED_IP_GFX, GFX064, GENMASK(7, 6), 0, 0 }
1541 
1542 /* CRT DVO disabled, configured for dual-edge mode */
1543 #define CRT_DVO_DD_DESC { ASPEED_IP_GFX, GFX064, GENMASK(7, 6), 1, 1 }
1544 
1545 /* CRT DVO enabled, configured for single-edge mode */
1546 #define CRT_DVO_ES_DESC { ASPEED_IP_GFX, GFX064, GENMASK(7, 6), 2, 2 }
1547 
1548 /* CRT DVO enabled, configured for dual-edge mode */
1549 #define CRT_DVO_ED_DESC { ASPEED_IP_GFX, GFX064, GENMASK(7, 6), 3, 3 }
1550 
1551 #define U21 204
1552 #define U21_DESC	SIG_DESC_SET(SCUA4, 20)
1553 SIG_EXPR_DECL_SINGLE(VPOG6, VPO, U21_DESC, VPO_DESC, CRT_DVO_ES_DESC);
1554 SIG_EXPR_DECL_SINGLE(VPOG6, VPOOFF1, U21_DESC, VPOOFF1_DESC, CRT_DVO_ES_DESC);
1555 SIG_EXPR_DECL_SINGLE(VPOG6, VPOOFF2, U21_DESC, VPOOFF2_DESC, CRT_DVO_ES_DESC);
1556 SIG_EXPR_LIST_DECL(VPOG6, VPO,
1557 		SIG_EXPR_PTR(VPOG6, VPO),
1558 		SIG_EXPR_PTR(VPOG6, VPOOFF1),
1559 		SIG_EXPR_PTR(VPOG6, VPOOFF2));
1560 SIG_EXPR_LIST_ALIAS(U21, VPOG6, VPO);
1561 SIG_EXPR_LIST_DECL_SINGLE(U21, NORA4, PNOR, PNOR_DESC);
1562 PIN_DECL_2(U21, GPIOZ4, VPOG6, NORA4);
1563 
1564 #define W22 205
1565 #define W22_DESC	SIG_DESC_SET(SCUA4, 21)
1566 SIG_EXPR_DECL_SINGLE(VPOG7, VPO, W22_DESC, VPO_DESC, CRT_DVO_ES_DESC);
1567 SIG_EXPR_DECL_SINGLE(VPOG7, VPOOFF1, W22_DESC, VPOOFF1_DESC, CRT_DVO_ES_DESC);
1568 SIG_EXPR_DECL_SINGLE(VPOG7, VPOOFF2, W22_DESC, VPOOFF2_DESC, CRT_DVO_ES_DESC);
1569 SIG_EXPR_LIST_DECL(VPOG7, VPO,
1570 		SIG_EXPR_PTR(VPOG7, VPO),
1571 		SIG_EXPR_PTR(VPOG7, VPOOFF1),
1572 		SIG_EXPR_PTR(VPOG7, VPOOFF2));
1573 SIG_EXPR_LIST_ALIAS(W22, VPOG7, VPO);
1574 SIG_EXPR_LIST_DECL_SINGLE(W22, NORA5, PNOR, PNOR_DESC);
1575 PIN_DECL_2(W22, GPIOZ5, VPOG7, NORA5);
1576 
1577 #define V22 206
1578 #define V22_DESC	SIG_DESC_SET(SCUA4, 22)
1579 SIG_EXPR_DECL_SINGLE(VPOG8, VPO, V22_DESC, VPO_DESC, CRT_DVO_ES_DESC);
1580 SIG_EXPR_DECL_SINGLE(VPOG8, VPOOFF1, V22_DESC, VPOOFF1_DESC, CRT_DVO_ES_DESC);
1581 SIG_EXPR_DECL_SINGLE(VPOG8, VPOOFF2, V22_DESC, VPOOFF2_DESC, CRT_DVO_ES_DESC);
1582 SIG_EXPR_LIST_DECL(VPOG8, VPO,
1583 		SIG_EXPR_PTR(VPOG8, VPO),
1584 		SIG_EXPR_PTR(VPOG8, VPOOFF1),
1585 		SIG_EXPR_PTR(VPOG8, VPOOFF2));
1586 SIG_EXPR_LIST_ALIAS(V22, VPOG8, VPO);
1587 SIG_EXPR_LIST_DECL_SINGLE(V22, NORA6, PNOR, PNOR_DESC);
1588 PIN_DECL_2(V22, GPIOZ6, VPOG8, NORA6);
1589 
1590 #define W21 207
1591 #define W21_DESC	SIG_DESC_SET(SCUA4, 23)
1592 SIG_EXPR_DECL_SINGLE(VPOG9, VPO, W21_DESC, VPO_DESC, CRT_DVO_ES_DESC);
1593 SIG_EXPR_DECL_SINGLE(VPOG9, VPOOFF1, W21_DESC, VPOOFF1_DESC, CRT_DVO_ES_DESC);
1594 SIG_EXPR_DECL_SINGLE(VPOG9, VPOOFF2, W21_DESC, VPOOFF2_DESC, CRT_DVO_ES_DESC);
1595 SIG_EXPR_LIST_DECL(VPOG9, VPO,
1596 		SIG_EXPR_PTR(VPOG9, VPO),
1597 		SIG_EXPR_PTR(VPOG9, VPOOFF1),
1598 		SIG_EXPR_PTR(VPOG9, VPOOFF2));
1599 SIG_EXPR_LIST_ALIAS(W21, VPOG9, VPO);
1600 SIG_EXPR_LIST_DECL_SINGLE(W21, NORA7, PNOR, PNOR_DESC);
1601 PIN_DECL_2(W21, GPIOZ7, VPOG9, NORA7);
1602 
1603 #define Y21 208
1604 #define Y21_DESC	SIG_DESC_SET(SCUA4, 24)
1605 SIG_EXPR_DECL_SINGLE(VPOR2, VPO, Y21_DESC, VPO_DESC, CRT_DVO_ES_DESC);
1606 SIG_EXPR_DECL_SINGLE(VPOR2, VPOOFF1, Y21_DESC, VPOOFF1_DESC, CRT_DVO_ES_DESC);
1607 SIG_EXPR_DECL_SINGLE(VPOR2, VPOOFF2, Y21_DESC, VPOOFF2_DESC, CRT_DVO_ES_DESC);
1608 SIG_EXPR_LIST_DECL(VPOR2, VPO,
1609 		SIG_EXPR_PTR(VPOR2, VPO),
1610 		SIG_EXPR_PTR(VPOR2, VPOOFF1),
1611 		SIG_EXPR_PTR(VPOR2, VPOOFF2));
1612 SIG_EXPR_LIST_ALIAS(Y21, VPOR2, VPO);
1613 SIG_EXPR_LIST_DECL_SINGLE(Y21, SALT7, SALT7, Y21_DESC);
1614 SIG_EXPR_LIST_DECL_SINGLE(Y21, NORD0, PNOR, PNOR_DESC);
1615 SIG_EXPR_LIST_DECL_SINGLE(Y21, GPIOAA0, GPIOAA0);
1616 PIN_DECL_(Y21, SIG_EXPR_LIST_PTR(Y21, VPOR2), SIG_EXPR_LIST_PTR(Y21, SALT7),
1617 		SIG_EXPR_LIST_PTR(Y21, NORD0), SIG_EXPR_LIST_PTR(Y21, GPIOAA0));
1618 FUNC_GROUP_DECL(SALT7, Y21);
1619 
1620 #define V21 209
1621 #define V21_DESC	SIG_DESC_SET(SCUA4, 25)
1622 SIG_EXPR_DECL_SINGLE(VPOR3, VPO, V21_DESC, VPO_DESC, CRT_DVO_ES_DESC);
1623 SIG_EXPR_DECL_SINGLE(VPOR3, VPOOFF1, V21_DESC, VPOOFF1_DESC, CRT_DVO_ES_DESC);
1624 SIG_EXPR_DECL_SINGLE(VPOR3, VPOOFF2, V21_DESC, VPOOFF2_DESC, CRT_DVO_ES_DESC);
1625 SIG_EXPR_LIST_DECL(VPOR3, VPO,
1626 		SIG_EXPR_PTR(VPOR3, VPO),
1627 		SIG_EXPR_PTR(VPOR3, VPOOFF1),
1628 		SIG_EXPR_PTR(VPOR3, VPOOFF2));
1629 SIG_EXPR_LIST_ALIAS(V21, VPOR3, VPO);
1630 SIG_EXPR_LIST_DECL_SINGLE(V21, SALT8, SALT8, V21_DESC);
1631 SIG_EXPR_LIST_DECL_SINGLE(V21, NORD1, PNOR, PNOR_DESC);
1632 SIG_EXPR_LIST_DECL_SINGLE(V21, GPIOAA1, GPIOAA1);
1633 PIN_DECL_(V21, SIG_EXPR_LIST_PTR(V21, VPOR3), SIG_EXPR_LIST_PTR(V21, SALT8),
1634 		SIG_EXPR_LIST_PTR(V21, NORD1), SIG_EXPR_LIST_PTR(V21, GPIOAA1));
1635 FUNC_GROUP_DECL(SALT8, V21);
1636 
1637 #define Y22 210
1638 #define Y22_DESC	SIG_DESC_SET(SCUA4, 26)
1639 SIG_EXPR_DECL_SINGLE(VPOR4, VPO, Y22_DESC, VPO_DESC, CRT_DVO_ES_DESC);
1640 SIG_EXPR_DECL_SINGLE(VPOR4, VPOOFF1, Y22_DESC, VPOOFF1_DESC, CRT_DVO_ES_DESC);
1641 SIG_EXPR_DECL_SINGLE(VPOR4, VPOOFF2, Y22_DESC, VPOOFF2_DESC, CRT_DVO_ES_DESC);
1642 SIG_EXPR_LIST_DECL(VPOR4, VPO,
1643 		SIG_EXPR_PTR(VPOR4, VPO),
1644 		SIG_EXPR_PTR(VPOR4, VPOOFF1),
1645 		SIG_EXPR_PTR(VPOR4, VPOOFF2));
1646 SIG_EXPR_LIST_ALIAS(Y22, VPOR4, VPO);
1647 SIG_EXPR_LIST_DECL_SINGLE(Y22, SALT9, SALT9, Y22_DESC);
1648 SIG_EXPR_LIST_DECL_SINGLE(Y22, NORD2, PNOR, PNOR_DESC);
1649 SIG_EXPR_LIST_DECL_SINGLE(Y22, GPIOAA2, GPIOAA2);
1650 PIN_DECL_(Y22, SIG_EXPR_LIST_PTR(Y22, VPOR4), SIG_EXPR_LIST_PTR(Y22, SALT9),
1651 		SIG_EXPR_LIST_PTR(Y22, NORD2), SIG_EXPR_LIST_PTR(Y22, GPIOAA2));
1652 FUNC_GROUP_DECL(SALT9, Y22);
1653 
1654 #define AA22 211
1655 #define AA22_DESC	SIG_DESC_SET(SCUA4, 27)
1656 SIG_EXPR_DECL_SINGLE(VPOR5, VPO, AA22_DESC, VPO_DESC, CRT_DVO_ES_DESC);
1657 SIG_EXPR_DECL_SINGLE(VPOR5, VPOOFF1, AA22_DESC, VPOOFF1_DESC, CRT_DVO_ES_DESC);
1658 SIG_EXPR_DECL_SINGLE(VPOR5, VPOOFF2, AA22_DESC, VPOOFF2_DESC, CRT_DVO_ES_DESC);
1659 SIG_EXPR_LIST_DECL(VPOR5, VPO,
1660 		SIG_EXPR_PTR(VPOR5, VPO),
1661 		SIG_EXPR_PTR(VPOR5, VPOOFF1),
1662 		SIG_EXPR_PTR(VPOR5, VPOOFF2));
1663 SIG_EXPR_LIST_ALIAS(AA22, VPOR5, VPO);
1664 SIG_EXPR_LIST_DECL_SINGLE(AA22, SALT10, SALT10, AA22_DESC);
1665 SIG_EXPR_LIST_DECL_SINGLE(AA22, NORD3, PNOR, PNOR_DESC);
1666 SIG_EXPR_LIST_DECL_SINGLE(AA22, GPIOAA3, GPIOAA3);
1667 PIN_DECL_(AA22, SIG_EXPR_LIST_PTR(AA22, VPOR5),
1668 	  SIG_EXPR_LIST_PTR(AA22, SALT10), SIG_EXPR_LIST_PTR(AA22, NORD3),
1669 	  SIG_EXPR_LIST_PTR(AA22, GPIOAA3));
1670 FUNC_GROUP_DECL(SALT10, AA22);
1671 
1672 #define U22 212
1673 #define U22_DESC	SIG_DESC_SET(SCUA4, 28)
1674 SIG_EXPR_DECL_SINGLE(VPOR6, VPO, U22_DESC, VPO_DESC, CRT_DVO_ES_DESC);
1675 SIG_EXPR_DECL_SINGLE(VPOR6, VPOOFF1, U22_DESC, VPOOFF1_DESC, CRT_DVO_ES_DESC);
1676 SIG_EXPR_DECL_SINGLE(VPOR6, VPOOFF2, U22_DESC, VPOOFF2_DESC, CRT_DVO_ES_DESC);
1677 SIG_EXPR_LIST_DECL(VPOR6, VPO,
1678 		SIG_EXPR_PTR(VPOR6, VPO),
1679 		SIG_EXPR_PTR(VPOR6, VPOOFF1),
1680 		SIG_EXPR_PTR(VPOR6, VPOOFF2));
1681 SIG_EXPR_LIST_ALIAS(U22, VPOR6, VPO);
1682 SIG_EXPR_LIST_DECL_SINGLE(U22, SALT11, SALT11, U22_DESC);
1683 SIG_EXPR_LIST_DECL_SINGLE(U22, NORD4, PNOR, PNOR_DESC);
1684 SIG_EXPR_LIST_DECL_SINGLE(U22, GPIOAA4, GPIOAA4);
1685 PIN_DECL_(U22, SIG_EXPR_LIST_PTR(U22, VPOR6), SIG_EXPR_LIST_PTR(U22, SALT11),
1686 		SIG_EXPR_LIST_PTR(U22, NORD4), SIG_EXPR_LIST_PTR(U22, GPIOAA4));
1687 FUNC_GROUP_DECL(SALT11, U22);
1688 
1689 #define T20 213
1690 #define T20_DESC	SIG_DESC_SET(SCUA4, 29)
1691 SIG_EXPR_DECL_SINGLE(VPOR7, VPO, T20_DESC, VPO_DESC, CRT_DVO_ES_DESC);
1692 SIG_EXPR_DECL_SINGLE(VPOR7, VPOOFF1, T20_DESC, VPOOFF1_DESC, CRT_DVO_ES_DESC);
1693 SIG_EXPR_DECL_SINGLE(VPOR7, VPOOFF2, T20_DESC, VPOOFF2_DESC, CRT_DVO_ES_DESC);
1694 SIG_EXPR_LIST_DECL(VPOR7, VPO,
1695 		SIG_EXPR_PTR(VPOR7, VPO),
1696 		SIG_EXPR_PTR(VPOR7, VPOOFF1),
1697 		SIG_EXPR_PTR(VPOR7, VPOOFF2));
1698 SIG_EXPR_LIST_ALIAS(T20, VPOR7, VPO);
1699 SIG_EXPR_LIST_DECL_SINGLE(T20, SALT12, SALT12, T20_DESC);
1700 SIG_EXPR_LIST_DECL_SINGLE(T20, NORD5, PNOR, PNOR_DESC);
1701 SIG_EXPR_LIST_DECL_SINGLE(T20, GPIOAA5, GPIOAA5);
1702 PIN_DECL_(T20, SIG_EXPR_LIST_PTR(T20, VPOR7), SIG_EXPR_LIST_PTR(T20, SALT12),
1703 		SIG_EXPR_LIST_PTR(T20, NORD5), SIG_EXPR_LIST_PTR(T20, GPIOAA5));
1704 FUNC_GROUP_DECL(SALT12, T20);
1705 
1706 #define N18 214
1707 #define N18_DESC	SIG_DESC_SET(SCUA4, 30)
1708 SIG_EXPR_DECL_SINGLE(VPOR8, VPO, N18_DESC, VPO_DESC, CRT_DVO_ES_DESC);
1709 SIG_EXPR_DECL_SINGLE(VPOR8, VPOOFF1, N18_DESC, VPOOFF1_DESC, CRT_DVO_ES_DESC);
1710 SIG_EXPR_DECL_SINGLE(VPOR8, VPOOFF2, N18_DESC, VPOOFF2_DESC, CRT_DVO_ES_DESC);
1711 SIG_EXPR_LIST_DECL(VPOR8, VPO,
1712 		SIG_EXPR_PTR(VPOR8, VPO),
1713 		SIG_EXPR_PTR(VPOR8, VPOOFF1),
1714 		SIG_EXPR_PTR(VPOR8, VPOOFF2));
1715 SIG_EXPR_LIST_ALIAS(N18, VPOR8, VPO);
1716 SIG_EXPR_LIST_DECL_SINGLE(N18, SALT13, SALT13, N18_DESC);
1717 SIG_EXPR_LIST_DECL_SINGLE(N18, NORD6, PNOR, PNOR_DESC);
1718 SIG_EXPR_LIST_DECL_SINGLE(N18, GPIOAA6, GPIOAA6);
1719 PIN_DECL_(N18, SIG_EXPR_LIST_PTR(N18, VPOR8), SIG_EXPR_LIST_PTR(N18, SALT13),
1720 		SIG_EXPR_LIST_PTR(N18, NORD6), SIG_EXPR_LIST_PTR(N18, GPIOAA6));
1721 FUNC_GROUP_DECL(SALT13, N18);
1722 
1723 #define P19 215
1724 #define P19_DESC	SIG_DESC_SET(SCUA4, 31)
1725 SIG_EXPR_DECL_SINGLE(VPOR9, VPO, P19_DESC, VPO_DESC, CRT_DVO_ES_DESC);
1726 SIG_EXPR_DECL_SINGLE(VPOR9, VPOOFF1, P19_DESC, VPOOFF1_DESC, CRT_DVO_ES_DESC);
1727 SIG_EXPR_DECL_SINGLE(VPOR9, VPOOFF2, P19_DESC, VPOOFF2_DESC, CRT_DVO_ES_DESC);
1728 SIG_EXPR_LIST_DECL(VPOR9, VPO,
1729 		SIG_EXPR_PTR(VPOR9, VPO),
1730 		SIG_EXPR_PTR(VPOR9, VPOOFF1),
1731 		SIG_EXPR_PTR(VPOR9, VPOOFF2));
1732 SIG_EXPR_LIST_ALIAS(P19, VPOR9, VPO);
1733 SIG_EXPR_LIST_DECL_SINGLE(P19, SALT14, SALT14, P19_DESC);
1734 SIG_EXPR_LIST_DECL_SINGLE(P19, NORD7, PNOR, PNOR_DESC);
1735 SIG_EXPR_LIST_DECL_SINGLE(P19, GPIOAA7, GPIOAA7);
1736 PIN_DECL_(P19, SIG_EXPR_LIST_PTR(P19, VPOR9), SIG_EXPR_LIST_PTR(P19, SALT14),
1737 		SIG_EXPR_LIST_PTR(P19, NORD7), SIG_EXPR_LIST_PTR(P19, GPIOAA7));
1738 FUNC_GROUP_DECL(SALT14, P19);
1739 
1740 #define N19 216
1741 #define N19_DESC	SIG_DESC_SET(SCUA8, 0)
1742 SIG_EXPR_DECL_SINGLE(VPODE, VPO, N19_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1743 SIG_EXPR_DECL_SINGLE(VPODE, VPOOFF1, N19_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1744 SIG_EXPR_DECL_SINGLE(VPODE, VPOOFF2, N19_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1745 SIG_EXPR_LIST_DECL(VPODE, VPO,
1746 		SIG_EXPR_PTR(VPODE, VPO),
1747 		SIG_EXPR_PTR(VPODE, VPOOFF1),
1748 		SIG_EXPR_PTR(VPODE, VPOOFF2));
1749 SIG_EXPR_LIST_ALIAS(N19, VPODE, VPO);
1750 SIG_EXPR_LIST_DECL_SINGLE(N19, NOROE, PNOR, PNOR_DESC);
1751 PIN_DECL_2(N19, GPIOAB0, VPODE, NOROE);
1752 
1753 #define T21 217
1754 #define T21_DESC	SIG_DESC_SET(SCUA8, 1)
1755 SIG_EXPR_DECL_SINGLE(VPOHS, VPO, T21_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1756 SIG_EXPR_DECL_SINGLE(VPOHS, VPOOFF1, T21_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1757 SIG_EXPR_DECL_SINGLE(VPOHS, VPOOFF2, T21_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1758 SIG_EXPR_LIST_DECL(VPOHS, VPO,
1759 		SIG_EXPR_PTR(VPOHS, VPO),
1760 		SIG_EXPR_PTR(VPOHS, VPOOFF1),
1761 		SIG_EXPR_PTR(VPOHS, VPOOFF2));
1762 SIG_EXPR_LIST_ALIAS(T21, VPOHS, VPO);
1763 SIG_EXPR_LIST_DECL_SINGLE(T21, NORWE, PNOR, PNOR_DESC);
1764 PIN_DECL_2(T21, GPIOAB1, VPOHS, NORWE);
1765 
1766 FUNC_GROUP_DECL(PNOR, Y20, AB20, AB21, AA21, U21, W22, V22, W21, Y21, V21, Y22,
1767 		AA22, U22, T20, N18, P19, N19, T21);
1768 
1769 #define T22 218
1770 #define T22_DESC	SIG_DESC_SET(SCUA8, 2)
1771 SIG_EXPR_DECL_SINGLE(VPOVS, VPO, T22_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1772 SIG_EXPR_DECL_SINGLE(VPOVS, VPOOFF1, T22_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1773 SIG_EXPR_DECL_SINGLE(VPOVS, VPOOFF2, T22_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1774 SIG_EXPR_LIST_DECL(VPOVS, VPO,
1775 		SIG_EXPR_PTR(VPOVS, VPO),
1776 		SIG_EXPR_PTR(VPOVS, VPOOFF1),
1777 		SIG_EXPR_PTR(VPOVS, VPOOFF2));
1778 SIG_EXPR_LIST_ALIAS(T22, VPOVS, VPO);
1779 SIG_EXPR_LIST_DECL_SINGLE(T22, WDTRST1, WDTRST1, T22_DESC);
1780 PIN_DECL_2(T22, GPIOAB2, VPOVS, WDTRST1);
1781 FUNC_GROUP_DECL(WDTRST1, T22);
1782 
1783 #define R20 219
1784 #define R20_DESC	SIG_DESC_SET(SCUA8, 3)
1785 SIG_EXPR_DECL_SINGLE(VPOCLK, VPO, R20_DESC, VPO_DESC, CRT_DVO_EN_DESC);
1786 SIG_EXPR_DECL_SINGLE(VPOCLK, VPOOFF1, R20_DESC, VPOOFF1_DESC, CRT_DVO_EN_DESC);
1787 SIG_EXPR_DECL_SINGLE(VPOCLK, VPOOFF2, R20_DESC, VPOOFF2_DESC, CRT_DVO_EN_DESC);
1788 SIG_EXPR_LIST_DECL(VPOCLK, VPO,
1789 		SIG_EXPR_PTR(VPOCLK, VPO),
1790 		SIG_EXPR_PTR(VPOCLK, VPOOFF1),
1791 		SIG_EXPR_PTR(VPOCLK, VPOOFF2));
1792 SIG_EXPR_LIST_ALIAS(R20, VPOCLK, VPO);
1793 SIG_EXPR_LIST_DECL_SINGLE(R20, WDTRST2, WDTRST2, R20_DESC);
1794 PIN_DECL_2(R20, GPIOAB3, VPOCLK, WDTRST2);
1795 FUNC_GROUP_DECL(WDTRST2, R20);
1796 
1797 FUNC_GROUP_DECL(VPO, V20, U19, R18, P18, R19, W20, U20, AA20, Y20, AB20,
1798 		AB21, AA21, U21, W22, V22, W21, Y21, V21, Y22, AA22, U22, T20,
1799 		N18, P19, N19, T21, T22, R20);
1800 
1801 #define ESPI_DESC	SIG_DESC_SET(HW_STRAP1, 25)
1802 
1803 #define G21 224
1804 SIG_EXPR_LIST_DECL_SINGLE(G21, ESPID0, ESPI, ESPI_DESC);
1805 SIG_EXPR_LIST_DECL_SINGLE(G21, LAD0, LAD0, SIG_DESC_SET(SCUAC, 0));
1806 PIN_DECL_2(G21, GPIOAC0, ESPID0, LAD0);
1807 FUNC_GROUP_DECL(LAD0, G21);
1808 
1809 #define G20 225
1810 SIG_EXPR_LIST_DECL_SINGLE(G20, ESPID1, ESPI, ESPI_DESC);
1811 SIG_EXPR_LIST_DECL_SINGLE(G20, LAD1, LAD1, SIG_DESC_SET(SCUAC, 1));
1812 PIN_DECL_2(G20, GPIOAC1, ESPID1, LAD1);
1813 FUNC_GROUP_DECL(LAD1, G20);
1814 
1815 #define D22 226
1816 SIG_EXPR_LIST_DECL_SINGLE(D22, ESPID2, ESPI, ESPI_DESC);
1817 SIG_EXPR_LIST_DECL_SINGLE(D22, LAD2, LAD2, SIG_DESC_SET(SCUAC, 2));
1818 PIN_DECL_2(D22, GPIOAC2, ESPID2, LAD2);
1819 FUNC_GROUP_DECL(LAD2, D22);
1820 
1821 #define E22 227
1822 SIG_EXPR_LIST_DECL_SINGLE(E22, ESPID3, ESPI, ESPI_DESC);
1823 SIG_EXPR_LIST_DECL_SINGLE(E22, LAD3, LAD3, SIG_DESC_SET(SCUAC, 3));
1824 PIN_DECL_2(E22, GPIOAC3, ESPID3, LAD3);
1825 FUNC_GROUP_DECL(LAD3, E22);
1826 
1827 #define C22 228
1828 SIG_EXPR_LIST_DECL_SINGLE(C22, ESPICK, ESPI, ESPI_DESC);
1829 SIG_EXPR_LIST_DECL_SINGLE(C22, LCLK, LCLK, SIG_DESC_SET(SCUAC, 4));
1830 PIN_DECL_2(C22, GPIOAC4, ESPICK, LCLK);
1831 FUNC_GROUP_DECL(LCLK, C22);
1832 
1833 #define F21 229
1834 SIG_EXPR_LIST_DECL_SINGLE(F21, ESPICS, ESPI, ESPI_DESC);
1835 SIG_EXPR_LIST_DECL_SINGLE(F21, LFRAME, LFRAME, SIG_DESC_SET(SCUAC, 5));
1836 PIN_DECL_2(F21, GPIOAC5, ESPICS, LFRAME);
1837 FUNC_GROUP_DECL(LFRAME, F21);
1838 
1839 #define F22 230
1840 SIG_EXPR_LIST_DECL_SINGLE(F22, ESPIALT, ESPI, ESPI_DESC);
1841 SIG_EXPR_LIST_DECL_SINGLE(F22, LSIRQ, LSIRQ, SIG_DESC_SET(SCUAC, 6));
1842 PIN_DECL_2(F22, GPIOAC6, ESPIALT, LSIRQ);
1843 FUNC_GROUP_DECL(LSIRQ, F22);
1844 
1845 #define G22 231
1846 SIG_EXPR_LIST_DECL_SINGLE(G22, ESPIRST, ESPI, ESPI_DESC);
1847 SIG_EXPR_LIST_DECL_SINGLE(G22, LPCRST, LPCRST, SIG_DESC_SET(SCUAC, 7));
1848 PIN_DECL_2(G22, GPIOAC7, ESPIRST, LPCRST);
1849 FUNC_GROUP_DECL(LPCRST, G22);
1850 
1851 FUNC_GROUP_DECL(ESPI, G21, G20, D22, E22, C22, F21, F22, G22);
1852 
1853 #define A7 232
1854 SIG_EXPR_LIST_DECL_SINGLE(A7, USB2AHDP, USB2AH, SIG_DESC_SET(SCU90, 29));
1855 SIG_EXPR_LIST_DECL_SINGLE(A7, USB2ADDP, USB2AD, SIG_DESC_BIT(SCU90, 29, 0));
1856 PIN_DECL_(A7, SIG_EXPR_LIST_PTR(A7, USB2AHDP), SIG_EXPR_LIST_PTR(A7, USB2ADDP));
1857 
1858 #define A8 233
1859 SIG_EXPR_LIST_DECL_SINGLE(A8, USB2AHDN, USB2AH, SIG_DESC_SET(SCU90, 29));
1860 SIG_EXPR_LIST_DECL_SINGLE(A8, USB2ADDN, USB2AD, SIG_DESC_BIT(SCU90, 29, 0));
1861 PIN_DECL_(A8, SIG_EXPR_LIST_PTR(A8, USB2AHDN), SIG_EXPR_LIST_PTR(A8, USB2ADDN));
1862 
1863 FUNC_GROUP_DECL(USB2AH, A7, A8);
1864 FUNC_GROUP_DECL(USB2AD, A7, A8);
1865 
1866 #define USB11BHID_DESC  { ASPEED_IP_SCU, SCU94, GENMASK(14, 13), 0, 0 }
1867 #define USB2BD_DESC   { ASPEED_IP_SCU, SCU94, GENMASK(14, 13), 1, 0 }
1868 #define USB2BH1_DESC { ASPEED_IP_SCU, SCU94, GENMASK(14, 13), 2, 0 }
1869 #define USB2BH2_DESC { ASPEED_IP_SCU, SCU94, GENMASK(14, 13), 3, 0 }
1870 
1871 #define B6 234
1872 SIG_EXPR_LIST_DECL_SINGLE(B6, USB11BDP, USB11BHID, USB11BHID_DESC);
1873 SIG_EXPR_LIST_DECL_SINGLE(B6, USB2BDDP, USB2BD, USB2BD_DESC);
1874 SIG_EXPR_DECL_SINGLE(USB2BHDP1, USB2BH, USB2BH1_DESC);
1875 SIG_EXPR_DECL_SINGLE(USB2BHDP2, USB2BH, USB2BH2_DESC);
1876 SIG_EXPR_LIST_DECL(USB2BHDP, USB2BH,
1877 		SIG_EXPR_PTR(USB2BHDP1, USB2BH),
1878 		SIG_EXPR_PTR(USB2BHDP2, USB2BH));
1879 SIG_EXPR_LIST_ALIAS(B6, USB2BHDP, USB2BH);
1880 PIN_DECL_(B6, SIG_EXPR_LIST_PTR(B6, USB11BDP), SIG_EXPR_LIST_PTR(B6, USB2BDDP),
1881 		SIG_EXPR_LIST_PTR(B6, USB2BHDP));
1882 
1883 #define A6 235
1884 SIG_EXPR_LIST_DECL_SINGLE(A6, USB11BDN, USB11BHID, USB11BHID_DESC);
1885 SIG_EXPR_LIST_DECL_SINGLE(A6, USB2BDN, USB2BD, USB2BD_DESC);
1886 SIG_EXPR_DECL_SINGLE(USB2BHDN1, USB2BH, USB2BH1_DESC);
1887 SIG_EXPR_DECL_SINGLE(USB2BHDN2, USB2BH, USB2BH2_DESC);
1888 SIG_EXPR_LIST_DECL(USB2BHDN, USB2BH,
1889 		SIG_EXPR_PTR(USB2BHDN1, USB2BH),
1890 		SIG_EXPR_PTR(USB2BHDN2, USB2BH));
1891 SIG_EXPR_LIST_ALIAS(A6, USB2BHDN, USB2BH);
1892 PIN_DECL_(A6, SIG_EXPR_LIST_PTR(A6, USB11BDN), SIG_EXPR_LIST_PTR(A6, USB2BDN),
1893 		SIG_EXPR_LIST_PTR(A6, USB2BHDN));
1894 
1895 FUNC_GROUP_DECL(USB11BHID, B6, A6);
1896 FUNC_GROUP_DECL(USB2BD, B6, A6);
1897 FUNC_GROUP_DECL(USB2BH, B6, A6);
1898 
1899 /* Pins, groups and functions are sort(1):ed alphabetically for sanity */
1900 
1901 static struct pinctrl_pin_desc aspeed_g5_pins[ASPEED_G5_NR_PINS] = {
1902 	ASPEED_PINCTRL_PIN(A10),
1903 	ASPEED_PINCTRL_PIN(A11),
1904 	ASPEED_PINCTRL_PIN(A12),
1905 	ASPEED_PINCTRL_PIN(A13),
1906 	ASPEED_PINCTRL_PIN(A14),
1907 	ASPEED_PINCTRL_PIN(A15),
1908 	ASPEED_PINCTRL_PIN(A16),
1909 	ASPEED_PINCTRL_PIN(A17),
1910 	ASPEED_PINCTRL_PIN(A18),
1911 	ASPEED_PINCTRL_PIN(A19),
1912 	ASPEED_PINCTRL_PIN(A2),
1913 	ASPEED_PINCTRL_PIN(A20),
1914 	ASPEED_PINCTRL_PIN(A21),
1915 	ASPEED_PINCTRL_PIN(A3),
1916 	ASPEED_PINCTRL_PIN(A4),
1917 	ASPEED_PINCTRL_PIN(A5),
1918 	ASPEED_PINCTRL_PIN(A6),
1919 	ASPEED_PINCTRL_PIN(A7),
1920 	ASPEED_PINCTRL_PIN(A8),
1921 	ASPEED_PINCTRL_PIN(A9),
1922 	ASPEED_PINCTRL_PIN(AA1),
1923 	ASPEED_PINCTRL_PIN(AA19),
1924 	ASPEED_PINCTRL_PIN(AA2),
1925 	ASPEED_PINCTRL_PIN(AA20),
1926 	ASPEED_PINCTRL_PIN(AA21),
1927 	ASPEED_PINCTRL_PIN(AA22),
1928 	ASPEED_PINCTRL_PIN(AA3),
1929 	ASPEED_PINCTRL_PIN(AA4),
1930 	ASPEED_PINCTRL_PIN(AA5),
1931 	ASPEED_PINCTRL_PIN(AB2),
1932 	ASPEED_PINCTRL_PIN(AB20),
1933 	ASPEED_PINCTRL_PIN(AB21),
1934 	ASPEED_PINCTRL_PIN(AB3),
1935 	ASPEED_PINCTRL_PIN(AB4),
1936 	ASPEED_PINCTRL_PIN(AB5),
1937 	ASPEED_PINCTRL_PIN(B1),
1938 	ASPEED_PINCTRL_PIN(B10),
1939 	ASPEED_PINCTRL_PIN(B11),
1940 	ASPEED_PINCTRL_PIN(B12),
1941 	ASPEED_PINCTRL_PIN(B13),
1942 	ASPEED_PINCTRL_PIN(B14),
1943 	ASPEED_PINCTRL_PIN(B15),
1944 	ASPEED_PINCTRL_PIN(B16),
1945 	ASPEED_PINCTRL_PIN(B17),
1946 	ASPEED_PINCTRL_PIN(B18),
1947 	ASPEED_PINCTRL_PIN(B19),
1948 	ASPEED_PINCTRL_PIN(B2),
1949 	ASPEED_PINCTRL_PIN(B20),
1950 	ASPEED_PINCTRL_PIN(B21),
1951 	ASPEED_PINCTRL_PIN(B22),
1952 	ASPEED_PINCTRL_PIN(B3),
1953 	ASPEED_PINCTRL_PIN(B4),
1954 	ASPEED_PINCTRL_PIN(B5),
1955 	ASPEED_PINCTRL_PIN(B6),
1956 	ASPEED_PINCTRL_PIN(B9),
1957 	ASPEED_PINCTRL_PIN(C1),
1958 	ASPEED_PINCTRL_PIN(C11),
1959 	ASPEED_PINCTRL_PIN(C12),
1960 	ASPEED_PINCTRL_PIN(C13),
1961 	ASPEED_PINCTRL_PIN(C14),
1962 	ASPEED_PINCTRL_PIN(C15),
1963 	ASPEED_PINCTRL_PIN(C16),
1964 	ASPEED_PINCTRL_PIN(C17),
1965 	ASPEED_PINCTRL_PIN(C18),
1966 	ASPEED_PINCTRL_PIN(C19),
1967 	ASPEED_PINCTRL_PIN(C2),
1968 	ASPEED_PINCTRL_PIN(C20),
1969 	ASPEED_PINCTRL_PIN(C21),
1970 	ASPEED_PINCTRL_PIN(C22),
1971 	ASPEED_PINCTRL_PIN(C3),
1972 	ASPEED_PINCTRL_PIN(C4),
1973 	ASPEED_PINCTRL_PIN(C5),
1974 	ASPEED_PINCTRL_PIN(D1),
1975 	ASPEED_PINCTRL_PIN(D10),
1976 	ASPEED_PINCTRL_PIN(D13),
1977 	ASPEED_PINCTRL_PIN(D14),
1978 	ASPEED_PINCTRL_PIN(D15),
1979 	ASPEED_PINCTRL_PIN(D16),
1980 	ASPEED_PINCTRL_PIN(D17),
1981 	ASPEED_PINCTRL_PIN(D18),
1982 	ASPEED_PINCTRL_PIN(D19),
1983 	ASPEED_PINCTRL_PIN(D2),
1984 	ASPEED_PINCTRL_PIN(D20),
1985 	ASPEED_PINCTRL_PIN(D21),
1986 	ASPEED_PINCTRL_PIN(D22),
1987 	ASPEED_PINCTRL_PIN(D4),
1988 	ASPEED_PINCTRL_PIN(D5),
1989 	ASPEED_PINCTRL_PIN(D6),
1990 	ASPEED_PINCTRL_PIN(D7),
1991 	ASPEED_PINCTRL_PIN(D8),
1992 	ASPEED_PINCTRL_PIN(D9),
1993 	ASPEED_PINCTRL_PIN(E1),
1994 	ASPEED_PINCTRL_PIN(E10),
1995 	ASPEED_PINCTRL_PIN(E12),
1996 	ASPEED_PINCTRL_PIN(E13),
1997 	ASPEED_PINCTRL_PIN(E14),
1998 	ASPEED_PINCTRL_PIN(E15),
1999 	ASPEED_PINCTRL_PIN(E16),
2000 	ASPEED_PINCTRL_PIN(E17),
2001 	ASPEED_PINCTRL_PIN(E18),
2002 	ASPEED_PINCTRL_PIN(E19),
2003 	ASPEED_PINCTRL_PIN(E2),
2004 	ASPEED_PINCTRL_PIN(E20),
2005 	ASPEED_PINCTRL_PIN(E21),
2006 	ASPEED_PINCTRL_PIN(E22),
2007 	ASPEED_PINCTRL_PIN(E3),
2008 	ASPEED_PINCTRL_PIN(E6),
2009 	ASPEED_PINCTRL_PIN(E7),
2010 	ASPEED_PINCTRL_PIN(E9),
2011 	ASPEED_PINCTRL_PIN(F1),
2012 	ASPEED_PINCTRL_PIN(F17),
2013 	ASPEED_PINCTRL_PIN(F18),
2014 	ASPEED_PINCTRL_PIN(F19),
2015 	ASPEED_PINCTRL_PIN(F2),
2016 	ASPEED_PINCTRL_PIN(F20),
2017 	ASPEED_PINCTRL_PIN(F21),
2018 	ASPEED_PINCTRL_PIN(F22),
2019 	ASPEED_PINCTRL_PIN(F3),
2020 	ASPEED_PINCTRL_PIN(F4),
2021 	ASPEED_PINCTRL_PIN(F5),
2022 	ASPEED_PINCTRL_PIN(F9),
2023 	ASPEED_PINCTRL_PIN(G1),
2024 	ASPEED_PINCTRL_PIN(G17),
2025 	ASPEED_PINCTRL_PIN(G18),
2026 	ASPEED_PINCTRL_PIN(G2),
2027 	ASPEED_PINCTRL_PIN(G20),
2028 	ASPEED_PINCTRL_PIN(G21),
2029 	ASPEED_PINCTRL_PIN(G22),
2030 	ASPEED_PINCTRL_PIN(G3),
2031 	ASPEED_PINCTRL_PIN(G4),
2032 	ASPEED_PINCTRL_PIN(G5),
2033 	ASPEED_PINCTRL_PIN(H18),
2034 	ASPEED_PINCTRL_PIN(H19),
2035 	ASPEED_PINCTRL_PIN(H20),
2036 	ASPEED_PINCTRL_PIN(H21),
2037 	ASPEED_PINCTRL_PIN(H22),
2038 	ASPEED_PINCTRL_PIN(H3),
2039 	ASPEED_PINCTRL_PIN(H4),
2040 	ASPEED_PINCTRL_PIN(H5),
2041 	ASPEED_PINCTRL_PIN(J18),
2042 	ASPEED_PINCTRL_PIN(J19),
2043 	ASPEED_PINCTRL_PIN(J20),
2044 	ASPEED_PINCTRL_PIN(K18),
2045 	ASPEED_PINCTRL_PIN(K19),
2046 	ASPEED_PINCTRL_PIN(L1),
2047 	ASPEED_PINCTRL_PIN(L18),
2048 	ASPEED_PINCTRL_PIN(L19),
2049 	ASPEED_PINCTRL_PIN(L2),
2050 	ASPEED_PINCTRL_PIN(L3),
2051 	ASPEED_PINCTRL_PIN(L4),
2052 	ASPEED_PINCTRL_PIN(M18),
2053 	ASPEED_PINCTRL_PIN(M19),
2054 	ASPEED_PINCTRL_PIN(M20),
2055 	ASPEED_PINCTRL_PIN(N1),
2056 	ASPEED_PINCTRL_PIN(N18),
2057 	ASPEED_PINCTRL_PIN(N19),
2058 	ASPEED_PINCTRL_PIN(N2),
2059 	ASPEED_PINCTRL_PIN(N20),
2060 	ASPEED_PINCTRL_PIN(N21),
2061 	ASPEED_PINCTRL_PIN(N22),
2062 	ASPEED_PINCTRL_PIN(N3),
2063 	ASPEED_PINCTRL_PIN(N4),
2064 	ASPEED_PINCTRL_PIN(N5),
2065 	ASPEED_PINCTRL_PIN(P1),
2066 	ASPEED_PINCTRL_PIN(P18),
2067 	ASPEED_PINCTRL_PIN(P19),
2068 	ASPEED_PINCTRL_PIN(P2),
2069 	ASPEED_PINCTRL_PIN(P20),
2070 	ASPEED_PINCTRL_PIN(P21),
2071 	ASPEED_PINCTRL_PIN(P22),
2072 	ASPEED_PINCTRL_PIN(P3),
2073 	ASPEED_PINCTRL_PIN(P4),
2074 	ASPEED_PINCTRL_PIN(P5),
2075 	ASPEED_PINCTRL_PIN(R1),
2076 	ASPEED_PINCTRL_PIN(R18),
2077 	ASPEED_PINCTRL_PIN(R19),
2078 	ASPEED_PINCTRL_PIN(R2),
2079 	ASPEED_PINCTRL_PIN(R20),
2080 	ASPEED_PINCTRL_PIN(R21),
2081 	ASPEED_PINCTRL_PIN(R22),
2082 	ASPEED_PINCTRL_PIN(R3),
2083 	ASPEED_PINCTRL_PIN(R4),
2084 	ASPEED_PINCTRL_PIN(R5),
2085 	ASPEED_PINCTRL_PIN(T1),
2086 	ASPEED_PINCTRL_PIN(T17),
2087 	ASPEED_PINCTRL_PIN(T19),
2088 	ASPEED_PINCTRL_PIN(T2),
2089 	ASPEED_PINCTRL_PIN(T20),
2090 	ASPEED_PINCTRL_PIN(T21),
2091 	ASPEED_PINCTRL_PIN(T22),
2092 	ASPEED_PINCTRL_PIN(T3),
2093 	ASPEED_PINCTRL_PIN(T4),
2094 	ASPEED_PINCTRL_PIN(T5),
2095 	ASPEED_PINCTRL_PIN(U1),
2096 	ASPEED_PINCTRL_PIN(U19),
2097 	ASPEED_PINCTRL_PIN(U2),
2098 	ASPEED_PINCTRL_PIN(U20),
2099 	ASPEED_PINCTRL_PIN(U21),
2100 	ASPEED_PINCTRL_PIN(U22),
2101 	ASPEED_PINCTRL_PIN(U3),
2102 	ASPEED_PINCTRL_PIN(U4),
2103 	ASPEED_PINCTRL_PIN(U5),
2104 	ASPEED_PINCTRL_PIN(V1),
2105 	ASPEED_PINCTRL_PIN(V19),
2106 	ASPEED_PINCTRL_PIN(V2),
2107 	ASPEED_PINCTRL_PIN(V20),
2108 	ASPEED_PINCTRL_PIN(V21),
2109 	ASPEED_PINCTRL_PIN(V22),
2110 	ASPEED_PINCTRL_PIN(V3),
2111 	ASPEED_PINCTRL_PIN(V4),
2112 	ASPEED_PINCTRL_PIN(V5),
2113 	ASPEED_PINCTRL_PIN(V6),
2114 	ASPEED_PINCTRL_PIN(W1),
2115 	ASPEED_PINCTRL_PIN(W19),
2116 	ASPEED_PINCTRL_PIN(W2),
2117 	ASPEED_PINCTRL_PIN(W20),
2118 	ASPEED_PINCTRL_PIN(W21),
2119 	ASPEED_PINCTRL_PIN(W22),
2120 	ASPEED_PINCTRL_PIN(W3),
2121 	ASPEED_PINCTRL_PIN(W4),
2122 	ASPEED_PINCTRL_PIN(W5),
2123 	ASPEED_PINCTRL_PIN(W6),
2124 	ASPEED_PINCTRL_PIN(Y1),
2125 	ASPEED_PINCTRL_PIN(Y19),
2126 	ASPEED_PINCTRL_PIN(Y2),
2127 	ASPEED_PINCTRL_PIN(Y20),
2128 	ASPEED_PINCTRL_PIN(Y21),
2129 	ASPEED_PINCTRL_PIN(Y22),
2130 	ASPEED_PINCTRL_PIN(Y3),
2131 	ASPEED_PINCTRL_PIN(Y4),
2132 	ASPEED_PINCTRL_PIN(Y5),
2133 	ASPEED_PINCTRL_PIN(Y6),
2134 };
2135 
2136 static const struct aspeed_pin_group aspeed_g5_groups[] = {
2137 	ASPEED_PINCTRL_GROUP(ACPI),
2138 	ASPEED_PINCTRL_GROUP(ADC0),
2139 	ASPEED_PINCTRL_GROUP(ADC1),
2140 	ASPEED_PINCTRL_GROUP(ADC10),
2141 	ASPEED_PINCTRL_GROUP(ADC11),
2142 	ASPEED_PINCTRL_GROUP(ADC12),
2143 	ASPEED_PINCTRL_GROUP(ADC13),
2144 	ASPEED_PINCTRL_GROUP(ADC14),
2145 	ASPEED_PINCTRL_GROUP(ADC15),
2146 	ASPEED_PINCTRL_GROUP(ADC2),
2147 	ASPEED_PINCTRL_GROUP(ADC3),
2148 	ASPEED_PINCTRL_GROUP(ADC4),
2149 	ASPEED_PINCTRL_GROUP(ADC5),
2150 	ASPEED_PINCTRL_GROUP(ADC6),
2151 	ASPEED_PINCTRL_GROUP(ADC7),
2152 	ASPEED_PINCTRL_GROUP(ADC8),
2153 	ASPEED_PINCTRL_GROUP(ADC9),
2154 	ASPEED_PINCTRL_GROUP(BMCINT),
2155 	ASPEED_PINCTRL_GROUP(DDCCLK),
2156 	ASPEED_PINCTRL_GROUP(DDCDAT),
2157 	ASPEED_PINCTRL_GROUP(ESPI),
2158 	ASPEED_PINCTRL_GROUP(FWSPICS1),
2159 	ASPEED_PINCTRL_GROUP(FWSPICS2),
2160 	ASPEED_PINCTRL_GROUP(GPID0),
2161 	ASPEED_PINCTRL_GROUP(GPID2),
2162 	ASPEED_PINCTRL_GROUP(GPID4),
2163 	ASPEED_PINCTRL_GROUP(GPID6),
2164 	ASPEED_PINCTRL_GROUP(GPIE0),
2165 	ASPEED_PINCTRL_GROUP(GPIE2),
2166 	ASPEED_PINCTRL_GROUP(GPIE4),
2167 	ASPEED_PINCTRL_GROUP(GPIE6),
2168 	ASPEED_PINCTRL_GROUP(I2C10),
2169 	ASPEED_PINCTRL_GROUP(I2C11),
2170 	ASPEED_PINCTRL_GROUP(I2C12),
2171 	ASPEED_PINCTRL_GROUP(I2C13),
2172 	ASPEED_PINCTRL_GROUP(I2C14),
2173 	ASPEED_PINCTRL_GROUP(I2C3),
2174 	ASPEED_PINCTRL_GROUP(I2C4),
2175 	ASPEED_PINCTRL_GROUP(I2C5),
2176 	ASPEED_PINCTRL_GROUP(I2C6),
2177 	ASPEED_PINCTRL_GROUP(I2C7),
2178 	ASPEED_PINCTRL_GROUP(I2C8),
2179 	ASPEED_PINCTRL_GROUP(I2C9),
2180 	ASPEED_PINCTRL_GROUP(LAD0),
2181 	ASPEED_PINCTRL_GROUP(LAD1),
2182 	ASPEED_PINCTRL_GROUP(LAD2),
2183 	ASPEED_PINCTRL_GROUP(LAD3),
2184 	ASPEED_PINCTRL_GROUP(LCLK),
2185 	ASPEED_PINCTRL_GROUP(LFRAME),
2186 	ASPEED_PINCTRL_GROUP(LPCHC),
2187 	ASPEED_PINCTRL_GROUP(LPCPD),
2188 	ASPEED_PINCTRL_GROUP(LPCPLUS),
2189 	ASPEED_PINCTRL_GROUP(LPCPME),
2190 	ASPEED_PINCTRL_GROUP(LPCRST),
2191 	ASPEED_PINCTRL_GROUP(LPCSMI),
2192 	ASPEED_PINCTRL_GROUP(LSIRQ),
2193 	ASPEED_PINCTRL_GROUP(MAC1LINK),
2194 	ASPEED_PINCTRL_GROUP(MAC2LINK),
2195 	ASPEED_PINCTRL_GROUP(MDIO1),
2196 	ASPEED_PINCTRL_GROUP(MDIO2),
2197 	ASPEED_PINCTRL_GROUP(NCTS1),
2198 	ASPEED_PINCTRL_GROUP(NCTS2),
2199 	ASPEED_PINCTRL_GROUP(NCTS3),
2200 	ASPEED_PINCTRL_GROUP(NCTS4),
2201 	ASPEED_PINCTRL_GROUP(NDCD1),
2202 	ASPEED_PINCTRL_GROUP(NDCD2),
2203 	ASPEED_PINCTRL_GROUP(NDCD3),
2204 	ASPEED_PINCTRL_GROUP(NDCD4),
2205 	ASPEED_PINCTRL_GROUP(NDSR1),
2206 	ASPEED_PINCTRL_GROUP(NDSR2),
2207 	ASPEED_PINCTRL_GROUP(NDSR3),
2208 	ASPEED_PINCTRL_GROUP(NDSR4),
2209 	ASPEED_PINCTRL_GROUP(NDTR1),
2210 	ASPEED_PINCTRL_GROUP(NDTR2),
2211 	ASPEED_PINCTRL_GROUP(NDTR3),
2212 	ASPEED_PINCTRL_GROUP(NDTR4),
2213 	ASPEED_PINCTRL_GROUP(NRI1),
2214 	ASPEED_PINCTRL_GROUP(NRI2),
2215 	ASPEED_PINCTRL_GROUP(NRI3),
2216 	ASPEED_PINCTRL_GROUP(NRI4),
2217 	ASPEED_PINCTRL_GROUP(NRTS1),
2218 	ASPEED_PINCTRL_GROUP(NRTS2),
2219 	ASPEED_PINCTRL_GROUP(NRTS3),
2220 	ASPEED_PINCTRL_GROUP(NRTS4),
2221 	ASPEED_PINCTRL_GROUP(OSCCLK),
2222 	ASPEED_PINCTRL_GROUP(PEWAKE),
2223 	ASPEED_PINCTRL_GROUP(PNOR),
2224 	ASPEED_PINCTRL_GROUP(PWM0),
2225 	ASPEED_PINCTRL_GROUP(PWM1),
2226 	ASPEED_PINCTRL_GROUP(PWM2),
2227 	ASPEED_PINCTRL_GROUP(PWM3),
2228 	ASPEED_PINCTRL_GROUP(PWM4),
2229 	ASPEED_PINCTRL_GROUP(PWM5),
2230 	ASPEED_PINCTRL_GROUP(PWM6),
2231 	ASPEED_PINCTRL_GROUP(PWM7),
2232 	ASPEED_PINCTRL_GROUP(RGMII1),
2233 	ASPEED_PINCTRL_GROUP(RGMII2),
2234 	ASPEED_PINCTRL_GROUP(RMII1),
2235 	ASPEED_PINCTRL_GROUP(RMII2),
2236 	ASPEED_PINCTRL_GROUP(RXD1),
2237 	ASPEED_PINCTRL_GROUP(RXD2),
2238 	ASPEED_PINCTRL_GROUP(RXD3),
2239 	ASPEED_PINCTRL_GROUP(RXD4),
2240 	ASPEED_PINCTRL_GROUP(SALT1),
2241 	ASPEED_PINCTRL_GROUP(SALT10),
2242 	ASPEED_PINCTRL_GROUP(SALT11),
2243 	ASPEED_PINCTRL_GROUP(SALT12),
2244 	ASPEED_PINCTRL_GROUP(SALT13),
2245 	ASPEED_PINCTRL_GROUP(SALT14),
2246 	ASPEED_PINCTRL_GROUP(SALT2),
2247 	ASPEED_PINCTRL_GROUP(SALT3),
2248 	ASPEED_PINCTRL_GROUP(SALT4),
2249 	ASPEED_PINCTRL_GROUP(SALT5),
2250 	ASPEED_PINCTRL_GROUP(SALT6),
2251 	ASPEED_PINCTRL_GROUP(SALT7),
2252 	ASPEED_PINCTRL_GROUP(SALT8),
2253 	ASPEED_PINCTRL_GROUP(SALT9),
2254 	ASPEED_PINCTRL_GROUP(SCL1),
2255 	ASPEED_PINCTRL_GROUP(SCL2),
2256 	ASPEED_PINCTRL_GROUP(SD1),
2257 	ASPEED_PINCTRL_GROUP(SD2),
2258 	ASPEED_PINCTRL_GROUP(SDA1),
2259 	ASPEED_PINCTRL_GROUP(SDA2),
2260 	ASPEED_PINCTRL_GROUP(SGPM),
2261 	ASPEED_PINCTRL_GROUP(SGPS1),
2262 	ASPEED_PINCTRL_GROUP(SGPS2),
2263 	ASPEED_PINCTRL_GROUP(SIOONCTRL),
2264 	ASPEED_PINCTRL_GROUP(SIOPBI),
2265 	ASPEED_PINCTRL_GROUP(SIOPBO),
2266 	ASPEED_PINCTRL_GROUP(SIOPWREQ),
2267 	ASPEED_PINCTRL_GROUP(SIOPWRGD),
2268 	ASPEED_PINCTRL_GROUP(SIOS3),
2269 	ASPEED_PINCTRL_GROUP(SIOS5),
2270 	ASPEED_PINCTRL_GROUP(SIOSCI),
2271 	ASPEED_PINCTRL_GROUP(SPI1),
2272 	ASPEED_PINCTRL_GROUP(SPI1CS1),
2273 	ASPEED_PINCTRL_GROUP(SPI1DEBUG),
2274 	ASPEED_PINCTRL_GROUP(SPI1PASSTHRU),
2275 	ASPEED_PINCTRL_GROUP(SPI2CK),
2276 	ASPEED_PINCTRL_GROUP(SPI2CS0),
2277 	ASPEED_PINCTRL_GROUP(SPI2CS1),
2278 	ASPEED_PINCTRL_GROUP(SPI2MISO),
2279 	ASPEED_PINCTRL_GROUP(SPI2MOSI),
2280 	ASPEED_PINCTRL_GROUP(TIMER3),
2281 	ASPEED_PINCTRL_GROUP(TIMER4),
2282 	ASPEED_PINCTRL_GROUP(TIMER5),
2283 	ASPEED_PINCTRL_GROUP(TIMER6),
2284 	ASPEED_PINCTRL_GROUP(TIMER7),
2285 	ASPEED_PINCTRL_GROUP(TIMER8),
2286 	ASPEED_PINCTRL_GROUP(TXD1),
2287 	ASPEED_PINCTRL_GROUP(TXD2),
2288 	ASPEED_PINCTRL_GROUP(TXD3),
2289 	ASPEED_PINCTRL_GROUP(TXD4),
2290 	ASPEED_PINCTRL_GROUP(UART6),
2291 	ASPEED_PINCTRL_GROUP(USB11BHID),
2292 	ASPEED_PINCTRL_GROUP(USB2AD),
2293 	ASPEED_PINCTRL_GROUP(USB2AH),
2294 	ASPEED_PINCTRL_GROUP(USB2BD),
2295 	ASPEED_PINCTRL_GROUP(USB2BH),
2296 	ASPEED_PINCTRL_GROUP(USBCKI),
2297 	ASPEED_PINCTRL_GROUP(VGABIOSROM),
2298 	ASPEED_PINCTRL_GROUP(VGAHS),
2299 	ASPEED_PINCTRL_GROUP(VGAVS),
2300 	ASPEED_PINCTRL_GROUP(VPI24),
2301 	ASPEED_PINCTRL_GROUP(VPO),
2302 	ASPEED_PINCTRL_GROUP(WDTRST1),
2303 	ASPEED_PINCTRL_GROUP(WDTRST2),
2304 };
2305 
2306 static const struct aspeed_pin_function aspeed_g5_functions[] = {
2307 	ASPEED_PINCTRL_FUNC(ACPI),
2308 	ASPEED_PINCTRL_FUNC(ADC0),
2309 	ASPEED_PINCTRL_FUNC(ADC1),
2310 	ASPEED_PINCTRL_FUNC(ADC10),
2311 	ASPEED_PINCTRL_FUNC(ADC11),
2312 	ASPEED_PINCTRL_FUNC(ADC12),
2313 	ASPEED_PINCTRL_FUNC(ADC13),
2314 	ASPEED_PINCTRL_FUNC(ADC14),
2315 	ASPEED_PINCTRL_FUNC(ADC15),
2316 	ASPEED_PINCTRL_FUNC(ADC2),
2317 	ASPEED_PINCTRL_FUNC(ADC3),
2318 	ASPEED_PINCTRL_FUNC(ADC4),
2319 	ASPEED_PINCTRL_FUNC(ADC5),
2320 	ASPEED_PINCTRL_FUNC(ADC6),
2321 	ASPEED_PINCTRL_FUNC(ADC7),
2322 	ASPEED_PINCTRL_FUNC(ADC8),
2323 	ASPEED_PINCTRL_FUNC(ADC9),
2324 	ASPEED_PINCTRL_FUNC(BMCINT),
2325 	ASPEED_PINCTRL_FUNC(DDCCLK),
2326 	ASPEED_PINCTRL_FUNC(DDCDAT),
2327 	ASPEED_PINCTRL_FUNC(ESPI),
2328 	ASPEED_PINCTRL_FUNC(FWSPICS1),
2329 	ASPEED_PINCTRL_FUNC(FWSPICS2),
2330 	ASPEED_PINCTRL_FUNC(GPID0),
2331 	ASPEED_PINCTRL_FUNC(GPID2),
2332 	ASPEED_PINCTRL_FUNC(GPID4),
2333 	ASPEED_PINCTRL_FUNC(GPID6),
2334 	ASPEED_PINCTRL_FUNC(GPIE0),
2335 	ASPEED_PINCTRL_FUNC(GPIE2),
2336 	ASPEED_PINCTRL_FUNC(GPIE4),
2337 	ASPEED_PINCTRL_FUNC(GPIE6),
2338 	ASPEED_PINCTRL_FUNC(I2C10),
2339 	ASPEED_PINCTRL_FUNC(I2C11),
2340 	ASPEED_PINCTRL_FUNC(I2C12),
2341 	ASPEED_PINCTRL_FUNC(I2C13),
2342 	ASPEED_PINCTRL_FUNC(I2C14),
2343 	ASPEED_PINCTRL_FUNC(I2C3),
2344 	ASPEED_PINCTRL_FUNC(I2C4),
2345 	ASPEED_PINCTRL_FUNC(I2C5),
2346 	ASPEED_PINCTRL_FUNC(I2C6),
2347 	ASPEED_PINCTRL_FUNC(I2C7),
2348 	ASPEED_PINCTRL_FUNC(I2C8),
2349 	ASPEED_PINCTRL_FUNC(I2C9),
2350 	ASPEED_PINCTRL_FUNC(LAD0),
2351 	ASPEED_PINCTRL_FUNC(LAD1),
2352 	ASPEED_PINCTRL_FUNC(LAD2),
2353 	ASPEED_PINCTRL_FUNC(LAD3),
2354 	ASPEED_PINCTRL_FUNC(LCLK),
2355 	ASPEED_PINCTRL_FUNC(LFRAME),
2356 	ASPEED_PINCTRL_FUNC(LPCHC),
2357 	ASPEED_PINCTRL_FUNC(LPCPD),
2358 	ASPEED_PINCTRL_FUNC(LPCPLUS),
2359 	ASPEED_PINCTRL_FUNC(LPCPME),
2360 	ASPEED_PINCTRL_FUNC(LPCRST),
2361 	ASPEED_PINCTRL_FUNC(LPCSMI),
2362 	ASPEED_PINCTRL_FUNC(LSIRQ),
2363 	ASPEED_PINCTRL_FUNC(MAC1LINK),
2364 	ASPEED_PINCTRL_FUNC(MAC2LINK),
2365 	ASPEED_PINCTRL_FUNC(MDIO1),
2366 	ASPEED_PINCTRL_FUNC(MDIO2),
2367 	ASPEED_PINCTRL_FUNC(NCTS1),
2368 	ASPEED_PINCTRL_FUNC(NCTS2),
2369 	ASPEED_PINCTRL_FUNC(NCTS3),
2370 	ASPEED_PINCTRL_FUNC(NCTS4),
2371 	ASPEED_PINCTRL_FUNC(NDCD1),
2372 	ASPEED_PINCTRL_FUNC(NDCD2),
2373 	ASPEED_PINCTRL_FUNC(NDCD3),
2374 	ASPEED_PINCTRL_FUNC(NDCD4),
2375 	ASPEED_PINCTRL_FUNC(NDSR1),
2376 	ASPEED_PINCTRL_FUNC(NDSR2),
2377 	ASPEED_PINCTRL_FUNC(NDSR3),
2378 	ASPEED_PINCTRL_FUNC(NDSR4),
2379 	ASPEED_PINCTRL_FUNC(NDTR1),
2380 	ASPEED_PINCTRL_FUNC(NDTR2),
2381 	ASPEED_PINCTRL_FUNC(NDTR3),
2382 	ASPEED_PINCTRL_FUNC(NDTR4),
2383 	ASPEED_PINCTRL_FUNC(NRI1),
2384 	ASPEED_PINCTRL_FUNC(NRI2),
2385 	ASPEED_PINCTRL_FUNC(NRI3),
2386 	ASPEED_PINCTRL_FUNC(NRI4),
2387 	ASPEED_PINCTRL_FUNC(NRTS1),
2388 	ASPEED_PINCTRL_FUNC(NRTS2),
2389 	ASPEED_PINCTRL_FUNC(NRTS3),
2390 	ASPEED_PINCTRL_FUNC(NRTS4),
2391 	ASPEED_PINCTRL_FUNC(OSCCLK),
2392 	ASPEED_PINCTRL_FUNC(PEWAKE),
2393 	ASPEED_PINCTRL_FUNC(PNOR),
2394 	ASPEED_PINCTRL_FUNC(PWM0),
2395 	ASPEED_PINCTRL_FUNC(PWM1),
2396 	ASPEED_PINCTRL_FUNC(PWM2),
2397 	ASPEED_PINCTRL_FUNC(PWM3),
2398 	ASPEED_PINCTRL_FUNC(PWM4),
2399 	ASPEED_PINCTRL_FUNC(PWM5),
2400 	ASPEED_PINCTRL_FUNC(PWM6),
2401 	ASPEED_PINCTRL_FUNC(PWM7),
2402 	ASPEED_PINCTRL_FUNC(RGMII1),
2403 	ASPEED_PINCTRL_FUNC(RGMII2),
2404 	ASPEED_PINCTRL_FUNC(RMII1),
2405 	ASPEED_PINCTRL_FUNC(RMII2),
2406 	ASPEED_PINCTRL_FUNC(RXD1),
2407 	ASPEED_PINCTRL_FUNC(RXD2),
2408 	ASPEED_PINCTRL_FUNC(RXD3),
2409 	ASPEED_PINCTRL_FUNC(RXD4),
2410 	ASPEED_PINCTRL_FUNC(SALT1),
2411 	ASPEED_PINCTRL_FUNC(SALT10),
2412 	ASPEED_PINCTRL_FUNC(SALT11),
2413 	ASPEED_PINCTRL_FUNC(SALT12),
2414 	ASPEED_PINCTRL_FUNC(SALT13),
2415 	ASPEED_PINCTRL_FUNC(SALT14),
2416 	ASPEED_PINCTRL_FUNC(SALT2),
2417 	ASPEED_PINCTRL_FUNC(SALT3),
2418 	ASPEED_PINCTRL_FUNC(SALT4),
2419 	ASPEED_PINCTRL_FUNC(SALT5),
2420 	ASPEED_PINCTRL_FUNC(SALT6),
2421 	ASPEED_PINCTRL_FUNC(SALT7),
2422 	ASPEED_PINCTRL_FUNC(SALT8),
2423 	ASPEED_PINCTRL_FUNC(SALT9),
2424 	ASPEED_PINCTRL_FUNC(SCL1),
2425 	ASPEED_PINCTRL_FUNC(SCL2),
2426 	ASPEED_PINCTRL_FUNC(SD1),
2427 	ASPEED_PINCTRL_FUNC(SD2),
2428 	ASPEED_PINCTRL_FUNC(SDA1),
2429 	ASPEED_PINCTRL_FUNC(SDA2),
2430 	ASPEED_PINCTRL_FUNC(SGPM),
2431 	ASPEED_PINCTRL_FUNC(SGPS1),
2432 	ASPEED_PINCTRL_FUNC(SGPS2),
2433 	ASPEED_PINCTRL_FUNC(SIOONCTRL),
2434 	ASPEED_PINCTRL_FUNC(SIOPBI),
2435 	ASPEED_PINCTRL_FUNC(SIOPBO),
2436 	ASPEED_PINCTRL_FUNC(SIOPWREQ),
2437 	ASPEED_PINCTRL_FUNC(SIOPWRGD),
2438 	ASPEED_PINCTRL_FUNC(SIOS3),
2439 	ASPEED_PINCTRL_FUNC(SIOS5),
2440 	ASPEED_PINCTRL_FUNC(SIOSCI),
2441 	ASPEED_PINCTRL_FUNC(SPI1),
2442 	ASPEED_PINCTRL_FUNC(SPI1CS1),
2443 	ASPEED_PINCTRL_FUNC(SPI1DEBUG),
2444 	ASPEED_PINCTRL_FUNC(SPI1PASSTHRU),
2445 	ASPEED_PINCTRL_FUNC(SPI2CK),
2446 	ASPEED_PINCTRL_FUNC(SPI2CS0),
2447 	ASPEED_PINCTRL_FUNC(SPI2CS1),
2448 	ASPEED_PINCTRL_FUNC(SPI2MISO),
2449 	ASPEED_PINCTRL_FUNC(SPI2MOSI),
2450 	ASPEED_PINCTRL_FUNC(TIMER3),
2451 	ASPEED_PINCTRL_FUNC(TIMER4),
2452 	ASPEED_PINCTRL_FUNC(TIMER5),
2453 	ASPEED_PINCTRL_FUNC(TIMER6),
2454 	ASPEED_PINCTRL_FUNC(TIMER7),
2455 	ASPEED_PINCTRL_FUNC(TIMER8),
2456 	ASPEED_PINCTRL_FUNC(TXD1),
2457 	ASPEED_PINCTRL_FUNC(TXD2),
2458 	ASPEED_PINCTRL_FUNC(TXD3),
2459 	ASPEED_PINCTRL_FUNC(TXD4),
2460 	ASPEED_PINCTRL_FUNC(UART6),
2461 	ASPEED_PINCTRL_FUNC(USB11BHID),
2462 	ASPEED_PINCTRL_FUNC(USB2AD),
2463 	ASPEED_PINCTRL_FUNC(USB2AH),
2464 	ASPEED_PINCTRL_FUNC(USB2BD),
2465 	ASPEED_PINCTRL_FUNC(USB2BH),
2466 	ASPEED_PINCTRL_FUNC(USBCKI),
2467 	ASPEED_PINCTRL_FUNC(VGABIOSROM),
2468 	ASPEED_PINCTRL_FUNC(VGAHS),
2469 	ASPEED_PINCTRL_FUNC(VGAVS),
2470 	ASPEED_PINCTRL_FUNC(VPI24),
2471 	ASPEED_PINCTRL_FUNC(VPO),
2472 	ASPEED_PINCTRL_FUNC(WDTRST1),
2473 	ASPEED_PINCTRL_FUNC(WDTRST2),
2474 };
2475 
2476 static struct aspeed_pin_config aspeed_g5_configs[] = {
2477 	/* GPIOA, GPIOQ */
2478 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, B14, B13, SCU8C, 16),
2479 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   B14, B13, SCU8C, 16),
2480 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, A11, N20, SCU8C, 16),
2481 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   A11, N20, SCU8C, 16),
2482 
2483 	/* GPIOB, GPIOR */
2484 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, K19, H20, SCU8C, 17),
2485 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   K19, H20, SCU8C, 17),
2486 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, AA19, E10, SCU8C, 17),
2487 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   AA19, E10, SCU8C, 17),
2488 
2489 	/* GPIOC, GPIOS*/
2490 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, C12, B11, SCU8C, 18),
2491 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   C12, B11, SCU8C, 18),
2492 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, V20, AA20, SCU8C, 18),
2493 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   V20, AA20, SCU8C, 18),
2494 
2495 	/* GPIOD, GPIOY */
2496 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, F19, C21, SCU8C, 19),
2497 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   F19, C21, SCU8C, 19),
2498 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, R22, P20, SCU8C, 19),
2499 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   R22, P20, SCU8C, 19),
2500 
2501 	/* GPIOE, GPIOZ */
2502 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, B20, B19, SCU8C, 20),
2503 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   B20, B19, SCU8C, 20),
2504 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, Y20, W21, SCU8C, 20),
2505 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   Y20, W21, SCU8C, 20),
2506 
2507 	/* GPIOF, GPIOAA */
2508 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, J19, H18, SCU8C, 21),
2509 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   J19, H18, SCU8C, 21),
2510 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, Y21, P19, SCU8C, 21),
2511 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   Y21, P19, SCU8C, 21),
2512 
2513 		/* GPIOG, GPIOAB */
2514 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, A19, E14, SCU8C, 22),
2515 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   A19, E14, SCU8C, 22),
2516 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, N19, R20, SCU8C, 22),
2517 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   N19, R20, SCU8C, 22),
2518 
2519 	/* GPIOH, GPIOAC */
2520 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, A18,  D18, SCU8C, 23),
2521 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   A18,  D18, SCU8C, 23),
2522 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, G21,  G22, SCU8C, 23),
2523 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   G21,  G22, SCU8C, 23),
2524 
2525 	/* GPIOs [I, P] */
2526 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, C18, A15, SCU8C, 24),
2527 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   C18, A15, SCU8C, 24),
2528 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, R2,  T3,  SCU8C, 25),
2529 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   R2,  T3,  SCU8C, 25),
2530 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, L3,  R1,  SCU8C, 26),
2531 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   L3,  R1,  SCU8C, 26),
2532 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, T2,  W1,  SCU8C, 27),
2533 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   T2,  W1,  SCU8C, 27),
2534 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, Y1,  T5,  SCU8C, 28),
2535 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   Y1,  T5,  SCU8C, 28),
2536 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, V2,  T4,  SCU8C, 29),
2537 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   V2,  T4,  SCU8C, 29),
2538 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, U5,  W4,  SCU8C, 30),
2539 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   U5,  W4,  SCU8C, 30),
2540 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, V4,  V6,  SCU8C, 31),
2541 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   V4,  V6,  SCU8C, 31),
2542 
2543 	/* GPIOs T[0-5] (RGMII1 Tx pins) */
2544 	ASPEED_SB_PINCONF(PIN_CONFIG_DRIVE_STRENGTH, B5, B5, SCU90, 8),
2545 	ASPEED_SB_PINCONF(PIN_CONFIG_DRIVE_STRENGTH, E9, A5, SCU90, 9),
2546 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, B5, D7, SCU90, 12),
2547 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   B5, D7, SCU90, 12),
2548 
2549 	/* GPIOs T[6-7], U[0-3] (RGMII2 TX pins) */
2550 	ASPEED_SB_PINCONF(PIN_CONFIG_DRIVE_STRENGTH, B2, B2, SCU90, 10),
2551 	ASPEED_SB_PINCONF(PIN_CONFIG_DRIVE_STRENGTH, B1, B3, SCU90, 11),
2552 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, B2, D4, SCU90, 14),
2553 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   B2, D4, SCU90, 14),
2554 
2555 	/* GPIOs U[4-7], V[0-1] (RGMII1 Rx pins) */
2556 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, B4, C4, SCU90, 13),
2557 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   B4, C4, SCU90, 13),
2558 
2559 	/* GPIOs V[2-7] (RGMII2 Rx pins) */
2560 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, C2, E6, SCU90, 15),
2561 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   C2, E6, SCU90, 15),
2562 
2563 	/* ADC pull-downs (SCUA8[19:4]) */
2564 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, F4, F4, SCUA8, 4),
2565 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   F4, F4, SCUA8, 4),
2566 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, F5, F5, SCUA8, 5),
2567 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   F5, F5, SCUA8, 5),
2568 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, E2, E2, SCUA8, 6),
2569 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   E2, E2, SCUA8, 6),
2570 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, E1, E1, SCUA8, 7),
2571 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   E1, E1, SCUA8, 7),
2572 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, F3, F3, SCUA8, 8),
2573 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   F3, F3, SCUA8, 8),
2574 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, E3, E3, SCUA8, 9),
2575 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   E3, E3, SCUA8, 9),
2576 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, G5, G5, SCUA8, 10),
2577 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   G5, G5, SCUA8, 10),
2578 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, G4, G4, SCUA8, 11),
2579 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   G4, G4, SCUA8, 11),
2580 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, F2, F2, SCUA8, 12),
2581 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   F2, F2, SCUA8, 12),
2582 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, G3, G3, SCUA8, 13),
2583 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   G3, G3, SCUA8, 13),
2584 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, G2, G2, SCUA8, 14),
2585 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   G2, G2, SCUA8, 14),
2586 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, F1, F1, SCUA8, 15),
2587 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   F1, F1, SCUA8, 15),
2588 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, H5, H5, SCUA8, 16),
2589 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   H5, H5, SCUA8, 16),
2590 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, G1, G1, SCUA8, 17),
2591 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   G1, G1, SCUA8, 17),
2592 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, H3, H3, SCUA8, 18),
2593 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   H3, H3, SCUA8, 18),
2594 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_PULL_DOWN, H4, H4, SCUA8, 19),
2595 	ASPEED_SB_PINCONF(PIN_CONFIG_BIAS_DISABLE,   H4, H4, SCUA8, 19),
2596 
2597 	/*
2598 	 * Debounce settings for GPIOs D and E passthrough mode are in
2599 	 * SCUA8[27:20] and so are managed by pinctrl. Normal GPIO debounce for
2600 	 * banks D and E is handled by the GPIO driver - GPIO passthrough is
2601 	 * treated like any other non-GPIO mux function. There is a catch
2602 	 * however, in that the debounce period is configured in the GPIO
2603 	 * controller. Due to this tangle between GPIO and pinctrl we don't yet
2604 	 * fully support pass-through debounce.
2605 	 */
2606 	ASPEED_SB_PINCONF(PIN_CONFIG_INPUT_DEBOUNCE, F19, E21, SCUA8, 20),
2607 	ASPEED_SB_PINCONF(PIN_CONFIG_INPUT_DEBOUNCE, F20, D20, SCUA8, 21),
2608 	ASPEED_SB_PINCONF(PIN_CONFIG_INPUT_DEBOUNCE, D21, E20, SCUA8, 22),
2609 	ASPEED_SB_PINCONF(PIN_CONFIG_INPUT_DEBOUNCE, G18, C21, SCUA8, 23),
2610 	ASPEED_SB_PINCONF(PIN_CONFIG_INPUT_DEBOUNCE, B20, C20, SCUA8, 24),
2611 	ASPEED_SB_PINCONF(PIN_CONFIG_INPUT_DEBOUNCE, F18, F17, SCUA8, 25),
2612 	ASPEED_SB_PINCONF(PIN_CONFIG_INPUT_DEBOUNCE, E18, D19, SCUA8, 26),
2613 	ASPEED_SB_PINCONF(PIN_CONFIG_INPUT_DEBOUNCE, A20, B19, SCUA8, 27),
2614 };
2615 
2616 static struct regmap *aspeed_g5_acquire_regmap(struct aspeed_pinmux_data *ctx,
2617 					       int ip)
2618 {
2619 	if (ip == ASPEED_IP_SCU) {
2620 		WARN(!ctx->maps[ip], "Missing SCU syscon!");
2621 		return ctx->maps[ip];
2622 	}
2623 
2624 	if (ip >= ASPEED_NR_PINMUX_IPS)
2625 		return ERR_PTR(-EINVAL);
2626 
2627 	if (likely(ctx->maps[ip]))
2628 		return ctx->maps[ip];
2629 
2630 	if (ip == ASPEED_IP_GFX) {
2631 		struct device_node *node;
2632 		struct regmap *map;
2633 
2634 		node = of_parse_phandle(ctx->dev->of_node,
2635 					"aspeed,external-nodes", 0);
2636 		if (node) {
2637 			map = syscon_node_to_regmap(node);
2638 			of_node_put(node);
2639 			if (IS_ERR(map))
2640 				return map;
2641 		} else
2642 			return ERR_PTR(-ENODEV);
2643 
2644 		ctx->maps[ASPEED_IP_GFX] = map;
2645 		dev_dbg(ctx->dev, "Acquired GFX regmap");
2646 		return map;
2647 	}
2648 
2649 	if (ip == ASPEED_IP_LPC) {
2650 		struct device_node *np;
2651 		struct regmap *map;
2652 
2653 		np = of_parse_phandle(ctx->dev->of_node,
2654 					"aspeed,external-nodes", 1);
2655 		if (np) {
2656 			if (!of_device_is_compatible(np->parent, "aspeed,ast2500-lpc-v2"))
2657 				return ERR_PTR(-ENODEV);
2658 
2659 			map = syscon_node_to_regmap(np->parent);
2660 			of_node_put(np);
2661 			if (IS_ERR(map))
2662 				return map;
2663 		} else
2664 			return ERR_PTR(-ENODEV);
2665 
2666 		ctx->maps[ASPEED_IP_LPC] = map;
2667 		dev_dbg(ctx->dev, "Acquired LPC regmap");
2668 		return map;
2669 	}
2670 
2671 	return ERR_PTR(-EINVAL);
2672 }
2673 
2674 static int aspeed_g5_sig_expr_eval(struct aspeed_pinmux_data *ctx,
2675 				   const struct aspeed_sig_expr *expr,
2676 				   bool enabled)
2677 {
2678 	int ret;
2679 	int i;
2680 
2681 	for (i = 0; i < expr->ndescs; i++) {
2682 		const struct aspeed_sig_desc *desc = &expr->descs[i];
2683 		struct regmap *map;
2684 
2685 		map = aspeed_g5_acquire_regmap(ctx, desc->ip);
2686 		if (IS_ERR(map)) {
2687 			dev_err(ctx->dev,
2688 				"Failed to acquire regmap for IP block %d\n",
2689 				desc->ip);
2690 			return PTR_ERR(map);
2691 		}
2692 
2693 		ret = aspeed_sig_desc_eval(desc, enabled, ctx->maps[desc->ip]);
2694 		if (ret <= 0)
2695 			return ret;
2696 	}
2697 
2698 	return 1;
2699 }
2700 
2701 /**
2702  * aspeed_g5_sig_expr_set() - Configure a pin's signal by applying an
2703  * expression's descriptor state for all descriptors in the expression.
2704  *
2705  * @ctx: The pinmux context
2706  * @expr: The expression associated with the function whose signal is to be
2707  *        configured
2708  * @enable: true to enable an function's signal through a pin's signal
2709  *          expression, false to disable the function's signal
2710  *
2711  * Return: 0 if the expression is configured as requested and a negative error
2712  * code otherwise
2713  */
2714 static int aspeed_g5_sig_expr_set(struct aspeed_pinmux_data *ctx,
2715 				  const struct aspeed_sig_expr *expr,
2716 				  bool enable)
2717 {
2718 	int ret;
2719 	int i;
2720 
2721 	for (i = 0; i < expr->ndescs; i++) {
2722 		const struct aspeed_sig_desc *desc = &expr->descs[i];
2723 		u32 pattern = enable ? desc->enable : desc->disable;
2724 		u32 val = (pattern << __ffs(desc->mask));
2725 		struct regmap *map;
2726 
2727 		map = aspeed_g5_acquire_regmap(ctx, desc->ip);
2728 		if (IS_ERR(map)) {
2729 			dev_err(ctx->dev,
2730 				"Failed to acquire regmap for IP block %d\n",
2731 				desc->ip);
2732 			return PTR_ERR(map);
2733 		}
2734 
2735 		/*
2736 		 * Strap registers are configured in hardware or by early-boot
2737 		 * firmware. Treat them as read-only despite that we can write
2738 		 * them. This may mean that certain functions cannot be
2739 		 * deconfigured and is the reason we re-evaluate after writing
2740 		 * all descriptor bits.
2741 		 *
2742 		 * We make two exceptions to the read-only rule:
2743 		 *
2744 		 * - The passthrough mode of GPIO ports D and E are commonly
2745 		 *   used with front-panel buttons to allow normal operation
2746 		 *   of the host if the BMC is powered off or fails to boot.
2747 		 *   Once the BMC has booted, the loopback mode must be
2748 		 *   disabled for the BMC to control host power-on and reset.
2749 		 *
2750 		 * - The operating mode of the SPI1 interface is simply
2751 		 *   strapped incorrectly on some systems and requires a
2752 		 *   software fixup, which we allow to be done via pinctrl.
2753 		 */
2754 		if (desc->ip == ASPEED_IP_SCU && desc->reg == HW_STRAP1 &&
2755 		    !(desc->mask & (BIT(22) | BIT(21) | BIT(13) | BIT(12))))
2756 			continue;
2757 
2758 		if (desc->ip == ASPEED_IP_SCU && desc->reg == HW_STRAP2)
2759 			continue;
2760 
2761 		/* On AST2500, Set bits in SCU70 are cleared from SCU7C */
2762 		if (desc->ip == ASPEED_IP_SCU && desc->reg == HW_STRAP1) {
2763 			u32 value = ~val & desc->mask;
2764 
2765 			if (value) {
2766 				ret = regmap_write(ctx->maps[desc->ip],
2767 						   HW_REVISION_ID, value);
2768 				if (ret < 0)
2769 					return ret;
2770 			}
2771 		}
2772 
2773 		ret = regmap_update_bits(ctx->maps[desc->ip], desc->reg,
2774 					 desc->mask, val);
2775 
2776 		if (ret)
2777 			return ret;
2778 	}
2779 
2780 	ret = aspeed_sig_expr_eval(ctx, expr, enable);
2781 	if (ret < 0)
2782 		return ret;
2783 
2784 	if (!ret)
2785 		return -EPERM;
2786 
2787 	return 0;
2788 }
2789 
2790 static const struct aspeed_pin_config_map aspeed_g5_pin_config_map[] = {
2791 	{ PIN_CONFIG_BIAS_PULL_DOWN,  0, 1, BIT_MASK(0)},
2792 	{ PIN_CONFIG_BIAS_PULL_DOWN, -1, 0, BIT_MASK(0)},
2793 	{ PIN_CONFIG_BIAS_DISABLE,   -1, 1, BIT_MASK(0)},
2794 	{ PIN_CONFIG_DRIVE_STRENGTH,  8, 0, BIT_MASK(0)},
2795 	{ PIN_CONFIG_DRIVE_STRENGTH, 16, 1, BIT_MASK(0)},
2796 };
2797 
2798 static const struct aspeed_pinmux_ops aspeed_g5_ops = {
2799 	.eval = aspeed_g5_sig_expr_eval,
2800 	.set = aspeed_g5_sig_expr_set,
2801 };
2802 
2803 static struct aspeed_pinctrl_data aspeed_g5_pinctrl_data = {
2804 	.pins = aspeed_g5_pins,
2805 	.npins = ARRAY_SIZE(aspeed_g5_pins),
2806 	.pinmux = {
2807 		.ops = &aspeed_g5_ops,
2808 		.groups = aspeed_g5_groups,
2809 		.ngroups = ARRAY_SIZE(aspeed_g5_groups),
2810 		.functions = aspeed_g5_functions,
2811 		.nfunctions = ARRAY_SIZE(aspeed_g5_functions),
2812 	},
2813 	.configs = aspeed_g5_configs,
2814 	.nconfigs = ARRAY_SIZE(aspeed_g5_configs),
2815 	.confmaps = aspeed_g5_pin_config_map,
2816 	.nconfmaps = ARRAY_SIZE(aspeed_g5_pin_config_map),
2817 };
2818 
2819 static const struct pinmux_ops aspeed_g5_pinmux_ops = {
2820 	.get_functions_count = aspeed_pinmux_get_fn_count,
2821 	.get_function_name = aspeed_pinmux_get_fn_name,
2822 	.get_function_groups = aspeed_pinmux_get_fn_groups,
2823 	.set_mux = aspeed_pinmux_set_mux,
2824 	.gpio_request_enable = aspeed_gpio_request_enable,
2825 	.strict = true,
2826 };
2827 
2828 static const struct pinctrl_ops aspeed_g5_pinctrl_ops = {
2829 	.get_groups_count = aspeed_pinctrl_get_groups_count,
2830 	.get_group_name = aspeed_pinctrl_get_group_name,
2831 	.get_group_pins = aspeed_pinctrl_get_group_pins,
2832 	.pin_dbg_show = aspeed_pinctrl_pin_dbg_show,
2833 	.dt_node_to_map = pinconf_generic_dt_node_to_map_all,
2834 	.dt_free_map = pinctrl_utils_free_map,
2835 };
2836 
2837 static const struct pinconf_ops aspeed_g5_conf_ops = {
2838 	.is_generic = true,
2839 	.pin_config_get = aspeed_pin_config_get,
2840 	.pin_config_set = aspeed_pin_config_set,
2841 	.pin_config_group_get = aspeed_pin_config_group_get,
2842 	.pin_config_group_set = aspeed_pin_config_group_set,
2843 };
2844 
2845 static const struct pinctrl_desc aspeed_g5_pinctrl_desc = {
2846 	.name = "aspeed-g5-pinctrl",
2847 	.pins = aspeed_g5_pins,
2848 	.npins = ARRAY_SIZE(aspeed_g5_pins),
2849 	.pctlops = &aspeed_g5_pinctrl_ops,
2850 	.pmxops = &aspeed_g5_pinmux_ops,
2851 	.confops = &aspeed_g5_conf_ops,
2852 };
2853 
2854 static int aspeed_g5_pinctrl_probe(struct platform_device *pdev)
2855 {
2856 	int i;
2857 
2858 	for (i = 0; i < ARRAY_SIZE(aspeed_g5_pins); i++)
2859 		aspeed_g5_pins[i].number = i;
2860 
2861 	aspeed_g5_pinctrl_data.pinmux.dev = &pdev->dev;
2862 
2863 	return aspeed_pinctrl_probe(pdev, &aspeed_g5_pinctrl_desc,
2864 			&aspeed_g5_pinctrl_data);
2865 }
2866 
2867 static const struct of_device_id aspeed_g5_pinctrl_of_match[] = {
2868 	{ .compatible = "aspeed,ast2500-pinctrl", },
2869 	/*
2870 	 * The aspeed,g5-pinctrl compatible has been removed the from the
2871 	 * bindings, but keep the match in case of old devicetrees.
2872 	 */
2873 	{ .compatible = "aspeed,g5-pinctrl", },
2874 	{ },
2875 };
2876 
2877 static struct platform_driver aspeed_g5_pinctrl_driver = {
2878 	.probe = aspeed_g5_pinctrl_probe,
2879 	.driver = {
2880 		.name = "aspeed-g5-pinctrl",
2881 		.of_match_table = aspeed_g5_pinctrl_of_match,
2882 	},
2883 };
2884 
2885 static int aspeed_g5_pinctrl_init(void)
2886 {
2887 	return platform_driver_register(&aspeed_g5_pinctrl_driver);
2888 }
2889 
2890 arch_initcall(aspeed_g5_pinctrl_init);
2891