18a0fd1a7SJared McNeill /*- 28a0fd1a7SJared McNeill * Copyright (c) 2016 Jared McNeill <jmcneill@invisible.ca> 38a0fd1a7SJared McNeill * 48a0fd1a7SJared McNeill * Redistribution and use in source and binary forms, with or without 58a0fd1a7SJared McNeill * modification, are permitted provided that the following conditions 68a0fd1a7SJared McNeill * are met: 78a0fd1a7SJared McNeill * 1. Redistributions of source code must retain the above copyright 88a0fd1a7SJared McNeill * notice, this list of conditions and the following disclaimer. 98a0fd1a7SJared McNeill * 2. Redistributions in binary form must reproduce the above copyright 108a0fd1a7SJared McNeill * notice, this list of conditions and the following disclaimer in the 118a0fd1a7SJared McNeill * documentation and/or other materials provided with the distribution. 128a0fd1a7SJared McNeill * 138a0fd1a7SJared McNeill * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 148a0fd1a7SJared McNeill * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 158a0fd1a7SJared McNeill * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 168a0fd1a7SJared McNeill * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 178a0fd1a7SJared McNeill * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 188a0fd1a7SJared McNeill * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 198a0fd1a7SJared McNeill * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 208a0fd1a7SJared McNeill * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 218a0fd1a7SJared McNeill * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 228a0fd1a7SJared McNeill * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 238a0fd1a7SJared McNeill * SUCH DAMAGE. 248a0fd1a7SJared McNeill */ 258a0fd1a7SJared McNeill 268a0fd1a7SJared McNeill #include <sys/param.h> 278a0fd1a7SJared McNeill #include <sys/systm.h> 288a0fd1a7SJared McNeill #include <sys/kernel.h> 298a0fd1a7SJared McNeill #include <sys/types.h> 308a0fd1a7SJared McNeill 318a0fd1a7SJared McNeill #include <arm/allwinner/allwinner_pinctrl.h> 328a0fd1a7SJared McNeill 338a0fd1a7SJared McNeill #ifdef SOC_ALLWINNER_A83T 348a0fd1a7SJared McNeill 358a0fd1a7SJared McNeill static const struct allwinner_pins a83t_pins[] = { 36*d07cc22bSEmmanuel Vadot { "PB0", 1, 0, { "gpio_in", "gpio_out", "uart2", "jtag", NULL, NULL, "pb_eint0" }, 6, 0, 0}, 37*d07cc22bSEmmanuel Vadot { "PB1", 1, 1, { "gpio_in", "gpio_out", "uart2", "jtag", NULL, NULL, "pb_eint1" }, 6, 1, 0}, 38*d07cc22bSEmmanuel Vadot { "PB2", 1, 2, { "gpio_in", "gpio_out", "uart2", "jtag", NULL, NULL, "pb_eint2" }, 6, 2, 0}, 39*d07cc22bSEmmanuel Vadot { "PB3", 1, 3, { "gpio_in", "gpio_out", "uart2", "jtag", NULL, NULL, "pb_eint3" }, 6, 3, 0}, 40*d07cc22bSEmmanuel Vadot { "PB4", 1, 4, { "gpio_in", "gpio_out", "i2s0", "tdm", NULL, NULL, "pb_eint4" }, 6, 4, 0}, 41*d07cc22bSEmmanuel Vadot { "PB5", 1, 5, { "gpio_in", "gpio_out", "i2s0", "tdm", NULL, NULL, "pb_eint5" }, 6, 5, 0}, 42*d07cc22bSEmmanuel Vadot { "PB6", 1, 6, { "gpio_in", "gpio_out", "i2s0", "tdm", NULL, NULL, "pb_eint6" }, 6, 6, 0}, 43*d07cc22bSEmmanuel Vadot { "PB7", 1, 7, { "gpio_in", "gpio_out", "i2s0", "tdm", NULL, NULL, "pb_eint7" }, 6, 7, 0}, 44*d07cc22bSEmmanuel Vadot { "PB8", 1, 8, { "gpio_in", "gpio_out", "i2s0", "tdm", NULL, NULL, "pb_eint8" }, 6, 8, 0}, 45*d07cc22bSEmmanuel Vadot { "PB9", 1, 9, { "gpio_in", "gpio_out", "uart0", NULL, NULL, NULL, "pb_eint9" }, 6, 9, 0}, 46*d07cc22bSEmmanuel Vadot { "PB10", 1, 10, { "gpio_in", "gpio_out", "uart0", NULL, NULL, NULL, "pb_eint10" }, 6, 10, 0}, 478a0fd1a7SJared McNeill 488a0fd1a7SJared McNeill { "PC0", 2, 0, { "gpio_in", "gpio_out", "nand", "spi0" } }, 498a0fd1a7SJared McNeill { "PC1", 2, 1, { "gpio_in", "gpio_out", "nand", "spi0" } }, 508a0fd1a7SJared McNeill { "PC2", 2, 2, { "gpio_in", "gpio_out", "nand", "spi0" } }, 518a0fd1a7SJared McNeill { "PC3", 2, 3, { "gpio_in", "gpio_out", "nand", "spi0" } }, 528a0fd1a7SJared McNeill { "PC4", 2, 4, { "gpio_in", "gpio_out", "nand" } }, 538a0fd1a7SJared McNeill { "PC5", 2, 5, { "gpio_in", "gpio_out", "nand", "mmc2" } }, 548a0fd1a7SJared McNeill { "PC6", 2, 6, { "gpio_in", "gpio_out", "nand", "mmc2" } }, 558a0fd1a7SJared McNeill { "PC7", 2, 7, { "gpio_in", "gpio_out", "nand" } }, 568a0fd1a7SJared McNeill { "PC8", 2, 8, { "gpio_in", "gpio_out", "nand", "mmc2" } }, 578a0fd1a7SJared McNeill { "PC9", 2, 9, { "gpio_in", "gpio_out", "nand", "mmc2" } }, 588a0fd1a7SJared McNeill { "PC10", 2, 10, { "gpio_in", "gpio_out", "nand", "mmc2" } }, 598a0fd1a7SJared McNeill { "PC11", 2, 11, { "gpio_in", "gpio_out", "nand", "mmc2" } }, 608a0fd1a7SJared McNeill { "PC12", 2, 12, { "gpio_in", "gpio_out", "nand", "mmc2" } }, 618a0fd1a7SJared McNeill { "PC13", 2, 13, { "gpio_in", "gpio_out", "nand", "mmc2" } }, 628a0fd1a7SJared McNeill { "PC14", 2, 14, { "gpio_in", "gpio_out", "nand", "mmc2" } }, 638a0fd1a7SJared McNeill { "PC15", 2, 15, { "gpio_in", "gpio_out", "nand", "mmc2" } }, 648a0fd1a7SJared McNeill { "PC16", 2, 16, { "gpio_in", "gpio_out", "nand", "mmc2" } }, 658a0fd1a7SJared McNeill { "PC17", 2, 17, { "gpio_in", "gpio_out", "nand" } }, 668a0fd1a7SJared McNeill { "PC18", 2, 18, { "gpio_in", "gpio_out", "nand" } }, 678a0fd1a7SJared McNeill 684fd54ea8SKyle Evans { "PD2", 3, 2, { "gpio_in", "gpio_out", "lcd", NULL, "gmac" } }, 694fd54ea8SKyle Evans { "PD3", 3, 3, { "gpio_in", "gpio_out", "lcd", NULL, "gmac" } }, 704fd54ea8SKyle Evans { "PD4", 3, 4, { "gpio_in", "gpio_out", "lcd", NULL, "gmac" } }, 714fd54ea8SKyle Evans { "PD5", 3, 5, { "gpio_in", "gpio_out", "lcd", NULL, "gmac" } }, 724fd54ea8SKyle Evans { "PD6", 3, 6, { "gpio_in", "gpio_out", "lcd", NULL, "gmac" } }, 734fd54ea8SKyle Evans { "PD7", 3, 7, { "gpio_in", "gpio_out", "lcd", NULL, "gmac" } }, 744fd54ea8SKyle Evans { "PD10", 3, 10, { "gpio_in", "gpio_out", "lcd", NULL, "gmac" } }, 754fd54ea8SKyle Evans { "PD11", 3, 11, { "gpio_in", "gpio_out", "lcd", NULL, "gmac" } }, 764fd54ea8SKyle Evans { "PD12", 3, 12, { "gpio_in", "gpio_out", "lcd", NULL, "gmac" } }, 774fd54ea8SKyle Evans { "PD13", 3, 13, { "gpio_in", "gpio_out", "lcd", NULL, "gmac" } }, 784fd54ea8SKyle Evans { "PD14", 3, 14, { "gpio_in", "gpio_out", "lcd", NULL, "gmac" } }, 794fd54ea8SKyle Evans { "PD15", 3, 15, { "gpio_in", "gpio_out", "lcd", NULL, "gmac" } }, 804fd54ea8SKyle Evans { "PD18", 3, 18, { "gpio_in", "gpio_out", "lcd", "lvds", "gmac" } }, 814fd54ea8SKyle Evans { "PD19", 3, 19, { "gpio_in", "gpio_out", "lcd", "lvds", "gmac" } }, 824fd54ea8SKyle Evans { "PD20", 3, 20, { "gpio_in", "gpio_out", "lcd", "lvds", "gmac" } }, 834fd54ea8SKyle Evans { "PD21", 3, 21, { "gpio_in", "gpio_out", "lcd", "lvds", "gmac" } }, 844fd54ea8SKyle Evans { "PD22", 3, 22, { "gpio_in", "gpio_out", "lcd", "lvds", "gmac" } }, 854fd54ea8SKyle Evans { "PD23", 3, 23, { "gpio_in", "gpio_out", "lcd", "lvds", "gmac" } }, 868a0fd1a7SJared McNeill { "PD24", 3, 24, { "gpio_in", "gpio_out", "lcd", "lvds" } }, 878a0fd1a7SJared McNeill { "PD25", 3, 25, { "gpio_in", "gpio_out", "lcd", "lvds" } }, 888a0fd1a7SJared McNeill { "PD26", 3, 26, { "gpio_in", "gpio_out", "lcd", "lvds" } }, 898a0fd1a7SJared McNeill { "PD27", 3, 27, { "gpio_in", "gpio_out", "lcd", "lvds" } }, 908a0fd1a7SJared McNeill { "PD28", 3, 28, { "gpio_in", "gpio_out", "pwm" } }, 918a0fd1a7SJared McNeill { "PD29", 3, 29, { "gpio_in", "gpio_out" } }, 928a0fd1a7SJared McNeill 938a0fd1a7SJared McNeill { "PE0", 4, 0, { "gpio_in", "gpio_out", "csi", NULL, "ccir" } }, 948a0fd1a7SJared McNeill { "PE1", 4, 1, { "gpio_in", "gpio_out", "csi", NULL, "ccir" } }, 958a0fd1a7SJared McNeill { "PE2", 4, 2, { "gpio_in", "gpio_out", "csi", NULL, "ccir" } }, 968a0fd1a7SJared McNeill { "PE3", 4, 3, { "gpio_in", "gpio_out", "csi", NULL, "ccir" } }, 978a0fd1a7SJared McNeill { "PE4", 4, 4, { "gpio_in", "gpio_out", "csi" } }, 988a0fd1a7SJared McNeill { "PE5", 4, 5, { "gpio_in", "gpio_out", "csi" } }, 998a0fd1a7SJared McNeill { "PE6", 4, 6, { "gpio_in", "gpio_out", "csi", NULL, "ccir" } }, 1008a0fd1a7SJared McNeill { "PE7", 4, 7, { "gpio_in", "gpio_out", "csi", NULL, "ccir" } }, 1018a0fd1a7SJared McNeill { "PE8", 4, 8, { "gpio_in", "gpio_out", "csi", NULL, "ccir" } }, 1028a0fd1a7SJared McNeill { "PE9", 4, 9, { "gpio_in", "gpio_out", "csi", NULL, "ccir" } }, 1038a0fd1a7SJared McNeill { "PE10", 4, 10, { "gpio_in", "gpio_out", "csi", "uart4", "ccir" } }, 1048a0fd1a7SJared McNeill { "PE11", 4, 11, { "gpio_in", "gpio_out", "csi", "uart4", "ccir" } }, 1058a0fd1a7SJared McNeill { "PE12", 4, 12, { "gpio_in", "gpio_out", "csi", "uart4", "ccir" } }, 1068a0fd1a7SJared McNeill { "PE13", 4, 13, { "gpio_in", "gpio_out", "csi", "uart4", "ccir" } }, 1078a0fd1a7SJared McNeill { "PE14", 4, 14, { "gpio_in", "gpio_out", "csi", "twi2" } }, 1088a0fd1a7SJared McNeill { "PE15", 4, 15, { "gpio_in", "gpio_out", "csi", "twi2" } }, 1098a0fd1a7SJared McNeill { "PE16", 4, 16, { "gpio_in", "gpio_out" } }, 1108a0fd1a7SJared McNeill { "PE17", 4, 17, { "gpio_in", "gpio_out" } }, 1118a0fd1a7SJared McNeill { "PE18", 4, 18, { "gpio_in", "gpio_out", NULL, "owa" } }, 1128a0fd1a7SJared McNeill { "PE19", 4, 19, { "gpio_in", "gpio_out" } }, 1138a0fd1a7SJared McNeill 1148a0fd1a7SJared McNeill { "PF0", 5, 0, { "gpio_in", "gpio_out", "mmc0", "jtag" } }, 1158a0fd1a7SJared McNeill { "PF1", 5, 1, { "gpio_in", "gpio_out", "mmc0", "jtag" } }, 1168a0fd1a7SJared McNeill { "PF2", 5, 2, { "gpio_in", "gpio_out", "mmc0", "uart0" } }, 1178a0fd1a7SJared McNeill { "PF3", 5, 3, { "gpio_in", "gpio_out", "mmc0", "jtag" } }, 1188a0fd1a7SJared McNeill { "PF4", 5, 4, { "gpio_in", "gpio_out", "mmc0", "uart0" } }, 1198a0fd1a7SJared McNeill { "PF5", 5, 5, { "gpio_in", "gpio_out", "mmc0", "jtag" } }, 1208a0fd1a7SJared McNeill { "PF6", 5, 6, { "gpio_in", "gpio_out" } }, 1218a0fd1a7SJared McNeill 122*d07cc22bSEmmanuel Vadot { "PG0", 6, 0, { "gpio_in", "gpio_out", "mmc1", NULL, NULL, NULL, "pg_eint0" }, 6, 0, 1}, 123*d07cc22bSEmmanuel Vadot { "PG1", 6, 1, { "gpio_in", "gpio_out", "mmc1", NULL, NULL, NULL, "pg_eint1" }, 6, 1, 1}, 124*d07cc22bSEmmanuel Vadot { "PG2", 6, 2, { "gpio_in", "gpio_out", "mmc1", NULL, NULL, NULL, "pg_eint2" }, 6, 2, 1}, 125*d07cc22bSEmmanuel Vadot { "PG3", 6, 3, { "gpio_in", "gpio_out", "mmc1", NULL, NULL, NULL, "pg_eint3" }, 6, 3, 1}, 126*d07cc22bSEmmanuel Vadot { "PG4", 6, 4, { "gpio_in", "gpio_out", "mmc1", NULL, NULL, NULL, "pg_eint4" }, 6, 4, 1}, 127*d07cc22bSEmmanuel Vadot { "PG5", 6, 5, { "gpio_in", "gpio_out", "mmc1", NULL, NULL, NULL, "pg_eint5" }, 6, 5, 1}, 128*d07cc22bSEmmanuel Vadot { "PG6", 6, 6, { "gpio_in", "gpio_out", "uart1", "spi1", NULL, NULL, "pg_eint6" }, 6, 6, 1}, 129*d07cc22bSEmmanuel Vadot { "PG7", 6, 7, { "gpio_in", "gpio_out", "uart1", "spi1", NULL, NULL, "pg_eint7" }, 6, 7, 1}, 130*d07cc22bSEmmanuel Vadot { "PG8", 6, 8, { "gpio_in", "gpio_out", "uart1", "spi1", NULL, NULL, "pg_eint8" }, 6, 8, 1}, 131*d07cc22bSEmmanuel Vadot { "PG9", 6, 9, { "gpio_in", "gpio_out", "uart1", "spi1", NULL, NULL, "pg_eint9" }, 6, 9, 1}, 132*d07cc22bSEmmanuel Vadot { "PG10", 6, 10, { "gpio_in", "gpio_out", "i2s1", "uart3", NULL, NULL, "pg_eint10" }, 6, 10, 1}, 133*d07cc22bSEmmanuel Vadot { "PG11", 6, 11, { "gpio_in", "gpio_out", "i2s1", "uart3", NULL, NULL, "pg_eint11" }, 6, 11, 1}, 134*d07cc22bSEmmanuel Vadot { "PG12", 6, 12, { "gpio_in", "gpio_out", "i2s1", "uart3", NULL, NULL, "pg_eint12" }, 6, 12, 1}, 135*d07cc22bSEmmanuel Vadot { "PG13", 6, 13, { "gpio_in", "gpio_out", "i2s1", "uart3", NULL, NULL, "pg_eint13" }, 6, 13, 1}, 1368a0fd1a7SJared McNeill 137*d07cc22bSEmmanuel Vadot { "PH0", 7, 0, { "gpio_in", "gpio_out", "i2c0", NULL, NULL, NULL, "ph_eint0" }, 6, 0, 2}, 138*d07cc22bSEmmanuel Vadot { "PH1", 7, 1, { "gpio_in", "gpio_out", "i2c0", NULL, NULL, NULL, "ph_eint1" }, 6, 1, 2}, 139*d07cc22bSEmmanuel Vadot { "PH2", 7, 2, { "gpio_in", "gpio_out", "i2c1", NULL, NULL, NULL, "ph_eint2" }, 6, 2, 2}, 140*d07cc22bSEmmanuel Vadot { "PH3", 7, 3, { "gpio_in", "gpio_out", "i2c1", NULL, NULL, NULL, "ph_eint3" }, 6, 3, 2}, 141*d07cc22bSEmmanuel Vadot { "PH4", 7, 4, { "gpio_in", "gpio_out", "i2c2", NULL, NULL, NULL, "ph_eint4" }, 6, 4, 2}, 142*d07cc22bSEmmanuel Vadot { "PH5", 7, 5, { "gpio_in", "gpio_out", "i2c2", NULL, NULL, NULL, "ph_eint5" }, 6, 5, 2}, 143*d07cc22bSEmmanuel Vadot { "PH6", 7, 6, { "gpio_in", "gpio_out", "hdmiddc", NULL, NULL, NULL, "ph_eint6" }, 6, 6, 2}, 144*d07cc22bSEmmanuel Vadot { "PH7", 7, 7, { "gpio_in", "gpio_out", "hdmiddc", NULL, NULL, NULL, "ph_eint7" }, 6, 7, 2}, 145*d07cc22bSEmmanuel Vadot { "PH8", 7, 8, { "gpio_in", "gpio_out", "hdmiddc", NULL, NULL, NULL, "ph_eint8" }, 6, 8, 2}, 146*d07cc22bSEmmanuel Vadot { "PH9", 7, 9, { "gpio_in", "gpio_out", NULL, NULL, NULL, NULL, "ph_eint9" }, 6, 9, 2}, 147*d07cc22bSEmmanuel Vadot { "PH10", 7, 10, { "gpio_in", "gpio_out", NULL, NULL, NULL, NULL, "ph_eint10" }, 6, 10, 2}, 148*d07cc22bSEmmanuel Vadot { "PH11", 7, 11, { "gpio_in", "gpio_out", NULL, NULL, NULL, NULL, "ph_eint11" }, 6, 11, 2}, 1498a0fd1a7SJared McNeill }; 1508a0fd1a7SJared McNeill 1518a0fd1a7SJared McNeill const struct allwinner_padconf a83t_padconf = { 1528a0fd1a7SJared McNeill .npins = nitems(a83t_pins), 1538a0fd1a7SJared McNeill .pins = a83t_pins, 1548a0fd1a7SJared McNeill }; 1558a0fd1a7SJared McNeill 1568a0fd1a7SJared McNeill #endif /* !SOC_ALLWINNER_A83T */ 157