.. | .. |
---|
1 | 1 | /* |
---|
2 | | - * Allwinner V3s SoCs pinctrl driver. |
---|
| 2 | + * Allwinner V3/V3s SoCs pinctrl driver. |
---|
3 | 3 | * |
---|
4 | 4 | * Copyright (C) 2016 Icenowy Zheng <icenowy@aosc.xyz> |
---|
5 | 5 | * |
---|
.. | .. |
---|
77 | 77 | SUNXI_FUNCTION(0x2, "i2c1"), /* SCK */ |
---|
78 | 78 | SUNXI_FUNCTION(0x3, "uart0"), /* RX */ |
---|
79 | 79 | SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 9)), /* PB_EINT9 */ |
---|
| 80 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(B, 10), |
---|
| 81 | + PINCTRL_SUN8I_V3, |
---|
| 82 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 83 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 84 | + SUNXI_FUNCTION(0x2, "jtag"), /* MS */ |
---|
| 85 | + SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 10)), /* PB_EINT10 */ |
---|
| 86 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(B, 11), |
---|
| 87 | + PINCTRL_SUN8I_V3, |
---|
| 88 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 89 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 90 | + SUNXI_FUNCTION(0x2, "jtag"), /* CK */ |
---|
| 91 | + SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 11)), /* PB_EINT11 */ |
---|
| 92 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(B, 12), |
---|
| 93 | + PINCTRL_SUN8I_V3, |
---|
| 94 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 95 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 96 | + SUNXI_FUNCTION(0x2, "jtag"), /* DO */ |
---|
| 97 | + SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 12)), /* PB_EINT12 */ |
---|
| 98 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(B, 13), |
---|
| 99 | + PINCTRL_SUN8I_V3, |
---|
| 100 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 101 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 102 | + SUNXI_FUNCTION(0x2, "jtag"), /* DI */ |
---|
| 103 | + SUNXI_FUNCTION_IRQ_BANK(0x6, 0, 13)), /* PB_EINT13 */ |
---|
80 | 104 | /* Hole */ |
---|
81 | 105 | SUNXI_PIN(SUNXI_PINCTRL_PIN(C, 0), |
---|
82 | 106 | SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
.. | .. |
---|
98 | 122 | SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
99 | 123 | SUNXI_FUNCTION(0x2, "mmc2"), /* D0 */ |
---|
100 | 124 | SUNXI_FUNCTION(0x3, "spi0")), /* MOSI */ |
---|
| 125 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(C, 4), |
---|
| 126 | + PINCTRL_SUN8I_V3, |
---|
| 127 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 128 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 129 | + SUNXI_FUNCTION(0x2, "mmc2")), /* D1 */ |
---|
| 130 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(C, 5), |
---|
| 131 | + PINCTRL_SUN8I_V3, |
---|
| 132 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 133 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 134 | + SUNXI_FUNCTION(0x2, "mmc2")), /* D2 */ |
---|
| 135 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(C, 6), |
---|
| 136 | + PINCTRL_SUN8I_V3, |
---|
| 137 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 138 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 139 | + SUNXI_FUNCTION(0x2, "mmc2")), /* D3 */ |
---|
| 140 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(C, 7), |
---|
| 141 | + PINCTRL_SUN8I_V3, |
---|
| 142 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 143 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 144 | + SUNXI_FUNCTION(0x2, "mmc2")), /* D4 */ |
---|
| 145 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(C, 8), |
---|
| 146 | + PINCTRL_SUN8I_V3, |
---|
| 147 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 148 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 149 | + SUNXI_FUNCTION(0x2, "mmc2")), /* D5 */ |
---|
| 150 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(C, 9), |
---|
| 151 | + PINCTRL_SUN8I_V3, |
---|
| 152 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 153 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 154 | + SUNXI_FUNCTION(0x2, "mmc2")), /* D6 */ |
---|
| 155 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(C, 10), |
---|
| 156 | + PINCTRL_SUN8I_V3, |
---|
| 157 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 158 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 159 | + SUNXI_FUNCTION(0x2, "mmc2")), /* D7 */ |
---|
| 160 | + /* Hole */ |
---|
| 161 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 0), |
---|
| 162 | + PINCTRL_SUN8I_V3, |
---|
| 163 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 164 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 165 | + SUNXI_FUNCTION(0x2, "lcd"), /* D2 */ |
---|
| 166 | + SUNXI_FUNCTION(0x4, "emac")), /* RXD3 */ |
---|
| 167 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 1), |
---|
| 168 | + PINCTRL_SUN8I_V3, |
---|
| 169 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 170 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 171 | + SUNXI_FUNCTION(0x2, "lcd"), /* D3 */ |
---|
| 172 | + SUNXI_FUNCTION(0x4, "emac")), /* RXD2 */ |
---|
| 173 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 2), |
---|
| 174 | + PINCTRL_SUN8I_V3, |
---|
| 175 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 176 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 177 | + SUNXI_FUNCTION(0x2, "lcd"), /* D4 */ |
---|
| 178 | + SUNXI_FUNCTION(0x4, "emac")), /* RXD1 */ |
---|
| 179 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 3), |
---|
| 180 | + PINCTRL_SUN8I_V3, |
---|
| 181 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 182 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 183 | + SUNXI_FUNCTION(0x2, "lcd"), /* D5 */ |
---|
| 184 | + SUNXI_FUNCTION(0x4, "emac")), /* RXD0 */ |
---|
| 185 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 4), |
---|
| 186 | + PINCTRL_SUN8I_V3, |
---|
| 187 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 188 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 189 | + SUNXI_FUNCTION(0x2, "lcd"), /* D6 */ |
---|
| 190 | + SUNXI_FUNCTION(0x4, "emac")), /* RXCK */ |
---|
| 191 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 5), |
---|
| 192 | + PINCTRL_SUN8I_V3, |
---|
| 193 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 194 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 195 | + SUNXI_FUNCTION(0x2, "lcd"), /* D7 */ |
---|
| 196 | + SUNXI_FUNCTION(0x4, "emac")), /* RXCTL/RXDV */ |
---|
| 197 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 6), |
---|
| 198 | + PINCTRL_SUN8I_V3, |
---|
| 199 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 200 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 201 | + SUNXI_FUNCTION(0x2, "lcd"), /* D10 */ |
---|
| 202 | + SUNXI_FUNCTION(0x4, "emac")), /* RXERR */ |
---|
| 203 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 7), |
---|
| 204 | + PINCTRL_SUN8I_V3, |
---|
| 205 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 206 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 207 | + SUNXI_FUNCTION(0x2, "lcd"), /* D11 */ |
---|
| 208 | + SUNXI_FUNCTION(0x4, "emac")), /* TXD3 */ |
---|
| 209 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 8), |
---|
| 210 | + PINCTRL_SUN8I_V3, |
---|
| 211 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 212 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 213 | + SUNXI_FUNCTION(0x2, "lcd"), /* D12 */ |
---|
| 214 | + SUNXI_FUNCTION(0x4, "emac")), /* TXD2 */ |
---|
| 215 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 9), |
---|
| 216 | + PINCTRL_SUN8I_V3, |
---|
| 217 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 218 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 219 | + SUNXI_FUNCTION(0x2, "lcd"), /* D13 */ |
---|
| 220 | + SUNXI_FUNCTION(0x4, "emac")), /* TXD1 */ |
---|
| 221 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 10), |
---|
| 222 | + PINCTRL_SUN8I_V3, |
---|
| 223 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 224 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 225 | + SUNXI_FUNCTION(0x2, "lcd"), /* D14 */ |
---|
| 226 | + SUNXI_FUNCTION(0x4, "emac")), /* TXD0 */ |
---|
| 227 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 11), |
---|
| 228 | + PINCTRL_SUN8I_V3, |
---|
| 229 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 230 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 231 | + SUNXI_FUNCTION(0x2, "lcd"), /* D15 */ |
---|
| 232 | + SUNXI_FUNCTION(0x4, "emac")), /* CRS */ |
---|
| 233 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 12), |
---|
| 234 | + PINCTRL_SUN8I_V3, |
---|
| 235 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 236 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 237 | + SUNXI_FUNCTION(0x2, "lcd"), /* D18 */ |
---|
| 238 | + SUNXI_FUNCTION(0x3, "lvds"), /* VP0 */ |
---|
| 239 | + SUNXI_FUNCTION(0x4, "emac")), /* TXCK */ |
---|
| 240 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 13), |
---|
| 241 | + PINCTRL_SUN8I_V3, |
---|
| 242 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 243 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 244 | + SUNXI_FUNCTION(0x2, "lcd"), /* D19 */ |
---|
| 245 | + SUNXI_FUNCTION(0x3, "lvds"), /* VN0 */ |
---|
| 246 | + SUNXI_FUNCTION(0x4, "emac")), /* TXCTL/TXEN */ |
---|
| 247 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 14), |
---|
| 248 | + PINCTRL_SUN8I_V3, |
---|
| 249 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 250 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 251 | + SUNXI_FUNCTION(0x2, "lcd"), /* D20 */ |
---|
| 252 | + SUNXI_FUNCTION(0x3, "lvds"), /* VP1 */ |
---|
| 253 | + SUNXI_FUNCTION(0x4, "emac")), /* TXERR */ |
---|
| 254 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 15), |
---|
| 255 | + PINCTRL_SUN8I_V3, |
---|
| 256 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 257 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 258 | + SUNXI_FUNCTION(0x2, "lcd"), /* D21 */ |
---|
| 259 | + SUNXI_FUNCTION(0x3, "lvds"), /* VN1 */ |
---|
| 260 | + SUNXI_FUNCTION(0x4, "emac")), /* CLKIN/COL */ |
---|
| 261 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 16), |
---|
| 262 | + PINCTRL_SUN8I_V3, |
---|
| 263 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 264 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 265 | + SUNXI_FUNCTION(0x2, "lcd"), /* D22 */ |
---|
| 266 | + SUNXI_FUNCTION(0x3, "lvds"), /* VP2 */ |
---|
| 267 | + SUNXI_FUNCTION(0x4, "emac")), /* MDC */ |
---|
| 268 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 17), |
---|
| 269 | + PINCTRL_SUN8I_V3, |
---|
| 270 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 271 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 272 | + SUNXI_FUNCTION(0x2, "lcd"), /* D23 */ |
---|
| 273 | + SUNXI_FUNCTION(0x3, "lvds"), /* VN2 */ |
---|
| 274 | + SUNXI_FUNCTION(0x4, "emac")), /* MDIO */ |
---|
| 275 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 18), |
---|
| 276 | + PINCTRL_SUN8I_V3, |
---|
| 277 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 278 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 279 | + SUNXI_FUNCTION(0x2, "lcd"), /* CLK */ |
---|
| 280 | + SUNXI_FUNCTION(0x3, "lvds")), /* VPC */ |
---|
| 281 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 19), |
---|
| 282 | + PINCTRL_SUN8I_V3, |
---|
| 283 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 284 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 285 | + SUNXI_FUNCTION(0x2, "lcd"), /* DE */ |
---|
| 286 | + SUNXI_FUNCTION(0x3, "lvds")), /* VNC */ |
---|
| 287 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 20), |
---|
| 288 | + PINCTRL_SUN8I_V3, |
---|
| 289 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 290 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 291 | + SUNXI_FUNCTION(0x2, "lcd"), /* HSYNC */ |
---|
| 292 | + SUNXI_FUNCTION(0x3, "lvds")), /* VP3 */ |
---|
| 293 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(D, 21), |
---|
| 294 | + PINCTRL_SUN8I_V3, |
---|
| 295 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 296 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 297 | + SUNXI_FUNCTION(0x2, "lcd"), /* VSYNC */ |
---|
| 298 | + SUNXI_FUNCTION(0x3, "lvds")), /* VN3 */ |
---|
101 | 299 | /* Hole */ |
---|
102 | 300 | SUNXI_PIN(SUNXI_PINCTRL_PIN(E, 0), |
---|
103 | 301 | SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
.. | .. |
---|
291 | 489 | SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
292 | 490 | SUNXI_FUNCTION(0x2, "mmc1"), /* D3 */ |
---|
293 | 491 | SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 5)), /* PG_EINT5 */ |
---|
| 492 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(G, 6), |
---|
| 493 | + PINCTRL_SUN8I_V3, |
---|
| 494 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 495 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 496 | + SUNXI_FUNCTION(0x2, "uart1"), /* TX */ |
---|
| 497 | + SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 6)), /* PG_EINT6 */ |
---|
| 498 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(G, 7), |
---|
| 499 | + PINCTRL_SUN8I_V3, |
---|
| 500 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 501 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 502 | + SUNXI_FUNCTION(0x2, "uart1"), /* RX */ |
---|
| 503 | + SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 7)), /* PG_EINT7 */ |
---|
| 504 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(G, 8), |
---|
| 505 | + PINCTRL_SUN8I_V3, |
---|
| 506 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 507 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 508 | + SUNXI_FUNCTION(0x2, "uart1"), /* RTS */ |
---|
| 509 | + SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 8)), /* PG_EINT8 */ |
---|
| 510 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(G, 9), |
---|
| 511 | + PINCTRL_SUN8I_V3, |
---|
| 512 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 513 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 514 | + SUNXI_FUNCTION(0x2, "uart1"), /* CTS */ |
---|
| 515 | + SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 9)), /* PG_EINT9 */ |
---|
| 516 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(G, 10), |
---|
| 517 | + PINCTRL_SUN8I_V3, |
---|
| 518 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 519 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 520 | + SUNXI_FUNCTION(0x2, "i2s"), /* SYNC */ |
---|
| 521 | + SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 10)), /* PG_EINT10 */ |
---|
| 522 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(G, 11), |
---|
| 523 | + PINCTRL_SUN8I_V3, |
---|
| 524 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 525 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 526 | + SUNXI_FUNCTION(0x2, "i2s"), /* BCLK */ |
---|
| 527 | + SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 11)), /* PG_EINT11 */ |
---|
| 528 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(G, 12), |
---|
| 529 | + PINCTRL_SUN8I_V3, |
---|
| 530 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 531 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 532 | + SUNXI_FUNCTION(0x2, "i2s"), /* DOUT */ |
---|
| 533 | + SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 12)), /* PG_EINT12 */ |
---|
| 534 | + SUNXI_PIN_VARIANT(SUNXI_PINCTRL_PIN(G, 13), |
---|
| 535 | + PINCTRL_SUN8I_V3, |
---|
| 536 | + SUNXI_FUNCTION(0x0, "gpio_in"), |
---|
| 537 | + SUNXI_FUNCTION(0x1, "gpio_out"), |
---|
| 538 | + SUNXI_FUNCTION(0x2, "i2s"), /* DIN */ |
---|
| 539 | + SUNXI_FUNCTION_IRQ_BANK(0x6, 1, 13)), /* PG_EINT13 */ |
---|
294 | 540 | }; |
---|
295 | 541 | |
---|
296 | 542 | static const unsigned int sun8i_v3s_pinctrl_irq_bank_map[] = { 1, 2 }; |
---|
.. | .. |
---|
305 | 551 | |
---|
306 | 552 | static int sun8i_v3s_pinctrl_probe(struct platform_device *pdev) |
---|
307 | 553 | { |
---|
308 | | - return sunxi_pinctrl_init(pdev, |
---|
309 | | - &sun8i_v3s_pinctrl_data); |
---|
| 554 | + unsigned long variant = (unsigned long)of_device_get_match_data(&pdev->dev); |
---|
| 555 | + |
---|
| 556 | + return sunxi_pinctrl_init_with_variant(pdev, &sun8i_v3s_pinctrl_data, |
---|
| 557 | + variant); |
---|
310 | 558 | } |
---|
311 | 559 | |
---|
312 | 560 | static const struct of_device_id sun8i_v3s_pinctrl_match[] = { |
---|
313 | | - { .compatible = "allwinner,sun8i-v3s-pinctrl", }, |
---|
314 | | - {} |
---|
| 561 | + { |
---|
| 562 | + .compatible = "allwinner,sun8i-v3-pinctrl", |
---|
| 563 | + .data = (void *)PINCTRL_SUN8I_V3 |
---|
| 564 | + }, |
---|
| 565 | + { |
---|
| 566 | + .compatible = "allwinner,sun8i-v3s-pinctrl", |
---|
| 567 | + .data = (void *)PINCTRL_SUN8I_V3S |
---|
| 568 | + }, |
---|
| 569 | + { }, |
---|
315 | 570 | }; |
---|
316 | 571 | |
---|
317 | 572 | static struct platform_driver sun8i_v3s_pinctrl_driver = { |
---|