1 # SPDX-FileCopyrightText: 2022 ShangYun
 
   3 # SPDX-License-Identifier: MIT
 
   4 """A Pin class for use with Rockchip RK3588."""
 
   6 from adafruit_blinka.microcontroller.generic_linux.libgpiod_pin import Pin
 
   8 # GPIOx_yz = x * 32 + y * 8 + z
 
   9 # y: A -> 0, B -> 1, C -> 2, D -> 3
 
  11 GPIO0_A0 = Pin((0, 0))
 
  12 GPIO0_A1 = Pin((0, 1))
 
  13 GPIO0_A2 = Pin((0, 2))
 
  14 GPIO0_A3 = Pin((0, 3))
 
  15 GPIO0_A4 = Pin((0, 4))
 
  16 GPIO0_A5 = Pin((0, 5))
 
  17 GPIO0_A6 = Pin((0, 6))
 
  18 GPIO0_A7 = Pin((0, 7))
 
  19 GPIO0_B0 = Pin((0, 8))
 
  20 GPIO0_B1 = Pin((0, 9))
 
  21 GPIO0_B2 = Pin((0, 10))
 
  22 GPIO0_B3 = Pin((0, 11))
 
  23 GPIO0_B4 = Pin((0, 12))
 
  24 GPIO0_B5 = Pin((0, 13))
 
  25 GPIO0_B6 = Pin((0, 14))
 
  26 GPIO0_B7 = Pin((0, 15))
 
  27 GPIO0_C0 = Pin((0, 16))
 
  28 GPIO0_C1 = Pin((0, 17))
 
  29 GPIO0_C2 = Pin((0, 18))
 
  30 GPIO0_C3 = Pin((0, 19))
 
  31 GPIO0_C4 = Pin((0, 20))
 
  32 GPIO0_C5 = Pin((0, 21))
 
  33 GPIO0_C6 = Pin((0, 22))
 
  34 GPIO0_C7 = Pin((0, 23))
 
  35 GPIO0_D0 = Pin((0, 24))
 
  36 GPIO0_D1 = Pin((0, 25))
 
  37 GPIO0_D2 = Pin((0, 26))
 
  38 GPIO0_D3 = Pin((0, 27))
 
  39 GPIO0_D4 = Pin((0, 28))
 
  40 GPIO0_D5 = Pin((0, 29))
 
  41 GPIO0_D6 = Pin((0, 30))
 
  42 GPIO0_D7 = Pin((0, 31))
 
  44 GPIO1_A0 = Pin((1, 0))
 
  45 GPIO1_A1 = Pin((1, 1))
 
  46 GPIO1_A2 = Pin((1, 2))
 
  47 GPIO1_A3 = Pin((1, 3))
 
  48 GPIO1_A4 = Pin((1, 4))
 
  49 GPIO1_A5 = Pin((1, 5))
 
  50 GPIO1_A6 = Pin((1, 6))
 
  51 GPIO1_A7 = Pin((1, 7))
 
  52 GPIO1_B0 = Pin((1, 8))
 
  53 GPIO1_B1 = Pin((1, 9))
 
  54 GPIO1_B2 = Pin((1, 10))
 
  55 GPIO1_B3 = Pin((1, 11))
 
  56 GPIO1_B4 = Pin((1, 12))
 
  57 GPIO1_B5 = Pin((1, 13))
 
  58 GPIO1_B6 = Pin((1, 14))
 
  59 GPIO1_B7 = Pin((1, 15))
 
  60 GPIO1_C0 = Pin((1, 16))
 
  61 GPIO1_C1 = Pin((1, 17))
 
  62 GPIO1_C2 = Pin((1, 18))
 
  63 GPIO1_C3 = Pin((1, 19))
 
  64 GPIO1_C4 = Pin((1, 20))
 
  65 GPIO1_C5 = Pin((1, 21))
 
  66 GPIO1_C6 = Pin((1, 22))
 
  67 GPIO1_C7 = Pin((1, 23))
 
  68 GPIO1_D0 = Pin((1, 24))
 
  69 GPIO1_D1 = Pin((1, 25))
 
  70 GPIO1_D2 = Pin((1, 26))
 
  71 GPIO1_D3 = Pin((1, 27))
 
  72 GPIO1_D4 = Pin((1, 28))
 
  73 GPIO1_D5 = Pin((1, 29))
 
  74 GPIO1_D6 = Pin((1, 30))
 
  75 GPIO1_D7 = Pin((1, 31))
 
  77 GPIO2_A0 = Pin((2, 0))
 
  78 GPIO2_A1 = Pin((2, 1))
 
  79 GPIO2_A2 = Pin((2, 2))
 
  80 GPIO2_A3 = Pin((2, 3))
 
  81 GPIO2_A4 = Pin((2, 4))
 
  82 GPIO2_A5 = Pin((2, 5))
 
  83 GPIO2_A6 = Pin((2, 6))
 
  84 GPIO2_A7 = Pin((2, 7))
 
  85 GPIO2_B0 = Pin((2, 8))
 
  86 GPIO2_B1 = Pin((2, 9))
 
  87 GPIO2_B2 = Pin((2, 10))
 
  88 GPIO2_B3 = Pin((2, 11))
 
  89 GPIO2_B4 = Pin((2, 12))
 
  90 GPIO2_B5 = Pin((2, 13))
 
  91 GPIO2_B6 = Pin((2, 14))
 
  92 GPIO2_B7 = Pin((2, 15))
 
  93 GPIO2_C0 = Pin((2, 16))
 
  94 GPIO2_C1 = Pin((2, 17))
 
  95 GPIO2_C2 = Pin((2, 18))
 
  96 GPIO2_C3 = Pin((2, 19))
 
  97 GPIO2_C4 = Pin((2, 20))
 
  98 GPIO2_C5 = Pin((2, 21))
 
  99 GPIO2_C6 = Pin((2, 22))
 
 100 GPIO2_C7 = Pin((2, 23))
 
 101 GPIO2_D0 = Pin((2, 24))
 
 102 GPIO2_D1 = Pin((2, 25))
 
 103 GPIO2_D2 = Pin((2, 26))
 
 104 GPIO2_D3 = Pin((2, 27))
 
 105 GPIO2_D4 = Pin((2, 28))
 
 106 GPIO2_D5 = Pin((2, 29))
 
 107 GPIO2_D6 = Pin((2, 30))
 
 108 GPIO2_D7 = Pin((2, 31))
 
 110 GPIO3_A0 = Pin((3, 0))
 
 111 GPIO3_A1 = Pin((3, 1))
 
 112 GPIO3_A2 = Pin((3, 2))
 
 113 GPIO3_A3 = Pin((3, 3))
 
 114 GPIO3_A4 = Pin((3, 4))
 
 115 GPIO3_A5 = Pin((3, 5))
 
 116 GPIO3_A6 = Pin((3, 6))
 
 117 GPIO3_A7 = Pin((3, 7))
 
 118 GPIO3_B0 = Pin((3, 8))
 
 119 GPIO3_B1 = Pin((3, 9))
 
 120 GPIO3_B2 = Pin((3, 10))
 
 121 GPIO3_B3 = Pin((3, 11))
 
 122 GPIO3_B4 = Pin((3, 12))
 
 123 GPIO3_B5 = Pin((3, 13))
 
 124 GPIO3_B6 = Pin((3, 14))
 
 125 GPIO3_B7 = Pin((3, 15))
 
 126 GPIO3_C0 = Pin((3, 16))
 
 127 GPIO3_C1 = Pin((3, 17))
 
 128 GPIO3_C2 = Pin((3, 18))
 
 129 GPIO3_C3 = Pin((3, 19))
 
 130 GPIO3_C4 = Pin((3, 20))
 
 131 GPIO3_C5 = Pin((3, 21))
 
 132 GPIO3_C6 = Pin((3, 22))
 
 133 GPIO3_C7 = Pin((3, 23))
 
 134 GPIO3_D0 = Pin((3, 24))
 
 135 GPIO3_D1 = Pin((3, 25))
 
 136 GPIO3_D2 = Pin((3, 26))
 
 137 GPIO3_D3 = Pin((3, 27))
 
 138 GPIO3_D4 = Pin((3, 28))
 
 139 GPIO3_D5 = Pin((3, 29))
 
 140 GPIO3_D6 = Pin((3, 30))
 
 141 GPIO3_D7 = Pin((3, 31))
 
 143 GPIO4_A0 = Pin((4, 0))
 
 144 GPIO4_A1 = Pin((4, 1))
 
 145 GPIO4_A2 = Pin((4, 2))
 
 146 GPIO4_A3 = Pin((4, 3))
 
 147 GPIO4_A4 = Pin((4, 4))
 
 148 GPIO4_A5 = Pin((4, 5))
 
 149 GPIO4_A6 = Pin((4, 6))
 
 150 GPIO4_A7 = Pin((4, 7))
 
 151 GPIO4_B0 = Pin((4, 8))
 
 152 GPIO4_B1 = Pin((4, 9))
 
 153 GPIO4_B2 = Pin((4, 10))
 
 154 GPIO4_B3 = Pin((4, 11))
 
 155 GPIO4_B4 = Pin((4, 12))
 
 156 GPIO4_B5 = Pin((4, 13))
 
 157 GPIO4_B6 = Pin((4, 14))
 
 158 GPIO4_B7 = Pin((4, 15))
 
 159 GPIO4_C0 = Pin((4, 16))
 
 160 GPIO4_C1 = Pin((4, 17))
 
 161 GPIO4_C2 = Pin((4, 18))
 
 162 GPIO4_C3 = Pin((4, 19))
 
 163 GPIO4_C4 = Pin((4, 20))
 
 164 GPIO4_C5 = Pin((4, 21))
 
 165 GPIO4_C6 = Pin((4, 22))
 
 166 GPIO4_C7 = Pin((4, 23))
 
 167 GPIO4_D0 = Pin((4, 24))
 
 168 GPIO4_D1 = Pin((4, 25))
 
 169 GPIO4_D2 = Pin((4, 26))
 
 170 GPIO4_D3 = Pin((4, 27))
 
 171 GPIO4_D4 = Pin((4, 28))
 
 172 GPIO4_D5 = Pin((4, 29))
 
 173 GPIO4_D6 = Pin((4, 30))
 
 174 GPIO4_D7 = Pin((4, 31))
 
 178 UART0_TX_M0 = GPIO0_C5
 
 179 UART0_RX_M0 = GPIO0_C4
 
 180 UART0_TX_M1 = GPIO0_B1
 
 181 UART0_RX_M1 = GPIO0_B0
 
 182 UART0_TX_M2 = GPIO4_A3
 
 183 UART0_RX_M2 = GPIO4_A4
 
 184 UART1_TX_M0 = GPIO2_B7
 
 185 UART1_RX_M0 = GPIO2_B6
 
 186 UART1_TX_M1 = GPIO1_B6
 
 187 UART1_RX_M1 = GPIO1_B7
 
 188 UART1_TX_M2 = GPIO0_D1
 
 189 UART1_RX_M2 = GPIO0_D2
 
 190 UART2_TX_M0 = GPIO0_B5
 
 191 UART2_RX_M0 = GPIO0_B6
 
 192 UART2_TX_M1 = GPIO0_D0
 
 193 UART2_RX_M1 = GPIO0_D1
 
 194 UART2_TX_M2 = GPIO3_B1
 
 195 UART2_RX_M2 = GPIO3_B2
 
 196 UART3_TX_M0 = GPIO1_C1
 
 197 UART3_RX_M0 = GPIO1_C0
 
 198 UART3_TX_M1 = GPIO3_B5
 
 199 UART3_RX_M1 = GPIO3_B6
 
 200 UART3_TX_M2 = GPIO4_A5
 
 201 UART3_RX_M2 = GPIO4_A6
 
 202 UART4_TX_M0 = GPIO1_D2
 
 203 UART4_RX_M0 = GPIO1_D3
 
 204 UART4_TX_M1 = GPIO3_D1
 
 205 UART4_RX_M1 = GPIO3_D0
 
 206 UART4_TX_M2 = GPIO1_B3
 
 207 UART4_RX_M2 = GPIO1_B2
 
 208 UART5_TX_M0 = GPIO4_D5
 
 209 UART5_RX_M0 = GPIO4_D4
 
 210 UART5_TX_M1 = GPIO3_C4
 
 211 UART5_RX_M1 = GPIO3_C5
 
 212 UART5_TX_M2 = GPIO2_D5
 
 213 UART5_RX_M2 = GPIO2_D4
 
 214 UART6_TX_M0 = GPIO2_A7
 
 215 UART6_RX_M0 = GPIO2_A6
 
 216 UART6_TX_M1 = GPIO1_A1
 
 217 UART6_RX_M1 = GPIO1_A0
 
 218 UART6_TX_M2 = GPIO1_D0
 
 219 UART6_RX_M2 = GPIO1_D1
 
 220 UART7_TX_M0 = GPIO2_B5
 
 221 UART7_RX_M0 = GPIO2_B4
 
 222 UART7_TX_M1 = GPIO3_C0
 
 223 UART7_RX_M1 = GPIO3_C1
 
 224 UART7_TX_M2 = GPIO1_B5
 
 225 UART7_RX_M2 = GPIO1_B4
 
 226 UART8_TX_M0 = GPIO4_B0
 
 227 UART8_RX_M0 = GPIO4_B1
 
 228 UART8_TX_M1 = GPIO3_A2
 
 229 UART8_RX_M1 = GPIO3_A3
 
 230 UART9_TX_M0 = GPIO2_C2
 
 231 UART9_RX_M0 = GPIO2_C4
 
 232 UART9_TX_M1 = GPIO4_B4
 
 233 UART9_RX_M1 = GPIO4_B5
 
 234 UART9_TX_M2 = GPIO3_D5
 
 235 UART9_RX_M2 = GPIO3_D4
 
 237 # ordered as uartId, txId, rxId
 
 239     (0, UART0_TX_M0, UART0_RX_M0),
 
 240     (0, UART0_TX_M1, UART0_RX_M1),
 
 241     (0, UART0_TX_M2, UART0_RX_M2),
 
 242     (1, UART1_TX_M0, UART1_RX_M0),
 
 243     (1, UART1_TX_M1, UART1_RX_M1),
 
 244     (1, UART1_TX_M2, UART1_RX_M2),
 
 245     (2, UART2_TX_M0, UART2_RX_M0),
 
 246     (2, UART2_TX_M1, UART2_RX_M1),
 
 247     (2, UART2_TX_M2, UART2_RX_M2),
 
 248     (3, UART3_TX_M0, UART3_RX_M0),
 
 249     (3, UART3_TX_M1, UART3_RX_M1),
 
 250     (3, UART3_TX_M2, UART3_RX_M2),
 
 251     (4, UART4_TX_M0, UART4_RX_M0),
 
 252     (4, UART4_TX_M1, UART4_RX_M1),
 
 253     (4, UART4_TX_M2, UART4_RX_M2),
 
 254     (5, UART5_TX_M0, UART5_RX_M0),
 
 255     (5, UART5_TX_M1, UART5_RX_M1),
 
 256     (5, UART5_TX_M2, UART5_RX_M2),
 
 257     (6, UART6_TX_M0, UART6_RX_M0),
 
 258     (6, UART6_TX_M1, UART6_RX_M1),
 
 259     (6, UART6_TX_M2, UART6_RX_M2),
 
 260     (7, UART7_TX_M0, UART7_RX_M0),
 
 261     (7, UART7_TX_M1, UART7_RX_M1),
 
 262     (7, UART7_TX_M2, UART7_RX_M2),
 
 263     (8, UART8_TX_M0, UART8_RX_M0),
 
 264     (8, UART8_TX_M1, UART8_RX_M1),
 
 265     (9, UART9_TX_M0, UART9_RX_M0),
 
 266     (9, UART9_TX_M1, UART9_RX_M1),
 
 267     (9, UART9_TX_M2, UART9_RX_M2),
 
 272 I2C0_SCL_M0 = GPIO0_B3
 
 273 I2C0_SDA_M0 = GPIO0_A6
 
 274 I2C0_SCL_M1 = GPIO4_C5
 
 275 I2C0_SDA_M1 = GPIO4_C6
 
 276 I2C0_SCL_M2 = GPIO0_D1
 
 277 I2C0_SDA_M2 = GPIO0_D2
 
 278 I2C1_SCL_M0 = GPIO0_B5
 
 279 I2C1_SDA_M0 = GPIO0_B6
 
 280 I2C1_SCL_M1 = GPIO0_B0
 
 281 I2C1_SDA_M1 = GPIO0_B1
 
 282 I2C1_SCL_M2 = GPIO0_D4
 
 283 I2C1_SDA_M2 = GPIO0_D5
 
 284 I2C1_SCL_M3 = GPIO2_D4
 
 285 I2C1_SDA_M3 = GPIO2_D5
 
 286 I2C1_SCL_M4 = GPIO1_B1
 
 287 I2C1_SDA_M4 = GPIO1_B2
 
 288 I2C2_SCL_M0 = GPIO0_B7
 
 289 I2C2_SDA_M0 = GPIO0_C0
 
 290 I2C2_SCL_M1 = GPIO2_C1
 
 291 I2C2_SDA_M1 = GPIO2_C0
 
 292 I2C2_SCL_M2 = GPIO2_A3
 
 293 I2C2_SDA_M2 = GPIO2_A2
 
 294 I2C2_SCL_M3 = GPIO1_C5
 
 295 I2C2_SDA_M3 = GPIO1_C4
 
 296 I2C2_SCL_M4 = GPIO1_A1
 
 297 I2C2_SDA_M4 = GPIO1_A0
 
 298 I2C3_SCL_M0 = GPIO1_C1
 
 299 I2C3_SDA_M0 = GPIO1_C0
 
 300 I2C3_SCL_M1 = GPIO3_B7
 
 301 I2C3_SDA_M1 = GPIO3_C0
 
 302 I2C3_SCL_M2 = GPIO4_A4
 
 303 I2C3_SDA_M2 = GPIO4_A5
 
 304 I2C3_SCL_M3 = GPIO2_B2
 
 305 I2C3_SDA_M3 = GPIO2_B3
 
 306 I2C3_SCL_M4 = GPIO4_D0
 
 307 I2C3_SDA_M4 = GPIO4_D1
 
 308 I2C4_SCL_M0 = GPIO3_A6
 
 309 I2C4_SDA_M0 = GPIO3_A5
 
 310 I2C4_SCL_M1 = GPIO2_B5
 
 311 I2C4_SDA_M1 = GPIO2_B4
 
 312 I2C4_SCL_M2 = GPIO0_C5
 
 313 I2C4_SDA_M2 = GPIO0_C4
 
 314 I2C4_SCL_M3 = GPIO1_A3
 
 315 I2C4_SDA_M3 = GPIO1_A2
 
 316 I2C4_SCL_M4 = GPIO1_C7
 
 317 I2C4_SDA_M4 = GPIO1_C6
 
 318 I2C5_SCL_M0 = GPIO3_C7
 
 319 I2C5_SDA_M0 = GPIO3_D0
 
 320 I2C5_SCL_M1 = GPIO4_B6
 
 321 I2C5_SDA_M1 = GPIO4_B7
 
 322 I2C5_SCL_M2 = GPIO4_A6
 
 323 I2C5_SDA_M2 = GPIO4_A7
 
 324 I2C5_SCL_M3 = GPIO1_B6
 
 325 I2C5_SDA_M3 = GPIO1_B7
 
 326 I2C5_SCL_M4 = GPIO2_B6
 
 327 I2C5_SDA_M4 = GPIO2_B7
 
 328 I2C6_SCL_M0 = GPIO0_D0
 
 329 I2C6_SDA_M0 = GPIO0_C7
 
 330 I2C6_SCL_M1 = GPIO1_C3
 
 331 I2C6_SDA_M1 = GPIO1_C2
 
 332 I2C6_SCL_M2 = GPIO2_C3
 
 333 I2C6_SDA_M2 = GPIO2_C2
 
 334 I2C6_SCL_M3 = GPIO4_B1
 
 335 I2C6_SDA_M3 = GPIO4_B0
 
 336 I2C6_SCL_M4 = GPIO3_A1
 
 337 I2C6_SDA_M4 = GPIO3_A0
 
 338 I2C7_SCL_M0 = GPIO1_D0
 
 339 I2C7_SDA_M0 = GPIO1_D1
 
 340 I2C7_SCL_M1 = GPIO4_C3
 
 341 I2C7_SDA_M1 = GPIO4_C4
 
 342 I2C7_SCL_M2 = GPIO3_D2
 
 343 I2C7_SDA_M2 = GPIO3_D3
 
 344 I2C7_SCL_M3 = GPIO4_B2
 
 345 I2C7_SDA_M3 = GPIO4_B3
 
 346 I2C8_SCL_M0 = GPIO4_D2
 
 347 I2C8_SDA_M0 = GPIO4_D3
 
 348 I2C8_SCL_M1 = GPIO2_B0
 
 349 I2C8_SDA_M1 = GPIO2_B1
 
 350 I2C8_SCL_M2 = GPIO1_D6
 
 351 I2C8_SDA_M2 = GPIO1_D7
 
 352 I2C8_SCL_M3 = GPIO4_C0
 
 353 I2C8_SDA_M3 = GPIO4_C1
 
 354 I2C8_SCL_M4 = GPIO3_C2
 
 355 I2C8_SDA_M4 = GPIO3_C3
 
 357 # ordered as i2cId, sclId, sdaId
 
 359     (0, I2C0_SCL_M0, I2C0_SDA_M0),
 
 360     (0, I2C0_SCL_M1, I2C0_SDA_M1),
 
 361     (0, I2C0_SCL_M2, I2C0_SDA_M2),
 
 362     (1, I2C1_SCL_M0, I2C1_SDA_M0),
 
 363     (1, I2C1_SCL_M1, I2C1_SDA_M1),
 
 364     (1, I2C1_SCL_M2, I2C1_SDA_M2),
 
 365     (1, I2C1_SCL_M3, I2C1_SDA_M3),
 
 366     (1, I2C1_SCL_M4, I2C1_SDA_M4),
 
 367     (2, I2C2_SCL_M0, I2C2_SDA_M0),
 
 368     (2, I2C2_SCL_M1, I2C2_SDA_M1),
 
 369     (2, I2C2_SCL_M2, I2C2_SDA_M2),
 
 370     (2, I2C2_SCL_M3, I2C2_SDA_M3),
 
 371     (2, I2C2_SCL_M4, I2C2_SDA_M4),
 
 372     (3, I2C3_SCL_M0, I2C3_SDA_M0),
 
 373     (3, I2C3_SCL_M1, I2C3_SDA_M1),
 
 374     (3, I2C3_SCL_M2, I2C3_SDA_M2),
 
 375     (3, I2C3_SCL_M3, I2C3_SDA_M3),
 
 376     (3, I2C3_SCL_M4, I2C3_SDA_M4),
 
 377     (4, I2C4_SCL_M0, I2C4_SDA_M0),
 
 378     (4, I2C4_SCL_M1, I2C4_SDA_M1),
 
 379     (4, I2C4_SCL_M2, I2C4_SDA_M2),
 
 380     (4, I2C4_SCL_M3, I2C4_SDA_M3),
 
 381     (4, I2C4_SCL_M4, I2C4_SDA_M4),
 
 382     (5, I2C5_SCL_M0, I2C5_SDA_M0),
 
 383     (5, I2C5_SCL_M1, I2C5_SDA_M1),
 
 384     (5, I2C5_SCL_M2, I2C5_SDA_M2),
 
 385     (5, I2C5_SCL_M3, I2C5_SDA_M3),
 
 386     (5, I2C5_SCL_M4, I2C5_SDA_M4),
 
 387     (6, I2C6_SCL_M0, I2C6_SDA_M0),
 
 388     (6, I2C6_SCL_M1, I2C6_SDA_M1),
 
 389     (6, I2C6_SCL_M2, I2C6_SDA_M2),
 
 390     (6, I2C6_SCL_M3, I2C6_SDA_M3),
 
 391     (6, I2C6_SCL_M4, I2C6_SDA_M4),
 
 392     (7, I2C7_SCL_M0, I2C7_SDA_M0),
 
 393     (7, I2C7_SCL_M1, I2C7_SDA_M1),
 
 394     (7, I2C7_SCL_M2, I2C7_SDA_M2),
 
 395     (7, I2C7_SCL_M3, I2C7_SDA_M3),
 
 396     (8, I2C8_SCL_M0, I2C8_SDA_M0),
 
 397     (8, I2C8_SCL_M1, I2C8_SDA_M1),
 
 398     (8, I2C8_SCL_M2, I2C8_SDA_M2),
 
 399     (8, I2C8_SCL_M3, I2C8_SDA_M3),
 
 400     (8, I2C8_SCL_M4, I2C8_SDA_M4),
 
 404 SPI0_MOSI_M0 = GPIO0_C0
 
 405 SPI0_MISO_M0 = GPIO0_C7
 
 406 SPI0_CLK_M0 = GPIO0_C6
 
 407 SPI0_SCLK_M0 = SPI0_CLK_M0
 
 408 SPI0_CS0_M0 = GPIO0_D1
 
 409 SPI0_CS1_M0 = GPIO0_B7
 
 411 SPI0_MOSI_M1 = GPIO4_A1
 
 412 SPI0_MISO_M1 = GPIO4_A0
 
 413 SPI0_CLK_M1 = GPIO4_A2
 
 414 SPI0_SCLK_M1 = SPI0_CLK_M1
 
 415 SPI0_CS0_M1 = GPIO4_B2
 
 416 SPI0_CS1_M1 = GPIO4_B1
 
 418 SPI0_MOSI_M2 = GPIO1_B2
 
 419 SPI0_MISO_M2 = GPIO1_B1
 
 420 SPI0_CLK_M2 = GPIO1_B3
 
 421 SPI0_SCLK_M2 = SPI0_CLK_M2
 
 422 SPI0_CS0_M2 = GPIO1_B4
 
 423 SPI0_CS1_M2 = GPIO1_B5
 
 425 SPI0_MOSI_M3 = GPIO3_D2
 
 426 SPI0_MISO_M3 = GPIO3_D1
 
 427 SPI0_CLK_M3 = GPIO3_D3
 
 428 SPI0_SCLK_M3 = SPI0_CLK_M3
 
 429 SPI0_CS0_M3 = GPIO3_D4
 
 430 SPI0_CS1_M3 = GPIO3_D5
 
 432 SPI1_MOSI_M0 = GPIO2_C2
 
 433 SPI1_MISO_M0 = GPIO2_C1
 
 434 SPI1_CLK_M0 = GPIO2_C0
 
 435 SPI1_SCLK_M0 = SPI1_CLK_M0
 
 436 SPI1_CS0_M0 = GPIO2_C3
 
 437 SPI1_CS1_M0 = GPIO2_C4
 
 439 SPI1_MOSI_M1 = GPIO3_B7
 
 440 SPI1_MISO_M1 = GPIO3_C0
 
 441 SPI1_CLK_M1 = GPIO3_C1
 
 442 SPI1_SCLK_M1 = SPI1_CLK_M1
 
 443 SPI1_CS0_M1 = GPIO3_C2
 
 444 SPI1_CS1_M1 = GPIO3_C3
 
 446 SPI1_MOSI_M2 = GPIO1_D1
 
 447 SPI1_MISO_M2 = GPIO1_D0
 
 448 SPI1_CLK_M2 = GPIO1_D2
 
 449 SPI1_SCLK_M2 = SPI1_CLK_M2
 
 450 SPI1_CS0_M2 = GPIO1_D3
 
 451 SPI1_CS1_M2 = GPIO1_D5
 
 453 SPI2_MOSI_M0 = GPIO1_A5
 
 454 SPI2_MISO_M0 = GPIO1_A4
 
 455 SPI2_CLK_M0 = GPIO1_A6
 
 456 SPI2_SCLK_M0 = SPI2_CLK_M0
 
 457 SPI2_CS0_M0 = GPIO1_A7
 
 458 SPI2_CS1_M0 = GPIO1_B0
 
 460 SPI2_MOSI_M1 = GPIO4_A5
 
 461 SPI2_MISO_M1 = GPIO4_A4
 
 462 SPI2_CLK_M1 = GPIO4_A6
 
 463 SPI2_SCLK_M1 = SPI2_CLK_M1
 
 464 SPI2_CS0_M1 = GPIO4_A7
 
 465 SPI2_CS1_M1 = GPIO4_B0
 
 467 SPI2_MOSI_M2 = GPIO0_A6
 
 468 SPI2_MISO_M2 = GPIO0_B3
 
 469 SPI2_CLK_M2 = GPIO0_A5
 
 470 SPI2_SCLK_M2 = SPI2_CLK_M2
 
 471 SPI2_CS0_M2 = GPIO0_B1
 
 472 SPI2_CS1_M2 = GPIO0_B0
 
 474 SPI3_MOSI_M0 = GPIO4_C4
 
 475 SPI3_MISO_M0 = GPIO4_C5
 
 476 SPI3_SCK_M0 = GPIO4_C6
 
 477 SPI3_SCLK_M0 = SPI3_SCK_M0
 
 478 SPI3_CS0_M0 = GPIO4_C2
 
 479 SPI3_CS1_M0 = GPIO4_C3
 
 481 SPI3_MOSI_M1 = GPIO4_B6
 
 482 SPI3_MISO_M1 = GPIO4_B5
 
 483 SPI3_SCK_M1 = GPIO4_B7
 
 484 SPI3_SCLK_M1 = SPI3_SCK_M1
 
 485 SPI3_CS0_M1 = GPIO4_C0
 
 486 SPI3_CS1_M1 = GPIO4_C1
 
 488 SPI3_MOSI_M2 = GPIO0_D2
 
 489 SPI3_MISO_M2 = GPIO0_D0
 
 490 SPI3_SCK_M2 = GPIO0_D3
 
 491 SPI3_SCLK_M2 = SPI3_SCK_M2
 
 492 SPI3_CS0_M2 = GPIO0_D4
 
 493 SPI3_CS1_M2 = GPIO0_D5
 
 495 SPI3_MOSI_M3 = GPIO3_C7
 
 496 SPI3_MISO_M3 = GPIO3_C6
 
 497 SPI3_SCK_M3 = GPIO3_D0
 
 498 SPI3_SCLK_M3 = SPI3_SCK_M3
 
 499 SPI3_CS0_M3 = GPIO3_C4
 
 500 SPI3_CS1_M3 = GPIO3_C5
 
 502 SPI4_MOSI_M0 = GPIO1_C1
 
 503 SPI4_MISO_M0 = GPIO1_C0
 
 504 SPI4_SCK_M0 = GPIO1_C2
 
 505 SPI4_SCLK_M0 = SPI4_SCK_M0
 
 506 SPI4_CS0_M0 = GPIO1_C3
 
 507 SPI4_CS1_M0 = GPIO1_C4
 
 509 SPI4_MOSI_M1 = GPIO3_A1
 
 510 SPI4_MISO_M1 = GPIO3_A0
 
 511 SPI4_SCK_M1 = GPIO3_A2
 
 512 SPI4_SCLK_M1 = SPI4_SCK_M1
 
 513 SPI4_CS0_M1 = GPIO3_A3
 
 514 SPI4_CS1_M1 = GPIO3_A4
 
 516 SPI4_MOSI_M2 = GPIO1_A1
 
 517 SPI4_MISO_M2 = GPIO1_A0
 
 518 SPI4_SCK_M2 = GPIO1_A2
 
 519 SPI4_SCLK_M2 = SPI4_SCK_M2
 
 520 SPI4_CS0_M2 = GPIO1_A3
 
 522 # ordered as spiId, sckId, mosiId, misoId
 
 524     (0, SPI0_SCLK_M0, SPI0_MOSI_M0, SPI0_MISO_M0),
 
 525     (0, SPI0_SCLK_M1, SPI0_MOSI_M1, SPI0_MISO_M1),
 
 526     (0, SPI0_SCLK_M2, SPI0_MOSI_M2, SPI0_MISO_M2),
 
 527     (0, SPI0_SCLK_M3, SPI0_MOSI_M3, SPI0_MISO_M3),
 
 528     (1, SPI1_SCLK_M0, SPI1_MOSI_M0, SPI1_MISO_M0),
 
 529     (1, SPI1_SCLK_M1, SPI1_MOSI_M1, SPI1_MISO_M1),
 
 530     (1, SPI1_SCLK_M2, SPI1_MOSI_M2, SPI1_MISO_M2),
 
 531     (2, SPI2_SCLK_M0, SPI2_MOSI_M0, SPI2_MISO_M0),
 
 532     (2, SPI2_SCLK_M1, SPI2_MOSI_M1, SPI2_MISO_M1),
 
 533     (2, SPI2_SCLK_M2, SPI2_MOSI_M2, SPI2_MISO_M2),
 
 534     (3, SPI3_SCLK_M0, SPI3_MOSI_M0, SPI3_MISO_M0),
 
 535     (3, SPI3_SCLK_M1, SPI3_MOSI_M1, SPI3_MISO_M1),
 
 536     (3, SPI3_SCLK_M2, SPI3_MOSI_M2, SPI3_MISO_M2),
 
 537     (3, SPI3_SCLK_M3, SPI3_MOSI_M3, SPI3_MISO_M3),
 
 538     (4, SPI4_SCLK_M0, SPI4_MOSI_M0, SPI4_MISO_M0),
 
 539     (4, SPI4_SCLK_M1, SPI4_MOSI_M1, SPI4_MISO_M1),
 
 540     (4, SPI4_SCLK_M2, SPI4_MOSI_M2, SPI4_MISO_M2),
 
 553 PWM3_IR_M0 = GPIO0_D4
 
 554 PWM3_IR_M1 = GPIO3_B2
 
 555 PWM3_IR_M2 = GPIO1_C2
 
 556 PWM3_IR_M3 = GPIO1_A7
 
 569 PWM7_IR_M0 = GPIO0_D0
 
 570 PWM7_IR_M1 = GPIO4_D4
 
 571 PWM7_IR_M2 = GPIO1_C3
 
 572 PWM7_IR_M3 = GPIO4_C6
 
 586 PWM11_IR_M0 = GPIO3_A1
 
 587 PWM11_IR_M1 = GPIO4_B4
 
 588 PWM11_IR_M2 = GPIO1_C4
 
 589 PWM11_IR_M3 = GPIO3_D5
 
 590 PWM11_M0 = PWM11_IR_M0
 
 591 PWM11_M1 = PWM11_IR_M1
 
 592 PWM11_M2 = PWM11_IR_M2
 
 593 PWM11_M3 = PWM11_IR_M3
 
 602 PWM15_IR_M0 = GPIO3_C3
 
 603 PWM15_IR_M1 = GPIO4_B3
 
 604 PWM15_IR_M2 = GPIO1_C6
 
 605 PWM15_IR_M3 = GPIO1_D7
 
 606 PWM15_M0 = PWM15_IR_M0
 
 607 PWM15_M1 = PWM15_IR_M1
 
 608 PWM15_M2 = PWM15_IR_M2
 
 609 PWM15_M3 = PWM15_IR_M3
 
 612 # SysFS pwm outputs, pwm channel and pin in first tuple
 
 623     ((0, 3), PWM3_IR_M0),
 
 624     ((0, 3), PWM3_IR_M1),
 
 625     ((0, 3), PWM3_IR_M2),
 
 626     ((0, 3), PWM3_IR_M3),
 
 635     ((0, 7), PWM7_IR_M0),
 
 636     ((0, 7), PWM7_IR_M1),
 
 637     ((0, 7), PWM7_IR_M2),
 
 638     ((0, 7), PWM7_IR_M3),
 
 648     ((0, 11), PWM11_IR_M0),
 
 649     ((0, 11), PWM11_IR_M1),
 
 650     ((0, 11), PWM11_IR_M2),
 
 651     ((0, 11), PWM11_IR_M3),
 
 660     ((0, 15), PWM15_IR_M0),
 
 661     ((0, 15), PWM15_IR_M1),
 
 662     ((0, 15), PWM15_IR_M3),
 
 665 # SysFS analog inputs, Ordered as analog analogInId, device, and channel