|                                  | ADDRESS                                | OFFSET                  | NAME                                                                                                                                                  | VALUE                                  | Notes                                                                                                                                                                                 |
|----------------------------------|----------------------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BASE                             | 0x50200000                             | UFFSET                  | PIO0 BASE                                                                                                                                             | VALUE                                  | Init PIO0                                                                                                                                                                             |
| CTRL                             | 0x50200000                             | 0x000                   | CLKDIV_RESTART<br>SM_RESRART<br>SM_ENABLE<br>TXEMPTY                                                                                                  | 0x00000001                             | PIO control register PIO = 0 SM = 0                                                                                                                                                   |
| FSTAT                            | 0x50200004                             | 0x004                   | TXFULL<br>RXEMPTY<br>RXFULL                                                                                                                           | 0x0f000f01                             | FIFO status register Tx FIFO is empty Rx FIFO is empty                                                                                                                                |
| EDERILO                          | . 5000000                              |                         | TXSTALL<br>TXOVER<br>RXUNDER                                                                                                                          |                                        |                                                                                                                                                                                       |
| FDEBUG                           | 0x50200008                             | 0x008                   | RXSTALL RX3 TX3 RX2 TX2 RX1 TX1                                                                                                                       | 0x00000000                             | FIFO lovel                                                                                                                                                                            |
| FLEVEL                           | 0x5020000c                             | 0x00c                   | RX0<br>TX0                                                                                                                                            | 0x00000000                             | FIFO level Init RX and TX                                                                                                                                                             |
| TXF0<br>TXF1                     | 0x50200010<br>0x50200014               | 0x010<br>0x014          | TXF0<br>TXF1                                                                                                                                          | 0x00000000<br>0x00000000               | TX FIFO for SM0 TX FIFO for SM1                                                                                                                                                       |
| TXF2<br>TXF3                     | 0x50200018<br>0x5020001c               | 0x018<br>0x01c          | TXF2<br>TXF3                                                                                                                                          | 0x00000000<br>0x00000000               | TX FIFO for SM2 TX FIFO for SM3                                                                                                                                                       |
| RXF0<br>RXF1                     | 0x50200020<br>0x50200024               | 0x020<br>0x024          | RXF0<br>RXF1                                                                                                                                          | 0x00c8a2c8<br>0x00c8a2c8               | 32 bits GRB color 32 bits GRB color                                                                                                                                                   |
| RXF2<br>RXF3                     | 0x50200028<br>0x5020002c               | 0x028<br>0x02c          | RXF2<br>RXF3                                                                                                                                          | 0x00c8a2c8<br>0x00c8a2c8               | 32 bits GRB color 32 bits GRB color                                                                                                                                                   |
|                                  |                                        |                         |                                                                                                                                                       |                                        | Write-only                                                                                                                                                                            |
| INSTR_MEM0 INSTR_MEMn            | 0x50200030                             | 0x030<br>               | INSTR_MEM0 INSTR_MEMn                                                                                                                                 | 0x00000000                             | Reset state  Mem0-Mem31 = 0  Write-only                                                                                                                                               |
| INSTR_MEM31                      | 0x502000c4                             | 0x0c4                   | INSTR_MEM31                                                                                                                                           | 0x00000000                             | Reset state Clock divisor register for state machine 0                                                                                                                                |
| SM0_CLKDIV                       | 0x502000c8                             | 0x0c8                   | EXEC_STALLED SIDE_EN SIDE_PINDIR JMP_PIN OUT_EN_SEL INLINE_OUT_EN OUT_STICKY WRAP_TOP                                                                 | 0x000fa000                             | Frequency = clock freq / (CLKDIV_INT + CLKDIV_FRAC / 256)                                                                                                                             |
| SM0_EXECCTRL                     | 0x502000cc                             | 0x0cc                   | WRAP_BOTTOM<br>STATUS_SEL<br>STATUS_N<br>FJOIN_RX<br>FJION_TX<br>PULL_THRESH<br>PUSH_THRESH<br>OUT_SHIFTDIR                                           | 0x00017a00                             | Execution/behavioural settings for state machine 0                                                                                                                                    |
| SM0_SHIFTCRTL SM0_ADDR SM0_INSTR | 0x502000d0<br>0x502000d4<br>0x502000d8 | 0x0d0<br>0x0d4<br>0x0d8 | IN_SHIFTDIR<br>AUTOPULL<br>AUTOPUSH                                                                                                                   | 0x40060000<br>0x00000014<br>0x00006221 | Control behaviour of the input/output shift registers for state machine 0  Current instruction address for state machine 0  Read the instruction currently addressed by state machine |
|                                  |                                        |                         | SIDESET_COUNT SET_COUNT OUT_COUNT IN_BASE SIDESET_BASE SET_BASE                                                                                       |                                        |                                                                                                                                                                                       |
| SM0_PINCTRL                      | 0x502000dc                             | 0x0dc                   | OUT_BASE                                                                                                                                              | 0x20003000                             | State machine pin control 0  Clock divisor register for state machine 1                                                                                                               |
| SM1_CLKDIV                       | 0x50200000                             | 0x0e0                   | FRAV                                                                                                                                                  | 0x00010000                             | Frequency = clock freq / (CLKDIV_INT + CLKDIV_FRAC / 256)                                                                                                                             |
| SM1_EXECCTRL                     | 0x5020000                              | 0x0e4                   | JMP_PIN OUT_EN_SEL INLINE_OUT_EN OUT_STICKY WRAP_TOP WRAP_BOTTOM STATUS_SEL STATUS_N  FJOIN_RX FJION_TX PULL_THRESH OUT_SHIFTDIR IN_SHIFTDIR AUTOPULL | 0x0001f000                             | Execution/behavioural settings for state machine 1                                                                                                                                    |
| SM1_SHIFTCTRL                    | 0x50200000                             | 0x0e8                   | AUTOPUSH                                                                                                                                              | 0x000c000                              | Control behaviour of the input/output shift registers for state machine 1                                                                                                             |
| SM1_ADDR<br>SM1_INSTR            | 0x50200ec<br>0x50200f0                 | 0x0ec<br>0x0f0          | SM1_ADDR SM1_INSTR SIDESET_COUNT SET_COUNT OUT_COUNT IN_BASE SIDESET_BASE SET_BASE                                                                    | 0x0000000<br>0x0000fcfe                | Current instruction address for state machine 1  Read the instruction currently addressed by state machine                                                                            |
| SM1_PINCTRL                      | 0x50200f4                              | 0x0f4                   | OUT_BASE<br>INT                                                                                                                                       | 0x00000000                             | State machine pin control 0  Clock divisor register for state machine 2                                                                                                               |
| SM2_CLKDIV  SM2_EXECCTRL         | 0x50200f8                              | 0x0f8                   | EXEC_STALLED SIDE_EN SIDE_PINDIR JMP_PIN OUT_EN_SEL INLINE_OUT_EN OUT_STICKY WRAP_TOP WRAP_BOTTOM STATUS_SEL STATUS_N                                 | 0x00010000                             | Frequency = clock freq / (CLKDIV_INT + CLKDIV_FRAC / 256)  Execution/behavioural settings for state machine 2                                                                         |
|                                  | 0x5020100                              | 0x100                   | FJOIN_RX FJION_TX PULL_THRESH PUSH_THRESH OUT_SHIFTDIR IN_SHIFTDIR AUTOPULL AUTOPUSH                                                                  | 0x000c0000                             | Control behaviour of the input/output shift registers for state machine 2                                                                                                             |
| SM2_SHIFTCTRL SM2_ADDR SM2_INSTR | 0x5020100<br>0x5020104<br>0x5020108    | 0x104<br>0x108          | SM2_ADDR SM2_INSTR SIDESET_COUNT SET_COUNT OUT_COUNT IN_BASE SIDESET_BASE SET_BASE                                                                    | 0x00000000<br>0x00000000<br>0x0000fcfe | Current instruction address for state machine 2 Read the instruction currently addressed by state machine                                                                             |
| SM2_PINCTRL                      | 0x502010c                              | 0x10c                   | OUT_BASE                                                                                                                                              | 0x14000000                             | State machine pin control 2                                                                                                                                                           |
| SM3_CLKDIV                       | 0x5020110                              | 0x110                   | INT FRAV  EXEC_STALLED SIDE_EN SIDE_PINDIR JMP_PIN OUT_EN_SEL INLINE_OUT_EN OUT_STICKY WRAP_TOP WRAP_BOTTOM                                           | 0x00010000                             | Clock divisor register for state machine 3 Frequency = clock freq / (CLKDIV_INT + CLKDIV_FRAC / 256)                                                                                  |
| SM3_EXECCTRL                     | 0x50200114                             | 0x114                   | STATUS_SEL<br>STATUS_N                                                                                                                                | 0x0001f000                             | Execution/behavioural settings for state machine 3                                                                                                                                    |
| SM3_SHIFTCTRL                    | 0x50200118                             | 0x118                   | FJOIN_RX FJION_TX PULL_THRESH PUSH_THRESH OUT_SHIFTDIR IN_SHIFTDIR AUTOPULL AUTOPUSH                                                                  | 0x000c0000                             | Control behaviour of the input/output shift registers for state machine 3                                                                                                             |
| SM3_ADDR<br>SM3_INSTR            | 0x5020011c<br>0x50200120               | 0x11c<br>0x120          | SM3_ADDR SM3_INSTR SIDESET_COUNT SET_COUNT OUT_COUNT IN_BASE SIDESET_BASE SET_BASE                                                                    | 0x00000000<br>0x0000fcfe               | Current instruction address for state machine 3 Read the instruction currently addressed by state machine                                                                             |
| SM3_PINCTRL                      | 0x50200124                             | 0x124                   | OUT_BASE                                                                                                                                              | 0x14000000                             | State machine pin control 3                                                                                                                                                           |