123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878 |
- /*
- * Copyright (C) 2016 IBM Corp.
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- */
- #include <linux/bitops.h>
- #include <linux/init.h>
- #include <linux/io.h>
- #include <linux/kernel.h>
- #include <linux/mutex.h>
- #include <linux/of.h>
- #include <linux/platform_device.h>
- #include <linux/pinctrl/pinctrl.h>
- #include <linux/pinctrl/pinmux.h>
- #include <linux/pinctrl/pinconf.h>
- #include <linux/pinctrl/pinconf-generic.h>
- #include <linux/string.h>
- #include <linux/types.h>
- #include "../core.h"
- #include "../pinctrl-utils.h"
- #include "pinctrl-aspeed.h"
- #define ASPEED_G5_NR_PINS 228
- #define COND1 { SCU90, BIT(6), 0, 0 }
- #define COND2 { SCU94, GENMASK(1, 0), 0, 0 }
- #define B14 0
- SSSF_PIN_DECL(B14, GPIOA0, MAC1LINK, SIG_DESC_SET(SCU80, 0));
- #define E13 3
- SSSF_PIN_DECL(E13, GPIOA3, TIMER4, SIG_DESC_SET(SCU80, 3));
- #define I2C9_DESC SIG_DESC_SET(SCU90, 22)
- #define C14 4
- SIG_EXPR_LIST_DECL_SINGLE(SCL9, I2C9, I2C9_DESC, COND1);
- SIG_EXPR_LIST_DECL_SINGLE(TIMER5, TIMER5, SIG_DESC_SET(SCU80, 4), COND1);
- MS_PIN_DECL(C14, GPIOA4, SCL9, TIMER5);
- FUNC_GROUP_DECL(TIMER5, C14);
- #define A13 5
- SIG_EXPR_LIST_DECL_SINGLE(SDA9, I2C9, I2C9_DESC, COND1);
- SIG_EXPR_LIST_DECL_SINGLE(TIMER6, TIMER6, SIG_DESC_SET(SCU80, 5), COND1);
- MS_PIN_DECL(A13, GPIOA5, SDA9, TIMER6);
- FUNC_GROUP_DECL(TIMER6, A13);
- FUNC_GROUP_DECL(I2C9, C14, A13);
- #define MDIO2_DESC SIG_DESC_SET(SCU90, 2)
- #define C13 6
- SIG_EXPR_LIST_DECL_SINGLE(MDC2, MDIO2, MDIO2_DESC, COND1);
- SIG_EXPR_LIST_DECL_SINGLE(TIMER7, TIMER7, SIG_DESC_SET(SCU80, 6), COND1);
- MS_PIN_DECL(C13, GPIOA6, MDC2, TIMER7);
- FUNC_GROUP_DECL(TIMER7, C13);
- #define B13 7
- SIG_EXPR_LIST_DECL_SINGLE(MDIO2, MDIO2, MDIO2_DESC, COND1);
- SIG_EXPR_LIST_DECL_SINGLE(TIMER8, TIMER8, SIG_DESC_SET(SCU80, 7), COND1);
- MS_PIN_DECL(B13, GPIOA7, MDIO2, TIMER8);
- FUNC_GROUP_DECL(TIMER8, B13);
- FUNC_GROUP_DECL(MDIO2, C13, B13);
- #define H20 15
- GPIO_PIN_DECL(H20, GPIOB7);
- #define SD1_DESC SIG_DESC_SET(SCU90, 0)
- #define C12 16
- #define I2C10_DESC SIG_DESC_SET(SCU90, 23)
- SIG_EXPR_LIST_DECL_SINGLE(SD1CLK, SD1, SD1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(SCL10, I2C10, I2C10_DESC);
- MS_PIN_DECL(C12, GPIOC0, SD1CLK, SCL10);
- #define A12 17
- SIG_EXPR_LIST_DECL_SINGLE(SD1CMD, SD1, SD1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(SDA10, I2C10, I2C10_DESC);
- MS_PIN_DECL(A12, GPIOC1, SD1CMD, SDA10);
- FUNC_GROUP_DECL(I2C10, C12, A12);
- #define B12 18
- #define I2C11_DESC SIG_DESC_SET(SCU90, 24)
- SIG_EXPR_LIST_DECL_SINGLE(SD1DAT0, SD1, SD1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(SCL11, I2C11, I2C11_DESC);
- MS_PIN_DECL(B12, GPIOC2, SD1DAT0, SCL11);
- #define D9 19
- SIG_EXPR_LIST_DECL_SINGLE(SD1DAT1, SD1, SD1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(SDA11, I2C11, I2C11_DESC);
- MS_PIN_DECL(D9, GPIOC3, SD1DAT1, SDA11);
- FUNC_GROUP_DECL(I2C11, B12, D9);
- #define D10 20
- #define I2C12_DESC SIG_DESC_SET(SCU90, 25)
- SIG_EXPR_LIST_DECL_SINGLE(SD1DAT2, SD1, SD1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(SCL12, I2C12, I2C12_DESC);
- MS_PIN_DECL(D10, GPIOC4, SD1DAT2, SCL12);
- #define E12 21
- SIG_EXPR_LIST_DECL_SINGLE(SD1DAT3, SD1, SD1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(SDA12, I2C12, I2C12_DESC);
- MS_PIN_DECL(E12, GPIOC5, SD1DAT3, SDA12);
- FUNC_GROUP_DECL(I2C12, D10, E12);
- #define C11 22
- #define I2C13_DESC SIG_DESC_SET(SCU90, 26)
- SIG_EXPR_LIST_DECL_SINGLE(SD1CD, SD1, SD1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(SCL13, I2C13, I2C13_DESC);
- MS_PIN_DECL(C11, GPIOC6, SD1CD, SCL13);
- #define B11 23
- SIG_EXPR_LIST_DECL_SINGLE(SD1WP, SD1, SD1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(SDA13, I2C13, I2C13_DESC);
- MS_PIN_DECL(B11, GPIOC7, SD1WP, SDA13);
- FUNC_GROUP_DECL(I2C13, C11, B11);
- FUNC_GROUP_DECL(SD1, C12, A12, B12, D9, D10, E12, C11, B11);
- #define SD2_DESC SIG_DESC_SET(SCU90, 1)
- #define GPID0_DESC SIG_DESC_SET(SCU8C, 8)
- #define GPID_DESC SIG_DESC_SET(HW_STRAP1, 21)
- #define F19 24
- SIG_EXPR_LIST_DECL_SINGLE(SD2CLK, SD2, SD2_DESC);
- SIG_EXPR_DECL(GPID0IN, GPID0, GPID0_DESC);
- SIG_EXPR_DECL(GPID0IN, GPID, GPID_DESC);
- SIG_EXPR_LIST_DECL_DUAL(GPID0IN, GPID0, GPID);
- MS_PIN_DECL(F19, GPIOD0, SD2CLK, GPID0IN);
- #define E21 25
- SIG_EXPR_LIST_DECL_SINGLE(SD2CMD, SD2, SD2_DESC);
- SIG_EXPR_DECL(GPID0OUT, GPID0, GPID0_DESC);
- SIG_EXPR_DECL(GPID0OUT, GPID, GPID_DESC);
- SIG_EXPR_LIST_DECL_DUAL(GPID0OUT, GPID0, GPID);
- MS_PIN_DECL(E21, GPIOD1, SD2CMD, GPID0OUT);
- FUNC_GROUP_DECL(GPID0, F19, E21);
- #define GPID2_DESC SIG_DESC_SET(SCU8C, 9)
- #define F20 26
- SIG_EXPR_LIST_DECL_SINGLE(SD2DAT0, SD2, SD2_DESC);
- SIG_EXPR_DECL(GPID2IN, GPID2, GPID2_DESC);
- SIG_EXPR_DECL(GPID2IN, GPID, GPID_DESC);
- SIG_EXPR_LIST_DECL_DUAL(GPID2IN, GPID2, GPID);
- MS_PIN_DECL(F20, GPIOD2, SD2DAT0, GPID2IN);
- #define D20 27
- SIG_EXPR_LIST_DECL_SINGLE(SD2DAT1, SD2, SD2_DESC);
- SIG_EXPR_DECL(GPID2OUT, GPID2, GPID2_DESC);
- SIG_EXPR_DECL(GPID2OUT, GPID, GPID_DESC);
- SIG_EXPR_LIST_DECL_DUAL(GPID2OUT, GPID2, GPID);
- MS_PIN_DECL(D20, GPIOD3, SD2DAT1, GPID2OUT);
- FUNC_GROUP_DECL(GPID2, F20, D20);
- #define GPIE_DESC SIG_DESC_SET(HW_STRAP1, 21)
- #define GPIE0_DESC SIG_DESC_SET(SCU8C, 12)
- #define B20 32
- SIG_EXPR_LIST_DECL_SINGLE(NCTS3, NCTS3, SIG_DESC_SET(SCU80, 16));
- SIG_EXPR_DECL(GPIE0IN, GPIE0, GPIE0_DESC);
- SIG_EXPR_DECL(GPIE0IN, GPIE, GPIE_DESC);
- SIG_EXPR_LIST_DECL_DUAL(GPIE0IN, GPIE0, GPIE);
- MS_PIN_DECL(B20, GPIOE0, NCTS3, GPIE0IN);
- #define C20 33
- SIG_EXPR_LIST_DECL_SINGLE(NDCD3, NDCD3, SIG_DESC_SET(SCU80, 17));
- SIG_EXPR_DECL(GPIE0OUT, GPIE0, GPIE0_DESC);
- SIG_EXPR_DECL(GPIE0OUT, GPIE, GPIE_DESC);
- SIG_EXPR_LIST_DECL_DUAL(GPIE0OUT, GPIE0, GPIE);
- MS_PIN_DECL(C20, GPIOE1, NDCD3, GPIE0OUT);
- FUNC_GROUP_DECL(GPIE0, B20, C20);
- #define SPI1_DESC { HW_STRAP1, GENMASK(13, 12), 1, 0 }
- #define SPI1DEBUG_DESC { HW_STRAP1, GENMASK(13, 12), 2, 0 }
- #define SPI1PASSTHRU_DESC { HW_STRAP1, GENMASK(13, 12), 3, 0 }
- #define C18 64
- SIG_EXPR_DECL(SYSCS, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
- SIG_EXPR_DECL(SYSCS, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
- SIG_EXPR_LIST_DECL_DUAL(SYSCS, SPI1DEBUG, SPI1PASSTHRU);
- SS_PIN_DECL(C18, GPIOI0, SYSCS);
- #define E15 65
- SIG_EXPR_DECL(SYSCK, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
- SIG_EXPR_DECL(SYSCK, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
- SIG_EXPR_LIST_DECL_DUAL(SYSCK, SPI1DEBUG, SPI1PASSTHRU);
- SS_PIN_DECL(E15, GPIOI1, SYSCK);
- #define B16 66
- SIG_EXPR_DECL(SYSMOSI, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
- SIG_EXPR_DECL(SYSMOSI, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
- SIG_EXPR_LIST_DECL_DUAL(SYSMOSI, SPI1DEBUG, SPI1PASSTHRU);
- SS_PIN_DECL(B16, GPIOI2, SYSMOSI);
- #define C16 67
- SIG_EXPR_DECL(SYSMISO, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
- SIG_EXPR_DECL(SYSMISO, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
- SIG_EXPR_LIST_DECL_DUAL(SYSMISO, SPI1DEBUG, SPI1PASSTHRU);
- SS_PIN_DECL(C16, GPIOI3, SYSMISO);
- #define VB_DESC SIG_DESC_SET(HW_STRAP1, 5)
- #define B15 68
- SIG_EXPR_DECL(SPI1CS0, SPI1, COND1, SPI1_DESC);
- SIG_EXPR_DECL(SPI1CS0, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
- SIG_EXPR_DECL(SPI1CS0, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
- SIG_EXPR_LIST_DECL(SPI1CS0, SIG_EXPR_PTR(SPI1CS0, SPI1),
- SIG_EXPR_PTR(SPI1CS0, SPI1DEBUG),
- SIG_EXPR_PTR(SPI1CS0, SPI1PASSTHRU));
- SIG_EXPR_LIST_DECL_SINGLE(VBCS, VGABIOSROM, COND1, VB_DESC);
- MS_PIN_DECL(B15, GPIOI4, SPI1CS0, VBCS);
- #define C15 69
- SIG_EXPR_DECL(SPI1CK, SPI1, COND1, SPI1_DESC);
- SIG_EXPR_DECL(SPI1CK, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
- SIG_EXPR_DECL(SPI1CK, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
- SIG_EXPR_LIST_DECL(SPI1CK, SIG_EXPR_PTR(SPI1CK, SPI1),
- SIG_EXPR_PTR(SPI1CK, SPI1DEBUG),
- SIG_EXPR_PTR(SPI1CK, SPI1PASSTHRU));
- SIG_EXPR_LIST_DECL_SINGLE(VBCK, VGABIOSROM, COND1, VB_DESC);
- MS_PIN_DECL(C15, GPIOI5, SPI1CK, VBCK);
- #define A14 70
- SIG_EXPR_DECL(SPI1MOSI, SPI1, COND1, SPI1_DESC);
- SIG_EXPR_DECL(SPI1MOSI, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
- SIG_EXPR_DECL(SPI1MOSI, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
- SIG_EXPR_LIST_DECL(SPI1MOSI, SIG_EXPR_PTR(SPI1MOSI, SPI1),
- SIG_EXPR_PTR(SPI1MOSI, SPI1DEBUG),
- SIG_EXPR_PTR(SPI1MOSI, SPI1PASSTHRU));
- SIG_EXPR_LIST_DECL_SINGLE(VBMOSI, VGABIOSROM, COND1, VB_DESC);
- MS_PIN_DECL(A14, GPIOI6, SPI1MOSI, VBMOSI);
- #define A15 71
- SIG_EXPR_DECL(SPI1MISO, SPI1, COND1, SPI1_DESC);
- SIG_EXPR_DECL(SPI1MISO, SPI1DEBUG, COND1, SPI1DEBUG_DESC);
- SIG_EXPR_DECL(SPI1MISO, SPI1PASSTHRU, COND1, SPI1PASSTHRU_DESC);
- SIG_EXPR_LIST_DECL(SPI1MISO, SIG_EXPR_PTR(SPI1MISO, SPI1),
- SIG_EXPR_PTR(SPI1MISO, SPI1DEBUG),
- SIG_EXPR_PTR(SPI1MISO, SPI1PASSTHRU));
- SIG_EXPR_LIST_DECL_SINGLE(VBMISO, VGABIOSROM, COND1, VB_DESC);
- MS_PIN_DECL(A15, GPIOI7, SPI1MISO, VBMISO);
- FUNC_GROUP_DECL(SPI1, B15, C15, A14, A15);
- FUNC_GROUP_DECL(SPI1DEBUG, C18, E15, B16, C16, B15, C15, A14, A15);
- FUNC_GROUP_DECL(SPI1PASSTHRU, C18, E15, B16, C16, B15, C15, A14, A15);
- FUNC_GROUP_DECL(VGABIOSROM, B15, C15, A14, A15);
- #define R2 72
- SIG_EXPR_LIST_DECL_SINGLE(SGPMCK, SGPM, SIG_DESC_SET(SCU84, 8));
- SS_PIN_DECL(R2, GPIOJ0, SGPMCK);
- #define L2 73
- SIG_EXPR_LIST_DECL_SINGLE(SGPMLD, SGPM, SIG_DESC_SET(SCU84, 9));
- SS_PIN_DECL(L2, GPIOJ1, SGPMLD);
- #define N3 74
- SIG_EXPR_LIST_DECL_SINGLE(SGPMO, SGPM, SIG_DESC_SET(SCU84, 10));
- SS_PIN_DECL(N3, GPIOJ2, SGPMO);
- #define N4 75
- SIG_EXPR_LIST_DECL_SINGLE(SGPMI, SGPM, SIG_DESC_SET(SCU84, 11));
- SS_PIN_DECL(N4, GPIOJ3, SGPMI);
- #define I2C5_DESC SIG_DESC_SET(SCU90, 18)
- #define L3 80
- SIG_EXPR_LIST_DECL_SINGLE(SCL5, I2C5, I2C5_DESC);
- SS_PIN_DECL(L3, GPIOK0, SCL5);
- #define L4 81
- SIG_EXPR_LIST_DECL_SINGLE(SDA5, I2C5, I2C5_DESC);
- SS_PIN_DECL(L4, GPIOK1, SDA5);
- FUNC_GROUP_DECL(I2C5, L3, L4);
- #define I2C6_DESC SIG_DESC_SET(SCU90, 19)
- #define L1 82
- SIG_EXPR_LIST_DECL_SINGLE(SCL6, I2C6, I2C6_DESC);
- SS_PIN_DECL(L1, GPIOK2, SCL6);
- #define N2 83
- SIG_EXPR_LIST_DECL_SINGLE(SDA6, I2C6, I2C6_DESC);
- SS_PIN_DECL(N2, GPIOK3, SDA6);
- FUNC_GROUP_DECL(I2C6, L1, N2);
- #define I2C7_DESC SIG_DESC_SET(SCU90, 20)
- #define N1 84
- SIG_EXPR_LIST_DECL_SINGLE(SCL7, I2C7, I2C7_DESC);
- SS_PIN_DECL(N1, GPIOK4, SCL7);
- #define P1 85
- SIG_EXPR_LIST_DECL_SINGLE(SDA7, I2C7, I2C7_DESC);
- SS_PIN_DECL(P1, GPIOK5, SDA7);
- FUNC_GROUP_DECL(I2C7, N1, P1);
- #define I2C8_DESC SIG_DESC_SET(SCU90, 21)
- #define P2 86
- SIG_EXPR_LIST_DECL_SINGLE(SCL8, I2C8, I2C8_DESC);
- SS_PIN_DECL(P2, GPIOK6, SCL8);
- #define R1 87
- SIG_EXPR_LIST_DECL_SINGLE(SDA8, I2C8, I2C8_DESC);
- SS_PIN_DECL(R1, GPIOK7, SDA8);
- FUNC_GROUP_DECL(I2C8, P2, R1);
- #define VPIOFF0_DESC { SCU90, GENMASK(5, 4), 0, 0 }
- #define VPIOFF1_DESC { SCU90, GENMASK(5, 4), 1, 0 }
- #define VPI24_DESC { SCU90, GENMASK(5, 4), 2, 0 }
- #define VPIRSVD_DESC { SCU90, GENMASK(5, 4), 3, 0 }
- #define V2 104
- #define V2_DESC SIG_DESC_SET(SCU88, 0)
- SIG_EXPR_LIST_DECL_SINGLE(DASHN0, DASHN0, VPIRSVD_DESC, V2_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(PWM0, PWM0, V2_DESC, COND2);
- MS_PIN_DECL(V2, GPION0, DASHN0, PWM0);
- FUNC_GROUP_DECL(PWM0, V2);
- #define W2 105
- #define W2_DESC SIG_DESC_SET(SCU88, 1)
- SIG_EXPR_LIST_DECL_SINGLE(DASHN1, DASHN1, VPIRSVD_DESC, W2_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(PWM1, PWM1, W2_DESC, COND2);
- MS_PIN_DECL(W2, GPION1, DASHN1, PWM1);
- FUNC_GROUP_DECL(PWM1, W2);
- #define V3 106
- #define V3_DESC SIG_DESC_SET(SCU88, 2)
- SIG_EXPR_DECL(VPIG2, VPI24, VPI24_DESC, V3_DESC, COND2);
- SIG_EXPR_DECL(VPIG2, VPIRSVD, VPIRSVD_DESC, V3_DESC, COND2);
- SIG_EXPR_LIST_DECL_DUAL(VPIG2, VPI24, VPIRSVD);
- SIG_EXPR_LIST_DECL_SINGLE(PWM2, PWM2, V3_DESC, COND2);
- MS_PIN_DECL(V3, GPION2, VPIG2, PWM2);
- FUNC_GROUP_DECL(PWM2, V3);
- #define U3 107
- #define U3_DESC SIG_DESC_SET(SCU88, 3)
- SIG_EXPR_DECL(VPIG3, VPI24, VPI24_DESC, U3_DESC, COND2);
- SIG_EXPR_DECL(VPIG3, VPIRSVD, VPIRSVD_DESC, U3_DESC, COND2);
- SIG_EXPR_LIST_DECL_DUAL(VPIG3, VPI24, VPIRSVD);
- SIG_EXPR_LIST_DECL_SINGLE(PWM3, PWM3, U3_DESC, COND2);
- MS_PIN_DECL(U3, GPION3, VPIG3, PWM3);
- FUNC_GROUP_DECL(PWM3, U3);
- #define W3 108
- #define W3_DESC SIG_DESC_SET(SCU88, 4)
- SIG_EXPR_DECL(VPIG4, VPI24, VPI24_DESC, W3_DESC, COND2);
- SIG_EXPR_DECL(VPIG4, VPIRSVD, VPIRSVD_DESC, W3_DESC, COND2);
- SIG_EXPR_LIST_DECL_DUAL(VPIG4, VPI24, VPIRSVD);
- SIG_EXPR_LIST_DECL_SINGLE(PWM4, PWM4, W3_DESC, COND2);
- MS_PIN_DECL(W3, GPION4, VPIG4, PWM4);
- FUNC_GROUP_DECL(PWM4, W3);
- #define AA3 109
- #define AA3_DESC SIG_DESC_SET(SCU88, 5)
- SIG_EXPR_DECL(VPIG5, VPI24, VPI24_DESC, AA3_DESC, COND2);
- SIG_EXPR_DECL(VPIG5, VPIRSVD, VPIRSVD_DESC, AA3_DESC, COND2);
- SIG_EXPR_LIST_DECL_DUAL(VPIG5, VPI24, VPIRSVD);
- SIG_EXPR_LIST_DECL_SINGLE(PWM5, PWM5, AA3_DESC, COND2);
- MS_PIN_DECL(AA3, GPION5, VPIG5, PWM5);
- FUNC_GROUP_DECL(PWM5, AA3);
- #define Y3 110
- #define Y3_DESC SIG_DESC_SET(SCU88, 6)
- SIG_EXPR_LIST_DECL_SINGLE(VPIG6, VPI24, VPI24_DESC, Y3_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(PWM6, PWM6, Y3_DESC, COND2);
- MS_PIN_DECL(Y3, GPION6, VPIG6, PWM6);
- FUNC_GROUP_DECL(PWM6, Y3);
- #define T4 111
- #define T4_DESC SIG_DESC_SET(SCU88, 7)
- SIG_EXPR_LIST_DECL_SINGLE(VPIG7, VPI24, VPI24_DESC, T4_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(PWM7, PWM7, T4_DESC, COND2);
- MS_PIN_DECL(T4, GPION7, VPIG7, PWM7);
- FUNC_GROUP_DECL(PWM7, T4);
- #define V6 127
- SIG_EXPR_LIST_DECL_SINGLE(DASHV6, DASHV6, SIG_DESC_SET(SCU90, 28),
- SIG_DESC_SET(SCU88, 23));
- SS_PIN_DECL(V6, GPIOP7, DASHV6);
- #define I2C3_DESC SIG_DESC_SET(SCU90, 16)
- #define A11 128
- SIG_EXPR_LIST_DECL_SINGLE(SCL3, I2C3, I2C3_DESC);
- SS_PIN_DECL(A11, GPIOQ0, SCL3);
- #define A10 129
- SIG_EXPR_LIST_DECL_SINGLE(SDA3, I2C3, I2C3_DESC);
- SS_PIN_DECL(A10, GPIOQ1, SDA3);
- FUNC_GROUP_DECL(I2C3, A11, A10);
- #define I2C4_DESC SIG_DESC_SET(SCU90, 17)
- #define A9 130
- SIG_EXPR_LIST_DECL_SINGLE(SCL4, I2C4, I2C4_DESC);
- SS_PIN_DECL(A9, GPIOQ2, SCL4);
- #define B9 131
- SIG_EXPR_LIST_DECL_SINGLE(SDA4, I2C4, I2C4_DESC);
- SS_PIN_DECL(B9, GPIOQ3, SDA4);
- FUNC_GROUP_DECL(I2C4, A9, B9);
- #define I2C14_DESC SIG_DESC_SET(SCU90, 27)
- #define N21 132
- SIG_EXPR_LIST_DECL_SINGLE(SCL14, I2C14, I2C14_DESC);
- SS_PIN_DECL(N21, GPIOQ4, SCL14);
- #define N22 133
- SIG_EXPR_LIST_DECL_SINGLE(SDA14, I2C14, I2C14_DESC);
- SS_PIN_DECL(N22, GPIOQ5, SDA14);
- FUNC_GROUP_DECL(I2C14, N21, N22);
- #define B10 134
- SSSF_PIN_DECL(B10, GPIOQ6, OSCCLK, SIG_DESC_SET(SCU2C, 1));
- #define N20 135
- SSSF_PIN_DECL(N20, GPIOQ7, PEWAKE, SIG_DESC_SET(SCU2C, 29));
- #define D8 142
- SIG_EXPR_LIST_DECL_SINGLE(MDC1, MDIO1, SIG_DESC_SET(SCU88, 30));
- SS_PIN_DECL(D8, GPIOR6, MDC1);
- #define E10 143
- SIG_EXPR_LIST_DECL_SINGLE(MDIO1, MDIO1, SIG_DESC_SET(SCU88, 31));
- SS_PIN_DECL(E10, GPIOR7, MDIO1);
- FUNC_GROUP_DECL(MDIO1, D8, E10);
- /* RGMII1/RMII1 */
- #define RMII1_DESC SIG_DESC_BIT(HW_STRAP1, 6, 0)
- #define RMII2_DESC SIG_DESC_BIT(HW_STRAP1, 7, 0)
- #define B5 152
- SIG_EXPR_LIST_DECL_SINGLE(GPIOT0, GPIOT0, SIG_DESC_SET(SCUA0, 0));
- SIG_EXPR_LIST_DECL_SINGLE(RMII1RCLKO, RMII1, RMII1_DESC,
- SIG_DESC_SET(SCU48, 29));
- SIG_EXPR_LIST_DECL_SINGLE(RGMII1TXCK, RGMII1);
- MS_PIN_DECL_(B5, SIG_EXPR_LIST_PTR(GPIOT0), SIG_EXPR_LIST_PTR(RMII1RCLKO),
- SIG_EXPR_LIST_PTR(RGMII1TXCK));
- #define E9 153
- SIG_EXPR_LIST_DECL_SINGLE(GPIOT1, GPIOT1, SIG_DESC_SET(SCUA0, 1));
- SIG_EXPR_LIST_DECL_SINGLE(RMII1TXEN, RMII1, RMII1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII1TXCTL, RGMII1);
- MS_PIN_DECL_(E9, SIG_EXPR_LIST_PTR(GPIOT1), SIG_EXPR_LIST_PTR(RMII1TXEN),
- SIG_EXPR_LIST_PTR(RGMII1TXCTL));
- #define F9 154
- SIG_EXPR_LIST_DECL_SINGLE(GPIOT2, GPIOT2, SIG_DESC_SET(SCUA0, 2));
- SIG_EXPR_LIST_DECL_SINGLE(RMII1TXD0, RMII1, RMII1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII1TXD0, RGMII1);
- MS_PIN_DECL_(F9, SIG_EXPR_LIST_PTR(GPIOT2), SIG_EXPR_LIST_PTR(RMII1TXD0),
- SIG_EXPR_LIST_PTR(RGMII1TXD0));
- #define A5 155
- SIG_EXPR_LIST_DECL_SINGLE(GPIOT3, GPIOT3, SIG_DESC_SET(SCUA0, 3));
- SIG_EXPR_LIST_DECL_SINGLE(RMII1TXD1, RMII1, RMII1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII1TXD1, RGMII1);
- MS_PIN_DECL_(A5, SIG_EXPR_LIST_PTR(GPIOT3), SIG_EXPR_LIST_PTR(RMII1TXD1),
- SIG_EXPR_LIST_PTR(RGMII1TXD1));
- #define E7 156
- SIG_EXPR_LIST_DECL_SINGLE(GPIOT4, GPIOT4, SIG_DESC_SET(SCUA0, 4));
- SIG_EXPR_LIST_DECL_SINGLE(RMII1DASH0, RMII1, RMII1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII1TXD2, RGMII1);
- MS_PIN_DECL_(E7, SIG_EXPR_LIST_PTR(GPIOT4), SIG_EXPR_LIST_PTR(RMII1DASH0),
- SIG_EXPR_LIST_PTR(RGMII1TXD2));
- #define D7 157
- SIG_EXPR_LIST_DECL_SINGLE(GPIOT5, GPIOT5, SIG_DESC_SET(SCUA0, 5));
- SIG_EXPR_LIST_DECL_SINGLE(RMII1DASH1, RMII1, RMII1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII1TXD3, RGMII1);
- MS_PIN_DECL_(D7, SIG_EXPR_LIST_PTR(GPIOT5), SIG_EXPR_LIST_PTR(RMII1DASH1),
- SIG_EXPR_LIST_PTR(RGMII1TXD3));
- #define B2 158
- SIG_EXPR_LIST_DECL_SINGLE(GPIOT6, GPIOT6, SIG_DESC_SET(SCUA0, 6));
- SIG_EXPR_LIST_DECL_SINGLE(RMII2RCLKO, RMII2, RMII2_DESC,
- SIG_DESC_SET(SCU48, 30));
- SIG_EXPR_LIST_DECL_SINGLE(RGMII2TXCK, RGMII2);
- MS_PIN_DECL_(B2, SIG_EXPR_LIST_PTR(GPIOT6), SIG_EXPR_LIST_PTR(RMII2RCLKO),
- SIG_EXPR_LIST_PTR(RGMII2TXCK));
- #define B1 159
- SIG_EXPR_LIST_DECL_SINGLE(GPIOT7, GPIOT7, SIG_DESC_SET(SCUA0, 7));
- SIG_EXPR_LIST_DECL_SINGLE(RMII2TXEN, RMII2, RMII2_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII2TXCTL, RGMII2);
- MS_PIN_DECL_(B1, SIG_EXPR_LIST_PTR(GPIOT7), SIG_EXPR_LIST_PTR(RMII2TXEN),
- SIG_EXPR_LIST_PTR(RGMII2TXCTL));
- #define A2 160
- SIG_EXPR_LIST_DECL_SINGLE(GPIOU0, GPIOU0, SIG_DESC_SET(SCUA0, 8));
- SIG_EXPR_LIST_DECL_SINGLE(RMII2TXD0, RMII2, RMII2_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII2TXD0, RGMII2);
- MS_PIN_DECL_(A2, SIG_EXPR_LIST_PTR(GPIOU0), SIG_EXPR_LIST_PTR(RMII2TXD0),
- SIG_EXPR_LIST_PTR(RGMII2TXD0));
- #define B3 161
- SIG_EXPR_LIST_DECL_SINGLE(GPIOU1, GPIOU1, SIG_DESC_SET(SCUA0, 9));
- SIG_EXPR_LIST_DECL_SINGLE(RMII2TXD1, RMII2, RMII2_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII2TXD1, RGMII2);
- MS_PIN_DECL_(B3, SIG_EXPR_LIST_PTR(GPIOU1), SIG_EXPR_LIST_PTR(RMII2TXD1),
- SIG_EXPR_LIST_PTR(RGMII2TXD1));
- #define D5 162
- SIG_EXPR_LIST_DECL_SINGLE(GPIOU2, GPIOU2, SIG_DESC_SET(SCUA0, 10));
- SIG_EXPR_LIST_DECL_SINGLE(RMII2DASH0, RMII2, RMII2_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII2TXD2, RGMII2);
- MS_PIN_DECL_(D5, SIG_EXPR_LIST_PTR(GPIOU2), SIG_EXPR_LIST_PTR(RMII2DASH0),
- SIG_EXPR_LIST_PTR(RGMII2TXD2));
- #define D4 163
- SIG_EXPR_LIST_DECL_SINGLE(GPIOU3, GPIOU3, SIG_DESC_SET(SCUA0, 11));
- SIG_EXPR_LIST_DECL_SINGLE(RMII2DASH1, RMII2, RMII2_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII2TXD3, RGMII2);
- MS_PIN_DECL_(D4, SIG_EXPR_LIST_PTR(GPIOU3), SIG_EXPR_LIST_PTR(RMII2DASH1),
- SIG_EXPR_LIST_PTR(RGMII2TXD3));
- #define B4 164
- SIG_EXPR_LIST_DECL_SINGLE(GPIOU4, GPIOU4, SIG_DESC_SET(SCUA0, 12));
- SIG_EXPR_LIST_DECL_SINGLE(RMII1RCLKI, RMII1, RMII1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII1RXCK, RGMII1);
- MS_PIN_DECL_(B4, SIG_EXPR_LIST_PTR(GPIOU4), SIG_EXPR_LIST_PTR(RMII1RCLKI),
- SIG_EXPR_LIST_PTR(RGMII1RXCK));
- #define A4 165
- SIG_EXPR_LIST_DECL_SINGLE(GPIOU5, GPIOU5, SIG_DESC_SET(SCUA0, 13));
- SIG_EXPR_LIST_DECL_SINGLE(RMII1DASH2, RMII1, RMII1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII1RXCTL, RGMII1);
- MS_PIN_DECL_(A4, SIG_EXPR_LIST_PTR(GPIOU5), SIG_EXPR_LIST_PTR(RMII1DASH2),
- SIG_EXPR_LIST_PTR(RGMII1RXCTL));
- #define A3 166
- SIG_EXPR_LIST_DECL_SINGLE(GPIOU6, GPIOU6, SIG_DESC_SET(SCUA0, 14));
- SIG_EXPR_LIST_DECL_SINGLE(RMII1RXD0, RMII1, RMII1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII1RXD0, RGMII1);
- MS_PIN_DECL_(A3, SIG_EXPR_LIST_PTR(GPIOU6), SIG_EXPR_LIST_PTR(RMII1RXD0),
- SIG_EXPR_LIST_PTR(RGMII1RXD0));
- #define D6 167
- SIG_EXPR_LIST_DECL_SINGLE(GPIOU7, GPIOU7, SIG_DESC_SET(SCUA0, 15));
- SIG_EXPR_LIST_DECL_SINGLE(RMII1RXD1, RMII1, RMII1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII1RXD1, RGMII1);
- MS_PIN_DECL_(D6, SIG_EXPR_LIST_PTR(GPIOU7), SIG_EXPR_LIST_PTR(RMII1RXD1),
- SIG_EXPR_LIST_PTR(RGMII1RXD1));
- #define C5 168
- SIG_EXPR_LIST_DECL_SINGLE(GPIOV0, GPIOV0, SIG_DESC_SET(SCUA0, 16));
- SIG_EXPR_LIST_DECL_SINGLE(RMII1CRSDV, RMII1, RMII1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII1RXD2, RGMII1);
- MS_PIN_DECL_(C5, SIG_EXPR_LIST_PTR(GPIOV0), SIG_EXPR_LIST_PTR(RMII1CRSDV),
- SIG_EXPR_LIST_PTR(RGMII1RXD2));
- #define C4 169
- SIG_EXPR_LIST_DECL_SINGLE(GPIOV1, GPIOV1, SIG_DESC_SET(SCUA0, 17));
- SIG_EXPR_LIST_DECL_SINGLE(RMII1RXER, RMII1, RMII1_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII1RXD3, RGMII1);
- MS_PIN_DECL_(C4, SIG_EXPR_LIST_PTR(GPIOV1), SIG_EXPR_LIST_PTR(RMII1RXER),
- SIG_EXPR_LIST_PTR(RGMII1RXD3));
- FUNC_GROUP_DECL(RGMII1, B4, A4, A3, D6, C5, C4, B5, E9, F9, A5, E7, D7);
- FUNC_GROUP_DECL(RMII1, B4, A3, D6, C5, C4, B5, E9, F9, A5);
- #define C2 170
- SIG_EXPR_LIST_DECL_SINGLE(GPIOV2, GPIOV2, SIG_DESC_SET(SCUA0, 18));
- SIG_EXPR_LIST_DECL_SINGLE(RMII2RCLKI, RMII2, RMII2_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII2RXCK, RGMII2);
- MS_PIN_DECL_(C2, SIG_EXPR_LIST_PTR(GPIOV2), SIG_EXPR_LIST_PTR(RMII2RCLKI),
- SIG_EXPR_LIST_PTR(RGMII2RXCK));
- #define C1 171
- SIG_EXPR_LIST_DECL_SINGLE(GPIOV3, GPIOV3, SIG_DESC_SET(SCUA0, 19));
- SIG_EXPR_LIST_DECL_SINGLE(RMII2DASH2, RMII2, RMII2_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII2RXCTL, RGMII2);
- MS_PIN_DECL_(C1, SIG_EXPR_LIST_PTR(GPIOV3), SIG_EXPR_LIST_PTR(RMII2DASH2),
- SIG_EXPR_LIST_PTR(RGMII2RXCTL));
- #define C3 172
- SIG_EXPR_LIST_DECL_SINGLE(GPIOV4, GPIOV4, SIG_DESC_SET(SCUA0, 20));
- SIG_EXPR_LIST_DECL_SINGLE(RMII2RXD0, RMII2, RMII2_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII2RXD0, RGMII2);
- MS_PIN_DECL_(C3, SIG_EXPR_LIST_PTR(GPIOV4), SIG_EXPR_LIST_PTR(RMII2RXD0),
- SIG_EXPR_LIST_PTR(RGMII2RXD0));
- #define D1 173
- SIG_EXPR_LIST_DECL_SINGLE(GPIOV5, GPIOV5, SIG_DESC_SET(SCUA0, 21));
- SIG_EXPR_LIST_DECL_SINGLE(RMII2RXD1, RMII2, RMII2_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII2RXD1, RGMII2);
- MS_PIN_DECL_(D1, SIG_EXPR_LIST_PTR(GPIOV5), SIG_EXPR_LIST_PTR(RMII2RXD1),
- SIG_EXPR_LIST_PTR(RGMII2RXD1));
- #define D2 174
- SIG_EXPR_LIST_DECL_SINGLE(GPIOV6, GPIOV6, SIG_DESC_SET(SCUA0, 22));
- SIG_EXPR_LIST_DECL_SINGLE(RMII2CRSDV, RMII2, RMII2_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII2RXD2, RGMII2);
- MS_PIN_DECL_(D2, SIG_EXPR_LIST_PTR(GPIOV6), SIG_EXPR_LIST_PTR(RMII2CRSDV),
- SIG_EXPR_LIST_PTR(RGMII2RXD2));
- #define E6 175
- SIG_EXPR_LIST_DECL_SINGLE(GPIOV7, GPIOV7, SIG_DESC_SET(SCUA0, 23));
- SIG_EXPR_LIST_DECL_SINGLE(RMII2RXER, RMII2, RMII2_DESC);
- SIG_EXPR_LIST_DECL_SINGLE(RGMII2RXD3, RGMII2);
- MS_PIN_DECL_(E6, SIG_EXPR_LIST_PTR(GPIOV7), SIG_EXPR_LIST_PTR(RMII2RXER),
- SIG_EXPR_LIST_PTR(RGMII2RXD3));
- FUNC_GROUP_DECL(RGMII2, B2, B1, A2, B3, D5, D4, C2, C1, C3, D1, D2, E6);
- FUNC_GROUP_DECL(RMII2, B2, B1, A2, B3, C2, C3, D1, D2, E6);
- /* Pins, groups and functions are sort(1):ed alphabetically for sanity */
- static struct pinctrl_pin_desc aspeed_g5_pins[ASPEED_G5_NR_PINS] = {
- ASPEED_PINCTRL_PIN(A10),
- ASPEED_PINCTRL_PIN(A11),
- ASPEED_PINCTRL_PIN(A12),
- ASPEED_PINCTRL_PIN(A13),
- ASPEED_PINCTRL_PIN(A14),
- ASPEED_PINCTRL_PIN(A15),
- ASPEED_PINCTRL_PIN(A2),
- ASPEED_PINCTRL_PIN(A3),
- ASPEED_PINCTRL_PIN(A4),
- ASPEED_PINCTRL_PIN(A5),
- ASPEED_PINCTRL_PIN(A9),
- ASPEED_PINCTRL_PIN(AA3),
- ASPEED_PINCTRL_PIN(B1),
- ASPEED_PINCTRL_PIN(B10),
- ASPEED_PINCTRL_PIN(B11),
- ASPEED_PINCTRL_PIN(B12),
- ASPEED_PINCTRL_PIN(B13),
- ASPEED_PINCTRL_PIN(B14),
- ASPEED_PINCTRL_PIN(B15),
- ASPEED_PINCTRL_PIN(B16),
- ASPEED_PINCTRL_PIN(B2),
- ASPEED_PINCTRL_PIN(B20),
- ASPEED_PINCTRL_PIN(B3),
- ASPEED_PINCTRL_PIN(B4),
- ASPEED_PINCTRL_PIN(B5),
- ASPEED_PINCTRL_PIN(B9),
- ASPEED_PINCTRL_PIN(C1),
- ASPEED_PINCTRL_PIN(C11),
- ASPEED_PINCTRL_PIN(C12),
- ASPEED_PINCTRL_PIN(C13),
- ASPEED_PINCTRL_PIN(C14),
- ASPEED_PINCTRL_PIN(C15),
- ASPEED_PINCTRL_PIN(C16),
- ASPEED_PINCTRL_PIN(C18),
- ASPEED_PINCTRL_PIN(C2),
- ASPEED_PINCTRL_PIN(C20),
- ASPEED_PINCTRL_PIN(C3),
- ASPEED_PINCTRL_PIN(C4),
- ASPEED_PINCTRL_PIN(C5),
- ASPEED_PINCTRL_PIN(D1),
- ASPEED_PINCTRL_PIN(D10),
- ASPEED_PINCTRL_PIN(D2),
- ASPEED_PINCTRL_PIN(D20),
- ASPEED_PINCTRL_PIN(D4),
- ASPEED_PINCTRL_PIN(D5),
- ASPEED_PINCTRL_PIN(D6),
- ASPEED_PINCTRL_PIN(D7),
- ASPEED_PINCTRL_PIN(D8),
- ASPEED_PINCTRL_PIN(D9),
- ASPEED_PINCTRL_PIN(E10),
- ASPEED_PINCTRL_PIN(E12),
- ASPEED_PINCTRL_PIN(E13),
- ASPEED_PINCTRL_PIN(E15),
- ASPEED_PINCTRL_PIN(E21),
- ASPEED_PINCTRL_PIN(E6),
- ASPEED_PINCTRL_PIN(E7),
- ASPEED_PINCTRL_PIN(E9),
- ASPEED_PINCTRL_PIN(F19),
- ASPEED_PINCTRL_PIN(F20),
- ASPEED_PINCTRL_PIN(F9),
- ASPEED_PINCTRL_PIN(H20),
- ASPEED_PINCTRL_PIN(L1),
- ASPEED_PINCTRL_PIN(L2),
- ASPEED_PINCTRL_PIN(L3),
- ASPEED_PINCTRL_PIN(L4),
- ASPEED_PINCTRL_PIN(N1),
- ASPEED_PINCTRL_PIN(N2),
- ASPEED_PINCTRL_PIN(N20),
- ASPEED_PINCTRL_PIN(N21),
- ASPEED_PINCTRL_PIN(N22),
- ASPEED_PINCTRL_PIN(N3),
- ASPEED_PINCTRL_PIN(N4),
- ASPEED_PINCTRL_PIN(P1),
- ASPEED_PINCTRL_PIN(P2),
- ASPEED_PINCTRL_PIN(R1),
- ASPEED_PINCTRL_PIN(T4),
- ASPEED_PINCTRL_PIN(U3),
- ASPEED_PINCTRL_PIN(V2),
- ASPEED_PINCTRL_PIN(V3),
- ASPEED_PINCTRL_PIN(V6),
- ASPEED_PINCTRL_PIN(W2),
- ASPEED_PINCTRL_PIN(W3),
- ASPEED_PINCTRL_PIN(Y3),
- };
- static const struct aspeed_pin_group aspeed_g5_groups[] = {
- ASPEED_PINCTRL_GROUP(GPID0),
- ASPEED_PINCTRL_GROUP(GPID2),
- ASPEED_PINCTRL_GROUP(GPIE0),
- ASPEED_PINCTRL_GROUP(I2C10),
- ASPEED_PINCTRL_GROUP(I2C11),
- ASPEED_PINCTRL_GROUP(I2C12),
- ASPEED_PINCTRL_GROUP(I2C13),
- ASPEED_PINCTRL_GROUP(I2C14),
- ASPEED_PINCTRL_GROUP(I2C3),
- ASPEED_PINCTRL_GROUP(I2C4),
- ASPEED_PINCTRL_GROUP(I2C5),
- ASPEED_PINCTRL_GROUP(I2C6),
- ASPEED_PINCTRL_GROUP(I2C7),
- ASPEED_PINCTRL_GROUP(I2C8),
- ASPEED_PINCTRL_GROUP(I2C9),
- ASPEED_PINCTRL_GROUP(MAC1LINK),
- ASPEED_PINCTRL_GROUP(MDIO1),
- ASPEED_PINCTRL_GROUP(MDIO2),
- ASPEED_PINCTRL_GROUP(OSCCLK),
- ASPEED_PINCTRL_GROUP(PEWAKE),
- ASPEED_PINCTRL_GROUP(PWM0),
- ASPEED_PINCTRL_GROUP(PWM1),
- ASPEED_PINCTRL_GROUP(PWM2),
- ASPEED_PINCTRL_GROUP(PWM3),
- ASPEED_PINCTRL_GROUP(PWM4),
- ASPEED_PINCTRL_GROUP(PWM5),
- ASPEED_PINCTRL_GROUP(PWM6),
- ASPEED_PINCTRL_GROUP(PWM7),
- ASPEED_PINCTRL_GROUP(RGMII1),
- ASPEED_PINCTRL_GROUP(RGMII2),
- ASPEED_PINCTRL_GROUP(RMII1),
- ASPEED_PINCTRL_GROUP(RMII2),
- ASPEED_PINCTRL_GROUP(SD1),
- ASPEED_PINCTRL_GROUP(SPI1),
- ASPEED_PINCTRL_GROUP(SPI1DEBUG),
- ASPEED_PINCTRL_GROUP(SPI1PASSTHRU),
- ASPEED_PINCTRL_GROUP(TIMER4),
- ASPEED_PINCTRL_GROUP(TIMER5),
- ASPEED_PINCTRL_GROUP(TIMER6),
- ASPEED_PINCTRL_GROUP(TIMER7),
- ASPEED_PINCTRL_GROUP(TIMER8),
- ASPEED_PINCTRL_GROUP(VGABIOSROM),
- };
- static const struct aspeed_pin_function aspeed_g5_functions[] = {
- ASPEED_PINCTRL_FUNC(GPID0),
- ASPEED_PINCTRL_FUNC(GPID2),
- ASPEED_PINCTRL_FUNC(GPIE0),
- ASPEED_PINCTRL_FUNC(I2C10),
- ASPEED_PINCTRL_FUNC(I2C11),
- ASPEED_PINCTRL_FUNC(I2C12),
- ASPEED_PINCTRL_FUNC(I2C13),
- ASPEED_PINCTRL_FUNC(I2C14),
- ASPEED_PINCTRL_FUNC(I2C3),
- ASPEED_PINCTRL_FUNC(I2C4),
- ASPEED_PINCTRL_FUNC(I2C5),
- ASPEED_PINCTRL_FUNC(I2C6),
- ASPEED_PINCTRL_FUNC(I2C7),
- ASPEED_PINCTRL_FUNC(I2C8),
- ASPEED_PINCTRL_FUNC(I2C9),
- ASPEED_PINCTRL_FUNC(MAC1LINK),
- ASPEED_PINCTRL_FUNC(MDIO1),
- ASPEED_PINCTRL_FUNC(MDIO2),
- ASPEED_PINCTRL_FUNC(OSCCLK),
- ASPEED_PINCTRL_FUNC(PEWAKE),
- ASPEED_PINCTRL_FUNC(PWM0),
- ASPEED_PINCTRL_FUNC(PWM1),
- ASPEED_PINCTRL_FUNC(PWM2),
- ASPEED_PINCTRL_FUNC(PWM3),
- ASPEED_PINCTRL_FUNC(PWM4),
- ASPEED_PINCTRL_FUNC(PWM5),
- ASPEED_PINCTRL_FUNC(PWM6),
- ASPEED_PINCTRL_FUNC(PWM7),
- ASPEED_PINCTRL_FUNC(RGMII1),
- ASPEED_PINCTRL_FUNC(RGMII2),
- ASPEED_PINCTRL_FUNC(RMII1),
- ASPEED_PINCTRL_FUNC(RMII2),
- ASPEED_PINCTRL_FUNC(SD1),
- ASPEED_PINCTRL_FUNC(SPI1),
- ASPEED_PINCTRL_FUNC(SPI1DEBUG),
- ASPEED_PINCTRL_FUNC(SPI1PASSTHRU),
- ASPEED_PINCTRL_FUNC(TIMER4),
- ASPEED_PINCTRL_FUNC(TIMER5),
- ASPEED_PINCTRL_FUNC(TIMER6),
- ASPEED_PINCTRL_FUNC(TIMER7),
- ASPEED_PINCTRL_FUNC(TIMER8),
- ASPEED_PINCTRL_FUNC(VGABIOSROM),
- };
- static struct aspeed_pinctrl_data aspeed_g5_pinctrl_data = {
- .pins = aspeed_g5_pins,
- .npins = ARRAY_SIZE(aspeed_g5_pins),
- .groups = aspeed_g5_groups,
- .ngroups = ARRAY_SIZE(aspeed_g5_groups),
- .functions = aspeed_g5_functions,
- .nfunctions = ARRAY_SIZE(aspeed_g5_functions),
- };
- static struct pinmux_ops aspeed_g5_pinmux_ops = {
- .get_functions_count = aspeed_pinmux_get_fn_count,
- .get_function_name = aspeed_pinmux_get_fn_name,
- .get_function_groups = aspeed_pinmux_get_fn_groups,
- .set_mux = aspeed_pinmux_set_mux,
- .gpio_request_enable = aspeed_gpio_request_enable,
- .strict = true,
- };
- static struct pinctrl_ops aspeed_g5_pinctrl_ops = {
- .get_groups_count = aspeed_pinctrl_get_groups_count,
- .get_group_name = aspeed_pinctrl_get_group_name,
- .get_group_pins = aspeed_pinctrl_get_group_pins,
- .pin_dbg_show = aspeed_pinctrl_pin_dbg_show,
- .dt_node_to_map = pinconf_generic_dt_node_to_map_pin,
- .dt_free_map = pinctrl_utils_free_map,
- };
- static struct pinctrl_desc aspeed_g5_pinctrl_desc = {
- .name = "aspeed-g5-pinctrl",
- .pins = aspeed_g5_pins,
- .npins = ARRAY_SIZE(aspeed_g5_pins),
- .pctlops = &aspeed_g5_pinctrl_ops,
- .pmxops = &aspeed_g5_pinmux_ops,
- };
- static int aspeed_g5_pinctrl_probe(struct platform_device *pdev)
- {
- int i;
- for (i = 0; i < ARRAY_SIZE(aspeed_g5_pins); i++)
- aspeed_g5_pins[i].number = i;
- return aspeed_pinctrl_probe(pdev, &aspeed_g5_pinctrl_desc,
- &aspeed_g5_pinctrl_data);
- }
- static const struct of_device_id aspeed_g5_pinctrl_of_match[] = {
- { .compatible = "aspeed,ast2500-pinctrl", },
- { .compatible = "aspeed,g5-pinctrl", },
- { },
- };
- static struct platform_driver aspeed_g5_pinctrl_driver = {
- .probe = aspeed_g5_pinctrl_probe,
- .driver = {
- .name = "aspeed-g5-pinctrl",
- .of_match_table = aspeed_g5_pinctrl_of_match,
- },
- };
- static int aspeed_g5_pinctrl_init(void)
- {
- return platform_driver_register(&aspeed_g5_pinctrl_driver);
- }
- arch_initcall(aspeed_g5_pinctrl_init);
|