1 // SPDX-License-Identifier: GPL-2.0 2 /* 3 * Copyright (c) 2020 Yangtao Li <frank@allwinnertech.com> 4 * 5 * Based on: 6 * huangshuosheng <huangshuosheng@allwinnertech.com> 7 */ 8 9 #include <linux/module.h> 10 #include <linux/of.h> 11 #include <linux/of_device.h> 12 #include <linux/pinctrl/pinctrl.h> 13 #include <linux/platform_device.h> 14 15 #include "pinctrl-sunxi.h" 16 17 static const struct sunxi_desc_pin a100_pins[] = { 18 SUNXI_PIN(SUNXI_PINCTRL_PIN(B, 0), 19 SUNXI_FUNCTION(0x0, "gpio_in"), 20 SUNXI_FUNCTION(0x1, "gpio_out"), 21 SUNXI_FUNCTION(0x2, "uart2"), /* TX */ 22 SUNXI_FUNCTION(0x3, "spi2"), /* CS */ 23 SUNXI_FUNCTION(0x4, "jtag"), /* MS */ 24 SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 0)), 25 SUNXI_PIN(SUNXI_PINCTRL_PIN(B, 1), 26 SUNXI_FUNCTION(0x0, "gpio_in"), 27 SUNXI_FUNCTION(0x1, "gpio_out"), 28 SUNXI_FUNCTION(0x2, "uart2"), /* RX */ 29 SUNXI_FUNCTION(0x3, "spi2"), /* CLK */ 30 SUNXI_FUNCTION(0x4, "jtag"), /* CK */ 31 SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 1)), 32 SUNXI_PIN(SUNXI_PINCTRL_PIN(B, 2), 33 SUNXI_FUNCTION(0x0, "gpio_in"), 34 SUNXI_FUNCTION(0x1, "gpio_out"), 35 SUNXI_FUNCTION(0x2, "uart2"), /* RTS */ 36 SUNXI_FUNCTION(0x3, "spi2"), /* MOSI */ 37 SUNXI_FUNCTION(0x4, "jtag"), /* DO */ 38 SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 2)), 39 SUNXI_PIN(SUNXI_PINCTRL_PIN(B, 3), 40 SUNXI_FUNCTION(0x0, "gpio_in"), 41 SUNXI_FUNCTION(0x1, "gpio_out"), 42 SUNXI_FUNCTION(0x2, "uart2"), /* CTS */ 43 SUNXI_FUNCTION(0x3, "spi2"), /* MISO */ 44 SUNXI_FUNCTION(0x4, "jtag"), /* DI */ 45 SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 3)), 46 SUNXI_PIN(SUNXI_PINCTRL_PIN(B, 4), 47 SUNXI_FUNCTION(0x0, "gpio_in"), 48 SUNXI_FUNCTION(0x1, "gpio_out"), 49 SUNXI_FUNCTION(0x2, "i2c1"), /* SCK */ 50 SUNXI_FUNCTION(0x3, "i2s0"), /* MCLK */ 51 SUNXI_FUNCTION(0x4, "jtag_gpu"), /* MS_GPU */ 52 SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 4)), 53 SUNXI_PIN(SUNXI_PINCTRL_PIN(B, 5), 54 SUNXI_FUNCTION(0x0, "gpio_in"), 55 SUNXI_FUNCTION(0x1, "gpio_out"), 56 SUNXI_FUNCTION(0x2, "i2c1"), /* SDA */ 57 SUNXI_FUNCTION(0x3, "i2s0"), /* BCLK */ 58 SUNXI_FUNCTION(0x4, "jtag_gpu"), /* CK_GPU */ 59 SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 5)), 60 SUNXI_PIN(SUNXI_PINCTRL_PIN(B, 6), 61 SUNXI_FUNCTION(0x0, "gpio_in"), 62 SUNXI_FUNCTION(0x1, "gpio_out"), 63 SUNXI_FUNCTION(0x3, "i2s0"), /* LRCK */ 64 SUNXI_FUNCTION(0x4, "jtag_gpu"), /* DO_GPU */ 65 SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 6)), 66 SUNXI_PIN(SUNXI_PINCTRL_PIN(B, 7), 67 SUNXI_FUNCTION(0x0, "gpio_in"), 68 SUNXI_FUNCTION(0x1, "gpio_out"), 69 SUNXI_FUNCTION(0x2, "spdif"), /* DIN */ 70 SUNXI_FUNCTION(0x3, "i2s0_dout0"), /* DOUT0 */ 71 SUNXI_FUNCTION(0x4, "i2s0_din1"), /* DIN1 */ 72 SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 7)), 73 SUNXI_PIN(SUNXI_PINCTRL_PIN(B, 8), 74 SUNXI_FUNCTION(0x0, "gpio_in"), 75 SUNXI_FUNCTION(0x1, "gpio_out"), 76 SUNXI_FUNCTION(0x2, "spdif"), /* DOUT */ 77 SUNXI_FUNCTION(0x3, "i2s0_din0"), /* DIN0 */ 78 SUNXI_FUNCTION(0x4, "i2s0_dout1"), /* DOUT1 */ 79 SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 8)), 80 SUNXI_PIN(SUNXI_PINCTRL_PIN(B, 9), 81 SUNXI_FUNCTION(0x0, "gpio_in"), 82 SUNXI_FUNCTION(0x1, "gpio_out"), 83 SUNXI_FUNCTION(0x2, "uart0"), /* TX */ 84 SUNXI_FUNCTION(0x3, "i2c0"), /* SCK */ 85 SUNXI_FUNCTION(0x4, "jtag_gpu"), /* DI_GPU */ 86 SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 9)), 87 SUNXI_PIN(SUNXI_PINCTRL_PIN(B, 10), 88 SUNXI_FUNCTION(0x0, "gpio_in"), 89 SUNXI_FUNCTION(0x1, "gpio_out"), 90 SUNXI_FUNCTION(0x2, "uart0"), /* RX */ 91 SUNXI_FUNCTION(0x3, "i2c0"), /* SDA */ 92 SUNXI_FUNCTION(0x4, "pwm1"), 93 SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 10)), 94 /* HOLE */ 95 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 0), 96 SUNXI_FUNCTION(0x0, "gpio_in"), 97 SUNXI_FUNCTION(0x1, "gpio_out"), 98 SUNXI_FUNCTION(0x2, "nand0"), /* WE */ 99 SUNXI_FUNCTION(0x3, "mmc2"), /* DS */ 100 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 0)), 101 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 1), 102 SUNXI_FUNCTION(0x0, "gpio_in"), 103 SUNXI_FUNCTION(0x1, "gpio_out"), 104 SUNXI_FUNCTION(0x2, "nand0"), /* ALE */ 105 SUNXI_FUNCTION(0x3, "mmc2"), /* RST */ 106 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 1)), 107 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 2), 108 SUNXI_FUNCTION(0x0, "gpio_in"), 109 SUNXI_FUNCTION(0x1, "gpio_out"), 110 SUNXI_FUNCTION(0x2, "nand0"), /* CLE */ 111 SUNXI_FUNCTION(0x4, "spi0"), /* MOSI */ 112 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 2)), 113 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 3), 114 SUNXI_FUNCTION(0x0, "gpio_in"), 115 SUNXI_FUNCTION(0x1, "gpio_out"), 116 SUNXI_FUNCTION(0x2, "nand0"), /* CE1 */ 117 SUNXI_FUNCTION(0x4, "spi0"), /* CS0 */ 118 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 3)), 119 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 4), 120 SUNXI_FUNCTION(0x0, "gpio_in"), 121 SUNXI_FUNCTION(0x1, "gpio_out"), 122 SUNXI_FUNCTION(0x2, "nand0"), /* CE0 */ 123 SUNXI_FUNCTION(0x4, "spi0"), /* MISO */ 124 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 4)), 125 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 5), 126 SUNXI_FUNCTION(0x0, "gpio_in"), 127 SUNXI_FUNCTION(0x1, "gpio_out"), 128 SUNXI_FUNCTION(0x2, "nand0"), /* RE */ 129 SUNXI_FUNCTION(0x3, "mmc2"), /* CLK */ 130 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 5)), 131 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 6), 132 SUNXI_FUNCTION(0x0, "gpio_in"), 133 SUNXI_FUNCTION(0x1, "gpio_out"), 134 SUNXI_FUNCTION(0x2, "nand0"), /* RB0 */ 135 SUNXI_FUNCTION(0x3, "mmc2"), /* CMD */ 136 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 6)), 137 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 7), 138 SUNXI_FUNCTION(0x0, "gpio_in"), 139 SUNXI_FUNCTION(0x1, "gpio_out"), 140 SUNXI_FUNCTION(0x2, "nand0"), /* RB1 */ 141 SUNXI_FUNCTION(0x4, "spi0"), /* CS1 */ 142 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 7)), 143 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 8), 144 SUNXI_FUNCTION(0x0, "gpio_in"), 145 SUNXI_FUNCTION(0x1, "gpio_out"), 146 SUNXI_FUNCTION(0x2, "nand0"), /* DQ7 */ 147 SUNXI_FUNCTION(0x3, "mmc2"), /* D3 */ 148 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 8)), 149 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 9), 150 SUNXI_FUNCTION(0x0, "gpio_in"), 151 SUNXI_FUNCTION(0x1, "gpio_out"), 152 SUNXI_FUNCTION(0x2, "nand0"), /* DQ6 */ 153 SUNXI_FUNCTION(0x3, "mmc2"), /* D4 */ 154 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 9)), 155 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 10), 156 SUNXI_FUNCTION(0x0, "gpio_in"), 157 SUNXI_FUNCTION(0x1, "gpio_out"), 158 SUNXI_FUNCTION(0x2, "nand0"), /* DQ5 */ 159 SUNXI_FUNCTION(0x3, "mmc2"), /* D0 */ 160 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 10)), 161 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 11), 162 SUNXI_FUNCTION(0x0, "gpio_in"), 163 SUNXI_FUNCTION(0x1, "gpio_out"), 164 SUNXI_FUNCTION(0x2, "nand0"), /* DQ4 */ 165 SUNXI_FUNCTION(0x3, "mmc2"), /* D5 */ 166 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 11)), 167 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 12), 168 SUNXI_FUNCTION(0x0, "gpio_in"), 169 SUNXI_FUNCTION(0x1, "gpio_out"), 170 SUNXI_FUNCTION(0x2, "nand0"), /* DQS */ 171 SUNXI_FUNCTION(0x4, "spi0"), /* CLK */ 172 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 12)), 173 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 13), 174 SUNXI_FUNCTION(0x0, "gpio_in"), 175 SUNXI_FUNCTION(0x1, "gpio_out"), 176 SUNXI_FUNCTION(0x2, "nand0"), /* DQ3 */ 177 SUNXI_FUNCTION(0x3, "mmc2"), /* D1 */ 178 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 13)), 179 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 14), 180 SUNXI_FUNCTION(0x0, "gpio_in"), 181 SUNXI_FUNCTION(0x1, "gpio_out"), 182 SUNXI_FUNCTION(0x2, "nand0"), /* DQ2 */ 183 SUNXI_FUNCTION(0x3, "mmc2"), /* D6 */ 184 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 14)), 185 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 15), 186 SUNXI_FUNCTION(0x0, "gpio_in"), 187 SUNXI_FUNCTION(0x1, "gpio_out"), 188 SUNXI_FUNCTION(0x2, "nand0"), /* DQ1 */ 189 SUNXI_FUNCTION(0x3, "mmc2"), /* D2 */ 190 SUNXI_FUNCTION(0x4, "spi0"), /* WP */ 191 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 15)), 192 SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 16), 193 SUNXI_FUNCTION(0x0, "gpio_in"), 194 SUNXI_FUNCTION(0x1, "gpio_out"), 195 SUNXI_FUNCTION(0x2, "nand0"), /* DQ0 */ 196 SUNXI_FUNCTION(0x3, "mmc2"), /* D7 */ 197 SUNXI_FUNCTION(0x4, "spi0"), /* HOLD */ 198 SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 16)), 199 /* HOLE */ 200 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 0), 201 SUNXI_FUNCTION(0x0, "gpio_in"), 202 SUNXI_FUNCTION(0x1, "gpio_out"), 203 SUNXI_FUNCTION(0x2, "lcd0"), /* D2 */ 204 SUNXI_FUNCTION(0x3, "lvds0"), /* D0P */ 205 SUNXI_FUNCTION(0x4, "dsi0"), /* DP0 */ 206 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 0)), 207 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 1), 208 SUNXI_FUNCTION(0x0, "gpio_in"), 209 SUNXI_FUNCTION(0x1, "gpio_out"), 210 SUNXI_FUNCTION(0x2, "lcd0"), /* D3 */ 211 SUNXI_FUNCTION(0x3, "lvds0"), /* D0N */ 212 SUNXI_FUNCTION(0x4, "dsi0"), /* DM0 */ 213 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 1)), 214 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 2), 215 SUNXI_FUNCTION(0x0, "gpio_in"), 216 SUNXI_FUNCTION(0x1, "gpio_out"), 217 SUNXI_FUNCTION(0x2, "lcd0"), /* D4 */ 218 SUNXI_FUNCTION(0x3, "lvds0"), /* D1P */ 219 SUNXI_FUNCTION(0x4, "dsi0"), /* DP1 */ 220 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 2)), 221 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 3), 222 SUNXI_FUNCTION(0x0, "gpio_in"), 223 SUNXI_FUNCTION(0x1, "gpio_out"), 224 SUNXI_FUNCTION(0x2, "lcd0"), /* D5 */ 225 SUNXI_FUNCTION(0x3, "lvds0"), /* D1N */ 226 SUNXI_FUNCTION(0x4, "dsi0"), /* DM1 */ 227 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 3)), 228 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 4), 229 SUNXI_FUNCTION(0x0, "gpio_in"), 230 SUNXI_FUNCTION(0x1, "gpio_out"), 231 SUNXI_FUNCTION(0x2, "lcd0"), /* D6 */ 232 SUNXI_FUNCTION(0x3, "lvds0"), /* D2P */ 233 SUNXI_FUNCTION(0x4, "dsi0"), /* CKP */ 234 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 4)), 235 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 5), 236 SUNXI_FUNCTION(0x0, "gpio_in"), 237 SUNXI_FUNCTION(0x1, "gpio_out"), 238 SUNXI_FUNCTION(0x2, "lcd0"), /* D7 */ 239 SUNXI_FUNCTION(0x3, "lvds0"), /* D2N */ 240 SUNXI_FUNCTION(0x4, "dsi0"), /* CKM */ 241 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 5)), 242 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 6), 243 SUNXI_FUNCTION(0x0, "gpio_in"), 244 SUNXI_FUNCTION(0x1, "gpio_out"), 245 SUNXI_FUNCTION(0x2, "lcd0"), /* D10 */ 246 SUNXI_FUNCTION(0x3, "lvds0"), /* CKP */ 247 SUNXI_FUNCTION(0x4, "dsi0"), /* DP2 */ 248 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 6)), 249 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 7), 250 SUNXI_FUNCTION(0x0, "gpio_in"), 251 SUNXI_FUNCTION(0x1, "gpio_out"), 252 SUNXI_FUNCTION(0x2, "lcd0"), /* D11 */ 253 SUNXI_FUNCTION(0x3, "lvds0"), /* CKN */ 254 SUNXI_FUNCTION(0x4, "dsi0"), /* DM2 */ 255 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 7)), 256 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 8), 257 SUNXI_FUNCTION(0x0, "gpio_in"), 258 SUNXI_FUNCTION(0x1, "gpio_out"), 259 SUNXI_FUNCTION(0x2, "lcd0"), /* D12 */ 260 SUNXI_FUNCTION(0x4, "dsi0"), /* DP3 */ 261 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 8)), 262 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 9), 263 SUNXI_FUNCTION(0x0, "gpio_in"), 264 SUNXI_FUNCTION(0x1, "gpio_out"), 265 SUNXI_FUNCTION(0x2, "lcd0"), /* D13 */ 266 SUNXI_FUNCTION(0x4, "dsi0"), /* DM3 */ 267 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 9)), 268 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 10), 269 SUNXI_FUNCTION(0x0, "gpio_in"), 270 SUNXI_FUNCTION(0x1, "gpio_out"), 271 SUNXI_FUNCTION(0x2, "lcd0"), /* D14 */ 272 SUNXI_FUNCTION(0x4, "spi1"), /* CS */ 273 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 10)), 274 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 11), 275 SUNXI_FUNCTION(0x0, "gpio_in"), 276 SUNXI_FUNCTION(0x1, "gpio_out"), 277 SUNXI_FUNCTION(0x2, "lcd0"), /* D15 */ 278 SUNXI_FUNCTION(0x4, "spi1"), /* CLK */ 279 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 11)), 280 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 12), 281 SUNXI_FUNCTION(0x0, "gpio_in"), 282 SUNXI_FUNCTION(0x1, "gpio_out"), 283 SUNXI_FUNCTION(0x2, "lcd0"), /* D18 */ 284 SUNXI_FUNCTION(0x4, "spi1"), /* MOSI */ 285 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 12)), 286 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 13), 287 SUNXI_FUNCTION(0x0, "gpio_in"), 288 SUNXI_FUNCTION(0x1, "gpio_out"), 289 SUNXI_FUNCTION(0x2, "lcd0"), /* D19 */ 290 SUNXI_FUNCTION(0x4, "spi1"), /* MISO */ 291 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 13)), 292 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 14), 293 SUNXI_FUNCTION(0x0, "gpio_in"), 294 SUNXI_FUNCTION(0x1, "gpio_out"), 295 SUNXI_FUNCTION(0x2, "lcd0"), /* D20 */ 296 SUNXI_FUNCTION(0x4, "uart3"), /* TX */ 297 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 14)), 298 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 15), 299 SUNXI_FUNCTION(0x0, "gpio_in"), 300 SUNXI_FUNCTION(0x1, "gpio_out"), 301 SUNXI_FUNCTION(0x2, "lcd0"), /* D21 */ 302 SUNXI_FUNCTION(0x4, "uart3"), /* RX */ 303 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 15)), 304 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 16), 305 SUNXI_FUNCTION(0x0, "gpio_in"), 306 SUNXI_FUNCTION(0x1, "gpio_out"), 307 SUNXI_FUNCTION(0x2, "lcd0"), /* D22 */ 308 SUNXI_FUNCTION(0x4, "uart3"), /* RTS */ 309 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 16)), 310 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 17), 311 SUNXI_FUNCTION(0x0, "gpio_in"), 312 SUNXI_FUNCTION(0x1, "gpio_out"), 313 SUNXI_FUNCTION(0x2, "lcd0"), /* D23 */ 314 SUNXI_FUNCTION(0x4, "uart3"), /* CTS */ 315 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 17)), 316 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 18), 317 SUNXI_FUNCTION(0x0, "gpio_in"), 318 SUNXI_FUNCTION(0x1, "gpio_out"), 319 SUNXI_FUNCTION(0x2, "lcd0"), /* CLK */ 320 SUNXI_FUNCTION(0x4, "uart4"), /* TX */ 321 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 18)), 322 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 19), 323 SUNXI_FUNCTION(0x0, "gpio_in"), 324 SUNXI_FUNCTION(0x1, "gpio_out"), 325 SUNXI_FUNCTION(0x2, "lcd0"), /* DE */ 326 SUNXI_FUNCTION(0x4, "uart4"), /* RX */ 327 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 19)), 328 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 20), 329 SUNXI_FUNCTION(0x0, "gpio_in"), 330 SUNXI_FUNCTION(0x1, "gpio_out"), 331 SUNXI_FUNCTION(0x2, "lcd0"), /* HSYNC */ 332 SUNXI_FUNCTION(0x3, "pwm2"), 333 SUNXI_FUNCTION(0x4, "uart4"), /* RTS */ 334 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 20)), 335 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 21), 336 SUNXI_FUNCTION(0x0, "gpio_in"), 337 SUNXI_FUNCTION(0x1, "gpio_out"), 338 SUNXI_FUNCTION(0x2, "lcd0"), /* VSYNC */ 339 SUNXI_FUNCTION(0x3, "pwm3"), 340 SUNXI_FUNCTION(0x4, "uart4"), /* CTS */ 341 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 21)), 342 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 22), 343 SUNXI_FUNCTION(0x0, "gpio_in"), 344 SUNXI_FUNCTION(0x1, "gpio_out"), 345 SUNXI_FUNCTION(0x2, "pwm1"), 346 SUNXI_FUNCTION(0x4, "i2c0"), /* SCK */ 347 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 22)), 348 SUNXI_PIN(SUNXI_PINCTRL_PIN(D, 23), 349 SUNXI_FUNCTION(0x0, "gpio_in"), 350 SUNXI_FUNCTION(0x1, "gpio_out"), 351 SUNXI_FUNCTION(0x2, "pwm0"), 352 SUNXI_FUNCTION(0x4, "i2c0"), /* SDA */ 353 SUNXI_FUNCTION_IRQ_BANK(0x6, 2, 23)), 354 /* HOLE */ 355 SUNXI_PIN(SUNXI_PINCTRL_PIN(E, 0), 356 SUNXI_FUNCTION(0x0, "gpio_in"), 357 SUNXI_FUNCTION(0x1, "gpio_out"), 358 SUNXI_FUNCTION(0x2, "csi"), /* MCLK */ 359 SUNXI_FUNCTION_IRQ_BANK(0x6, 3, 0)), 360 SUNXI_PIN(SUNXI_PINCTRL_PIN(E, 1), 361 SUNXI_FUNCTION(0x0, "gpio_in"), 362 SUNXI_FUNCTION(0x1, "gpio_out"), 363 SUNXI_FUNCTION(0x2, "i2c2"), /* SCK */ 364 SUNXI_FUNCTION_IRQ_BANK(0x6, 3, 1)), 365 SUNXI_PIN(SUNXI_PINCTRL_PIN(E, 2), 366 SUNXI_FUNCTION(0x0, "gpio_in"), 367 SUNXI_FUNCTION(0x1, "gpio_out"), 368 SUNXI_FUNCTION(0x2, "i2c2"), /* SDA */ 369 SUNXI_FUNCTION_IRQ_BANK(0x6, 3, 2)), 370 SUNXI_PIN(SUNXI_PINCTRL_PIN(E, 3), 371 SUNXI_FUNCTION(0x0, "gpio_in"), 372 SUNXI_FUNCTION(0x1, "gpio_out"), 373 SUNXI_FUNCTION(0x2, "i2c3"), /* SCK */ 374 SUNXI_FUNCTION_IRQ_BANK(0x6, 3, 3)), 375 SUNXI_PIN(SUNXI_PINCTRL_PIN(E, 4), 376 SUNXI_FUNCTION(0x0, "gpio_in"), 377 SUNXI_FUNCTION(0x1, "gpio_out"), 378 SUNXI_FUNCTION(0x2, "i2c3"), /* SDA */ 379 SUNXI_FUNCTION_IRQ_BANK(0x6, 3, 4)), 380 SUNXI_PIN(SUNXI_PINCTRL_PIN(E, 5), 381 SUNXI_FUNCTION(0x0, "gpio_in"), 382 SUNXI_FUNCTION(0x1, "gpio_out"), 383 SUNXI_FUNCTION(0x2, "csi"), /* MCLK */ 384 SUNXI_FUNCTION(0x3, "pll"), /* LOCK_DBG */ 385 SUNXI_FUNCTION(0x4, "i2s2"), /* MCLK */ 386 SUNXI_FUNCTION(0x5, "ledc"), /* LEDC */ 387 SUNXI_FUNCTION_IRQ_BANK(0x6, 3, 5)), 388 SUNXI_PIN(SUNXI_PINCTRL_PIN(E, 6), 389 SUNXI_FUNCTION(0x0, "gpio_in"), 390 SUNXI_FUNCTION(0x1, "gpio_out"), 391 SUNXI_FUNCTION(0x3, "bist0"), /* RESULT0 */ 392 SUNXI_FUNCTION(0x4, "i2s2"), /* BCLK */ 393 SUNXI_FUNCTION_IRQ_BANK(0x6, 3, 6)), 394 SUNXI_PIN(SUNXI_PINCTRL_PIN(E, 7), 395 SUNXI_FUNCTION(0x0, "gpio_in"), 396 SUNXI_FUNCTION(0x1, "gpio_out"), 397 SUNXI_FUNCTION(0x2, "csi"), /* SM_VS */ 398 SUNXI_FUNCTION(0x3, "bist0"), /* RESULT1 */ 399 SUNXI_FUNCTION(0x4, "i2s2"), /* LRCK */ 400 SUNXI_FUNCTION(0x5, "tcon0"), /* TRIG */ 401 SUNXI_FUNCTION_IRQ_BANK(0x6, 3, 7)), 402 SUNXI_PIN(SUNXI_PINCTRL_PIN(E, 8), 403 SUNXI_FUNCTION(0x0, "gpio_in"), 404 SUNXI_FUNCTION(0x1, "gpio_out"), 405 SUNXI_FUNCTION(0x3, "bist0"), /* RESULT2 */ 406 SUNXI_FUNCTION(0x4, "i2s2"), /* DOUT0 */ 407 SUNXI_FUNCTION_IRQ_BANK(0x6, 3, 8)), 408 SUNXI_PIN(SUNXI_PINCTRL_PIN(E, 9), 409 SUNXI_FUNCTION(0x0, "gpio_in"), 410 SUNXI_FUNCTION(0x1, "gpio_out"), 411 SUNXI_FUNCTION(0x3, "bist0"), /* RESULT3 */ 412 SUNXI_FUNCTION(0x4, "i2s2"), /* DIN0 */ 413 SUNXI_FUNCTION_IRQ_BANK(0x6, 3, 9)), 414 /* HOLE */ 415 SUNXI_PIN(SUNXI_PINCTRL_PIN(F, 0), 416 SUNXI_FUNCTION(0x0, "gpio_in"), 417 SUNXI_FUNCTION(0x1, "gpio_out"), 418 SUNXI_FUNCTION(0x2, "mmc0"), /* D1 */ 419 SUNXI_FUNCTION(0x3, "jtag"), /* MS1 */ 420 SUNXI_FUNCTION(0x4, "jtag_gpu"), /* MS_GPU */ 421 SUNXI_FUNCTION_IRQ_BANK(0x6, 4, 0)), 422 SUNXI_PIN(SUNXI_PINCTRL_PIN(F, 1), 423 SUNXI_FUNCTION(0x0, "gpio_in"), 424 SUNXI_FUNCTION(0x1, "gpio_out"), 425 SUNXI_FUNCTION(0x2, "mmc0"), /* D0 */ 426 SUNXI_FUNCTION(0x3, "jtag"), /* DI1 */ 427 SUNXI_FUNCTION(0x4, "jtag_gpu"), /* DI_GPU */ 428 SUNXI_FUNCTION_IRQ_BANK(0x6, 4, 1)), 429 SUNXI_PIN(SUNXI_PINCTRL_PIN(F, 2), 430 SUNXI_FUNCTION(0x0, "gpio_in"), 431 SUNXI_FUNCTION(0x1, "gpio_out"), 432 SUNXI_FUNCTION(0x2, "mmc0"), /* CLK */ 433 SUNXI_FUNCTION(0x3, "uart0"), /* TX */ 434 SUNXI_FUNCTION_IRQ_BANK(0x6, 4, 2)), 435 SUNXI_PIN(SUNXI_PINCTRL_PIN(F, 3), 436 SUNXI_FUNCTION(0x0, "gpio_in"), 437 SUNXI_FUNCTION(0x1, "gpio_out"), 438 SUNXI_FUNCTION(0x2, "mmc0"), /* CMD */ 439 SUNXI_FUNCTION(0x3, "jtag"), /* DO */ 440 SUNXI_FUNCTION(0x4, "jtag_gpu"), /* DO_GPU */ 441 SUNXI_FUNCTION_IRQ_BANK(0x6, 4, 3)), 442 SUNXI_PIN(SUNXI_PINCTRL_PIN(F, 4), 443 SUNXI_FUNCTION(0x0, "gpio_in"), 444 SUNXI_FUNCTION(0x1, "gpio_out"), 445 SUNXI_FUNCTION(0x2, "mmc0"), /* D3 */ 446 SUNXI_FUNCTION(0x3, "uart0"), /* RX */ 447 SUNXI_FUNCTION_IRQ_BANK(0x6, 4, 4)), 448 SUNXI_PIN(SUNXI_PINCTRL_PIN(F, 5), 449 SUNXI_FUNCTION(0x0, "gpio_in"), 450 SUNXI_FUNCTION(0x1, "gpio_out"), 451 SUNXI_FUNCTION(0x2, "mmc0"), /* D2 */ 452 SUNXI_FUNCTION(0x3, "jtag"), /* CK */ 453 SUNXI_FUNCTION(0x4, "jtag_gpu"), /* CK_GPU */ 454 SUNXI_FUNCTION_IRQ_BANK(0x6, 4, 5)), 455 SUNXI_PIN(SUNXI_PINCTRL_PIN(F, 6), 456 SUNXI_FUNCTION(0x0, "gpio_in"), 457 SUNXI_FUNCTION(0x1, "gpio_out"), 458 SUNXI_FUNCTION_IRQ_BANK(0x6, 4, 6)), 459 /* HOLE */ 460 SUNXI_PIN(SUNXI_PINCTRL_PIN(G, 0), 461 SUNXI_FUNCTION(0x0, "gpio_in"), 462 SUNXI_FUNCTION(0x1, "gpio_out"), 463 SUNXI_FUNCTION(0x2, "mmc1"), /* CLK */ 464 SUNXI_FUNCTION_IRQ_BANK(0x6, 5, 0)), 465 SUNXI_PIN(SUNXI_PINCTRL_PIN(G, 1), 466 SUNXI_FUNCTION(0x0, "gpio_in"), 467 SUNXI_FUNCTION(0x1, "gpio_out"), 468 SUNXI_FUNCTION(0x2, "mmc1"), /* CMD */ 469 SUNXI_FUNCTION_IRQ_BANK(0x6, 5, 1)), 470 SUNXI_PIN(SUNXI_PINCTRL_PIN(G, 2), 471 SUNXI_FUNCTION(0x0, "gpio_in"), 472 SUNXI_FUNCTION(0x1, "gpio_out"), 473 SUNXI_FUNCTION(0x2, "mmc1"), /* D0 */ 474 SUNXI_FUNCTION_IRQ_BANK(0x6, 5, 2)), 475 SUNXI_PIN(SUNXI_PINCTRL_PIN(G, 3), 476 SUNXI_FUNCTION(0x0, "gpio_in"), 477 SUNXI_FUNCTION(0x1, "gpio_out"), 478 SUNXI_FUNCTION(0x2, "mmc1"), /* D1 */ 479 SUNXI_FUNCTION_IRQ_BANK(0x6, 5, 3)), 480 SUNXI_PIN(SUNXI_PINCTRL_PIN(G, 4), 481 SUNXI_FUNCTION(0x0, "gpio_in"), 482 SUNXI_FUNCTION(0x1, "gpio_out"), 483 SUNXI_FUNCTION(0x2, "mmc1"), /* D2 */ 484 SUNXI_FUNCTION_IRQ_BANK(0x6, 5, 4)), 485 SUNXI_PIN(SUNXI_PINCTRL_PIN(G, 5), 486 SUNXI_FUNCTION(0x0, "gpio_in"), 487 SUNXI_FUNCTION(0x1, "gpio_out"), 488 SUNXI_FUNCTION(0x2, "mmc1"), /* D3 */ 489 SUNXI_FUNCTION_IRQ_BANK(0x6, 5, 5)), 490 SUNXI_PIN(SUNXI_PINCTRL_PIN(G, 6), 491 SUNXI_FUNCTION(0x0, "gpio_in"), 492 SUNXI_FUNCTION(0x1, "gpio_out"), 493 SUNXI_FUNCTION(0x2, "uart1"), /* TX */ 494 SUNXI_FUNCTION_IRQ_BANK(0x6, 5, 6)), 495 SUNXI_PIN(SUNXI_PINCTRL_PIN(G, 7), 496 SUNXI_FUNCTION(0x0, "gpio_in"), 497 SUNXI_FUNCTION(0x1, "gpio_out"), 498 SUNXI_FUNCTION(0x2, "uart1"), /* RX */ 499 SUNXI_FUNCTION_IRQ_BANK(0x6, 5, 7)), 500 SUNXI_PIN(SUNXI_PINCTRL_PIN(G, 8), 501 SUNXI_FUNCTION(0x0, "gpio_in"), 502 SUNXI_FUNCTION(0x1, "gpio_out"), 503 SUNXI_FUNCTION(0x2, "uart1"), /* RTS */ 504 SUNXI_FUNCTION_IRQ_BANK(0x6, 5, 8)), 505 SUNXI_PIN(SUNXI_PINCTRL_PIN(G, 9), 506 SUNXI_FUNCTION(0x0, "gpio_in"), 507 SUNXI_FUNCTION(0x1, "gpio_out"), 508 SUNXI_FUNCTION(0x2, "uart1"), /* CTS */ 509 SUNXI_FUNCTION(0x3, "i2s1"), /* MCLK */ 510 SUNXI_FUNCTION_IRQ_BANK(0x6, 5, 9)), 511 SUNXI_PIN(SUNXI_PINCTRL_PIN(G, 10), 512 SUNXI_FUNCTION(0x0, "gpio_in"), 513 SUNXI_FUNCTION(0x1, "gpio_out"), 514 SUNXI_FUNCTION(0x3, "i2s1"), /* BCLK */ 515 SUNXI_FUNCTION_IRQ_BANK(0x6, 5, 10)), 516 SUNXI_PIN(SUNXI_PINCTRL_PIN(G, 11), 517 SUNXI_FUNCTION(0x0, "gpio_in"), 518 SUNXI_FUNCTION(0x1, "gpio_out"), 519 SUNXI_FUNCTION(0x3, "i2s1"), /* LRCK */ 520 SUNXI_FUNCTION_IRQ_BANK(0x6, 5, 11)), 521 SUNXI_PIN(SUNXI_PINCTRL_PIN(G, 12), 522 SUNXI_FUNCTION(0x0, "gpio_in"), 523 SUNXI_FUNCTION(0x1, "gpio_out"), 524 SUNXI_FUNCTION(0x3, "i2s1_dout0"), /* DOUT0 */ 525 SUNXI_FUNCTION(0x4, "i2s1_din1"), /* DIN1 */ 526 SUNXI_FUNCTION_IRQ_BANK(0x6, 5, 12)), 527 SUNXI_PIN(SUNXI_PINCTRL_PIN(G, 13), 528 SUNXI_FUNCTION(0x0, "gpio_in"), 529 SUNXI_FUNCTION(0x1, "gpio_out"), 530 SUNXI_FUNCTION(0x3, "i2s1_din0"), /* DIN0 */ 531 SUNXI_FUNCTION(0x4, "i2s1_dout1"), /* DOUT1 */ 532 SUNXI_FUNCTION_IRQ_BANK(0x6, 5, 13)), 533 /* HOLE */ 534 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 0), 535 SUNXI_FUNCTION(0x0, "gpio_in"), 536 SUNXI_FUNCTION(0x1, "gpio_out"), 537 SUNXI_FUNCTION(0x2, "i2c0"), /* SCK */ 538 SUNXI_FUNCTION(0x5, "emac0"), /* RXD1 */ 539 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 0)), 540 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 1), 541 SUNXI_FUNCTION(0x0, "gpio_in"), 542 SUNXI_FUNCTION(0x1, "gpio_out"), 543 SUNXI_FUNCTION(0x2, "i2c0"), /* SDA */ 544 SUNXI_FUNCTION(0x5, "emac0"), /* RXD0 */ 545 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 1)), 546 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 2), 547 SUNXI_FUNCTION(0x0, "gpio_in"), 548 SUNXI_FUNCTION(0x1, "gpio_out"), 549 SUNXI_FUNCTION(0x2, "i2c1"), /* SCK */ 550 SUNXI_FUNCTION(0x5, "emac0"), /* RXCTL */ 551 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 2)), 552 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 3), 553 SUNXI_FUNCTION(0x0, "gpio_in"), 554 SUNXI_FUNCTION(0x1, "gpio_out"), 555 SUNXI_FUNCTION(0x2, "i2c1"), /* SDA */ 556 SUNXI_FUNCTION(0x3, "cir0"), /* OUT */ 557 SUNXI_FUNCTION(0x5, "emac0"), /* CLKIN */ 558 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 3)), 559 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 4), 560 SUNXI_FUNCTION(0x0, "gpio_in"), 561 SUNXI_FUNCTION(0x1, "gpio_out"), 562 SUNXI_FUNCTION(0x2, "uart3"), /* TX */ 563 SUNXI_FUNCTION(0x3, "spi1"), /* CS */ 564 SUNXI_FUNCTION(0x5, "emac0"), /* TXD1 */ 565 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 4)), 566 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 5), 567 SUNXI_FUNCTION(0x0, "gpio_in"), 568 SUNXI_FUNCTION(0x1, "gpio_out"), 569 SUNXI_FUNCTION(0x2, "uart3"), /* RX */ 570 SUNXI_FUNCTION(0x3, "spi1"), /* CLK */ 571 SUNXI_FUNCTION(0x4, "ledc"), 572 SUNXI_FUNCTION(0x5, "emac0"), /* TXD0 */ 573 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 5)), 574 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 6), 575 SUNXI_FUNCTION(0x0, "gpio_in"), 576 SUNXI_FUNCTION(0x1, "gpio_out"), 577 SUNXI_FUNCTION(0x2, "uart3"), /* RTS */ 578 SUNXI_FUNCTION(0x3, "spi1"), /* MOSI */ 579 SUNXI_FUNCTION(0x5, "emac0"), /* TXCK */ 580 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 6)), 581 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 7), 582 SUNXI_FUNCTION(0x0, "gpio_in"), 583 SUNXI_FUNCTION(0x1, "gpio_out"), 584 SUNXI_FUNCTION(0x2, "uart3"), /* CTS */ 585 SUNXI_FUNCTION(0x3, "spi1"), /* MISO */ 586 SUNXI_FUNCTION(0x4, "spdif"), /* OUT */ 587 SUNXI_FUNCTION(0x5, "emac0"), /* TXCTL */ 588 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 7)), 589 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 8), 590 SUNXI_FUNCTION(0x0, "gpio_in"), 591 SUNXI_FUNCTION(0x1, "gpio_out"), 592 SUNXI_FUNCTION(0x2, "dmic"), /* CLK */ 593 SUNXI_FUNCTION(0x3, "spi2"), /* CS */ 594 SUNXI_FUNCTION(0x4, "i2s2"), /* MCLK */ 595 SUNXI_FUNCTION(0x5, "i2s2_din2"), /* DIN2 */ 596 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 8)), 597 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 9), 598 SUNXI_FUNCTION(0x0, "gpio_in"), 599 SUNXI_FUNCTION(0x1, "gpio_out"), 600 SUNXI_FUNCTION(0x2, "dmic"), /* DATA0 */ 601 SUNXI_FUNCTION(0x3, "spi2"), /* CLK */ 602 SUNXI_FUNCTION(0x4, "i2s2"), /* BCLK */ 603 SUNXI_FUNCTION(0x5, "emac0"), /* MDC */ 604 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 9)), 605 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 10), 606 SUNXI_FUNCTION(0x0, "gpio_in"), 607 SUNXI_FUNCTION(0x1, "gpio_out"), 608 SUNXI_FUNCTION(0x2, "dmic"), /* DATA1 */ 609 SUNXI_FUNCTION(0x3, "spi2"), /* MOSI */ 610 SUNXI_FUNCTION(0x4, "i2s2"), /* LRCK */ 611 SUNXI_FUNCTION(0x5, "emac0"), /* MDIO */ 612 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 10)), 613 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 11), 614 SUNXI_FUNCTION(0x0, "gpio_in"), 615 SUNXI_FUNCTION(0x1, "gpio_out"), 616 SUNXI_FUNCTION(0x2, "dmic"), /* DATA2 */ 617 SUNXI_FUNCTION(0x3, "spi2"), /* MISO */ 618 SUNXI_FUNCTION(0x4, "i2s2_dout0"), /* DOUT0 */ 619 SUNXI_FUNCTION(0x5, "i2s2_din1"), /* DIN1 */ 620 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 11)), 621 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 12), 622 SUNXI_FUNCTION(0x0, "gpio_in"), 623 SUNXI_FUNCTION(0x1, "gpio_out"), 624 SUNXI_FUNCTION(0x2, "dmic"), /* DATA3 */ 625 SUNXI_FUNCTION(0x3, "i2c3"), /* SCK */ 626 SUNXI_FUNCTION(0x4, "i2s2_din0"), /* DIN0 */ 627 SUNXI_FUNCTION(0x5, "i2s2_dout1"), /* DOUT1 */ 628 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 12)), 629 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 13), 630 SUNXI_FUNCTION(0x0, "gpio_in"), 631 SUNXI_FUNCTION(0x1, "gpio_out"), 632 SUNXI_FUNCTION(0x3, "i2c3"), /* SCK */ 633 SUNXI_FUNCTION(0x4, "i2s3"), /* MCLK */ 634 SUNXI_FUNCTION(0x5, "emac0"), /* EPHY */ 635 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 13)), 636 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 14), 637 SUNXI_FUNCTION(0x0, "gpio_in"), 638 SUNXI_FUNCTION(0x1, "gpio_out"), 639 SUNXI_FUNCTION(0x4, "i2s3"), /* BCLK */ 640 SUNXI_FUNCTION(0x5, "emac0"), /* RXD3 */ 641 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 14)), 642 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 15), 643 SUNXI_FUNCTION(0x0, "gpio_in"), 644 SUNXI_FUNCTION(0x1, "gpio_out"), 645 SUNXI_FUNCTION(0x4, "i2s3"), /* LRCK */ 646 SUNXI_FUNCTION(0x5, "emac0"), /* RXD2 */ 647 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 15)), 648 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 16), 649 SUNXI_FUNCTION(0x0, "gpio_in"), 650 SUNXI_FUNCTION(0x1, "gpio_out"), 651 SUNXI_FUNCTION(0x3, "i2s3_dout0"), /* DOUT0 */ 652 SUNXI_FUNCTION(0x4, "i2s3_din1"), /* DIN1 */ 653 SUNXI_FUNCTION(0x5, "emac0"), /* RXCK */ 654 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 16)), 655 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 17), 656 SUNXI_FUNCTION(0x0, "gpio_in"), 657 SUNXI_FUNCTION(0x1, "gpio_out"), 658 SUNXI_FUNCTION(0x3, "i2s3_dout1"), /* DOUT1 */ 659 SUNXI_FUNCTION(0x4, "i2s3_din0"), /* DIN0 */ 660 SUNXI_FUNCTION(0x5, "emac0"), /* TXD3 */ 661 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 17)), 662 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 18), 663 SUNXI_FUNCTION(0x0, "gpio_in"), 664 SUNXI_FUNCTION(0x1, "gpio_out"), 665 SUNXI_FUNCTION(0x2, "cir0"), /* OUT */ 666 SUNXI_FUNCTION(0x3, "i2s3_dout2"), /* DOUT2 */ 667 SUNXI_FUNCTION(0x4, "i2s3_din2"), /* DIN2 */ 668 SUNXI_FUNCTION(0x5, "emac0"), /* TXD2 */ 669 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 18)), 670 SUNXI_PIN(SUNXI_PINCTRL_PIN(H, 19), 671 SUNXI_FUNCTION(0x0, "gpio_in"), 672 SUNXI_FUNCTION(0x1, "gpio_out"), 673 SUNXI_FUNCTION(0x2, "cir0"), /* IN */ 674 SUNXI_FUNCTION(0x3, "i2s3_dout3"), /* DOUT3 */ 675 SUNXI_FUNCTION(0x4, "i2s3_din3"), /* DIN3 */ 676 SUNXI_FUNCTION(0x5, "ledc"), 677 SUNXI_FUNCTION_IRQ_BANK(0x6, 6, 19)), 678 }; 679 680 static const unsigned int a100_irq_bank_map[] = { 1, 2, 3, 4, 5, 6, 7}; 681 682 static const struct sunxi_pinctrl_desc a100_pinctrl_data = { 683 .pins = a100_pins, 684 .npins = ARRAY_SIZE(a100_pins), 685 .irq_banks = 7, 686 .irq_bank_map = a100_irq_bank_map, 687 .io_bias_cfg_variant = BIAS_VOLTAGE_PIO_POW_MODE_CTL, 688 }; 689 690 static int a100_pinctrl_probe(struct platform_device *pdev) 691 { 692 return sunxi_pinctrl_init(pdev, &a100_pinctrl_data); 693 } 694 695 static const struct of_device_id a100_pinctrl_match[] = { 696 { .compatible = "allwinner,sun50i-a100-pinctrl", }, 697 {} 698 }; 699 MODULE_DEVICE_TABLE(of, a100_pinctrl_match); 700 701 static struct platform_driver a100_pinctrl_driver = { 702 .probe = a100_pinctrl_probe, 703 .driver = { 704 .name = "sun50i-a100-pinctrl", 705 .of_match_table = a100_pinctrl_match, 706 }, 707 }; 708 module_platform_driver(a100_pinctrl_driver); 709